/* =================================================
   物流・出荷管理ラベル カテゴリーページ
   ================================================= */

/* Hero
   ------------------------------------------------- */
.logistics-hero {
    position: relative;
    color: var(--color-white);
    padding-bottom: 0;
}

.logistics-hero__inner {
    position: relative;
    padding: 22rem 0 18rem;
    background:
        linear-gradient(90deg, rgba(21, 45, 42, 0.88) 0%, rgba(21, 45, 42, 0.72) 48%, rgba(21, 45, 42, 0.4) 100%),
        url('../../images/label-lineup/logistics-label/top_hero.webp');
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
}

.logistics-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    margin-bottom: var(--space-sm);
    padding: 0.45rem 0.9rem;
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.16);
    color: var(--color-white);
    font-size: var(--font-sm);
    font-weight: 700;
}

.logistics-hero__title {
    font-size: var(--font-5xl);
    font-weight: 700;
    letter-spacing: 0;
    margin-bottom: var(--space-sm);
}

.logistics-hero__lead {
    max-width: 820px;
    font-size: var(--font-xl);
    line-height: 1.85;
    opacity: 0.96;
}

.logistics-hero__actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
}

.logistics-hero__actions .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.logistics-hero__actions .btn--outline {
    border-color: rgba(255, 255, 255, 0.84);
    color: var(--color-white);
    background: rgba(255, 255, 255, 0.08);
}

.logistics-hero__actions .btn--outline:hover {
    background: rgba(255, 255, 255, 0.18);
}

.logistics-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: var(--space-lg);
    max-width: 820px;
}

.logistics-hero__chips li {
    flex: 0 0 auto;
    padding: 0.45rem 0.85rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #183c35;
    font-size: var(--font-sm);
    font-weight: 700;
    white-space: nowrap;
}

.breadcrumb-container {
    background-color: var(--color-white);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    padding: var(--space-md) 0;
}

.breadcrumb--dark {
    display: flex;
    justify-content: flex-start;
    margin: 0;
}

.breadcrumb--dark .breadcrumb__item {
    color: var(--color-secondary);
    padding: 0 1.5rem;
    position: relative;
}

.breadcrumb--dark .breadcrumb__item:not(:last-child)::after {
    content: '\203A';
    position: absolute;
    right: 0;
    color: var(--color-secondary);
}

.breadcrumb--dark .breadcrumb__item a {
    color: var(--color-primary);
    text-decoration: none;
}

.breadcrumb--dark .breadcrumb__item a:hover {
    text-decoration: underline;
    opacity: 0.8;
}

/* Promise
   ------------------------------------------------- */
.logistics-promise {
    padding: var(--space-2xl) 0;
    background: var(--color-white);
}

.logistics-promise__lead {
    font-size: var(--font-xl);
    font-weight: 700;
    line-height: 1.9;
    color: #183c35;
    margin-bottom: var(--space-md);
}

.logistics-promise__text {
    font-size: var(--font-lg);
    line-height: 1.9;
    color: var(--color-text);
}

/* Routing
   ------------------------------------------------- */
.logistics-routing {
    padding: var(--space-3xl) 0;
    background: #f4f7f4;
}

.logistics-routing__header {
    max-width: 900px;
    margin: 0 auto var(--space-2xl);
    text-align: center;
}

.logistics-routing__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-md);
}

.logistics-routing__card {
    display: grid;
    gap: var(--space-xs);
    min-height: 100%;
    padding: var(--space-lg);
    border: 1px solid rgba(24, 60, 53, 0.14);
    border-radius: 8px;
    background: var(--color-white);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 14px 32px rgba(20, 48, 45, 0.07);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.logistics-routing__card:hover {
    transform: translateY(-4px);
    border-color: rgba(35, 119, 93, 0.42);
    box-shadow: 0 20px 42px rgba(20, 48, 45, 0.12);
}

.logistics-routing__card span {
    width: fit-content;
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    background: #fff3cf;
    color: #7d5a00;
    font-size: var(--font-sm);
    font-weight: 700;
}

.logistics-routing__card h3 {
    color: #183c35;
    font-size: var(--font-lg);
    font-weight: 700;
    line-height: 1.5;
}

.logistics-routing__card p {
    color: var(--color-text);
    line-height: 1.75;
}

/* Intro
   ------------------------------------------------- */
.logistics-intro {
    padding: var(--space-3xl) 0;
    background: var(--color-white);
}

.logistics-intro__content {
    max-width: 1020px;
    margin: 0 auto;
    text-align: center;
}

.logistics-intro__list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-lg);
    margin-top: var(--space-2xl);
}

