@charset "utf-8";

@font-face {
    font-family: 'North Avellion';
    src: url('/penguin/resources/css/bestrent/home/fonts/north_avellion/North Avellion.ttf') format('truetype');
}

.font_01 {
    font-family: 'North Avellion', sans-serif;
    letter-spacing: 0.03em;
    line-height: 1;
}

@font-face {
    font-family: 'noto sans jp black';
    src: url('/penguin/resources/css/bestrent/home/fonts/Noto_Sans_JP/NotoSansJP-Black.otf') format('opentype');
}

@font-face {
    font-family: 'helvetica bold';
    src: url('/penguin/resources/css/bestrent/home/fonts/Helvetica-Font/Helvetica-Bold.ttf') format('truetype');
}

@font-face {
    font-family: 'helvetica regular';
    src: url('/penguin/resources/css/bestrent/home/fonts/Helvetica-Font/Helvetica.ttf') format('truetype');
}


* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

html {
    font-size: 100%;
    overflow-y: scroll;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
}

html,
button,
input,
select,
textarea {
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
}

body {
    color: #000;
    font-size: 12px;
    line-height: 1.4;
    margin: 0px;
    min-width: 1340px;
    overflow: hidden;
    margin-bottom: 60px;
}

body {
    background-color: #FFFFFF;
}

p {
    margin: 0px;
}

img {
    max-width: 100%;
    vertical-align: bottom;
}

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

h1, h2, h3, h4 {
    margin: 0;
}

.pr_img {
    overflow: hidden;
    position: relative;
}

img.pa_img {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    display: block;
}

.sp {
    display: none;
}

.flex {
    flex-wrap: wrap;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
}

.flex-sb {
    flex-wrap: wrap;
    display: -webkit-box;
    display: -moz-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    justify-content: space-between;
}

a {
    text-decoration: none;
}

.wrap {
    width: 1140px;
    margin: 0 auto;
}

.wrap.wide {
    width: 1240px;
}

.hd_cont {
    width: 1340px;
    margin: auto;
    background-color: #fff;
    border-radius: 100px;
    align-items: center;
    padding: 13px 50px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
}

.hd_nav ul li a {
    color: #000;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.04em;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.hd_nav ul li + li {
    margin-left: 35px;
}

.hd_nav ul li a:hover {
    color: #015BAC;
}

.hd_cont .link_cont {
    align-items: center;
}

.hd_cont .link_cont .fav_btn {
    margin-left: 35px;
}

.hd_cont .link_cont .fav_btn a {
    width: 150px;
    height: 36px;
    border-radius: 100vmax;
    border: 1px solid #015BAC;
    color: #015BAC;
    align-items: center;
    justify-content: center;
    transition: .3s;
}

.hd_cont .link_cont .fav_btn a:hover {
    background-color: #015BAC;
    color: #fff;
}

.hd_cont .link_cont .fav_btn a .icon {
    width: 15px;
    line-height: 1;
    margin-right: 10px;
}

.hd_cont .link_cont .fav_btn a .icon svg {
    width: 100%;
    vertical-align: middle;
}

.hd_cont .link_cont .fav_btn a .icon svg path {
    fill: #015BAC;
    transition: .3s;
}

.hd_cont .link_cont .fav_btn a:hover .icon svg path {
    fill: #fff;
}

.hd_cont .link_cont .fav_btn a .text {
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.05em;
    line-height: 1;
}



header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    padding: 25px 0 0;
    z-index: 100000;
}

section.top_mv {
    background-image: url(/penguin/resources/image/bestrent/home/top_mv_img.jpg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    background-color: #a1a1a1;
    padding: 140px 0 89px;
    position: relative;
    overflow: hidden;
}

.top_mv .slider_wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.top_mv .slider_wrap .slick-list {
    height: 100%;
}

.top_mv .slider_wrap .slick-track {
    height: 100%;
}

.top_mv .slider_wrap ul {
    height: 100%;
}

.top_mv .slider_wrap ul li {
    height: 100%;
    line-height: 1;
}

.top_mv .slider_wrap ul li img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.top_mv .wrap {
    position: relative;
    z-index: 2;
}

.top_mv_container .text_box {
    color: #fff;
}

.top_mv_container {
    display: grid;
    grid-template-columns: 1fr 500px;
    column-gap: 50px;
    align-items: center;
}

.top_mv_container .text_box .title {
    font-size: 34px;
    letter-spacing: 0.06em;
    line-height: 1.9;
    text-shadow: 0 3px 6px rgba(0,0,0,0.3);
}

.top_mv_container .btn_box {
    margin-top: 40px;
}

.top_mv_container .btn_box ul {
    display: grid;
    grid-template-columns: repeat(2, 260px);
    column-gap: 18px;
}

.top_mv_container .btn_box ul li a {
    display: block;
    text-align: center;
    color: #fff;
    font-size: 17px;
    font-weight: bold;
    letter-spacing: 0.04em;
    padding: 20px 0;
    position: relative;
    z-index: 0;
    transition-duration: .3s;
    border-radius: 6px;
}

.top_mv_container .btn_box ul li a::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 18px;
    translate: 0 -50%;
    width: 8px;
    height: 8px;
    border-top: 1px solid currentColor;
    border-right: 1px solid currentColor;
    rotate: 45deg;
}

.top_mv_container .btn_box ul li a:hover {
    opacity: .9;
}

.top_mv_text_box {
    color: #fff;
    text-align: center;
}

.top_mv_text_box p.sub_ttl {
    font-size: 26px;
    font-weight: bold;
    letter-spacing: 0.2em;
}

.top_mv_text_box p.ttl {
    font-size: 70px;
    font-weight: bold;
    letter-spacing: 0.2em;
    line-height: 1;
    margin-top: 2px;
}

.top_mv_text_box h1 {
    font-size: 30px;
    font-weight: bold;
    letter-spacing: 0.2em;
    margin-top: 4px;
}

section.top_mv .img_box {
    text-align: center;
    margin-top: 32px;
}

section.top_mv::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 92, 169, 0.3);
    z-index: 1;
}

section.top_news {
    position: relative;
    z-index: 100;
    margin-top: -30px;
}

.top_news_cont {
    align-items: center;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    background-image: url(/penguin/resources/image/bestrent/home/icon_arrow_blue.svg);
    background-position: right 50px center;
    background-repeat: no-repeat;
    background-size: 30px;
    background-color: #fff;
}

.top_news_cont .ttl_box {
    width: 12%;
    background-color: #015BAC;
    text-align: center;
    padding: 14px 0;
}

.top_news_cont .ttl_box p.text {
    color: #fff;
    font-size: 22px;
    font-weight: bold;
}

.top_news_cont .text_box {
    width: 88%;
    padding: 0 120px 0 50px;
    color: #000;
}

.top_news_cont .text_box p.time {
    font-size: 12px;
    width: 8%;
    letter-spacing: 0.03em;
}

.top_news_cont .text_box p.ttl {
    font-size: 12px;
    width: 89%;
    letter-spacing: 0.03em;
}

section.top_merit {
    margin-top: 100px;
    position: relative;
    z-index: 0;
    padding: 13.5vw 0 0;
}

.top_merit_ttl_box {
    text-align: center;
}

.top_merit_ttl_box p.en {
    color: rgba(0, 0, 0, 0.4);
    font-size: 110px;
}

.top_merit_ttl_box h2 {
    font-size: 26px;
    font-weight: bold;
    letter-spacing: 0.1em;
    font-family: 'noto sans jp black', sans-serif;
    margin-top: -30px;
}

.top_merit_ttl_box p.text {
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 0.12em;
    margin-top: 12px;
    line-height: 1.5;
}

.top_merit_list {
    margin-top: 40px;
    /* margin-bottom: 40px; */
}

.top_merit_list ul li {
    /* width: 350px; */
    position: relative;
}

.top_merit_list ul li span.en {
    color: #015BAC;
    font-size: 40px;
    position: absolute;
    z-index: 100;
    right: 18px;
    top: -14px;
    transform: rotate(-6deg);
}

.top_merit_list ul li .img {
    border-radius: 10px;
    overflow: hidden;
}

.top_merit_list ul li .text_box {
    text-align: center;
    margin-top: 14px;
    padding: 0 22px;
}

.top_merit_list ul li .text_box h3 {
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 0.06em;
}

.top_merit_list ul li .text_box p.text {
    font-size: 16px;
    letter-spacing: 0.04em;
    line-height: 1.7;
    margin-top: 8px;
}

.top_merit_list ul li::before {
    /* content: ''; */
    /* position: absolute; */
    /* top: 0; */
    /* right: -23px; */
    /* height: 100%; */
    /* width: 2px; */
    /* border-right: 1px dashed #000; */
}

.top_merit_list ul li:last-child::before {
    display: none;
}

