@charset "UTF-8"; 

:root {
    --red: #ED0303;
    --pink: #F8F2F2;
    --black: #100F10;
    --orange: #FF4E00;
    --white: #ffffff;
    --blue: #215888;
    --ja: "Noto Sans JP", sans-serif;
    --en: "Josefin Sans", sans-serif;
}


body.top .header__logo,
body.top .header__tel {
    opacity: 0;visibility: hidden;
}

body.top.no-scroll .header__logo,
body.top.no-scroll .header__tel,
body.top .scrolled .header__logo,
body.top .scrolled .header__tel{
opacity: 1;visibility: visible;
}

/* ---  メインビジュアル  --- */
.sec-mainv {
    position: relative;
    width: 100%;
    height: 90vh; 
    overflow: hidden;
    background: var(--pink);
}

.sec-mainv::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 7%;
    width: clamp(100px, 18vw, 200px);
    aspect-ratio: 5 / 1;
    background: #fff;
    clip-path: polygon(20% 0, 80% 0, 100% 100%, 0 100%);
    z-index: 1;
}

.sec-mainv::before {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    width: 70%;
    height: 50%;
    background: url('../img/main1.jpg') no-repeat center/cover;
}

.sec-mainv__left {
    position: absolute;
    top: 0;
    left: 0;
    width: 55vw;
    height: 75vh;
    clip-path: polygon(00% 0, 100% 0, 70% 100%, 0 100%);
    z-index: 2;
    background: linear-gradient(to bottom, #FF4E00, #ED0303);
}

.sec-mainv__en--l {
    position: absolute;
    top: 18%;
    left: 10%;
    color: #fff;
    font-size: clamp(5rem, 3.7rem + 4vw, 9rem);
    text-align: left;
    line-height: 1.2; 
    font-family: var(--en);
    font-weight: 300;
}

.sec-mainv__en--s {
    font-size: 0.7em; 
    display: block; 
}

.sec-mainv__left--white {
    position: absolute;
    top: calc(18% + 145px + 6.5vw);
    background: white;
    clip-path: polygon(0 0, 100% 0, 88% 100%, 0 100%);
    padding: 30px 20% 30px;
    line-height: 1.2;
}

.sec-mainv__left--white::before {
    content: ''; 
    position: absolute;
    top: -1px; 
    left: 6%; 
    width: 15%; 
    min-width: 60px;
    aspect-ratio: 3 / 1;
    background: #F82E02; 
    clip-path: polygon(0 0, 100% 0, 80% 100%, 20% 100%);
    z-index: 3;
}

.sec-mainv__left--white h1 {
    font-size: min(calc(1.2rem + 1.8vw),3rem);
}

.sec-mainv__left--s { 
    font-size: 0.8em;
}

.sec-mainv__left--l {
    font-size: 1.3em;
}

.sec-mainv__left--s,
.sec-mainv__left--l {
    color: var(--red);
}

.sec-mainv__right {
    content: '';
    position: absolute;
    bottom: 0;
    right: 0;
    width: 55vw;
    height: 70vh;
    background: white;
    clip-path: polygon(30% 0, 100% 0, 100% 100%, 0 100%);
    z-index: 4; 
}

.sec-mainv__right--img {
    position: relative;
    width: 100%;
    height: 100%;
}

.clip-image {
    position: absolute;
    bottom: 0;
    right: 0;
    width: calc(100% - 3vw);
    height: calc(100% - 3vw);
    clip-path: polygon(30% 0, 100% 0, 100% 100%, 0 100%);
    object-fit: cover;
}
/* ---  レスポンシブ --- */
@media (max-width: 768px) {
    .sec-mainv__left {
        width: 100%;
    }
    
    .sec-mainv__left--white {
        width: 100%;
    }
    
    .sec-mainv__right {
        height: 50vh;
    }
}
/* ---  レスポンシブ  --- */
/* ---  メインビジュアル  --- */

/* ---  日本を代表する京都セクション  --- */
.sec-kyoto {
    padding-top: 12em;
    padding-bottom: 11em;
    background: linear-gradient(#ffffff, #ffd6d6);
    overflow: hidden;
}

.sec-kyoto__wrapper {
    position: relative;
    width: 100%;
    overflow: hidden; /* ←スライドアニメがはみ出さないように */
}

.sec-kyoto__wrapper::before, 
.sec-kyoto__wrapper::after {
    content: "";
    position: absolute;
    width: 30vw;  
    height: 40vh; 
    background-size: contain;
    background-repeat: no-repeat;
    z-index: 1;
    opacity: 0;
    transition: transform 1.4s cubic-bezier(0.23, 1, 0.32, 1), 
                opacity 1.4s cubic-bezier(0.23, 1, 0.32, 1);
}

/* 雲（左側） */
.sec-kyoto__wrapper::before {
    background-image: url('../img/deco_left.svg');
    top: 20%;
    left: -3%; 
    transform: translateX(-100px); /*  左 → 右に入ってくる */
    transition-delay: 0s; /*  最初は遅延なし（後でJSでクラス付与後に効く） */
}

/* 雲（右側） */
.sec-kyoto__wrapper::after {
    background-image: url('../img/deco_right.svg');
    top: 20%;
    right: -3%; 
    transform: translateX(80px); /*  右 → 左に入ってくる */
    transition-delay: 0s;
}

.sec-kyoto__ttl {
    font-size: min(calc(2.5rem + 1.8vw), 4.5rem);
    font-weight: 400;
    color: #8E2323;
    margin-bottom: 1.6em;
    text-align: center; 
    text-indent: 0.5em;
    font-family: serif;
    opacity: 0;
    transform: translateY(50px); 
    transition: opacity 1.2s cubic-bezier(0.23, 1, 0.32, 1),
                transform 1.2s cubic-bezier(0.23, 1, 0.32, 1);
}

.sec-kyoto__text{
    position: relative;
    height: 40vh;
    min-height: 350px;
    margin: 0 auto 12em; 
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: clamp(1.4rem,calc(1rem + 1.4vw), 2rem);
    line-height: 2.5;
    font-weight: 300;
    white-space: normal;
    color: var(--black);
    z-index: 2;
    opacity: 0; /* ← 初期非表示 */
    transform: translateY(50px);
    transition: opacity 1.2s cubic-bezier(0.23, 1, 0.32, 1),
                transform 1.2s cubic-bezier(0.23, 1, 0.32, 1);
}

/* --------------------
    表示時に発火するクラス
-------------------- */
.sec-kyoto.js-animate .sec-kyoto__ttl,
.sec-kyoto.js-animate .sec-kyoto__text {
    opacity: 1;
    transform: translateY(0);
}

.sec-kyoto.js-animate .sec-kyoto__wrapper::before,
.sec-kyoto.js-animate .sec-kyoto__wrapper::after {
    opacity: 1;
    transform: translateX(0);
    transition-delay: 0.2s; /* タイトル＆テキストのあと */
}

.sec-kyoto.js-animate .sec-kyoto__wrapper::after {
    opacity: 1;
    transform: translateX(0);
    transition-delay: 0.6s; /* 左雲のさらにあと */
}

/* ---  レスポンシブ  --- */
@media (max-width: 600px) {
    .sec-kyoto__wrapper::before, 
    .sec-kyoto__wrapper::after {
        width: 50vw;  
        height: 50vh; 
    }

    .sec-kyoto__wrapper::before {
        top: 50%;
        left: -27%; 
    }

    .sec-kyoto__wrapper::after {
        top: -20%;
        right: -33%; 
    }
}  
/* ---  レスポンシブ  --- */
/* ---  日本を代表する京都セクション  --- */

/* ---  LINEUPセクション  --- */
.sec-lineup {
    width: 80%;
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
}

.sec-lineup__ttl,
.sec-pickup__ttl {
    font-family: var(--en);
    font-weight: 200;
    font-size: min(calc(4rem + 2.8vw), 6.9rem);
    line-height: 1.2;
    color: #ED0303;
    text-align: center;
}

.sec-lineup__subttl {
    font-size: min(calc(1.2rem + 1.4vw), 2.2rem);
    font-weight: 700;
    color: var(--black);
    margin-bottom: 3em;
    text-align: center;
}

.sec-lineup__list {
    display: grid;
    grid-template-columns: repeat(3, minmax(260px, 1fr));
    gap: 3vw;
}

.sec-lineup__item--a {
    position: relative;
    z-index: 0;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 100%;
    padding: 1.8rem 2.5rem;
    border-radius: 9999px;
    border-left: 5px solid #5397db;
    background: #fff;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2);
    transition: box-shadow 0.3s ease, color 0.3s ease, transform 0.3s ease; 
}

.sec-lineup__item--a::before {
    content: '';
    position: absolute;
    top: 0;
    left: -130%;
    width: 120%;
    height: 100%;
    background: #5397db;
    transform: skewX(-25deg);
    z-index: -1;
}

.sec-lineup__item--a:hover {
    box-shadow: 4px 4px 20px rgba(0, 0, 0, 0.3);
    transform: scale(1.05);
}

.sec-lineup__item--a:hover::before {
    animation: skewanime 0.5s forwards;
}

@keyframes skewanime {
    100% {
        left: -10%;
    }
}

.sec-lineup__item--a:hover .sec-lineup--text {
    color: #fff;
}


.sec-lineup--text,
.icon {
    position: relative;
    z-index: 1;
}

.sec-lineup--text {
    font-size: min(calc(1rem + 1.5vw), 2.4rem);
    font-weight: 500;
    text-align: center;
}

.icon {
    width: 5.5rem;
    height: 5.5rem;
    border-radius: 50%;
    object-fit: cover;
}


.icon.icon-kyotometro {
    object-position: 0% center;
}

.icon.icon-shinkansen {
    object-position: 30% center;
}

.icon.icon-jr-west {
    object-position: 20% center;
}

.icon.icon-hankyu {
    object-position: 90% center;
}

.icon.icon-keihan {
    object-position: 60% center;
}

.icon.icon-kintetsu {
    object-position: 100% center;
}


/* ---  レスポンシブ  --- */
@media (max-width: 960px) {
    .sec-lineup__list {
        grid-template-columns: repeat(2, minmax(250px, 1fr)); /* 2列 */
        /* grid-template-rows: repeat(3,1fr); */
        gap: 3vw;
    }
    .lineup-item {
        min-width: 250px; 
    }
}

/* スマホ用 */
@media (max-width: 600px) {
    .sec-lineup__list {
        grid-template-columns: repeat(1, minmax(250px, 1fr)); /* 1列 */
        gap: 4vw;
        place-items: center;
    }

    .sec-lineup__item {
        min-width: 250px;
    }

    .sec-lineup__item--a:hover {
        box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2); 
        transform: none; 
    }

    .sec-lineup__item--a:hover::before {
        animation: none; 
    }

    .sec-lineup__item--a:hover .sec-lineup--text {
        color: inherit; 
    }
} 
/* ---  レスポンシブ  --- */
/* ---  LINEUPセクション  --- */

/* ---  PICKUPセクション  --- */
.sec-pickup {
    padding: 8em 0;
    background: #F8F2F2;
    text-align: center;
    overflow: visible; 
}

.swiper-top {
    overflow: hidden;
    margin-top: 3em;
}

.swiper-wrapper {
    transition-timing-function: linear;
    padding: 0 0 2rem;
}

.pickup-item {
    width: 100%;
    position: relative;
    display: flex;
    min-height: 400px;
    margin-top: 2em;
    background: #FFF;
    border-radius: 70px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
    transition: transform 0.5s ease, opacity 0.5s ease;
    opacity: 0.5;
    transform: scale(0.8);
    /* overflow: hidden; ← 不要！これがあると ::after が隠れる */
}

/* 中央スライドを拡大＆強調 */
.swiper-slide-active .pickup-item {
    transform: scale(1);
    opacity: 1;
    z-index: 2;
}

.pickup-image {
    width: 40%;
    position: relative;
}

/* ★ 画像の枠を制御する内ラッパー */
.pickup-img-inner {
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: 70px 0 0 70px; /* ここで画像の角丸も適用 */
}

/* ★ 実際にズームするのはこの img */
.pickup-img-inner img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform 0.5s ease;
}