.logistics-intro__list li {
    background: var(--color-white);
    border: 1px solid rgba(24, 60, 53, 0.12);
    border-radius: 8px;
    padding: var(--space-lg);
    box-shadow: 0 14px 32px rgba(20, 48, 45, 0.07);
    text-align: left;
}

.logistics-intro__list h3 {
    font-size: var(--font-xl);
    font-weight: 700;
    color: #183c35;
    margin-bottom: var(--space-sm);
}

.logistics-intro__list p {
    line-height: 1.8;
    color: var(--color-text);
}

/* Spec table
   ------------------------------------------------- */
.logistics-process {
    padding: var(--space-3xl) 0;
    background: #fbfaf5;
}

.logistics-process__inner {
    max-width: 1040px;
    margin: 0 auto;
}

.logistics-process__inner p {
    font-size: var(--font-lg);
    line-height: 1.9;
    color: var(--color-text);
    margin-bottom: var(--space-md);
}

.logistics-spec-table {
    margin-top: var(--space-xl);
    overflow-x: auto;
    border: 1px solid rgba(24, 60, 53, 0.12);
    border-radius: 8px;
    background: var(--color-white);
    box-shadow: 0 16px 36px rgba(20, 48, 45, 0.08);
}

.logistics-spec-table table {
    width: 100%;
    min-width: 900px;
    border-collapse: collapse;
}

.logistics-spec-table th,
.logistics-spec-table td {
    padding: 1.35rem 1.2rem;
    border-bottom: 1px solid rgba(24, 60, 53, 0.1);
    text-align: left;
    vertical-align: top;
    line-height: 1.75;
}

.logistics-spec-table thead th {
    background: #183c35;
    color: var(--color-white);
    font-weight: 700;
}

.logistics-spec-table tbody th {
    width: 20%;
    color: #183c35;
    font-weight: 700;
}

.logistics-spec-table tbody tr:last-child th,
.logistics-spec-table tbody tr:last-child td {
    border-bottom: none;
}

.logistics-spec-table tbody tr:nth-child(even) {
    background: #f7faf8;
}

/* Cases
   ------------------------------------------------- */
.logistics-gallery {
    padding: var(--space-3xl) 0;
    background: var(--color-white);
}

.logistics-gallery__header {
    text-align: center;
    max-width: 860px;
    margin: 0 auto var(--space-2xl);
}

.logistics-case-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-lg);
}

.logistics-case-card {
    display: block;
    overflow: hidden;
    border: 1px solid rgba(24, 60, 53, 0.1);
    border-radius: 8px;
    background: var(--color-white);
    color: inherit;
    text-decoration: none;
    box-shadow: 0 16px 36px rgba(20, 48, 45, 0.08);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.logistics-case-card:hover {
    transform: translateY(-5px);
    border-color: rgba(35, 119, 93, 0.38);
    box-shadow: 0 24px 50px rgba(20, 48, 45, 0.12);
}

.logistics-case-card img {
    width: 100%;
    aspect-ratio: 3 / 2;
    display: block;
    object-fit: cover;
    object-position: center;
    background: #eef5f0;
    transition: transform 0.3s ease;
}

.logistics-case-card:hover img {
    transform: scale(1.04);
}

.logistics-case-card__body {
    display: grid;
    gap: var(--space-xs);
    padding: var(--space-lg);
}

.logistics-case-card__body span {
    width: fit-content;
    padding: 0.28rem 0.75rem;
    border-radius: 999px;
    background: #ecf6ef;
    color: #2f6e42;
    font-size: var(--font-sm);
    font-weight: 700;
}

.logistics-case-card__body h3 {
    color: #183c35;
    font-size: var(--font-xl);
    font-weight: 700;
    line-height: 1.45;
}

.logistics-case-card__body p {
    color: var(--color-text);
    line-height: 1.75;
}

.logistics-gallery__cta {
    text-align: center;
    margin-top: var(--space-2xl);
}

/* Articles
   ------------------------------------------------- */
.logistics-articles {
    padding: var(--space-3xl) 0;
    background: #f4f7f4;
}

.logistics-articles__header {
    text-align: center;
    max-width: 880px;
    margin: 0 auto var(--space-2xl);
}

.logistics-articles__list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-lg);
}

