* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Gilroy', sans-serif;
    background-color: #FFFFFF;
    color: #333;
    line-height: 1.6;
    font-weight: 500;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

.container {
    max-width: 1180px;
    margin: auto;
}

.hero-area {
    background: url('../img/hero.jpg') no-repeat center bottom / cover;
    padding: 50px 0;
    position: relative;
}

.hero-top {
    text-align: center;
}

.hero-top h1 {
    color: #FFFCDC;
    text-transform: uppercase;
    font-size: 85px;
    margin: 0;
    padding: 0;
    font-family: 'Gilroy', sans-serif;
    text-shadow: 0 0 10px rgba(0, 0, 0, 0.9), 0 0 20px rgb(251 169 56 / 80%), 0 0 30px rgb(255 229 154);
    letter-spacing: 2px;
    line-height: 85px;
}

.hero-top .sub-title {
    color: #FFFCDC;
    font-size: 46px;
}

.hero-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: center;
    padding: 50px 0;
    min-height: 1200px;
}

.hero-footer h2 {
    font-weight: 700;
    color: #fff;
    font-size: 35px;
    line-height: 50px;
}

.hero-footer p {
    color: #FBA41C;
    font-size: 26px;
    margin: 0;
}

.hero-footer p:first-child {
    letter-spacing: 5px;
}

.hero {
    display: flex;
    flex-direction: column;
    height: 1200px;
    justify-content: space-between;
    padding: 50px;
}

.project-area {
    background: #231F20;
    border-top: 2px solid #fff;
    padding: 15px 0;
}

.project-list {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.project-list img {
    max-width: 170px;
    max-height: 100px;
}

.video-area {
    background: #FBA41C;
    padding: 100px 0;
}

.video-box video {
    border: 3px solid #231F20;
    border-radius: 40px;
    max-width: 750px;
}

.video-box {
    text-align: center;
    margin: 0 0 40px;
}

.video-text {
    text-align: center;
    color: #231F20;
    font-size: 40px;
    font-weight: 600;
}

.adopt-area {
    border-top: 2px solid #FDBD60;
    background: #fff;
    position: relative;
    padding: 50px 0 100px;
}

.adopt-area::after {
    content: "";
    background: var(--bg-url) no-repeat center top / cover;
    position: absolute;
    inset: 0;
    opacity: 0.8;
}

.adopt-list {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    min-height: 520px;
    position: relative;
    z-index: 1;
}

.adopt-item {
    background: #231F20;
    color: #fff;
    font-weight: 600;
    font-size: 30px;
    border: 3px solid #FBA41C;
    padding: 0 20px 0 0;
    border-radius: 50px;
    letter-spacing: 2px;
    text-transform: uppercase;
    width: fit-content;
    display: flex;
    align-items: center;
}

.adopt-number {
    background: #FBA41C;
    color: #231F20;
    font-weight: 900;
    width: 55px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 50px;
    border: 4px solid #231F20;
    height: 55px;
    position: relative;
    left: -7px;
    font-size: 35px;
}

.adopt-list .adopt-item:nth-child(2) {
    margin-top: auto;
    margin-bottom: 100px;
}

.join-area {
    background: #FBA41C;
    padding: 60px 0 0;
    position: relative;
    text-align: center;
}

.join-box p {
    font-size: 36px;
    font-weight: 600;
    color: #231F20;
}

.join-box h2 {
    color: #231F20;
    border: 5px solid #231F20;
    border-radius: 50px;
    width: 145px;
    font-weight: 900;
    font-size: 35px;
    padding: 0px 20px;
    letter-spacing: 3px;
    margin: 25px auto 0;
    position: relative;
    bottom: -27px;
    background: #FBA41C;
    z-index: 2;
    line-height: 45px;
}

.join-form-area,
.shabbat-list-area {
    padding: 70px 0;
}

.shabbat-list {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-gap: 10px 5px;
}

.shabbat-card {
    overflow: hidden;
}

.shabbat-card img {
    transition: transform 0.3s ease;
}

.shabbat-card img:hover {
    transform: scale(1.1) translateY(10px);
}

.footer-bottom {
    text-align: center;
    margin-top: 60px;
}

.btn-primary,
.page-template-template-home .gform_wrapper.gravity-theme .gform_footer input {
    background: #FBA41C;
    color: #200200;
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 700;
    padding: 15px 25px;
    border-radius: 10px;
    box-shadow: inset 5px 6px 7px rgba(255, 255, 255, 0.5), inset -2px -2px 6px rgba(0, 0, 0, 0.5);
    font-size: 18px;
    transition: 0.3s ease;
    display: inline-block;
}

.btn-primary:hover,
.page-template-template-home .gform_wrapper.gravity-theme .gform_footer input:hover {
    background: #E82B25;
    color: #fff;
}

.shb-step.adopt-item {
    position: relative;
    left: -40px;
    margin: 50px 0 20px;
}

.description-custom,
.page-template-template-home .gform_wrapper.gravity-theme legend.gfield_label.gfield_label_before_complex {
    color: #343233 !important;
    font-size: 24px;
    font-weight: 600;
    margin: 0 0 50px;
}

.page-template-template-home .gform_wrapper.gravity-theme legend.gfield_label.gfield_label_before_complex {
    margin: 0;
}

.description-custom span {
    color: #D43431;
}

.page-template-template-home .gform_wrapper.gravity-theme input {
    border: 1px solid #435560 !important;
    border-radius: 0;
}

.page-template-template-home .gform_wrapper.gravity-theme .gfield_label {
    color: #585D62 !important;
    font-weight: 500;
}

.join-form-area .container {
    max-width: 1000px;
}

.page-template-template-home .link-email {
    color: #499EC7;
}

.page-template-template-home .gform_wrapper.gravity-theme .gform_footer input {
    letter-spacing: 2px;
    border: 0 !important;
    cursor: pointer;
}

.page-template-template-home .gform_footer.top_label {
    justify-content: center;
}

.page-template-template-home .gfield.field_description_below {
    display: flex !important;
    flex-direction: column;
}

.page-template-template-home .gfield_description {
    order: 2;
    color: #e5321f;
    margin: 0px 0 20px !important;
    padding: 0 !important;
}

.page-template-template-home .ginput_container {
    order: 3;
}

.page-template-template-home .gfield_checkbox li {
    display: flex;
    align-items: center;
    gap: 10px;
}

.page-template-template-home .gfield_checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: 2px solid #000;
    background: #f5b21a;
    display: inline-grid;
    place-content: center;
    margin: 7px 0px 0;
    cursor: pointer;
    position: relative;
    transition: filter .15s ease, transform .05s ease;
}

