/********** common setting **********/
* {
    direction: ltr;
    text-align: left;
}

h2 {
    font-size: 2.8rem !important;
    font-weight: 700;
}



img {
    display: block;
    max-width: 100%;
}

a,
button {
    cursor: pointer;
    color: white !important;
    text-decoration: underline !important;
}

html {
    width: 100%;
    height: 100%;
}

body {
    background-color: #f3f3f3;
    width: 100%;
    height: 100%;
}

.part_a {
    width: 59%;
    height: 100%;
    display: inline-block;
    vertical-align: top;
    float: left;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

.part_b {
    width: 40%;
    height: 100%;
    display: inline-block;
    vertical-align: top;
    text-align: center;
    float: right;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

.shape_a {
    background-color: #fead34;
    width: 13%;
    height: 75%;
    display: inline-block;
    border-top-left-radius: 10rem;
    border-top-right-radius: 10rem;
    position: absolute;
    bottom: 0;
    right: 21%;
}

.shape_a > div {
    background-color: #f0693b;
    width: 76%;
    height: 90%;
    border-radius: 10rem;
    vertical-align: top;
    text-align: center;
    margin: 12% auto 0 auto;
}

.shape_b {
    background-color: #000436;
    width: 13%;
    height: 85%;
    display: inline-block;
    border-bottom-left-radius: 10rem;
    border-bottom-right-radius: 10rem;
    position: absolute;
    top: 0;
    right: 14%;
}

.shape_b_1 {
    background-color: #3dbc6f;
    width: 76%;
    height: 46%;
    border-radius: 10rem;
    vertical-align: top;
    text-align: center;
    margin: 12% auto 0 auto;
}

.shape_b_2 {
    background-color: #fcc1ad;
    width: 76%;
    height: 46%;
    border-radius: 10rem;
    vertical-align: bottom;
    text-align: center;
    margin: 0% auto 0 auto;
}

.part_a_1 {
    width: 100%;
    height: 30%;
}

.hollow-semicircle {
    width: 100px;
    height: 50px;
    border: 25px solid #000436;
    border-radius: 100px 100px 0 0;
    border-bottom: none;
    background-color: transparent;
    transform: rotate(-40deg);
    margin-top: -12px;
    margin-left: 25px;
}

.hollow-semicircle2 {
    width: 100px;
    height: 50px;
    border: 25px solid #3DBC6F;
    border-radius: 100px 100px 0 0;
    border-bottom: none;
    background-color: transparent;
    transform: rotate(180deg);
    margin-top: -45px;
    margin-left: 800px;
}

.part_a_2 {
    width: 100%;
    height: 20%;
}

.part_a_2 .logo {
    width: 175px;
    height: auto;
    margin-left: 35%;
}

.part_a_2 > div {
    font-size: 30px;
    font-weight: 600;
    width: 422px;
    color: #000436;
    margin-left: 35%;
}

.part_a_2 > div > span {
    color: #3dbc6f;
}

.part_a_3 {
    width: 100%;
    height: 20%;
}

.part_a_4 {
    width: 100%;
    height: 15%;
}

.semicircle {
    width: 90px;
    height: 45px;
    background-color: #FCC1AD;
    border-radius: 100px 100px 0 0;
    position: relative;
    margin-left: 75%;
    transform: rotate(145deg);
}

.semicircle2 {
    width: 90px;
    height: 45px;
    background-color: #3dbc6f;
    border-radius: 100px 100px 0 0;
    transform: rotate(20deg);
    position: inherit;
    right: -15px;
    bottom: 0;
}


.part_a_5 {
    width: 100%;
    height: 15%;
    position: absolute;
    left: 0;
    bottom: 0;
    margin: 0;
    overflow: hidden;
}

.cube {
    position: inherit;
    width: auto;
    height: auto;
}

.cube .front {
    position: relative;
    top: 0px;
    left: 250px;
    width: 37px;
    height: 37px;
    background-color: #fead34;
}

.cube .back {
    position: relative;
    bottom: 70px;
    left: 214px;
    width: 73px;
    height: 35px;
    transform: rotateY(180deg);
    background-color: #fead34;
}

.cube2 {
    position: inherit;
    width: auto;
    height: auto;
    left: 0;
    bottom: 0;
}

.cube2 .front {
    position: relative;
    top: 0;
    left: 0;
    width: 35px;
    height: 35px;
    background-color: #F0693B;
}

.cube2 .back {
    position: relative;
    bottom: 0px;
    left: 0px;
    width: 75px;
    height: 35px;
    transform: rotateY(180deg);
    background-color: #F0693B;
}


.subscribe {
    text-align: center;
    width: fit-content;
    margin-left: 35%;
    padding-top: 2%;
}


.not-found {
    text-align: center;
    width: fit-content;
    margin-left: 35%;
    padding-top: 2%;
}


.c-checkbox {
  display: none;
}
.c-checkbox:checked + .c-formContainer .c-form {
  width: 37.5em;
}
.c-checkbox:checked + .c-formContainer .c-form__toggle {
  visibility: hidden;
  opacity: 0;
  transform: scale(0.7);
}
.c-checkbox:checked + .c-formContainer .c-form__input,
.c-checkbox:checked + .c-formContainer .c-form__buttonLabel {
  transition: 0.2s 0.1s;
  visibility: visible;
  opacity: 1;
  transform: scale(1);
}
/*.c-checkbox:not(:checked) + .c-formContainer .c-form__input:required:valid ~ .c-form__toggle::before, .c-checkbox:checked + .c-formContainer .c-form__input:required:valid ~ .c-form__toggle::before {
  content: "Will keep you posted 😊";
}*/
.c-checkbox:not(:checked) + .c-formContainer .c-form__input:required:valid ~ .c-form__toggle {
  pointer-events: none;
  cursor: default;
}

.c-formContainer,
.c-form,
.c-form__toggle {
    width: 20em;
    height: 6.25em;
    max-width: 280px;
    max-height: 60px;
}

.c-formContainer {
  position: relative;
  font-weight: 700;
}

.c-form,
.c-form__toggle {
  position: absolute;
  border-radius: 10rem;
  background-color: #fcc1ad;
  transition: 0.2s;
}

.c-form {
  left: 50%;
  transform: translateX(-50%);
  padding: 0.625em;
  box-sizing: border-box;
  box-shadow: 0 0.125em 0.3125em rgba(0, 0, 0, 0.3);
  display: flex;
  justify-content: center;
}

.c-form__toggle {
  color: #000436;
  top: 0;
  cursor: pointer;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-form__toggle::before {
  font-size: 15px;
    content: attr(data-title);
    font-weight: 600;
}

.c-form__input,
.c-form__button {
  font: inherit;
  border: 0;
  outline: 0;
  border-radius: 5em;
  box-sizing: border-box;
}

.c-form__input,
.c-form__buttonLabel {
  font-size: 1.75em;
  opacity: 0;
  visibility: hidden;
  transform: scale(0.7);
  transition: 0s;
}

.c-form__input {
    color: #000436;
    height: 100%;
    width: 100%;
    padding: 0 0.714em;
    font-size: 15px;
    font-weight: 600;
    border-radius: 10rem;
}
.c-form__input::placeholder {
  color: currentColor;
}
.c-form__input:required:valid {
  color: #3dbc6f;
}
.c-form__input:required:valid + .c-form__buttonLabel {
  color: #ffffff;
}
.c-form__input:required:valid + .c-form__buttonLabel::before {
  pointer-events: initial;
}

.c-form__buttonLabel {
    color: #000436;
    height: 100%;
    width: auto;
}
.c-form__buttonLabel::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  pointer-events: none;
  cursor: pointer;
}

.c-form__button {
    color: inherit;
    padding: 0;
    height: 100%;
    width: 70px;
    background-color: #000436;
    border-radius: 10rem;
    max-width: 65px;
    font-size: 15px;
    text-decoration: none !important;
    font-weight: 600;
    text-align: center;
    vertical-align: top;
}

.c-form__input::placeholder {
    color: #9d9d9d;
}

.error_message_div {
    display: none;
    margin: 15px 0px 0px 25px;
    color: #bc0000;
    font-weight: 500;
}

#success_message {
    display: none;
    color: #000436;
    font-weight: 500;
    width: 100%;
    transition: 0.2s;
    text-align: center;
    margin-top: 9px;
}

.c-form__button:focus {
    outline: none !important;
}


@media only screen and (max-width: 768px) {
    * {
        width: 100%;
        height: 100%;
    }
    
    .semicircle2, .part_a_4 > .cube, .hollow-semicircle2 {
        display: none;
    }
    
    .part_a {
        width: 73%;
    }
    
    .part_b {
        width: 27%;
    }
    
    .shape_a {
        width: 20%;
        height: 78%;
        right: 4%;
        bottom: 0;
    }
    
    .shape_b {
        width: 70%;
        height: 90%;
        right: -45%;
        position: relative;
    }
    
    .cube2 .front {
        width: 30px;
        height: 30px;
    }
    
    .cube2 .back {
        width: 60px;
        height: 30px;
    }
    
    .semicircle {
        margin-left: 60%;
        margin-top: 20%;
    }
    
    .part_a_2 .logo {
        width: 125px;
        margin-left: 8%;
    }
    
    .part_a_2 div {
        margin-left: 8%;
        font-size: 18px;
        max-width: 100%;
    }
    
    .subscribe {
        margin-left: 8%;
    } 
    
    .not-found {
        margin-left: 8%;
    } 
    
    .c-formContainer, .c-form, .c-form__toggle {
        max-width: 240px;
    }
    
    .c-form__button, .c-form__toggle::before, .c-form__input {
        font-size: 13px;
    }
    
    .error_message_div {
        margin: 15px 0px 0px 20px;
    }

}