/**% Frontend Global Variables & Objects %**/
:root {
    --primary-color: rgb(250, 170, 45, 1);
    --primary-color-less-opacity: rgba(250, 170, 45, 0.7);
    --primary-color-half-opacity: rgba(250, 170, 45, 0.5);
    --primary-color-dim-opacity: rgba(250, 170, 45, 0.25);
    --primary-color-glass-opacity: rgba(250, 170, 45, 0.125);
    --secondary-color: rgb(0, 91, 170, 1);
    --secondary-color-less-opacity: rgba(0, 91, 170, 0.7);
    --secondary-color-half-opacity: rgba(0, 91, 170, 0.5);
    --secondary-color-overlay: #176ab0;
    --grey-color: rgb(125, 130, 107);
    --vehicle-bg-color: #e9efff;
    --input-bg-color: #f6f7f9;
    --input-text-placeholder-color: #90a3bf;
    --input-text-color: #1a202c;
}

/**% Frontend Global Style Classes %**/
/*- CONTAINERS */
/*- <Sozo Floating Box> -*/
.sozo-floating-box {
    border-radius: 16px;
    padding: 1.75%;
    background-color: white;
    font-style: normal;
    line-height: 100%;
    letter-spacing: 0%;
    color: black;
}
.sozo-floating-box .floating-box-heading {
    margin-top: 2%;
    font-family: "Quantico", sans-serif;
    font-weight: 700;
    font-size: clamp(4px, 13vw, 23px);
    text-align: center;
    background-color: inherit;
}
.sozo-floating-box .floating-box-paragraph {
    font-family: "Quantico", sans-serif;
    font-weight: lighter;
    font-size: clamp(4px, 10vw, 15px);
    text-align: justify;
    background-color: inherit;
}
/* <Sozo Floating Box> */
/* CONTAINERS -*/

/*- LISTS */
ul.list-sozo-primary {
    margin: 0;
    padding: 0;
}
ul.list-sozo-primary li {
    display: list-item;
    list-style: none;
}
ul.list-sozo-primary li::before {
    content: ">";
    font-family: sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 1em;
    color: var(--primary-color);
    scale: 1.2;
    margin: auto;
    padding-right: 0.75rem;
}
ul.list-sozo-primary li.item-sozo-list:first-child {
    margin-top: 0;
}
ul.list-sozo-primary li.item-sozo-list:last-child {
    margin-bottom: 0;
}
ul.list-sozo-primary li.item-sozo-list {
    font-family: "Poppins", sans-serif;
    font-style: normal;
    font-weight: 500;
    font-size: clamp(0.7rem, 1.45vw, 2.2rem);
    line-height: 100%;
    letter-spacing: 0%;
    color: rgba(255, 255, 255, 1);
    margin-block: 0.35rem;
}
/* LISTS -*/