.logistics-article-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
    background: var(--color-white);
    border-radius: 8px;
    text-decoration: none;
    color: inherit;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    box-shadow: 0 16px 36px rgba(20, 48, 45, 0.08);
}

.logistics-article-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 24px 48px rgba(20, 48, 45, 0.12);
}

.logistics-article-card__image {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: #e4eee6;
}

.logistics-article-card__image img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
    transition: transform 0.3s ease;
}

.logistics-article-card:hover .logistics-article-card__image img {
    transform: scale(1.04);
}

.logistics-article-card__body {
    display: grid;
    gap: var(--space-xs);
    padding: var(--space-lg) var(--space-lg) 0;
}

.logistics-article-card__tag {
    display: inline-block;
    width: fit-content;
    padding: 0.3rem 1rem;
    border-radius: 999px;
    background: rgba(24, 60, 53, 0.12);
    color: #183c35;
    font-size: var(--font-sm);
    font-weight: 700;
}

.logistics-article-card__title {
    font-size: var(--font-xl);
    font-weight: 700;
    line-height: 1.45;
}

.logistics-article-card__text {
    line-height: 1.8;
    color: var(--color-text);
}

.logistics-article-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0 var(--space-lg) var(--space-lg);
    font-weight: 600;
    color: #183c35;
}

/* Support
   ------------------------------------------------- */
.logistics-support {
    padding: var(--space-3xl) 0;
    background: linear-gradient(135deg, #183c35 0%, #2f6e42 100%);
    color: var(--color-white);
}

.logistics-support__inner {
    max-width: 1080px;
    margin: 0 auto;
    text-align: center;
    display: grid;
    gap: var(--space-lg);
}

.logistics-support .section-title {
    color: var(--color-white);
    font-size: var(--font-5xl);
}

.logistics-support__text {
    line-height: 1.9;
    margin: var(--space-md) 0;
    color: rgba(255, 255, 255, 0.9);
    font-size: var(--font-xl);
}

.logistics-support__cta {
    display: flex;
    gap: var(--space-md);
    justify-content: center;
    flex-wrap: wrap;
}

.logistics-support__cta .btn--outline {
    border-color: rgba(255, 255, 255, 0.84);
    color: var(--color-white);
    background: rgba(255, 255, 255, 0.08);
}

/* FAQ
   ------------------------------------------------- */
.logistics-faq {
    padding: var(--space-3xl) 0;
    background: var(--color-white);
}

.logistics-faq__header {
    text-align: center;
    max-width: 820px;
    margin: 0 auto var(--space-2xl);
}

.logistics-faq__items {
    display: grid;
    gap: var(--space-lg);
}

.logistics-faq__item {
    border: 1px solid rgba(24, 60, 53, 0.18);
    border-radius: 8px;
    padding: var(--space-lg);
    box-shadow: 0 12px 28px rgba(20, 48, 45, 0.06);
    background: var(--color-white);
}

.logistics-faq__question {
    font-size: var(--font-xl);
    font-weight: 700;
    color: #183c35;
    margin-bottom: var(--space-sm);
}

.logistics-faq__answer p {
    line-height: 1.8;
    color: var(--color-text);
}

.logistics-faq__cta {
    margin-top: var(--space-2xl);
    display: flex;
    justify-content: center;
    gap: var(--space-md);
    flex-wrap: wrap;
}

/* Bottom CTA
   ------------------------------------------------- */
.logistics-bottom-cta {
    padding: var(--space-3xl) 0;
    background: linear-gradient(135deg, #fbfaf5 0%, #ffffff 100%);
}

.logistics-bottom-cta__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-lg);
    background: var(--color-white);
    padding: var(--space-xl);
    border: 1px solid rgba(24, 60, 53, 0.1);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(20, 48, 45, 0.08);
}

