/*==============================================================
/ 共通
/==============================================================*/
.single-solution .header {
    background-color: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(20px);
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1);
    transition: var(--transition);
}


.single-solution .container-m {
    max-width: 1062px;
    padding: 0 20px;
    margin: 0 auto;
}

.solution-title-jp {
    font-size: clamp(24px, 4vw, 32px);
    font-weight: 500;
    margin: clamp(40px, 10vw, 80px) 0 clamp(48px, 10vw, 80px);
}

/*==============================================================
/ Solution archive(TOP)
/==============================================================*/
.solution-section {
    padding: clamp(80px, 10vw, 160px) 0;
}

/* =========================================================
   Solution Hero
   ========================================================= */
.hero-solution {
    position: relative;
    top: -64px;
    margin-bottom: -64px;
    width: 100%;
    min-height: 320px;
    color: var(--color-white);
    overflow: hidden;
}

.hero-solution__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.hero-solution__bg-img {
    width: 100%;
    height: 100%;
}

.hero-solution__bg-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-solution__overlay {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    background: #00000066;
}

.hero-solution__inner {
    position: relative;
    width: 100%;
    z-index: 2;
}

.hero-solution__label {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: clamp(16px, 2vw, 24px);
    letter-spacing: 0.05em;
}

.hero-solution__label span:last-child {
    background-color: var(--color-bg-white);
}


.hero-solution__heading-wrap {
    padding: clamp(120px, 15vw, 220px) 0 clamp(48px, 15vw, 120px);
}

.hero-solution__heading {
    font-size: clamp(32px, 5vw, 40px);
    font-weight: 500;
    line-height: 1.4;
}

/* パンくずをヒーロー右下に配置（PC時） */
.hero-solution__breadcrumb {
    font-size: 12px;
    color: var(--color-white);
    opacity: 0.9;
    padding-bottom: clamp(63px, 10vw, 40px);
}

.hero-solution__breadcrumb li a {
    color: var(--color-white);
    text-decoration: underline;
}

.hero-solution__breadcrumb li.is-current span {
    text-decoration: none;
    color: var(--color-white) !important;

}

/* Hero Solution CTA */
.hero-solution-cta {
    --grad-a: #450101;
    --grad-b: var(--color-red);
    color: var(--color-white);
    background: linear-gradient(90deg, var(--grad-a) 0%, var(--grad-b) 100%);

}

.hero-solution-cta__inner {
    max-width: 1060px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 32px;
    align-items: center;
    padding: 40px 20px;
}

.hero-solution-cta__title {
    font-size: clamp(18px, 3vw, 20px);
    font-weight: 500;
    margin: 0 0 8px;
}

.hero-solution-cta__lead {
    margin: 0;
    font-size: 14px;
    line-height: 1.8;
}

.hero-solution-cta__action .cta-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 288px;
    border-radius: var(--radius-sm);
}

@media screen and (max-width: 767px) {
    .hero-solution-cta__inner {
        grid-template-columns: 1fr;
    }

    .hero-solution-cta__action .cta-btn {
        width: 100%;
    }
}

/*==============================================================
/  Solution Effort
/==============================================================*/
.solution-effort {
    padding: clamp(80px, 10vw, 100px) 0;
    background-color: #F5F7F8;
}


/* 2カラム */
.solution-effort__grid {
    display: grid;
    grid-template-columns: 1fr 520px;
    gap: clamp(32px, 10vw, 80px);
    align-items: start;
}

@media (max-width: 1024px) {
    .solution-effort__grid {
        grid-template-columns: 1fr;
    }
}

.solution-effort__media {
    border-radius: var(--radius-md);
    background-size: cover;
    background-position: center;
    min-height: 300px;
    height: 100%;
    width: 100%;
}

/* ISSUE / SOLUTION ブロック */
.effort-block+.effort-block {
    margin-top: clamp(32px, 10vw, 64px);
}

.effort-block__eyebrow {
    font-family: var(--font-latin);
    font-style: normal;
    font-weight: 500;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.05em;
    color: var(--color-text);
    margin-bottom: clamp(24px, 2vw, 20px);
}

.effort-block__eyebrow span {
    font-weight: 500;
    padding-right: 8px;
    display: inline-block;
    border-right: 1px solid #D9D9D9;
}

.effort-block__eyebrow em {
    font-style: normal;
    color: var(--color-red);
    font-weight: 500;
    padding-left: 8px;
}

.effort-block__heading {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8;
    margin: 0 0 10px;
}

.effort-block__body {
    margin: 0;
}

