@charset "UTF-8";
/*-----------------------------------------------------------------------------------
	CSS INDEX
	===================
	-> Base - Default
	-> Layouts - Header
	-> Layouts - Main
	-> Layouts - Footer
	-> Pages - 
	-> Parts - 
-----------------------------------------------------------------------------------*/
/*****************************
* Base - Default
*****************************/
/*-- Common Style --*/
*,
*::after,
*::before {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

body,
html {
  height: 100%;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #000000;
  -webkit-text-size-adjust: 100%;
  background: #ffffff;
}

section {
  position: relative;
}

img {
  max-width: 100%;
  height: auto;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 400;
}

h1 {
  font-size: 1.5rem;
}

h2 {
  font-size: 1.5rem;
  line-height: 1;
}
h2 img {
  display: inline-block;
}
h2.underline {
  padding-bottom: 20px;
  border-bottom: solid 1px #333333;
}
@media (max-width: 540px) {
  h2.underline {
    margin-bottom: 20px;
    font-size: 1rem;
  }
}
h2.rounded {
  padding: 8px 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border-radius: 20px;
  background: #333333;
}
h2.rounded span {
  word-break: break-all;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
h2.rounded span.icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
h2.rounded span.icon span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
h2.rounded span.icon span i {
  margin-right: 10px;
  font-size: 1.6875rem;
}
@media (max-width: 540px) {
  h2.rounded span.icon span i {
    height: auto;
    font-size: 1.625rem;
  }
}
h2.rounded.more {
  height: 40px;
  margin-bottom: 25px;
  padding: 0 0 0 15px;
  background: #333333;
  border-radius: 40px;
  font-size: 1.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
          justify-content: space-between;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
@media (max-width: 540px) {
  h2.rounded.more {
    margin: 0 20px 20px;
    font-size: 1rem;
  }
}
h2.rounded.more > span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
h2.rounded.more > span > i {
  margin-right: 10px;
  font-size: 1.75rem;
}
@media (max-width: 540px) {
  h2.rounded.more > span > i {
    font-size: 1.625rem;
  }
}
h2.rounded.more a {
  width: 40px;
  height: 40px;
  border: solid 1px #ffffff;
  border-radius: 40px;
  font-size: 0.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
h2.rounded.more a > span {
  display: none;
}
@media (max-width: 540px) {
  h2.rounded.more a > span {
    padding-right: 0.5em;
  }
}
h2.rounded.more a > i {
  position: absolute;
  top: 50%;
  right: 12px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
h2.rounded.more a:hover {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 12px 0 24px;
  opacity: 1;
}
@media (max-width: 540px) {
  h2.rounded.more a:hover {
    width: 40px;
    padding: 0;
  }
}
h2.rounded.more a:hover span {
  padding-right: 18px;
  display: block;
}
@media (max-width: 540px) {
  h2.rounded.more a:hover span {
    display: none;
  }
}
h2.rounded.more a:focus {
  opacity: 1;
}

h3 {
  font-size: 0.875rem;
}

h4 {
  font-size: 0.875rem;
}

h5 {
  font-size: 0.875rem;
}

h6 {
  font-size: 0.875rem;
}

ol, ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

a {
  color: #000000;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
@media (max-width: 1024px) {
  a {
    -webkit-transition: all 0s ease;
    transition: all 0s ease;
  }
}
a:hover {
  text-decoration: none;
  opacity: 0.5;
}
@media (max-width: 1024px) {
  a:hover {
    opacity: 1;
  }
}
a:focus {
  outline: none;
  text-decoration: none;
  opacity: 0.5;
}
@media (max-width: 1024px) {
  a:focus {
    opacity: 1;
  }
}
a:active {
  outline: none;
  text-decoration: none;
  opacity: 0.5;
}
@media (max-width: 1024px) {
  a:active {
    opacity: 1;
  }
}

p {
  margin-bottom: 1.8em;
  text-align: justify;
}
p:has(+ .note) {
  margin-bottom: 0;
}
p.note {
  font-size: 0.8em;
}

.marker {
  display: inline;
  padding: 0 4px 2px 4px;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(70%, transparent), color-stop(0%, #ffcc00));
  background: linear-gradient(transparent 70%, #ffcc00 0%);
}

table {
  margin: 0 auto;
  border-collapse: collapse;
}
table th,
table td {
  padding: 0.25em;
}

.disp-none {
  display: none;
}

.pc-none {
  display: none;
}
@media (max-width: 540px) {
  .pc-none {
    display: block;
  }
}

.sp-none {
  display: block;
}
@media (max-width: 540px) {
  .sp-none {
    display: none;
  }
}

button, input, textarea, select {
  border: none;
  outline: none;
  background: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}

form {
  display: block;
}
@media (max-width: 540px) {
  form {
    width: 100%;
  }
}
form ul li {
  margin-bottom: 10px;
  font-size: 0.875rem;
}
form dl {
  font-size: 0.875rem;
  text-align: left;
}
form dl dt {
  margin-bottom: 10px;
  font-weight: bold;
}
form dl dd:not(:last-of-type) {
  margin-bottom: 20px;
}
form dl dd .note {
  margin-top: 5px;
  font-size: 0.75rem;
  display: block;
}
form dl dd .note.error {
  color: red;
}
form table {
  font-size: 1.125rem;
  text-align: left;
}
form table th {
  font-weight: bold;
}
form table td .wpcf7-not-valid-tip {
  margin-top: 5px;
  font-size: 0.875rem;
  color: red;
}

input, textarea {
  width: 100%;
}
input[type=radio], textarea[type=radio] {
  width: auto;
  height: auto;
}

input:not([type=checkbox]):not([type=radio]) {
  width: 100%;
  height: auto;
  padding: 0.5em;
  font-size: 1.125rem;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  background-color: #ecf7ff;
}
input:not([type=checkbox]):not([type=radio]):focus {
  background: #7cbdff;
}
input:not([type=checkbox]):not([type=radio]):invalid {
  background: #fff700;
}
input:not([type=checkbox]):not([type=radio])[type=text], input:not([type=checkbox]):not([type=radio])[type=tel], input:not([type=checkbox]):not([type=radio])[type=email], input:not([type=checkbox]):not([type=radio])[type=password] {
  line-height: 1;
}
input:not([type=checkbox]):not([type=radio])[type=checkbox] {
  width: auto;
  height: auto;
}
input:not([type=checkbox]):not([type=radio])[type=submit] {
  cursor: pointer;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
input:not([type=checkbox]):not([type=radio])[type=submit]:hover {
  opacity: 0.5;
}
input:not([type=checkbox]):not([type=radio]).error-background {
  background: #ff3a33;
}

textarea {
  width: 100%;
  padding: 0.5em;
  font-size: 1.125rem;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  display: block;
  resize: vertical;
  background-color: #ecf7ff;
  overflow: hidden;
}
@media (max-width: 540px) {
  textarea {
    width: 100%;
  }
}
textarea:focus {
  background: #7cbdff;
}

select {
  padding: 0.5em;
  font-size: 1.125rem;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  background: #ecf7ff;
}
select:focus {
  background-color: #7cbdff;
}
select:invalid {
  background: #fff700;
}

button {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  cursor: pointer;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
button:hover {
  opacity: 0.5;
}
button:disabled {
  cursor: inherit;
  -webkit-transition: none;
  transition: none;
}
button:disabled:hover {
  opacity: 1;
}

.content {
  max-width: 960px;
  margin: 0 auto;
  padding: 24px 0;
}
.content p {
  font-size: 0.875rem;
  text-align: center;
}

.btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.5em;
  color: #ffffff;
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border-radius: 9999px;
  -webkit-box-shadow: 0 8px 0 0 #ab2924;
          box-shadow: 0 8px 0 0 #ab2924;
  background: #ff3a33;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.btn:hover {
  -webkit-box-shadow: 0 6px 0 0 #ab2924;
          box-shadow: 0 6px 0 0 #ab2924;
  opacity: 1;
}
.btn:active {
  -webkit-box-shadow: 0 0 0 0 #ab2924;
          box-shadow: 0 0 0 0 #ab2924;
  opacity: 1;
}
.btn:focus {
  opacity: 1;
}

.search-box {
  border: solid 4px #0099ff;
  border-radius: 25px;
  background: #ffffff;
  -webkit-box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
          box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
  overflow: hidden;
}
@media (max-width: 540px) {
  .search-box {
    border-radius: 12px;
    background: #ffffff;
  }
}
.search-box h2 {
  height: 100px;
  margin: 0;
  font-size: 2.5rem;
  color: #ffffff;
  text-align: center;
  line-height: 1;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  background: #0099ff;
}
@media (max-width: 540px) {
  .search-box h2 {
    font-size: 1.5rem;
    line-height: 1.2;
  }
}
.search-box > div {
  padding: 40px 60px 60px;
}
@media (max-width: 540px) {
  .search-box > div {
    padding: 20px;
  }
}
.search-box > div h3 {
  margin-bottom: 1.1em;
  font-size: 2.25rem;
  color: #0099ff;
  text-align: center;
  line-height: 1;
  font-weight: 400;
}
@media (max-width: 540px) {
  .search-box > div h3 {
    font-size: 1.25rem;
    line-height: 1.2;
  }
}
.search-box > div .rentcheck {
  margin-bottom: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 25px;
}
@media (max-width: 540px) {
  .search-box > div .rentcheck {
    margin-bottom: 30px;
    gap: 15px;
  }
}
.search-box > div .rentcheck label {
  width: calc((100% - 50px) / 3);
  height: 100px;
  font-size: 1.875rem;
  color: #0099ff;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border: solid 4px #0099ff;
  border-radius: 10px;
  background: #ffffff;
  cursor: pointer;
}
@media (max-width: 540px) {
  .search-box > div .rentcheck label {
    width: calc((100% - 15px) / 2);
    height: 50px;
    font-size: 1.25rem;
  }
}
.search-box > div .rentcheck label input[type=checkbox] {
  display: none;
}
.search-box > div .rentcheck label input[type=checkbox]:checked + span {
  font-weight: 600;
}
.search-box > div .rentcheck label:has(input:checked) {
  color: #ffffff;
  background: #0099ff;
  -webkit-box-shadow: inset 5px 5px 0 0 #0089e5;
          box-shadow: inset 5px 5px 0 0 #0089e5;
}
.search-box > div .rentcheck input[type=checkbox] {
  display: block;
}
.search-box > div ul li {
  margin-bottom: 40px;
  padding: 0 40px;
  height: 100px;
  font-size: 1.875rem;
  color: #0099ff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border: solid 4px #0099ff;
  border-radius: 10px;
  background: #ffffff;
  position: relative;
  cursor: pointer;
}
@media (max-width: 540px) {
  .search-box > div ul li {
    margin-bottom: 20px;
    padding: 0.5em 20px;
    height: auto;
    display: block;
  }
}
.search-box > div ul li:after {
  content: "\e5c6";
  font-size: 2.25rem;
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 1;
  margin-left: auto;
}
@media (max-width: 540px) {
  .search-box > div ul li:after {
    position: absolute;
    top: 50%;
    right: 10px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
.search-box > div ul li h3 {
  width: 44%;
  margin-bottom: 0;
  font-size: 1.875rem;
  text-align: left;
  line-height: 1;
}
@media (max-width: 540px) {
  .search-box > div ul li h3 {
    width: 100%;
    margin-bottom: 0.25em;
    font-size: 1.375rem;
    text-align: center;
    line-height: 1.2;
  }
}
.search-box > div ul li span {
  margin: 0;
  font-size: 1.875rem;
  font-weight: 600;
  display: block;
}
@media (max-width: 540px) {
  .search-box > div ul li span {
    width: 100%;
    font-size: 1.375rem;
    text-align: center;
  }
}
.search-box > div button {
  width: 45%;
  height: 80px;
  margin-inline: auto;
  font-size: 2rem;
  color: #ffffff;
  font-weight: 600;
  background: #ffa033;
  -webkit-box-shadow: 0 8px 0 0 #f29033;
          box-shadow: 0 8px 0 0 #f29033;
}
@media (max-width: 540px) {
  .search-box > div button {
    width: 100%;
    height: 60px;
    font-size: 1.5rem;
  }
}
.search-box > div button:hover {
  -webkit-box-shadow: 0 6px 0 0 #f29033;
          box-shadow: 0 6px 0 0 #f29033;
}
.search-box > div button:active {
  -webkit-box-shadow: 0 0 0 0 #f29033;
          box-shadow: 0 0 0 0 #f29033;
}
.search-box > div button:focus {
  -webkit-box-shadow: 0 6px 0 0 #f29033;
          box-shadow: 0 6px 0 0 #f29033;
}
.search-box > div button span {
  font-size: 1.2em;
  font-weight: 600;
}

.card {
  margin-bottom: 60px;
  padding: 50px 60px 60px;
  border: solid 8px #0099ff;
  border-radius: 25px;
  background: #ffffff;
  -webkit-box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
          box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
  position: relative;
}
@media (max-width: 540px) {
  .card {
    margin-bottom: 30px;
    padding: 90px 20px 20px;
  }
}
.card.no1:before, .card.no2:before, .card.no3:before {
  content: "";
  position: absolute;
  top: -15px;
  left: 20px;
}
.card.no1 .header, .card.no2 .header, .card.no3 .header {
  padding-left: 135px;
}
@media (max-width: 540px) {
  .card.no1 .header, .card.no2 .header, .card.no3 .header {
    padding-left: 0;
  }
}
@media (max-width: 540px) {
  .card.no1 .balloon, .card.no2 .balloon, .card.no3 .balloon {
    top: 10px;
    right: 10px;
    left: auto;
    -webkit-transform: revert;
            transform: revert;
  }
}
.card.no1 {
  border-color: #d2962d;
  -webkit-box-shadow: 8px 8px 0 0 #f1b848;
          box-shadow: 8px 8px 0 0 #f1b848;
}
.card.no1:before {
  content: url(../../assets/images/icn_ranking1.png);
}
@media (max-width: 540px) {
  .card.no1:before {
    content: url(../../assets/images/icn_ranking1_sp.png);
  }
}
.card.no2:before {
  content: url(../../assets/images/icn_ranking2.png);
}
@media (max-width: 540px) {
  .card.no2:before {
    content: url(../../assets/images/icn_ranking2_sp.png);
  }
}
.card.no3:before {
  content: url(../../assets/images/icn_ranking3.png);
}
@media (max-width: 540px) {
  .card.no3:before {
    content: url(../../assets/images/icn_ranking3_sp.png);
  }
}
.card .header {
  margin-bottom: 70px;
}
@media (max-width: 540px) {
  .card .header {
    margin-bottom: 30px;
  }
}
.card .header h3 {
  margin-bottom: 0.2em;
  font-size: 2.75rem;
  font-weight: 800;
}
@media (max-width: 540px) {
  .card .header h3 {
    font-size: 1.75rem;
  }
}
.card .header h4 {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 2rem;
  font-size: 1.75rem;
  color: #ff3a33;
  font-weight: 600;
  line-height: 1.1;
}
@media (max-width: 540px) {
  .card .header h4 {
    font-size: 1.375rem;
  }
}
.card .header h4:before {
  content: "\e8e8";
  font-size: 2.5rem;
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 1;
  vertical-align: -0.15em;
}
@media (max-width: 540px) {
  .card .header h4:before {
    font-size: 1.75rem;
  }
}
.card .balloon {
  width: 250px;
  height: 194px;
  padding: 2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border-radius: 100%;
  background: #0099ff;
  position: absolute;
  top: 20px;
  right: 24px;
}
@media (max-width: 540px) {
  .card .balloon {
    width: 250px;
    height: 60px;
    padding: 0 1.5em;
    margin-inline: auto;
    border-radius: 9999px;
    top: 10px;
    right: auto;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.card .balloon:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 40px 15px 0;
  border-color: #0099ff transparent transparent;
  position: absolute;
  bottom: -24px;
  left: 60px;
  -webkit-transform: rotatez(25deg);
          transform: rotatez(25deg);
}
@media (max-width: 540px) {
  .card .balloon:after {
    border-width: 20px 8px 0;
    bottom: -14px;
    left: 100px;
  }
}
.card .balloon p {
  margin-bottom: 0;
  font-size: 1.25rem;
  color: #ffffff;
  font-weight: 600;
}
@media (max-width: 540px) {
  .card .balloon p {
    font-size: 0.875rem;
  }
}
.card .detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: start;
  -webkit-box-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 40px;
}
@media (max-width: 540px) {
  .card .detail {
    gap: 20px;
  }
}
@media (max-width: 540px) {
  .card .detail figure {
    margin-inline: auto;
  }
}
.card .detail table {
  width: calc(100% - 340px);
  border-spacing: 4px;
  border-collapse: separate;
}
@media (max-width: 540px) {
  .card .detail table {
    width: 100%;
  }
}
.card .detail table tr th {
  width: 25%;
  padding: 15px 0;
  font-size: 1.25rem;
  font-weight: 600;
  background: #f5f5f5;
}
@media (max-width: 540px) {
  .card .detail table tr th {
    font-size: 0.875rem;
  }
}
.card .detail table tr td {
  width: 25%;
  min-height: 60px;
  font-size: 1.25rem;
  text-align: center;
  font-weight: 800;
  background: #ffffff;
}
@media (max-width: 540px) {
  .card .detail table tr td {
    font-size: 0.875rem;
  }
}
.card .detail table tr td.circle_w {
  background-image: url(../../assets/images/circle_w.png);
  background-repeat: no-repeat;
  background-position: center center;
}
.card .detail table tr td.circle_s {
  background-image: url(../../assets/images/circle_s.png);
  background-repeat: no-repeat;
  background-position: center center;
}
.card .detail table tr td img {
  margin-inline: auto;
}
.card .detail ul {
  width: 100%;
  margin-bottom: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 12px;
}
@media (max-width: 540px) {
  .card .detail ul {
    margin-bottom: 20px;
  }
}
.card .detail ul li {
  width: calc((100% - 60px) / 6);
  height: 50px;
  font-size: 1.125rem;
  color: #ffffff;
  text-align: center;
  line-height: 1;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border-radius: 9999px;
  background: #0099ff;
}
@media (max-width: 540px) {
  .card .detail ul li {
    width: calc((100% - 24px) / 3);
    height: 40px;
    font-size: 0.875rem;
  }
}
.card .detail ul li.off {
  background: #d9d9d9;
}
.card .recommend {
  margin-bottom: 60px;
}
@media (max-width: 540px) {
  .card .recommend {
    margin-bottom: 30px;
  }
}
.card .recommend h4 {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 50px;
  margin-inline: auto;
  padding: 0 1em;
  font-size: 1.5rem;
  text-align: center;
  line-height: 1;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border-radius: 9999px;
  background: #ffcc00;
  position: relative;
}
@media (max-width: 540px) {
  .card .recommend h4 {
    font-size: 1.125rem;
  }
}
.card .recommend h4:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 25px 12.5px 0;
  border-color: #ffcc00 transparent transparent;
  position: absolute;
  bottom: -25px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1;
}
@media (max-width: 540px) {
  .card .recommend h4:after {
    border-width: 18px 9px 0;
    bottom: -18px;
  }
}
.card .recommend .recommend-inner {
  height: 160px;
  height: auto;
  position: relative;
}
.card .recommend .recommend-inner ul {
  height: 100%;
  padding: 35px 30px 30px;
  border-radius: 20px;
  background: #ecf7ff;
  -webkit-box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
          box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
  overflow: hidden;
}
@media (max-width: 540px) {
  .card .recommend .recommend-inner ul {
    padding: 25px 20px 20px;
  }
}
.card .recommend .recommend-inner ul li {
  font-size: 1.5rem;
  font-weight: 800;
}
@media (max-width: 540px) {
  .card .recommend .recommend-inner ul li {
    font-size: 1.125rem;
  }
}
.card .recommend .recommend-inner ul li:not(:last-child) {
  margin-bottom: 1em;
}
.card .recommend .recommend-inner ul li strong {
  color: #ff3a33;
}
.card .recommend .recommend-inner ul li:before {
  content: "\e86c";
  color: #ffcc00;
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 1;
  vertical-align: -0.15em;
}
.card .voice {
  margin-bottom: 40px;
  height: 160px;
  height: auto;
}
@media (max-width: 540px) {
  .card .voice {
    margin-bottom: 30px;
  }
}
.card .voice.is-open:after {
  display: none;
}
.card .voice {
  position: relative;
}
.card .voice .voice-inner {
  height: 100%;
  padding: 40px 30px 30px 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: stretch;
  -webkit-box-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 30px;
  border-radius: 20px;
  background: #f5f5f5;
  -webkit-box-shadow: 8px 8px 0 0 #d9d9d9;
          box-shadow: 8px 8px 0 0 #d9d9d9;
  position: relative;
  overflow: hidden;
}
@media (max-width: 540px) {
  .card .voice .voice-inner {
    padding: 20px;
    display: block;
  }
}
.card .voice .voice-inner .line {
  width: 170px;
  height: 30px;
  font-size: 1.25rem;
  color: #ffffff;
  text-align: center;
  font-weight: 600;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  background: #ffa033;
  position: absolute;
  top: 20px;
  left: -40px;
  -webkit-transform: rotateZ(-36.4deg);
          transform: rotateZ(-36.4deg);
}
@media (max-width: 540px) {
  .card .voice .voice-inner figure {
    width: 70px;
    margin-inline: auto;
    margin-bottom: 10px;
  }
}
.card .voice .voice-inner .voice-content {
  width: calc(100% - 130px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: stretch;
  -webkit-box-align: stretch;
          align-items: stretch;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media (max-width: 540px) {
  .card .voice .voice-inner .voice-content {
    width: 100%;
    display: block;
  }
}
.card .voice .voice-inner .voice-content .rating {
  width: 32%;
  font-size: 2rem;
  line-height: 1.25;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  font-weight: 600;
}
@media (max-width: 540px) {
  .card .voice .voice-inner .voice-content .rating {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    margin-bottom: 10px;
    display: block;
  }
}
.card .voice .voice-inner .voice-content .rating .star {
  margin-left: 0.25em;
  font-size: 1.5rem;
}
.card .voice .voice-inner .voice-content .rating .star span {
  color: #ffcc00;
}
.card .voice .voice-inner .voice-content .rating .star span.off {
  color: #d9d9d9;
}
.card .voice .voice-inner .voice-content .rating .profile {
  width: 100%;
  font-size: 1.125rem;
  font-weight: 400;
}
.card .voice .voice-inner .voice-content .borrow {
  width: calc(68% - 30px);
  margin-left: auto;
  font-size: 1.125rem;
  text-align: center;
  font-weight: 600;
  border: solid 2px #000000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
@media (max-width: 540px) {
  .card .voice .voice-inner .voice-content .borrow {
    width: 100%;
  }
}
.card .voice .voice-inner .voice-content .comment {
  margin-top: 10px;
}
.card .voice .voice-inner .voice-content .comment p {
  margin-bottom: 0;
}
.card a.btn {
  width: 73%;
  height: 80px;
  margin-bottom: 40px;
  margin-inline: auto;
  font-size: 2.5rem;
  font-weight: 600;
}
@media (max-width: 540px) {
  .card a.btn {
    width: 100%;
    height: 40px;
    font-size: 1.5rem;
  }
}
.card p.note {
  width: 33%;
  margin-bottom: 0;
  margin-inline: auto;
  font-size: 0.625rem;
}
@media (max-width: 540px) {
  .card p.note {
    width: 100%;
  }
}

#step-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1000;
}
#step-modal[style*="display: block"] {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
#step-modal #step-modal-inner {
  background: #fff;
  border-radius: 12px;
  width: 90%;
  max-width: 480px;
  max-height: 80vh;
  overflow-y: auto;
  padding: 24px;
}
#step-modal #step-modal-inner h3 {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 0.5px solid #ddd;
}
#step-modal #step-modal-inner ul {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
}
#step-modal #step-modal-inner ul li {
  padding: 12px 16px;
  border-bottom: 0.5px solid #ddd;
  cursor: pointer;
  color: #222;
  -webkit-transition: background 0.15s;
  transition: background 0.15s;
}
#step-modal #step-modal-inner ul li:last-child {
  border-bottom: none;
}
#step-modal #step-modal-inner ul li:hover {
  background: #E6F1FB;
}
#step-modal #step-modal-inner ul li.selected {
  color: #378ADD;
  font-weight: 500;
  background: #E6F1FB;
}
#step-modal #step-modal-inner button {
  width: 100%;
  height: 50px;
  margin-inline: auto;
  font-size: 1.5rem;
  color: #ffffff;
  font-weight: 600;
  background: #ffa033;
  -webkit-box-shadow: 0 8px 0 0 #f29033;
          box-shadow: 0 8px 0 0 #f29033;
  display: none;
}
@media (max-width: 540px) {
  #step-modal #step-modal-inner button {
    width: 100%;
    height: 40px;
    font-size: 1.25rem;
  }
}
#step-modal #step-modal-inner button:hover {
  -webkit-box-shadow: 0 6px 0 0 #f29033;
          box-shadow: 0 6px 0 0 #f29033;
}
#step-modal #step-modal-inner button:active {
  -webkit-box-shadow: 0 0 0 0 #f29033;
          box-shadow: 0 0 0 0 #f29033;
}
#step-modal #step-modal-inner button:focus {
  -webkit-box-shadow: 0 6px 0 0 #f29033;
          box-shadow: 0 6px 0 0 #f29033;
}
#step-modal #step-modal-inner button span {
  font-size: 1.2em;
  font-weight: 600;
}
#step-modal #step-modal-inner #modal-prev {
  display: block;
  text-align: center;
  font-size: 13px;
  color: #555;
  cursor: pointer;
  padding-top: 8px;
  border-top: 0.5px solid #ddd;
}
#step-modal #step-modal-inner #modal-prev:hover {
  color: #222;
}