/*- IMAGES */
[sozo-img] {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
[sozo-img][img-appear] {
    display: block;
    height: 100%;
    width: auto;
}
[sozo-img][hidden] {
    display: none;
}
[sozo-img].fire-line-blue {
    background-image: url("../images/textures/fire-line--blue.webp");
}
[sozo-img].fire-parallelogram-orange {
    background-image: url("../images/textures/fire-parallelogram--orange.svg");
    background-position: top center;
    background-size: cover;
}
[sozo-img].L-shape-orange {
    background-image: url("../images/textures/L-shape--orange.webp");
    background-size: contain;
}
[sozo-img].irregular-splash-blue {
    background-image: url("../images/textures/irregular-splash-blue.webp");
    background-size: contain;
}
[sozo-img].irregular-splash-orange {
    background-image: url("../images/textures/irregular-splash-orange.webp");
    background-size: contain;
}
/* IMAGES -*/

/*- PARAGRAPHS & LABELS */
.label-sozo {
    font-family: "Poppins", sans-serif;
    line-height: 100%;
    letter-spacing: 0%;
}
.label-sozo.label-sozo-L1 {
    font-weight: lighter;
    /* font-size: 1.85rem; */
    font-size: clamp(1.5rem, 2vw, 3.5rem);
    text-align: justify;
}
.label-sozo.label-sozo-L2 {
    font-weight: 500;
    /* font-size: 3.25rem; */
    font-size: clamp(1.25rem, 1.5vw, 3rem);
    text-transform: uppercase;
}
.label-sozo.label-sozo-L3 {
    font-weight: 300;
    font-style: normal;
    /* font-size: 3.5rem; */
    font-size: clamp(0.85rem, 1.215vw, 2rem);
    text-align: justify;
    line-height: 1.5; /* 150% spacing */
}
.label-sozo.label-sozo-L4 {
    font-weight: 300;
    font-style: normal;
    /* font-size: 3.5rem; */
    font-size: clamp(0.75rem, 1.05vw, 1.85rem);
    text-align: justify;
    line-height: 1.5; /* 150% spacing */
}
/* PARAGRAPHS & LABELS -*/

/*- HEADING & TITLES */
.base-heading-sozo {
    font-family: "Quantico", sans-serif;
    font-weight: 700;
    font-size: 23px;
    line-height: 100%;
    letter-spacing: 0%;
    text-transform: uppercase;
}
.title-sozo {
    position: relative;
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    color: white;
    font-family: "Quantico", sans-serif;
    font-weight: 700;
    font-size: clamp(1.25rem, 2.75vw, 3.75rem);
    line-height: 100%;
    letter-spacing: 0%;
    text-align: center;
    text-transform: uppercase;
    max-width: fit-content;
    max-width: max-content;
    padding-bottom: 1.15em;
    margin: 0;
}
.title-sozo.title-sozo-primary::before {
    content: "";
    background-color: var(--primary-color);
}
.title-sozo.title-sozo-primary::after {
    content: "";
    background-color: white;
}
.title-sozo.title-sozo-secondary::before {
    content: "";
    background-color: white;
}
.title-sozo.title-sozo-secondary::after {
    content: "";
    background-color: var(--secondary-color);
}
.title-sozo.title-sozo-tertiary::before {
    content: "";
    background-color: var(--primary-color);
}
.title-sozo.title-sozo-tertiary::after {
    content: "";
    background-color: var(--secondary-color);
}
.title-sozo::before {
    position: absolute;
    /* height: 3.5px; */
    height: 4.5%;
    width: 45%;
    bottom: 18%;
    left: 17%;
}
.title-sozo::after {
    content: "";
    position: absolute;
    background-color: var(--primary-color);
    /* height: 3.5px; */
    height: 4.5%;
    width: 45%;
    bottom: 0;
    right: 17%;
}
.title-sozo.title-align-start {
    text-align: start;
}
.title-sozo.title-align-start::before {
    left: 0;
}
.title-sozo.title-align-start::after {
    right: 30%;
}
.title-sozo.title-align-end {
    text-align: end;
}
.title-sozo.title-align-end::before {
    left: 30%;
}
.title-sozo.title-align-end::after {
    right: 0;
}
/* HEADING & TITLES -*/

/*- OVERLAYS */
.overlay-sozo {
    position: absolute;
    display: block;
    height: 100%;
    width: 100%;
    top: 0;
    left: 0;
    /* z-index: 1;
    pointer-events: none;
    opacity: 0.5; */
}
.overlay-sozo.overlay-sozo-blue {
    background-color: rgba(0, 91, 170, 0.9);
}
/* OVERLAYS -*/

/*- BUTTONS */
.btn-sozo {
    background-color: transparent;
    transition: background-color 350ms ease, color 350ms ease;
    border: 1px solid;
    border-radius: 10px;
    color: white;
}
.btn-sozo:hover {
    color: white;
}
.btn-sozo.btn-sozo-primary {
    background-color: var(--primary-color);
}
.btn-sozo.btn-sozo-primary:hover {
    background-color: var(--primary-color);
    mix-blend-mode: hard-light;
    color: inherit !important;
}
.btn-sozo.btn-sozo-outline-primary {
    border-color: var(--primary-color);
    color: var(--primary-color);
}
.btn-sozo.btn-sozo-outline-primary:hover {
    background-color: var(--primary-color);
    color: inherit !important;
}
.btn-sozo.btn-sozo-secondary {
    background-color: var(--secondary-color);
}
.btn-sozo.btn-sozo-secondary:hover {
    background-color: var(--secondary-color);
    mix-blend-mode: hard-light;
    color: inherit !important;
}
.btn-sozo.btn-sozo-outline-secondary {
    border-color: var(--secondary-color);
    color: var(--secondary-color) !important;
}
.btn-sozo.btn-sozo-outline-secondary:hover {
    background-color: var(--secondary-color);
    color: inherit !important;
}
/* BUTTONS -*/

/*- INPUT: Radio */
.sozo-radio-primary:checked {
    accent-color: var(--primary-color);
    border-color: ghostwhite;
}
.sozo-radio-secondary:checked {
    accent-color: var(--secondary-color);
    border-color: ghostwhite;
}
.sozo-radio-primary.form-check-input,
.sozo-radio-secondary.form-check-input {
    border-color: var(--input-text-color);
    background-color: white;
    outline-offset: 0; /* gap between border and outline */
    scale: 1.15;
}
.sozo-radio-primary.form-check-input:checked,
.sozo-radio-secondary.form-check-input:checked {
    --bs-form-check-bg-image: none !important;
    outline: 1.25px solid;
    border: none;
    outline-offset: 2.5px; /* gap between border and outline */
    scale: 0.75;
}
.sozo-radio-primary.form-check-input:checked {
    outline-color: var(--primary-color); /* inner border */
    background-color: var(--primary-color);
}
.sozo-radio-secondary.form-check-input:checked {
    outline-color: var(--secondary-color); /* inner border */
    background-color: var(--secondary-color);
}
/* INPUT: Radio -*/
