
    #item-page-lp-gr5 img {
        height: auto;
    }
    #item-page-lp-gr5 * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
    }

    #item-page-lp-gr5 html {
        scroll-behavior: smooth;
    }

    #item-page-lp-gr5 body {
        font-family: 'Noto Sans JP', sans-serif;
        line-height: 1.6;
        color: #1a1a1a;
        background: #fff;
        padding-bottom: 70px;
    }

    #item-page-lp-gr5 h1, #item-page-lp-gr5 h2, #item-page-lp-gr5 h3, #item-page-lp-gr5 h4 {
        font-weight: 700;
        line-height: 1.3;
    }

    #item-page-lp-gr5 h1 {
        font-size: clamp(3.2rem, 5vw, 5.6rem);
        margin-bottom: 1.5rem;
    }

    #item-page-lp-gr5 h2 {
        font-size: clamp(2.88rem, 4vw, 4.48rem);
        margin-bottom: 1.5rem;
    }

    #item-page-lp-gr5 h3 {
        font-size: clamp(2.08rem, 3vw, 2.88rem);
        margin-bottom: 1rem;
    }

    #item-page-lp-gr5 p {
        font-size: 1.6rem;
        line-height: 1.8;
        margin-bottom: 1rem;
    }

    #item-page-lp-gr5 .accent-text {
        font-family: 'Inter', sans-serif;
        font-weight: 600;
        color: #b8a88a;
    }

    #item-page-lp-gr5 section {
        padding: 6rem 0;
        margin-inline: calc(50% - 50vw);
    }

    #item-page-lp-gr5 .container-wrapper {
        width: 67%;
        margin-inline: auto;
    }

    #item-page-lp-gr5 section.light-bg {
        background: #f5f3f0;
    }

    /* ===== &#10102; Hero ===== */

    #item-page-lp-gr5 .hero {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0;
        align-items: center;
        padding: 0;
        max-width: 1200px;
        margin: 0 auto;
        height: auto;
    }

    #item-page-lp-gr5 .hero-content-wrap {
        display: flex;
        align-items: center;
        padding: 4rem 3rem;
    }

    #item-page-lp-gr5 .hero-content h1 {
        color: #1a1a1a;
        font-size: clamp(2.88rem, 5vw, 4.48rem);
    }

    #item-page-lp-gr5 .hero-lead {
        font-size: 1.84rem;
        color: #444;
        margin-bottom: 0;
        line-height: 2;
    }

    #item-page-lp-gr5 .hero-image {
        width: 100%;
        aspect-ratio: 3/4;
        object-fit: cover;
        border-radius: 0;
    }

    /* ===== &#10103; Trust Badges ===== */

    #item-page-lp-gr5 .trust-badges {
        padding: 4.8rem 0;
        background: #f9f8f6;
        border-bottom: 1px solid #f0ede8;
    }

    #item-page-lp-gr5 .badges-row {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 2.4rem;
        max-width: 780px;
        margin: 0 auto;
    }

    #item-page-lp-gr5 .badge-item {
        background: #fff;
        border-radius: 12px;
        padding: 2.4rem 1.6rem;
        text-align: center;
        position: relative;
        overflow: hidden;
        box-shadow: 0 2px 12px rgba(0,0,0,0.04);
        border: 1px solid #f0ede8;
    }

    #item-page-lp-gr5 .badge-icon {
        width: 40px;
        height: 40px;
        margin: 0 auto 1.2rem;
        background: #f5f3f0;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    #item-page-lp-gr5 .badge-icon svg {
        width: 20px;
        height: 20px;
    }

    #item-page-lp-gr5 .badge-number {
        font-family: 'Inter', sans-serif;
        font-weight: 800;
        font-size: 2.88rem;
        color: #b8a88a;
        letter-spacing: -0.5px;
        line-height: 1.2;
        display: block;
    }

    #item-page-lp-gr5 .badge-suffix {
        font-size: 1.36rem;
        font-weight: 700;
        color: #999;
    }

    #item-page-lp-gr5 .badge-unit {
        display: block;
        font-size: 1.2rem;
        color: #999;
        margin-top: 0.56rem;
        letter-spacing: 0.5px;
    }

    /* ===== &#10104; Pain Points ===== */

    #item-page-lp-gr5 .pain-points {
        text-align: center;
    }

    #item-page-lp-gr5 .points-intro {
        font-size: 1.52rem;
        color: #666;
        margin-bottom: 3rem;
        max-width: 600px;
        margin-left: auto;
        margin-right: auto;
    }

    #item-page-lp-gr5 .points-grid {
        display: flex;
        flex-direction: column;
        gap: 0;
        max-width: 640px;
        margin: 0 auto 4rem;
        position: relative;
    }

    /* Vertical connector line */

    #item-page-lp-gr5 .points-grid::before {
        content: '';
        position: absolute;
        left: 31px;
        top: 40px;
        bottom: 45px;
        width: 2px;
        background: linear-gradient(to bottom, #d4cdc2, #b8a88a);
    }

    #item-page-lp-gr5 .point-card {
        display: flex;
        align-items: flex-start;
        gap: 2.4rem;
        padding: 2rem 0;
        text-align: left;
        position: relative;
    }

    #item-page-lp-gr5 .point-step {
        width: 62px;
        min-width: 62px;
        height: 62px;
        border-radius: 50%;
        background: #fff;
        border: 2px solid #b8a88a;
        display: flex;
        align-items: center;
        justify-content: center;
        font-family: 'Inter', sans-serif;
        font-size: 1.28rem;
        font-weight: 700;
        color: #b8a88a;
        letter-spacing: 0.5px;
        position: relative;
        z-index: 1;
    }

    #item-page-lp-gr5 .point-text {
        flex: 1;
        padding-top: 0.8rem;
    }

    #item-page-lp-gr5 .point-card h3 {
        font-size: 1.68rem;
        margin-bottom: 0.64rem;
        color: #1a1a1a;
    }

    #item-page-lp-gr5 .point-card p {
        font-size: 1.44rem;
        color: #666;
        line-height: 1.7;
        margin: 0;
    }

    #item-page-lp-gr5 .conclusion-box {
        background: transparent;
        padding: 0.8rem 1rem 0;
        text-align: center;
        font-size: 1.76rem;
        font-weight: 600;
        line-height: 1.9;
        color: #1a1a1a;
        max-width: 640px;
        margin: 0 auto;
    }

    /* ===== &#10105; Product Role ===== */

    #item-page-lp-gr5 .product-role {
        text-align: center;
    }

    #item-page-lp-gr5 .role-body {
        max-width: 700px;
        margin: 2rem auto 3rem;
        color: #666;
        line-height: 1.9;
    }

    #item-page-lp-gr5 .scenes-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(185px, 1fr));
        gap: 2rem;
    }

    #item-page-lp-gr5 .scene-image {
        width: 100%;
        aspect-ratio: 3/4;
        object-fit: cover;
        border-radius: 8px;
        margin-bottom: 1rem;
    }

    #item-page-lp-gr5 .scene-label {
        font-size: 1.76rem;
        font-weight: 600;
        text-align: center;
        color: #1a1a1a;
    }

    /* ===== &#10106; Features (WHY型) ===== */

    #item-page-lp-gr5 .features-section {
        background: #fff;
    }

    #item-page-lp-gr5 .features-intro {
        max-width: 800px;
        margin: 0 auto 6.4rem;
        text-align: center;
    }

    #item-page-lp-gr5 .features-intro p {
        color: #666;
        font-size: 1.68rem;
        line-height: 1.8;
    }

    #item-page-lp-gr5 .feature-point {
        margin-bottom: 8rem;
        display: grid;
        grid-template-columns: 1fr .7fr;
        gap: 0 4.8rem;
        align-items: start;
        grid-template-areas:
    "header image"
    "detail image";
    }

    #item-page-lp-gr5 .feature-point.reverse {
        grid-template-areas:
    "image header"
    "image detail";
        grid-template-columns: .7fr 1fr;
    }


    #item-page-lp-gr5 .feature-header {
        grid-area: header;
        padding-top: 3.2rem;
    }

    #item-page-lp-gr5 .feature-detail {
        grid-area: detail;
    }

    #item-page-lp-gr5 .feature-number {
        font-family: 'Inter', sans-serif;
        font-size: 1.36rem;
        font-weight: 600;
        color: #b8a88a;
        letter-spacing: 1px;
        margin-bottom: 1.2rem;
    }

    #item-page-lp-gr5 .feature-header h3 {
        font-size: 2.08rem;
        margin-bottom: 0;
        color: #1a1a1a;
        line-height: 1.5;
    }

    #item-page-lp-gr5 .feature-why {
        background: #f5f3f0;
        padding: 2.4rem 3.2rem;
        border-left: 4px solid #b8a88a;
        border-radius: 0 4px 4px 0;
        margin-bottom: 2.4rem;
    }

    #item-page-lp-gr5 .feature-why .why-label {
        font-size: 1.28rem;
        font-weight: 700;
        color: #b8a88a;
        letter-spacing: 1px;
        margin-bottom: 0.8rem;
    }

    #item-page-lp-gr5 .feature-why p {
        color: #555;
        font-size: 1.52rem;
        line-height: 1.8;
        margin-bottom: 0;
    }

    #item-page-lp-gr5 .feature-result {
        color: #1a1a1a;
        font-size: 1.52rem;
        font-weight: 500;
        line-height: 1.8;
    }

    #item-page-lp-gr5 .feature-image {
        grid-area: image;
        width: 100%;
        border-radius: 8px;
        align-self: center;
    }

    #item-page-lp-gr5 .info-box {
        background: #f5f3f0;
        padding: 2.4rem 3.2rem;
        border-radius: 4px;
        margin: 2.4rem 0;
        font-size: 1.44rem;
        color: #666;
    }

    #item-page-lp-gr5 .info-box strong {
        color: #b8a88a;
    }

    /* ===== &#10107; Color Variations ===== */

    #item-page-lp-gr5 .colors {
        text-align: center;
    }

    #item-page-lp-gr5 .colors-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: 2rem;
    }

    #item-page-lp-gr5 .color-card {
        text-align: center;
    }

    #item-page-lp-gr5 .color-image {
        width: 100%;
        border-radius: 8px;
        margin-bottom: 1rem;
    }

    #item-page-lp-gr5 .color-name {
        font-family: 'Inter', sans-serif;
        font-size: 1.6rem;
        font-weight: 600;
        color: #1a1a1a;
        margin-bottom: 0.5rem;
    }

    #item-page-lp-gr5 .color-desc {
        font-size: 1.44rem;
        color: #666;
        line-height: 1.7;
    }

    /* ===== &#10108; CODE Series + Weekly ===== */

    #item-page-lp-gr5 .code-weekly {
        background: #f5f3f0;
    }

    #item-page-lp-gr5 .code-weekly-header {
        text-align: center;
        margin-bottom: 2rem;
    }

    #item-page-lp-gr5 .code-weekly-lead {
        max-width: 700px;
        margin: 0 auto 3rem;
        text-align: center;
        color: #666;
        line-height: 1.9;
    }

    #item-page-lp-gr5 .weekly-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
        gap: 1.5rem;
        margin-bottom: 3rem;
    }

    #item-page-lp-gr5 .weekly-card {
        background: #fff;
        border-radius: 8px;
        overflow: hidden;
        text-align: center;
        flex-shrink: 0;
    }

    #item-page-lp-gr5 .weekly-image {
        width: 100%;
        aspect-ratio: 3/4;
        object-fit: cover;
    }

    #item-page-lp-gr5 .weekly-info {
        padding: 1.25rem;
    }

    #item-page-lp-gr5 .weekly-day {
        font-family: 'Inter', sans-serif;
        font-size: 1.36rem;
        font-weight: 600;
        color: #b8a88a;
        letter-spacing: 1px;
        margin-bottom: 0.25rem;
    }

    #item-page-lp-gr5 .weekly-item {
        font-size: 1.44rem;
        font-weight: 500;
        color: #1a1a1a;
        margin-bottom: 0.25rem;
    }

    #item-page-lp-gr5 .weekly-desc {
        font-size: 1.28rem;
        color: #666;
    }

    #item-page-lp-gr5 .weekly-scroll-hint {
        display: none;
    }

    /* ===== &#10109; Customer Reviews ===== */

    #item-page-lp-gr5 .reviews {
        text-align: center;
    }

    #item-page-lp-gr5 .reviews-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        gap: 2rem;
        margin-top: 3rem;
    }

    #item-page-lp-gr5 .review-card {
        background: #f5f3f0;
        padding: 2rem;
        border-radius: 8px;
        text-align: center;
    }

    #item-page-lp-gr5 .review-profile {
        font-size: 1.36rem;
        color: #999;
        margin-bottom: 0.75rem;
    }

    #item-page-lp-gr5 .review-rating {
        color: #b8a88a;
        margin-bottom: 1rem;
        font-size: 1.76rem;
        letter-spacing: 1px;
    }

    #item-page-lp-gr5 .review-text {
        font-size: 1.52rem;
        color: #555;
        line-height: 1.8;
    }

    /* ===== &#10110; Services ===== */

    #item-page-lp-gr5 .services {
        background: #f5f3f0;
    }

    #item-page-lp-gr5 .services-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        gap: 2rem;
    }

    #item-page-lp-gr5 .service-card {
        background: #fff;
        padding: 2.5rem;
        border-radius: 8px;
        text-align: center;
    }

    #item-page-lp-gr5 .service-card h3 {
        font-size: 1.92rem;
        margin-bottom: 1.5rem;
        color: #1a1a1a;
    }

    #item-page-lp-gr5 .service-card p {
        color: #666;
        font-size: 1.52rem;
        line-height: 1.8;
    }

    /* ===== &#10111; Size Guide ===== */

    #item-page-lp-gr5 .size-guide {
        background: #fff;
    }

    #item-page-lp-gr5 .size-guide-header {
        text-align: center;
        margin-bottom: 1rem;
    }

    #item-page-lp-gr5 .size-guide-lead {
        text-align: center;
        max-width: 600px;
        margin: 0 auto 3rem;
        font-size: 1.52rem;
        color: #666;
        line-height: 1.8;
    }

    #item-page-lp-gr5 .size-table-wrapper {
        margin: 0 0 2.5rem;
        overflow-x: auto;
    }

    #item-page-lp-gr5 .size-table {
        width: 100%;
        border-collapse: collapse;
        font-size: 1.44rem;
    }

    #item-page-lp-gr5 .size-table th, #item-page-lp-gr5 .size-table td {
        padding: 0.85rem 1rem;
        text-align: center;
        border-bottom: 1px solid #e0e0e0;
    }

    #item-page-lp-gr5 .size-table th {
        background: #f5f3f0;
        font-weight: 600;
        color: #1a1a1a;
        font-size: 1.36rem;
        white-space: nowrap;
    }

    #item-page-lp-gr5 .size-table td {
        color: #555;
    }

    #item-page-lp-gr5 .size-table tbody tr:hover {
        background: #faf9f7;
    }

    #item-page-lp-gr5 .size-note {
        max-width: 900px;
        margin: 0 auto 2rem;
        font-size: 1.28rem;
        color: #999;
        line-height: 1.7;
    }

    #item-page-lp-gr5 .spec-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
        gap: 1rem;
        max-width: 900px;
        margin: 0 auto;
    }

    #item-page-lp-gr5 .spec-item {
        display: flex;
        justify-content: space-between;
        padding: 0.6rem 0;
        border-bottom: 1px solid #eee;
        font-size: 1.44rem;
    }

    #item-page-lp-gr5 .spec-label {
        color: #999;
    }

    #item-page-lp-gr5 .spec-value {
        color: #1a1a1a;
        font-weight: 500;
    }

    /* ===== &#10111; Body Type Comparison ===== */

    #item-page-lp-gr5 .size-comparison {
        text-align: center;
        background: #f5f3f0;
    }

    #item-page-lp-gr5 .size-intro {
        max-width: 700px;
        margin: 0 auto 3rem;
        color: #666;
    }

    #item-page-lp-gr5 .staff-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        gap: 2rem;
    }

    #item-page-lp-gr5 .staff-card {
        background: #fff;
        padding: 2rem;
        border-radius: 8px;
        text-align: center;
    }

    #item-page-lp-gr5 .staff-image {
        width: 100%;
        aspect-ratio: 3/4;
        background: #ddd;
        object-fit: cover;
        border-radius: 8px;
        margin-bottom: 1.5rem;
    }

    #item-page-lp-gr5 .staff-info {
        font-weight: 600;
        margin-bottom: 1rem;
        color: #1a1a1a;
    }

    #item-page-lp-gr5 .staff-tags {
        display: flex;
        gap: 0.5rem;
        justify-content: center;
        margin-bottom: 1rem;
        flex-wrap: wrap;
    }

    #item-page-lp-gr5 .staff-tag {
        font-size: 1.28rem;
        padding: 0.3rem 0.8rem;
        background: #f5f3f0;
        border-radius: 20px;
        color: #666;
    }

    #item-page-lp-gr5 .staff-comment {
        font-size: 1.52rem;
        color: #666;
        line-height: 1.8;
    }

    /* ===== Responsive ===== */

    @media (max-width: 768px) {


        #item-page-lp-gr5 .container-wrapper {
            width: 90%;
        }
        #item-page-lp-gr5 .container-wrapper.no-w {
            width: 100%;
        }

        #item-page-lp-gr5 .hero {
            grid-template-columns: 1fr;
            padding: 0;
        }

        #item-page-lp-gr5 .hero-image-wrap {
            order: 1 !important;
        }

        #item-page-lp-gr5 .hero-content-wrap {
            order: 2 !important;
            padding: 2rem 1.5rem 2.5rem;
        }

        #item-page-lp-gr5 .hero-image {
            border-radius: 0;
        }

        #item-page-lp-gr5 .hero-content h1 {
            font-size: 2.56rem;
            margin-bottom: 1rem;
        }

        #item-page-lp-gr5 .hero-lead {
            font-size: 1.6rem;
            margin-bottom: 0;
        }

        #item-page-lp-gr5 .feature-point,
        #item-page-lp-gr5 .feature-point.reverse {
            grid-template-columns: 1fr;
            grid-template-areas:
            "header"
            "image"
            "detail";
            gap: 2.4rem 0;
        }

        #item-page-lp-gr5 .feature-point.reverse > * {
            direction: ltr;
        }

        #item-page-lp-gr5 .badges-row {
            gap: 1.5rem;
        }

        #item-page-lp-gr5 .badge-divider {
            display: none;
        }

         /*Weekly slide UI */

        #item-page-lp-gr5 .weekly-grid {
            display: flex;
            overflow-x: auto;
            scroll-snap-type: x mandatory;
            -webkit-overflow-scrolling: touch;
            gap: 1rem;
            padding-bottom: 1rem;
            margin-bottom: 2rem;
        }

        #item-page-lp-gr5 .weekly-image {
            aspect-ratio: unset;
            object-fit: unset;
        }

        /*#item-page-lp-gr5 .weekly-card {
            min-width: 70vw;
            scroll-snap-align: center;
        }*/
        #item-page-lp-gr5 .weekly-card {
            min-width: unset;
            width: 80%;
        }

        #item-page-lp-gr5 .weekly-scroll-hint {
            display: block;
        }

        #item-page-lp-gr5 .weekly-scroll-arrow {
            display: flex;
        }

        /* Color 2col */

        #item-page-lp-gr5 .colors-grid {
            grid-template-columns: repeat(2, 1fr) !important;
            gap: 1rem;
        }

        /* Series links 2col */

        #item-page-lp-gr5 .series-links-grid {
            grid-template-columns: repeat(2, 1fr) !important;
            gap: 0.75rem;
        }
    }

    @media (max-width: 480px) {

        #item-page-lp-gr5 section {
            padding: 3rem 0;
        }

        #item-page-lp-gr5 h1 {
            font-size: 2.4rem;
        }

        #item-page-lp-gr5 h2 {
            font-size: 2.16rem;
        }

        #item-page-lp-gr5 .container-wrapper {
            padding: 0 1rem;
        }

        #item-page-lp-gr5 .sticky-cta {
            gap: 0.75rem;
            flex-direction: column;
            padding: 0.75rem;
        }

        #item-page-lp-gr5 .scenes-grid {
            grid-template-columns: repeat(3, 1fr);
        }
        #item-page-lp-gr5 .scene-image {
            aspect-ratio: 2 / 3.5;
        }

        /*#item-page-lp-gr5 .weekly-card {
            min-width: 75vw;
        }*/
    }


    /* スワイプ矢印（スマホのみ表示） */

    #item-page-lp-gr5 .weekly-scroll-arrow {
        display: none;
        justify-content: center;
        align-items: center;
        gap: 1.5rem;
        margin-bottom: 2rem;
    }

    #item-page-lp-gr5 .weekly-scroll-arrow svg {
        opacity: 0.6;
    }

    #item-page-lp-gr5 .weekly-scroll-arrow span {
        font-size: 1.2rem;
        color: #999;
    }



    /* ===== CODE SYSTEM Section ===== */
    #item-page-lp-gr5 .code-system {
        padding: 0 0 4.8rem; text-align: center;
    }
    #item-page-lp-gr5 .code-system-title {
        font-family: 'Inter', sans-serif; font-size: 1.28rem; font-weight: 700;
        letter-spacing: 3px; color: #b8a88a; margin-bottom: 0.64rem;
    }
    #item-page-lp-gr5 .code-system-sub {
        font-size: clamp(2.88rem, 4vw, 4.48rem); font-weight: 700; color: #1a1a1a; margin-bottom: 0.8rem;
    }
    #item-page-lp-gr5 .code-system-lead {
        font-size: 1.44rem; color: #666; margin-bottom: 4rem;
    }
    
    /* Items heading */
    #item-page-lp-gr5 .cs-items-head {
        text-align: center; margin: 4.8rem 0 2.4rem;
    }
    #item-page-lp-gr5 .cs-items-eyebrow {
        font-family: 'Inter', sans-serif; font-size: 1.2rem; font-weight: 600;
        letter-spacing: 3px; color: #b8a88a; margin-bottom: 0.8rem;
    }
    #item-page-lp-gr5 .cs-items-title {
        font-size: 1.76rem; font-weight: 600; color: #1a1a1a;
    }
    /* Step flow */
    #item-page-lp-gr5 .cs-vertical {
        margin: 0 auto 4rem;
        display: grid; grid-template-columns: 1fr 3fr 1fr; gap: 1.2rem;
        align-items: stretch;
        position: relative;
    }
    #item-page-lp-gr5 .cs-vertical::after {
        content: '';
        position: absolute;
        top: 16px;
        left: 0; right: 0;
        height: 2px;
        background: #e8e4de;
        z-index: 0;
    }
    #item-page-lp-gr5 .cs-step-arrow {
        position: absolute;
        top: 0;
        transform: translateX(-50%);
        z-index: 2;
        display: flex; align-items: center; justify-content: center;
        width: 32px; height: 32px;
    }
    #item-page-lp-gr5 .cs-vertical > :nth-child(2) { left: 25%; }
    #item-page-lp-gr5 .cs-vertical > :nth-child(4) { left: 75%; }
    #item-page-lp-gr5 .cs-step-arrow svg {
        width: 18px; height: 18px;
        color: #ccc;
    }
    #item-page-lp-gr5 .cs-vstep {
        text-align: center;
        display: flex; flex-direction: column;
        align-items: center;
    }
    #item-page-lp-gr5 .cs-vstep-num {
        display: inline-flex; align-items: center; justify-content: center;
        width: 32px; height: 32px; border-radius: 50%;
        background: #1a1a1a; color: #fff;
        font-family: 'Inter', sans-serif; font-size: 1.04rem; font-weight: 700;
        margin-bottom: 0.8rem;
        position: relative; z-index: 1;
    }
    #item-page-lp-gr5 .cs-vstep.is-step2 .cs-vstep-num { background: #8a8a8a; }
    #item-page-lp-gr5 .cs-vstep.is-step3 .cs-vstep-num { background: #7b8fa1; }
    #item-page-lp-gr5 .cs-vstep-label {
        font-family: 'Inter', sans-serif; font-size: 1.04rem; font-weight: 700;
        letter-spacing: 1.5px; color: #b8a88a; margin-bottom: 0.4rem;
    }
    #item-page-lp-gr5 .cs-vstep-main {
        font-size: 1.76rem; font-weight: 700; color: #1a1a1a; margin-bottom: 0.48rem;
    }
    #item-page-lp-gr5 .cs-vstep-note {
        font-size: 1.28rem; color: #999; margin-bottom: 1.6rem;
    }
    /* Product cards */
    #item-page-lp-gr5 .cs-cards {
        display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
        flex: 1;
    }
    #item-page-lp-gr5 .cs-vstep.is-step1 .cs-cards,
    #item-page-lp-gr5 .cs-vstep.is-step3 .cs-cards {
        grid-template-columns: 1fr;
    }
    #item-page-lp-gr5 .cs-card {
        text-align: center; background: #fff; border: 1px solid #e8e4de;
        border-radius: 6px; padding: 1.6rem 0.8rem;
        display: flex; flex-direction: column;
        text-decoration: none; color: inherit;
        transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    }
    #item-page-lp-gr5 a.cs-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 6px 20px rgba(0,0,0,0.08);
        border-color: #b8a88a;
    }
    #item-page-lp-gr5 .cs-card-img {
        width: 100%; aspect-ratio: 3/4; object-fit: cover; object-position: top;
        border-radius: 4px; margin-bottom: 0.96rem; max-height: 200px;
    }
    #item-page-lp-gr5 .cs-card-body {
        flex: 1; display: flex; flex-direction: column;
    }
    #item-page-lp-gr5 .cs-card-role {
        font-size: 1.12rem; font-weight: 600; color: #b8a88a; margin-bottom: 0.24rem;
    }
    #item-page-lp-gr5 .cs-vstep.is-step1 .cs-card-role { color: #1a1a1a; }
    #item-page-lp-gr5 .cs-vstep.is-step2 .cs-card-role { color: #8a8a8a; }
    #item-page-lp-gr5 .cs-vstep.is-step3 .cs-card-role { color: #7b8fa1; }
    #item-page-lp-gr5 .cs-card-name {
        font-size: 1.28rem; font-weight: 700; color: #1a1a1a; margin-bottom: auto; padding-bottom: 0.8rem;
    }
    #item-page-lp-gr5 .cs-card-cta {
        display: inline-block; font-size: 1.12rem; font-weight: 600;
        color: #b8a88a; text-decoration: none; letter-spacing: 0.5px;
        padding: 0.48rem 0.96rem; border: 1px solid #b8a88a; border-radius: 2px;
        transition: all 0.2s ease;
    }
    #item-page-lp-gr5 .cs-card-cta:hover { background: #b8a88a; color: #fff; }
    #item-page-lp-gr5 .cs-vstep.is-step1 .cs-card-cta { color: #1a1a1a; border-color: #1a1a1a; }
    #item-page-lp-gr5 .cs-vstep.is-step1 .cs-card-cta:hover { background: #1a1a1a; color: #fff; }
    #item-page-lp-gr5 .cs-vstep.is-step2 .cs-card-cta { color: #8a8a8a; border-color: #8a8a8a; }
    #item-page-lp-gr5 .cs-vstep.is-step2 .cs-card-cta:hover { background: #8a8a8a; color: #fff; }
    #item-page-lp-gr5 .cs-vstep.is-step3 .cs-card-cta { color: #7b8fa1; border-color: #7b8fa1; }
    #item-page-lp-gr5 .cs-vstep.is-step3 .cs-card-cta:hover { background: #7b8fa1; color: #fff; }
    /* "Now viewing" card */
    #item-page-lp-gr5 .cs-card.is-now {
        border: 2px solid #b8a88a;
        background: #fefcf7;
    }
    #item-page-lp-gr5 .cs-card-now-static {
        font-size: 1.09rem;
        color: #8a7a5c;
        padding-top: 0.64rem;
        margin-top: 0.48rem;
        border-top: 1px dashed #d9cfbd;
    }

    /* Mobile styles for CODE SYSTEM */
    @media (max-width: 768px) {
        #item-page-lp-gr5 .code-system { padding: 2rem 1rem; }
        #item-page-lp-gr5 .cs-summary {
            grid-template-columns: repeat(3, 1fr);
            gap: 0.4rem; margin-bottom: 1.5rem;
        }
        #item-page-lp-gr5 .cs-summary-arrow { display: none; }
        #item-page-lp-gr5 .cs-summary-card { padding: 0.9rem 0.4rem 0.75rem; }
        #item-page-lp-gr5 .cs-summary-badge { width: 24px; height: 24px; font-size: 1.04rem; margin-bottom: 0.5rem; }
        #item-page-lp-gr5 .cs-summary-label { font-size: 0.88rem; letter-spacing: 1px; margin-bottom: 0.3rem; }
        #item-page-lp-gr5 .cs-summary-title { font-size: 1.2rem; margin-bottom: 0.25rem; }
        #item-page-lp-gr5 .cs-summary-note { font-size: 0.96rem; }
        #item-page-lp-gr5 .cs-vertical {
            display: block; position: relative; padding-left: 2rem;
        }
        #item-page-lp-gr5 .cs-vertical::before {
            content: ''; position: absolute; left: 9px; top: 0; bottom: 0;
            width: 2px; background: #e8e4de;
        }
        #item-page-lp-gr5 .cs-step-arrow { display: none; }
        #item-page-lp-gr5 .cs-vertical::after { display: none; }
        #item-page-lp-gr5 .cs-vstep { position: relative; margin-bottom: 2rem; text-align: left; align-items: stretch; }
        #item-page-lp-gr5 .cs-vstep::before,
        #item-page-lp-gr5 .cs-vstep::after { display: none !important; }
        #item-page-lp-gr5 .cs-vstep:last-child { margin-bottom: 0; }
        #item-page-lp-gr5 .cs-vstep-num {
            position: absolute; left: -2rem; top: 0;
            width: 20px; height: 20px; font-size: 0.88rem;
        }
        #item-page-lp-gr5 .cs-vstep-main { font-size: 1.52rem; }
        #item-page-lp-gr5 .cs-cards {
            grid-template-columns: 1fr !important; max-width: none !important;
            gap: 0.6rem;
        }
        #item-page-lp-gr5 .cs-card {
            flex-direction: row; align-items: center; gap: 0.75rem;
            text-align: left; padding: 0.75rem;
        }
        #item-page-lp-gr5 .cs-card-img {
            width: 72px; height: 72px; aspect-ratio: 1/1; max-height: none;
            flex-shrink: 0; margin-bottom: 0; border-radius: 4px;
        }
        #item-page-lp-gr5 .cs-card-body {
            flex: 1; display: block;
        }
        #item-page-lp-gr5 .cs-card-role { font-size: 1.04rem; }
        #item-page-lp-gr5 .cs-card-name { font-size: 1.2rem; margin-bottom: 0.35rem; padding-bottom: 0; }
        #item-page-lp-gr5 .cs-card-cta { font-size: 1.04rem; padding: 0.25rem 0.5rem; }
    }




    /*#item-page-lp-gr5 section {
        margin-inline: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    #item-page-lp-gr5 .container-wrapper,
    #item-page-lp-gr5 .container-wrapper.no-w {
        width: 100% !important;
        max-width: 1200px;
        margin-inline: auto;
        padding-inline: 1.6rem;
    }

    #item-page-lp-gr5 .hero {
        max-width: 100% !important;
    }

    #item-page-lp-gr5 .hero-content h1 {
        font-size: clamp(2.4rem, 3.4vw, 3.6rem);
        line-height: 1.4;
    }

    #item-page-lp-gr5 .hero-content-wrap {
        padding: 3.2rem 2.4rem;
    }
    #item-page-lp-gr5 .hero-image-wrap {
        overflow: hidden;
    }

    #item-page-lp-gr5 img,
    #item-page-lp-gr5 video {
        max-width: 100% !important;
        height: auto !important;
        display: block;
    }
    #item-page-lp-gr5 table {
        width: 100%;
        border-collapse: collapse;
        background: transparent;
    }
    #item-page-lp-gr5 table th,
    #item-page-lp-gr5 table td {
        background: transparent;
    }

    #item-page-lp-gr5 {
        box-sizing: border-box;
        overflow-x: clip;
        max-width: 100%;
    }*/

    /* feature-point: 親幅が狭い場合に画像列が潰れすぎないよう微調整 */
    @media (min-width: 769px) {
        #item-page-lp-gr5 .feature-point {
            gap: 0 3.2rem;
        }
        #item-page-lp-gr5 .feature-why {
            padding: 2rem 2.4rem;
        }
    }

    /* code-system の step 列が狭い時に矢印が重ならないよう微調整 */
    @media (max-width: 900px) and (min-width: 769px) {
        #item-page-lp-gr5 .cs-vertical {
            grid-template-columns: 1fr 2fr 1fr;
        }
    }

    /* size-table / cmpt が Bootstrap の table.css に上書きされないよう明示 */
    #item-page-lp-gr5 .size-table,
    #item-page-lp-gr5 table.cmpt {
        margin: 0 auto;
    }
    #item-page-lp-gr5 .size-table tbody tr,
    #item-page-lp-gr5 table.cmpt tbody tr {
        background: transparent;
    }

    /* ===========================================================
       ▼ サイズガイド固有の崩れ修正
       =========================================================== */
    #item-page-lp-gr5 .fit-row {
        gap: 1.6rem;
    }
    #item-page-lp-gr5 .fit-row label {
        flex: 0 0 auto !important;
        white-space: nowrap;
        min-width: 9em;            /* 「希望のフィット感」が1行で収まる幅 */
        display: inline-block !important;
        max-width: none !important;
    }
    #item-page-lp-gr5 .fit-row select.val {
        flex: 0 0 auto !important;
        width: auto !important;
        display: inline-block !important;
        max-width: 100%;
        appearance: auto;          /* 念のため矢印を残す（Futureshop環境で消える対策） */
        -webkit-appearance: auto;
    }
    #item-page-lp-gr5 .size-table-wrapper {
        width: 100% !important;
        display: block;
    }
    #item-page-lp-gr5 .size-table {
        width: 100% !important;
        min-width: 100%;
        table-layout: auto;
    }
    #item-page-lp-gr5 .size-table th,
    #item-page-lp-gr5 .size-table td {
        white-space: nowrap;
    }

    /* 「CODEパンツのサイズ比較」テーブルにも同様の保険 */
    #item-page-lp-gr5 table.cmpt {
        width: 100% !important;
        min-width: 100%;
        table-layout: auto;
    }

    /* スマホでテーブルが横スクロール可能になるよう保険 */
    @media (max-width: 600px) {
        #item-page-lp-gr5 .size-table-wrapper {
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
        }
        #item-page-lp-gr5 .size-table {
            min-width: 480px;       /* 最低限の表幅を確保してスクロールで見せる */
        }
        /* フィット診断もスマホで縦並びに */
        #item-page-lp-gr5 .fit-row {
            flex-wrap: wrap;
            gap: 0.4rem 1rem;
        }
        #item-page-lp-gr5 .fit-row label {
            min-width: auto;
        }
    }

    /* スマホで「04 CODEパンツのサイズ比較」見出しが崩れる対策
       - 元CSSは .block-sub に flex-basis:100% を指定しているが、
         .block-head 側に flex-wrap が無いため改行されず、
         隣の .block-title が1文字幅まで圧迫されて
         縦に1文字ずつ折り返されていた */
    @media (max-width: 768px) {
        #item-page-lp-gr5 .block-head {
            flex-wrap: wrap;
            align-items: baseline;
            row-gap: 0.4rem;
        }
        #item-page-lp-gr5 .block-title {
            flex: 1 1 0;
            min-width: 0;           /* テキストが必要に応じて折り返せるよう保険 */
        }
        #item-page-lp-gr5 .block-sub {
            flex: 0 0 100%;
            order: 3;               /* タイトルの下に確実に表示 */
            margin-top: .2rem;
        }
    }



    /* ===== 改修：サイズ判断補助（LP本体トンマナ #b8a88a / #f5f3f0 に統一） ===== */
    #item-page-lp-gr5 .size-fit-inner{ margin:5rem 0 2rem; }

    /* ブロック見出し（番号＋タイトル＋細線） */
    #item-page-lp-gr5 .block-head{
        display:flex; align-items:baseline; gap:1.6rem;
        margin:6rem 0 2.4rem; padding:1.6rem 0 1.4rem;
        border-top:1px solid #1a1a1a; position:relative;
    }
    #item-page-lp-gr5 .block-head::before{
        content:""; position:absolute; top:-1px; left:0;
        width:6rem; height:3px; background:#b8a88a;
    }
    #item-page-lp-gr5 .block-head:first-of-type{ margin-top:0; }
    #item-page-lp-gr5 .block-num{
        font-family:"Inter",sans-serif; font-weight:600;
        font-size:1.3rem; color:#b8a88a; letter-spacing:.2em; flex:0 0 auto;
    }
    #item-page-lp-gr5 .block-title{
        font-size:clamp(2rem,2.6vw,2.4rem); font-weight:700; color:#1a1a1a;
        line-height:1.4; flex:1; letter-spacing:.02em;
    }
    #item-page-lp-gr5 .block-sub{
        font-size:1.2rem; color:#999; flex:0 0 auto; letter-spacing:.02em;
    }

    /* カード共通（白背景・細枠） */
    #item-page-lp-gr5 .size-fit-inner .card{
        background:#fff; border:1px solid #eee;
        padding:3rem; margin-bottom:1.6rem;
    }

    /* VOICES（薄ベージュ・落ち着いた印象） */
    #item-page-lp-gr5 .voices{
        background:#f5f3f0; padding:2.4rem; margin-bottom:1.6rem;
    }
    #item-page-lp-gr5 .voices .vhead{
        display:flex; align-items:center; gap:1rem;
        padding-bottom:1.4rem; margin-bottom:1.4rem; border-bottom:1px solid #e0d8c8;
    }
    #item-page-lp-gr5 .voices .vlabel{
        background:#b8a88a; color:#fff; font-size:1.1rem;
        padding:.4rem 1rem; letter-spacing:.15em; font-weight:500;
    }
    #item-page-lp-gr5 .voices .vh-title{ font-size:1.2rem; color:#999; margin-left:auto; font-weight:400; }
    #item-page-lp-gr5 .voices .vh-sub{ display:none; }
    #item-page-lp-gr5 .voices .vrow{
        display:flex; gap:1.4rem; padding:1.2rem 0; align-items:flex-start;
        border-bottom:1px solid #e8e0d0;
    }
    #item-page-lp-gr5 .voices .vrow:last-child{ border-bottom:none; padding-bottom:0; }
    #item-page-lp-gr5 .voices .vnum{
        flex:0 0 3rem; height:3rem; border-radius:50%;
        border:1.5px solid #b8a88a; color:#b8a88a; background:#fff;
        font-family:Georgia,serif; font-size:1.4rem; font-weight:600;
        display:flex; align-items:center; justify-content:center;
    }
    #item-page-lp-gr5 .voices .vbody{ flex:1; font-size:1.4rem; line-height:1.7; color:#1a1a1a; }
    #item-page-lp-gr5 .voices .vmsg b{ color:#1a1a1a; font-weight:600; }
    #item-page-lp-gr5 .voices .vans{ color:#6a5a40; font-size:1.25rem; margin-top:.3rem; }
    #item-page-lp-gr5 .voices .vcount{
        font-size:1.1rem; color:#999; flex:0 0 auto; align-self:center;
        background:#fff; padding:.3rem 1rem; border:1px solid #e8e0d0; border-radius:10px;
    }

    /* フィット診断 */
    #item-page-lp-gr5 .fit-disclaimer{
        font-size:1.2rem; color:#888; margin-bottom:1.6rem; line-height:1.7;
        padding:1.2rem 1.4rem; background:#f5f3f0; border-left:3px solid #b8a88a;
    }
    #item-page-lp-gr5 .fit-form{
        background:#fafaf7; border:1px solid #eee; padding:1.4rem 1.6rem;
    }
    #item-page-lp-gr5 .fit-row{
        display:flex; justify-content:space-between; align-items:center;
        padding:1rem 0; border-bottom:1px solid #eee; font-size:1.4rem;
    }
    #item-page-lp-gr5 .fit-row:last-of-type{ border-bottom:none; }
    #item-page-lp-gr5 .fit-row label{ color:#666; font-size:1.35rem; }
    #item-page-lp-gr5 .fit-row select.val{
        border:none; background:transparent;
        font-family:inherit; color:#1a1a1a; font-weight:500; font-size:1.4rem;
        cursor:pointer; padding:.3rem .4rem;
    }
    #item-page-lp-gr5 .fit-row select.val:focus{ outline:1px solid #b8a88a; }
    #item-page-lp-gr5 .fit-result{
        background:#1a1a1a; color:#fff;
        padding:1.8rem 2rem; margin-top:1.6rem;
        display:flex; justify-content:space-between; align-items:center;
    }
    #item-page-lp-gr5 .fit-result .label{ font-size:1.1rem; color:#b8a88a; letter-spacing:.2em; }
    #item-page-lp-gr5 .fit-result .desc{ font-size:1.2rem; color:#aaa; margin-top:.3rem; }
    #item-page-lp-gr5 .fit-result .ans{ font-size:3.6rem; font-weight:600; letter-spacing:.05em; }
    #item-page-lp-gr5 .fit-result .ans.no-match{ font-size:1.5rem; letter-spacing:.03em; line-height:1.4; text-align:right; }
    #item-page-lp-gr5 .fit-note{ font-size:1.2rem; color:#666; margin-top:1rem; line-height:1.7; }
    #item-page-lp-gr5 .fit-note b{ color:#1a1a1a; }

    /* 採寸イラスト折りたたみ */
    #item-page-lp-gr5 .size-illust-acc{
        margin:0 0 2rem; border:1px solid #eee; background:#fafaf7;
    }
    #item-page-lp-gr5 .size-illust-acc > summary{
        cursor:pointer; list-style:none;
        padding:1.4rem 1.8rem; font-size:1.3rem; color:#1a1a1a;
        font-weight:500; letter-spacing:.02em;
        display:flex; justify-content:space-between; align-items:center;
    }
    #item-page-lp-gr5 .size-illust-acc > summary::-webkit-details-marker{ display:none; }
    #item-page-lp-gr5 .size-illust-acc[open] > summary{ border-bottom:1px solid #eee; }
    #item-page-lp-gr5 .size-illust-acc .acc-arrow{ color:#b8a88a; transition:transform .2s; font-size:1.4rem; }
    #item-page-lp-gr5 .size-illust-acc[open] .acc-arrow{ transform:rotate(180deg); }
    #item-page-lp-gr5 .size-illust-body{ padding:2rem; text-align:center; }
    #item-page-lp-gr5 .size-illust-body img{ max-width:360px; width:80%; margin:0 auto; }
    #item-page-lp-gr5 .size-illust-body p{ font-size:1.1rem; color:#999; margin-top:1rem; }

    /* サイズ表ハイライト連動 */
    #item-page-lp-gr5 .size-table tr.fit-me th,
    #item-page-lp-gr5 .size-table tr.fit-me td{
        background:#f5f3f0 !important; font-weight:600; color:#1a1a1a;
    }

    /* CODEパンツ比較：商品画像（コンパクトに中央寄せ） */
    #item-page-lp-gr5 .cmp-images{
        display:flex; gap:1.6rem; justify-content:center; margin-bottom:2.4rem;
    }
    #item-page-lp-gr5 .cmp-img-card{
        flex:0 1 160px; max-width:160px;
        background:#fafaf7; border:1px solid #eee; overflow:hidden; margin:0;
    }
    #item-page-lp-gr5 .cmp-img-card img{
        width:100%; aspect-ratio:1/1; object-fit:contain; display:block; background:#fff;
    }
    #item-page-lp-gr5 .cmp-img-card figcaption{ padding:.8rem 1rem; text-align:center; }
    #item-page-lp-gr5 .cmp-img-card figcaption b{
        display:block; font-weight:600; color:#1a1a1a; font-size:1.3rem; margin-bottom:.2rem;
    }
    #item-page-lp-gr5 .cmp-img-card figcaption span{ font-size:1rem; color:#999; }
    #item-page-lp-gr5 .cmp-img-card.cmp-img-summer{ border-top:3px solid #b8a88a; }
    #item-page-lp-gr5 .cmp-img-card.cmp-img-regular{ border-top:3px solid #ccc; }
    #item-page-lp-gr5 .cmp-img-link{
        flex:0 1 160px; max-width:160px;
        text-decoration:none; color:inherit;
        transition:opacity .15s;
    }
    #item-page-lp-gr5 .cmp-img-link:hover{ opacity:.8; }
    #item-page-lp-gr5 .cmp-img-link .cmp-img-card{
        flex:none; max-width:none; width:100%;
    }

    /* CODEパンツ比較：サイズ切替・表 */
    #item-page-lp-gr5 .cmp-sizesel-label{
        text-align:center; font-size:1.1rem; letter-spacing:.2em;
        color:#999; margin-top:.5rem;
    }
    #item-page-lp-gr5 .cmp-sizesel{
        display:flex; gap:.6rem; margin:1rem 0 .5rem; justify-content:center;
    }
    #item-page-lp-gr5 .cmp-sizesel button{
        flex:1; max-width:8rem;
        background:#fff; border:1px solid #d8d0c0; color:#666;
        padding:1rem 0; font-size:1.35rem; font-weight:500; letter-spacing:.05em;
        cursor:pointer; transition:all .15s; font-family:inherit;
    }
    #item-page-lp-gr5 .cmp-sizesel button:hover{ border-color:#b8a88a; color:#1a1a1a; }
    #item-page-lp-gr5 .cmp-sizesel button.active{
        background:#1a1a1a; border-color:#1a1a1a; color:#fff;
    }
    #item-page-lp-gr5 table.cmpt{
        width:100%; border-collapse:collapse; font-size:1.3rem; margin-top:.8rem; background:#fff;
    }
    #item-page-lp-gr5 table.cmpt th,
    #item-page-lp-gr5 table.cmpt td{
        padding:1rem .6rem; text-align:center; border-bottom:1px solid #eee;
    }
    #item-page-lp-gr5 table.cmpt thead th{
        background:#f5f3f0; color:#1a1a1a; font-size:1.2rem; letter-spacing:.05em; font-weight:500;
    }
    #item-page-lp-gr5 table.cmpt td.lbl{
        text-align:left; font-size:1.2rem; padding-left:1.2rem; color:#1a1a1a; font-weight:500;
    }
    #item-page-lp-gr5 table.cmpt tr.me td{ background:#f5f3f0; font-weight:600; }
    #item-page-lp-gr5 table.cmpt tr.me td.lbl{ background:#f5f3f0; color:#1a1a1a; }
    #item-page-lp-gr5 table.cmpt tr.diff-row td{
        background:#fafaf7; font-size:1.25rem; color:#b8a88a;
        border-top:1px solid #e8e0d0; font-weight:600; letter-spacing:.02em;
    }
    #item-page-lp-gr5 table.cmpt tr.diff-row td.lbl{
        background:#fafaf7; color:#b8a88a; font-size:1.2rem; font-weight:600;
    }
    #item-page-lp-gr5 table.cmpt tr.diff-row td.zero{ color:#bbb; font-weight:400; }
    #item-page-lp-gr5 .cmp-summary{
        background:#f5f3f0; padding:1.4rem 1.6rem; margin-top:1.6rem;
        font-size:1.25rem; line-height:1.8; color:#1a1a1a;
        border-left:3px solid #b8a88a;
    }

    /* スタッフ試着 */
    #item-page-lp-gr5 .model-grid{
        display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-bottom:2rem;
    }
    #item-page-lp-gr5 .model-card{
        background:#fafaf7; overflow:hidden; border:1px solid #eee;
    }
    #item-page-lp-gr5 .model-img-wrap{
        position:relative; aspect-ratio:3/4; overflow:hidden; background:#eee;
    }
    #item-page-lp-gr5 .model-img-wrap img{ width:100%; height:100%; object-fit:cover; }
    #item-page-lp-gr5 .model-img-wrap .ph-tag{
        position:absolute; top:.8rem; right:.8rem;
        background:rgba(184,168,138,.95); color:#fff;
        padding:.3rem .8rem; font-size:1rem; letter-spacing:.1em; font-weight:500;
    }
    #item-page-lp-gr5 .model-card .mname{
        font-size:1.4rem; font-weight:600; padding:1.2rem 1.2rem 0;
        color:#1a1a1a; letter-spacing:.03em;
    }
    #item-page-lp-gr5 .model-card .mmeta{
        font-size:1.15rem; color:#888; padding:.3rem 1.2rem 1.2rem; line-height:1.5;
    }
    #item-page-lp-gr5 .model-note{
        font-size:1.2rem; color:#888; margin-top:2rem; line-height:1.8;
    }
    #item-page-lp-gr5 .model-note b{ color:#b8a88a; }

    /* スペース広げ：着用イメージカードと素材情報 */
    #item-page-lp-gr5 .size-fit-inner > .card:last-of-type{ padding:3rem 3rem 4rem; margin-bottom:0; }
    #item-page-lp-gr5 .spec-grid{ margin-top:5rem; gap:1.6rem 3rem; }
    #item-page-lp-gr5 .spec-item{ padding:1.2rem 0; font-size:1.5rem; }

    @media screen and (max-width: 768px){
        #item-page-lp-gr5 .size-fit-inner .card{ padding:2rem; }
        #item-page-lp-gr5 .block-title{ font-size:1.8rem; }
        #item-page-lp-gr5 .block-num{ font-size:1.2rem; }
        #item-page-lp-gr5 .block-sub{ display:block; flex-basis:100%; margin-top:.4rem; }
        #item-page-lp-gr5 .fit-result .ans{ font-size:3rem; }
        #item-page-lp-gr5 .model-grid{ grid-template-columns:repeat(3,1fr); gap:.8rem; }
        #item-page-lp-gr5 .model-card .mname{ font-size:1.2rem; padding:.8rem .6rem 0; }
        #item-page-lp-gr5 .model-card .mmeta{ font-size:1rem; padding:.2rem .6rem .8rem; }
        #item-page-lp-gr5 .cmp-images{ gap:.8rem; }
        #item-page-lp-gr5 .cmp-img-card{ flex:0 1 130px; max-width:130px; }
        #item-page-lp-gr5 .cmp-img-link{ flex:0 1 130px; max-width:130px; }
        #item-page-lp-gr5 .spec-grid{ margin-top:4rem; }
    }




    /* ===== 信頼の証明：補足タイトル（追加） ===== */
    #item-page-lp-gr5 .trust-head {
        text-align: center;
        margin-bottom: 3.2rem;
    }
    #item-page-lp-gr5 .trust-eyebrow {
        font-family: 'Inter', sans-serif;
        font-size: 1.2rem;
        font-weight: 600;
        letter-spacing: 3px;
        color: #b8a88a;
        margin-bottom: 0.8rem;
    }
    #item-page-lp-gr5 .trust-title {
        font-size: 2.4rem;
        font-weight: 700;
        color: #1a1a1a;
        line-height: 1.4;
        margin-bottom: 0;
    }

    /* ===== あと1枚で完成（ジャケット併売 / oj3259）追加 ===== */
    #item-page-lp-gr5 .complete-set {
        background: #f5f3f0;
    }
    #item-page-lp-gr5 .complete-inner {
        display: grid;
        grid-template-columns: 0.85fr 1fr;
        gap: 4.8rem;
        align-items: center;
    }
    #item-page-lp-gr5 .complete-media img {
        width: 100%;
        border-radius: 8px;
        display: block;
    }
    #item-page-lp-gr5 .complete-eyebrow {
        font-family: 'Inter', sans-serif;
        font-size: 1.2rem;
        font-weight: 600;
        letter-spacing: 1.5px;
        color: #b8a88a;
        margin-bottom: 1.2rem;
    }
    #item-page-lp-gr5 .complete-body h2 {
        font-size: clamp(2.4rem, 3vw, 3.2rem);
        line-height: 1.4;
        margin-bottom: 1.6rem;
    }
    #item-page-lp-gr5 .complete-body > p {
        color: #555;
        font-size: 1.6rem;
        line-height: 1.9;
        margin-bottom: 2.4rem;
    }
    #item-page-lp-gr5 .complete-prod {
        display: flex;
        align-items: center;
        gap: 1.6rem;
        border-top: 1px solid #e8e4de;
        border-bottom: 1px solid #e8e4de;
        padding: 1.6rem 0;
        margin-bottom: 2.4rem;
    }
    #item-page-lp-gr5 .complete-prod img {
        width: 64px;
        aspect-ratio: 3/4;
        object-fit: cover;
        border-radius: 4px;
        flex-shrink: 0;
    }
    #item-page-lp-gr5 .complete-prod-name {
        font-size: 1.6rem;
        font-weight: 700;
        color: #1a1a1a;
    }
    #item-page-lp-gr5 .complete-prod-meta {
        font-size: 1.36rem;
        color: #999;
    }
    #item-page-lp-gr5 .complete-actions {
        display: flex;
        align-items: center;
        gap: 2rem;
        flex-wrap: wrap;
    }
    #item-page-lp-gr5 .complete-cta {
        display: inline-flex;
        align-items: center;
        gap: 0.8rem;
        background: #1a1a1a;
        color: #fff;
        text-decoration: none;
        font-size: 1.52rem;
        font-weight: 700;
        padding: 1.4rem 3.2rem;
        border-radius: 6px;
        transition: opacity 0.2s ease;
    }
    #item-page-lp-gr5 .complete-cta:hover { opacity: 0.85; }
    #item-page-lp-gr5 .complete-sublink {
        font-size: 1.44rem;
        color: #555;
        text-decoration: none;
        border-bottom: 1px solid #ccc;
        padding-bottom: 2px;
    }
    @media (max-width: 768px) {
        #item-page-lp-gr5 .complete-inner {
            grid-template-columns: 1fr;
            gap: 2.4rem;
        }
        #item-page-lp-gr5 .complete-media {
            max-width: 320px;
            margin: 0 auto;
        }
        #item-page-lp-gr5 .trust-title { font-size: 2rem; }
    }

    /* ===== 悩み：3カード（スッキリ版） ===== */
    #item-page-lp-gr5 .pain-cards {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 2.4rem;
        max-width: 960px;
        margin: 0 auto 4rem;
    }
    #item-page-lp-gr5 .pain-card {
        background: #fff;
        border: 1px solid #f0ede8;
        border-radius: 12px;
        padding: 3.2rem 2.8rem;
        text-align: left;
    }
    #item-page-lp-gr5 .pain-no {
        font-family: 'Inter', sans-serif;
        font-size: 1.36rem;
        font-weight: 700;
        color: #b8a88a;
        letter-spacing: 2px;
        margin-bottom: 1.2rem;
    }
    #item-page-lp-gr5 .pain-card h3 {
        font-size: 1.68rem;
        margin-bottom: 0.8rem;
        color: #1a1a1a;
        line-height: 1.6;
    }
    #item-page-lp-gr5 .pain-card p {
        font-size: 1.44rem;
        color: #666;
        line-height: 1.7;
        margin: 0;
    }

    /* ===== CODE SYSTEM：均一3ステップ（スッキリ版） ===== */
    #item-page-lp-gr5 .container-wrapper.cs-wide {
        width: 90%;
        max-width: 1080px;
    }
    #item-page-lp-gr5 .cs-steprow {
        display: grid;
        grid-template-columns: 1fr auto 1.8fr auto 1fr;
        align-items: stretch;
        max-width: 100%;
        margin: 0 auto 4rem;
    }
    #item-page-lp-gr5 .cs-stepcard {
        background: #fff;
        border: 1px solid #e8e4de;
        border-radius: 12px;
        padding: 2.4rem 1.8rem;
        text-align: center;
        display: flex;
        flex-direction: column;
    }
    #item-page-lp-gr5 .cs-stepcard.is-now {
        border: 2px solid #b8a88a;
        background: #fefcf7;
    }
    #item-page-lp-gr5 .cs-stepcard.is-jacket {
        border-color: #d9cdb6;
        box-shadow: 0 6px 22px rgba(184,168,138,0.12);
    }
    #item-page-lp-gr5 .cs-step-num {
        display: flex; align-items: center; justify-content: center;
        width: 3.2rem; height: 3.2rem; border-radius: 50%;
        border: 1.5px solid #b8a88a; color: #b8a88a;
        font-family: 'Inter', sans-serif; font-weight: 700; font-size: 1.28rem;
        margin: 0 auto 0.8rem;
    }
    #item-page-lp-gr5 .cs-step-label {
        font-family: 'Inter', sans-serif; font-size: 1.04rem; font-weight: 700;
        letter-spacing: 1.5px; color: #b8a88a; margin-bottom: 0.3rem;
    }
    #item-page-lp-gr5 .cs-step-main {
        font-size: 1.6rem; font-weight: 700; color: #1a1a1a; margin-bottom: 1.6rem;
    }
    #item-page-lp-gr5 .cs-thumb {
        display: block; border-radius: 6px; overflow: hidden;
        background: #faf8f4; margin-bottom: 1.2rem;
    }
    #item-page-lp-gr5 .cs-thumb img {
        width: 100%; aspect-ratio: 3/4; object-fit: cover; object-position: top;
        display: block; max-height: 220px;
    }
    #item-page-lp-gr5 .cs-trio {
        display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.6rem; margin-bottom: 1.2rem;
    }
    #item-page-lp-gr5 .cs-trio a {
        display: block; border-radius: 4px; overflow: hidden; background: #faf8f4;
    }
    #item-page-lp-gr5 .cs-trio img {
        width: 100%; aspect-ratio: 3/4; object-fit: cover; object-position: top; display: block;
    }
    #item-page-lp-gr5 .cs-step-prod {
        font-size: 1.36rem; font-weight: 700; color: #1a1a1a; margin-bottom: 0.3rem;
    }
    #item-page-lp-gr5 .cs-step-tag {
        font-size: 1.2rem; color: #999; margin-top: auto;
    }
    #item-page-lp-gr5 .cs-stepcard.is-now .cs-step-tag {
        color: #8a7a5c; font-weight: 600;
    }
    #item-page-lp-gr5 .cs-step-cta {
        display: inline-block; margin-top: 1.4rem;
        font-size: 1.28rem; font-weight: 700; color: #fff; background: #1a1a1a;
        text-decoration: none; padding: 1rem 1.6rem; border-radius: 6px;
        transition: opacity 0.2s ease;
    }
    #item-page-lp-gr5 .cs-step-cta:hover { opacity: 0.85; }
    #item-page-lp-gr5 .cs-step-conn {
        display: flex; align-items: center; justify-content: center;
        color: #b8a88a; font-size: 1.8rem; padding: 0 0.8rem;
    }

    /* タブレット以下：3ステップを縦積み（中間幅の潰れ対策） */
    @media (max-width: 1024px) {
        #item-page-lp-gr5 .cs-steprow {
            grid-template-columns: 1fr;
            gap: 1.2rem;
            max-width: 480px;
        }
        #item-page-lp-gr5 .cs-step-conn { transform: rotate(90deg); padding: 0.4rem 0; }
    }
    @media (max-width: 768px) {
        #item-page-lp-gr5 .pain-cards { grid-template-columns: 1fr; gap: 1.6rem; }
        #item-page-lp-gr5 .cs-thumb img { max-height: none; }
    }



    /* __img-guard-fix : 画像/動画のはみ出し防止（width=800のコーデ画像等が横スクロール・フルブリード破綻を起こすのを防ぐ） */
    #item-page-lp-gr5 img, #item-page-lp-gr5 video,
    #product-page_auen-first img {
        max-width: 100%;
        height: auto;
    }