.overlay {
  position: fixed;
  inset: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  background: rgba(0, 0, 0, 0.38);
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.18s ease;
  transition: opacity 0.18s ease;
  z-index: 9999;
}
.overlay.active {
  opacity: 1;
  pointer-events: auto;
}
.overlay.active .modal {
  -webkit-transform: scale(1);
          transform: scale(1);
}

.modal {
  width: 340px;
  background: #ffffff;
  position: relative;
  -webkit-transform: scale(0.92);
          transform: scale(0.92);
  -webkit-transition: -webkit-transform 0.18s ease;
  transition: -webkit-transform 0.18s ease;
  transition: transform 0.18s ease;
  transition: transform 0.18s ease, -webkit-transform 0.18s ease;
}
.modal-close {
  width: 28px;
  height: 28px;
  font-size: 1.125rem;
  line-height: 1;
  position: absolute;
  top: -12px;
  right: -12px;
  border-radius: 50%;
  background: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  cursor: pointer;
  -webkit-transition: background 0.12s;
  transition: background 0.12s;
}
.modal-actions {
  padding: 15px 15px 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.modal-actions .btn {
  width: 100%;
  padding: 0.5em;
  font-size: 1.375rem;
  font-weight: 600;
}

.select-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.25s ease;
  transition: opacity 0.25s ease;
  z-index: 9000;
}
.select-overlay.active {
  opacity: 1;
  pointer-events: auto;
}
.select-overlay.active .select-modal {
  -webkit-transform: scale(1);
          transform: scale(1);
  opacity: 1;
}

