:root {
    --rouge: #d41f2a;
}

.highlighted * {
    color: var(--rouge);
}

* {
    font-family: 'Open Sans';
    font-weight: 400;
    font-size: 0;
    outline: none;
    margin: 0;
    padding: 0;
}

.layout-root {
    margin-left: auto;
    margin-right: auto;
    max-width: 900px;
    padding-left: 20px;
    padding-right: 20px;
}

.layout-global-head {
    margin-top: 40px;
    margin-bottom: 50px;
}

.layout-global-head h1 {
    font-size: 40px;
    font-weight: 600;
    line-height: 1.15;
    margin-bottom: 30px;
}

.layout-global-head h2 {
    font-size: 28px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: -0.02em;
    margin-bottom: 10px;
    color: var(--rouge);
}

.layout-global-head p {
    font-size: 18px;
    line-height: 1.4;
    margin-bottom: 10px;
}

.layout-global-head p a {
    font-size: inherit;
    color: var(--rouge);
}

.layout-global-head p strong {
    font-size: inherit;
    font-weight: 600;
}


.layout-form {}


span.required {
    display: inline-block !important;
    color: var(--rouge);
    margin-left: 5px;
    line-height: 1;
    width: 5px;
    font-size: 18px;
    text-align: right;
    font-weight: 700;
}

.layout-part {
    margin-bottom: 80px;
}

.layout-head {
    margin-bottom: 40px;
    border-top: 1px solid #000;
    padding-top: 20px;
    margin-top: 40px;
}

.layout-head h2 {
    font-size: 30px;
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1.1;
}

.layout-head h3 {
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.01em;
}

.layout-head p {
    font-size: 16px;
    margin-top: 5px;
    line-height: 1.2;
}

.layout-body {}

.layout-body p {
    margin-bottom: 20px;
}

.layout-body .layout-note {
    font-size: 18px;
    margin-top: 40px;
    margin-bottom: 40px;
}

.layout-body .layout-note strong {
    font-size: inherit;
    font-weight: 600;
}

.layout-body p label {
    display: inline-block;
    position: relative;
    vertical-align: top;
    font-size: 18px;
    margin-right: 10px;
    width: 250px;
    font-weight: 500;
    letter-spacing: -0.01em;
    line-height: 1.2;
}

.layout-body p label span {
    display: block;
    font-size: 14px;
    margin-top: 4px;
}


.layout-body p label strong {
    font-size: inherit;
    font-weight: 700;
}


.layout-body p input[type="text"],
.layout-body p input[type="tel"],
.layout-body p input[type="url"],
.layout-body p input[type="number"],
.layout-body p input[type="email"],
.layout-body p input[type="date"],
.layout-body p select {
    display: inline-block;
    vertical-align: top;
    width: calc(100% - 290px);
    border: 1px solid #ccc;
    font-size: 16px;
    height: 40px;
    line-height: 40px;
    padding: 0px 5px;
    background-color: #fff;
}


.layout-body p select {
    width: calc(100% - 278px);
    background-color: #fff;
}

.layout-body p select option {
    font-size: inherit;
}


.layout-body .layout-check-list {}

.layout-body .layout-check-list p {}

.layout-body .layout-check-list p input[type="checkbox"] {
    display: inline-block;
    position: relative;
    vertical-align: top;
    margin-right: 20px;
    width: 20px;
    height: 20px;
    border: 1px solid #ccc;
}

.layout-body .layout-check-list p label {
    width: calc(100% - 50px);
}


.layout-body .layout-radio-list {}

.layout-body .layout-radio-list p {}

.layout-body .layout-radio-list p input[type="radio"] {
    display: inline-block;
    position: relative;
    vertical-align: top;
    margin-right: 20px;
    width: 20px;
    height: 20px;
    border: 1px solid #ccc;
}

.layout-body .layout-radio-list p label {
    width: calc(100% - 50px);
}


.layout-body .layout-fit-content label {
    width: fit-content;
}

.layout-body .layout-fit-content input[type="text"],
.layout-body .layout-fit-content input[type="number"] {
    width: fit-content;
}

.layout-body .layout-billing-details {
    display: none;
    margin-top: 50px;
    border: 1px dashed #ccc;
    padding: 30px;
    border-radius: 10px;
}

.layout-body .layout-cancelation-policy {}