/* ===== __jacket-special : STEP3ジャケット(oj3259)を特別仕様に（あと1枚で完成の格上げ） ===== */
#item-page-lp-gr5 .cs-vstep.is-step3 .cs-card.is-jacket{
    position: relative;
    border: 1.5px solid #d9cdb6;
    background: linear-gradient(180deg,#fffdf8 0%,#fbf5ea 100%);
    box-shadow: 0 8px 26px rgba(184,168,138,0.18);
}
#item-page-lp-gr5 .cs-jacket-badge{
    position: absolute; top: -11px; left: 16px; z-index: 2;
    background: #b8a88a; color: #fff;
    font-size: 1.04rem; font-weight: 700; letter-spacing: 0.08em;
    padding: 0.34rem 0.9rem; border-radius: 999px;
    box-shadow: 0 2px 8px rgba(184,168,138,0.35); white-space: nowrap;
}
#item-page-lp-gr5 .cs-vstep.is-step3 .cs-card.is-jacket .cs-card-role{ color: #8a7a5c; }
/* CTAを弱いテキストリンク → 実ボタンに格上げ */
#item-page-lp-gr5 .cs-vstep.is-step3 .cs-card.is-jacket .cs-card-cta{
    display: inline-block; margin-top: 0.5rem;
    background: #1a1a1a; color: #fff; border: none; border-radius: 6px;
    padding: 0.7rem 1.4rem; font-weight: 700; letter-spacing: 0.02em;
}
#item-page-lp-gr5 a.cs-card.is-jacket:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 30px rgba(184,168,138,0.26);
    border-color: #c9b58e;
}
@media (max-width: 768px){
    #item-page-lp-gr5 .cs-vstep.is-step3 .cs-card.is-jacket{ padding-top: 1.1rem; }
    #item-page-lp-gr5 .cs-jacket-badge{ top: -9px; left: 10px; font-size: 0.96rem; padding: 0.28rem 0.7rem; }
    #item-page-lp-gr5 .cs-vstep.is-step3 .cs-card.is-jacket .cs-card-cta{ padding: 0.55rem 1rem; }
}


/* ===== __complete-prod-link : 併売の商品情報ブロック全体をリンク化（どこを押しても遷移） ===== */
#item-page-lp-gr5 a.complete-prod{
    text-decoration: none;
    color: inherit;
    transition: opacity 0.2s ease;
    cursor: pointer;
}
#item-page-lp-gr5 a.complete-prod:hover{ opacity: 0.82; }