.select-modal {
  width: 800px;
  background: #ffffff;
  position: relative;
  -webkit-transform: scale(0.92);
          transform: scale(0.92);
  -webkit-transition: -webkit-transform 0.18s ease;
  transition: -webkit-transform 0.18s ease;
  transition: transform 0.18s ease;
  transition: transform 0.18s ease, -webkit-transform 0.18s ease;
}
.select-modal-links {
  padding: 2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 30px;
}
.select-modal-link.btn {
  width: 70%;
  margin-inline: auto;
  font-size: 1.25rem;
  text-align: center;
  font-weight: 700;
  line-height: 1.5;
  display: block;
}
.select-modal-link.btn span {
  font-size: 1rem;
  font-weight: 400;
  display: block;
}
.select-modal-link--first.btn {
  -webkit-box-shadow: 0 8px 0 0 #0089e5;
          box-shadow: 0 8px 0 0 #0089e5;
  background: #0099ff;
}
.select-modal-link--first.btn:hover {
  -webkit-box-shadow: 0 6px 0 0 #0089e5;
          box-shadow: 0 6px 0 0 #0089e5;
}
.select-modal-link--first.btn:active {
  -webkit-box-shadow: 0 0 0 0 #0089e5;
          box-shadow: 0 0 0 0 #0089e5;
}
.select-modal-link--second.btn {
  -webkit-box-shadow: 0 8px 0 0 #0a3b00;
          box-shadow: 0 8px 0 0 #0a3b00;
  background: #147a00;
}
.select-modal-link--second.btn:hover {
  -webkit-box-shadow: 0 6px 0 0 #0a3b00;
          box-shadow: 0 6px 0 0 #0a3b00;
}
.select-modal-link--second.btn:active {
  -webkit-box-shadow: 0 0 0 0 #0a3b00;
          box-shadow: 0 0 0 0 #0a3b00;
}

