:root {
  --color-navy-navy-50: #E6EAEE;
  --color-navy-navy-100: #CCD4DE;
  --color-navy-navy-new-200: #99A9BC;
  --color-navy-navy-300: #667E9B;
  --color-navy-navy-400: #335379;
  --color-slate-400: #99A1AF;
 --color-dark-blue:#004C9D;
  --color-gray-200: #e5e7eb;
}

/* Theme base styles */

/* Generic */

*, *:before, *:after {
  box-sizing: border-box;
}
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers.
 */

body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */

main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */

img {
  border-style: none;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

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

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Misc
   ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */

template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */

[hidden] {
  display: none;
}

/* Objects */

/* Responsive grid */

.row-fluid {
    width: 100%;
    *zoom: 1;
}

.row-fluid:before, .row-fluid:after {
    display: table;
    content: "";
}

.row-fluid:after {
    clear: both;
}

.row-fluid [class*="span"] {
    display: block;
    float: left;
    width: 100%;
    min-height: 1px;
    margin-left: 2.127659574%;
    *margin-left: 2.0744680846382977%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

.row-fluid [class*="span"]:first-child {
    margin-left: 0;
}

.row-fluid .span12 {
    width: 99.99999998999999%;
    *width: 99.94680850063828%;
}

.row-fluid .span11 {
    width: 91.489361693%;
    *width: 91.4361702036383%;
}

.row-fluid .span10 {
    width: 82.97872339599999%;
    *width: 82.92553190663828%;
}

.row-fluid .span9 {
    width: 74.468085099%;
    *width: 74.4148936096383%;
}

.row-fluid .span8 {
    width: 65.95744680199999%;
    *width: 65.90425531263828%;
}

.row-fluid .span7 {
    width: 57.446808505%;
    *width: 57.3936170156383%;
}

.row-fluid .span6 {
    width: 48.93617020799999%;
    *width: 48.88297871863829%;
}

.row-fluid .span5 {
    width: 40.425531911%;
    *width: 40.3723404216383%;
}

.row-fluid .span4 {
    width: 31.914893614%;
    *width: 31.8617021246383%;
}

.row-fluid .span3 {
    width: 23.404255317%;
    *width: 23.3510638276383%;
}

.row-fluid .span2 {
    width: 14.89361702%;
    *width: 14.8404255306383%;
}

.row-fluid .span1 {
    width: 6.382978723%;
    *width: 6.329787233638298%;
}

.container-fluid {
    *zoom: 1;
}

.container-fluid:before, .container-fluid:after {
    display: table;
    content: "";
}

.container-fluid:after {
    clear: both;
}

@media (max-width: 767px) {
    .row-fluid {
        width: 100%;
    }

    .row-fluid [class*="span"] {
        display: block;
        float: none;
        width: auto;
        margin-left: 0;
    }
}

@media (min-width: 768px) and (max-width: 1139px) {
    .row-fluid {
        width: 100%;
        *zoom: 1;
    }

    .row-fluid:before, .row-fluid:after {
        display: table;
        content: "";
    }

    .row-fluid:after {
        clear: both;
    }

    .row-fluid [class*="span"] {
        display: block;
        float: left;
        width: 100%;
        min-height: 1px;
        margin-left: 2.762430939%;
        *margin-left: 2.709239449638298%;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        -ms-box-sizing: border-box;
        box-sizing: border-box;
    }

    .row-fluid [class*="span"]:first-child {
        margin-left: 0;
    }

    .row-fluid .span12 {
        width: 99.999999993%;
        *width: 99.9468085036383%;
    }

    .row-fluid .span11 {
        width: 91.436464082%;
        *width: 91.38327259263829%;
    }

    .row-fluid .span10 {
        width: 82.87292817100001%;
        *width: 82.8197366816383%;
    }

    .row-fluid .span9 {
        width: 74.30939226%;
        *width: 74.25620077063829%;
    }

    .row-fluid .span8 {
        width: 65.74585634900001%;
        *width: 65.6926648596383%;
    }

    .row-fluid .span7 {
        width: 57.182320438000005%;
        *width: 57.129128948638304%;
    }

    .row-fluid .span6 {
        width: 48.618784527%;
        *width: 48.5655930376383%;
    }

    .row-fluid .span5 {
        width: 40.055248616%;
        *width: 40.0020571266383%;
    }

    .row-fluid .span4 {
        width: 31.491712705%;
        *width: 31.4385212156383%;
    }

    .row-fluid .span3 {
        width: 22.928176794%;
        *width: 22.874985304638297%;
    }

    .row-fluid .span2 {
        width: 14.364640883%;
        *width: 14.311449393638298%;
    }

    .row-fluid .span1 {
        width: 5.801104972%;
        *width: 5.747913482638298%;
    }
}

@media (min-width: 1280px) {
    .row-fluid {
        width: 100%;
        *zoom: 1;
    }

    .row-fluid:before, .row-fluid:after {
        display: table;
        content: "";
    }

    .row-fluid:after {
        clear: both;
    }

    .row-fluid [class*="span"] {
        display: block;
        float: left;
        width: 100%;
        min-height: 1px;
        margin-left: 2.564102564%;
        *margin-left: 2.510911074638298%;
        -webkit-box-sizing: border-box;
        -moz-box-sizing: border-box;
        -ms-box-sizing: border-box;
        box-sizing: border-box;
    }

    .row-fluid [class*="span"]:first-child {
        margin-left: 0;
    }

    .row-fluid .span12 {
        width: 100%;
        *width: 99.94680851063829%;
    }

    .row-fluid .span11 {
        width: 91.45299145300001%;
        *width: 91.3997999636383%;
    }

    .row-fluid .span10 {
        width: 82.905982906%;
        *width: 82.8527914166383%;
    }

    .row-fluid .span9 {
        width: 74.358974359%;
        *width: 74.30578286963829%;
    }

    .row-fluid .span8 {
        width: 65.81196581200001%;
        *width: 65.7587743226383%;
    }

    .row-fluid .span7 {
        width: 57.264957265%;
        *width: 57.2117657756383%;
    }

    .row-fluid .span6 {
        width: 48.717948718%;
        *width: 48.6647572286383%;
    }

    .row-fluid .span5 {
        width: 40.170940171000005%;
        *width: 40.117748681638304%;
    }

    .row-fluid .span4 {
        width: 31.623931624%;
        *width: 31.5707401346383%;
    }

    .row-fluid .span3 {
        width: 23.076923077%;
        *width: 23.0237315876383%;
    }

    .row-fluid .span2 {
        width: 14.529914530000001%;
        *width: 14.4767230406383%;
    }

    .row-fluid .span1 {
        width: 5.982905983%;
        *width: 5.929714493638298%;
    }
}

/* Clearfix */

.clearfix {
    *zoom: 1;
}

.clearfix:before, .clearfix:after {
    display: table;
    content: "";
}

.clearfix:after {
    clear: both;
}

/* Visibilty Classes */

.hide {
    display: none;
}

.show {
    display: block;
}

.invisible {
    visibility: hidden;
}

.hidden {
    display: none;
    visibility: hidden;
}

/* Responsive Visibilty Classes */

.visible-phone {
    display: none !important;
}

.visible-tablet {
    display: none !important;
}

.hidden-desktop {
    display: none !important;
}

@media (max-width: 767px) {
    .visible-phone {
        display: inherit !important;
    }

    .hidden-phone {
        display: none !important;
    }

    .hidden-desktop {
        display: inherit !important;
    }

    .visible-desktop {
        display: none !important;
    }
}

@media (min-width: 768px) and (max-width: 1139px) {
    .visible-tablet {
        display: inherit !important;
    }

    .hidden-tablet {
        display: none !important;
    }

    .hidden-desktop {
        display: inherit !important;
    }

    .visible-desktop {
        display: none !important ;
    }
}
/* Content wrappers for blog post and system templates */

.content-wrapper {
  padding: 0 20px;
  margin: 0 auto;
}

/* Drag and drop layout styles */

.dnd-section > .row-fluid {
  margin: 0 auto;
}

@media (max-width: 767px) {
  .dnd-section .dnd-column {
    padding: 0;
  }
}

/* Elements */

body {
  line-height: 1.4;
  overflow-wrap: break-word;
}

html[lang^='ja'] body,
html[lang^='zh'] body,
html[lang^='ko'] body {
  line-break: strict;
  overflow-wrap: normal;
  word-break: break-all;
}

/* Paragraphs */

p {
  margin: 0 0 1.4rem;
  font-size: 1rem;
}

/* Anchors */

a {
  cursor: pointer;
}

/* Headings */

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0 0 1.4rem;
}

/* Lists */

ul,
ol {
  padding-left: 1rem;
  margin: 0 0 1.4rem;
}

ul li,
ol li {
  margin: 0.7rem;
}

ul ul,
ol ul,
ul ol,
ol ol {
  margin: 1.4rem 0;
}

.no-list {
  padding-left: 0;
  margin: 0;
  list-style: none;
}

.no-list li {
  margin: 0;
}

/* Code blocks */

pre {
  overflow: auto;
}

code {
  vertical-align: bottom;
}

/* Blockquotes */

blockquote {
  padding: 20px 10px 10px 16px;
  border-left: 4px solid;
  margin: 0 0 1.4rem;
}



/* Horizontal rules */

hr {
  border: 0 none;
  border-bottom: 1px solid;
}

/* Subscripts and superscripts */

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

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Image alt text */

img {
  font-size: 1rem;
  word-break: normal;
}
/* Primary button */

button,
.button,
.hs-button {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  text-align: center;
  transition: color 0.15s linear;
  white-space: normal;
}

/* Simple button */

.button.button--simple {
  position: relative;
  padding: 0;
  border: none;
  border-radius: 0;
  background-color: transparent;
}

.button.button--simple:hover,
.button.button--simple:focus {
  border: none;
  background-color: transparent;
}

/* Disabled button */

button:disabled,
.button:disabled,
.hs-button:disabled {
  border-color: #f1f1f1;
  background-color: #f1f1f1;
  pointer-events: none;
}

button:disabled,
.button:disabled,
.button.button--secondary:disabled,
.button.button--simple:disabled {
  color: #d0d0d0;
}

/* No button */

.no-button,
.no-button:hover,
.no-button:focus,
.no-button:active {
  padding: 0;
  border: none;
  border-radius: 0;
  margin-bottom: 0;
  background: none;
  color: initial;
  font-family: inherit;
  font-size: inherit;
  font-style: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  text-align: left;
  text-decoration: none;
  transition: none;
}

/* Button icons */

.button .button__icon svg {
  display: block;
/*   height: 1.25rem; */
/*   margin-right: 1rem; */
  fill: inherit;
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .button .button__icon svg {
    width: 1.25rem;
  }
}

.button--icon-right .button__icon {
  order: 1;
}

.button--icon-right .button__icon svg {
  margin-right: 0;
/*   margin-left: 1rem; */
}
/* .hs_cos_wrapper_type_form{
  box-shadow: 0 2px 10px 0 rgba(151, 153, 155, 0.35);
} */

/** to change to different color- change %23515D69 to 515D69 hex color ****/
form select{
  background-image: url('data:image/svg+xml,<svg width="18" height="19" viewBox="0 0 18 19" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M15.4287 6.28613L9.00014 12.7147L2.57157 6.28613" stroke="%230D244A" stroke-width="2" stroke-linecap="round"/></svg>');
}
form .hs-dateinput:before {
  background-image: url('data:image/svg+xml,<svg width="18" height="19" viewBox="0 0 18 19" fill="none" xmlns="http://www.w3.org/2000/svg"><rect x="0.818359" y="1.31836" width="16.3636" height="3.27273" fill="%230D244A"/><rect x="0.5" y="1" width="17" height="17" rx="1.5" stroke="%230D244A"/><rect x="3.70249" y="13.8163" width="0.859092" height="0.85909" stroke="%230D244A" stroke-width="0.85909"/><rect x="6.97496" y="7.47544" width="0.859091" height="0.859091" stroke="%230D244A" stroke-width="0.859091"/><rect x="6.97496" y="10.7479" width="0.859091" height="0.85909" stroke="%230D244A" stroke-width="0.85909"/><rect x="3.70249" y="10.7479" width="0.859092" height="0.85909" stroke="%230D244A" stroke-width="0.85909"/><rect x="6.97496" y="13.8163" width="0.859091" height="0.85909" stroke="%230D244A" stroke-width="0.85909"/><rect x="10.2479" y="7.47544" width="0.85909" height="0.859091" stroke="%230D244A" stroke-width="0.85909"/><rect x="13.5204" y="7.47544" width="0.85909" height="0.859091" stroke="%230D244A" stroke-width="0.85909"/><rect x="10.2479" y="10.7479" width="0.85909" height="0.85909" stroke="%230D244A" stroke-width="0.85909"/><rect x="13.5204" y="10.7479" width="0.859091" height="0.85909" stroke="%230D244A" stroke-width="0.85909"/><rect x="10.2479" y="13.8163" width="0.85909" height="0.859091" stroke="%230D244A" stroke-width="0.85909"/></svg>');
}
/** to change to different color- change fill 515D69 to different hex color ****/
.hs-fieldtype-number .input::before {
  background-image: url('data:image/svg+xml,<svg width="14" height="11" viewBox="0 0 14 11" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0.960801 10.5L7.0058 0.0449996L13.0358 10.5H0.960801Z" fill="%230D244A"/></svg>');
}
.hs-fieldtype-number .input::after {
  background-image: url('data:image/svg+xml,<svg width="13" height="11" viewBox="0 0 13 11" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M6.5058 10.5L0.460801 0.0449996H12.5358L6.5058 10.5Z" fill="%230D244A"/></svg>');
}

form .inputs-list.multi-container span {
  font-weight: 300;
}

.custom-dropdown select {
  background-image: url('data:image/svg+xml,<svg width="18" height="19" viewBox="0 0 18 19" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M15.4287 6.28613L9.00014 12.7147L2.57157 6.28613" stroke="%230D244A" stroke-width="2" stroke-linecap="round"/></svg>');
  display: inline-block;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background-position: right 12px center;
  background-repeat: no-repeat;
  background-size: 18px;
  outline: none;
  border-radius: 4px;
  border: 1px solid #D0D9C4;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.08);
  padding: 10px 40px 10px 10px;
  width: 100%;
}

input[type="radio"]:checked,
input[type="checkbox"]:checked{
  background: #008CCF !important;
  border: 1px solid  #008CCF !important;
}
input[type="radio"],
input[type="checkbox"] {
  border: 1px solid #C6C2C2;
}


.form-title {
  margin-top: 0;
  margin-bottom: 0 !important; 
  text-transform: unset;
}

#hs_cos_wrapper_dnd_area-dnd_partial-3-module-7,
#hs_cos_wrapper_dnd_area-dnd_partial-2-module-8{
  background: white;
}