/* ★ここで画像を拡大（img の位置を修正） */
.pickup-item:hover .pickup-img-inner img {
    transform: scale(1.1);
}

/* リボン装飾 */
.pickup-image::after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    width: 30%;
    height: 20px;
    transform: translate(-50%, -99%);
    background: var(--red);
    clip-path: polygon(20% 0%, 80% 0%, 100% 100%, 0% 100%);
    z-index: 1;
}


.pickup-info {
    width: 60%;
    padding: 1.5em 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pickup-info table {
    width: 80%;
    border-collapse: collapse;
    text-align: left;
}

.pickup-info th {
    width: 30%; 
    padding: 1.8em 0 0.5em;
    color: var(--red);
    font-weight: 400;
    font-size: min(calc(1rem + 1.2vw), 1.8rem);
    text-align: left;
    white-space: nowrap;
}

.pickup-info td {
    width: 70%; 
    padding: 1.8em 0 0.5em;
    color: #333;
    font-weight: 300;
    font-size: min(calc(1.1rem + 1.3vw), 2.0rem);
}

.pickup-info tr {
    border-bottom: 1px dotted #707070;
}

.pickup-info tr:last-child {
    border-bottom: none;
}

/* レスポンシブ対応 */
@media (max-width:600px) {
    .sec-pickup {
        width: 80%;
        margin: 0 auto;
    }

    .pickup-item {
        flex-direction: column;
    }

    .pickup-image {
        width: 100%;
    }

    .pickup-img-inner {
        border-radius: 70px 70px 0 0; 
    }

    .pickup-info {
        width: 100%;
    }
}
/* ---  PICKUPセクション  --- */

/* ---  各電鉄の主要駅  --- */
.sec-mainsta {
    margin-bottom: 11em;
}

.sec-mainsta__wrapper {
    position: relative;
    width: 90%;
    height: auto;
    margin: 0 auto;
    padding: 5em;
    border-radius: 35px;
    background-color: #fff;
    text-align: center;
}

.sec-mainsta__wrapper::before {
    position: absolute;
    content: "";
    top: 0;
    left: calc(6% + 2vw); 
    width: max(10vw, 120px); 
    aspect-ratio: 4 / 1;
    background-color: var(--pink);
    clip-path: polygon(0 0, 100% 0, 90% 100%, 10% 100%);
}

.sec-mainsta__li {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    justify-content: space-between;
    gap: 3rem;
}

.sec-mainsta__ttl {
    grid-column: span 2;
    border: solid 1px var(--red);
    border-radius: 120px;
    text-align: center;
    width: 90%;
    margin: auto;
    padding: 1.8em 0;
    line-height: 1.2;
}

.sec-mainsta__ttl h2 {
    font-size: min(calc(1.4rem + 1.5vw), 2.4rem);
    font-weight: 400;
}

.sec-mainsta__ttl span {
    font-size: min(calc(1rem + 1vw), 1.8rem);
    color: var(--red);
}

/* 主要駅ボタン */
.sec-mainsta__item_a {
    display: flex; 
    flex-direction: column;
    justify-content: center; 
    align-items: center;
    aspect-ratio: 230 / 130;
    border-top: 3px solid var(--red);
    border-radius: 20px;
    background-color: var(--pink);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.sec-mainsta__item_a:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); 
}

