@charset "UTF-8";
/* CTAセクション：TECHNOCRAFT用 */
.c-section--cta-gradient-bg {
    position: relative;
    overflow: hidden;
    color: #3e2f2a;
    background: none !important;
}

/* ベース（ベージュグラデーション） */
.c-section--cta-gradient-bg::before {
    content: "";
    position: absolute;
    inset: -40%;
    background: linear-gradient(130deg, #f3ede4, #e8dfcf, #d8cbb5, #f3ede4);
    background-size: 400% 400%;
    animation: ctaGradientFlow 18s ease infinite;
    z-index: 0;
}

/* 光のニュアンス */
.c-section--cta-gradient-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(
            circle at 20% 30%,
            rgba(255, 255, 255, 0.5),
            transparent 60%
        ),
        radial-gradient(
            circle at 80% 70%,
            rgba(255, 255, 255, 0.25),
            transparent 60%
        );
    animation: ctaLightDrift 8s ease-in-out infinite alternate;
    z-index: 1;
    pointer-events: none;
}

/* コンテンツ前面 */
.c-section--cta-gradient-bg > .container {
    position: relative;
    z-index: 2;
}

/* 背景カラー */
.bg-gray {
    background-color: #cecece91;
}

/* テキスト */
.c-section--cta-gradient-bg h2 {
    color: #3e2f2a;
}

.c-section--cta-gradient-bg h3 {
    color: #6b5b52;
}

.c-section--cta-gradient-bg p {
    color: #3e2f2a;
}

/* ボタン */
a:hover {
    color: #5a3c37;
}

/* aboutコンテンツ枠 */
.p-about-flow {
    border: 2px solid rgba(0, 0, 0, 0.08) !important;
}
.p-about-card {
    border: 2px solid rgba(0, 0, 0, 0.08) !important;
}
.p-about-equip,
.p-about-mini {
    border: 2px solid rgba(0, 0, 0, 0.08) !important;
}

/* frowコンテンツ */
.p-about-flow {
    padding: 28px 18px;
    background: #fff;
    border: 2px solid rgba(0, 0, 0, 0.08);
    border-radius: 24px;
}

