/* ===================================================
   LOCAFT Website - Custom Styles
   =================================================== */

/* ホバー時の斜めスライド背景エフェクト */
.hover-slide-bg {
    position: relative;
    overflow: hidden;
    transition: all 0.4s ease;
    z-index: 1;
}

.hover-slide-bg::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background-color: currentColor;
    transform: skewX(-20deg);
    transform-origin: left;
    transition: left 0.4s ease;
    z-index: -1;
    opacity: 0.1;
}

.hover-slide-bg:hover::before {
    left: 0;
}

/* カード内の二重線装飾 */
.double-border-inner {
    position: relative;
    border: 1px solid #e7e5e4; /* stone-200 */
}

.double-border-inner::after {
    content: "";
    position: absolute;
    top: 4px;
    left: 4px;
    right: 4px;
    bottom: 4px;
    border: 1px solid #e7e5e4;
    pointer-events: none;
}

/* TOP画像のズーム＆パンアニメーション (Ken Burns Effect) */
@keyframes ken-burns {
    0% {
        transform: scale(1) translate(0, 0);
    }
    100% {
        transform: scale(1.1) translate(-2%, -1%);
    }
}

.animate-ken-burns {
    animation: ken-burns 25s ease-in-out infinite alternate;
}

/* Perspectives画像のフィルター - サイトの雰囲気に合わせたくすんだ風合い */
.perspectives-filter {
    filter: sepia(30%) saturate(60%) contrast(85%) brightness(90%) grayscale(15%);
    transition: filter 0.7s ease;
}

.perspectives-filter:hover {
    filter: sepia(15%) saturate(75%) contrast(90%) brightness(95%) grayscale(5%);
}

/* 縦書きテキスト */
.writing-vertical-rl {
    writing-mode: vertical-rl;
    text-orientation: mixed;
}

/* ロゴの浮遊アニメーション */
@keyframes floating {
    0% {
        transform: translateY(0px);
    }
    50% {
        transform: translateY(-15px);
    }
    100% {
        transform: translateY(0px);
    }
}

.animate-floating {
    animation: floating 3s ease-in-out infinite;
}

/* スクロールバー非表示（横スクロールエリア用） */
.no-scrollbar::-webkit-scrollbar {
    display: none;
}

.no-scrollbar {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

/* フェードインアニメーション */
.fade-in-section {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fade-in-section.is-visible {
    opacity: 1;
    transform: none;
}

/* スクロール指示線のドロップアニメーション */
@keyframes drop {
    0% {
        top: -50%;
    }
    100% {
        top: 100%;
    }
}

/* スクロール指示線の右スライドアニメーション */
@keyframes slideRight {
    0% {
        left: -100%;
    }
    100% {
        left: 100%;
    }
}

/* アニメーション用ユーティリティクラス */
.animate-drop {
    animation: drop 1.5s infinite;
}

.animate-slide-right {
    animation: slideRight 1.5s infinite;
}

/* ゆっくりとした点滅アニメーション */
@keyframes pulse-slow {
    0%, 100% {
        opacity: 0.9;
    }
    50% {
        opacity: 0.4;
    }
}

.animate-pulse-slow {
    animation: pulse-slow 3s ease-in-out infinite;
}

/* モノクロ→カラー変換（スクロール連動） */
.bw-to-color {
    filter: grayscale(100%) brightness(95%);
    transition: filter 1.5s ease-out;
}

.bw-to-color.is-colored {
    filter: grayscale(0%) brightness(100%);
}