a.common_top_link {
    display: block;
    width: 300px;
    margin: auto;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.08em;
    color: #000;
    border-radius: 6px;
    border: 2px solid #DBDBDB;
    padding: 16px 0;
    position: relative;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

a.common_top_link::before {
    transform: rotate(45deg);
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 20px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #707070;
    border-right: 2px solid #707070;
    margin: auto;
}

a.common_top_link:hover {
    box-shadow: 0 6px 2px rgba(0, 0, 0, 0.16);
    transform: translate(0px, -4px);
}

section.top_search {
    margin-top: 120px;
}

.top_search_cont_box {
    /* width: 420px; */
    background-color: #fff;
    padding: 36px 30px;
    border-radius: 10px;
}

.top_search_cont_box .ttl_box {
    text-align: center;
}

.top_search_cont_box .ttl_box p.en {
    font-size: 36px;
    font-weight: bold;
    letter-spacing: 0.04em;
    font-family: 'helvetica bold', sans-serif;
}

.top_search_cont_box .ttl_box h2 {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.06em;
}

.top_search_btn_box {
    margin-top: 28px;
}

.top_search_btn_box ul li {
    width: 48%;
}

.top_search_btn_box ul li a {
    background-color: #fff;
    display: block;
    text-align: center;
    background-position: top 40px center;
    background-repeat: no-repeat;
    background-size: 60px;
    padding: 116px 0 26px;
    border-radius: 4px;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    position: relative;
    color: #015BAC;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.top_search_btn_box ul li a::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    width: 80px;
    height: 6px;
    background-color: #015BAC;
    margin: auto;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.top_search_btn_box ul li a:hover::before {
    background-color: #fff;
}

.top_search_btn_box ul li a p.en {
    font-size: 21px;
    font-weight: bold;
}

.top_search_btn_box ul li a h3 {
    font-size: 15px;
    font-weight: bold;
    letter-spacing: 0.1em;
}

.top_search_btn_box ul li a:hover {
    background-color: #015BAC;
    color: #fff;
}

.top_search_btn_box ul li a.area {
    background-image: url(/penguin/resources/image/bestrent/home/icon_area_blue.svg);
}

.top_search_btn_box ul li a.train {
    background-image: url(/penguin/resources/image/bestrent/home/icon_train_blue.svg);
}

.top_search_btn_box ul li a.area:hover {
    background-image: url(/penguin/resources/image/bestrent/home/icon_area_white.svg);
}

.top_search_btn_box ul li a.train:hover {
    background-image: url(/penguin/resources/image/bestrent/home/icon_train_white.svg);
}

.top_search_free_word_box {
    margin-top: 28px;
}

.top_search_free_word_box p.ttl {
    font-size: 17px;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.1em;
}

.free_word_box {
    margin-top: 6px;
}

.free_word_box form {
    position: relative;
}

.free_word_box form .input input {
    width: 100%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1) inset, 0 1px 2px rgba(0, 0, 0, 0.1);
    border: none;
    border-radius: 100px;
    line-height: 50px;
    padding: 0 24px;
}

.free_word_box form .input input::placeholder {
    font-size: 12px;
    color: #C9C9C9;
    font-weight: bold;
    letter-spacing: 0.06em;
}

.free_word_box form .submit {
    position: absolute;
    top: 0;
    right: 0;
    background-color: transparent;
    width: 16px;
    height: 16px;
    /* background-color: #eee; */
    background-image: url(/penguin/resources/image/bestrent/home/icon_search_blue.svg);
    background-repeat: no-repeat;
    background-position: center;
    margin: auto;
    background-size: contain;
    bottom: 0;
    right: 27px;
}

.free_word_box form .submit .input_submit {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    background-color: transparent;
    padding: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
    text-indent: -999px;
}

.top_search_kodawari_box {
    width: 700px;
}

.top_search_kodawari_box ul li {
    width: 165px;
}

.top_search_kodawari_box ul li a {
    display: block;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    border-radius: 4px;
}

.top_search_kodawari_box ul li .img {}

.top_search_kodawari_box ul li .text_box {
    text-align: center;
    padding: 9px 0;
    background-color: #fff;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.top_search_kodawari_box ul li .text_box p.text {
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 0.04em;
    color: #000;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.top_search_kodawari_box ul li:hover .text_box {
    background-color: #015BAC;
}

.top_search_kodawari_box ul li:hover .text_box p.text {
    color: #fff;
}

.top_search_kodawari_box ul li.banner {
    width: 344px;
    border-radius: 4px;
    overflow: hidden;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
    cursor: pointer;
}

.top_search_kodawari_box ul li:nth-child(n + 5) {
    margin-top: 15px;
}

.top_search_cont {
    align-items: flex-end;
}

.top_search_kodawari_box ul li.banner:hover {
    opacity: 0.8;
}

.common_top_h2_box {
    text-align: center;
}

.common_top_h2_box p.en {
    font-family: 'helvetica bold', sans-serif;
    font-size: 36px;
    letter-spacing: 0.02em;
    line-height: 1;
}

.common_top_h2_box h2 {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.04em;
    margin-top: 13px;
}

section.top_new_arrival {
    margin-top: 80px;
}

.top_new_arrival_list {
    margin-top: 28px;
}

.top_new_arrival_list ul li {
    width: 270px;
    margin-left: 20px;
}

.top_new_arrival_list ul li:nth-child(4n + 1) {
    margin-left: 0;
}

.top_new_arrival_list ul li .img {
    border-radius: 6px;
    overflow: hidden;
    height: 300px;
}

.top_new_arrival_list ul li .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.top_new_arrival_list ul li .text_box {
    margin-top: 10px;
}

.top_new_arrival_list ul li .text_box p.name {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.06em;
    margin-bottom: 5px;
}

.top_new_arrival_list ul li a {
    color: #000;
}

.top_new_arrival_list ul li .text_box p.text {
    font-size: 12px;
    letter-spacing: 0.08em;
}

.top_new_arrival_list ul li .text_box p.text+p.text {
    margin-top: 3px;
}

.top_new_arrival_list ul li .text_box p.text span.color {
    color: #C10000;
    font-weight: bold;
}

.top_new_arrival_list ul li:nth-child(n + 5) {
    margin-top: 20px;
}

section.top_post {
    margin-top: 100px;
    margin-bottom: 100px;
}

.top_post_list {
    margin-top: 28px;
    margin-bottom: 40px;
}

.top_post_list ul li {
    width: 270px;
    margin-left: 20px;
}

.top_post_list ul li:nth-child(4n + 1) {
    margin-left: 0;
}

a {}

.top_post_list ul li .img {
    overflow: hidden;
    border-radius: 6px;
    height: 170px;
}

.top_post_list ul li .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.top_post_list ul li .text_box {
    margin-top: 12px;
}

.top_post_list ul li .text_box p.time {
    font-size: 12px;
    color: #8A8A8A;
    font-family: 'helvetica regular', sans-serif;
}

.top_post_list ul li .text_box p.ttl {
    color: #000;
    font-weight: bold;
    font-size: 16px;
    letter-spacing: 0.04em;
    border-bottom: 1px dashed #000;
    padding: 0 0 5px;
    margin-top: 2px;
}

.top_post_list ul li .text_box p.text {
    font-size: 14px;
    color: #8C8C8C;
    letter-spacing: 0.04em;
    margin-top: 6px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden;
}

.ft_contact {
    background-color: #000;
    padding: 56px 0;
}

.ft_contact_cont {
    align-items: center;
}

.ft_contact_cont .info_box {
    align-items: flex-end;
    border-right: 1px solid #7B7B7B;
    width: 54%;
}

.ft_contact_cont .info_box .ttl_box {
    color: #fff;
}

.ft_contact_cont .info_box .ttl_box p.en {
    font-size: 100px;
}

.ft_contact_cont .info_box .ttl_box h2 {
    font-size: 16px;
    letter-spacing: 0.1em;
    text-align: right;
    margin-top: -30px;
}

.ft_contact_cont .info_box .tel_box {
    color: #fff;
    background-image: url(/penguin/resources/image/bestrent/home/icon_smartpohone.svg);
    background-position: left center;
    background-repeat: no-repeat;
    background-size: 30px 53px;
    padding-left: 62px;
    margin-left: 70px;
}

.ft_contact_cont .info_box .tel_box p.num {
    font-family: 'helvetica bold', sans-serif;
    font-size: 40px;
    letter-spacing: 0.04em;
}

.ft_contact_cont .info_box .tel_box p.time {
    font-size: 12px;
    letter-spacing: 0.06em;
    margin-top: -6px;
}

.ft_contact_cont .link_box {
    width: 470px;
}

.ft_contact_cont .link_box ul li {
    width: 230px;
}

.ft_contact_cont .link_box ul li a {
    display: block;
    background-color: #fff;
    color: #000;
    border-radius: 5px;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.04em;
    padding: 12.2px 0;
    position: relative;
    text-indent: 0;
}

.ft_contact_cont .link_box ul li a::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 20px;
    width: 4px;
    height: 4px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
    margin: auto;
    transform: rotate(45deg);
}