.sec-mainsta__item_a p {
    font-size: min(calc(0.8rem + 1.2vw), 1.6rem);
    font-weight: 400;
}
.sec-mainsta__item_a h3 {
    font-size: min(calc(1rem + 1.5vw), 2.08rem);
    font-weight: 600;
}

/* ---  レスポンシブ  --- */
@media (max-width: 960px) {
    .sec-mainsta__ttl {
        width: 100%;
        padding: 1.4em 0;
    }
    .sec-mainsta__li {
        grid-template-columns: repeat(2, 1fr); 
    }
}
@media(max-width:600px) {
    .sec-mainsta__wrapper {
        padding: 5rem 3rem;
    }
    .sec-mainsta__li {
        grid-template-columns: repeat(2, 1fr); 
    }

    .sec-mainsta__item_a:hover {
        transform: none;        
        box-shadow: none;       
    }
}
/* ---  レスポンシブ  --- */
/* ---  各電鉄の主要駅  --- */


/* ---  MEDIA Search  --- */
.sec-medsrch {
    margin-bottom: 11em;
}

.sec-medsrch_ttl {
    font-family: var(--en);
    font-weight: 400;
    font-size: min(calc(3.6rem + 2.4vw), 6.3rem);
    line-height: 1.2;
    text-align: center;
    background: linear-gradient(45deg, #36B4D2 20%, #29489B 40%, #74C368 70%);
            -webkit-background-clip: text;
            background-clip: text;
            -webkit-text-fill-color: transparent;
}

.sec-medsrch__subttl {
    font-size: min(calc(1.2rem + 1.4vw), 2.2rem);
    font-weight: 700;
    color: var(--black);
    margin-bottom: 3em;
    text-align: center;
}

.sec-medsrch__list {
    display: flex;
    justify-content: space-between;
    width: 90%;
    margin: 0 auto;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.sec-medsrch__item {
    width: 30%;
}

/* .sec-medsrch__img {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    object-fit: cover;
    align-items: center;
    text-align: center;
    width: 100%;

}

.sec-medsrch__img img {
    width: 100%;
    height: auto;
    transition: transform 0.4s ease;
} */

.sec-medsrch__img {
    position: relative;
    overflow: hidden; 
    width: 100%;
    height: 340px; 
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.sec-medsrch__img img {
    width: 100%;
    height: 100%; /* ★ 枠いっぱいに広げる */
    object-fit: cover; /* ★ 縦横比を崩さずトリミング */
    transition: transform 0.4s ease; /* hoverエフェクト用（必要なら） */
}

/* ホバー時に画像を拡大 */
.sec-medsrch__item:hover .sec-medsrch__img img{
    transform: scale(1.1); 
}


.sec-medsrch__cap {
    position: absolute;
    bottom: 0;
    background-color: white;
    padding:1.3em 1em 1em;
    width: 100%;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
}

/* 白い台形 */
.sec-medsrch__cap::after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    width: clamp(40px, 10vw, 100px);
    aspect-ratio: 5 / 1;
    background-color: #FFF;
    clip-path: polygon(10% 0, 90% 0, 100% 100%, 0% 100%);
    transform: translate(-50%, calc(-100% + 1px));
}

.sec-medsrch__item-ttl {
    font-size: min(calc(1.4rem + 1.3vw), 2.0rem);
    font-weight: 400;
    line-height: 1;
}

.sec-medsrch__item-subttl {
    font-family: var(--en);
    font-size: min(calc(1rem + 0.8vw), 1.6rem);
    font-weight: 300;
    color: #C3C3C3;
}

.sec-medsrch__text {
    padding: 1.9em 1.1em;
    font-weight: 400;
    line-height: 1.8;
}
/* ---  レスポンシブ  --- */
@media (max-width: 1100px) {
    .sec-medsrch__list {
        width: 70%;
        gap: 8rem;
    }
    .sec-medsrch__img {
        flex-wrap: wrap;
    }
    .sec-medsrch__img::after {
        width: clamp(80px, 25vw, 200px);
    }
    .sec-medsrch__item {
        width: 100%;
    }
}
@media (max-width: 600px) {
    .sec-medsrch__list {
        width: 90%;
    }

    .sec-medsrch__item:hover .sec-medsrch__img img {
        transform: none; 
    }
}
/* ---  レスポンシブ  --- */
/* ---  MEDIA Search  --- */

/* ---  NEWS  --- */
.sec-news {
    position: relative;
    min-height: 60vh;
    display: flex;
    align-items: center; 
    background-color: #215888;
    overflow: hidden;
}

.sec-news::before {
    content: "";
    position: absolute;
    top: 0;
    left: 27%;
    width: 25vw;
    height: 100%;
    background-color: #F8F2F2;
    clip-path: polygon(80% 0%, 100% 0%, 20% 100%, 0% 100%);
    transform: translateX(0);
    z-index: 0;
}

.sec-news__container {
    display: grid;
    width: 100%;
    grid-template-columns: minmax(200px, 25vw) minmax(400px, 50vw); 
    justify-content: space-between;
    align-items: center;
    gap: clamp(20px, 3vw, 60px);
    position: relative;
}

.sec-news__ttlbtn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.sec-news__ttl {
    font-family: var(--en);
    font-weight: 300;
    color: #ffffff;
    font-size: min(calc(4rem + 2.8vw), 6.9rem);
    line-height: 1.2;
    text-align: center;
}

.sec-news__btn,
.sec-blog__btn {
    background-color: var(--black);
    color: #fff !important;
    border: none;
    margin-top: 1em;
    padding: 10px 40px;
    border-radius: 40px;
    cursor: pointer;
    font-size: min(calc(1.1rem + 1.3vw), 2.0rem);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.sec-news__btn:hover,
.sec-blog__btn:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    background-color: var(--white);
    color: var(--black) !important;
}

.sec-news__list {
    display: grid;
    grid-template-columns: 1fr; 
    gap: 15px;
    padding: 5vh 5vw 5vh 0; 
    max-width: 100%;
}

.sec-news__link {
    display: block; 
    color: inherit;
}

.sec-news__link:hover {
    opacity: 0.7;
}


.sec-news__item {
    position: relative;
    color: #fff;
    padding: 10px;
}

/* 日付ホバー */
.sec-news__time {
    display: block;
    font-size: min(calc(1.2rem + 1.2vw), 1.8rem);
    font-family: "Josefin Sans", serif;
    font-weight: 300;
    line-height: 1.6em;
    color: var(--white);
}


/* 黄色の装飾 */
.sec-news__item::before {
    content: "";
    position: absolute;
    top: 20px;
    left: -15px;
    width: 15px;
    height: 2px;
    background: linear-gradient(
        to right,
        #DBC75A, 
        #F3F8AC,
        #B2A720, 
        #CCCC19, 
        #A29216  
    );
}

/* 階段状にずらす */
.sec-news__link:nth-child(1) .sec-news__item {
    transform: translateX(calc(25vw * 0.2)); /* `clip-path` の 20% に合わせる */
}
.sec-news__link:nth-child(2) .sec-news__item {
    transform: translateX(calc(25vw * 0.1)); /* 10% に合わせる */
}
.sec-news__link:nth-child(3) .sec-news__item {
    transform: translateX(0);
}

/* テキストホバー */
.sec-news__text {
    position: relative;
    display: inline-block;
    color: var(--white);
}



/* ---  レスポンシブ  --- */
@media (max-width: 960px) {
    .sec-news {
        min-height: 90vh;
    }
    .sec-news__container {
        grid-template-columns: 1fr; 
        gap: 30px;
    }

    .sec-news::before {
        display: none;
    }

    .sec-news__list {
        width: 65%;
        margin: 0 auto;
        padding: 3vh 0;
    }

    .sec-news__link:nth-child(1) .sec-news__item,
    .sec-news__link:nth-child(2) .sec-news__item,
    .sec-news__link:nth-child(3) .sec-news__item {
        transform: translateX(0);
    }
}
@media (max-width: 600px) {
    .sec-news__list {
        width: 80%;
    }

    .sec-news__link:hover {
        opacity: 1;
    }
}
/* ---  レスポンシブ  --- */
/* ---  NEWS  --- */

/* ---  OTHER SITE  --- */
.sec-other {
    position: relative;
    min-height: 70vh;
    display: flex;
    align-items: center; 
    background-color: #2C88B9;
}

.sec-other::before {
    content: "";
    position: absolute;
    top: 0;
    left: 2%;
    width: 25vw;
    height: 100%;
    background-color: #215888;
    clip-path: polygon(80% 0%, 100% 0%, 20% 100%, 0% 100%);
    transform: translateX(0);
    z-index: 0;
}

.sec-other__container {
    display: grid;
    grid-template-columns: 1fr 1fr; 
    align-items: center;
    gap: 2rem;
}

.sec-other__ttldiv {
    text-align: center;
    z-index: 1;
}

.sec-other__ttl {
    font-family: var(--en);
    font-weight: 300;
    color: #ffffff;
    font-size: min(calc(4rem + 2.8vw), 6.9rem);
    line-height: 1.2;
    text-align: center;
    color: #fff;
}

.sec-other__subttl {
    color: #ffffff;
    font-size: min(calc(1.1rem + 1.3vw), 2.0rem);
    font-weight: 500;
}

.sec-other__links {
    display: flex;
    gap: 2rem;
    overflow: hidden;
    overflow-x: scroll;
    padding: 1rem;
}

.sec-other__link {
    display: block;
    min-width: 290px;
    transition: transform 0.3s ease; /* ←追加 */
}

.sec-other__link:hover {
    transform: scale(1.05);
}

.sec-other__card {
    background-color: #fff;
    border-radius: 20px;
    text-align: center;
    overflow: hidden;
    position: relative;
    border: 1px solid var(--black);
    box-shadow: 5px 5px 0 0;
}

.sec-other__card img{
    display: block;
    width: 100%;
    object-fit: cover;
    border-radius: 15px;
    border: 2px solid var(--black);
    height: 230px;
}

.sec-other__cap {
    padding: 1.5rem;
    font-size: 1.4rem;
    font-weight: 700;
}

/* ---  レスポンシブ  --- */
@media (max-width: 960px) {
    .sec-other::before {
        display: none;
    }

    .sec-other__container {
        grid-template-columns: 1fr; /* スマホでは1列 */
    }

    .sec-other__links {
        width: 92.5%;
        margin: 0 auto;
    }
}

@media (max-width: 600px) {
    .sec-other {
        min-height: auto;
        padding: 8vh 0;
    }

    .sec-other__link:hover {
        transform: none;
    }
}
/* ---  レスポンシブ  --- */
/* ---  OTHER SITE  --- */

/* ---  BLOG  --- */
.sec-blog {
    position: relative;
    display: flex;
    align-items: center; 
    min-height: 70vh;
    background: linear-gradient(to bottom, #ED0303, #FF4E00);
}

.sec-blog::before {
    content: "";
    position: absolute;
    top: 0;
    left: 2%;
    width: 25vw;
    height: 100%;
    background-color: #fff;
    clip-path: polygon(0 0, 20% 0, 100% 100%, 80% 100%);
    transform: translateX(0);
    z-index: 0;
}

.sec-blog__container {
    width: 100%;
    display: grid;
    grid-template-columns: 2fr 1fr; 
    align-items: center;
}

.sec-blog__links {
    /* display: grid;
    grid-template-columns: repeat(3, minmax(250px, 1fr));  */
    display: flex;
    justify-content: center;
    gap: 1em;
}

.sec-blog__link {
    max-width: 280px;
    display: block;
    position: relative;
    min-height: 300px;
    background: #fff;
    border-radius: 15px;
    padding: 1.6rem;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.2);
    text-align: center;
    border: 1px solid var(--black);
    box-shadow: 5px 5px 0 0;
    transition: transform 0.3s ease; /* ←追加 */
}

/* ホバー */
.sec-blog__link:hover {
    transform: scale(1.08); 
}

/* 矢印 */
.sec-blog__link::after {
    content: "";
    position: absolute;
    right: 3rem;
    bottom: 1.2rem;
    width: 30%;
    height: 10px;
    border-bottom:1px solid red;
    border-right: 2px solid red;
    transform: skew(60deg);
}

.sec-blog__tag {
    display: block;
    background: var(--red);
    color: #fff;
    font-size: clamp(1.4rem, 2vw, 1.8rem); 
    white-space: nowrap; 
    padding: 0.5em 1.4em;
    text-align: center;
    border-radius: 10rem;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    border: 1px solid var(--black);
    box-shadow: inset 0 5px 0 black;
    top: 5px;
}

.sec-blog__img {
    width: 100%;
    aspect-ratio: 16 / 9; 
    overflow: hidden;
    display: block;
}

.sec-blog__img img {
    width: 100%;
    height: 100%;
    object-fit: cover; 
    display: block;
}

.sec-blog__content {
    margin: 0.6em 0 1.2em;
    display: flex;
    justify-content: flex-start;
    gap: 10px;
    align-items: flex-start;
    text-align: left;
}

.sec-blog__time {
    display: inline-block;
    font-size: min(calc(1.1rem + 1.3vw), 2.0rem);
    color: var(--black);
    writing-mode: vertical-lr;
    font-family: var(--en);
    font-weight: 200;
}

.sec-blog__text {
    font-size: min(calc(1rem + 0.8vw), 1.6rem);
    line-height: 1.8;
    color: var(--black);
}

.sec-blog__ttlbtn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.sec-blog__ttl {
    font-family: var(--en);
    font-weight: 300;
    color: #ffffff;
    font-size: min(calc(4rem + 2.8vw), 6.9rem);
    line-height: 1.2;
    text-align: center;
}

/* ---  レスポンシブ  --- */
@media (max-width: 960px) {
    .sec-blog {
        min-height: 85vh;
    }
    .sec-blog__container {
        display: flex;
        flex-direction: column-reverse;
        align-items: center;
        gap: 30px;
    }

    .sec-blog::before {
        display: none;
    }

    /* .sec-blog__links {
        width: 90%; 
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        display: flex;
        gap: 20px;
        padding-bottom: 25px; 
        -webkit-overflow-scrolling: touch; 
    }

    .sec-blog__link {
        min-width: 240px;
        flex: 0 0 clamp(90%, 20vw, 100%);
        max-width: clamp(270px, 25vw, 320px);
        scroll-snap-align: start; 
        padding-left: 0;
    } */

    .sec-blog__links {
        display: flex;
        justify-content: left;
        flex-wrap: nowrap;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 16px;
        padding: 10px 5% 25px; 
        width: 100%;
        box-sizing: border-box; 
    }

    .sec-blog__link {
        flex: 0 0 auto;
        width: 80%;
        max-width: 300px;
        min-width: 240px;
        scroll-snap-align: start;
    }
}

@media (max-width: 600px) {
    .sec-blog__link:hover {
        transform: none; 
    }
}
/* ---  レスポンシブ  --- */
/* ---  BLOG  --- */