@charset "utf-8";

/* reset */
@import url("reset.css");


/* header */
header {
    background: var(--red);
    color: #ffffff;
    height: 4.6875rem;
    box-shadow: 0 2px 4px 0 rgba(100, 0, 0, 0.25);
    position: relative;
}

.hd_wrap {
    margin-left: calc((100% - 1186px) / 2);
    width: auto;
    height: 100%;
    justify-content: space-between;
    padding-right:5.5rem ;
    align-items: center;
    gap: 1rem;
}

@media (max-width: 1186px) {
    .hd_wrap {
        width: 96%;
        margin-left: 4%;
        margin-right: 0;
        padding-right:5.5rem ;
    }
}

/* SP */
@media (max-width: 768px) {
.hd_wrap {
    padding-right: 4rem;
}

}


.logo_area {
    height: 100%;
    width: fit-content;
}
.logo_area a {
    color: #ffffff;
    justify-content: center;
    height: 100%;
    line-height: 1;
}

.logo_area a small {
    font-size: 1rem;
    display: block;
letter-spacing: 0.1rem;
}

.logo_area a strong {
    font-size: 2.25rem;
    font-weight: normal;
    display: block;
}

/* SP */
@media (max-width: 768px) {
    header {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        z-index: 300;
    }
header .logo_area a small {
    font-size: 0.9rem;
    display: block;
letter-spacing: 0.1rem;
font-weight: 500;
}

header .logo_area a strong {
    font-size: 1.9rem;
    font-weight: normal;
    display: block;
}

}


/* 翻訳プルダウン */
.gtranslate_wrapper {
    width: fit-content;
}


.gt_selector {
   border: none;
   background: #ffffff;
   border-right:solid 5px #ffffff;
   color: var(--red);
   width: 6.75rem;
    height: 2.1875rem;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border-radius: 0;
   display: flex;
   align-items: center;
   padding-left: 1rem;
    padding-right: 1.75rem;
   font-size: 18px;
   font-weight: 400;
   font-family: "futura-pt", sans-serif;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M4.24265 5.30325L-0.000102848 1.0605L1.0604 -3.70913e-07L4.7729 3.7125L8.4854 -4.63559e-08L9.5459 1.0605L5.30315 5.30325C5.1625 5.44385 4.97177 5.52284 4.7729 5.52284C4.57402 5.52284 4.38329 5.44385 4.24265 5.30325Z' fill='%23C2191F'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.6rem center;
    background-size: 10px 6px;
   
}





/* メニュー全体のスタイル */
.menu-container {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2%;
    display: flex;
    align-items: center;
    z-index: 1100;
}

/* PC only*/
@media (min-width: 769px) {
    .menu-container {
        right: 1.3rem;
    }
}

/* ハンバーガーメニューアイコン */
.hamburger {
   width: 2.5rem;
   height: 25px;
   display: flex;
   flex-direction: column;
   justify-content: space-between;
   cursor: pointer;
   z-index: 1001;
    position: relative;
    top: 0;
    right: 0;
    transform: none;
    -webkit-transform: none;
    -ms-transform: none;
}

.hamburger.pc {
   display: none;
}

.hamburger span {
   display: block;
   height: 1px;
   width: 2rem;
   background: #FFFFFF;
   transition: all 0.3s ease;
}

/* メニューのスタイル（デフォルト非表示・全画面） */
.menu {
   position: fixed;
    top: 4.6875rem;
   left: 0;
   width: 100%;
    height: calc(100vh - 4.6875rem);
    background: #ffffff;
   display: flex;
    align-items: flex-start;
    justify-content: center;
   opacity: 0;
   visibility: hidden;
   transition: opacity 0.3s ease, visibility 0.3s ease;
    overflow-y: auto;
    z-index: 1090;
    pointer-events: none;
}

/* PC only*/
@media (min-width: 769px) {
    .menu {
        width: 430px;
        height: 610px;
        right: 0;
        left: auto;
        border-radius: 0 0 0 50px;
        background: #FFF;
        box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
    }
}

.menu ul {
   list-style: none;
    margin: 2rem 0 3rem;
   padding: 0;
    text-align: left;
    width: min(92%, 420px);
}

.menu ul li {
    margin: 0;
}