.page-template-template-home .gfield_checkbox input[type="checkbox"]::after {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #000;
    transform: scale(0);
    transition: transform .12s ease-in-out;
}

.page-template-template-home .gfield_checkbox input[type="checkbox"]:checked::after {
    transform: scale(1);
}

.page-template-template-home .gfield_checkbox input[type="checkbox"]:hover {
    filter: brightness(1.03);
}

.page-template-template-home .gfield_checkbox input[type="checkbox"]:active {
    transform: scale(.96);
}

.page-template-template-home .gfield_checkbox input[type="checkbox"]:focus-visible {
    outline: 3px solid #000;
    outline-offset: 3px;
}

.page-template-template-home .gfield_checkbox input[type="checkbox"]:disabled {
    opacity: .5;
    cursor: not-allowed;
}

.page-template-template-home .gchoice {
    margin-bottom: 10px;
    display: flex;
    gap: 8px;
}

.page-template-template-home .gchoice label {
    font-size: 18px !important;
}

.page-template-template-home .gform_wrapper.gravity-theme #field_7_10 legend.gfield_label.gfield_label_before_complex {
    color: #D32C2E !important;
    margin: 0 0 20px;
}

.page-template-template-home div#field_7_15 {
    display: flex;
    justify-content: center;
}

.page-template-template-home select#input_7_15 {
    border: 2px solid #231F20;
    text-align: center;
    cursor: pointer;
    border-radius: 50px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 25px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='800' viewBox='0 0 30.727 30.727'><path d='M29.994,10.183L15.363,24.812L0.733,10.184c-0.977-0.978-0.977-2.561,0-3.536c0.977-0.977,2.559-0.976,3.536,0 l11.095,11.093L26.461,6.647c0.977-0.976,2.559-0.976,3.535,0C30.971,7.624,30.971,9.206,29.994,10.183z' fill='%23000'/></svg>") no-repeat right 15px center / 20px;
}