.ft_contact_cont .link_box ul li:nth-child(n + 3) {
    margin-top: 10px;
}

.ft_message {
    margin-top: 60px;
}

.ft_message p.main_text {
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 0.04em;
    line-height: 1.5;
}

.ft_message p.text {
    font-size: 14px;
    letter-spacing: 0.04em;
    line-height: 1.7;
    margin-top: 16px;
}

.ft_cont_inner {
    border-top: 1px solid #DBDBDB;
    margin-top: 40px;
    padding: 42px 0 0;
}

.ft_cont_info_box {
    width: 290px;
}

.ft_cont_info_box .logo_box {
    align-items: center;
}

.ft_cont_info_box .logo_box p.name {
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.04em;
    margin-left: 30px;
}

.ft_cont_info_box .info_list {
    margin-top: 16px;
}

.ft_cont_info_box .info_list ul li {
    font-size: 12px;
    font-family: 'helvetica regular', sans-serif;
    letter-spacing: 0.04em;
}

.ft_cont_info_box .info_list ul li+li {
    margin-top: 3px;
}

.ft_cont_info_box .banner_box {
    margin-top: 30px;
}

.ft_cont_info_box .banner_box .img+.img {
    margin-top: 10px;
}

.ft_cont_contents {
    width: 785px;
}

.ft_cont_contents .ttl_box {
    border-bottom: 1px dashed #000;
    padding: 0 0 14px;
}

.ft_cont_contents .ttl_box p.en {
    font-size: 30px;
    font-family: 'helvetica bold', sans-serif;
    letter-spacing: 0.02em;
    line-height: 1;
}

.ft_cont_contents .ttl_box h2 {
    font-size: 14px;
    font-weight: bold;
    margin-top: 4px;
    letter-spacing: 0.02em;
}

.ft_menu_list {}

.ft_menu_list p.ttl {
    font-size: 14px;
}

.ft_menu_list ul li a {
    color: #000;
    font-size: 14px;
    letter-spacing: 0.04em;
    display: inline-block;
    margin: 8px 12px 0 0;
    border-right: 1px solid #000;
    padding-right: 12px;
    line-height: 1;
}

.ft_menu_list+.ft_menu_list {
    margin-top: 24px;
}

.ft_menu_box {
    width: 670px;
    margin-top: 16px;
}

.ft_copyright_box {
    align-items: center;
    margin-top: 44px;
}

.ft_copyright_box .link_box {}

.ft_copyright_box .link_box li a {
    color: #000;
    font-size: 12px;
    color: #8C8C8C;
    letter-spacing: 0.04em;
    line-height: 1;
    padding-right: 10px;
    display: inline-block;
    border-right: 1px solid #8c8c8c;
    margin-right: 10px;
    position: static;
    text-indent: 0;
    width: auto;
    height: auto;
}

.ft_copyright_box .link_box li {}

.ft_copyright_box .link_box li:last-child a {
    border-right: none;
}

.ft_copyright_box .copyright {
    font-size: 12px;
    font-family: 'helvetica regular', sans-serif;
    letter-spacing: 0.04em;
}

.ft_cont {
    padding: 0 0 50px;
}

.top_banner_slider li.slick-slide {
    width: 700px !important;
    margin: 0 14px;
}

.top_banner_slider button.slick-btn {
    position: absolute;
    bottom: -7px;
    right: 0px;
    left: 0px;
    margin: auto;
    width: 30px;
    height: 30px;
    background-color: transparent;
    border: none;
    cursor: pointer;
}

.top_banner_slider button.slick-btn::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    width: 8px;
    height: 8px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
}

.top_banner_slider button.slick-btn.slick-prev {
    left: -200px;
}

.top_banner_slider button.slick-btn.slick-prev::before {
    transform: rotate(-135deg);
}

.top_banner_slider button.slick-btn.slick-next {
    right: -200px;
}

.top_banner_slider button.slick-btn.slick-next::before {
    transform: rotate(45deg);
}

.top_banner_slider .slick-dots {
    display: flex !important;
    justify-content: center;
    margin-top: 30px;
}

.top_banner_slider .slick-dots li button {
    text-indent: -9999px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    background-color: transparent;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
}

.top_banner_slider .slick-dots li {
    width: 14px;
    height: 14px;
    background-color: #E0E0E0;
    border-radius: 50%;
    margin: 0 12px;
}

.top_banner_slider .slick-dots li.slick-active {
    background-color: #015BAC;
}

.modal_high_grade_series {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    z-index: 999999;
    display: none;
}

.modal_high_grade_series_cont {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.modal_high_grade_series .inner {
    background-color: #fff;
    width: 1000px;
    padding: 60px 60px;
    border-radius: 10px;
    position: relative;
}

.modal_high_grade_series .inner .ttl_box p.ttl {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.06em;
    margin-top: 6px;
}

.modal_high_grade_series .inner .ttl_box p.en {
    font-family: 'helvetica bold', sans-serif;
    font-size: 28px;
    letter-spacing: 0.04em;
    line-height: 1;
}

.modal_high_grade_series .inner .ttl_box {
    text-align: center;
}

.modal_high_grade_series_list {
    width: 750px;
    margin: 24px auto 0;
}

.modal_high_grade_series_list ul li {
    width: 32%;
}

.modal_high_grade_series_list ul li a {
    display: block;
    text-align: center;
    color: #000;
    border: 2px solid #DBDBDB;
    border-radius: 4px;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.04em;
    position: relative;
    padding: 8px 0;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.modal_high_grade_series_list ul li a::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 10px;
    margin: auto;
    width: 4px;
    height: 4px;
    border-top: 2px solid #dbdbdb;
    border-right: 2px solid #dbdbdb;
    transform: rotate(45deg);
}

.modal_high_grade_series_list ul li:nth-child(n + 4) {
    margin-top: 16px;
}

.modal_high_grade_series_list ul li a:hover {
    box-shadow: 0 2px 6px #dbdbdb;
    transform: translate(0px, -1px);
}

.modal_high_grade_series .inner span.close_btn {
    position: absolute;
    top: -12px;
    right: -12px;
    width: 30px;
    height: 30px;
    background-color: #fff;
    border: 2px solid #dbdbdb;
    border-radius: 50%;
    cursor: pointer;
}

.modal_high_grade_series .inner span.close_btn::before, .modal_high_grade_series .inner span.close_btn::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 2px;
    height: 12px;
    background-color: #000;
    margin: auto;
}

.modal_high_grade_series .inner span.close_btn::before {
    transform: rotate(45deg);
}

.modal_high_grade_series .inner span.close_btn::after {
    transform: rotate(-45deg);
}

section.top_banner_box {
    margin-top: 120px;
}

/* .top_service_slider li.slick-slide .inner {
    width: 230px;
    box-shadow: 0 3px 6px rgba(0,0,0,0.1);
    border-radius: 10px;
    overflow: hidden;
    margin-right: 20px;
    transition: 0.3s;
}

.top_service_slider li.slick-slide .inner .img {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 500px;
}

.top_service_slider li.slick-slide + li.slick-slide.slick-active .inner {
    width: 380px;
}

.top_service_slider li.slick-slide .inner .text_box {
    text-align: center;
    padding: 15px 0;
}

.top_service_slider li.slick-slide .inner .text_box p.text {
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.04em;
}

.top_service_slider .slick-list {
    padding: 0 0 10px;
} */

.top_service_slider li.swiper-slide {
    width: 380px;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    border-radius: 10px;
    overflow: hidden;
}

.top_service_slider li:not(.swiper-slide-active) {
    transform: scale(0.6);
    transform-origin: top;
}

.top_service_slider li.swiper-slide-active+li.swiper-slide,
.top_service_slider li.swiper-slide-active+li.swiper-slide+li.swiper-slide,
.top_service_slider li.swiper-slide-active+li.swiper-slide+li.swiper-slide+li.swiper-slide {
    margin-right: -130px !important;
}

.top_service_slider li.swiper-slide.swiper-slide-active {
    margin-right: -50px !important;
    box-shadow: none;
}

.top_service_slider li.swiper-slide .inner .img {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 500px;
}

.top_service_slider_box {
    overflow: hidden;
}

.top_service_slider li.swiper-slide .inner {}

