@media only screen and (max-width: 768px) {
  .home_page .key {
    --height: calc(100vh - 60px);
    --max-height: 145vw;
    --min-height: 320px;
    margin: 60px 20px;
    font-size: 8px;
  }
  .home_page .key .inner_max {
    padding: 20px;
  }
  .home_page .key .key_text .item {
    padding: 0;
  }
  .home_page .key .key_text .item::before {
    background-image: linear-gradient(to top, rgb(0, 0, 0) 15%, rgba(0, 0, 0, 0) 70%);
  }
  .home_page .key .catch {
    padding-bottom: clamp(50px, 15.625vw, 80px);
  }
  .home_page .key h2,
  .home_page .key p {
    text-align: center;
  }
  .home_page .key h2 {
    font-size: max(26px, 6.4em);
  }
  .home_page .key p {
    line-height: 1.5;
    font-size: max(18px, 2.9em);
  }
}
@media only screen and (max-width: 640px) {
  .home_page .key {
    font-size: 1vmin;
  }
}
@media only screen and (max-width: 768px) and (orientation: landscape) {
  .home_page .key {
    font-size: 1vmin;
  }
}
@media only screen and (max-width: 768px) and (orientation: portrait) {
  .home_page .key .s1 {
    background-image: url("../images/idx_key_bg01_sp.jpg");
  }
  .home_page .key .slick-initialized .s2 {
    background-image: url("../images/idx_key_bg02_sp.jpg");
  }
  .home_page .key .slick-initialized .s3 {
    background-image: url("../images/idx_key_bg03_sp.jpg");
  }
}
@media only screen and (max-width: 768px) {
  .home_page h3 {
    margin-bottom: 30px;
    font-size: calc(var(--ttl_size));
  }
  .home_page h3.sm {
    font-size: calc(var(--ttl_size) - 2px);
  }
}
@media only screen and (max-width: 768px) {
  .idx01 {
    padding: 60px 0;
  }
  .idx01 h4 {
    font-size: calc(var(--ttl_size) + 6px);
    text-align: center;
  }
  .idx01 h4 > span {
    display: block;
  }
  .idx01 h4 .jp {
    font-size: 14px;
  }
  .idx01 .content .box {
    padding: 30px 20px;
    border-radius: 20px;
    margin: 0 auto;
  }
  .idx01 .content .box:not(:last-child) {
    margin-bottom: 30px;
  }
  .idx01 .content .btn-group .btn {
    margin: 0 auto;
  }
  .idx01 .content li a {
    padding: 1.2em 0;
    --w: 7em;
  }
  .idx01 .content ul {
    margin-bottom: 20px;
  }
  .idx02 {
    padding-bottom: 60px;
  }
  .idx02::before, .idx02::after {
    font-size: min(0.46875vw, 10px);
  }
  .idx02 .content {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }
  .idx02 .content .box {
    display: contents;
  }
  .idx02 .content .box .item {
    font-size: min(2.1875vw, 10px);
    width: calc(50% - 5px);
    max-width: 21.2em;
    aspect-ratio: 1/1;
    height: auto;
  }
  .idx02 .content .box .item .txt::after {
    font-size: min(2.1875vw, 10px);
  }
  .idx02 picture {
    font-size: min(2.1875vw, 10px);
    width: calc(50% - 5px);
    max-width: 21.2em;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .idx02 picture img {
    width: auto;
    max-height: 100%;
    margin: 0 auto;
  }
  .idx03 .box_img .en {
    font-size: clamp(40px, 8vw, 80px);
  }
  .idx04 {
    padding: 60px 0;
  }
  .idx04::before {
    height: clamp(250px, 30vw, 520px);
  }
  .idx04 .TabContainer .TabPager {
    border-radius: 10px 10px 0 0;
  }
  .idx04 .TabContainer .TabPager .tt {
    padding: 15px 10px;
    font-size: 18px;
  }
  .idx04 .TabContainer .TabContent {
    border-radius: 0 0 15px 15px;
  }
  .idx04 .TabContainer .TabContent .content > div {
    padding: 30px 20px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_box {
    margin-bottom: 30px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_box picture {
    margin-bottom: 20px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_box picture img {
    width: 100%;
    max-width: 450px;
    margin: 0 auto;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_box .ttl {
    text-align: center;
    font-size: 24px;
    margin-bottom: 20px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_box .btn-group {
    justify-content: center;
  }
  .idx04 .TabContainer .TabContent .content > div .box_content {
    margin: 0 auto;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_list {
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_list .item {
    width: calc(50% - 5px);
    height: clamp(120px, 20vw, 150px);
  }
  .idx04 .TabContainer .TabContent .content > div .idx_list .item .ic-arr {
    font-size: 6px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_list .item .ic-arr::after {
    right: 9px;
  }
  .idx05 .wrap {
    font-size: min(0.9375vw, 10px);
  }
  .idx05 .TabContainer .TabPager {
    border-radius: 10px 10px 0 0;
    gap: 10px;
  }
  .idx05 .TabContainer .TabPager > div {
    border-radius: 10px 10px 0 0;
    width: calc(45% - 5px);
  }
  .idx05 .TabContainer .TabPager > div .tt {
    padding: 15px 10px;
    font-size: 16px;
  }
  .idx05 .TabContainer .TabContent {
    border-radius: 15px;
  }
  .idx05 .TabContainer .TabContent .content > div {
    padding: 30px 15px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list {
    --gap: 10px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list .item {
    width: calc(50% - var(--gap) / 2);
    padding: 20px 10px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list .item .ttl {
    font-size: 18px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list .item .ttl::before {
    margin-bottom: 1em;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list .item .ic-arr {
    font-size: 6px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list .item .ic-arr::after {
    right: 9px;
  }
  .idx06 {
    padding: 180px 0 100px;
  }
  .idx06::before {
    width: 100%;
    max-width: 425px;
    left: 0;
  }
  .idx06 .idx_box::before {
    font-size: 3px;
    bottom: -100px;
    right: 0;
  }
  .idx06 .desc {
    margin-bottom: 30px;
  }
  .idx06 .desc p:not(:last-child) {
    margin-bottom: 15px;
  }
  .idx06 .btn-group .btn {
    margin: 0 auto;
  }
  .idx07 {
    padding: 60px 0;
  }
  .idx07 .wrap {
    border-radius: 15px;
  }
  .idx07 .sub-ttl {
    font-size: 20px;
    text-align: center;
  }
  .idx07 .idx_box {
    margin-bottom: 40px;
  }
  .idx07 .idx_box picture {
    margin-bottom: 20px;
  }
  .idx07 .idx_box picture img {
    max-width: 450px;
    width: 100%;
    margin: 0 auto;
  }
  .idx07 .idx_box .desc {
    margin-bottom: 30px;
  }
  .idx07 .idx_box .btn-group .btn {
    margin: 0 auto;
  }
  .idx07 .idx_list {
    --gap: 10px;
    margin-bottom: 40px;
  }
  .idx07 .idx_list .item {
    font-size: clamp(6px, 1.2vw, 8.75px);
    width: calc(50% - var(--gap) / 2);
    padding: 20px 10px;
  }
  .idx07 .idx_list .item .ttl {
    line-height: 1.5;
  }
  .idx07 .idx_list .item .ic-arr {
    font-size: 6px;
  }
  .idx07 .idx_list .item .ic-arr::after {
    right: 9px;
  }
  .idx08 {
    padding-bottom: 80px;
  }
  .idx08::before {
    font-size: 3px;
    bottom: 0;
    right: 0;
  }
  .idx08 h3 {
    margin-bottom: 50px;
  }
  .idx08 .idx_list {
    max-width: 550px;
    margin: 0 auto;
    font-size: 10px;
    margin-bottom: max(50px, 10vw);
  }
  .idx08 .idx_list .item:not(:last-child) {
    margin-bottom: max(50px, 10vw);
  }
  .idx08 .idx_list .item:nth-child(4n+1) .ite_img::before, .idx08 .idx_list .item:nth-child(4n) .ite_img::before {
    top: -35px;
    left: -15px;
  }
  .idx08 .idx_list .item:nth-child(4n+1) .ite_img picture, .idx08 .idx_list .item:nth-child(4n) .ite_img picture {
    max-width: 360px;
  }
  .idx08 .idx_list .item:nth-child(4n+1) .ite_content, .idx08 .idx_list .item:nth-child(4n) .ite_content {
    margin-left: auto;
  }
  .idx08 .idx_list .item:nth-child(4n+2) .ite_img::before, .idx08 .idx_list .item:nth-child(4n+3) .ite_img::before {
    top: -35px;
    right: -15px;
  }
  .idx08 .idx_list .item:nth-child(4n+2) .ite_img picture, .idx08 .idx_list .item:nth-child(4n+3) .ite_img picture {
    max-width: 440px;
    margin-left: auto;
  }
  .idx08 .idx_list .ite_img picture {
    width: 90%;
  }
  .idx08 .idx_list .ite_img picture img {
    border-radius: 15px;
  }
  .idx08 .idx_list .ite_content {
    position: relative;
    width: 60%;
    margin-top: -25em;
  }
  .idx08 .idx_list .ite_content .ttl {
    margin-bottom: 15px;
    text-shadow: 2px 2px 8px #fff, 3px 3px 10px #fff, 4px 4px 12px #fff;
  }
  .idx08 .idx_list .ite_content .txt {
    border-radius: 10px;
    padding: 20px 20px 30px;
  }
  .idx08 .idx_list .ite_content .ic-arr {
    font-size: 6px;
    right: 20px;
    bottom: 20px;
  }
  .idx08 .idx_list .ite_content .ic-arr::after {
    right: 9px;
  }
  .idx09 {
    padding: 60px 0;
  }
  .idx09 .idx_box {
    max-width: 550px;
    margin: 0 auto;
    flex-direction: column-reverse;
  }
  .idx09 .box_img picture {
    margin-bottom: 30px;
  }
  .idx09 .box_img picture img {
    border-radius: 15px;
  }
  .idx09 .idx_logo a {
    margin: 0 auto;
  }
  .idx09 .idx_payment {
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 30px;
  }
  .idx09 .time_sheet .tbl {
    font-size: min(2.25vw, 10px);
  }
  .idx_map {
    height: 299px;
  }
  .idx10 {
    padding: 50px 0 0;
  }
  .idx10 h3 {
    text-shadow: 2px 2px 8px #fff, 3px 3px 10px #fff, 4px 4px 12px #fff;
    margin-bottom: 20px;
  }
  .idx10 .wrap {
    border-radius: 15px;
    padding-bottom: 40px;
  }
}
@media only screen and (max-width: 639px) {
  .idx03 .box_content {
    padding: 30px 20px;
  }
  .idx03 .box_content .desc {
    margin-bottom: 30px;
  }
  .idx03 .box_content .txt {
    padding: 30px 20px;
  }
  .idx08 .idx_list .ite_content {
    width: 90%;
    margin-top: -12em;
  }
}
@media only screen and (max-width: 430px) {
  .idx07 .idx_list .item {
    padding-bottom: 30px;
  }
  .idx07 .idx_list .item .txt {
    flex-direction: column;
  }
  .idx07 .idx_list .item .txt .ic {
    margin-bottom: 10px;
  }
  .idx07 .idx_list .item .txt .ttl {
    text-align: center;
  }
}
@media only screen and (max-width: 360px) {
  .home_page .key .inner_max {
    padding: 15px;
  }
  .home_page .key h2 {
    font-size: 22px;
  }
  .idx02 .item .txt {
    font-size: 12px;
  }
  .idx04 .TabContainer .TabContent .content > div {
    padding-left: 15px;
    padding-right: 15px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_list {
    gap: 5px;
  }
  .idx04 .TabContainer .TabContent .content > div .idx_list .item .ttl {
    font-size: 14px;
  }
  .idx05 .TabContainer .TabContent .content > div {
    padding-left: 15px;
    padding-right: 15px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list {
    --gap: 4px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list .item {
    padding-left: 5px;
    padding-right: 5px;
  }
  .idx05 .TabContainer .TabContent .content > div .idx_list .item .ttl {
    font-size: 16px;
  }
}

/*# sourceMappingURL=index_sp.css.map */