.page-template-template-home .bring-wrapper {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-gap: 50px;
}

.page-template-template-home #field_7_8 .preview {
    border: 1px solid #231F20;
    position: relative;
    top: -80px;
    padding: 30px 20px 0;
}

.admin-hidden-markup {
    display: none;
}

#field_7_20,
#field_7_21,
#field_7_23,
#field_7_25 {
    flex-direction: row-reverse;
    gap: 10px;
    width: 100px;
}

#field_7_23 {
    width: 100%;
    justify-content: flex-end;
}

#field_7_20 input,
#field_7_21 input,
#field_7_23 input,
#field_7_25 input {
    width: 100%;
    padding: 0;
    border-width: 0 0 1px !important;
    margin: 0 !important;
}

#field_7_20 .gfield_description,
#field_7_21 .gfield_description,
#field_7_23 .gfield_description,
#field_7_25 .gfield_description {
    color: #333;
    font-size: 18px !important;
    margin: 0 !important;
}

input:focus {
    outline: 0;
    box-sizing: 0 0 0;
}

div#field_7_24 {
    margin-top: 30px;
}

.gfield_select option:disabled {
    color: #df1c1c;
}

div#field_7_27 {
    flex-direction: column-reverse;
    gap: 15px;
    margin-top: 30px;
}

div#field_7_27 .gfield_description {
    color: #000;
}

@media screen and (max-width: 1150px) {
    .container {
        max-width: 90%;
    }

    .join-form-area .container {
        max-width: 80%;
    }
}

@media screen and (max-width: 991px) {
    .hero-top h1 {
        font-size: 65px;
    }

    .hero-top .sub-title {
        font-size: 36px;
    }

    .hero {
        height: 730px;
    }

    .hero-footer {
        min-height: 320px;
    }

    .project-list img {
        max-width: 120px;
        max-height: 65px;
    }

    .shabbat-list {
        grid-template-columns: repeat(4, 1fr);
    }

    .join-form-area .container {
        max-width: 90%;
    }

    .shb-step.adopt-item {
        left: 0;
    }
}

@media screen and (max-width: 767px) {
    .hero-top h1 {
        font-size: 30px;
        line-height: 33px;
    }

    .hero-top .sub-title {
        font-size: 18px;
    }

    .hero-footer {
        flex-direction: column;
        gap: 50px;
        min-height: auto;
        margin-top: auto;
    }

    .hero {
        padding: 0;
        height: 560px;
        position: relative;
        z-index: 2;
    }

    .hero-area:after {
        content: "";
        position: absolute;
        background: #000;
        inset: 0;
        opacity: .5;
    }

    .project-list img {
        max-width: 70px;
        max-height: 40px;
    }

    .video-area,
    .adopt-area,
    .join-form-area,
    .shabbat-list-area {
        padding: 50px 0;
    }

    .video-text,
    .join-box p {
        font-size: 18px;
    }

    .video-box {
        margin-bottom: 20px;
    }

    .video-box video {
        border-radius: 20px;
    }

    .adopt-item {
        font-size: 20px;
        display: flex;
        align-items: center;
        letter-spacing: 0;
    }

    .adopt-number {
        width: 70px;
        height: 70px;
    }

    .adopt-text {
        flex: 1;
    }

    .adopt-list {
        min-height: 450px;
    }

    .join-box h2 {
        font-size: 30px;
        border-width: 3px;
        margin-top: 0;
    }

    .shabbat-list {
        grid-template-columns: repeat(3, 1fr);
    }

    .btn-primary {
        font-size: 16px;
    }

    .page-template-template-home .bring-wrapper {
        grid-template-columns: 1fr;
        grid-gap: 0;
    }

    .page-template-template-home #field_7_8 .preview {
        top: 0;
    }

    #field_7_20 input,
    #field_7_21 input {
        position: relative;
        top: -9px;
    }

    .hero-footer h2 {
        font-size: 24px;
        line-height: 32px;
    }
}