.menu ul li a.menu_main {
   text-decoration: none;
   color: #C2191F;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    transition: color 0.3s ease, opacity 0.3s ease;
    
    border-bottom: 1px solid #C2191F;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 0.25rem;
}

.menu ul li a.menu_main::after {
    content: "";
    width: 8px;
    height: 14px;
    flex-shrink: 0;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    transition: transform 0.3s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='14' viewBox='0 0 8 14' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.07113 7.7456L1.41413 13.4026L0.00012207 11.9886L4.95012 7.0386L0.00012207 2.0886L1.41413 0.674591L7.07113 6.3316C7.2586 6.51917 7.36392 6.77352 7.36392 7.0386C7.36392 7.30367 7.2586 7.55803 7.07113 7.7456Z' fill='%23C2191F'/%3E%3C/svg%3E");
}

/* メニューが開いたとき */
.menu.active {
   opacity: 1;
   visibility: visible;
    pointer-events: auto;
}

.menu_label {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

.menu_label img {
    width: 1.5rem;
    height: 1.5rem;
    object-fit: contain;
    flex-shrink: 0;
}

.menu ul li a:hover {
    opacity: 0.8;
}

.menu ul li a:hover::after {
    transform: translateX(4px);
}

.menu_brand_block {
    /* border-bottom: 1px solid #C2191F; */
    padding: 1.4rem 0.25rem 0.8rem;
}

.menu_brand_head {
    color: #C2191F;
    font-size: 2.2rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
    text-align: left;
}

.menu_brand_head::after {
    content: "";
    width: 14px;
    height: 11px;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    transition: transform 0.3s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M5.29289 0.928932C5.68342 0.538408 6.31658 0.538408 6.70711 0.928932L11.7071 5.92893L10.2929 7.34315L6 3.05025L1.70711 7.34315L0.292893 5.92893L5.29289 0.928932Z' fill='%23C2191F'/%3E%3C/svg%3E");
}

.menu_brand_items {
    gap: 1.2rem;
    justify-content: center;
    max-height: 0;
    opacity: 0;
    margin-top: 0;
    overflow: hidden;
    pointer-events: none;
    transform: translateY(-6px);
    will-change: max-height, opacity, transform;
    transition: max-height 0.45s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.3s ease, transform 0.3s ease, margin-top 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.menu_brand_block.is-open .menu_brand_items {
    max-height: 320px;
    opacity: 1;
    pointer-events: auto;
    margin-top: 1rem;
    transform: translateY(0);
}

.menu_brand_block.is-open .menu_brand_head::after {
    transform: rotate(180deg);
}

.menu_brand_items a {
    border: 0;
    min-height: 0;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    width: calc((100% - 1.2rem) / 2);
    /* max-width: 170px; */
    border-bottom:0!important;
}

.menu_brand_items a::after {
    content: none;
}

.menu_brand_items a img {
    width: 90%;
    height: auto;
}

.menu ul li a:after {
content: none;
}
.menu_brand_head {
    font-size: 1.5rem;
    font-family: "futura-pt", sans-serif;
}

/* ハンバーガーメニューのアニメーション（×に変化） */
.hamburger.active {
    justify-content: center;
}

.hamburger.active span {
    position: absolute;
    left: 0;
    top: 50%;
    width: 2rem;
    transform-origin: center;
}

.hamburger.active span:nth-child(1) {
    transform: translateY(-50%) rotate(45deg);
}

.hamburger.active span:nth-child(2) {
   opacity: 0;
    transform: translateY(-50%) scaleX(0);
}

.hamburger.active span:nth-child(3) {
    transform: translateY(-50%) rotate(-45deg);
}

/* スクロール禁止 */
body.no-scroll {
   overflow: hidden;
}







/* SP */
@media (max-width: 768px) {
main {
    padding-top: 4.6875rem;
}
}


/* mainvisual */

.mainvisual {
    position: relative;
    padding-bottom: 2rem;
    margin-top: 1.2rem;
    margin-bottom: 4rem;
}


.mainvisual .slick-slide img {
    width: 100%;
    height: auto;
    /* max-width: 600px;
    max-height: 742px; */
    aspect-ratio: 600 / 742;
    object-fit: cover;
    display: block;
    margin: 0 auto;
}

.mainvisual .slick-list {
    /* margin: 0 -0.5rem; */
    width: 100%;
}

.mainvisual .slick-slide {
    padding: 0 0.8rem;
    box-sizing: border-box;
}

.mainvisual .slick-slide a {
    width: 100%;
    max-width: 600px;
    display: block;
    margin: 0 auto;
}

@media (max-width: 768px) {
    .mainvisual .slick-track {
        display: flex;
        align-items: flex-end;
    }

    .mainvisual .slick-slide {
        transition: transform 0.3s ease, opacity 0.3s ease;
        transform-origin: center bottom;
        padding: 0 0rem;
    }

    .mainvisual .slick-slide:not(.slick-center) {
        transform: scale(0.92);
        opacity: 0.92;
    }
}


.mainvisual .slick-dots {
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    width: 100%;
}

.mainvisual .slick-dots li {
    line-height: 0;
}

.mainvisual .slick-dots li button {
    width: 0.875rem;
    height: 0.875rem;
    border: 1px solid var(--red);
    border-radius: 50%;
    background: #ffffff;
    font-size: 0;
    padding: 0;
}

.mainvisual .slick-dots li button::before {
    content: none;
}

.mainvisual .slick-dots li.slick-active button {
    background: var(--red);
}


/* page_nav */
.page_nav {
    gap: 34px;
    justify-content: space-between;
    margin-bottom: 5rem;
}


.page_nav a {
    width: calc((100% - 68px) / 3);
    border: solid 1px var(--red);
    overflow: hidden;
    align-items: center;
    color: var(--red);
}

.page_nav a:hover {
    background: var(--red);
    color: #ffffff;
}

/* SP only */
@media (max-width: 768px) {
    .page_nav {
        flex-wrap: wrap;
        gap: 10px;
        margin-bottom: 2rem;
    }

    .page_nav a {
        width: calc((100% - 10px) / 2);
    }

    .page_nav a:first-child {
        width: 100%;
    }

}

.page_nav a .icon_area {
    background: var(--red);
    padding: 5px;
    text-align: center;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50px;
}

.page_nav a:hover .icon_area {
    background: #ffffff;

}

.page_nav a .icon_area.icon_search:before {
    content: "";
    display: block;
    background-image: url(../img/icon_search.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    image-rendering: crisp-edges;
    width:23px;
    height: 32px;
    transition-duration: 300ms;
}

.page_nav a:hover .icon_area.icon_search:before {
    background-image: url(../img/icon_search_hover.png);
}


.page_nav a .icon_area.icon_plan:before {
    content: "";
    display: block;
    background-image: url(../img/icon_plan.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    image-rendering: crisp-edges;
    width:26px;
    height: 29px;
    transition-duration: 300ms;
}

.page_nav a:hover .icon_area.icon_plan:before {
    background-image: url(../img/icon_plan_hover.png);
}


.page_nav a .icon_area.icon_topics:before {
    content: "";
    display: block;
    background-image: url(../img/icon_topics.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    image-rendering: crisp-edges;
    width:26px;
    height: 30px;
    transition-duration: 300ms;
}

.page_nav a:hover .icon_area.icon_topics:before {
    background-image: url(../img/icon_topics_hover.png);
}


.page_nav a .name_area {
    font-size: 1.4rem;
    padding-top: 0.5rem;

}

.page_nav a:after {
    content: "";
    display: block;
    height: 0.34519rem;
    width: 0.59663rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M4.24265 5.30325L-0.000102848 1.0605L1.0604 -3.70913e-07L4.7729 3.7125L8.4854 -4.63559e-08L9.5459 1.0605L5.30315 5.30325C5.1625 5.44385 4.97177 5.52284 4.7729 5.52284C4.57402 5.52284 4.38329 5.44385 4.24265 5.30325Z' fill='%23C2191F'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: cover;
    margin-bottom: 5px;
}

.page_nav a:hover:after {
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M4.24265 5.30325L-0.000102848 1.0605L1.0604 -3.70913e-07L4.7729 3.7125L8.4854 -4.63559e-08L9.5459 1.0605L5.30315 5.30325C5.1625 5.44385 4.97177 5.52284 4.7729 5.52284C4.57402 5.52284 4.38329 5.44385 4.24265 5.30325Z' fill='%23ffffff'/%3E%3C/svg%3E");
transform: translateY(3px);
}


.exp_txt {
    background-image:url(../img/exp_bg.webp) ;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    
    min-height: 23.125rem;
    padding: 2rem;
    border-radius: 0.75rem;
    align-items: center;
    justify-content: center;
    margin-bottom: 5rem;
}

.exp_txt p {
    text-shadow: 0 2px 4px #000;
    font-size: 1.4rem;
    line-height: 1.5;
    color: #ffffff;
    max-width: 61rem;
}

/* SP only */
@media (max-width: 768px) {
    .exp_txt {
        width: 100%;
        border-radius: 0;
        min-height: fit-content;
        padding: 1.5rem;
        margin-bottom: 2rem;
    }
    .exp_txt p {
        font-size: 1rem;
    }
}

.search {
    width: 92%;
    max-width: 980px;
    margin-bottom: 7rem;

}

.search h2 {
    color: var(--red);
    align-items: center;
    font-size: 2rem;
    font-weight: 500;
    gap: 1rem;
    margin-bottom: 2rem;
}

/* SP only */
@media (max-width: 768px) {
    .search h2 {
        margin-bottom: 1rem;
    }
    .search {
        margin-bottom: 3rem;
    }
}

.search h2 img {
    width: 1.44044rem;
}

p.search_exp {
    width: 100%;
    font-size: 1.3rem;
    font-weight: 500;
    margin-bottom: 3rem;
}

/* SP only */
@media (max-width: 768px) {
    p.search_exp {
        margin-bottom: 1rem;
    }
}


.search .map_wrap {
    gap: 2rem;
}


.search .map {
    aspect-ratio: 564 / 312;
    width: 564px;
    height: fit-content;
    position: relative;
    display: inline-block;
} 


/* SP only */
@media (max-width: 768px) {
    .search .map {
        width: 100%;
    }
}


.map img {
    width: 100%;
    height: auto;
    display: block;
}

.search .map a {
    position: absolute;
    display: block;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 15%;   /* 115 / 元画像横幅 */
    height: auto;      /* 102 / 元画像高さ */
    aspect-ratio: 1/1;
}

.search .map .link_osaka {
    left: 31.5%;
    top: 47.5%;
    background-image: url(../img/icon_osaka.png);
}

.search .map .link_osaka:hover {
    background-image: url(../img/icon_osaka_hover.png);
    transform: translateY(10px);
}


.search .map a.link_sapporo {
    left: 68%;
  top: 10%;
    background-image: url(../img/icon_sapporo.png);
}

.search .map .link_sapporo:hover {
    background-image: url(../img/icon_sapporo_hover.png);
    transform: translateY(10px);
}


.search .map_wrap .txt {
    width: 344px;
    word-break: break-word;
}


/* SP only */
@media (max-width: 768px) {
    .search .map_wrap .txt {
        width: 100%;
        gap: 1rem;
        justify-content: center;
    }
}

.search .map_wrap .txt a {
    font-size: 1.5rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 0.3rem;
}
.search .map_wrap .txt a:after {
    content: "";
    width: 0.75rem;
    height: 1.5rem;
    flex-shrink: 0;
    aspect-ratio: 1/2;
    display: block;
    transition: transform 0.3s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='24' viewBox='0 0 12 24' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.1569 12.7116L4.49994 18.3686L3.08594 16.9546L8.03594 12.0046L3.08594 7.05463L4.49994 5.64062L10.1569 11.2976C10.3444 11.4852 10.4497 11.7395 10.4497 12.0046C10.4497 12.2698 10.3444 12.5241 10.1569 12.7116Z' fill='%23C2191F'/%3E%3C/svg%3E");
}

.search .map_wrap .txt a:hover {
    color: var(--red);
}

.search .map_wrap .txt a:hover:after {
    transform: translateX(7px);
}

.search .map_wrap .txt p {
font-size: 1.25rem;
font-weight: 500;
margin-bottom: 3rem;
}




/* plan */

.plan {
    margin-bottom: 7rem;

}
/* SP only */
@media (max-width: 768px) {
    .plan {
    margin-bottom: 3rem;

}
}

.plan h2 {
    color: var(--red);
    align-items: center;
    font-size: 2rem;
    font-weight: 500;
    gap: 1rem;
    margin-bottom: 2rem;
}

/* SP only */
@media (max-width: 768px) {
    .plan h2 {
        margin-bottom: 1rem;
    }
}

.plan h2 img {
    width: 1.44044rem;
}

.plan_list {
    margin-left: calc((100% - 1186px) / 2);
    width: auto;
    margin-right: 0;
    justify-content: space-between;
    margin-bottom: 3rem;
}

@media (max-width: 1186px) { 
    .plan_list {
        width: 96%;      /* 100% - 左余白2% */
        margin-left: 4%; /* .wd の 96% 幅によって生じる左余白と同じ */
        margin-right: 0;
        gap: 1rem;
    margin-bottom: 2rem;
    }
}

.pl_exp {
    width: 326px;
    gap: 1rem;
}

.pl_exp h3 {
    width: 252px;
}

.pl_exp p {
    font-size: 22px;
    font-weight: 500;
}

/* SP only */
@media (max-width: 768px) {
    .pl_exp {
        width: 100%;
    }
    .pl_exp p {
        font-size: 1.1rem;
    }
}


.pl_slide {
    width: calc(100% - 326px - 2rem);
    position: relative;
}

/* SP only */
@media (max-width: 768px) {
    .pl_slide {
    width: 100%;
}
}

.pl_slide {
    /* padding-left:3% ; */
    padding-bottom: 2.5rem;

}
.pl_slide .slick-slide:first-child {

}
.pl_slide .slick-slide {
    pointer-events: none; /* デフォルトでクリック不可 */
    margin-right: 10px;
}
.pl_slide .slick-slide:last-child {
    margin-right: 0;

}
.pl_slide .slick-active {
    pointer-events: auto; /* アクティブなスライドだけクリック可能 */
}

.pl_slide .slick-prev,
.pl_slide .slick-next {
    position: absolute;
    bottom: -0.7rem;
    background: #ffffff;
    border: solid 1px #C2191F;
    width: 2.3rem;
    height: 2.3rem;
    display: block;

    z-index: 10;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size:2px;
    box-shadow: none; 
}

/* SP only */
@media (max-width: 768px) {
    .pl_slide .slick-prev,
.pl_slide .slick-next {
    bottom: -3.5rem;
}
}

.pl_slide .slick-prev {
    right: calc(7% + 3rem);
}


.pl_slide .slick-next {
    right: 6%;
}


/* ✅ 矢印の形を `＜` `＞` にする */
.pl_slide .slick-prev::before,
.pl_slide .slick-next::before {
    position: absolute;
    content: "";
    font-family: "Font Awesome 5 Free"; /* フォントアイコンを使用 */
    font-weight: 900;
    font-size: 20px;
    color: #C2191F;
    top: 50%;
    left: 41%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

/* 左矢印 */
.pl_slide .slick-prev::before {
    content: "\f104"; /* FontAwesomeの左矢印（←） */
    left: 34%;
}

/* 右矢印 */
.pl_slide .slick-next::before {
    content: "\f105"; /* FontAwesomeの右矢印（→） */
    left: 39%;

}

.pl_slide .slick-dots {
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    width: 100%;
}

/* SP only */
@media (max-width: 768px) {
    .pl_slide .slick-dots {
        left: 50%;
        right: auto;
        width: 100%;
        transform: translateX(-50%);
    }
}


.pl_slide .slick-dots li {
    line-height: 0;
}

.pl_slide .slick-dots li button {
    width: 0.875rem;
    height: 0.875rem;
    border: 1px solid var(--red);
    border-radius: 50%;
    background: #ffffff;
    font-size: 0;
    padding: 0;
}

.pl_slide .slick-dots li button::before {
    content: none;
}

.pl_slide .slick-dots li.slick-active button {
    background: var(--red);
}



/* スライド記事部分 */
.pl_slide .sl_wrap {
    gap: 0.3rem;

}

.pl_slide .sl_wrap:hover {
    opacity: 0.6;
}

.pl_slide .sl_wrap img {
    border-radius: 12px;
    width: 100%;
    height: auto;
    aspect-ratio: 250 / 180;
    object-fit: cover;
    object-position: top center;
}

.pl_slide .sl_wrap dl {
    justify-content: space-between;
    color: #9E9E9E;
    font-size: 14px;
    font-weight: 500;
}

.pl_slide .sl_wrap dl img {
    width: 15px;
    height: 15px;
    border-radius: none;
}

.pl_slide .sl_wrap dl dd {
    align-items: center;
}

.pl_slide .sl_wrap h3 {
    font-size: 22px;
    font-weight: 500;
}
.pl_slide .sl_wrap:hover h3 {
    color: var(--red);

}

/* SP only */
@media (max-width: 768px) {
    .pl_slide .sl_wrap h3 {
        font-size: 20px;
    }
}




a.seemore {
    width: 180px;
    height: 47px;
    color: var(--red);
    border: solid 1px var(--red);
    border-radius: 12px;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    font-weight: 500;
    position: relative;
}

a.seemore:after {
    content: "";
display: block;
/* 整数値に変更（元のSVGが 6:10 なので 6px:10px が理想） */
width: 6px;
height: 10px;
position: absolute;
right: 1rem;
top: 50%;
/* 小数点によるボケを防ぐため、まとめて指定 */
transform: translateY(-50%);
transition: transform 0.3s ease;
/* 歪み防止の肝 */
background-size: contain;
background-repeat: no-repeat;
background-position: center;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='10' viewBox='0 0 6 10' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M5.30325 5.30325L1.0605 9.546L0 8.4855L3.7125 4.773L0 1.0605L1.0605 0L5.30325 4.24275C5.44385 4.3834 5.52284 4.57413 5.52284 4.773C5.52284 4.97187 5.44385 5.16261 5.30325 5.30325Z' fill='%23C2191F'/%3E%3C/svg%3E");
}

a.seemore:hover {
    background: var(--red);
    color: #ffffff;
}

a.seemore:hover:after {
    transform: translate(4px, -50%);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='10' viewBox='0 0 6 10' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M5.30325 5.30325L1.0605 9.546L0 8.4855L3.7125 4.773L0 1.0605L1.0605 0L5.30325 4.24275C5.44385 4.3834 5.52284 4.57413 5.52284 4.773C5.52284 4.97187 5.44385 5.16261 5.30325 5.30325Z' fill='%23ffffff'/%3E%3C/svg%3E");
}

/* TOPICS */
.topics {
    width: 92%;
    max-width: 1100px;
    margin: 0 auto 7rem;
}

.topics h2 {
    color: var(--red);
    align-items: center;
    font-size: 2rem;
    font-weight: 500;
    gap: 1rem;
    margin-bottom: 2rem;
}

/* SP only */
@media (max-width: 768px) {
    .topics h2 {
        margin-bottom: 1rem;
    }
}

.topics h2 img {
    width: 1.44044rem;
}

.topics .tp_wrap {
    width: 96%;
    max-width: 986px;
    margin: 0 auto;
    gap: 2rem;
    align-items: flex-start;
    justify-content: space-between;
}
/* SP only */
@media (max-width: 768px) {
    .topics .tp_wrap {
    }
}

.topics_tab_area {
    flex: 1;
    min-width: 460px;
    max-width: 460px;
    width:460px;
}

/* SP only */
@media (max-width: 768px) {

.topics_tab_area {
    width: 100%;
    min-width: 100%;
}
}


.topics_tabs {
    width: 100%;
    margin: 0 0 0.3rem;
    display: flex;
}

.topics_tab_btn {
    width: 50%;
    height: 47px;
    border: 1px solid var(--red);
    background: #ffffff;
    color: var(--red);
    font-size: 22px;
    font-weight: 400;
    line-height: 1;
    font-family: "futura-pt", sans-serif;
    cursor: pointer;
    transition-duration: 300ms;
}

.topics_tab_btn:hover {
    background: var(--red);
    color: #ffffff;
    transition-duration: 300ms;
}

.topics_tab_btn:first-child {
    border-radius: 0.75rem 0.75rem 0 0;
}

.topics_tab_btn:last-child {
    border-radius: 0.75rem 0.75rem 0 0;
}

.topics_tab_btn.is-active {
    background: var(--red);
    color: #ffffff;
}

.topics_panels {
    width: 100%;
    margin: 0;
    position: relative;
}

.topics_panel {
    position: absolute;
    inset: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.35s ease, visibility 0s linear 0.35s;
}

.topics_panel.is-active {
    position: relative;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    z-index: 2;
    transition-delay: 0s;
}

.topics_panel.is-leaving {
    position: absolute;
    inset: 0;
    opacity: 0;
    visibility: visible;
    pointer-events: none;
    z-index: 1;
    transition-delay: 0s;
}

/* SP only */
@media (max-width: 768px) {


    .topics_side {
        width: 100%;
        min-height: 0;
    }

    .topics_tab_btn {

    }
}



.tp_art {
    border-bottom: solid 1px var(--red);
    padding: 0.9rem 0;
    gap: 13px;
    align-items: stretch;
    position: relative;
}

.tp_art img {
    border-radius: 12px;
    width: 130px;
    height: 93px;
    object-fit: cover;
}

/* SP only */
@media (max-width: 768px) {
    .tp_art {
        padding: 0.6rem 0;
        gap: 10px;
    }
    .tp_art img {
        width: 30%;
        height: auto;
        aspect-ratio: 130 / 93;
    }

}

.tp_art .column {
    width: calc(100% - 137px);
    gap: 0.35rem;
    padding: 0.5rem 2rem 0.5rem 0;
    position: relative;
}

@media (max-width: 768px) {
    .tp_art .column {
        width: 70%;
        padding-right: 1.5rem;
    }
}

.tp_art .column::after {
    content: "";
    width: 10px;
    height: 16px;
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    transition: transform 0.3s ease;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='16' viewBox='0 0 10 16' fill='none'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.83945 8.83945L2.18245 15.4965L0.768448 14.0825L6.71845 8.13245L0.768448 2.18245L2.18245 0.768448L8.83945 7.42545C9.02692 7.61301 9.13225 7.86738 9.13225 8.13245C9.13225 8.39752 9.02692 8.65188 8.83945 8.83945Z' fill='%23C2191F'/%3E%3C/svg%3E");
}

.tp_art:hover .column::after {
    transform: translate(10px, -50%);
}

@media (max-width: 768px) {
    .tp_art .column::after {
        right: 0.5rem;
    }
}



.tp_art .days {
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem;
    color: var(--red);
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
}

.tp_art .days .genre,
.tp_art .days .place {
    border: 1px solid var(--red);
    border-radius: 4px;
    padding: 0.05rem 0.15rem;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
}

.tp_art .days .genre {
    background: var(--red);
    color: #ffffff;

}

@media (max-width: 768px) {
    .tp_art .days {
        font-size: 13px;
        gap: 0.2rem;
    }
    .tp_art .days .genre,
.tp_art .days .place {
    font-size: 11px;
}
}


.tp_art p {
    font-size: 22px;
    font-weight: 500;
    line-height: 1.22;
    letter-spacing: 0.01em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    width: 260px;
    transition-duration: 300ms;
}

.tp_art:hover p {
    color: var(--red);
    transition-duration: 300ms;
}


/* SP only */
@media (max-width: 768px) {

    .tp_art p {
        font-size: 1.05rem;
        width: 100%;
    }
}


.topics_side {
    width: 372px;
    min-height: 8rem;
}
@media (max-width: 768px) {
    .topics_side {
        width: 100%;
    }    
}

a.insta_link {
    gap: 0.5rem;
    font-size: 22px;
    font-weight: 500;
    align-items: center;
    margin-bottom: 1.5rem;
}

a.insta_link img {
    width: 32.474px;
    height: 32.759px;
}




/* footer */
footer {
    background: var(--red);
    border-radius: 80px 80px 0 0;
}

/* SP */
@media (max-width: 768px) {
footer {
    border-radius: 2.5rem 2.5rem 0 0;
}
}

.ft_top {
    width: 90%;
    padding-top: 4rem;
    padding-bottom: 4rem;
    color: #ffffff;
}


/* SP */
@media (max-width: 768px) {
    .ft_top {
    padding-top: 4rem;
    padding-bottom: 3rem;
    }
}


.ft_top .logo_area {
    margin-bottom: 3rem;
}
/* SP */
@media (max-width: 768px) {
    .ft_top .logo_area {
        text-align: center;
        margin: 0 auto 3rem;
    }
}

.ft_top .ft_menu {
    margin-bottom: 3rem;
}

.ft_top .ft_menu a {
    color: #ffffff;
    font-size: 24px;
    font-weight: 400;
    gap: 10px;
    margin-bottom: 1.5rem;
    width: fit-content;
}

.ft_top .ft_menu a:hover {
    opacity: 0.7;
}

.ft_top a img {
    width: 30px;
    height: auto;
}


.brand_list {

}

.brand_list span {
    font-size: 1.1rem;
    gap: 0.5rem;
    color: #ffffff;
    margin-bottom: 1rem;
}
.brand_list span img {
    width: 21px;
    height: auto;
}

.brand_list ul {
    gap: 1rem;
    flex-wrap: wrap;

}

.brand_list ul li {
    width: 200px;
    height: 104px;
    border-radius: 12px;
}


.brand_list ul li a {
    display: flex;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    background: #ffffff;
    border-radius: 12px;
}

.brand_list ul li a:hover {
    opacity: 0.7;
}

.brand_list ul li a img {
    height: 82px;
    width: auto;
}

/* SP */
@media (max-width: 768px) {
    .brand_list ul li {
        width: calc(50% - 0.5rem);
        height: fit-content;
    }

    .brand_list ul li a {
        height: fit-content;
        padding: 0.5rem 0;
    }
    .brand_list ul li a img {
        width: 70%;
        height: auto;
    }


}



.ft_bottom {
    background: #ffffff;
    height: 250px;
    justify-content: center;
    align-items: center;
    color: var(--red);
}

/* SP */
@media (max-width: 768px) {
    .ft_bottom {
        height: fit-content;
        padding: 3rem 0 4rem;
    }
}

.ft_bottom p {
    font-size: 20px;
    font-weight: 500;
}

.ftlink {
    justify-content: center;
    gap: 0.5rem;
    margin: 1rem 0;
}

.ftlink a {
    color: var(--red);
    text-decoration: none;
    cursor: pointer;
    transition: opacity 0.2s;

    font-size: 20px;
    font-weight: 500;
}

.ftlink a:hover {
    opacity: 0.7;
}


/* モーダル */
/* オーバーレイのスタイル */
#overlay {
   position: fixed;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background: rgba(0, 0, 0, 0.5); /* 薄暗い背景 */
   opacity: 0;
   visibility: hidden;
   transition: opacity 0.3s, visibility 0.3s;
   z-index: 200;
 }
 
 /* モーダルウィンドウの基本スタイル */
 #modal1, #modal2 {
   position: fixed;
   bottom: -100%; /* 初期状態では画面外に */
   left: 50%;
   transform: translate(-50%, 0%); /* X軸方向に-50%移動して中央に配置 */
   background: white;
   width: 80vw;
   max-width: 800px;
   height: 80vh;
   overflow: auto;
   /* max-width: 400px; */
   padding: 20px;
   box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
   transition: bottom 0.3s;
   visibility: hidden;
   z-index: 9999999;
   transition: opacity 0.3s, transform 0.5s; 
 }
 
 /* モーダルウィンドウの表示スタイル */
 #modal1:not(.hidden),
 #modal2:not(.hidden) {
   top: 10vh; /* 画面の下から20%の位置に */
   transform: translate(-50%, 0%); /* Y軸の変化を削除 */
   visibility: visible;
 }
 
 #modal1.hidden,
#modal2.hidden {
  top: 100vh; /* 画面外の下部から開始 */
  opacity: 0;
  transform: translate(-50%, 100%); /* 初期位置を下に設定 */
}


 /* オーバーレイの表示スタイル */
 #overlay:not(.hidden) {
   opacity: 1;
   visibility: visible;
 }
 
 /* モーダルコンテンツ */
 .modal-content {
   text-align: center;
 }
 
 .modal-content p {
   /* white-space: pre-wrap; */
   
 }
 .modal-content p span {
   font-weight: bold;
 }

.modalClose {
   border: 0;
   font-size: 1.3rem;
   color: #ffffff;
   font-weight: bold;
   background: #C2191F;
   padding: 0.5rem 3rem;
   border-radius: 1.5rem;
}