.page-top {
  width: 90px;
  height: 90px;
  display: none;
  position: fixed;
  bottom: 15px;
  right: 10px;
  z-index: 2000;
}
@media (max-width: 540px) {
  .page-top {
    width: 70px;
    height: 70px;
    bottom: 10px;
  }
}

/*****************************
* icons
*****************************/
.material-symbols-sharp {
  color: #000000;
  font-variation-settings: "FILL" 1, "wght" 600, "GRAD" 0, "opsz" 24;
  vertical-align: -0.15em;
}

.material-symbols-outlined {
  font-variation-settings: "FILL" 1, "wght" 600, "GRAD" 0, "opsz" 24;
  vertical-align: -0.15em;
}

/************************************
* Layouts - Header
************************************/
header {
  width: 100%;
  height: 100px;
  background: #0099ff;
  position: relative;
}
@media (max-width: 540px) {
  header {
    height: 70px;
    padding: 0 10px;
  }
}
header .header-inner {
  max-width: 1100px;
  height: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  position: relative;
  z-index: 1000;
}
header .header-inner .logo {
  font-size: 3rem;
  color: #ffffff;
  line-height: 1;
  font-weight: 800;
}
@media (max-width: 540px) {
  header .header-inner .logo {
    width: 130px;
  }
}
header .header-inner .pr {
  width: 60px;
  height: 28px;
  margin-left: auto;
  font-size: 1.5rem;
  color: #ffffff;
  text-align: center;
  line-height: 1;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border: solid 1px #ffffff;
}

