:root {
    --main-color: #1C345D;
    --secondary-color: #FFFCEB;
    --dark-color: #152642;
    --secondary-dark-color: #D3D3D3;
    --almost-white: #FEFEFE;
    --alternative_white: #F9F9F9;
    --gray: #E0E0E0;
    --light-gray: #F7F7F7;
    --font-family: 'Open Sans';
    --small-font: 0.9rem;
    --red: rgba(248, 215, 218, 0.7);
    --blue: rgba(215, 228, 247, 0.7);
    --green: rgba(240, 247, 215, 0.7);
    --intense_red: #D93654;
    --intense_blue: #1BAFBF;
    --intense_green: #198754;
    --intense_yellow: #F2A007;
}

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

a {
  text-decoration: none;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    overflow-x: hidden;
    width: 100%;
}

section {
    height: auto;
    min-height: 60vh;
    width: 100%;
    transition: 1s;
}

h1, h2, h3 {
    color: var(--main-color);
    font-family: var(--font-family);
    margin: 1.5vh 0;
    -webkit-font-smoothing: antialiased;
}

h1 {
    font-size: 4.9rem;
    font-weight: 750;
    letter-spacing: 3px;
    line-height: 4.9rem;
    text-align: center;
    text-transform: uppercase;
}

h2 {
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    opacity: 0.95;
    text-align: center;
}

h3 {
    font-size: 3rem;
    font-weight: 1000;
    letter-spacing: 1px;
    line-height: 3.5rem;
    margin-bottom: 5vh;
    text-align: center;
}

h4 {
    color: var(--main-color);
    font-size: 1.5rem;
    font-family: var(--font-family);
    font-weight: 750;
    letter-spacing: 0px;
    line-height: 2rem;
    margin: 0vh 0vw 0vh 0vw;
    padding: 0vh 0vw 0vh 0.25vw;
    text-align: left;
    text-transform: uppercase;
    width: 100%;
    -webkit-font-smoothing: antialiased;
}

h5 {
    color: var(--main-color);
    font-size: 4.5rem;
    font-family: var(--font-family);
    font-weight: 750;
    letter-spacing: 0px;
    line-height: 4.5rem;
    margin: 0vh 0vw 7vh 0vw;
    text-align: left;
    text-transform: uppercase;
    vertical-align: top;
    width: 100%;
    -webkit-font-smoothing: antialiased;
}

p, label {
    color: var(--dark-color);
    font-family: var(--font-family);
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.5px;
    line-height: 1.5;
    opacity: 0.95;
    text-align: justify;
    text-justify: inter-word;
}

p.center {
    text-align: center;
}

p.h6 {
    color: var(--main-color);
    font-family: var(--font-family);
    -webkit-font-smoothing: antialiased;
    font-size: 1.25rem;
    font-weight: 600;
    margin: 5vh 0vw 2vh 0vw;
    opacity: 0.95;
    text-align: left;
    width: 100%;
}

p.h7 {
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    opacity: 0.95;
    text-align: center;
    color: var(--main-color);
    font-family: var(--font-family);
    margin: 1.5vh 0;
    -webkit-font-smoothing: antialiased;
}

p.text_box {
    margin: 3vh 0 3vh 0;
}

p.subtext_box {
    margin: 0vh 0 5vh 0;
}

a {
    color: var(--dark-color);
    font-family: var(--font-family);
    font-size: 1rem;
    text-decoration: underline;
}

form:not(.form_container form) {
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 30vw;
    width: 100%;
}

label {
    color: var(--main-color);
    display: block;
    font-weight: 500;
    margin: 0vw 0vw 1vh 3px;
    max-width: 30vw;
    text-align: left;
}

input[type="radio"] {
    -webkit-appearance: none;
    appearance: none;
    background-color: var(--almost-white);
    border: 0.10em solid var(--dark-color);
    border-radius: 50%;
    cursor: pointer;
    height: 2vmin;
    margin-right: 0.5em;
    margin-bottom: 5px;
    vertical-align: bottom;
    width: 2vmin;
}

input[type="radio"]:checked {
    background-color: var(--main-color);
}

input[type="radio"] + label {
    cursor: pointer;
    display: inline-flex;
    align-items: flex-end;
    font-size: 2em;
}

input[type="checkbox"] {
    -webkit-appearance: none;
    appearance: none;
    background-color: var(--almost-white);
    border: 1px solid var(--dark-color);
    border-radius: 0.15em;
    cursor: pointer;
    height: 1.5em;
    width: 1.5em;
    margin-right: 0.5em;
    margin-bottom: 5px;
    vertical-align: middle;
    display: inline-block;
}

input[type="checkbox"]:checked {
    background-color: var(--main-color);
}

input[type="checkbox"] + label {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    font-size: 1em;
}