/* KPI circles */
.kpi-circles {
    margin: clamp(40px, 10vw, 80px) 0 clamp(10px, 10vw, 80px);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
@media (max-width: 900px) {
    grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 767px) {
    .kpi-circles {
        grid-template-columns: 1fr;
        gap: 20px;
    }
}

.kpi-circle {
    list-style: none;
    background: var(--color-white);
    border-radius: 50%;
    aspect-ratio: 1/1;
    /* box-shadow: 0 6px 20px rgba(0, 0, 0, .06); */
    display: grid;
    place-items: center;
}

@media (max-width: 767px) {
    .kpi-circle {
        width: clamp(295px, 70vw, 425px);
        margin: 0 auto;
    }
}

.kpi-circle__inner {
    text-align: center;
    width: 78%;
    margin: 0 auto;
}

@media (max-width: 767px) {
    .kpi-circle__inner {
        width: 66%;
    }
}


.kpi-circle__label {
    margin-bottom: clamp(16px, 2vw, 24px);
    font-size: clamp(14px, 1.2vw + 2px, 16px);
}

.kpi-circle__value {
    margin-bottom: 16px;
    font-weight: 500;
    line-height: 1;
    display: flex;
    justify-content: center;
    align-items: baseline;
    gap: 2px;
}

.kpi-circle__value .num {
    font-size: clamp(48px, 6vw, 80px);
    color: var(--color-red);
    letter-spacing: -0.05em;
    line-height: 80%;
    text-wrap: nowrap;
}

.kpi-circle__value .unit {
    font-size: clamp(18px, 2.5vw, 26px);
    text-wrap: nowrap;
}

.kpi-circle__img {
    width: auto;
    height: clamp(12px, 1.5vw, 16px);
    display: block;
    margin-inline: auto;
    margin-bottom: clamp(16px, 2vw, 24px);
}

.kpi-circle__note {
    font-size: clamp(12px, 1.2vw, 14px);
    line-height: normal;
    margin-bottom: 12px;
}

.kpi-circle__source {
    font-size: 12px;
    color: #1C1C1C;
}

/* スマートフォン表示用のフォントサイズ調整 */
@media (max-width: 767px) {
    .kpi-circle__label {
        font-size: clamp(14px, 3.3vw, 20px);
    }
    .kpi-circle__value .num {
        font-size: clamp(70px, 18vw, 108px);
    }
    .kpi-circle__value .unit {
        font-size: clamp(24px, 6vw, 36px);
    }
    .kpi-circle__img {
        height: clamp(17px, 3.6vw, 24px);
    }
    .kpi-circle__note {
        font-size: clamp(14px, 3.3vw, 20px);
    }
}

/* 右下の注釈 */
.solution-effort__disclaimer {
    text-align: right;
    font-size: clamp(12px, 2vw, 14px);
    color: #80878C;
    font-size: 8px;
}

/*==============================================================
/ solution-feature
/==============================================================*/
.solution-feature {
    padding: clamp(80px, 10vw, 155px) 0 clamp(80px, 10vw, 100px);
    background-color: var(--color-white);
}

.feature-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(16px, 10vw, 40px);
    margin-bottom: clamp(60px, 10vw, 84px);
}

.feature-item {
    background: #F5F7F8;
    padding: 48px 32px;
    border-radius: var(--radius-md);
}

.feature-label {
    font-size: clamp(18px, 2vw, 20px);
    color: var(--color-text);
    margin-bottom: 24px;
    font-weight: 500;
    line-height: 1.5;
}

.feature-text {
    font-size: clamp(13px, 2vw, 14px);
    color: var(--color-text);
    line-height: 1.6;
}

.feature-logos {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.feature-logos img {
    width: auto;
    height: auto;
    max-width: clamp(105px, 10vw, 184px);
    max-height: clamp(60px, 10vw, 120px);
    object-fit: contain;
}

/* スライダー機能が有効な場合 */
.feature-logos--slider {
    overflow: hidden;
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    flex-wrap: nowrap;
}

.feature-logos__slider {
    width: 100%;
    overflow: hidden;
}

.feature-logos__track {
    display: flex;
    align-items: center;
    gap: clamp(32px, 4vw, 64px);
    width: fit-content;
}

.feature-logos__track--animate {
    animation: logoSlide var(--slider-duration, 20s) linear infinite;
}

@keyframes logoSlide {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-33.333%); /* 3セット分の1/3を移動 */
    }
}

.feature-logos--slider img {
    flex-shrink: 0;
    margin: 0;
}


/* SPレスポンシブ */
@media (max-width: 768px) {
    .feature-list {
        grid-template-columns: 1fr;
    }
}

/*==============================================================
/ solution-voice
/==============================================================*/