/************************************
* Layouts - Main
************************************/
main {
  min-height: calc(100vh - 100px);
  padding-bottom: 70px;
  background-color: #ffffff;
  position: relative;
}
main #content-wrapper {
  margin: 0 auto;
  position: relative;
}
main #content-wrapper #side-menu {
  display: none;
}
main #content-wrapper #main-content {
  margin: 0 auto;
  padding: 0;
  position: relative;
}
main #content-wrapper #main-content.single {
  width: 100%;
}
@media (max-width: 1024px) {
  main #content-wrapper #main-content {
    width: 100%;
  }
}
@media (max-width: 540px) {
  main #content-wrapper #main-content {
    width: 100%;
  }
}
main #content-wrapper #main-content section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
  position: relative;
}
main #content-wrapper #main-content section:not(:last-of-type) {
  margin-bottom: 40px;
}
@media (max-width: 540px) {
  main #content-wrapper #main-content section:not(:last-of-type) {
    margin-bottom: 35px;
  }
}
main #content-wrapper #main-content section .content-inner {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
@media (max-width: 1024px) {
  main #content-wrapper #main-content section .content-inner {
    width: 100%;
  }
}
@media (max-width: 540px) {
  main #content-wrapper #main-content section .content-inner {
    width: 100%;
  }
}
main #content-wrapper #main-content section .content-inner.w560 {
  max-width: 560px;
  text-align: center;
}
@media (max-width: 540px) {
  main #content-wrapper #main-content section .content-inner.w560 {
    width: calc(100% - 40px);
  }
}
main #content-wrapper #main-content section .content-inner.w560 h2 {
  margin-bottom: 40px;
  font-size: 1.5rem;
}
@media (max-width: 540px) {
  main #content-wrapper #main-content section .content-inner.w560 h2 {
    margin-bottom: 15px;
  }
}
main #content-wrapper #main-content section .content-inner.w560 h3 {
  margin-bottom: 25px;
  font-size: 1rem;
  font-weight: normal;
}
@media (max-width: 540px) {
  main #content-wrapper #main-content section .content-inner.w560 h3 {
    margin-bottom: 15px;
  }
}
main #content-wrapper #main-content section .content-inner.w800 {
  width: 800px;
}
@media (max-width: 1024px) {
  main #content-wrapper #main-content section .content-inner.w800 {
    width: 96%;
  }
}
@media (max-width: 540px) {
  main #content-wrapper #main-content section .content-inner.w800 {
    width: calc(100% - 40px);
  }
}

/************************************
* Layouts - Footer
************************************/
footer {
  padding: 2.6em 0 0;
  font-size: 0.875rem;
  text-align: center;
  color: #0099ff;
  background: #ecf7ff;
}
@media (max-width: 540px) {
  footer {
    padding: 2em 0 0;
  }
}
footer table {
  text-align: justify;
}
footer .logo {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 40px;
  margin-inline: auto;
  font-size: 3rem;
  font-weight: 800;
}
@media (max-width: 540px) {
  footer .logo {
    width: 130px;
  }
}
footer ul li:before {
  content: "・";
}
footer > dl {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 40px;
  margin-inline: auto;
  text-align: justify;
}
@media (max-width: 540px) {
  footer > dl {
    padding: 0 20px;
  }
}
footer > dl > dd > dl > dd > ul > li > ul {
  padding-left: 2em;
}
footer a {
  margin-bottom: 50px;
  color: #0099ff;
  display: block;
}
footer #copyright {
  height: 100px;
  font-family: "Helvetica Neue", Arial, sans-serif;
  color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  background: #0099ff;
}
@media (max-width: 540px) {
  footer #copyright {
    font-size: 0.625rem;
  }
}