input[type="date"],
input[type="datetime-local"],
input:not([type="radio"]):not([type="checkbox"]),
textarea,
select,
.suggestions_list {
    border: 1px solid var(--dark-color);
    border-radius: 10px;
    box-sizing: border-box;
    color: var(--dark-color);
    display: flex;
    font-family: var(--font-family);
    font-size: 1rem;
    letter-spacing: 0.5px;
    line-height: 1;
    margin: 0vh 0vw 2vh 0vh;
    padding: 2vh 2vw;
    width: 30vw;
    text-align: left;
    text-transform: uppercase;
}

.nouppercase {
    text-transform: none !important;
}

form input.short_input {
    display: inline-block !important;
    margin: 0;
    width: 20vw !important;
}

textarea {
    min-height: 150px;
    resize: vertical;
}

footer {
    align-items: center;
    background-color: var(--alternative_white);
    display: flex;
    font-family: var(--font-family);
    font-size: 0.4rem;
    font-weight: 100;
    height: 60vh;
    justify-content: center;
}

.duration_input_container {
    align-items: center;
    display: flex;
    flex-direction: column;
    margin: 0vh 0vw 2vh 0vh;
    width: 30vw;
}

.label_container {
    text-align: left;
    width: 100%;
}

.custom_help_text {
    color: var(--main-color);
    display: block;
    font-weight: 500;
    font-size: var(--small-font);
    margin: 0vw 0vw 1vh 3px;
    max-width: 30vw;
    opacity: 0.75;
    text-align: left;
}


.duration_input_container input {
    margin: 0vh 1vw;
    width: 14vw;
}

.duration_input_container .input_group {
    display: flex;
    justify-content: center;
}

.cover_box {
    align-items: center;
    display: flex;
    flex-direction: column;
    height: 100vh;
    justify-content: center;    
    overflow: hidden;
    width: 100%;
}

.claim_box {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 90vw;
    top: 50vh;
}

.header_box {
    width: 100%;
}

.underline {
    display: inline-block;
    position: relative;
    margin-bottom: 3vh;
}

.underline::after {
    content: "";
    position: absolute;
    bottom: -10px;
    width: 60%;
    height: 5px;
    background-color: var(--main-color);
    border-radius: 25px;
}

.underline.center::after {
    left: 50%;
    transform: translateX(-50%);/
}

.section {
    align-items: center;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    justify-content: flex-start;
    padding: 20vh 0vw 10vh 0vw;
    margin: auto;
    width: 40%;
    z-index: 0;
}

.section_short {
    min-height: 60vh !important;
}

.section_wide {
    width: 60%;
}

.alternative_background_color {
    background-color: #F9F9F9;
}

.repeater_box {
    display: flex;
    flex-direction: row;
    justify-content: center;
}

.repeater {
    align-items: center;
    background-color: #F4F4F4;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    padding: 5vh 2vw 7vh 2vw;
    overflow-wrap: break-word;
    margin: 5vh 3vw 5vh 3vw;
    width: 15vw;
}

.repeater_subsection_title {
    display: flex;
    margin: 5vh 0vw 0vh 0vw;
}


.repeater_description {
    align-items: center;
    display: flex;
    flex-direction: column;
    margin: 2vh 0vw 0vh 0vw;
    overflow-wrap: break-word;
    text-align: left;
}

.repeater_description ul {
    padding: 0vh 0vw;
}

.repeater_description ul {
    list-style-type: none;
}

.repeater_description ul li.repeater_point::before {
    content: "✔";
    margin: 0vh 0.5vw 0vh 0vw;
    color: green;
}

.repeater_point {
    color: var(--dark-color);
    font-family: var(--font-family);
    font-size: 0.8rem;
    font-weight: 500;
    margin: 0vh 0vw 2vh 0vw;
    opacity: 0.9;
    padding: 0vw 0vw 0vh 1vw;
    text-align: left;
}

.repeater_title {
    color: var(--dark-color);
    font-family: var(--font-family);
    font-size: 2.5rem;
    font-weight: 1000;
    margin: 2vh 2vw 2vh 2vw;
    opacity: 0.9;
}

.repeater_smalltext {
    color: var(--dark-color);
    font-family: var(--font-family);
    font-size: 0.8rem;
    font-weight: 750;
    opacity: 0.9;
    margin: 0vh 0vw 3vh 0vw;
}

.repeater_text {
    color: var(--dark-color);
    font-family: var(--font-family);
    font-size: 0.8rem;
    font-weight: 500;
    opacity: 0.9;
    text-align: center;
}

.circle_image {
    border-radius: 100%;
    height: 20vmin;
    filter: blur(0.5px);
    filter: grayscale(1);
    object-fit: cover;
    width: 20vmin;
}

.circle_image:hover {
    transform: scale(1.2);
    transition: 0.2s;
}

.cta_box {
    width: 100%;
}