.hs_cos_wrapper_type_form {
  display: block;
  border-radius: 0px;
}

.form-title ~ div > form {
  border-top: none;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

/* Labels */

form label {
  display: block;
  letter-spacing: 0.2px;
}

/* Form fields */

form .hs-form-field {
  margin-bottom: 16px;
}

form input[type='text'],
form input[type='email'],
form input[type='password'],
form input[type='tel'],
form input[type='number'],
form input[type='search'],
form input[type='date'],
form select,
form textarea {
  display: inline-block;
  height: 40px;
  width: 100% !important;
}

form fieldset {
  max-width: 100% !important;
}

form input[type='text']:focus,
form input[type='email']:focus,
form input[type='password']:focus,
form input[type='tel']:focus,
form input[type='number']:focus,
form input[type='file']:focus,
form input[type='search']:focus,
form input[type='date']:focus,
form select:focus,
form textarea:focus{
  outline: none;
}
form select{
  font-weight: 400 !important;
}

form input::-webkit-input-placeholder,
form select::-webkit-input-placeholder,
form textarea::-webkit-input-placeholder{
  font-weight: 400;
}
form input::-moz-placeholder,
form select::-moz-placeholder,
form textarea::-moz-placeholder{
  font-weight: 400;
}
form input:-ms-input-placeholder,
form select:-ms-input-placeholder,
form textarea:-ms-input-placeholder{
  font-weight: 400;
} 

form select::-ms-expand {
  display: none;
}

form textarea {
  min-height: 100px;
}

form select{
  background-position: right 12px center;
  background-repeat: no-repeat;
  background-size: 18px;
  outline: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
}
form select option:disabled{
  opacity: 0.36;
}
form select:invalid{
  color: #C6C2C2;
  font-weight: 300 !important;
}

/* Form fields - checkbox/radio */

form .inputs-list {
  padding: 0;
  margin: 0;
  list-style: none;
}

form .inputs-list > li {
  display: block;
  margin: 0.7rem 0;
}

form .inputs-list input,
form .inputs-list span {
  vertical-align: middle;
}

:root {
  --form-control-color: #FFFFFF;
}

input[type="radio"],
input[type="checkbox"] {
  display: grid;
  /* Add if not using autoprefixer */
  -webkit-appearance: none;

  /* For iOS < 15 to remove gradient background */
  background-color: var(--form-control-color);

  /* Not removed via appearance */  
  appearance: none;
  background-color: #fff;
  color: inherit;
  font: inherit;
  width: 18px !important;
  height: 18px;
  margin: 0 10px 0 0;
  transform: translateY(0.2em);
  place-content: center;
  cursor: pointer;
}
.hs-form-booleancheckbox-display, 
.hs-form-checkbox-display, 
.hs-form-radio-display {
  display: grid;
  gap: 0.7em;
  grid-template-columns: 1em auto;
}
input[type="radio"]{
  border-radius: 50%;
}
input[type="checkbox"]{
  border-radius: 2px;
  position: relative;
}
.hs-form-radio-display + .hs-form-radio-display,
.hs-form-checkbox-display + .hs-form-checkbox-display {
  margin-top: 1em;
}
input[type="checkbox"]::before {
  content: "";
  transform: scale(0);
  transition: 50ms transform ease-in-out;
}
input[type="radio"]::before{
  content: "";
  transform: scale(0);
  transition: 50ms transform ease-in-out;
  background: #fff;
}
input[type="radio"]::before{
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
input[type="checkbox"]:checked::before{
  border-bottom: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
  transform: rotate(45deg);
  -o-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  height: 10px;
  width: 5px;
  top: -2px;
  left: 1px;
  right: 0;
  bottom: 0;
  margin: auto;
}

input[type="radio"]:checked::before {
  transform: scale(1);
} 

/* Form fields - date picker */

form .hs-dateinput {
  position: relative;
}

/** to change to different color- change 515D69 to different hex color ****/

form .hs-dateinput:before {
  content:'';
  width: 18px;
  height: 19px;
  background-size: contain;
  position: absolute;
  right: 5%;
  top: 50%;
  transform: translateY(-50%);
}

form .fn-date-picker .pika-table th{
  color: #FFF !important;
  background-color: #004C9D;
}

form .pika-table tbody td.is-empty{
  background-color: transparent !important;
}

form .is-selected .pika-button {
  border-radius: 0px !important; /* stylelint-disable-line declaration-no-important */
  box-shadow: none !important; /* stylelint-disable-line declaration-no-important */
  text-align:center !important;
}

form .fn-date-picker .pika-button:hover,
form .fn-date-picker .pika-button:focus {
  border-radius: 0 !important; /* stylelint-disable-line declaration-no-important */
}

form .fn-date-picker .is-today .pika-button{
  color: #004C9D;
}

form .fn-date-picker .is-selected .pika-button,
form .fn-date-picker .pika-button:hover,
form .fn-date-picker .pika-button:focus{
  background: #004C9D !important;
}

/* Form fields - file picker */

form input[type=file] {
  border: 0 !important;
  background-color: transparent;
  border: initial;
  padding: initial;
}

form input[type=file]::file-selector-button {
  color: #004C9D;
  font-size: 14px;
  padding: 9px 12px 7px;
  border: 1px solid #004C9D;
  border-radius: 6px;
  background-color: transparent;
  display: block;
  margin-bottom: 15px;
}

.form__file-upload {
  background-color: transparent;
  padding: 10px 16px;
  margin: 0;
  border-radius: 6px;
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 700;
  line-height: 24px;
  color: #004C9D;
  font-family: Bison;
  font-size: 20px;
  font-style: italic;
  font-weight: 700;
  line-height: 130%; /* 26px */
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid #004C9D;
}
.form__file-upload:hover{
  border: 1px solid #2284B3;
  background-color:#2284B3;
  color: #ffffff;
}

.upload-file-text {
  font-size: 16px;
  color: #0D244A;
}

/* Numbur spin button */

.hs-fieldtype-number .input{
  position: relative;
}

.hs-fieldtype-number .input::before {
  position: absolute;
  top: 8px;
  content: "";
  height: 11px;
  background-size: cover;
  pointer-events: none;
  right: 15px;
  width: 13px;
}
.hs-fieldtype-number .input::after {
  position: absolute;
  content: "";
  pointer-events: none;
  background-size: cover;
  bottom: 8px;
  height: 10px;
  width: 12px;
  right: 15px;
}
.hs-quantity .input .hs-input::-webkit-inner-spin-button {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  transform: scale(5);
  transform-origin: right center;
  opacity: 0;
  cursor: pointer;
}

/* Headings and text */

form .hs-richtext,
form .hs-richtext p {
  font-size: 14px;
  margin-bottom: 15px;
}

form .hs-richtext h5{
  font-size: 16px;  
  font-weight: 400;
  color: #004C9D;
  margin-top: 10px;
}

form .hs-richtext img {
  height: auto;
  max-width: 100% !important; /* stylelint-disable-line declaration-no-important */
}

form .inputs-list>li{
  margin-top: 0;
  margin-bottom: 16px;
}
form .inputs-list>li:last-child{
  margin-bottom: 10px;
}


/* GDPR */

form .legal-consent-container{
  margin-bottom: 24px;
}

form .legal-consent-container .hs-form-booleancheckbox-display > span {
  margin-left: 0.5rem !important;
  font-weight: 400;
  line-height: 150%;
}

form .legal-consent-container .hs-form-booleancheckbox-display p{
  display: inline-block !important;
  font-size: 12px;
  line-height: 20px;
}

/* Validation */

form .hs-form-required {
  color: #ef6b51;
}

form .hs-input.error {
  border-color: #ef6b51;
}

form .hs-error-msg,
form .hs-error-msgs {
  margin-top: 0.35rem;
  color: #ef6b51;
  line-height: 16px;
  font-weight: 400;
}

form .input ul li label span{
  font-weight:300;
}

/* Captcha */

.grecaptcha-badge {
  margin: 0 auto;
}


/* Related to the merchent form  */

@media(max-width:1040px) {
  .form-container {
    padding: 25px 25px !important;
  }
}
@media(max-width:767px) {
  .form-container {
    padding: 20px 20px !important;
  }
}


.hsfc-FormWrapper .hsfc-Form .hsfc-FieldLabel > span {
  font-weight: bold !important;
}

.hsfc-Form .hsfc-NavigationRow {
  margin-top: 0px !important;
}
.hsfc-Form .hsfc-RichText {
  line-height: 1.5 !important;
}
.hsfc-Form .hsfc-RichText span {
  display: inline-block !important;
}
.hsfc-DataPrivacyField .hsfc-Row {
  margin-bottom: 10px !important;
}

.hsfc-Form .hsfc-RadioInput:checked:after,
.hsfc-Form .hsfc-CheckboxInput:checked:after{
  background-color: white !important;
}

.hsfc-Form .hsfc-NumberField>*:not(:last-child),
.hsfc-Form .hsfc-DateField>*:not(:last-child),
.hsfc-Form .hsfc-SelectField>*:not(:last-child),
.hsfc-Form .hsfc-DropdownField>*:not(:last-child),
.hsfc-Form .hsfc-TextareaField>*:not(:last-child),
.hsfc-Form .hsfc-PhoneField>*:not(:last-child),
.hsfc-Form .hsfc-RadioFieldGroup>*:not(:last-child),
.hsfc-Form .hsfc-hsfc-FileField>*:not(:last-child),
.hsfc-Form .hsfc-CheckboxFieldGroup>*:not(:last-child),
.hsfc-Form .hsfc-EmailField>*:not(:last-child),
.hsfc-Form .hsfc-TextField>*:not(:last-child),
.hsfc-Form .hsfc-FileField>*:not(:last-child){
  margin-bottom: 0px !important;
}

.hsfc-Form .hsfc-RadioFieldGroup__Options label span,
.hsfc-Form .hsfc-CheckboxFieldGroup__Options label span {
  font-weight: 400;
  line-height: 1.5;
}
.hsfc-Form .hsfc-FieldLabel span{
  font-size: 14px;
}
/* Icon wrapper */

.icon {
  display: inline-flex;
  border-radius: 50%;
}

.icon--square.icon--small .icon{
  border-radius: 8px;
}
.icon--square .icon {
  border-radius: 12px;
}
.icon--square.icon--large .icon{
  border-radius: 16px;
}

/* Icon */

.icon svg {
  vertical-align: middle;
}
/* Table */

table {
  border-collapse: collapse;
  margin-bottom: 1.4rem;
  overflow-wrap: break-word;
}

/* Table cells */

th,
td {
  padding: 0.7rem;
  vertical-align: top;
}

/* Table header */

thead th,
thead td {
  vertical-align: bottom;
}

/* Components */

/* Navigation skipper */

.header__skip {
  position: absolute;
  top: -1000px;
  left: -1000px;
  overflow: hidden;
  height: 1px;
  width: 1px;
  text-align: left;
}

.header__skip:hover,
.header__skip:focus,
.header__skip:active {
  z-index: 2;
  top: 0;
  left: 0;
  overflow: visible;
  height: auto;
  width: auto;
}
.header-wrapper .header__logo-link {
  display: block;
  padding: 0;
  margin: 0;
  line-height: 0;
  overflow: hidden;
}

@media(max-width: 767px) {
  .subscription-header img.hs-image-widget  {
    max-width: 160px !important;
    height: auto;
  }
}
.main-footer .hs-image-widget{
  margin-bottom: 0;
  line-height: 0;
}
.main-footer .span8{
  text-align: right;
}

.main-footer .hs-menu-wrapper ul{
  margin-top: 10px;
}
.main-footer .hs-menu-wrapper ul > li{
  font-size: 12px;
  margin-right: 10px;
}
.main-footer .hs-menu-wrapper ul > li a{
  color: #BBC9DF;
  text-decoration: none;
  border-right: 1px solid #FFFFFF;
  padding-right: 10px;
}
.main-footer .hs-menu-wrapper ul > li:last-child a{
  border-right: 0;
  padding-right: 0;
}

/* Footer DND sections */
.main-footer .social-links{
  justify-content: flex-end !important;
}

@media (max-width: 767px) {
  .main-footer{
    text-align: center;
  }
  .main-footer .span8{
    text-align: center;
  }
  .main-footer .hs-image-widget{
    margin-bottom: 15px;
  }
  .main-footer .hs-menu-wrapper ul>li{
    margin-right: 0;
    margin-bottom: 5px;
  }
  .main-footer .hs-menu-wrapper ul>li a{
    border-right: 0;
    padding-right: 0;
  }
  .main-footer .social-links{
    margin: 30px auto 0;
    justify-content: center !important;
  }
}
/* Card */

.card {
  border: 0;
}

.card--dark,
.card--light {
/*   padding: 1.4rem; */
}
/* Blog listing */

.blog-listing {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.blog-listing--3-col,
.blog-listing--4-col {
  justify-content: flex-start;
}

/* Section heading */

.blog-listing__heading {
  width: 100%;
  text-align: center;
}

/* Article */

.blog-listing__post {
  display: flex;
  width: 100%;
  padding: 0;
  margin-bottom: 2.8rem;
  flex-direction: column;
}

.blog-listing__post-inner-wrapper {
  display: flex;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.4);
}

/* Featured image */

.blog-listing__post-image-wrapper {
  display: flex;
}

.blog-listing__post-image {
  height: auto;
  width: 100%;
}

/* Content */

.blog-listing__post-content {
  display: flex;
  padding: 0.7rem 0 0;
  flex-direction: column;
  flex-grow: 1;
}

.card--dark .blog-listing__post-content,
.card--light .blog-listing__post-content {
  padding: 1.4rem;
}

/* Heading */

.blog-listing__header {
  margin-bottom: 1.05rem;
}

/* Tags */

/* .blog-listing__post-tags {
  margin-bottom: 0.7rem;
} */

.blog-listing__post-tag,
.blog-listing__post-tag:hover,
.blog-listing__post-tag:focus,
.blog-listing__post-tag:active {
  text-decoration: none;
}

/* Title */

.blog-listing__post-title {
  margin-bottom: 0.7rem;
}

/* Author */

.blog-listing__post-author {
  display: flex;
  margin-bottom: 0.7rem;
  align-items: center;
}

.blog-listing__post-author-image {
  height: auto;
  width: 50px;
  margin-right: 0.7rem;
}

.blog-listing__post-author-name,
.blog-listing__post-author-name:hover,
.blog-listing__post-author-name:focus,
.blog-listing__post-author-name:active {
  text-decoration: none;
}

/* Date */

.blog-listing__post-timestamp {
  display: block;
}

/* Button */

.blog-listing__post-button-wrapper {
  margin-top: auto;
}

/* Blog listing - basic grid */

.blog-listing--card .blog-listing__post {
  flex-direction: column;
}

.blog-listing--2-col .blog-listing__post {
  width: calc(50% - 1rem);
}

.blog-listing--3-col .blog-listing__post {
  width: calc(33.3% - 1rem);
}

.blog-listing--4-col .blog-listing__post {
  width: calc(25% - 1rem);
}

.blog-listing--3-col .blog-listing__post:nth-of-type(3n + 1),
.blog-listing--3-col .blog-listing__post:nth-of-type(3n + 2) {
  margin-right: 1.5rem;
}

.blog-listing--4-col .blog-listing__post:nth-of-type(4n + 1),
.blog-listing--4-col .blog-listing__post:nth-of-type(4n + 2),
.blog-listing--4-col .blog-listing__post:nth-of-type(4n + 3) {
  margin-right: 1.333rem;
}

@media (max-width: 767px) {
  .blog-listing .blog-listing__post {
    width: 100%;
    margin-right: 0 !important; /* stylelint-disable-line declaration-no-important */
  }
}

.blog-listing--card .blog-listing__post-image-wrapper {
  height: 200px;
}

.blog-listing--card .blog-listing__post-image {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .blog-listing--card .blog-listing__post-image-wrapper,
  .blog-listing--card .blog-listing__post-image {
    height: auto;
  }
}

/* Blog listing - side by side */

/* stylelint-disable no-descending-specificity */
.blog-listing--list .blog-listing__post {
  display: flex;
}
/* stylelint-enable no-descending-specificity */

.blog-listing--list .blog-listing__post-image-wrapper {
  width: 100%;
}

.blog-listing--list .blog-listing__post-image {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .blog-listing--list .blog-listing__post-image-wrapper,
  .blog-listing--list .blog-listing__post-image {
    height: auto;
  }
}

@media (min-width: 768px) {
  .blog-post-listing__post--list {
    flex-direction: row;
  }

  .blog-listing__post-content--list {
    order: 1;
  }

  .blog-post-listing__post-image-wrapper--list {
    order: 1;
  }

  .blog-post-listing__post-image-wrapper--right {
    order: 2;
  }

  .blog-listing--list .blog-listing__post-image-wrapper {
    width: 25%;
  }

  .blog-listing--list .blog-post-listing__post-image-wrapper--left {
    margin-right: 1.4rem;
  }

  .blog-listing--list .blog-post-listing__post-image-wrapper--right {
    margin-left: 1.4rem;
  }
}
/* Logo */

.widget-type-logo img {
  height: auto;
  max-width: 100%;
  margin-bottom: 1.4rem;
}

/* Menu and simple menu */

.hs-menu-wrapper ul {
  display: flex;
  padding-left: 0;
  margin: 0;
  flex-wrap: wrap;
  justify-content: flex-start;
  list-style: none;
}

.hs-menu-wrapper li {
  margin: 0;
}

@media (max-width: 767px) {
  .hs-menu-wrapper li {
    margin-bottom: 1.4rem;
    text-align: center;
  }
}

/* Horizontal menu */

.hs-menu-wrapper.hs-menu-flow-horizontal .hs-menu-children-wrapper {
  flex-direction: column;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.hs-menu-flow-horizontal ul {
    flex-direction: column;
  }
}

/* Vertical menu */

.hs-menu-wrapper.hs-menu-flow-vertical ul {
  flex-direction: column;
}

/* Flyouts */

.hs-menu-wrapper.hs-menu-flow-vertical.flyouts ul {
  display: inline-flex;
}

@media (max-width: 767px) {
  .hs-menu-wrapper.hs-menu-flow-vertical ul {
    display: flex;
  }
}

.hs-menu-wrapper.flyouts .hs-item-has-children {
  position: relative;
}

.hs-menu-wrapper.flyouts .hs-menu-children-wrapper {
  position: absolute;
  left: -9999px;
  opacity: 0;
}

.hs-menu-wrapper.flyouts .hs-menu-children-wrapper a {
  display: block;
  white-space: nowrap;
}

/* prettier-ignore */
.hs-menu-wrapper.hs-menu-flow-horizontal.flyouts
.hs-item-has-children:hover
> .hs-menu-children-wrapper {
  top: 100%;
  left: 0;
  opacity: 1;
}

/* prettier-ignore */
.hs-menu-wrapper.hs-menu-flow-vertical.flyouts
.hs-item-has-children:hover
> .hs-menu-children-wrapper {
  top: 0;
  left: 100%;
  opacity: 1;
}

@media (max-width: 767px) {
  /* prettier-ignore */
  .hs-menu-wrapper.flyouts .hs-menu-children-wrapper,
  .hs-menu-wrapper.hs-menu-flow-horizontal.flyouts
  .hs-item-has-children:hover
  > .hs-menu-children-wrapper,
  .hs-menu-wrapper.hs-menu-flow-vertical.flyouts
  .hs-item-has-children:hover
  > .hs-menu-children-wrapper {
    position: relative;
    top: auto;
    left: 0;
    opacity: 1;
  }
}

/* Rich text */

.widget-type-rich_text img {
  height: auto;
  max-width: 100%;
}

/* Utilities */

/* For content that needs to be visually hidden but stay visible for screenreaders */

/* stylelint-disable declaration-no-important */
.show-for-sr {
  position: absolute !important;
  overflow: hidden !important;
  height: 1px !important;
  width: 1px !important;
  padding: 0 !important;
  border: 0 !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
}

@media (max-width: 767px) {
  .show-for-sr--mobile {
    position: absolute !important;
    overflow: hidden !important;
    height: 1px !important;
    width: 1px !important;
    padding: 0 !important;
    border: 0 !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
  }
}
/* stylelint-enable declaration-no-important */

/* ============================================================
   LAYOUT REFERENCE — Flexbox · Grid · Position · Typography
   ============================================================ */

/* ─── 0. FONT WEIGHT ─────────────────────────────────────────
   ──────────────────────────────────────────────────────────── */

.font-thin {
  font-weight: 100;
} /* Thin */
.font-extralight {
  font-weight: 200;
} /* Extra Light */
.font-light {
  font-weight: 300;
} /* Light */
.font-normal {
  font-weight: 400;
} /* Regular — body text default */
.font-medium {
  font-weight: 500;
} /* Medium */
.active\:font-medium:active,
.focus\:font-medium:focus,
.hover\:font-medium:hover {
  font-weight: 500;
}
.font-semibold {
  font-weight: 600;
} /* Semi Bold */
.font-bold {
  font-weight: 700;
} /* Bold */
.font-extrabold {
  font-weight: 800;
} /* Extra Bold */
.font-black {
  font-weight: 900;
} /* Black / Heavy */

/* ─── 1. FLEXBOX ─────────────────────────────────────────────
   Parent (container) properties
   ──────────────────────────────────────────────────────────── */

.font-xxs {
  font-size: 10px;
}

.font-xs {
  font-size: 12px;
}
.font-sm {
  font-size: 14px;
}
.text-base {
  font-size: 16px;
}
.text-lg {
  font-size: 18px;
}
.text-xl {
  font-size: 20px;
}
.text-\[30px\] {
  font-size: 30px;
}
.text-\[36px\] {
  font-size: 36px;
}

.text-navy-50{
  color: #E6EAEE;
}
.text-navy-100{
  color: #CCD4DE;
}
.text-navy-200{
  color: #99A9BC;
}
.text-navy-300{
  color: #667E9B;
}
.text-navy-400{
  color: #335379;
}
.text-slate-400{
  color: #99A1AF;
}
.text-dark-blue {
  color: #004C9D;
}




.hover:text-white {
  color: white;
}

.flex {
  display: flex;
}
.inline-flex {
  display: inline-flex;
}

/* Direction */
.flex-row {
  flex-direction: row;
} /* default — left to right */
.flex-row-reverse {
  flex-direction: row-reverse;
} /* right to left */
.flex-col {
  flex-direction: column;
} /* top to bottom */
.flex-col-reverse {
  flex-direction: column-reverse;
} /* bottom to top */

/* Wrap */
.flex-nowrap {
  flex-wrap: nowrap;
} /* default — single line */
.flex-wrap {
  flex-wrap: wrap;
} /* items wrap to next line */

/* Justify content — main axis (horizontal in row, vertical in col) */
.justify-start {
  justify-content: flex-start;
} /* pack to start */
.justify-end {
  justify-content: flex-end;
} /* pack to end */
.justify-center {
  justify-content: center;
} /* center */
.justify-between {
  justify-content: space-between;
} /* equal gaps between */
.justify-around {
  justify-content: space-around;
} /* equal gaps around */
.justify-evenly {
  justify-content: space-evenly;
} /* equal gaps everywhere */

/* Align items — cross axis (vertical in row, horizontal in col) */
.items-start {
  align-items: flex-start;
} /* pin to start of cross axis */
.items-end {
  align-items: flex-end;
} /* pin to end of cross axis */
.items-center {
  align-items: center;
} /* center on cross axis */
.items-stretch {
  align-items: stretch;
} /* stretch to fill (default) */
.items-baseline {
  align-items: baseline;
} /* align by text baseline */

/* Align self — override align-items for a single child */
.self-start {
  align-self: flex-start;
}
.self-end {
  align-self: flex-end;
}
.self-center {
  align-self: center;
}
.self-stretch {
  align-self: stretch;
}

/** Text alignment ***/
.text-left {
  text-align: left;
}
.text-right {
  text-align: right;
}
.text-center {
  text-align: center;
}

.w-full {
  width: 100%;
}

.h-full {
  height: 100%;
}
/* line height */
.leading-normal {
  line-height: normal;
}
.leading-\[1.5\] {
  line-height: 1.5;
}


.stroke-inherit {
  stroke-width: inherit;
}


/* Gap */
.gap-1 {
  gap: 4px;
}
.gap-2 {
  gap: 8px;
}
.gap-3 {
  gap: 12px;
}
.gap-4 {
  gap: 16px;
}
.gap-5 {
  gap: 20px;
}
.gap-6 {
  gap: 24px;
}
.gap-8 {
  gap: 32px;
}
.gap-10 {
  gap: 40px;
}
.gap-12 {
  gap: 48px;
}
.gap-14 {
  gap: 56px;
}

/* Child (item) properties */
.flex-1 {
  flex: 1 1 0%;
} /* grow + shrink + zero base */
.flex-auto {
  flex: 1 1 auto;
} /* grow + shrink + natural size */
.flex-none {
  flex: none;
} /* fixed — no grow or shrink */

.grow {
  flex-grow: 1;
}
.grow-0 {
  flex-grow: 0;
}
.shrink {
  flex-shrink: 1;
}
.shrink-0 {
  flex-shrink: 0;
} /* prevents item from shrinking */

.order-first {
  order: -9999;
}
.order-last {
  order: 9999;
}
.order-none {
  order: 0;
}

/* ─── 2. GRID ────────────────────────────────────────────────
   Parent (container) properties
   ──────────────────────────────────────────────────────────── */

.grid {
  display: grid;
}
.inline-grid {
  display: inline-grid;
}

/* Columns */
.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}
.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.grid-cols-6 {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

/* Rows */
.grid-rows-1 {
  grid-template-rows: repeat(1, minmax(0, 1fr));
}
.grid-rows-2 {
  grid-template-rows: repeat(2, minmax(0, 1fr));
}
.grid-rows-3 {
  grid-template-rows: repeat(3, minmax(0, 1fr));
}

/* Auto-fit responsive columns (no breakpoints needed) */
.grid-auto-fit-sm {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.grid-auto-fit-md {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.grid-auto-fit-lg {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

/* Place items (shorthand for align-items + justify-items) */
.place-center {
  place-items: center;
}
.place-start {
  place-items: start;
}
.place-end {
  place-items: end;
}
.place-stretch {
  place-items: stretch;
}

/* Child (item) properties — spanning columns */
.col-span-1 {
  grid-column: span 1 / span 1;
}
.col-span-2 {
  grid-column: span 2 / span 2;
}
.col-span-3 {
  grid-column: span 3 / span 3;
}
.col-span-4 {
  grid-column: span 4 / span 4;
}
.col-full {
  grid-column: 1 / -1;
} /* stretch across all columns */

/* Child (item) properties — spanning rows */
.row-span-1 {
  grid-row: span 1 / span 1;
}
.row-span-2 {
  grid-row: span 2 / span 2;
}
.row-span-3 {
  grid-row: span 3 / span 3;
}

/* ─── 3. POSITION ────────────────────────────────────────────
   ──────────────────────────────────────────────────────────── */

.static {
  position: static;
} /* default — in normal flow */
.relative {
  position: relative;
} /* offset from normal position; creates stacking context */
.absolute {
  position: absolute;
} /* removed from flow; placed relative to nearest non-static ancestor */
.fixed {
  position: fixed;
} /* relative to viewport; stays on scroll */
.sticky {
  position: sticky;
} /* in flow until scroll threshold, then fixed */

/* Inset helpers (top / right / bottom / left) */
.inset-0 {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
} /* fill parent */
.inset-auto {
  top: auto;
  right: auto;
  bottom: auto;
  left: auto;
}

.top-0 {
  top: 0;
}
.top-auto {
  top: auto;
}
.right-0 {
  right: 0;
}
.bottom-0 {
  bottom: 0;
}
.left-0 {
  left: 0;
}

/* Common positioning patterns */

/* Centre a child absolutely inside a relative parent */
.abs-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Fill the entire parent */
.abs-fill {
  position: absolute;
  inset: 0; /* shorthand for top:0 right:0 bottom:0 left:0 */
  width: 100%;
  height: 100%;
}

/* Pin to a corner */
.abs-top-left {
  position: absolute;
  top: 0;
  left: 0;
}
.abs-top-right {
  position: absolute;
  top: 0;
  right: 0;
}
.abs-bottom-left {
  position: absolute;
  bottom: 0;
  left: 0;
}
.abs-bottom-right {
  position: absolute;
  bottom: 0;
  right: 0;
}

/* Z-index scale */
.z-0 {
  z-index: 0;
}
.z-10 {
  z-index: 10;
}
.z-20 {
  z-index: 20;
}
.z-30 {
  z-index: 30;
}
.z-40 {
  z-index: 40;
}
.z-50 {
  z-index: 50;
}
.z-100 {
  z-index: 100;
}
.z-auto {
  z-index: auto;
}

/* ─── 4. BACKGROUND IMAGE ────────────────────────────────────
   ──────────────────────────────────────────────────────────── */

/* background-size */
.bg-cover {
  background-size: cover;
} /* scale to fill — crops if needed */
.bg-contain {
  background-size: contain;
} /* scale to fit — letterboxes if needed */
.bg-auto {
  background-size: auto;
} /* use image's natural size */
.bg-full {
  background-size: 100% 100%;
} /* stretch to fill exactly */

/* background-repeat */
.bg-no-repeat {
  background-repeat: no-repeat;
}
.bg-repeat {
  background-repeat: repeat;
} /* default — tile both axes */
.bg-repeat-x {
  background-repeat: repeat-x;
} /* tile horizontally only */
.bg-repeat-y {
  background-repeat: repeat-y;
} /* tile vertically only */
.bg-repeat-round {
  background-repeat: round;
} /* rescale tiles so none are clipped */
.bg-repeat-space {
  background-repeat: space;
} /* space tiles evenly without clipping */

.bg-none {
  background: none;
}
.bg-white {
  background:white;
}
.hover\:bg-none:hover {
  background-color: transparent;
}

.focus\:bg-none:focus {
  background-color: transparent;
}
.active\:bg-none:active {
  background-color: transparent;
}

/*** Cursor ***/
.cursor-pointer {
  cursor: pointer;
}

.no-underline {
  text-decoration: none;
}
.hover\:no-underline{
  text-decoration: none;
}


/*** White space ****/

.whitespace-nowrap {
  white-space: nowrap;
}


.overflow-hidden{
  overflow:hidden;
}


/* background-position */
.bg-center {
  background-position: center;
}
.bg-top {
  background-position: top;
}
.bg-bottom {
  background-position: bottom;
}
.bg-left {
  background-position: left;
}
.bg-right {
  background-position: right;
}
.bg-top-left {
  background-position: top left;
}
.bg-top-right {
  background-position: top right;
}
.bg-bottom-left {
  background-position: bottom left;
}
.bg-bottom-right {
  background-position: bottom right;
}

/* background-attachment */
.bg-fixed {
  background-attachment: fixed;
} /* parallax — stays fixed relative to viewport */
.bg-local {
  background-attachment: local;
} /* scrolls with element's content */
.bg-scroll {
  background-attachment: scroll;
} /* default — scrolls with element */

/* background-origin */
.bg-origin-border {
  background-origin: border-box;
} /* image starts at border edge */
.bg-origin-padding {
  background-origin: padding-box;
} /* image starts at padding edge (default) */
.bg-origin-content {
  background-origin: content-box;
} /* image starts at content edge */

/* background-clip */
.bg-clip-border {
  background-clip: border-box;
} /* extends under border (default) */
.bg-clip-padding {
  background-clip: padding-box;
} /* stops at border edge */
.bg-clip-content {
  background-clip: content-box;
} /* stops at padding edge */
.bg-clip-text {
  background-clip: text;
  -webkit-background-clip: text;
} /* clip to text shape — pair with color:transparent */

/* Common ready-to-use patterns */

/* Full-bleed hero: cover + no-repeat + centered */
.bg-hero {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

/* Full-bleed hero that doesn't scroll with page */
.bg-hero-fixed {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-attachment: fixed;
}

/* Gradient overlay helper — pair with a background-image gradient */
.bg-overlay-dark::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
}
.bg-overlay-light::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.45);
}

/*** Border ****/
.border-none {
  border-style: none;
}
.hover\:border-none:hover {
  border-style: none;
}
/* ─── 5. BORDER RADIUS ───────────────────────────────────────
   ──────────────────────────────────────────────────────────── */
/* All corners */
.rounded-none {
  border-radius: 0;
}
.rounded-xs {
  border-radius: 2px;
}
.rounded-sm {
  border-radius: 4px;
}
.rounded {
  border-radius: 6px;
}
.rounded-md {
  border-radius: 8px;
}
.rounded-lg {
  border-radius: 12px;
}
.rounded-xl {
  border-radius: 16px;
}
.border-\[14px\] {
  border-radius: 14px;
}
.rounded-2xl {
  border-radius: 20px;
}
.rounded-3xl {
  border-radius: 24px;
}
.rounded-4xl {
  border-radius: 32px;
}
.rounded-full {
  border-radius: 9999px;
}

/* Top corners only */
.rounded-t-none {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.rounded-t-sm {
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
}
.rounded-t-md {
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
}
.rounded-t-lg {
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
}
.rounded-t-xl {
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
}
.rounded-t-2xl {
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
}

/* Bottom corners only */
.rounded-b-none {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.rounded-b-sm {
  border-bottom-left-radius: 4px;
  border-bottom-right-radius: 4px;
}
.rounded-b-md {
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
}
.rounded-b-lg {
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
}
.rounded-b-xl {
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}
.rounded-b-2xl {
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
}

/* Left corners only */
.rounded-l-none {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.rounded-l-sm {
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
}
.rounded-l-md {
  border-top-left-radius: 8px;
  border-bottom-left-radius: 8px;
}
.rounded-l-lg {
  border-top-left-radius: 12px;
  border-bottom-left-radius: 12px;
}
.rounded-l-xl {
  border-top-left-radius: 16px;
  border-bottom-left-radius: 16px;
}

/* Right corners only */
.rounded-r-none {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.rounded-r-sm {
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
}
.rounded-r-md {
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
}
.rounded-r-lg {
  border-top-right-radius: 12px;
  border-bottom-right-radius: 12px;
}
.rounded-r-xl {
  border-top-right-radius: 16px;
  border-bottom-right-radius: 16px;
}

/* Individual corners */
.rounded-tl-sm {
  border-top-left-radius: 4px;
}
.rounded-tl-md {
  border-top-left-radius: 8px;
}
.rounded-tl-lg {
  border-top-left-radius: 12px;
}

.rounded-tr-sm {
  border-top-right-radius: 4px;
}
.rounded-tr-md {
  border-top-right-radius: 8px;
}
.rounded-tr-lg {
  border-top-right-radius: 12px;
}

.rounded-bl-sm {
  border-bottom-left-radius: 4px;
}
.rounded-bl-md {
  border-bottom-left-radius: 8px;
}
.rounded-bl-lg {
  border-bottom-left-radius: 12px;
}

.rounded-br-sm {
  border-bottom-right-radius: 4px;
}
.rounded-br-md {
  border-bottom-right-radius: 8px;
}
.rounded-br-lg {
  border-bottom-right-radius: 12px;
}

/* ─── 6. SPACING — Padding & Margin ─────────────────────────
   Base unit: 4px  (p-1 = 4px, p-2 = 8px … p-10 = 40px)
   ──────────────────────────────────────────────────────────── */

/* All sides */
.p-0 {
  padding: 0;
}
.p-1 {
  padding: 4px;
}
.p-2 {
  padding: 8px;
}
.p-3 {
  padding: 12px;
}
.p-4 {
  padding: 16px;
}
.p-5 {
  padding: 20px;
}
.p-6 {
  padding: 24px;
}
.p-7 {
  padding: 28px;
}
.p-8 {
  padding: 32px;
}
.p-9 {
  padding: 36px;
}
.p-10 {
  padding: 40px;
}

/* Horizontal (left + right) */
.px-0 {
  padding-left: 0;
  padding-right: 0;
}
.px-1 {
  padding-left: 4px;
  padding-right: 4px;
}
.px-2 {
  padding-left: 8px;
  padding-right: 8px;
}
.px-3 {
  padding-left: 12px;
  padding-right: 12px;
}
.px-4 {
  padding-left: 16px;
  padding-right: 16px;
}
.px-5 {
  padding-left: 20px;
  padding-right: 20px;
}
.px-6 {
  padding-left: 24px;
  padding-right: 24px;
}
.px-7 {
  padding-left: 28px;
  padding-right: 28px;
}
.px-8 {
  padding-left: 32px;
  padding-right: 32px;
}
.px-9 {
  padding-left: 36px;
  padding-right: 36px;
}
.px-10 {
  padding-left: 40px;
  padding-right: 40px;
}

/* Vertical (top + bottom) */
.py-0 {
  padding-top: 0;
  padding-bottom: 0;
}
.py-1 {
  padding-top: 4px;
  padding-bottom: 4px;
}
.py-2 {
  padding-top: 8px;
  padding-bottom: 8px;
}
.py-3 {
  padding-top: 12px;
  padding-bottom: 12px;
}
.py-4 {
  padding-top: 16px;
  padding-bottom: 16px;
}
.py-5 {
  padding-top: 20px;
  padding-bottom: 20px;
}
.py-6 {
  padding-top: 24px;
  padding-bottom: 24px;
}
.py-7 {
  padding-top: 28px;
  padding-bottom: 28px;
}
.py-8 {
  padding-top: 32px;
  padding-bottom: 32px;
}
.py-9 {
  padding-top: 36px;
  padding-bottom: 36px;
}
.py-10 {
  padding-top: 40px;
  padding-bottom: 40px;
}

/* Individual sides */
.pt-0 {
  padding-top: 0;
}
.pt-1 {
  padding-top: 4px;
}
.pt-2 {
  padding-top: 8px;
}
.pt-3 {
  padding-top: 12px;
}
.pt-4 {
  padding-top: 16px;
}
.pt-5 {
  padding-top: 20px;
}
.pt-6 {
  padding-top: 24px;
}
.pt-7 {
  padding-top: 28px;
}
.pt-8 {
  padding-top: 32px;
}
.pt-9 {
  padding-top: 36px;
}
.pt-10 {
  padding-top: 40px;
}

.pr-0 {
  padding-right: 0;
}
.pr-1 {
  padding-right: 4px;
}
.pr-2 {
  padding-right: 8px;
}
.pr-3 {
  padding-right: 12px;
}
.pr-4 {
  padding-right: 16px;
}
.pr-5 {
  padding-right: 20px;
}
.pr-6 {
  padding-right: 24px;
}
.pr-7 {
  padding-right: 28px;
}
.pr-8 {
  padding-right: 32px;
}
.pr-9 {
  padding-right: 36px;
}
.pr-10 {
  padding-right: 40px;
}

.pb-0 {
  padding-bottom: 0;
}
.pb-1 {
  padding-bottom: 4px;
}
.pb-2 {
  padding-bottom: 8px;
}
.pb-3 {
  padding-bottom: 12px;
}
.pb-4 {
  padding-bottom: 16px;
}
.pb-5 {
  padding-bottom: 20px;
}
.pb-6 {
  padding-bottom: 24px;
}
.pb-7 {
  padding-bottom: 28px;
}
.pb-8 {
  padding-bottom: 32px;
}
.pb-9 {
  padding-bottom: 36px;
}
.pb-10 {
  padding-bottom: 40px;
}

.pl-0 {
  padding-left: 0;
}
.pl-1 {
  padding-left: 4px;
}
.pl-2 {
  padding-left: 8px;
}
.pl-3 {
  padding-left: 12px;
}
.pl-4 {
  padding-left: 16px;
}
.pl-5 {
  padding-left: 20px;
}
.pl-6 {
  padding-left: 24px;
}
.pl-7 {
  padding-left: 28px;
}
.pl-8 {
  padding-left: 32px;
}
.pl-9 {
  padding-left: 36px;
}
.pl-10 {
  padding-left: 40px;
}

/* ── Margin ──────────────────────────────────────────────── */

/* All sides */
.m-0 {
  margin: 0;
}
.m-1 {
  margin: 4px;
}
.m-2 {
  margin: 8px;
}
.m-3 {
  margin: 12px;
}
.m-4 {
  margin: 16px;
}
.m-5 {
  margin: 20px;
}
.m-6 {
  margin: 24px;
}
.m-7 {
  margin: 28px;
}
.m-8 {
  margin: 32px;
}
.m-9 {
  margin: 36px;
}
.m-10 {
  margin: 40px;
}
.m-auto {
  margin: auto;
}

/* Horizontal (left + right) */
.mx-0 {
  margin-left: 0;
  margin-right: 0;
}
.mx-1 {
  margin-left: 4px;
  margin-right: 4px;
}
.mx-2 {
  margin-left: 8px;
  margin-right: 8px;
}
.mx-3 {
  margin-left: 12px;
  margin-right: 12px;
}
.mx-4 {
  margin-left: 16px;
  margin-right: 16px;
}
.mx-5 {
  margin-left: 20px;
  margin-right: 20px;
}
.mx-6 {
  margin-left: 24px;
  margin-right: 24px;
}
.mx-7 {
  margin-left: 28px;
  margin-right: 28px;
}
.mx-8 {
  margin-left: 32px;
  margin-right: 32px;
}
.mx-9 {
  margin-left: 36px;
  margin-right: 36px;
}
.mx-10 {
  margin-left: 40px;
  margin-right: 40px;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
} /* centre a block element */

/* Vertical (top + bottom) */
.my-0 {
  margin-top: 0;
  margin-bottom: 0;
}
.my-1 {
  margin-top: 4px;
  margin-bottom: 4px;
}
.my-2 {
  margin-top: 8px;
  margin-bottom: 8px;
}
.my-3 {
  margin-top: 12px;
  margin-bottom: 12px;
}
.my-4 {
  margin-top: 16px;
  margin-bottom: 16px;
}
.my-5 {
  margin-top: 20px;
  margin-bottom: 20px;
}
.my-6 {
  margin-top: 24px;
  margin-bottom: 24px;
}
.my-7 {
  margin-top: 28px;
  margin-bottom: 28px;
}
.my-8 {
  margin-top: 32px;
  margin-bottom: 32px;
}
.my-9 {
  margin-top: 36px;
  margin-bottom: 36px;
}
.my-10 {
  margin-top: 40px;
  margin-bottom: 40px;
}

/* Individual sides */
.mt-0 {
  margin-top: 0;
}
.mt-1 {
  margin-top: 4px;
}
.mt-2 {
  margin-top: 8px;
}
.mt-3 {
  margin-top: 12px;
}
.mt-4 {
  margin-top: 16px;
}
.mt-5 {
  margin-top: 20px;
}
.mt-6 {
  margin-top: 24px;
}
.mt-7 {
  margin-top: 28px;
}
.mt-8 {
  margin-top: 32px;
}
.mt-9 {
  margin-top: 36px;
}
.mt-10 {
  margin-top: 40px;
}
.mt-auto {
  margin-top: auto;
}

.mr-0 {
  margin-right: 0;
}
.mr-1 {
  margin-right: 4px;
}
.mr-2 {
  margin-right: 8px;
}
.mr-3 {
  margin-right: 12px;
}
.mr-4 {
  margin-right: 16px;
}
.mr-5 {
  margin-right: 20px;
}
.mr-6 {
  margin-right: 24px;
}
.mr-7 {
  margin-right: 28px;
}
.mr-8 {
  margin-right: 32px;
}
.mr-9 {
  margin-right: 36px;
}
.mr-10 {
  margin-right: 40px;
}
.mr-auto {
  margin-right: auto;
}

.mb-0 {
  margin-bottom: 0;
}
.mb-1 {
  margin-bottom: 4px;
}
.mb-2 {
  margin-bottom: 8px;
}
.mb-3 {
  margin-bottom: 12px;
}
.mb-4 {
  margin-bottom: 16px;
}
.mb-5 {
  margin-bottom: 20px;
}
.mb-6 {
  margin-bottom: 24px;
}
.mb-7 {
  margin-bottom: 28px;
}
.mb-8 {
  margin-bottom: 32px;
}
.mb-9 {
  margin-bottom: 36px;
}
.mb-10 {
  margin-bottom: 40px;
}
.mb-auto {
  margin-bottom: auto;
}

.ml-0 {
  margin-left: 0;
}
.ml-1 {
  margin-left: 4px;
}
.ml-2 {
  margin-left: 8px;
}
.ml-3 {
  margin-left: 12px;
}
.ml-4 {
  margin-left: 16px;
}
.ml-5 {
  margin-left: 20px;
}
.ml-6 {
  margin-left: 24px;
}
.ml-7 {
  margin-left: 28px;
}
.ml-8 {
  margin-left: 32px;
}
.ml-9 {
  margin-left: 36px;
}
.ml-10 {
  margin-left: 40px;
}
.ml-auto {
  margin-left: auto;
}

/** HTML doesn't allow classes with arbitrary values like ml-[30px], so we need to escape the brackets with backslashes. */
.ml-\[30px\] {
  margin-left: 30px;
}

/* ─── LIST STYLE ────────────────────────────────────────
──────────────────────────────────────────────────────────── */
.list-none {
list-style-type: none;
}
.list-disc {
list-style-type: disc;
}

/*** Object fit ***/
.object-contain {
  object-fit: contain;
}
.object-cover {
  object-fit: cover;
}
.object-fill {
  object-fit: fill;
}
.object-none {
  object-fit: none;
}
.object-scale-down {
  object-fit: scale-down;
}
.object-center {
  object-position: center;
}
.object-top {
  object-position: top;
}


/* ─── 7. ASPECT RATIO ────────────────────────────────────────
   ──────────────────────────────────────────────────────────── */

/* Square */
.aspect-square {
  aspect-ratio: 1 / 1;
} /* 1:1   — avatars, thumbnails */

/* Video / film */
.aspect-16-9 {
  aspect-ratio: 16 / 9;
} /* 1.78  — HD video, YouTube, TV */
.aspect-9-16 {
  aspect-ratio: 9 / 16;
} /* 0.56  — vertical/portrait video, Reels */
.aspect-4-3 {
  aspect-ratio: 4 / 3;
} /* 1.33  — classic TV, old monitors */
.aspect-3-4 {
  aspect-ratio: 3 / 4;
} /* 0.75  — portrait photos */
.aspect-21-9 {
  aspect-ratio: 21 / 9;
} /* 2.33  — ultrawide / cinematic */
.aspect-9-21 {
  aspect-ratio: 9 / 21;
} /* 0.43  — tall ultrawide portrait */
.aspect-18-9 {
  aspect-ratio: 18 / 9;
} /* 2.0   — full screen mobile (18:9) */
.aspect-2-1 {
  aspect-ratio: 2 / 1;
} /* 2.0   — wide banner */
.aspect-1-2 {
  aspect-ratio: 1 / 2;
} /* 0.5   — tall banner */

/* Photo */
.aspect-3-2 {
  aspect-ratio: 3 / 2;
} /* 1.5   — standard DSLR / 35mm film */
.aspect-2-3 {
  aspect-ratio: 2 / 3;
} /* 0.67  — portrait DSLR */
.aspect-5-4 {
  aspect-ratio: 5 / 4;
} /* 1.25  — medium format / print */
.aspect-4-5 {
  aspect-ratio: 4 / 5;
} /* 0.8   — Instagram portrait */
.aspect-7-5 {
  aspect-ratio: 7 / 5;
} /* 1.4   — 5×7 print */
.aspect-5-7 {
  aspect-ratio: 5 / 7;
} /* 0.71  — 5×7 portrait print */

/* Golden ratio */
.aspect-golden {
  aspect-ratio: 1.618 / 1;
} /* φ     — golden rectangle */

/* Social media */
.aspect-1-91-1 {
  aspect-ratio: 1.91 / 1;
} /* ~1.91 — Facebook/LinkedIn link preview */
.aspect-4-1 {
  aspect-ratio: 4 / 1;
} /* 4.0   — Twitter/X header banner */

/* Auto — removes any set ratio */
.aspect-auto {
  aspect-ratio: auto;
}
/*** max-width ***/
.max-w-\[675px\] {
  max-width: 675px;
}
.max-w-\[900px\] {
  max-width: 900px;
}
.max-w-\[940px\] {
  max-width: 940px;
}
.max-w-\[1340px\] {
  max-width: 1340px;
}


.shadow {
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.10), 0 1px 2px -1px rgba(0, 0, 0, 0.10)
}

/* ─── 8. RESPONSIVE HELPERS ──────────────────────────────────
   Re-use these breakpoints with any class above.
   xs  < 480px  (no prefix — mobile-first base)
   sm  ≥ 480px
   md  ≥ 768px
   lg  ≥ 1024px
   xl  ≥ 1280px
   ──────────────────────────────────────────────────────────── */

@media (min-width: 480px) {
  .sm\:flex-row {
    flex-direction: row;
  }
  .sm\:flex-col {
    flex-direction: column;
  }
  .sm\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sm\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (min-width: 767px) {
  .md\:grid-cols-2 {
     grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* 
 .md:p-7 is an example of a responsive padding class that applies padding of 28px (1.75rem) to all sides when the viewport width is 768px or larger. You can create similar classes for other padding values and breakpoints as needed.
*/
@media (min-width: 768px) {
  .md\:p-7 {
    padding: 28px;
  }
  
  .md\:justify-start {
    justify-content: flex-start;
  }
}

@media (min-width: 768px) {
  .md\:flex-row {
    flex-direction: row;
  }
  .md\:flex-col {
    flex-direction: column;
  }
  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .md\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .lg\:flex-row {
    flex-direction: row;
  }
  .lg\:flex-col {
    flex-direction: column;
  }
  .lg\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}