html, body {
  margin: 0;
  padding: 0;
}

@media (max-width: 1200px) {
  header {
    text-align: center;
    padding: 1em 0;
  }
  header img {
    width: 60%;
  }
  ul, ol {
    padding-inline-start: 1em;
  }
  footer {
    margin-top: 2em;
  }
}
@media (min-width: 1200px) {
  header {
    padding: 1em 2em;
  }
  footer {
    margin-top: 3em;
  }
}
footer {
  width: 100%;
  text-align: center;
}

#term-link {
  color: #1eb9ee;
  text-decoration: none;
}

#term-link p {
  margin-top: 1em;
}

footer #copyright-cover {
  background-color: #044f81;
}

footer #copyright-text {
  padding: 0.5em 0;
  font-size: 16px;
  color: #FFFFFF;
}

.page-title-cover {
  width: 100%;
  background: linear-gradient(to right, #0a71cd, #52c1e7);
  color: #FFFFFF;
  text-align: center;
  padding: 1.2em 0;
}

@media (max-width: 1200px) {
  .content {
    width: 90%;
  }
  .content h1 {
    margin-top: 1em;
  }
  li {
    margin: 0.5em 0;
  }
  .cta-cover {
    padding: 1em 0;
  }
  .cta2-cover {
    font-size: 18px;
  }
  .cta-button {
    padding: 1em;
    margin: 0.5em 2em 0;
    font-size: 4vw;
  }
  .cta .cta-text {
    font-size: 6vw;
  }
  footer img {
    width: 90%;
  }
}
@media (min-width: 1200px) {
  .content {
    width: 70%;
  }
  .page-title-cover {
    font-size: 42px;
  }
  .message-cover {
    font-size: 42px;
  }
  .cta-cover {
    margin-top: 3em;
    padding: 2em 0;
    display: flex;
  }
  .cta2-cover {
    display: flex;
  }
  .cta-content {
    display: flex;
  }
  .cta-button {
    margin: 0 2em;
  }
  .cta .cta-button {
    padding: 2em;
  }
  .terms-abstract {
    font-size: 24px;
    margin: 4em 0;
  }
  .cta .cta-text-small {
    font-size: 40px;
  }
  .cta .cta-text-large {
    font-size: 52px;
  }
  .cta .free-attention {
    font-size: 30px;
  }
  .cta .button-text {
    font-size: 40px;
  }
  #term-link {
    font-size: 24px;
  }
}
.content {
  margin: 0 auto;
}

.terms-abstract {
  color: #0973ba;
  font-weight: 550;
}

.end-term {
  text-align: right;
}

.cta {
  width: 100%;
}

.cta-cover {
  width: 100%;
  text-align: center;
  background-image: url("https://d54q1bdp9407m.cloudfront.net/images/cta_bg.png?version=S5TjTV_.ufMlA6lFKCFQ..beT3_5Mr8w");
  background-repeat: no-repeat;
  background-size: cover;
}

.cta2-cover {
  width: 100%;
  padding: 5em 0;
  text-align: center;
  background-image: url("https://d54q1bdp9407m.cloudfront.net/images/cta_bg.png?version=S5TjTV_.ufMlA6lFKCFQ..beT3_5Mr8w");
  background-repeat: no-repeat;
  background-size: cover;
}

.cta-content {
  margin: auto;
}

.cta .cta-text-small {
  width: 100%;
  color: #FFFFFF;
}

.cta .cta-text-large {
  width: 100%;
  color: #FFFFFF;
}

.cta .cta-button {
  background-color: #dd0024;
}

.cta .cta-link {
  text-decoration: none;
  font-weight: 550;
}

.cta .free-attention {
  background-color: #FFFFFF;
  color: #dd0024;
  padding: 0.2em;
}

.cta .button-text {
  background-color: #dd0024;
  color: #FFFFFF;
}