/* アニメーション */
@keyframes ctaGradientFlow {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

@keyframes ctaLightDrift {
    0% {
        transform: translate(-20px, -10px);
    }
    100% {
        transform: translate(20px, 10px);
    }
}
/* トップページ */
.rotate3d .center {
    background-color: #21252978;
}
/* スマホ（基本） */
.rotate3d .en {
    font-size: 3rem;
}
.u-font-kc {
    color: #ff6010;
}
.c-visual-sub .c-visual-sub__ttl:before {
    color: #ff6010;
}
.c-headline-leftbig .c-headline-leftbig__sttl {
    color: #ff6010;
}
.g-hamburger .g-hamburger__body .list .nav-link:after {
    color: #5a3c37;
}
/* PC（992px以上） */
@media screen and (min-width: 992px) {
    .rotate3d .en {
        font-size: 4rem;
    }
}
.p-common-artist article:first-child {
    transform: translateY(0px);
}
.p-common-artist article:last-child {
    transform: translateY(-10px);
}
.g-header .g-header__nav-btn {
    background-color: #ff6010;
}
.g-header .g-header__resv {
    background-color: #5a3c37;
}
.g-header .g-header__nav {
    background-color: #ff6010;
}
.g-nav .g-nav__list .nav-link:hover {
    color: #ff6010;
}
.g-nav .g-nav__list .nav-link:before {
    background: linear-gradient(#ff6010, #ff6010) right bottom / 0 1px no-repeat;
}
.g-fixarea .g-fixarea-footer .g-fixarea-footer__item {
    background-color: #ff6010;
}
.g-fixarea .contact--1 {
    background-color: #ff6010;
}
.g-fixarea .contact--2 {
    background-color: #5a3c37;
}
.g-pagetop a {
    background: #ff6010;
}
.p-common-news .p-common-news__ttl:before {
    color: #ff6010;
}
.c-image .c-image__caption {
    background-color: #ff6010;
}
.l-aside h3 {
    background-color: #ff6010;
}
.u-font-sc {
    color: #ff6010;
}
@media screen and (min-width: 992px) {
    .p-common-menu.--02 {
        max-width: 60px;
        top: 550px;
        left: -50px;
    }
}
@media screen and (min-width: 992px) {
    .p-common-menu.--04 {
        max-width: 40px;
        top: 1040px;
        left: 1400px;
    }
}

/* こだわりコンテンツ */
.commitment {
    padding: 80px 20px;
    background-color: #ffffff; /* 外側のうっすらした背景 */
    font-family:
        "Noto Sans JP", "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
}

.commitment__inner {
    max-width: 1080px;
    margin: 0 auto;
    background-color: #fff2ec;
    padding: 64px 40px;
    border-radius: 8px;
}

/* ---- 見出し ---- */
.commitment__label {
    letter-spacing: 0.25em;
    color: #5f5e5a;
}

/* ---- 3カラムリスト ---- */
.commitment__list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}

.commitment__item {
    padding: 8px 24px;
    border-right: 1px solid #e5e4dd;
}

.commitment__item:last-child {
    border-right: none;
}

/* ---- 数字(セリフ体) ---- */
.commitment__number {
    line-height: 1;
}

/* ---- 英字ラベル ---- */
.commitment__en {
    font-size: 12px;
    letter-spacing: 0.25em;
    color: #888780;
    margin: 0 0 16px;
}

/* ---- 日本語見出し ---- */
.commitment__name {
    font-size: 18px;
    font-weight: 500;
    margin: 0 0 14px;
    line-height: 1.5;
    letter-spacing: 0.05em;
}

/* ---- 説明文 ---- */
.commitment__desc {
    font-size: 13px;
    color: #5f5e5a;
}

/* =========================================
   タブレット(768px以下)
   ========================================= */
@media screen and (max-width: 768px) {
    .commitment {
        padding: 56px 16px;
    }

    .commitment__inner {
        padding: 48px 24px;
    }

    .commitment__list {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .commitment__item {
        border-right: none;
        border-bottom: 1px solid #e5e4dd;
        padding: 32px 16px;
    }

    .commitment__item:last-child {
        border-bottom: none;
    }

    .commitment__number {
        font-size: 48px;
    }

    .commitment__name br {
        display: none; /* スマホでは1行にしてバランスを取る */
    }

    .commitment__desc {
        text-align: center;
        max-width: 360px;
        margin: 0 auto;
    }
}

/* =========================================
   スマートフォン(480px以下)
   ========================================= */
@media screen and (max-width: 480px) {
    .commitment__title {
        font-size: 22px;
    }

    .commitment__number {
        font-size: 42px;
    }

    .commitment__name {
        font-size: 16px;
    }
    /* aboutコンテンツpadding */
    .p-about-card,
    .p-about-equip,
    .p-about-mini,
    .p-about-flow {
        padding: 12px !important;
    }
}

/* 事業内容タグ */
.service-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    /* リストのデフォルトスタイルをリセット */
    list-style: none;
}

.service-tags .tag {
    display: inline-block;
    font-size: 13px;
    line-height: 1;
    padding: 8px 16px;
    border-radius: 999px;
    color: #2c2c2a;
    background: #fff2ec;
    white-space: nowrap;
}

/* シーン別レイアウト */
.hero {
    border-radius: 12px;
    padding: 56px 32px;
    text-align: center;
}

/* テーマカラー */
.theme-family .hero {
    background: #5a3c37;
    color: #633806;
}

/* シーンタイル 2×2 */
.scenes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}
.scene {
    background: #f5f3ee;
    border-radius: 8px;
    padding: 16px;
}
.scene__icon {
    color: #666;
}
.scene__desc {
    color: #666;
}

/* スマホ */
@media (max-width: 480px) {
    .hero {
        padding: 40px 20px;
    }
    .scenes {
        grid-template-columns: 1fr;
    }
}

/* スライダー：枠は「非クローンの現在スライド」1枚のみに限定 */
/* 既存の slick-center ベースの枠を全て無効化 */
.c-slider__thum .slick-slide .c-image {
    outline: 0 !important;
    outline-offset: 0 !important;
}
/* 非クローンの現在スライドだけに枠と通常不透明度を適用 */
.c-slider__thum .slick-slide.slick-current:not(.slick-cloned) .c-image {
    outline: 5px solid var(--kc) !important;
    outline-offset: -5px !important;
}
.c-slider__thum .slick-slide.slick-current:not(.slick-cloned) {
    opacity: 1 !important;
}

/* スライダー：全サムネが収まるとき中央寄せ・矢印非表示 */
@media (min-width: 768px) {
    .c-slider__thum.c-slider__thum--fit-pc .slick-list {
        padding: 0 !important;
    }
    .c-slider__thum.c-slider__thum--fit-pc .slick-track {
        margin: 0 auto !important;
        transform: none !important;
    }
    .c-slider__thum.c-slider__thum--fit-pc .c-slider__arrow {
        display: none !important;
    }
}
@media (max-width: 767.98px) {
    .c-slider__thum.c-slider__thum--fit-sp .slick-list {
        padding: 0 !important;
    }
    .c-slider__thum.c-slider__thum--fit-sp .slick-track {
        margin: 0 auto !important;
        transform: none !important;
    }
    .c-slider__thum.c-slider__thum--fit-sp .c-slider__arrow {
        display: none !important;
    }
}