/************************************
* Layouts - Home
************************************/
main#home {
  padding-bottom: 0;
}
main#home #content-wrapper #main-content section {
  max-width: none;
  padding: 80px 20px;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section {
    padding: 40px 20px;
  }
}
main#home #content-wrapper #main-content section:not(:last-of-type) {
  margin-bottom: 0;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section:not(:last-of-type) {
    margin-bottom: 0;
  }
}
main#home #content-wrapper #main-content section .content-inner {
  max-width: 1100px;
}
main#home #content-wrapper #main-content section .content-inner > h2 {
  margin: 0 auto 1em;
  font-size: 2.5rem;
  color: #000000;
  text-align: center;
  line-height: 1.2;
  font-weight: 800;
  position: relative;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section .content-inner > h2 {
    font-size: 1.5rem;
  }
}
main#home #content-wrapper #main-content section .content-inner > h2 img {
  margin: 0 auto 5px;
  display: block;
}
main#home #content-wrapper #main-content section .content-inner p {
  line-height: 1.2;
}
main#home #content-wrapper #main-content section .content-inner sub {
  font-size: 0.7em;
  vertical-align: baseline;
}
main#home #content-wrapper #main-content section#kv {
  max-width: none;
  width: 100%;
  height: 800px;
  margin-bottom: 0;
  padding: 0;
  overflow: hidden;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv {
    height: 55vh;
  }
}
main#home #content-wrapper #main-content section#kv .content-inner {
  max-width: none;
  width: 100%;
  height: 100%;
}
main#home #content-wrapper #main-content section#kv .content-inner > figure {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
main#home #content-wrapper #main-content section#kv .content-inner > figure > img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv .content-inner > figure > img {
    -o-object-position: 80%;
       object-position: 80%;
  }
}
main#home #content-wrapper #main-content section#kv .content-inner > figure > img.btm {
  height: auto;
  -o-object-fit: revert;
     object-fit: revert;
  position: absolute;
  bottom: 0;
}
main#home #content-wrapper #main-content section#kv .content-inner .lead {
  max-width: 1100px;
  height: 100%;
  margin-inline: auto;
  position: relative;
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div {
  height: auto;
  padding-top: 100px;
}
@media (max-width: 960px) {
  main#home #content-wrapper #main-content section#kv .content-inner .lead > div {
    width: 95%;
    margin-inline: auto;
    padding-top: 25px;
  }
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div h1 {
  margin-bottom: 30px;
  font-size: 7.5rem;
  font-size: 4.375rem;
  color: #fff700;
  text-align: justify;
  font-weight: 800;
  line-height: 1.2;
  text-shadow: 8px 8px 0 #0099ff;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv .content-inner .lead > div h1 {
    font-size: 2.25rem;
    text-align: center;
    text-shadow: 4px 4px 0 #0099ff;
  }
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div h1 ruby rt {
  font-size: 1.375rem;
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  gap: 40px;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv .content-inner .lead > div ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -webkit-box-pack: center;
            justify-content: center;
    -ms-flex-align: center;
    -webkit-box-align: center;
            align-items: center;
    gap: 10px;
  }
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div ul li {
  width: 200px;
  height: 200px;
  font-size: 2.25rem;
  color: #0099ff;
  text-align: center;
  line-height: 1.2;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border-radius: 100%;
  background: #ffffff;
  -webkit-box-shadow: 0 0 30px rgba(0, 166, 255, 0.8);
          box-shadow: 0 0 30px rgba(0, 166, 255, 0.8);
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div ul li:last-child {
  font-size: 1.75rem;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv .content-inner .lead > div ul li:last-child {
    font-size: 1.125rem;
  }
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv .content-inner .lead > div ul li {
    width: 120px;
    height: 120px;
    font-size: 1.375rem;
  }
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div p {
  margin-bottom: 30px;
  font-size: 4rem;
  color: #ffffff;
  text-align: justify;
  font-weight: 800;
  text-shadow: 8px 8px 0 #0099ff;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv .content-inner .lead > div p {
    font-size: 2.5rem;
    text-align: center;
    text-shadow: 4px 4px 0 #0099ff;
  }
}
main#home #content-wrapper #main-content section#kv .content-inner .lead > div p span {
  font-size: 3rem;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#kv .content-inner .lead > div p span {
    font-size: 1.875rem;
  }
}
main#home #content-wrapper #main-content section#comparison {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_wh.svg) no-repeat center top #ecf7ff;
  background-size: contain;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison {
    padding: 80px 0 40px;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner h2 {
  color: #0099ff;
}
main#home #content-wrapper #main-content section#comparison .content-inner p.note {
  padding: 0 20px;
}
main#home #content-wrapper #main-content section#comparison .content-inner .compare-outer {
  margin-bottom: 40px;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .compare-outer {
    padding: 0 20px;
    overflow: hidden;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .compare-outer .compare-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .compare-outer .compare-inner {
    padding: 10px 0 18px;
    overflow-x: scroll;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .col-labels {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col-labels-header {
  width: 200px;
  margin-bottom: 4px;
  padding: 20px 0 15px;
  text-align: center;
  font-weight: 600;
  margin-bottom: 4px;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .col-labels-header {
    width: 120px;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .col-labels-header .plan figure img {
  max-width: 130px;
  margin-inline: auto;
}
main#home #content-wrapper #main-content section#comparison .content-inner .row-label {
  width: 200px;
  height: 80px;
  font-size: 1.25rem;
  color: #0099ff;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  background: #ffffff;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .row-label {
    width: 120px;
    height: 60px;
    font-size: 1rem;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .row-label:not(:last-of-type) {
  margin-bottom: 4px;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col.featured {
  margin-top: -16px;
  margin-bottom: -16px;
  background: #ecf7ff;
  -webkit-box-shadow: 8px 8px 0 0 #f29033;
          box-shadow: 8px 8px 0 0 #f29033;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .col.featured {
    margin-top: -8px;
    margin-bottom: -8px;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .col.featured {
  z-index: 1;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col.featured .col-header {
  width: 330px;
  margin-bottom: 4px;
  font-weight: 600;
  background: #ffa033;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .col.featured .col-header {
    width: 220px;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .col.featured .cell {
  width: 330px;
  height: 85px;
  font-weight: 500;
  background: #ffe0bd;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .col.featured .cell {
    width: 220px;
    height: 65px;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .col.featured .cell.circle_w {
  background-image: url(../../assets/images/circle_w.png);
  background-repeat: no-repeat;
  background-position: center center;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col.featured .cell.circle_s {
  background-image: url(../../assets/images/circle_s.png);
  background-repeat: no-repeat;
  background-position: center center;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col.featured .price {
  font-size: 20px;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col-header {
  width: 187px;
  margin-bottom: 4px;
  padding: 20px 0 15px;
  text-align: center;
  font-weight: 400;
  background: #ffffff;
}
main#home #content-wrapper #main-content section#comparison .content-inner .col-header .plan figure img {
  max-width: 130px;
  margin-inline: auto;
}
main#home #content-wrapper #main-content section#comparison .content-inner .cell {
  width: 187px;
  height: 80px;
  font-size: 1.25rem;
  text-align: center;
  font-weight: 600;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  background: #ffffff;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#comparison .content-inner .cell {
    height: 60px;
  }
}
main#home #content-wrapper #main-content section#comparison .content-inner .cell:not(:last-of-type) {
  margin-bottom: 4px;
}
main#home #content-wrapper #main-content section#comparison .content-inner .cell.circle_w {
  background-image: url(../../assets/images/circle_w.png);
  background-repeat: no-repeat;
  background-position: center center;
}
main#home #content-wrapper #main-content section#comparison .content-inner .cell.circle_s {
  background-image: url(../../assets/images/circle_s.png);
  background-repeat: no-repeat;
  background-position: center center;
}
main#home #content-wrapper #main-content section#comparison .content-inner .cell a.btn {
  width: 85%;
  padding: 0.5em;
  font-size: 1.625rem;
  font-weight: 600;
}
main#home #content-wrapper #main-content section#comparison .content-inner .check {
  color: #000;
  font-size: 16px;
}
main#home #content-wrapper #main-content section#comparison .content-inner .cross {
  color: #000;
  font-size: 16px;
}
main#home #content-wrapper #main-content section#comparison .content-inner .price {
  font-size: 18px;
  font-weight: 500;
}
main#home #content-wrapper #main-content section#recommend {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_lb.svg) no-repeat center top #ffe0bd;
  background-size: contain;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#recommend {
    padding: 80px 20px 60px;
  }
}
main#home #content-wrapper #main-content section#recommend .content-inner h2 {
  margin-bottom: 80px;
  padding: 36px 0;
  font-size: 3rem;
  color: #ffffff;
  background: #0099ff;
  -webkit-filter: drop-shadow(8px 8px 0 rgba(0, 153, 255, 0.5));
          filter: drop-shadow(8px 8px 0 rgba(0, 153, 255, 0.5));
  position: relative;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#recommend .content-inner h2 {
    margin-bottom: 60px;
    padding: 0.5em;
    font-size: 1.5rem;
  }
}
main#home #content-wrapper #main-content section#recommend .content-inner h2:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 45px 22.5px 0;
  border-color: #0099ff transparent transparent;
  position: absolute;
  bottom: -45px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#recommend .content-inner h2:after {
    border-width: 30px 15px 0;
    border-color: #0099ff transparent transparent;
    position: absolute;
    bottom: -30px;
  }
}
main#home #content-wrapper #main-content section#recommend .content-inner h2 span {
  font-size: 4rem;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#recommend .content-inner h2 span {
    font-size: 2.25rem;
  }
}
main#home #content-wrapper #main-content section#flow {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_lo.svg) no-repeat center top #ecf7ff;
  background-size: contain;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow {
    padding: 80px 20px 60px;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner h2 {
  font-size: 3rem;
  color: #0099ff;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner h2 {
    margin-bottom: 1.5em;
    font-size: 1.875rem;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner h2 span {
  font-size: 6rem;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner h2 span {
    font-size: 3rem;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul {
  margin-bottom: 2em;
}
main#home #content-wrapper #main-content section#flow .content-inner ul li {
  height: 250px;
  border-radius: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  background: #0099ff;
  -webkit-box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
          box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
  position: relative;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul li {
    height: 210px;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul li.time {
  height: 110px;
  background: #fff700;
  -webkit-box-shadow: 8px 8px 0 0 #f1dcb2;
          box-shadow: 8px 8px 0 0 #f1dcb2;
}
main#home #content-wrapper #main-content section#flow .content-inner ul li.time p {
  margin-bottom: 0;
  font-size: 2.5rem;
  color: #0099ff;
  text-align: center;
  font-weight: 600;
}
main#home #content-wrapper #main-content section#flow .content-inner ul li.time p span {
  color: #ff3a33;
  font-weight: 800;
}
main#home #content-wrapper #main-content section#flow .content-inner ul li.time p span strong {
  font-size: 4rem;
}
main#home #content-wrapper #main-content section#flow .content-inner ul li:first-child {
  margin-bottom: 20px;
}
main#home #content-wrapper #main-content section#flow .content-inner ul li:not(:first-child):not(:last-child) {
  margin-bottom: 110px;
}
main#home #content-wrapper #main-content section#flow .content-inner ul li:not(:first-child):not(:last-child):after {
  content: "\eef6";
  font-size: 6.25rem;
  color: #0099ff;
  font-family: "Material Symbols Outlined";
  position: absolute;
  bottom: -135px;
  -webkit-transform: rotateZ(180deg);
          transform: rotateZ(180deg);
}
main#home #content-wrapper #main-content section#flow .content-inner ul li > div.no {
  width: 162px;
  height: 162px;
  border-radius: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  background: #ffffff;
  position: absolute;
  top: -60px;
  left: -35px;
  -webkit-box-shadow: 8px 8px 0 0 #0089e5;
          box-shadow: 8px 8px 0 0 #0089e5;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul li > div.no {
    width: 80px;
    height: 80px;
    -webkit-box-shadow: 4px 4px 0 0 #0089e5;
            box-shadow: 4px 4px 0 0 #0089e5;
    top: -20px;
    left: -10px;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul li > div.no div {
  font-size: 6rem;
  color: #0099ff;
  text-align: center;
  font-weight: 600;
  line-height: 1;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul li > div.no div {
    font-size: 2.5rem;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul li > div.no div span {
  width: 100%;
  font-size: 1.5rem;
  display: block;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul li > div.no div span {
    font-size: 1rem;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul li figure {
  width: calc(100% - 165px);
  height: 100%;
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul li figure {
    width: 100%;
    height: auto;
    display: block;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul li figure img {
  margin-inline: auto;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul li figure img {
    width: 60%;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul li figure figcaption {
  width: 58%;
  margin-left: auto;
  font-size: 2.5rem;
  color: #ffffff;
  font-weight: 600;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul li figure figcaption {
    width: 100%;
    font-size: 1.5rem;
    text-align: center;
  }
}
main#home #content-wrapper #main-content section#flow .content-inner ul {
  text-align: justify;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#flow .content-inner ul {
    font-size: 1rem;
  }
}
main#home #content-wrapper #main-content section#offer {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_lb.svg) no-repeat center top #fff700;
  background-size: contain;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#offer {
    padding: 80px 20px 20px;
  }
}
main#home #content-wrapper #main-content section#offer .content-inner h2 {
  margin-bottom: 80px;
  padding: 36px 0;
  font-size: 3rem;
  color: #ffffff;
  background: #0099ff;
  -webkit-filter: drop-shadow(8px 8px 0 rgba(0, 153, 255, 0.5));
          filter: drop-shadow(8px 8px 0 rgba(0, 153, 255, 0.5));
  position: relative;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#offer .content-inner h2 {
    font-size: 1.5rem;
  }
}
main#home #content-wrapper #main-content section#offer .content-inner h2:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 45px 22.5px 0;
  border-color: #0099ff transparent transparent;
  position: absolute;
  bottom: -45px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
main#home #content-wrapper #main-content section#offer .content-inner h2 span {
  font-size: 4rem;
}
@media (max-width: 540px) {
  main#home #content-wrapper #main-content section#offer .content-inner h2 span {
    font-size: 1.875rem;
  }
}