.top_service_slider li.swiper-slide .inner .text_box {
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    letter-spacing: 0.06em;
    padding: 24px 0;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.top_service_slider li.swiper-slide.swiper-slide-active .inner .text_box {
    height: 0;
    padding: 0;
}

.top_service_text_box {
    padding-left: 420px;
    margin-top: -214px;
    position: relative;
    z-index: 1000;
}

.top_service_text_box .count_box {
    font-size: 14px;
    font-weight: bold;
    font-family: 'helvetica bold', sans-serif;
    font-style: italic;
    letter-spacing: 0.06em;
    margin-left: -4px;
}

.top_service_text_box .count_box span {
    margin: 0 4px;
}

.top_service_text_box .text_box {
    margin-top: 2px;
}

.top_service_text_box .text_box p.ttl {
    font-weight: bold;
    font-size: 20px;
    color: #015BAC;
    letter-spacing: 0.08em;
}

.top_service_text_box .text_box p.text {
    font-size: 14px;
    letter-spacing: 0.06em;
    line-height: 1.6;
    margin-top: 6px;
}

.top_service_text_box .text_box .swiper-pagination {
    position: static;
}

.top_service_text_box .swiper-pagination {
    position: static;
    text-align: left;
    width: auto !important;
    margin: 0 10px;
}

.top_service_text_box span.swiper-pagination-bullet {
    width: 9px;
    height: 9px;
    background-color: #E0E0E0;
    opacity: 1;
    margin-right: 12px !important;
}

.top_service_text_box span.swiper-pagination-bullet-active {
    background-color: #015BAC;
}

.top_service_slider_control_box .slide_button {
    width: 30px;
    height: 30px;
    position: relative;
    cursor: pointer;
}

.top_service_slider_control_box {
    display: flex;
    align-items: center;
    margin-top: 10px;
}

.top_service_slider_control_box .slide_button::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    width: 6px;
    height: 6px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
    margin: auto;
}

.top_service_slider_control_box .button-prev::before {
    transform: rotate(-135deg);
}

.top_service_slider_control_box .button-next::before {
    transform: rotate(45deg);
}

section.top_parallax .img .parallax_img {
    height: 280px;
    width: 100%;
    background-color: transparent;
}

section.top_parallax {
    margin-top: 100px;
}

section.top_service {
    margin-top: 150px;
    margin-bottom: 100px;
}

.fixed_contact_box {
    position: fixed;
    top: 250px;
    right: -140px;
    z-index: 10000;
    background-color: #fff;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid #eee;
}

.fixed_contact_cont {
    padding: 24px 0;
}

.fixed_contact_cont .ttl_box {
    width: 80px;
}