.logistics-bottom-cta__content h2 {
    font-size: var(--font-3xl);
    margin-bottom: var(--space-sm);
    color: #183c35;
}

.logistics-bottom-cta__content p {
    font-size: var(--font-md);
    color: var(--color-text);
    line-height: 1.7;
}

.logistics-bottom-cta__actions {
    display: flex;
    gap: var(--space-md);
    flex-wrap: wrap;
}

/* Responsive
   ------------------------------------------------- */
@media (max-width: 1200px) {
    .logistics-routing__grid,
    .logistics-intro__list,
    .logistics-articles__list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 960px) {
    .logistics-hero__inner {
        padding: 17rem 0 13rem;
    }

    .logistics-hero__title {
        font-size: var(--font-4xl);
    }

    .logistics-hero__lead {
        font-size: var(--font-lg);
    }

    .logistics-hero__actions {
        align-items: stretch;
        max-width: 580px;
    }

    .logistics-case-grid {
        grid-template-columns: 1fr;
    }

    .logistics-bottom-cta__inner {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 768px) {
    .logistics-hero__inner {
        padding: 13rem 0 9rem;
        background:
            linear-gradient(rgba(21, 45, 42, 0.82), rgba(21, 45, 42, 0.66)),
            url('../../images/label-lineup/logistics-label/top_hero.webp');
        background-size: cover;
        background-position: 66% center;
    }

    .logistics-hero__title {
        font-size: var(--font-3xl);
    }

    .logistics-hero__lead {
        font-size: var(--font-md);
    }

    .logistics-hero__actions {
        flex-direction: column;
    }

    .logistics-hero__actions .btn {
        width: 100%;
        justify-content: center;
    }

    .logistics-hero__chips {
        gap: 0.6rem;
    }

    .logistics-routing__grid,
    .logistics-intro__list,
    .logistics-articles__list {
        grid-template-columns: 1fr;
    }

    .logistics-spec-table {
        margin-right: calc(var(--space-md) * -1);
        border-right: none;
        border-radius: 8px 0 0 8px;
    }

    .logistics-case-card img {
        width: calc(100% - 20px);
        max-width: 520px;
        height: clamp(180px, 50vw, 260px);
        margin: var(--space-sm) auto 0;
        border-radius: 6px;
        object-fit: contain;
        object-position: center;
        background: #f7faf8;
    }

    .logistics-article-card__image {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: var(--space-sm);
        aspect-ratio: auto;
        background: #f7faf8;
    }

    .logistics-article-card__image img {
        width: 100%;
        max-width: 520px;
        height: clamp(170px, 48vw, 230px);
        max-height: none;
        object-fit: contain;
        object-position: center;
    }

    .logistics-support .section-title {
        font-size: var(--font-3xl);
    }

    .logistics-bottom-cta__content h2 {
        font-size: var(--font-2xl);
    }
}

@media (max-width: 576px) {
    .logistics-hero__inner {
        padding: 11rem 0 7rem;
    }

    .logistics-hero__title {
        font-size: var(--font-2xl);
    }

    .logistics-hero__chips li {
        font-size: var(--font-sm);
    }

    .logistics-routing__card,
    .logistics-intro__list li,
    .logistics-case-card__body,
    .logistics-article-card__body {
        padding: var(--space-md);
    }

    .logistics-article-card__link {
        padding: 0 var(--space-md) var(--space-md);
    }

    .logistics-bottom-cta__inner {
        padding: var(--space-lg);
    }
}