/************************************
* Layouts - Result
************************************/
main#result {
  padding-bottom: 0;
}
main#result #content-wrapper #main-content section {
  max-width: none;
  padding: 80px 20px;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section {
    padding: 40px 20px;
  }
}
main#result #content-wrapper #main-content section:not(:last-of-type) {
  margin-bottom: 0;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section:not(:last-of-type) {
    margin-bottom: 0;
  }
}
main#result #content-wrapper #main-content section .content-inner {
  max-width: 1100px;
}
main#result #content-wrapper #main-content section .content-inner > h2 {
  margin: 0 auto 1em;
  font-size: 2.5rem;
  color: #000000;
  text-align: center;
  line-height: 1.2;
  font-weight: 800;
  position: relative;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section .content-inner > h2 {
    font-size: 1.5rem;
  }
}
main#result #content-wrapper #main-content section .content-inner > h2 img {
  margin: 0 auto 5px;
  display: block;
}
main#result #content-wrapper #main-content section .content-inner sub {
  font-size: 0.7em;
  vertical-align: baseline;
}
main#result #content-wrapper #main-content section#results {
  background: #ecf7ff;
}
main#result #content-wrapper #main-content section#results .content-inner .result-box {
  border: solid 4px #0099ff;
  border-radius: 25px;
  background: #ffffff;
  -webkit-box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
          box-shadow: 8px 8px 0 0 rgba(0, 153, 255, 0.5);
  overflow: hidden;
}
main#result #content-wrapper #main-content section#results .content-inner .result-box h2 {
  height: 100px;
  margin: 0;
  font-size: 2.5rem;
  color: #ffffff;
  text-align: center;
  line-height: 1;
  font-weight: 800;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  background: #0099ff;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#results .content-inner .result-box h2 {
    font-size: 1.5rem;
    height: 60px;
    line-height: 1.2;
  }
}
main#result #content-wrapper #main-content section#results .content-inner .result-box h2 span {
  color: #ffcc00;
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div {
  padding: 40px 60px 60px;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#results .content-inner .result-box > div {
    padding: 20px;
  }
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div ul {
  margin-bottom: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 40px 0;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#results .content-inner .result-box > div ul {
    margin-bottom: 20px;
    display: block;
  }
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div ul li {
  width: 50%;
  font-size: 1.5rem;
  color: #0099ff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#results .content-inner .result-box > div ul li {
    width: 100%;
    margin-bottom: 0.5em;
    font-size: 1.125rem;
  }
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div a {
  width: 45%;
  height: 80px;
  margin-inline: auto;
  font-size: 2rem;
  color: #0099ff;
  font-weight: 600;
  background: #f5f5f5;
  -webkit-box-shadow: 0 8px 0 0 #d9d9d9;
          box-shadow: 0 8px 0 0 #d9d9d9;
  position: relative;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#results .content-inner .result-box > div a {
    width: 100%;
    height: 60px;
    font-size: 1.5rem;
  }
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div a:hover {
  -webkit-box-shadow: 0 6px 0 0 #d9d9d9;
          box-shadow: 0 6px 0 0 #d9d9d9;
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div a:active {
  -webkit-box-shadow: 0 0 0 0 #d9d9d9;
          box-shadow: 0 0 0 0 #d9d9d9;
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div a:focus {
  -webkit-box-shadow: 0 6px 0 0 #d9d9d9;
          box-shadow: 0 6px 0 0 #d9d9d9;
}
main#result #content-wrapper #main-content section#results .content-inner .result-box > div a:after {
  content: "\f591";
  font-size: 2.25rem;
  font-family: "Material Symbols Outlined";
  font-variation-settings: "FILL" 1;
  position: absolute;
  right: 20px;
}
main#result #content-wrapper #main-content section#search {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_lb.svg) no-repeat center top #ffffff;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#search {
    padding: 80px 20px 60px;
  }
}
main#result #content-wrapper #main-content section#recommend {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_lb.svg) no-repeat center top #ffffff;
  background-size: contain;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#recommend {
    padding: 80px 20px 60px;
  }
}
main#result #content-wrapper #main-content section#recommend .content-inner h2 {
  margin-bottom: 80px;
  padding: 36px 0;
  font-size: 4rem;
  color: #0099ff;
  background: #fff700;
  -webkit-filter: drop-shadow(8px 8px 0 #eadf00);
          filter: drop-shadow(8px 8px 0 #eadf00);
  position: relative;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#recommend .content-inner h2 {
    margin-bottom: 60px;
    padding: 0.5em;
    font-size: 1.5rem;
  }
}
main#result #content-wrapper #main-content section#recommend .content-inner h2:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 45px 22.5px 0;
  border-color: #fff700 transparent transparent;
  position: absolute;
  bottom: -45px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#recommend .content-inner h2:after {
    border-width: 30px 15px 0;
    border-color: #fff700 transparent transparent;
    position: absolute;
    bottom: -30px;
  }
}
main#result #content-wrapper #main-content section#recommend .content-inner h2 span {
  font-size: 4rem;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#recommend .content-inner h2 span {
    font-size: 2.25rem;
  }
}
main#result #content-wrapper #main-content section#chart {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_yl.svg) no-repeat center top #ecf7ff;
  background-size: contain;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart {
    padding: 80px 20px 60px;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner h2 {
  font-size: 3rem;
  color: #0099ff;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner h2 {
    font-size: 1.5rem;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner h2 span {
  font-size: 6rem;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner h2 span {
    font-size: 3rem;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab {
  margin-bottom: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  gap: 20px;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner ul.tab {
    margin-bottom: 30px;
    gap: 10px;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab li {
  width: calc((100% - 60px) / 4);
  height: 50px;
  font-size: 2.5rem;
  font-weight: 600;
  color: #0099ff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
          justify-content: center;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  border: solid 4px #0099ff;
  border-radius: 10px;
  background: #ffffff;
  cursor: pointer;
  position: relative;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner ul.tab li {
    width: calc((100% - 30px) / 4);
    font-size: 1rem;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab li:hover, main#result #content-wrapper #main-content section#chart .content-inner ul.tab li.active {
  color: #ffffff;
  background: #0099ff;
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab li:hover:after, main#result #content-wrapper #main-content section#chart .content-inner ul.tab li.active:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 40px 20px 0;
  border-color: #0099ff transparent transparent;
  position: absolute;
  bottom: -40px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner ul.tab li:hover:after, main#result #content-wrapper #main-content section#chart .content-inner ul.tab li.active:after {
    border-width: 20px 10px 0;
    bottom: -20px;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab li sub {
  font-size: 0.5em;
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content {
  margin-bottom: 20px;
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li {
  padding: 20px 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  gap: 10px;
  border: solid 4px #0099ff;
  border-radius: 10px;
  background: #ffffff;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li {
    padding: 10px;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li:not(:last-child) {
  margin-bottom: 10px;
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li img {
  width: 55px;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li img {
    width: 40px;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li p {
  font-size: 3rem;
  color: #000000;
  font-weight: 800;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li p {
    font-size: 1.375rem;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li a.btn {
  height: 50px;
  margin-left: auto;
  padding: 0 1em;
  font-size: 1.625rem;
  font-weight: 600;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#chart .content-inner ul.tab-content li a.btn {
    height: 40px;
    font-size: 1.125rem;
  }
}
main#result #content-wrapper #main-content section#chart .content-inner p {
  margin-bottom: 0;
  font-size: 0.875rem;
  color: #0099ff;
}
main#result #content-wrapper #main-content section#offer {
  padding: 150px 0 80px;
  background: url(../../assets/images/common/sep_wh.svg) no-repeat center top #fff700;
  background-size: contain;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#offer {
    padding: 80px 20px 60px;
  }
}
main#result #content-wrapper #main-content section#offer .content-inner h2 {
  margin-bottom: 80px;
  padding: 36px 0;
  font-size: 3rem;
  color: #ffffff;
  background: #0099ff;
  -webkit-filter: drop-shadow(8px 8px 0 rgba(0, 153, 255, 0.5));
          filter: drop-shadow(8px 8px 0 rgba(0, 153, 255, 0.5));
  position: relative;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#offer .content-inner h2 {
    margin-bottom: 60px;
    padding: 0.5em;
    font-size: 1.5rem;
  }
}
main#result #content-wrapper #main-content section#offer .content-inner h2:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 45px 22.5px 0;
  border-color: #0099ff transparent transparent;
  position: absolute;
  bottom: -45px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#offer .content-inner h2:after {
    border-width: 30px 15px 0;
    border-color: #0099ff transparent transparent;
    position: absolute;
    bottom: -30px;
  }
}
main#result #content-wrapper #main-content section#offer .content-inner h2 span {
  font-size: 4rem;
  color: #fff700;
}
@media (max-width: 540px) {
  main#result #content-wrapper #main-content section#offer .content-inner h2 span {
    font-size: 1.875rem;
  }
}
main#result #content-wrapper #main-content section#offer .content-inner .card {
  display: none;
}
main#result #content-wrapper #main-content section#offer .content-inner .card.active {
  display: block;
}

/************************************
* Layouts - Lower
************************************/
main#lower {
  min-height: auto;
  padding-bottom: 0;
}
main#lower #content-wrapper #main-content section {
  max-width: none;
  padding: 80px 20px;
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section {
    padding: 40px 20px;
  }
}
main#lower #content-wrapper #main-content section:not(:last-of-type) {
  margin-bottom: 0;
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section:not(:last-of-type) {
    margin-bottom: 0;
  }
}
main#lower #content-wrapper #main-content section#request-completed .content-inner {
  text-align: center;
  background: #ffffff;
}
main#lower #content-wrapper #main-content section#request-completed .content-inner h2 {
  margin-bottom: 1em;
  text-align: center;
}
main#lower #content-wrapper #main-content section#tos, main#lower #content-wrapper #main-content section#privacy-policy, main#lower #content-wrapper #main-content section#inquiry, main#lower #content-wrapper #main-content section#company {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
          justify-content: space-between;
  -ms-flex-align: start;
  -webkit-box-align: start;
          align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