@media (max-width: 1200px) {
  .message-cover {
    margin: 2em 0.5em;
    padding: 3em 1em;
  }
  .quotation-flow-title-ja {
    font-size: 5vw;
    margin-bottom: 1em;
  }
}
@media (min-width: 1200px) {
  .message-cover {
    margin: 2em 3em;
    padding: 1.5em 3em;
  }
  .quotation-flow-title {
    margin: 1em 0 2em;
  }
  .quotation-flow-title-ja {
    font-size: 42px;
  }
}
@media (min-width: 1200px) {
  .quotation-flow-step {
    width: 23%;
    padding: 2em 2em 1.5em;
    gap: 2em;
  }
  .quotation-flow-step-title {
    font-size: 28px;
  }
  .quotation-flow-description {
    font-size: 22px;
    gap: 3em;
  }
  .return-top-button {
    margin: 1em auto 0.5em;
    font-size: 32px;
    width: 15%;
  }
}
@media (max-width: 1200px) {
  .quotation-flow-step {
    width: 80%;
    padding: 0.5em;
    gap: 1em;
  }
  .quotation-flow-step img {
    width: 45%;
  }
  .quotation-flow-description {
    gap: 1em;
  }
  .return-top-button {
    margin: 1em 6em 0em;
  }
  .quotation-flow-step-title {
    width: 60vw;
    margin: 0 auto;
    font-size: 4vw;
  }
  .quotation-flow-step-description {
    font-size: 4vw;
  }
}
.message-cover {
  background-color: #0972cd;
  color: #ffffff;
  text-align: center;
}

.quotation-flow-cover {
  background-color: #dbe8ec;
  padding: 2em 0;
}

.quotation-flow-title {
  width: 100%;
  text-align: center;
}

.quotation-flow-title-en {
  color: #71b9d8;
  font-size: 24px;
  font-weight: bold;
}

.quotation-flow-title-ja {
  color: #166bb3;
  font-weight: bold;
}