.fixed_contact_cont .ttl_box .icon {
    width: 40px;
    height: 40px;
    background-image: url(/penguin/resources/image/bestrent/home/icon_contact.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    margin: auto;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.fixed_contact_cont .ttl_box h2 {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 14px;
    color: #015BAC;
    margin: 12px auto 0;
    letter-spacing: 0.14em;
    font-family: 'noto sans jp black', sans-serif;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.fixed_contact_cont .info_box {
    text-align: center;
    width: 140px;
    margin-top: 12px;
    padding: 0 18px 0 0;
}

.fixed_contact_cont .info_box .logo {
    width: 65px;
    height: 43px;
    background-image: url(/penguin/resources/image/bestrent/home/logo.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    margin: auto;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.fixed_contact_cont .info_box p.tel {
    font-size: 18px;
    color: #015BAC;
    font-family: 'helvetica bold', sans-serif;
    letter-spacing: 0.04em;
    margin-top: 10px;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.fixed_contact_cont .info_box p.time {
    font-size: 10px;
    color: #8A8A8A;
    letter-spacing: 0.04em;
    margin-top: 3px;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.fixed_contact_cont .info_box .btn_list {
    margin-top: 6px;
}

.fixed_contact_cont .info_box .btn_list ul li {
    width: 24px;
    height: 24px;
}

.fixed_contact_cont .info_box .btn_list ul li a {
    display: block;
    width: 100%;
    height: 100%;
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.fixed_contact_box .fixed_contact_cont .info_box .btn_list ul li a.line {
    background-image: url(/penguin/resources/image/bestrent/home/icon_line.svg);
}

.fixed_contact_box .fixed_contact_cont .info_box .btn_list ul li a.mail {
    background-image: url(/penguin/resources/image/bestrent/home/icon_mail_blue.svg);
}

.fixed_contact_box .fixed_contact_cont .info_box .btn_list ul li a.request {
    background-image: url(/penguin/resources/image/bestrent/home/icon_request_blue.svg);
}

.fixed_contact_box .fixed_contact_cont .info_box .btn_list ul li a.reservation {
    background-image: url(/penguin/resources/image/bestrent/home/icon_reservation_blue.svg);
}

.fixed_contact_box.open .fixed_contact_cont .info_box .btn_list ul li a.mail {
    background-image: url(/penguin/resources/image/bestrent/home/icon_mail.svg);
}

.fixed_contact_box.open .fixed_contact_cont .info_box .btn_list ul li a.request {
    background-image: url(/penguin/resources/image/bestrent/home/icon_request.svg);
}

.fixed_contact_box.open .fixed_contact_cont .info_box .btn_list ul li a.reservation {
    background-image: url(/penguin/resources/image/bestrent/home/icon_reservation.svg);
}

.fixed_contact_box .arrow_box {
    background-color: #015BAC;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 0;
    width: 80px;
    transition: 0.3s cubic-bezier(0.65, 0, 0.35, 1);
}

.fixed_contact_box .arrow_box .img img {
    display: block;
}

.fixed_contact_box:hover {
    right: 0;
}

.fixed_contact_box:hover .arrow_box {
    width: 100%;
}

.fixed_contact_box.open {
    background-color: #005bab;
}

.fixed_contact_box.open .arrow_box {
    background-color: #EDE405;
}

.fixed_contact_box.open .fixed_contact_cont .ttl_box h2 {
    color: #fff;
}

.fixed_contact_box.open .fixed_contact_cont .ttl_box .icon {
    background-image: url(/penguin/resources/image/bestrent/home/icon_contact_white.svg);
}

.fixed_contact_box.open .fixed_contact_cont .info_box .logo {
    background-image: url(/penguin/resources/image/bestrent/home/logo_white.svg);
}

.fixed_contact_box.open .fixed_contact_cont .info_box p.tel {
    color: #fff;
}

.fixed_contact_box.open .fixed_contact_cont .info_box p.time {
    color: #fff;
}

.sp_hg_menu_box {}

.sp_hg_menu_box .ttl_box {
    text-align: center;
}

.sp_hg_menu_box .ttl_box p.en {
    font-family: 'helvetica bold', sans-serif;
    font-size: 22px;
    letter-spacing: 0.04em;
}

.sp_hg_menu_box .ttl_box h2 {
    font-size: 16px;
    margin-top: -2px;
}

.sp_hg_menu_box_list {
    margin-top: 20px;
}

.sp_hg_menu_box_list ul li {
    width: 46%;
}

.sp_hg_menu_box_list ul {
    justify-content: space-between;
}

.sp_hg_menu_box_list ul li a {
    font-size: 14px;
    font-weight: bold;
    color: #000;
    display: block;
    border-bottom: 1px solid #eee;
    padding: 18px 16px 18px 0;
    position: relative;
}

.sp_hg_menu_box_list ul li a::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 4px;
    width: 4px;
    height: 4px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
    margin: auto;
    transform: rotate(45deg);
}


.sp_hg_cont .wrap {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: scroll;
}

.sp_hg_cont {
    display: none;
}

section.top_review {
    background: #f1f1f1;
    padding: 80px 0 50px;
    position: relative;
}

section.top_review .title_area {
    position: absolute;
    left: calc((100% - 1140px) / 2);
    padding-top: 40px;
}

section.top_review .title_area .common_top_h2_box {
    margin-bottom: 30px;
    text-align: left;
}

section.top_review .title_area .text {
    font-size: 16px;
    color: #333;
    line-height: 2;
    margin-bottom: 30px;
}

section.top_review .btn {
    background: #015BAC;
    color: #fff;
    text-align: center;
    display: block;
    width: 250px;
    line-height: 50px;
    font-size: 16px;
    letter-spacing: .08em;
    border-radius: 6px;
    font-weight: 600;
}

section.top_review .title_area .common_top_h2_box p.en {
    margin-bottom: .3em;
}

section.top_review .slider_area {
    margin-left: calc((100% - 1140px) / 2 + 400px);
}

section.top_review .bx-viewport {
    background: none;
}

section.top_review .slider_area li .image {
    width: 100%;
    height: 250px;
    border-radius: 10px;
    overflow: hidden;
}

section.top_review .slider_area li .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

section.top_review .slider_area li .data {
    color: #333;
    margin: 10px 0;
}

section.top_review .slider_area li .title {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.top_text_review_block {
    background-color: #f1f1f1;
    padding-bottom: 80px;
}

.top_text_review_block .cont .list {
    margin-bottom: 60px;
}

.top_text_review_block .cont .list ul {
    width: 100%;
    height: 230px;
    padding: 30px 50px;
    background-color: #fff;
    border-radius: 6px;
    overflow-y: scroll;
}

.top_text_review_block .cont .list ul li + li a {
    padding-top: 15px;
}

.top_text_review_block .cont .list ul li a {
    flex-wrap: nowrap;
    align-items: center;
    padding-bottom: 15px;
    border-bottom: 1px solid #ccc;
}

.top_text_review_block .cont .list ul li a .date {
    flex-shrink: 0;
    font-size: 12px;
    letter-spacing: 0.05em;
    margin-right: 30px;
    color: #535353;
}

.top_text_review_block .cont .list ul li a .ttl {
    width: 100%;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.08em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-text-overflow: ellipsis;
    -o-text-overflow: ellipsis;
    transition: .3s;
}

.top_text_review_block .cont .list ul li a:hover .ttl {
    color: #015BAC;
}

.top_text_review_block .cont .list ul li a .arrow {
    flex-shrink: 0;
    width: 30px;
    line-height: 1;
    margin-left: 30px;
}

.top_text_review_block .cont .list ul li a .arrow img {
    width: 100%;
}

.top_text_review_block .cont .btn {
    display: block;
    width: 300px;
    line-height: 60px;
    background-color: #005CA9;
    border: 1px solid #005CA9;
    color: #fff;
    margin: 0 auto;
    letter-spacing: 0.08em;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
    transition: .3s;
    border-radius: 6px;
}

.top_text_review_block .cont .btn:hover {
    background-color: #fff;
    color: #005CA9;
}

section.top_member {
    background: #f1f1f1;
    padding: 50px 0;
    margin-top: 100px;
}

section.top_member .slider_wrap .bx-wrapper {
    -moz-box-shadow: none;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: none;
    background: transparent;
    margin: 0 auto;
}

section.top_member .slider_wrap .bx-wrapper .bx-controls-auto {
    display: none;
}

section.top_member .title_area .common_top_h2_box {
    margin-bottom: 20px;
}

section.top_member .title_area .common_top_h2_box p.en {
    margin-bottom: .2em;
}

section.top_member .title_area .text {
    font-size: 13px;
    color: #333;
    line-height: 2;
    margin-bottom: 30px;
    text-align: center;
}

section.top_member .bx-viewport {
    background: none;
}

section.top_member li .text_area {
    text-align: center;
    font-weight: 600;
}

section.top_member li .image {
    height: 350px;
    margin-bottom: 20px;
    background-size: cover !important;
    background-position: center !important;
}

section.top_member li .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

section.top_member li .jp {
    font-size: 20px;
    color: #333;
    margin-bottom: .5em;
}

section.top_member li .en {
    font-size: 14px;
    color: #B3B3B3;
}

section.top_member .btn {
    background: #015BAC;
    color: #fff;
    text-align: center;
    display: block;
    width: 280px;
    line-height: 50px;
    font-size: 14px;
    border-radius: 10px;
    font-weight: 600;
    margin: 40px auto 0 auto;
}

.mainContaints.thanks_area {
    text-align: center;
}

.mainContaints.thanks_area h2 {
    margin-bottom: 1em;
}

.mainContaints.thanks_area .font-M {
    margin-bottom: 30px;
}

.top_banner {
    margin-top: 50px;
}

.area_search_container {
    display: grid;
    grid-template-columns: 1fr 708px;
    column-gap: 24px;
    align-items: center;
    margin-bottom: 30px;
}

.area_search_map_route_box {
    position: relative;
    z-index: 0;
    border: 3px solid #eee;
    border-radius: 10px;
    overflow: hidden;
    width: 708px;
    flex-shrink: 0;
}

.area_search_map_route_box .station_list {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 100;
}

.area_search_map_route_box .map_box {
    position: relative;
    z-index: 0;
}

.area_search_map_route_box .station_list li {
    position: absolute;
}

.area_search_map_route_box .station_list li a {
    display: block;
    border: 4px solid #cdcdcd;
    border-radius: 5px;
    background-color: #fff;
    font-size: 17px;
    font-weight: 600;
    letter-spacing: 0.04em;
    padding: 1px 9px;
    transition-duration: 0.2s;
    position: relative;
    z-index: 0;
}

.area_search_map_route_box .station_list li.juso {
    top: 102px;
    left: 90px;
}

.area_search_map_route_box .station_list li a:hover {
    background-color: #005bab;
    color: #fff;
}

.area_search_map_route_box .station_list li.nakatsu1 {
    top: 151px;
    left: 69px;
}

.area_search_map_route_box .station_list li.tsukamoto {
    top: 179px;
    left: 12px;
}

.area_search_map_route_box .station_list li.fukushima {
    top: 242px;
    left: 28px;
}

.area_search_map_route_box .station_list li.shin_fukushima {
    top: 286px;
    left: 28px;
}

.area_search_map_route_box .station_list li.osaka_umeda {
    top: 174px;
    left: 159px;
}

.area_search_map_route_box .station_list li.osaka_umeda a {
    padding: 18px 26px;
}

.area_search_map_route_box .station_list li.kita_shinchi {
    top: 327px;
    left: 163px;
}

.area_search_map_route_box .station_list li.higobashi {
    top: 374px;
    left: 115px;
}

.area_search_map_route_box .station_list li.yodoyabashi {
    top: 374px;
    left: 212px;
}

.area_search_map_route_box .station_list li.higasi_mikuni {
    top: 21px;
    left: 275px;
}

.area_search_map_route_box .station_list li.shin_osaka {
    left: 275px;
    top: 64px;
}

.area_search_map_route_box .station_list li.nishi_nakajima_minamikata {
    top: 108px;
    left: 259px;
}

.area_search_map_route_box .station_list li.minamikata {
    top: 143px;
    left: 323px;
}

.area_search_map_route_box .station_list li.nakatsu {
    top: 179px;
    left: 261px;
}

.area_search_map_route_box .station_list li a::before {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 0;
    height: 0;
    border-bottom: 7px solid currentColor;
    border-left: 7px solid transparent;
}

.area_search_map_route_box .station_list li.nakazakicho {
    top: 174px;
    left: 367px;
}

.area_search_map_route_box .station_list li.shimo_shinjo {
    top: 21px;
    left: 429px;
}

.area_search_map_route_box .station_list li.awaji {
    top: 68px;
    left: 440px;
}

.area_search_map_route_box .station_list li.kunijima {
    top: 127px;
    left: 439px;
}

.area_search_map_route_box .station_list li.tenjinbashisuji_6chome {
    top: 172px;
    left: 451px;
}

.area_search_map_route_box .station_list li.ougimachi {
    top: 249px;
    left: 440px;
}

.area_search_map_route_box .station_list li.minami_morimachi {
    top: 289px;
    left: 430px;
}

.area_search_map_route_box .station_list li.osaka_tenmangu {
    top: 327px;
    left: 480px;
}

.area_search_map_route_box .station_list li.kitahama {
    top: 375px;
    left: 439px;
}

.area_search_map_route_box .station_list li.tenma {
    top: 224px;
    left: 590px;
}

.area_search_map_route_box .station_list li.tenjinbashi {
    top: 374px;
    left: 600px;
}

.area_search_link_box {
    display: flex;
    flex-direction: column;
}

.common_sub_title {
    background-color: #005bac;
    color: #fff;
    text-align: center;
    font-size: 20px;
    letter-spacing: 0.04em;
    padding: 10px 0;
}

.area_search_link_box .item {
    border-radius: 10px;
    overflow: hidden;
}

.area_search_link_box .item .list > ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 10px;
    row-gap: 10px;
}

.area_search_link_box .item .list {
    background-color: #F5F5F5;
    padding: 28px 26px;
}

.area_search_link_box .item .list > ul a {
    display: block;
    text-align: center;
    font-weight: bold;
    letter-spacing: 0.04em;
    font-size: 16px;
    border: 2px solid #C9C9C9;
    border-radius: 6px;
    background-color: #fff;
    padding: 20px 0px;
    position: relative;
    z-index: 0;
    transition-duration: .2s;
}

.area_search_link_box .item .list > ul a.has_icon {
    display: grid;
    grid-template-columns: 26px 1fr;
    column-gap: 7px;
    align-items: center;
    text-align: left;
    padding: 9px 7px;
    height: 100%;
    /* justify-items: center; */
}

.area_search_link_box .item .list > ul a.has_icon .icon {
    width: 100%;
}

.area_search_link_box .item .list > ul a::before {
    content: '';
    position: absolute;
    bottom: 4px;
    right: 4px;
    width: 0;
    height: 0;
    border-bottom: 8px solid currentColor;
    border-left: 8px solid transparent;
}

.area_search_link_box .item + .item {
    margin-top: auto;
}

.top_area_search {
    margin-top: 80px;
}

.area_search_link_box .item .list > ul a:hover {
    background-color: #005bac;
    color: #fff;
}

.area_search_link_box .item .list > ul a.has_icon .icon svg {
    display: block;
    aspect-ratio: 1/ 1;
}

.area_search_link_box .item .list > ul a.has_icon:hover svg {
    fill: currentColor;
}

.area_search_map_route_box::before {
    /* content: ''; */
    width: 100%;
    height: 100%;
    border: 2px solid #eee;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 10px;
    z-index: -100;
    transform: scale(1.015);
}

.top_banner_list_container .list > ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    column-gap: 24px;
}

.top_banner_list {
    padding: 85px 0;
}

section.top_review .slider_area .bx-wrapper {
    background-color: transparent;
    box-shadow: none;
    border: none;
    margin-bottom: 0;
}

.common_top_h2_box .text {
    font-size: 16px;
    letter-spacing: 0.04em;
    color: #535353;
    margin-top: 24px;
}

.common_top_h2_box.white {
    color: #fff;
}

section.top_merit .bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
}

.top_merit_list > ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 26px;
}

.top_recruit {
    background-image: url(/penguin/resources/image/bestrent/home/top_recruit_bg.jpg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    padding: 66px 0;
}

.top_recruit_container {
    /* background-color: #fff; */
    /* padding: 54px 0; */
    /* text-align: center; */
    /* border-radius: 10px; */
}

.top_recruit_container .title_box {
    color: #005CA9;
}

.top_recruit_container .title_box .en {
    font-size: 42px;
    font-weight: bold;
    letter-spacing: 0.06em;
}

.top_recruit_container .title_box h2 {
    margin-top: 8px;
}

.top_recruit_container .text {
    font-size: 17px;
    line-height: 1.8;
    margin-top: 24px;
    letter-spacing: 0.03em;
}

.top_recruit_container .link {
    background-color: #005CA9;
    color: #fff;
    font-size: 19px;
    font-weight: bold;
    letter-spacing: 0.04em;
    padding: 22px 100px;
    display: inline-block;
    margin-top: 36px;
    border-radius: 6px;
}

.ft_cont_info_box .banner_box > ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 6px;
    row-gap: 6px;
}

.top_recruit_box {
    display: grid;
    grid-template-columns: 40% 1fr;
    align-items: center;
    background-color: #fff;
    padding: 40px;
    margin: auto;
    border-radius: 10px;
    column-gap: 40px;
}

.top_recruit_img_box img {
    border-radius: 10px;
}

.bottom_fixed_menu {
    position: fixed;
    z-index: 1000;
    bottom: 0;
    left: 0;
    width: 100%;
    translate: 0 100%;
    transition-duration: .4s;
}

.bottom_fixed_menu.show {
    translate: 0 0;
}

.bottom_fixed_menu_container {
    display: flex;
    align-items: center;
    column-gap: 1.9vw;
    background-color: #f1f1f1;
    justify-content: center;
    padding: 1vw 0;
    border-top: 3px solid #005bab;
}

.bottom_fixed_menu_container .btn_box > ul {
    display: flex;
    column-gap: 1vw;
}

.bottom_fixed_menu_container .btn_box > ul > li {
    width: 4vw;
    aspect-ratio: 1 / 1;
}

.bottom_fixed_menu_container .btn_box > ul > li img {
    width: 100%;
    display: block;
}

.bottom_fixed_menu_container .btn_box > ul > li a {
    height: 100%;
    display: flex;
    place-content: center;
}

.bottom_fixed_menu_container .logo_box {
    width: 5.5vw;
}

.bottom_fixed_menu_container .logo_box img {
    width: 100%;
}

.bottom_fixed_menu_container .tel_box {
    display: flex;
    align-items: center;
    column-gap: 0.8vw;
}

.bottom_fixed_menu_container .tel_box .tel {
    font-size: 3vw;
    font-weight: bold;
    font-family: 'helvetica bold', sans-serif;
    letter-spacing: 0.03em;
    line-height: 1;
}

.bottom_fixed_menu_container .tel_box .text {
    font-size: 1vw;
    letter-spacing: 0.04em;
    font-weight: 600;
}

.bottom_fixed_menu_container .tel_box .tel .char {
    font-size: 0.5em;
    margin-right: 0.4vw;
}

.top_instagram_sec {
    background-color: #f1f1f1;
    padding: 80px 0;
}

.top_instagram_sec .common_top_h2_box {
    margin-bottom: 30px;
}

.caption-overlay .long-caption {
    font-size: 14px;
}

.top_instagram_sec .cont .snapwidget-widget {
    margin: 0 auto;
    width: 100% !important;
    height: 570px !important;
}

.caption-details {
    font-size: 15px;
}

.caption-overlay .caption-details .long-caption {
    font-size: 14px !important;
}

.top_instagram_sec .cont {
    position: relative;
}

.top_instagram_sec .cont a {
    position: absolute;
    width: 100%;
    height: 100%;
    inset: 0;
}

.top_area_search .area_search_container .area_search_link_box .text_box .ttl {
    font-size: 36px;
    font-weight: 700;
    font-family: 'helvetica bold', sans-serif;
    margin-bottom: 0.3em;
    color: #015BAC;
}

.top_area_search .area_search_container .area_search_link_box .text_box .theme {
    font-weight: 700;
    font-size: 18px;
    margin-bottom: 0.9em;
    letter-spacing: .03em;
}

.top_area_search .area_search_container .area_search_link_box .text_box .text {
    font-size: 15px;
    letter-spacing: .03em;
    margin-bottom: 1.6em;
    line-height: 1.8;
    color: #626262;
}

.top_area_search .category_box .text_box {
    display: grid;
    grid-template-columns: repeat(4,1fr);
    gap: 20px;
}

.top_area_search .category_box .text_box .link {
    display: flex;
    align-items: end;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    color: #fff;
    min-block-size: 11em;
    font-size: 15px;
    padding: 1em;
    font-weight: 700;
    position: relative;
    z-index: 2;
    transition: .3s
}

.top_area_search .category_box .text_box .link.new_building {
    background-image: url(/penguin/resources/image/bestrent/home/categor_newly_built_img.jpg);
}

.top_area_search .category_box .text_box .link.pet {
    background-image: url(/penguin/resources/image/bestrent/home/categor_pet_img.jpg);
}

.top_area_search .category_box .text_box .link.high_apartment {
    background-image: url(/penguin/resources/image/bestrent/home/categor_high_apartment_img.jpg);
}

.top_area_search .category_box .text_box .link.two {
    background-image: url(/penguin/resources/image/bestrent/home/categor_living_togethe_img.jpg);
}

.top_area_search .category_box .text_box .link::after {
    content: "";
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: 0.3;
    z-index: -1;
}

.top_area_search .category_box .text_box .link:hover {
    opacity: 0.7;
}

@media (max-width: 750px) {

    .pc {
        display: none;
    }

    .sp {
        display: block;
    }

    .wrap {
        max-width: 88%;
    }

    body {
        min-width: 100%;
        /* margin-bottom: 52px; */
    }

    .fixed_contact_box {
        display: none;
    }

    section.top_mv .wrap {
        display: flex;
        flex-wrap: wrap;
        flex-direction: column-reverse;
    }

    section.top_mv {
        padding: 130px 0 100px;
    }

    section.top_mv .img_box {
        width: 135px;
        margin: auto;
    }

    .top_mv_text_box p.sub_ttl {
        font-size: 18px;
    }

    .top_mv_text_box p.ttl {
        font-size: 48px;
        margin-top: 6px;
    }

    .top_mv_text_box h1 {
        font-size: 16px;
        margin-top: 10px;
    }

    .top_mv_text_box {
        margin-top: 5px;
    }

    section.top_news {
        margin-top: -30px;
    }

    .top_news_cont .ttl_box {
        padding: 24px 0;
        width: 18%;
    }

    .top_news_cont .ttl_box p.text {
        font-size: 10px;
        letter-spacing: 0.04em;
    }

    .top_news_cont .text_box p.time {
        width: 100%;
    }

    .top_news_cont .text_box p.ttl {
        width: 100%;
        margin-top: 3px;
    }

    .top_news_cont .text_box {
        padding: 0 50px 0 20px;
        width: 82%;
    }

    .top_news_cont {
        background-size: 18px;
        background-position: right 16px center;
        border-radius: 12px;
    }

    .top_news_cont .text_box p.ttl {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 1;
        overflow: hidden;
    }

    .top_merit_ttl_box p.en {
        font-size: 60px;
    }

    .top_merit_ttl_box h2 {
        font-size: 18px;
    }

    .top_merit_ttl_box p.text {
        font-size: 14px;
    }

    .top_merit_list ul li .img {
        height: 130px;
    }

    .top_merit_list ul li .text_box {
        padding: 0 0;
    }

    .top_merit_list ul li .text_box h3 {
        font-size: 16px;
    }

    .top_merit_list ul li .text_box p.text {
        font-size: 13px;
        margin-top: 3px;
    }

    .top_merit_list ul li {
        width: 100%;
    }

    .top_merit_list ul li+li {
        /* margin-top: 20px; */
    }

    section.top_merit {
        margin-top: 49px;
        padding: 23vw 0 0;
    }

    a.common_top_link {
        width: 80%;
        font-size: 16px;
        padding: 12px 0;
    }

    .top_merit_list {
        margin-bottom: 30px;
    }

    section.top_search {
        margin-top: 70px;
    }

    .top_search_cont_box .ttl_box p.en {
        font-size: 26px;
    }

    .top_search_cont_box .ttl_box h2 {
        font-size: 14px;
    }

    .top_search_btn_box ul li {
        width: 48%;
    }

    .top_search_btn_box ul li a {
        background-size: 40px;
        padding: 80px 0 20px;
        background-position: center top 25px;
    }

    .top_search_btn_box ul li a p.en {
        font-size: 12px;
    }

    .top_search_btn_box ul li a::before {
        height: 5px;
    }

    .top_search_btn_box ul li a h3 {
        font-size: 16px;
        margin-top: 2px;
    }

    .top_search_kodawari_box ul li {
        width: 43%;
        display: inline-block;
    }

    .top_search_kodawari_box {
        width: 100%;
        position: relative;
        padding: 0;
        margin-top: 16px;
    }

    .top_search_kodawari_box ul {
        display: block;
        overflow-x: auto;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
    }

    .top_search_kodawari_box ul li .text_box p.text {
        font-size: 10px;
    }

    .top_search_kodawari_box ul li+li {
        margin-left: 10px;
    }

    .top_search_kodawari_box ul li.banner {
        display: none;
    }

    .banner.high_grade_btn {
        margin-top: 10vw;
    }

    .top_search_btn_box {
        margin-top: 30px;
    }

    .common_top_h2_box p.en {
        font-size: 26px;
    }

    .common_top_h2_box h2 {
        font-size: 14px;
        margin-top: 4px;
    }

    .top_new_arrival_list ul li {
        margin-left: 0;
        width: 100%;
        border-bottom: 1px solid #eee;
        padding: 24px 0;
    }

    .top_new_arrival_list ul li a {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    .top_new_arrival_list ul li .img {
        width: 45%;
        height: 30vw;
    }

    .top_new_arrival_list ul li .text_box {
        width: 55%;
        margin-top: 0;
        padding: 5px 0px 0 10px;
    }

    .top_new_arrival_list ul li .text_box p.name {
        font-size: 14px;
        line-height: 1.3;
    }

    .top_new_arrival_list ul li .text_box p.text {
        font-size: 11px;
    }

    .top_new_arrival_list ul li .text_box p.text span.color {
        font-size: 13px;
    }

    .top_new_arrival_list ul li:nth-child(n + 2) {}

    .top_new_arrival_list {
        margin-top: 6px;
    }

    section.top_new_arrival {
        margin-top: 13vw;
    }

    section.top_parallax .img .parallax_img {
        height: 100px;
    }

    section.top_parallax {
        display: none;
    }

    .top_post_list ul li {
        margin-left: 0;
        width: 100%;
    }

    .top_post_list ul li a {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }

    .top_post_list ul li .img {
        width: 45%;
        height: 100px;
    }

    .top_post_list ul li .text_box {
        width: 55%;
        margin-top: 0;
        padding: 0 0 0 10px;
    }

    .top_post_list ul li .text_box p.time {
        font-size: 10px;
    }

    .top_post_list ul li .text_box p.ttl {
        font-size: 14px;
    }

    .top_post_list ul li .text_box p.text {
        font-size: 11px;
    }

    .top_post_list ul li:nth-child(n + 2) {
        margin-top: 24px;
    }

    .top_post_list {
        margin-bottom: 30px;
    }

    section.top_post {
        margin-top: 70px;
    }

    .ft_contact_cont .info_box {
        width: 100%;
        justify-content: center;
        border-right: none;
    }

    .ft_contact_cont .info_box .ttl_box p.en {
        font-size: 80px;
    }

    .ft_contact_cont .info_box .ttl_box h2 {
        font-size: 14px;
        margin-top: -12px;
        text-align: center;
    }

    .ft_contact_cont .info_box .tel_box {
        margin-left: 0;
        background-image: none;
        padding-left: 0;
        text-align: center;
        margin-top: 8px;
    }

    .ft_contact_cont .info_box .tel_box p.num {
        font-size: 30px;
    }

    .ft_contact_cont .info_box .tel_box p.time {
        font-size: 11px;
    }

    .ft_contact_cont .link_box {
        width: 100%;
        margin-top: 18px;
    }

    .ft_contact_cont .link_box ul li {
        width: 49%;
    }

    .ft_contact_cont .link_box ul li a {
        font-size: 13px;
        padding: 8px 0;
    }

    .ft_contact {
        padding: 30px 0 40px;
    }

    .ft_message p.main_text {
        font-size: 15px;
    }

    .ft_message p.text {
        font-size: 11px;
        margin-top: 10px;
    }

    .ft_message {
        margin-top: 30px;
    }

    .ft_cont_inner {
        margin-top: 30px;
        padding: 30px 0 0;
    }

    .ft_cont_info_box .banner_box .img {
        width: 49%;
    }

    .ft_cont_info_box .banner_box {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        margin-top: 24px;
    }

    .ft_cont_info_box {
        width: 100%;
    }

    .ft_cont_info_box .banner_box .img+.img {
        margin-top: 0;
    }

    .ft_cont_info_box .info_list {
        text-align: center;
    }

    .ft_cont_info_box .logo_box {
        justify-content: center;
        flex-direction: column;
    }

    .ft_cont_info_box .logo_box p.name {
        margin-left: 0;
        margin-top: 22px;
    }

    .ft_cont_contents {}

    .ft_cont_contents .ttl_box {
        display: none;
    }

    .ft_menu_box {
        display: none;
    }

    .ft_copyright_box {
        flex-direction: column;
    }

    .ft_copyright_box .copyright {
        text-align: center;
        margin-top: 10px;
    }

    .ft_cont {
        padding: 0 0 24px;
    }

    .top_banner_slider li.slick-slide {
        width: 300px !important;
        margin: 0 8px;
    }

    .top_banner_slider .slick-dots li {
        width: 12px;
        height: 12px;
    }

    section.top_banner_box {
        margin-top: 60px;
    }

    .top_service_text_box {
        padding: 0 0;
        margin-top: -95px;
    }

    .top_service_slider li.swiper-slide {
        width: 250px;
    }

    .top_service_slider li.swiper-slide .inner .img {
        height: 350px;
    }

    .top_service_slider li.swiper-slide.swiper-slide-active {
        margin-right: -30px !important;
    }

    section.top_service {
        margin-top: 100px;
        margin-bottom: 52px;
    }

    .fixed_contact_box_sp {
        position: fixed;
        bottom: 0;
        z-index: 10000;
        background-color: #fff;
        width: 100%;
        padding: 12px 20px;
        border-top: 1px solid #eee;
    }

    .fixed_contact_box_sp_cont {}

    .fixed_contact_box_sp_cont ul li {
        width: 31.5%;
    }

    .fixed_contact_box_sp_cont ul li a {
        display: block;
        text-align: center;
        font-weight: bold;
        font-size: 13px;
        background-color: #005bab;
        color: #fff;
        padding: 8px 0;
        border-radius: 7px;
        letter-spacing: 0.04em;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .fixed_contact_box_sp_cont ul li a::before {
        content: '';
        display: block;
        width: 14px;
        height: 14px;
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        margin-right: 5px;
    }

    .fixed_contact_box_sp_cont ul li a.tel::before {
        background-image: url(/penguin/resources/image/bestrent/home/icon_tel_sp.svg);
    }

    .fixed_contact_box_sp_cont ul li a.reservation::before {
        background-image: url(/penguin/resources/image/bestrent/home/icon_reservation_sp.svg);
    }

    .fixed_contact_box_sp_cont ul li a.line::before {
        background-image: url(/penguin/resources/image/bestrent/home/icon_line_sp.svg);
    }

    .fixed_contact_box_sp_cont ul li a.line {
        background-color: #00B900;
    }

    .modal_high_grade_series .inner {
        width: 80%;
        padding: 40px 24px;
    }

    .modal_high_grade_series .inner .ttl_box p.en {
        font-size: 20px;
    }

    .modal_high_grade_series .inner .ttl_box p.ttl {
        font-size: 13px;
    }

    .modal_high_grade_series_list {
        width: 100%;
    }

    .modal_high_grade_series_list ul li {
        width: 100%;
    }

    .modal_high_grade_series_list ul li:nth-child(n + 4) {
        margin-top: 0;
    }

    .modal_high_grade_series_list ul li:nth-child(n + 2) {
        margin-top: 10px;
    }

    .modal_high_grade_series_list ul li a {
        font-size: 15px;
    }

    .sp_hd_cont {
        background-color: #fff;
        border-radius: 100px;
        align-items: center;
        padding: 12px 30px;
        box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
    }

    .sp_hd_box {
        position: fixed;
        top: 16px;
        z-index: 500000;
        left: 0;
        width: 100%;
    }

    .sp_hd_cont .logo {
        width: 45px;
    }

    .hg_menu p.ttl {
        color: #015BAC;
        font-weight: bold;
        font-size: 12px;
        padding: 6px 5px 6px 10px;
    }

    .sp_hg_cont {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        z-index: 50000;
        background-color: #fff;
        width: 100%;
        height: 100%;
        padding-top: 100px;
    }

    .sp_hg_sub_menu_box .item {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: #fff;
    }

    .sp_hg_sub_menu_box .item .inner {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
        height: 100%;
        align-content: center;
    }

    .sp_hg_sub_menu_box .item .inner p.ttl {
        font-size: 18px;
        font-weight: bold;
        letter-spacing: 0.04em;
        position: relative;
        padding: 0 0 20px;
    }

    .sp_hg_sub_menu_box .item .inner ul {
        flex-direction: column;
        width: 100%;
        margin-top: 30px;
    }

    .sp_hg_sub_menu_box .item .inner ul li {
        text-align: center;
    }

    .sp_hg_sub_menu_box .item .inner ul li a {
        font-size: 14px;
        font-weight: bold;
        color: #000;
        border-bottom: 1px solid #eee;
        display: block;
        padding: 16px 0;
        position: relative;
    }

    .sp_hg_sub_menu_box .item .inner ul li a::before {
        content: '';
        position: absolute;
        top: 0;
        bottom: 0;
        right: 16px;
        width: 5px;
        height: 5px;
        border-top: 2px solid #000;
        border-right: 2px solid #000;
        margin: auto;
        transform: rotate(45deg);
    }

    .sp_hg_sub_menu_box .item .inner p.ttl::before {
        content: '';
        position: absolute;
        bottom: 0;
        right: 0;
        left: 0;
        width: 50px;
        height: 2px;
        background-color: #000;
        margin: auto;
    }

    .sp_hg_sub_menu_box .item .inner p.back_btn {
        font-size: 15px;
        font-weight: bold;
        border: 2px solid #000;
        border-radius: 100px;
        padding: 2px 26px;
        margin-top: 40px;
    }

    .sp_hg_menu_box {
        max-height: 100%;
    }

    section.top_review {
        padding: 10vw 4vw;
    }

    section.top_review .title_area {
        position: static;
        padding-top: 0;
    }

    section.top_review .title_area .common_top_h2_box {
        margin-bottom: 4vw;
        text-align: center;
    }

    section.top_review .title_area .text {
        font-size: 4vw;
        margin-bottom: 7vw;
        text-align: center;
    }

    section.top_review .btn {
        width: 100%;
        line-height: 12vw;
        font-size: 4vw;
        margin: 5vw auto 0;
    }

    section.top_review .slider_area {
        margin-left: auto;
    }

    section.top_review .slider_area ul {
        white-space: nowrap;
        overflow: scroll;
        padding-bottom: 10px;
    }

    section.top_review .slider_area li {
        display: inline-block;
        white-space: initial;
        width: 60vw;
    }

    section.top_review .slider_area li+li {
        margin-left: 5vw;
    }

    section.top_review .slider_area li .image {
        height: 60vw;
    }

    section.top_review .slider_area li .data {
        font-size: 3.5vw;
    }

    section.top_review .slider_area li .title {
        font-size: 4vw;
        -webkit-line-clamp: 1;
    }

    .top_text_review_block {
        padding-bottom: 12vw;
    }

    .top_text_review_block .cont .list {
        margin-bottom: 7vw;
    }

    .top_text_review_block .cont .list ul {
        height: 55vw;
        padding: 6vw 3.5vw;
    }

    .top_text_review_block .cont .list ul li + li a {
        padding-top: 4.5vw;
    }

    .top_text_review_block .cont .list ul li a {
        display: block;
        padding-bottom: 3.5vw;
    }

    .top_text_review_block .cont .list ul li a .date {
        font-size: 3.2vw;
        margin-right: 0;
        margin-bottom: 2vw;
    }

    .top_text_review_block .cont .list ul li a .ttl {
        font-size: 3.7vw;
    }

    .top_text_review_block .cont .list ul li a:hover .ttl {
        color: #000;
    }

    .top_text_review_block .cont .list ul li a .arrow {
        display: none;
    }

    .top_text_review_block .cont .btn {
        width: 100%;
        line-height: 12vw;
        font-size: 4vw;
    }

    .top_text_review_block .cont .btn:hover {
        background-color: #005CA9;
        color: #fff;
    }

    section.top_member {
        overflow: hidden;
        margin-top: 50px;
    }

    section.top_member .slider_wrap {
        width: 55vw;
        margin: 0 auto;
    }

    section.top_member .bx-viewport {
        overflow: visible !important;
    }

    section.top_member li .image {
        height: 70vw;
        margin-bottom: 4vw;
    }

    section.top_member .btn {
        width: 60%;
        line-height: 12vw;
        font-size: 4vw;
        margin: 10vw auto 0 auto;
    }

    .top_mv_container {
        grid-template-columns: 1fr;
        row-gap: 10px;
    }

    .top_mv_container .btn_box ul {
        grid-template-columns: repeat(1, 1fr);
        row-gap: 8px;
    }

    .top_mv_container .text_box .title {
        font-size: 6.2vw;
    }

    .top_mv_container .btn_box {
        margin-top: 18px;
    }

    .top_search_cont_box {
        padding: 22px 20px;
    }

    .area_search_container {
        grid-template-columns: 1fr;
        margin-bottom: 5vw;
    }

    .area_search_map_route_box .map {
        display: none;
    }

    .area_search_map_route_box .station_list li {
        position: static;
    }

    .area_search_map_route_box .station_list {
        position: static;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        column-gap: 5px;
        row-gap: 2px;
        background-color: #f5f5f5;
        padding: 12px 12px;
    }

    .area_search_map_route_box .station_list li.osaka_umeda a {
        padding: 5px 0px;
    }

    .area_search_map_route_box .station_list li a {
        text-align: center;
        border-width: 2px;
        padding: 5px 0;
        font-size: 15px;
    }

    .area_search_map_route_box::before {
        display: none;
    }

    .area_search_link_box .item + .item {
        margin-top: 16px;
    }

    .area_search_link_box {
        margin-top: 16px;
    }

    .area_search_link_box .item .list {
        padding: 12px 12px;
    }

    .area_search_link_box .item .list > ul {
        grid-template-columns: repeat(2, 1fr);
        row-gap: 5px;
        column-gap: 5px;
    }

    .top_area_search {
        margin-top: 50px;
    }

    .area_search_link_box .item .list > ul a {
        font-size: 15px;
        padding: 10px 0;
    }

    .common_sub_title {
        font-size: 17px;
    }

    .area_search_map_route_box .title {
        font-size: 17px;
        background-color: #005bac;
        color: #fff;
        text-align: center;
        letter-spacing: 0.04em;
        padding: 10px 0;
    }

    .area_search_map_route_box {
        border-radius: 10px;
        overflow: hidden;
    }

    .area_search_link_box .item .list > ul a::before {
        right: 0;
        bottom: 0;
    }

    .top_banner_list_container .list > ul {
        grid-template-columns: repeat(2, 1fr);
        column-gap: 12px;
        row-gap: 12px;
    }

    .top_banner_list {
        padding: 50px 0;
    }

    .common_top_h2_box .text {
        font-size: 15px;
    }

    .top_merit_list > ul {
        grid-template-columns: 1fr;
        row-gap: 24px;
    }

    section.top_merit .bg {
        width: 165%;
        left: 50%;
        translate: -50% 0;
    }

    .top_recruit_container .title_box .en {
        font-size: 28px;
    }

    .top_recruit_box {
        padding: 30px 25px;
        grid-template-columns: 1fr;
        row-gap: 18px;
    }


    .top_recruit_container .title_box h2 {
        font-size: 15px;
        margin-top: 4px;
    }

    .top_recruit_container .text {
        font-size: 15px;
        margin-top: 20px;
    }

    .top_recruit_container .link {
        padding: 10px 36px;
        font-size: 17px;
        margin-top: 20px;
    }

    .top_recruit {
        padding: 40px 0;
    }

    .area_search_map_route_box {
        display: none;
    }

    .sp_hd_cont .sns_box {
    display: flex;
    align-items: center;
    gap: 3vw;
}

.sp_hd_cont .sns_box .link {
    width: 7.5vw;
}

.sp_hd_cont .sns_box .link img {
    width: 100%;
}

.top_instagram_sec {
    padding: 10vw 0;
}

.top_instagram_sec .cont .snapwidget-widget {
    height: 44vw !important;
}

.top_instagram_sec .common_top_h2_box {
    margin-bottom: 5vw;
}

.top_area_search .area_search_container .area_search_link_box .text_box .ttl {
    font-size: 6.9vw;
}

.top_area_search .area_search_container .area_search_link_box .text_box .theme {
    font-size: 4vw;
    margin-bottom: 0.6em;
}

.top_area_search .area_search_container .area_search_link_box .text_box .text {
    font-size: 3.4vw;
}

.top_area_search .category_box .text_box .link:hover {
    opacity: 1;
}

.top_area_search .category_box .text_box {
    grid-template-columns: repeat(2, 1fr);
    gap: 3vw;
}

.top_area_search .category_box .text_box .link {
    padding: 2vw 2.6vw;
    font-size: 3.4vw;
    min-block-size: 8em;
}

.top_area_search {
    margin: unset;
}

.area_search_link_box {
    margin-top: 7vw;
}


}