main#lower #content-wrapper #main-content section#tos .content-inner, main#lower #content-wrapper #main-content section#privacy-policy .content-inner, main#lower #content-wrapper #main-content section#inquiry .content-inner, main#lower #content-wrapper #main-content section#company .content-inner {
  max-width: 1100px;
  margininline: auto;
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section#tos .content-inner, main#lower #content-wrapper #main-content section#privacy-policy .content-inner, main#lower #content-wrapper #main-content section#inquiry .content-inner, main#lower #content-wrapper #main-content section#company .content-inner {
    width: 100%;
  }
}
main#lower #content-wrapper #main-content section#tos .content-inner > h2, main#lower #content-wrapper #main-content section#privacy-policy .content-inner > h2, main#lower #content-wrapper #main-content section#inquiry .content-inner > h2, main#lower #content-wrapper #main-content section#company .content-inner > h2 {
  margin: 0 auto 1em;
  font-size: 2.5rem;
  text-align: center;
  line-height: 1.2;
  font-weight: 800;
  position: relative;
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section#tos .content-inner > h2, main#lower #content-wrapper #main-content section#privacy-policy .content-inner > h2, main#lower #content-wrapper #main-content section#inquiry .content-inner > h2, main#lower #content-wrapper #main-content section#company .content-inner > h2 {
    font-size: 1.5rem;
  }
}
main#lower #content-wrapper #main-content section#tos .content-inner dl {
  margin-top: 1em;
}
main#lower #content-wrapper #main-content section#tos .content-inner dl dd {
  padding-left: 1em;
}
main#lower #content-wrapper #main-content section#tos .content-inner dl dd:not(:last-of-type) {
  margin-bottom: 1em;
}
main#lower #content-wrapper #main-content section#tos .content-inner dl dd > ul > li > ul {
  padding-left: 1em;
}
main#lower #content-wrapper #main-content section#privacy-policy .content-inner > ol {
  margin: 1em 0 1em 2em;
  list-style: decimal;
}
main#lower #content-wrapper #main-content section#inquiry .content-inner dl {
  margin-bottom: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section#inquiry .content-inner dl {
    display: block;
  }
}
main#lower #content-wrapper #main-content section#inquiry .content-inner dl dt {
  width: calc(10% + 2em);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: start;
  -webkit-box-pack: start;
          justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section#inquiry .content-inner dl dt {
    width: 100%;
  }
}
main#lower #content-wrapper #main-content section#inquiry .content-inner dl dd {
  width: calc(90% - 2em);
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section#inquiry .content-inner dl dd {
    width: 100%;
  }
}
main#lower #content-wrapper #main-content section#inquiry .content-inner dl dd input, main#lower #content-wrapper #main-content section#inquiry .content-inner dl dd textarea {
  width: 100%;
}
main#lower #content-wrapper #main-content section#inquiry .content-inner .acceptance {
  margin-bottom: 20px;
  text-align: center;
}
main#lower #content-wrapper #main-content section#inquiry .content-inner input[type=submit] {
  margin: auto;
  display: block;
}
@media (max-width: 540px) {
  main#lower #content-wrapper #main-content section#company .content-inner table td {
    width: 100%;
    display: block;
    border: none;
  }
}
/*# sourceMappingURL=style.css.map */