.section-contact.is-wide {
    width: 100%;
}

.section-contact-container {
    /* 600px = 37.5rem */
    max-width: calc(600 / 16 * 1rem);
    width: 90%;
    margin: 0 auto;
    padding: 0 var(--space-xl);
}

.section-contact {
    position: relative;
    margin: var(--space-sm) auto 0 auto;
    width: auto;
    border: calc(1 / 16 * 1rem) solid var(--color-section-contact-border);
    background-color: var(--source-color-white-transparent) !important;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-z2);
    padding: var(--space-lg) var(--space-xl);
}

h1 {
    font-size: var(--font-size-xl);
    color: var(--color-contact-h1);
    margin-left: 0 !important;
    font-weight: var(--fw-bold);
    margin-bottom: var(--space-xxl);
    border-bottom: calc(2 / 16 * 1rem) solid var(--color-contact-h1-border);
    display: inline-block;
    padding-bottom: var(--space-xs);
    /* 2px = 0.125rem */
    letter-spacing: calc(2 / 16 * 1rem);
}
.form-group {
    margin-bottom: var(--space-xl);
    display: flex;
    flex-direction: column;
}

label {
    /* -15px = -0.9375rem */
    margin-top: calc(-15 / 16 * 1rem);
    color: var(--color-contact-label);
    font-weight: var(--fw-bold);
    margin-bottom: var(--space-xxs);
    font-size: var(--font-size-contact-label);
    text-transform: uppercase;
}

input[type="text"],
input[type="email"],
textarea {
    width: 100%;
    /* 7px = 0.4375rem */
    padding: calc(7 / 16 * 1rem);
    border: calc(1 / 16 * 1rem) solid #cccccc;
    background-color: var(--color-not-white);
    border-radius: var(--radius-md);
    font-size: var(--font-size-textarea);
    box-sizing: border-box;
}

textarea {
    resize: vertical;
    /* 150px = 9.375rem */
    min-height: calc(150 / 16 * 1rem);
    background-color: var(--color-not-white);
    font-size: var(--font-size-md);
    font-family: 'Roboto', 'Helvetica Neue', Arial, sans-serif;
}

input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus {
    margin-top: var(--space-xs) !important;
    margin-bottom: 0 !important;
    border-color: var(--source-color-accent-one);
    outline: none;
    /* 3px = 0.1875rem */
    box-shadow: 0 0 0 calc(3 / 16 * 1rem) var(--color-contact-textarea-focus-box-shadow);
    background-color: var(--color-not-white) !important;
}

.error-message {
    color: var(--color-error);
    font-size: var(--font-size-contact-error-message);
    margin-top: 0 !important;
    /* 3px = 0.1875rem */
    margin-bottom: calc(3 / 16 * 1rem) !important;
    font-weight: var(--fw-bold);
    /* -0.5px = -0.03125rem */
    letter-spacing: calc(-0.5 / 16 * 1rem);
}

.is-error {
    border: calc(1 / 16 * 1rem) solid var(--color-error) !important;
}

input.is-error,
textarea.is-error {
    background-color: var(--color-not-white) !important;
}

button[type="submit"] {
    padding: var(--space-md);
    cursor: pointer;
    text-transform: uppercase;
    justify-content: center;
    align-items: center;
    display: flex;
    line-height: 1;
    box-sizing: border-box;
    margin: 0;
}

p[style*="color: green"],
p[style*="color: red"] {
    padding: var(--space-md);
    border-radius: var(--radius-md);
    text-align: center;
    margin-top: var(--space-xl) !important;
    margin-bottom: var(--space-xl) !important;
}

p[style*="color: green"] {
    background-color: var(--color-success-bg);
    border: calc(2 / 16 * 1rem) solid var(--color-success-border);
    color: var(--color-success) !important;
}

p[style*="color: red"] {
    background-color: var(--color-error-bg);
    border: calc(2 / 16 * 1rem) solid var(--color-error-border);
    color: var(--color-error) !important;
}

.contact-header-wrap {
    position: relative;
}
.contact-header-wrap h1 {
    /* 1.4rem = 22.4px */
    font-size: calc(22.4 / 16 * 1rem);
}
.contact-icon-box {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 0;
    pointer-events: none;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-title-icon-container-bg);
    /* 64px = 4rem */
    width: calc(64 / 16 * 1rem);
    height: calc(64 / 16 * 1rem);
    /* 50px = 3.125rem */
    border-radius: calc(50 / 16 * 1rem);
    border: solid var(--color-border-main) calc(2 / 16 * 1rem);
}

.contact-icon {
    /* 35px = 2.1875rem */
    width: calc(35 / 16 * 1rem);
    height: calc(35 / 16 * 1rem);
}

/* ================================================= */
/* === MODE SOMBRE === */
/* ================================================= */
html[data-theme="dark"] .section-contact {
    background-color: black !important;
}

html[data-theme="dark"] label {
    color: lightgrey;
    font-weight: var(--fw-normal);
}

html[data-theme="dark"] input[type="text"],
input[type="email"],
textarea {
    width: 100%;
    /* 7px = 0.4375rem */
    padding: calc(7 / 16 * 1rem);
    border: calc(1 / 16 * 1rem) solid #cccccc;
    background-color: #8c8c8c;
    border-radius: var(--radius-md);
    font-size: var(--font-size-textarea);
    box-sizing: border-box;
}

html[data-theme="dark"] .error-message {
    color: #ff7777;
    font-weight: normal;
}

html[data-theme="dark"] h1 {
    border-bottom: calc(1 / 16 * 1rem) solid var(--color-contact-h1-border);
}