.layout-body .layout-cancelation-policy h3 {
    font-size: 25px;
    font-weight: 600;
    color: var(--rouge);
}

.layout-body .layout-cancelation-policy p {
    font-size: 18px;
}

.layout-body .layout-list {
    margin-top: 30px;
    margin-bottom: 30px;
}

.layout-body .layout-list ul {
    margin-left: 20px;
}

.layout-body .layout-list li {
    font-size: 18px;
    margin-bottom: 20px;
}

.layout-body .layout-list strong {
    font-size: inherit;
    font-weight: 700;
}

.layout-body .layout-date select {
    width: calc((100% - (3 * 10px)) / 3);
    margin-right: 10px;
    font-size: 16px;
    padding: 5px;
}

.layout-body .layout-date select option {
    font-size: inherit;
}

.layout-body .layout-date input[type="date"] {
    font-size: 18px;
    max-width: 200px;
}


.layout-body .layout-submit {
    margin-top: 40px;
    margin-bottom: 50px;
}


.layout-body .layout-submit button {
    display: inline-block;
    position: relative;
    border: none;
    font-size: 18px;
    background-color: var(--rouge);
    color: #fff;
    padding: 10px 100px;
    border-radius: 5px;
    cursor: pointer;
}


.layout-categories {}

.layout-categories .layout-part {
    border: 1px dashed #ccc;
    padding: 30px;
    border-radius: 10px;
    margin-bottom: 30px;
    margin-top: 30px;
}

.layout-categories .layout-head {
    border-top: none;
    padding-top: 0px;
    margin-top: 0px;
    margin-bottom: 30px;
}

.layout-categories .layout-head h3 {}


.layout-body .layout-commitment .layout-check-list p input[type="checkbox"] {
    margin-right: 0;
}

.layout-body .layout-commitment .layout-check-list p label {
    width: calc(100% - 80px);
    margin-left: 10px;
    line-height: 1.4;
}

.layout-body .layout-commitment p label span {
    display: inline;
    font-size: inherit;
    font-weight: 700;
    color: var(--rouge);
}

.layout-body  .layout-standard-paragraph {margin-bottom: 40px;}

.layout-body  .layout-standard-paragraph  p {
    font-size: 18px;
    margin-bottom: 10px;
}

.layout-body .layout-standard-paragraph p a {
    font-size: inherit;
    color: var(--rouge);
}

.layout-body  .layout-standard-paragraph  p strong {
    font-size: 18px;
    margin-bottom: 10px;
    font-weight: 600;
}

.layout-message {
    display: flex;
    padding: 25px;
    background-color: #eeeeee;
    margin-top: 30px;
    flex-direction: row;
    justify-content: center;
    border-radius: 5px;
}

.layout-message p {
    font-size: 16px;
    font-weight: 600;
    color: var(--rouge);
    margin-bottom: 0;
}

.layout-message:empty {
    display: none;
}


.layout-confirm p {
    font-size: 16px;
    margin-bottom: 10px;
}

.layout-confirm p strong {
    font-size: inherit;
    font-weight: 600;
}

.layout-confirm p span {
    font-size: inherit;
}

.layout-confirm .layout-part {
    padding-top: 20px;
    border-top: 1px solid #000;
    margin-bottom: 30px;
}

.layout-confirm .layout-part h3 {
    font-size: 25px;
    font-weight: 600;
    line-height: 1.1;
    margin-bottom: 10px;
}

.layout-submit a {
    text-decoration: none;
    margin-right: 20px;
    display: inline-block;
    position: relative;
    border: none;
    font-size: 18px;
    background-color: var(--rouge);
    color: #fff;
    padding: 10px 0px;
    border-radius: 5px;
    cursor: pointer;
    margin-bottom: 10px;
    width: 300px;
    text-align: center;
}

.layout-submit {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.layout-submit a:first-child {
    background-color: #acacac;
}

@media screen and (max-width: 600px) {

    .layout-body p label {
        width: 100%;
        margin-bottom: 10px;
    }

    .layout-body p input[type="text"],
    .layout-body p input[type="tel"],
    .layout-body p input[type="url"],
    .layout-body p input[type="email"] {
        width: calc(100% - 22px);
    }

    .layout-body p select {
        width: calc(100% - 10px);
    }

}