.solution-voice {
    background-image: url("../images/solution/bg-voice-pc.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: var(--color-white);
    text-align: center;
}

.solution-voice > div {
    display: grid;
    padding: 0 100px;
    width: 100%;
    min-height: 740px;
    justify-content: center;
    align-items: center;

    @media (max-width: 900px) {
        display: block;
        min-height: unset;
        padding: 80px 40px;
    }
}

.solution-voice__content {
    max-width: 960px;
    margin: 0 auto;

}


.solution-voice__text {
    font-family: var(--font-sans-jp);
    font-weight: 500;
    font-size: clamp(20px, 2vw, 24px);
    line-height: 155%;
    text-align: center;
    letter-spacing: 0.05em;
    font-feature-settings: 'palt' on;
    color: var(--color-white);
    margin-bottom: 24px;

    @media (max-width: 768px) {
        text-align: left;
    }
}

 /*改行調整*/
@media (max-width: 768px) {
    /*大手チェーン企業向けソリューション*/
    .single-chain-companies .solution-voice__text br:is(:nth-child(2),:nth-child(3)) {
        display: none;
    }
    /*ジム*/
    .single-gym .solution-voice__text br:is(:nth-child(2),:nth-child(3)) {
        display: none;
    }

    /*ホテル*/
    .single-hotel .solution-voice__text br:is(:nth-child(2),:nth-child(3)) {
        display: none;
    }

    /*美容室*/
    .single-beauty-salon .solution-voice__text br:is(:nth-child(1),:nth-child(2),:nth-child(4)) {
        display: none;
    }
    /*スーパーマーケット*/
    .single-supermarket .solution-voice__text br:is(:nth-child(1),:nth-child(2),:nth-child(3),:nth-child(4)) {
        display: none;
    }
    /*アパレル*/
    .single-apparel .solution-voice__text br:is(:nth-child(1),:nth-child(3),:nth-child(4),:nth-child(5)) {
        display: none;
    }
    /*薬局*/
    .single-drugstore .solution-voice__text br:is(:nth-child(1),:nth-child(3),:nth-child(4),:nth-child(5)) {
        display: none;
    }
    /*レストラン*/
    .single-restaurant .solution-voice__text br:is(:nth-child(1)) {
        display: none;
    }
    /*居酒屋*/
    .single-izakaya .solution-voice__text br:is(:nth-child(1),:nth-child(3)) {
        display: none;
    }
}

.solution-voice__author {
    font-size: clamp(12px, 2vw, 14px);
    @media (max-width: 768px) {
        text-align: left;
    }
}

/* SP対応 */
@media (max-width: 768px) {
    .solution-voice {
        background-image: url("../images/solution/bg-voice-sp.jpg");
        /* SP用 */
    }
}


/*==============================================================
/  solution-services
/==============================================================*/
.solution-services {
    background-color: #450101;
    color: var(--color-white);
    padding: clamp(64px, 10vw, 120px) 0 clamp(64px, 10vw, 120px);
}

.solution-services p.h2-title-jp span:nth-child(2) {
    background-color: var(--color-white);
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 64px 40px;
}

.service-card {
    background: none;
    /* 背景なし */
    color: var(--color-white);
}

.service-card>img {
    width: 100%;
    height: auto;
    margin-bottom: clamp(24px, 5vw, 32px);
}

.service-card__title {
    font-size: clamp(18px, 2vw, 20px);
    font-weight: 500;
    margin-bottom: clamp(12px, 2vw, 16px);
}

.service-card__text {
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: clamp(24px, 5vw, 32px);
}

.service-card .btn-arrow {
    margin-inline: auto 0;
}

/* レスポンシブ */
@media (max-width: 1024px) {
    .services-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .services-grid {
        grid-template-columns: 1fr;
    }
}

/*==============================================================
/  solution-cases
/==============================================================*/
.solution-cases {
    padding: clamp(64px, 10vw, 120px) 0;
    background: linear-gradient(270deg, #C50018 0%, #450101 100%);
}

.solution-cases .case-head {
    margin-bottom: 0;
}

.solution-cases p.h2-title-jp {
    color: var(--color-white);
}

.solution-cases p.h2-title-jp span:nth-child(2) {
    background-color: var(--color-white);
}

.solution-cases .solution-title-jp {
    color: var(--color-white);
    margin-bottom: 24px;
}

.solution-cases .case-card {
    background: none;
    /* 背景なし */
    color: var(--color-white);
}

.solution-cases .case-card .slide-ttl,
.solution-cases .case-card .meta,
.solution-cases .case-card .lead,
.solution-cases .case-card .more {
    padding-left: 0;
}

.solution-cases .case-card .meta,
.solution-cases .case-card span {
    color: var(--color-white);
}

.solution-cases .case-card .meta {
    opacity: 0.5;
}