.cta_button, .cta_button_2 {
  background-color: var(--main-color);
  border-radius: 50px;
  cursor: pointer;
  font-family: var(--font-family);
  font-size: 1.1rem;
  font-weight: 750;
  letter-spacing: 1px;
  margin-top: 2vh;
  padding: 2.5vh 2.5vw;
  transition: background-color 0.2s, color 0.2s, border-color 0.2s;
}

.cta_button {
    border: 2px solid var(--main-color);
    color: var(--almost-white);
}

.cta_button_2 {
    background-color: var(--almost-white);
    justify-self: flex-start;
    border: 2px solid var(--main-color);;
    color: var(--main-color);
}

.cta_button:hover {
    background-color: var(--almost-white);
    border: 2px solid var(--main-color);
    color: var(--main-color);
}

.cta_button_2:hover {
    background-color: var(--main-color);
    border: 2px solid var(--almost-white);
    color: var(--almost-white);
}

.tag_cloud {
    display: inline-flex;
}

.tag_button {
    background-color: var(--almost-white);
    border: 2px solid var(--main-color);
    border-radius: 50px;
    color: var(--main-color);
    cursor: pointer;
    font-family: var(--font-family);
    font-size: 0.75rem;
    font-weight: 750;
    letter-spacing: 1px;
    margin: 2vh 1vw;
    padding: 2vh 1.5vw;
    transition: background-color 0.2s, color 0.2s, border-color 0.2s;
    white-space: nowrap;
}

.function_button {
    background-color: var(--almost-white);
    border: 1px solid var(--dark-color);
    border-radius: 50px;
    color: var(--dark-color);
    cursor: pointer;
    font-family: var(--font-family);
    font-size: 0.75rem;
    font-weight: 750;
    letter-spacing: 1px;
    margin: 0vh 1vw 2vh 1vw;
    padding: 2vh 1.5vw;
    transition: background-color 0.2s, color 0.2s, border-color 0.2s;
    white-space: nowrap;
}

.function_button:hover {
    background-color: var(--dark-color);
    border: 1px solid var(--dark-color);
    border-radius: 50px;
    color: var(--almost-white);
    cursor: pointer;
    font-family: var(--font-family);
    font-size: 0.75rem;
    font-weight: 750;
    letter-spacing: 1px;
    margin: 0vh 1vw 2vh 1vw;
    padding: 2vh 1.5vw;
    transition: background-color 0.2s, color 0.2s, border-color 0.2s;
    white-space: nowrap;
}


.icon {
    height: 25px;
    width: 25px;
    opacity: 0.5;  
}

.icon_button {

}

.small {
    font-size: 0.75rem;
}

/*Navigation bar*/

.nav {
    background-color: white;
    height: 20vh;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 900;
}

.nav_background {
    align-items: flex-start;
    background-color: var(--almost-white);
    display: flex;
    height: 100vh;
    left: 0;
    max-height: 100vh;
    opacity: 0.9;
    position: fixed;  
    top: 0;
    width: 100vw;
    z-index: 900;
}

.nav_background.hidden {
    display: none;
}

.nav_list {
    height: 100vh;
    margin: 0vh 0vw 10vh 12vw;
    overflow-y: auto;
    padding: 20vh 0vw 10vh 0vw;
}

.nav_list {
    background-color: var(--almost-white);
    list-style: none;
    max-height: 100vh;
    width: 33vw;
    z-index: 1100;
}

.hidden {
    display: none;
}

.nav_list a, .menu_list a {
    color: var(--main-color) !important;
    font-size: 5vmin;
    text-decoration: none;
}

.nav_list a:hover, .menu_list a:hover, .menu_list li:hover {
    color: var(--main-color) !important;
    font-weight: bold;
}

.nav_list li, .menu_list li {
    color: var(--main-color) !important;
    font-size: 3vmin;
    margin: 0vh 0vw 2vh 0vw;
    text-decoration: none;
}

.nav_phrase {
    color: var(--main-color);
    font-family: var(--font-family);
    font-size: 1.2rem;
    font-weight: 1000;
    position: fixed;
    top: 8vh;
    right: 10vw;
    z-index: 1000;
}

.nav_phrase > .nav_phrase_mini {
    font-size: 0.8rem;
    font-weight: 100;
    text-align: right;
}

.icon_box {
    align-items: center;
    display: flex;
    flex-direction: row;
    height: 10vh;
    justify-content: center;
    margin: 5vh 0vw 0vh 10vw;
    position: fixed;
    width: 10vw;
    top: 0;
    z-index: 1000;
}

.hamburger_box {
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 3vw;
    z-index: 1000;
}

.hamburger {
    cursor: pointer;
    display: flex;
    height: 30px;
    margin: 3vh 0vw;
    position: relative;
    width: 30px;
    z-index: 1000;
}