.quotation-flow-description {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.quotation-flow-step {
  background-color: #FFFFFF;
  text-align: center;
  display: flex;
  flex-direction: column;
}

.quotation-flow-step-title {
  background-color: #0973ba;
  color: #ffffff;
  padding: 0.5em;
  border-radius: 2em;
  font-weight: bold;
}

.quotation-flow-image-container {
  overflow: hidden;
  height: 100%;
  margin: 0;
}

.quotation-flow-step img {
  object-fit: fill;
}

.quotation-flow-step-description {
  color: #0973ba;
}

.return-top-link {
  text-decoration: none;
}

.return-top-button {
  padding: 0.75em 1em;
  text-align: center;
  background-color: #dd0024;
  color: #ffffff;
  font-weight: bold;
}

.top-cover {
  display: flex;
  overflow-wrap: break-word;
}

.message-content {
  text-align: center;
}

.first-message {
  margin: 0;
}

.second-message {
  margin: 0;
}

@media (max-width: 1200px) {
  .top-cover {
    flex-direction: column;
  }
  .message-content {
    background-image: url("https://d54q1bdp9407m.cloudfront.net/images/mobile/fv_sp.png?version=i3o5QlE4ASeVOGXpEGjKFkkMZ5BNul7K");
    background-size: cover;
  }
  .first-message {
    font-size: 10vw;
    color: #f3f52f;
    font-weight: bold;
    margin: 1em auto 0.5em;
  }
  .first-message .strong-impression {
    font-size: 14vw;
  }
  .second-message {
    font-size: 5vw;
    color: #FFFFFF;
  }
  .top-logo {
    padding: 1.5em 0;
    width: 100%;
  }
  .top-logo img {
    width: 80%;
  }
  .form-content {
    padding: 1em;
  }
  .feature-cover {
    padding: 1em 0 0;
  }
  .form-header {
    overflow-wrap: break-word;
    word-break: keep-all;
  }
  .form-header-firstline {
    font-size: 5vw;
  }
  .form-header-secondline {
    font-size: 4vw;
    padding: 0.5em;
  }
  .form-header-headline {
    font-size: 7vw;
  }
  .form-body-headline {
    font-size: 5vw;
  }
  .form-body .submit-button {
    font-size: 5vw;
    padding: 2vw 7vw;
    margin: 5vw auto;
  }
  .feature-container {
    margin: 1em auto 0;
    padding: 0 1em;
  }
  .feature-point-description {
    padding: 2em 0;
    align-items: center;
  }
  .feature-point-description-image-area {
    width: 40em;
  }
  .feature-point-description-image-area img {
    width: 80%;
  }
  .feature-point-comment {
    font-size: 3vw;
    padding: 0.5em;
  }
  .voice {
    margin: 0 1em 1em;
    width: 100%;
    gap: 0.5em;
  }
  .voice-container {
    margin: 1em auto 0;
    width: 100%;
  }
  .voice-building-image-area {
    width: 65%;
  }
  .voice-user-image-area {
    margin-top: -2em;
    width: 30%;
  }
  .user-profile {
    font-size: 2vw;
  }
  .voice-user-image {
    width: 100%;
  }
  .cost {
    font-size: 2vw;
  }
  .cost .impression-cost {
    font-size: 3vw;
  }
  .cost .impression-cost-thousand {
    font-size: 2vw;
  }
  .price-down {
    font-size: 3vw;
  }
  .voice-text-area {
    font-size: 4vw;
  }
  .form-headline {
    padding: 1em 0 0;
  }
  .form-label {
    width: 40vw;
    font-size: 3vw;
  }
  .form-icon {
    padding: 1em 0;
    font-size: 3vw;
  }
  .form-input {
    width: 100%;
  }
  .form-error {
    font-size: 4vw;
    width: 100%;
  }
  .form-body input[type=text], input[type=email], input[type=tel], select {
    font-size: 3vw;
  }
  .form-input label {
    font-size: 3vw;
  }
  input[type=radio] {
    width: 7vw;
  }
  .feature-point-title {
    font-size: 4vw;
  }
  .feature-point-description-text-area {
    padding: 1em;
    font-size: 3vw;
    line-height: 2em;
    width: 100em;
  }
  .voice-cover {
    padding-top: 2em;
  }
}
@media (min-width: 1200px) {
  .form-content {
    width: 35%;
    padding: 1.5em 2vw;
  }
  .feature-cover {
    padding: 4em 0 2em;
  }
  .message-content {
    width: 65%;
    padding: 6em 0;
    background-image: url("https://d54q1bdp9407m.cloudfront.net/images/fv.png?version=GrJ3B9_h253NHxwsIF61vGhhJ.5gyhSN");
    background-size: cover;
  }
  .first-message {
    font-size: 51px;
    color: #f3f52f;
    font-weight: bold;
    margin-bottom: 0.5em;
  }
  .first-message .strong-impression {
    font-size: 77px;
  }
  .second-message {
    font-size: 36px;
    color: #FFFFFF;
  }
  .top-logo {
    margin-top: 2em;
  }
  .form-header-firstline {
    font-size: 30px;
  }
  .form-header-secondline {
    font-size: 16px;
    padding: 0.5em;
  }
  .form-body-headline {
    font-size: 18px;
  }
  .form-body .submit-button {
    font-size: 16pt;
    padding: 0.5em 3vw;
    margin: 0.5em auto;
  }
  .feature-container {
    margin: 3em auto;
    width: 70vw;
  }
  .feature-point-description {
    margin: 2em 0 3em;
    align-items: flex-end;
  }
  .feature-point-description-image-area {
    width: 70vw;
  }
  .feature-point-comment {
    padding: 1.5em;
    font-size: 28px;
  }
  .voice {
    margin: 0 1em 3em;
    width: 40em;
  }
  .voice-container {
    margin: 3em auto;
    width: 100%;
  }
  .voice-building-image-area {
    width: 28em;
  }
  .voice-user-image-area {
    margin-top: -3em;
    padding-left: 1em;
    width: 11em;
  }
  .user-profile {
    font-size: 16px;
  }
  .cost {
    font-size: 10px;
  }
  .cost .impression-cost {
    font-size: 30px;
  }
  .cost .impression-cost-thousand {
    font-size: 21px;
  }
  .price-down {
    font-size: 16px;
    margin: 0 1.5em;
  }
  .voice-text-area {
    font-size: 18px;
  }
  .require-icon {
    font-size: 14px;
  }
  .optional-icon {
    font-size: 14px;
  }
  .form-headline {
    padding-top: 1em;
  }
  .form-label {
    width: 8em;
    padding: 1em 0 0.5em;
  }
  .form-icon {
    width: 5em;
    padding: 1em 0 0.5em;
  }
  .form-input {
    padding: 1em 0 0.5em;
  }
  .form-error {
    width: 100%;
  }
  .form-body input[type=text], input[type=email], input[type=tel], select {
    font-size: 16px;
  }
  .feature-point-description-text-area {
    padding: 2em;
    margin-left: 1vw;
    font-size: 22px;
    line-height: 2.5em;
    width: 160vw;
  }
  .feature-point-title {
    font-size: 28px;
  }
  .feature-impression {
    font-size: 36px;
  }
  .voice-cover {
    padding-top: 4em;
  }
  .voice-user-image {
    margin-left: -1.5em;
  }
}
.form-content {
  background-color: #e8e8e8;
}

.form-header {
  background-color: #166bb3;
  text-align: center;
}

.form-body {
  background-color: #FFFFFF;
  padding: 0 1em;
}

.free-icon {
  background-color: #c46500;
  padding: 0.2em;
}

.free-impression {
  color: #f2c700;
  padding: 0.2em;
}

.form-header-firstline {
  text-align: center;
  font-weight: bold;
  color: #FFFFFF;
  padding: 0.5em 0.5em 0;
}

.form-header-secondline {
  color: #FFFFFF;
}

.form-body table {
  width: 100%;
}

.form-body table hr {
  margin: 0;
}

.form-body-headline {
  color: #166bb3;
  font-weight: bold;
  text-align: left;
}

.form-label-column {
  width: 9em;
}

.form-icon-column {
  width: 3em;
}

.require-icon {
  color: #c77626;
  margin: 0 1em;
  padding: 0.5em;
  border: solid 1px;
}

.optional-icon {
  color: #166bb3;
  margin: 0 1em;
  padding: 0.5em;
  border: solid 1px;
}

.form-body td label {
  color: #171717;
  font-size: 15px;
}

.form-body th {
  padding-top: 1em;
}

.form-body td {
  padding: 0.4em 0;
}

.select-placeholder {
  display: none;
  color: gray;
}

.form-body form {
  margin: 0;
  text-align: center;
}

.form-body input[type=text], input[type=email], input[type=tel], select {
  padding: 0.5em;
  border: solid 1px gray;
  width: 100%;
  color: gray;
}

.form-body .submit-button {
  text-align: center;
  cursor: pointer;
  background: #dd0024;
  color: #ffffff;
  border: 2px solid #dd0024;
  transition: transform 0.5s ease, box-shadow 0.5s ease;
  box-shadow: 0 0 3px 0 gray;
}

.form-body .submit-button:hover {
  cursor: pointer;
  box-shadow: 1px 5px 5px 1px gray;
  transform: translateY(-4px);
}

.top-quotation-flow-cover {
  background-color: #FFFFFF;
}

.feature-cover {
  background-color: #dbe8ec;
}

.feature-point-heading {
  text-align: center;
  border: solid 1px black;
}

.feature-point-title {
  background-color: #0973ba;
  color: #FFFFFF;
  font-weight: bold;
  padding: 1em;
}

.feature-impression {
  color: #f3f52f;
  font-weight: bold;
}

.feature-point-comment {
  background-color: #FFFFFF;
  color: #0973ba;
  font-weight: bold;
}

.feature-point-description {
  display: flex;
}

.feature-point-description-image-area {
  overflow: hidden;
  text-align: center;
}

.feature-point-description-text-area {
  background-color: #0973ba;
  border-radius: 5%;
  color: #FFF;
  height: 100%;
}

.impression-description-text {
  color: #f3f52f;
}

.x-icon {
  padding: 0.1em 0.1em 0.3em 0.1em;
}

.voice-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.voice {
  padding: 1em;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  border: solid 3px #166bb3;
}

.voice-building-image {
  width: 100%;
}

.voice-user-image-area {
  text-align: center;
}

.user-profile {
  color: #166bb3;
  font-weight: bold;
  margin-top: 0.5em;
}

.cost {
  font-weight: bold;
  margin: 0.5em 0;
}

.cost .impression-cost {
  font-weight: bold;
}

.cost .impression-cost-thousand {
  font-weight: bold;
}

.price-down {
  background-color: #e62525;
  color: #FFFFFF;
  border-radius: 2em;
  padding: 0.3em 0;
}

.voice-text-area {
  width: 100%;
  padding-top: 1em;
}

.form-error-field {
  border-color: #dd0024;
}

.form-error-message {
  margin: 0 0 0.5em;
  color: #dd0024;
}

.form-item {
  display: flex;
  flex-wrap: wrap;
  text-align: left;
  align-items: center;
}

@media (min-width: 1200px) {
  .only-mobile-view {
    display: none;
  }
  .only-desktop-view {
    display: block;
  }
}
@media (max-width: 1200px) {
  .only-mobile-view {
    display: block;
  }
  .only-desktop-view {
    display: none;
  }
}
.flex-view {
  display: flex;
}

@media (min-width: 1200px) {
  .form-input {
    width: 40%;
  }
}
@media (min-width: 1650px) {
  .form-input {
    width: 60%;
  }
}
