/* -------------------------------------------- pc */

body {
    font-family: "M PLUS 1p", sans-serif;
    font-weight: 400;
    font-style: normal;
}

header { display: none; }
main { padding-top: 0; color: #251e1c; }

.txt { line-height: 2.2; }
.ruby { display: inline-block; position: relative; line-height: 1.2; }
.ruby .rt { text-align: center; position: absolute; bottom: 100%; width: 100%; font-size: 9px; left: 0; }

.inner { max-width: 520px; width: 88%; margin: auto; }

.request_btn-wrap { position: sticky; bottom: 2rem; width: 100%; pointer-events: none; margin-bottom: 2rem; z-index: 3; }
.request_btn { font-size: 500; border-radius: 50px; display: inline-block;  pointer-events: all;
    font-size: 1.25rem;
    font-size: clamp(1rem, 1.5vw, 1.5rem);
    padding: 0.25rem 4%; 
    padding-left: 12%;
    background: url(../img/hylo/icn-book.png) no-repeat 14% center;
    background-size: auto 50%;
}
.request_btn span { line-height: 1; }

.centered_img { width: 100%; margin: 0; background: none; }

/* -------------------------------------------- fonts */

.font-brandon { font-family: "brandon-grotesque", sans-serif; font-weight: 400; font-style: normal; }

/* -------------------------------------------- font-size */

.fs-1 { font-size: clamp(12px, 1.125vw, 1.125rem); }
.fs-2 { font-size: clamp(14px, 1.375vw, 1.25rem); }

/* -------------------------------------------- bg */

.bg1 { background: url(../img/hylo/bg1.jpg) no-repeat center center; background-size: cover; }
.bg-main { background-color: #787536; color: #fff; }
.bg-brown1 { background-color: #625e15; }
.bg-brown2 { background-color: #b9b38e; }
.bg-brown3 { background-color: #deddce; }
.bg-black { background-color: #251e1c; color: #fff; }
.bg-orange { background-color: #cf6134; color: #fff; }
.bg-gray { background-color: #646464; color: #fff; }

.color-main { color: #787536; }
.color-brown1 { color: #625e15; }

/* -------------------------------------------- border */

.border-1 { border: 1px solid #251e1c; box-sizing: border-box; }

/* -------------------------------------------- hover-fade */

.hover-fade { transition: 0.5s; }
.hover-fade:hover { opacity: 0.7; }

/* -------------------------------------------- box-shadow */

.box-shadow1 { box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.25); }

/* -------------------------------------------- headings */

.head-style1 { text-align: center; padding: 1rem 0; font-size: 13px; line-height: 1.1; }
.head-style1 span { display: block; font-size: 3.5rem; font-size: clamp(2rem, 3.5vw, 3.5rem); font-weight: 600; }

.head-style2 { text-align: center; padding: 1.5rem 0; }
.head-style2 span { padding: 0 1rem; display: inline-block; }
.head-style2 .big { font-size: 2.75rem; line-height: 1;  font-weight: 600; }
.head-style2 .small { border-left: 2px solid #787536; }

/* -------------------------------------------- columns */

.main-col-left { width: 51%; position: sticky; top: 0; left: 0; height: 100vh; box-sizing: border-box; float: left; }
.main-col-left .hylo-marquee { display: none; animation-direction: reverse; }
.main-col-center { width: 39%; margin-left: 51%; box-sizing: border-box; }
.main-col-center-wrap { padding: 0 3%; } 
.main-col-right { width: 10%; position: sticky; float: right; top: 0; height: 100vh; text-align: center; overflow: hidden; }

/* -------------------------------------------- hylo-marquee */

.hylo-marquee { animation: marquee_animation 12s linear infinite; }
.hylo-marquee p { padding-bottom: 60px; pointer-events: none; }
.hylo-marquee img { height: 420px; width: auto; }

@keyframes marquee_animation {
    from { transform: translateY(0); }
    to { transform: translateY(-50%); }
}

/* -------------------------------------------- hylo-nav */

.hylo-nav { padding: 8% 4% 0; }
.hylo-nav-img img { width: 49%; border-radius: 0.5rem; }
.hylo-nav-wrap { max-width: 580px; padding-top: 2rem; margin: auto; }
.hylo-nav ul { margin-left: -10px; }
.hylo-nav ul li { width: calc(50% - 10px); margin-left: 10px; margin-bottom: 10px; border-radius: 0.75rem; overflow: hidden; display: flex; justify-content: center; box-sizing: border-box; }
.hylo-nav ul li.col3 { width: calc((100% / 3) - 10px); }
.hylo-nav ul li.col1 { width: 100%; }
.hylo-nav ul li a { width: 100%; font-size: 14px; display: block; color: #625e15; padding: 1rem 0; }
.hylo-nav ul li a span { display: block; font-weight: bold; font-size: 1.5rem; line-height: 1.2; }
.hylo-nav ul li.bg-orange a { color: #fff; font-size: 1.5rem; font-weight: 500; }
.hylo-nav ul li.bg-orange a::before { width: 30px; height: 25px; content: ''; display: inline-block; margin-right: 0.5rem; margin-bottom: 0.5rem; vertical-align: middle;
    background: url(../img/hylo/icn-book.png) no-repeat center center;
    background-size: 100% auto;
}
.hylo-nav-footer { bottom: 0; left: 0; width: 100%; padding: 1.5rem 0; }
.hylo-nav-footer img { width: 88%; max-width: 346px; }

.hylo-logo { padding: 3rem 0 2rem; }
.hylo-logo img { width: 50%; max-width: 300px; }

.fv { padding-bottom: 4rem; }
.fv p { font-size: 10px; }

/* -------------------------------------------- concept */

.concept { padding-bottom: 2rem; }
.concept .txt { font-size: 14px; font-size: clamp(14px, 1.375vw, 1.325rem); }
.concept .txt rt { letter-spacing: 0; }
.concept-intro { padding: 4rem 0 4rem; }
.concept-intro img { max-width: 544px; width: 88%; }
.concept-facade { padding: 2rem 0 0; }
.concept-facade img { width: 49%; }

/* -------------------------------------------- collab */

.collab { padding: 2rem 0 4rem; }
.collab .txt { font-size: 14px; font-size: clamp(14px, 1.125vw, 1.125rem); text-align: justify; }
.collab-logos { padding: 3rem 0 2rem; }
.collab-logos a { display: inline-block; box-sizing: border-box; position: relative; padding-right: 1.5rem;
    background: url(../img/hylo/icn-external_link.png) no-repeat right bottom;
    background-size: 17px auto;
}
.collab-logos .three_coins { max-width: 240px; width: calc(60% - 20px); }
.collab-logos .unsta { max-width: 380px; width: calc(82% - 20px); }
.collab-logos .x { width: 30px; margin: 1rem auto; display: block; }

/* -------------------------------------------- performance */

.performance { padding: 0 0 3rem; }
.performance .inner { padding-top: 2rem; }
.performance ul { padding-top: 2rem; }
.performance ul li { padding: 2rem 6%; margin-bottom: 2rem; }
.performance ul li h4 { font-size: 1.5rem; font-weight: 600; padding-bottom: 1.75rem; line-height: 1.6; letter-spacing: 1px;
    background: url(../img/hylo/border-1.png) bottom center repeat-x;
    background-size: auto 8px;
}
.performance ul li h4 .box-text { font-size: 1rem; padding: 0.125rem 0.5rem; display: inline-block; vertical-align: middle; }
.performance ul li .row { padding-top: 1.5rem; }
.performance ul li img { width: 100px; }
.performance ul li .txt { width: calc(100% - 120px); line-height: 1.8; }

/* -------------------------------------------- plan */

.plan { padding-bottom: 2rem; }
.plan-wrap { padding-bottom: 3rem; }
.plan-wrap::after { width: 94%; margin: auto; bottom: 0; left: 0; right: 0; height: 1px; background-color: #787536; }
.plan-wrap ul { padding: 2rem 0 0; }
.plan-wrap ul li { max-width: 585px; margin: 0 auto; padding: 1rem 0; }
.plan-wrap ul li .txt { line-height: 1.8; padding-top: 1rem; }
.plan-wrap ul li .caption { font-size: 1.25rem; font-weight: 600; padding-bottom: 0.5rem; }
.plan-slider { padding: 6% 6% 2%; border-radius: 0.5rem; position: relative; }
.plan-slider .swiper-slide { width: 28vw; max-width: 460px; }
.plan-slider .swiper-slide p { font-size: 1.25rem; font-weight: 500; padding-top: 1%; }
.plan-slider .slider-nav { padding: 0 3%; top: 0; bottom: 0; width: 100%; height: 100%; left: 0; z-index: 1; box-sizing: border-box; pointer-events: none; }
.plan-slider .slider-nav img { width: 40px; height: auto; pointer-events: all; cursor: pointer; }
.plan-slider .slider-nav-next { transform: rotate(180deg); }
.plan-slider .slider-nav-wrap { width: 100%; height: 100%; }

.sticky-bubble { top: 30px; position: sticky; z-index: 2; left: 0; margin-top: 1rem; height: 0; }
.sticky-bubble-wrap { width: 20%; max-width: 100px; text-align: center; }
.sticky-bubble-box { padding-top: 100%; }
.sticky-bubble-box p { width: 100%; height: 100%; top:0; left: 0; color: #fff; background-color: #251e1c; border-radius: 50%; position: absolute; }
.sticky-bubble-box p .big { font-size: 1.25rem; }

.floorplan { padding: 2rem 0 0; }
.floorplan-wrap { border: 1px solid #000; border-radius: 0.5rem; overflow: hidden; margin-top: 1rem; }
.floorplan-wrap-box { padding: 1rem 4% 2rem; background-color: #fff; }
.floorplan-wrap-box.hiraya { padding-top: 2rem; }
.floorplan-wrap-box img { margin: auto; display: none; width: 100%; max-width: 640px; }
.floorplan-wrap-box.hiraya img { width: 88%; }
.floorplan-wrap-box .active { display: block; }
.floorplan-tabs {  background-color: #808080; }
.floorplan-tabs-btn { width: 50%; padding: 0.25rem 0; font-size: 1.75rem; font-weight: 600; cursor: pointer; box-sizing: border-box;
    border-left: 1px solid #000;
    border-bottom: 1px solid #000;
}
.floorplan-tabs-btn:first-child { border-left: none; }
.floorplan-tabs-btn span { position: relative; z-index: 2; }
.floorplan-tabs-btn.active { background-color: #fff; cursor: default; position: relative; border-bottom: none; }
.floorplan-info { width: 88%; box-sizing: border-box; margin: auto; padding-top: 2rem; }
.floorplan-info .madori { border-radius: 0.375rem; display: inline-block; padding: 0 0.75rem; font-weight: 500; }
.floorplan-info p { padding-top: 0.5rem; font-size: 14px; }

/* -------------------------------------------- living_ideas */ 

.living_ideas { padding-bottom: 2rem; }
.living_ideas ul { padding: 3rem 2% 0; }
.living_ideas ul li { width: 48%; margin-bottom: 2rem; }
.living_ideas ul li .num { padding-bottom: 1.25rem; }
.living_ideas ul li .num span { display: inline-block; padding: 0 1rem; font-size: 1.5rem; font-weight: 600; height: 36px; line-height: 37px; }
.living_ideas ul li img { margin: auto; width: 88%; display: block; }
.living_ideas ul li .ttl { font-size: 1.25rem; font-weight: 600; padding: 1rem 0 0.5rem; line-height: 1.4; }
.living_ideas ul li .txt { font-size: 14px; line-height: 2; }

.bottom-links { padding: 4rem 0; }
.bottom-links-img { width: 64px; margin: auto; }
.bottom-links .btn { border-radius: 1rem; width: 48%; box-sizing: border-box; padding: 2rem 3%; }
.bottom-links .btn img { width: 100% !important; }
.bottom-links .btn span { display: block; line-height: 1.4; padding-top: 1rem; }

/* -------------------------------------------- dealers */

.dealers { padding: 4rem 0; }
.dealers .main-ttl { font-size: 1.5rem; font-weight: 600; }

.store-areas { padding: 2rem 0 0; }
.store-areas span { padding: 0 0.5rem; font-size: 14px; height: 30px; line-height: 30px; display: block; border: 1px solid #000; border-radius: 0.25rem; margin-right: 0.5rem; }
.store-list { padding: 1rem 0; }
.store-list-card { padding: 2rem 4%; border: 1px solid #000; border-radius: 0.5rem; margin: 0 auto 1rem; max-width: 580px; box-sizing: border-box; }
.store-list-card .pic { padding-bottom: 1rem; text-align: center; }
.store-list-card .pic img { width: 70%; border-radius: 0.5rem; }
.store-list-card h4 { font-size: 1.25rem; font-weight: 600; padding: 0.5rem 0 1rem; }
.store-list-card h4 a { display: inline-block; padding-right: 1.5rem;
    background: url(../../assets/img/_common/icon-link.svg) no-repeat right center;
    background-size: 1rem auto;
}
.store-list-card p { font-size: 14px; }
.store-list-card .info { padding-bottom: 1.5rem; }
.store-list-card .info p { padding: 0.25rem 0; }
.store-links { padding-bottom: 2rem; border-bottom: 1px solid #000; }
.store-links p { padding: 0.25rem 0; }
.store-links a { display: inline-block; font-weight: 600; font-size: 1rem; padding-left: 2rem;  transition: 0.25s;
    background: url(../../assets/img/_common/icon_arrow_link.svg) no-repeat 0% center;
    background-size: 1.125rem auto;
}
.store-links a:hover { background-position: 3% center; }
.store-list-products { padding: 1rem 0 0; }
.store-list-products .caption { padding-bottom: 0.5rem; }

@media screen and (min-width: 768px) {
    .pc-none { display: none; }
}

/* -------------------------------------------- tablet */

@media screen and (max-width: 1100px) {
    .hylo-nav,
    .hylo-nav-footer { display: none; }
    
    .main-col-left,
    .main-col-right { width: 20%; z-index: -1; }
    .main-col-left .hylo-marquee { display: block; }
    .main-col-center { width: 60%; margin: auto; }

    .plan-slider .swiper-slide { width: 42vw; }
}

/* -------------------------------------------- sp */

@media screen and (max-width: 767px) {
    .sp-none { display: none; }
    html { font-size: 14px; }

    .head-style1 span { font-size: clamp(2.5rem, 3.25vw, 4rem); }

    .main-col-left,
    .main-col-right { display: none; }
    .main-col-center { width: 100%; } 

    .concept-intro img { width: 64%; max-width: 320px; }

    .sticky-bubble-wrap { max-width: 72px; }

    .request_btn { padding: 0.5rem 1.25rem; padding-left: 3.25rem; background-size: auto 45%; }
    .request_btn span { font-size: 1.25rem; }

    .living_ideas ul li .num span { font-size: 1.25rem; height: 30px; line-height: 30px; padding: 0 0.75rem; }
    .living_ideas ul li .txt { font-size: 13px; }

    .bottom-links-img { width: 50px; }

    .plan-slider .swiper-slide { width: 72vw; }

    .performance ul li { padding: 1.5rem 6%; margin-bottom: 1.25rem; }
    .performance ul li h4 { font-size: 1.5rem; width: calc(100% - 120px); text-align: left; line-height: 1.4; }
    .performance ul li h4 span { font-size: 1rem; }
    .performance ul li h4 .box-text { font-size: 12px; }
    .performance ul li .row { padding-top: 1rem; }
    .performance ul li img { width: 110px; float: right; margin: 0 0 0.5rem 0.5rem; }
    .performance ul li .txt { width: 100%; font-size: 12px; }
}