.small_icon_full_strip {
    display: flex;
    height: 5vh;
    justify-content: flex-end;
    padding: 2vh 0vw;
    width: 60vw;
}

.small_icon_strip {
    position: relative;
    display: flex;
    height: 5vh;
    justify-content: flex-end;
    width: 100%;
    z-index: 10;
}

.small_icon_strip_left_strip {
    position: relative;
    display: flex;
    height: 5vh;
    justify-content: flex-start;
    padding: 2vh 1vw;
    width: 50%; 
}

.small_icon_strip_right_strip {
    position: relative;
    display: flex;
    height: 5vh;
    justify-content: flex-end;
    padding: 2vh 1vw;
    width: 50%;
}

.small_icon_box {
    align-items: center;
    background-color: var(--almost-white);
    border-radius: 50%;
    box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.5);
    color: var(--main-color);
    cursor: pointer;
    display: flex;
    font-size: var(--small-font);
    height: 35px;
    justify-content: center;
    margin: 0vh 0.5vw 0vh 0.5vw;
    min-width: 35px;
    width: 35px;
}

.small_icon_box_2 {
    align-items: center;
    background-color: var(--almost-white);
    border-radius: 50%;
    box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.5);
    cursor: pointer;
    display: flex;
    height: 20px;
    justify-content: center;
    margin: 0vh 0.5vw 0vh 0.5vw;
    min-width: 20px;
    width: 20px;
}

.small_icon_box.default_cursor {
    padding-left: -1px;
    cursor: default;
}

.small_icon_box.revert {
    background-color: var(--main-color);
}

.center > .small_icon_box {
    margin: 0;
}

.icon_box > .small_icon_box {
    margin: 0vh 0.5vw;
}

.invisible_small_icon_box {
    visibility: hidden;
}

.small_icon {
    border-radius: 50%;
    height: 15px;
    min-width: 15px;
    object-fit: cover;
    width: 15px;
}

.small_icon_2 {
    border-radius: 50%;
    height: 8px;
    min-width: 8px;
    object-fit: cover;
    width: 8x;
}

.small_icon_labels {
    border-radius: 50%;
    height: 70px;
    min-width: 35px;
    object-fit: cover;
    width: 70px;
}

.small_icon_initials {
    color: var(--main-color);
    cursor: default;
    font-family: var(--font-family);
    font-weight: 1000;
    padding-left: -1px;
    text-align: center;
}

.small_icon_initials_2 {
    background-color: var(--main-color);
    color: var(--almost-white);
    cursor: default;
    font-family: var(--font-family);
    font-weight: 1000;
    text-align: center;
}

/*Messages*/

.messages_container {
    position: relative;
    top: 20vh;
    z-index: 1000;
}

/*Effects*/

.fade_in {
  opacity: 0;
  transform: translateY(3rem);
  transition: opacity 1s ease, transform 1s ease;
  visibility: hidden;
}

.fade-out {
    animation: fadeOut 1s forwards;
}

@keyframes fadeOut {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
        visibility: hidden;
    }
}

.initial_fade_in {
  opacity: 0;
}

.initial_fade_in_loaded {
  opacity: 1;
  transition: opacity 1s ease, transform 1s ease;
}

/* Common classes */

.center {
    align-items: center;
    display: flex;
    justify-content: center;
}

.strip {
    height: 10vh;
}

.unselectable, .small_icon_box {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.errorlist {
    color: red;
    font-family: var(--font-family);
    font-size: 0.75rem;
    list-style: none;
    margin-bottom: -0.5vh;
    opacity: 0.95;
    padding: 0 2px;
    text-align: left;
    width: 30vw;
}

.import_section .cta_button_2:hover label {
    color: var(--almost-white);
}

.uppercase {
    text-transform: uppercase;
}

.buttons_container {
    align-items: center;
    display: flex;
    justify-content: center;
}

.buttons {
    display: flex;
    gap: 10px;
    justify-content: space-between;
}

.in_bold {
    font-weight: 1000;
}

.readonly {
    background-color: #e9ecef;
    cursor: default;
    pointer-events: none;
}

input.readonly {
    background-color: #e9ecef;
    cursor: default;
    pointer-events: none;
}

select.readonly {
    background-color: #e9ecef;
    cursor: default;
    pointer-events: none;
}

input[readonly],
textarea[readonly],
select[readonly] {
    background-color: #e9ecef;
    cursor: default;
    pointer-events: none;
}

.invisible {
    visibility: hidden;
}

.link {
    text-decoration: none;
}

.link:hover {
    font-weight: 1000;
}

.form_container {
    align-items: center;
    display: flex;
    gap: 1vw;
    justify-content: center;
    margin: auto;
    min-width: 100%;
}

.form_container form {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 48%;
}

.form_container form:first-child button {
    margin-left: auto;
}

.form_container form:last-child button {
    margin-right: auto;
}