/* ============================================================
   COMMON.CSS — Plusらぼ サイトリニューアル
   共通スタイル（変数・リセット・コンポーネント・ヘッダー・フッター）
   ============================================================ */

/* ----------------------------------------------------------
   カスタムプロパティ
   ---------------------------------------------------------- */
:root {
  /* Colors */
    --color-bg:             #F7F5F1;   /* クリーム（メイン背景） */
    --color-text:           #424242;   /* ほぼ黒 */
    --color-white:          #ffffff;
    --color-primary:        #005149;
    --color-accent-lime:    #A8BD38;
    --color-accent-orange:  #E29339;
    --color-bg-sub:         #EDEBE5;   /* サブ背景（薄クリーム） */
    --color-footer-bg:      #424242;   /* フッター背景 */


    /* Typography */
    --font-base: "LINE Seed JP", "Noto Sans JP", sans-serif;

    /* Layout */
    --container-max: 1728px;
    --header-h:      clamp(60px, calc(80 / 1728 * 100vw), 80px);

    /* Easing */
    --ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* LINE Seed JP — /fonts/ にファイルを配置後に有効化 */
/*
@font-face {
    font-family: "LINE Seed JP";
    src: url("../fonts/LINESeedJP_OTF_Rg.woff2") format("woff2");
    font-weight: 400;
    font-display: swap;
}
@font-face {
    font-family: "LINE Seed JP";
    src: url("../fonts/LINESeedJP_OTF_Bd.woff2") format("woff2");
    font-weight: 700;
    font-display: swap;
}
*/

/* ----------------------------------------------------------
   リセット / ベース
   ---------------------------------------------------------- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-base);
    font-size: clamp(14px, calc(16 / 1728 * 100vw), 16px);
    line-height: 1.75;
    color: var(--color-text);
    background-color: var(--color-bg);
}

body.is-menu-open {
    overflow: hidden; /* 開いている時にスクロールさせない */
}

img {
    height: auto;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

ul, ol {
    list-style: none;
}

/* ----------------------------------------------------------
   ユーティリティ
   ---------------------------------------------------------- */
.u-pc-br {
    display: inline;
}

@media (max-width: 768px) {
    .u-pc-br {
        display: none;
    }
}

/* ----------------------------------------------------------
   コンポーネント：ボタン (.c-btn)
   ---------------------------------------------------------- */
   .c-btn {
    position: relative; /* 追加 */
    max-width: fit-content;
    display: inline-flex;
    align-items: center;
    gap: clamp(8px, calc(10 / 1728 * 100vw), 10px);
    border-bottom: solid 2px var(--color-text);
    padding-block: clamp(6px, calc(28 / 1728 * 100vw), 14px);
    font-size: clamp(13px, calc(15 / 1728 * 100vw), 15px);
    font-weight: 700;
    transition: color 0.25s var(--ease-out);
}

/* カーテンアニメーション用擬似要素 */
.c-btn::before {
    content: '';
    position: absolute;
    bottom: -2px; /* border-bottom に重なる位置 */
    left: 0;
    width: 0;
    height: 2px;
    background-color: var(--color-accent-orange);
    transition: width 0.3s var(--ease-out);
}

.c-btn:hover::before {
    width: 100%;
}

.c-btn .c-btn__icon {
    width: 55px;
    height: 35px;
    border-radius: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
    padding: 4px 8px;
    background-color: var(--color-text);
    transition: transform 0.25s var(--ease-out), background-color 0.25s var(--ease-out);
}

.c-btn .c-btn__icon::after {
    content: '→';
    color: #fff;
    font-size: 20px;
}

.c-btn:hover {
    color: var(--color-accent-orange);
}


.c-btn:hover .c-btn__icon {
    transform: translateX(4px);
    background-color: var(--color-accent-orange);
}




/* お問い合わせボタン（ヘッダー専用） */
.c-btn-contact {
    display: inline-flex;
    align-items: center;
    padding:
        clamp(8px, calc(10 / 1728 * 100vw), 10px)
        clamp(14px, calc(20 / 1728 * 100vw), 20px);
    border-radius: 100px;
    background-color: var(--color-contact-btn);
    font-size: clamp(12px, calc(14 / 1728 * 100vw), 14px);
    font-weight: 700;
    color: var(--color-text);
    transition: opacity 0.25s var(--ease-out);
}

.c-btn-contact:hover {
    opacity: 0.82;
}

/* ----------------------------------------------------------
   コンポーネント：ラベル (.c-label)
   ---------------------------------------------------------- */
.c-label {
    display: inline-block;
    font-size: clamp(11px, calc(13 / 1728 * 100vw), 13px);
    font-weight: 700;
    color: var(--color-primary);
    letter-spacing: 0.04em;
}

.c-label--lime {
    color: var(--color-accent-lime);
}

/* ----------------------------------------------------------
    レイアウト：ヘッダー (.l-header)
   ---------------------------------------------------------- */

/* Header Styles */
.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100px;
    background-color: transparent;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 40px;
    box-sizing: border-box;
    z-index: 1000;
    transition: background-color 0.3s ease;
}

.header.is-open {
    background-color: transparent;
    z-index: 1004;
}

.header.is-open .header__logo,
.header.is-open .header__contact {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

.header__logo {
    display: flex;
    align-items: center;
    max-width: clamp(120px, 13vw, 200px);
}

.header__logo img {
    width: 100%;
    height: auto;
}

.header__right {
    display: flex;
    align-items: center;
    gap: 30px;
}

.header__contact {
    position: relative;
    display: flex;
    align-items: center;
    color: var(--color-text);
    text-decoration: none;
    font-size: 18px;
    font-weight: bold;
    border-bottom: solid 2px var(--color-text);
    padding-bottom: 4px;
    transition: color 0.25s var(--ease-out);
}

/* カーテンアニメーション（c-btn と同じ） */
.header__contact::before {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background-color: var(--color-accent-orange);
    transition: width 0.3s var(--ease-out);
}

.header__contact:hover::before {
    width: 100%;
}

.header__contact-btn {
    background-color: #444;
    width: 55px;
    height: 40px;
    border-radius: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-left: 10px;
    position: relative;
    transition: background-color 0.25s var(--ease-out), transform 0.25s var(--ease-out);
}

.header__contact-btn::after {
    content: '→';
    color: #fff;
    font-size: 20px;
}

.header__contact:hover {
    color: var(--color-accent-orange);
}
.header__contact:hover .header__contact-btn {
    background-color: var(--color-accent-orange);
    transform: translateX(4px);
}


/* トグルボタン */
.menu-toggle {
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0;
    outline: none;
    position: relative;
    z-index: 1003;
}

.menu-toggle__icon {
    position: relative;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Circles */
.circle {
    position: absolute;
    border: 2px solid var(--color-primary);
    border-radius: 50%;
    box-sizing: border-box;
    /* Default state for menu (Triple Circles) */
    opacity: 1;
    transform: scale(1);
}

.circle--outer { width: 40px; height: 40px; z-index: 3; }
.circle--middle { width: 30px; height: 30px; z-index: 2; }
.circle--inner { width: 20px; height: 20px; z-index: 1; }

/* --- オープンアニメーション (Menu -> Close) --- */
.is-open .circle--outer {
    animation: openOuter 0.6s cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
.is-open .circle--middle {
    animation: shrinkMiddle 0.4s cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
.is-open .circle--inner {
    animation: openInner 0.6s cubic-bezier(0.65, 0, 0.35, 1) forwards;
}

/* --- クローズアニメーション (Close -> Menu) --- */
/* Adding a specific class via JS to trigger close animation */
.is-closing .circle--outer {
    animation: closeOuter 0.6s cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
.is-closing .circle--middle {
    animation: expandMiddle 0.6s cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
.is-closing .circle--inner {
    animation: closeInner 0.6s cubic-bezier(0.65, 0, 0.35, 1) forwards;
}

/* --- KEYFRAMES --- */

/* Open State Keyframes */
@keyframes openOuter {
    0% { width: 40px; height: 40px; opacity: 1; }
    40% { width: 10px; height: 10px; opacity: 0; transform: scale(0.2); }
    100% { width: 40px; height: 40px; opacity: 1; transform: scale(1); }
}
@keyframes shrinkMiddle {
    0% { width: 30px; height: 30px; opacity: 1; }
    100% { width: 10px; height: 10px; opacity: 0; transform: scale(0.2); }
}
@keyframes openInner {
    0% { width: 20px; height: 20px; background-color: transparent; border-width: 2px; }
    40% { width: 10px; height: 10px; background-color: var(--color-primary); border-width: 0; transform: scale(0.5); }
    100% { width: 24px; height: 24px; background-color: var(--color-primary); border-width: 0; transform: scale(1); }
}

/* Close State Keyframes (Returning to Triple Circles) */
@keyframes closeOuter {
    0% { width: 40px; height: 40px; opacity: 1; }
    40% { width: 10px; height: 10px; opacity: 0; transform: scale(0.2); }
    100% { width: 40px; height: 40px; opacity: 1; transform: scale(1); }
}
@keyframes expandMiddle {
    0% { width: 10px; height: 10px; opacity: 0; transform: scale(0.2); }
    40% { width: 10px; height: 10px; opacity: 0; transform: scale(0.2); }
    100% { width: 30px; height: 30px; opacity: 1; transform: scale(1); }
}
@keyframes closeInner {
    0% { width: 24px; height: 24px; background-color: var(--color-primary); border-width: 0; }
    40% { width: 10px; height: 10px; background-color: transparent; border-width: 2px; transform: scale(0.5); }
    100% { width: 20px; height: 20px; background-color: transparent; border-width: 2px; transform: scale(1); }
}

.menu-toggle__text {
    margin-top: 4px;
    font-size: 12px;
    color: var(--color-primary);
    font-weight: bold;
    text-transform: uppercase;
}

/* Full Screen Menu Overlay */
.menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    height: 100dvh;
    background-color: var(--color-white);
    z-index: 1002;
    display: flex;
    flex-direction: column;
    padding: 100px 80px;
    box-sizing: border-box;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s ease;
}

.menu-overlay.is-active {
    opacity: 1;
    visibility: visible;
}

.menu-content {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
    grid-template-rows: calc(100dvh / 6);
    gap: 10px;
    width: 100%;
}

.menu-left {
    grid-column: 3 / 5;
    grid-row: 2 / 6;
}

.menu-title {
    font-size: 32px;
    color: var(--color-primary);
    line-height: 1.4;
    margin-bottom: 1.5rem;
}

.menu-desc {
    font-size: 14px;
    color: #666;
    line-height: 1.8;
    margin-bottom: 7.25rem;
}

.menu-contact-btn {
    display: inline-block;
    background-color: var(--color-accent-orange);
    color: var(--color-white);
    padding: 15px 40px;
    border-radius: 30px;
    text-decoration: none;
    font-weight: bold;
    transition: .2s;
    text-align: center;
}

.menu-contact-btn:hover {
    opacity: 0.8;
}

.menu-links {
    grid-column: 6 / 11;
    grid-row: 2 / 6;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(4, auto);
    grid-auto-flow: column;
    align-content: start;
    column-gap: clamp(2rem, calc(80 / 1728 * 100vw), 5rem);
}

.menu-link-item {
    font-size: clamp(16px, calc(20 / 1728 * 100vw), 20px);
    color: var(--color-text);
    text-decoration: none;
    font-weight: bold;
    display: block;
    margin-bottom: clamp(2.5rem, calc(88 / 1728 * 100vw), 5.5rem);
    transition: .2s;
    white-space: nowrap;
}

.menu-link-item:hover {
    color: var(--color-accent-orange);
}

.menu-footer-logo {
    max-width: 27.314vw;
    position: absolute;
    bottom: 40px;
    right: 80px;
    display: flex;
    align-items: center;
    gap: 15px;
}

.menu-footer-logo img {
    width: 100%;
    height: auto;
}

/* Mobile Styles */
@media (max-width: 768px) {
    .header {
        padding: 0 20px;
        height: 60px;
    }

    .header__logo {
        max-width: 160px;
    }

    .header__contact {
        display: none;
    }

    .menu-toggle {
        position: fixed;
        top: 10px;
        right: 20px;
        z-index: 1003;
    }

    .menu-toggle__icon {
        width: 40px;
        height: 40px;
    }

    .menu-overlay {
        height: 100%;
        padding: 80px 32px 40px;
        overflow-y: auto;
    }

    .circle--outer { width: 36px; height: 36px; z-index: 3; }
    .circle--middle { width: 24px; height: 24px; z-index: 2; }
    .circle--inner { width: 12px; height: 12px; z-index: 1; }

    .menu-content {
        display: flex;
        flex-direction: column;
        grid-template-columns: unset;
        grid-template-rows: unset;
        gap: 0;
        width: 100%;
    }

    .menu-links {
        grid-column: unset;
        grid-row: unset;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: unset;
        grid-auto-flow: row;
        column-gap: 16px;
        row-gap: 0;
        margin: 0 0 40px;
        order: 1;
    }

    .menu-link-item {
        font-size: 16px;
        margin-bottom: 28px;
    }

    .menu-left {
        grid-column: unset;
        grid-row: unset;
        margin: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding-top: 32px;
        border-top: 1px solid rgba(0,0,0,0.08);
        order: 2;
    }

    .menu-title {
        font-size: 28px;
        text-align: center;
        margin-bottom: 16px;
    }

    .menu-title br {
        display: none;
    }

    .menu-desc {
        text-align: center;
        margin-bottom: 24px;
        font-size: 13px;
    }

    .menu-footer-logo {
        max-width: 180px;
        position: static;
        bottom: unset;
        left: unset;
        transform: none;
        margin: 40px auto 0;
    }
}




/* ============================================================
   CTA
   ============================================================ */
.p-cta {
    padding-block: clamp(56px, calc(100 / 1728 * 100vw), 160px);
    padding-inline: 286px 218px;
}

.p-cta__inner {
    max-width: 742px;
    margin-inline: auto;
    padding-inline: clamp(20px, calc(48 / 1728 * 100vw), 48px);
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: clamp(32px, calc(72 / 1728 * 100vw), 72px);
}

.p-cta__visual {
    width: clamp(120px, calc(200 / 1728 * 100vw), 200px);
    flex-shrink: 0;

    & img {
        width: 100%;
        height: auto;
        display: block;
    }
}

.p-cta__body {
    display: flex;
    flex-direction: column;
    gap: clamp(12px, calc(20 / 1728 * 100vw), 20px);
}

.p-cta__title {
    font-size: clamp(22px, calc(36 / 1728 * 100vw), 36px);
    font-weight: 700;
    line-height: 1.5;
}

.p-cta__text {
    font-size: clamp(13px, calc(15 / 1728 * 100vw), 15px);
    line-height: 1.85;
}

/* ============================================================
    SP (768px以下)
    ============================================================ */
@media (max-width: 768px) {

    /* Hero */
    .p-hero {
      padding-block: calc(24 / 390 * 100vw) calc(56 / 390 * 100vw);
    }

    .p-hero__inner {
    grid-template-columns: 1fr;
    min-height: auto;
      gap: calc(20 / 390 * 100vw);
    }

    .p-hero__visual { order: -1; }

    .p-hero__circle-wrap {
    width: calc(240 / 390 * 100vw);
    margin-inline: auto;
    }

    .p-hero__catch { font-size: calc(32 / 390 * 100vw); }
    .p-hero__sub   { font-size: calc(13 / 390 * 100vw); }

    .p-hero__dec--green  { width: calc(20 / 390 * 100vw); left: 0; }
    .p-hero__dec--pink-l { width: calc(32 / 390 * 100vw); right: 0; top: 0; }
    .p-hero__dec--pink-s { width: calc(18 / 390 * 100vw); }

    /* Info */
    .p-info { padding-block: calc(20 / 390 * 100vw); }
    .p-info__inner { padding-inline: 20px; }

    /* About */
    .p-about {
      padding-block: calc(48 / 390 * 100vw);
    }

    .p-about__deco { display: none; }

    .p-about__inner {
        grid-template-columns: 1fr;
        padding-inline: 20px;
        gap: calc(32 / 390 * 100vw);
    }

    .p-about__title { font-size: calc(22 / 390 * 100vw); }

    .p-about__blob {
        width: calc(280 / 390 * 100vw);
        margin-inline: auto;
    }

    /* Service */
    .p-service {
      padding-block: calc(48 / 390 * 100vw);
      gap: calc(40 / 390 * 100vw);
    }

    .p-service__inner {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    /* SP: workブロックはsliderを上に */
    .p-service__block--work .p-service__slider-wrap { 
        order: -1; 
    }

    
    .p-service__slider-wrap {
      min-height: calc(240 / 390 * 100vw);
    }

    .p-service__title { font-size: calc(20 / 390 * 100vw); }

    /* Column */
    .p-column { padding-block: calc(48 / 390 * 100vw); }

    .p-column__inner { padding-inline: 20px; }

    .p-column__head {
        flex-direction: column;
        align-items: center;
        text-align: center;
        margin-bottom: calc(24 / 390 * 100vw);
    }

    .p-column__head-left { align-items: center; }

    .p-column__title { font-size: calc(28 / 390 * 100vw); }

    .p-column__nav-btn {
        width: 60px;
        padding: 4px 16px;
    }

    /* CTA */
    .p-cta { 
        padding-block: calc(48 / 390 * 100vw); 
        padding-inline: 0;
        
    }

    .p-cta__inner {
        grid-template-columns: 1fr;
        padding-inline: 20px;
        gap: calc(24 / 390 * 100vw);
        justify-items: center;
        text-align: center;
    }

    .p-cta__body {
        align-items: center;
    }

    .p-cta__visual { width: calc(140 / 390 * 100vw); }
    .p-cta__title  { font-size: calc(22 / 390 * 100vw); }
}





/* ----------------------------------------------------------
   レイアウト：フッター (.l-footer)
   ---------------------------------------------------------- */
.l-footer {
    background-color: var(--color-footer-bg);
    color: var(--color-white);
    padding-block:
        clamp(48px, calc(80 / 1728 * 100vw), 80px)
        clamp(28px, calc(40 / 1728 * 100vw), 40px);
    padding-inline:
        clamp(20px, calc(120 / 1728 * 100vw), 120px)
        clamp(20px, calc(100 / 1728 * 100vw), 100px);
}

.l-footer__inner {
    max-width: var(--container-max);
    margin-inline: auto;
}

.l-footer__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: clamp(24px, calc(48 / 1728 * 100vw), 48px);
    padding-bottom: clamp(32px, calc(48 / 1728 * 100vw), 48px);
    margin-bottom: clamp(28px, calc(40 / 1728 * 100vw), 40px);
}

/* ロゴ共通 */
.l-footer__logo {
    display: block;
    flex-shrink: 0;
    width: clamp(140px, calc(220 / 1728 * 100vw), 220px);
}

.l-footer__logo-img {
    width: 100%;
    height: auto;
    filter: brightness(0) invert(1);
}

/* SP専用ロゴはPCで非表示 */
.l-footer__logo--sp {
    display: none;
}

.l-footer__nav {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: clamp(10px, calc(14 / 1728 * 100vw), 14px);
}

.l-footer__nav-list {
    display: flex;
    gap: clamp(24px, calc(40 / 1728 * 100vw), 40px);
}

.l-footer__nav-link {
    font-size: clamp(12px, calc(14 / 1728 * 100vw), 14px);
    color: rgba(255, 255, 255, 0.75);
    transition: color 0.25s;
}

.l-footer__nav-link:hover {
    color: var(--color-white);
} 

.l-footer__bottom {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: clamp(20px, calc(32 / 1728 * 100vw), 32px);
}

.l-footer__address {
    font-style: normal;
    font-size: clamp(11px, calc(13 / 1728 * 100vw), 13px);
    line-height: 1.9;
    color: rgba(255, 255, 255, 0.65);
}

.l-footer__address a {
    color: inherit;
    transition: color 0.25s;
}

.l-footer__address :hover {
    color: var(--color-white);
}

.l-footer__legal {
    display: flex;
    align-items: flex-end;
    gap: 1rem;
}

.l-footer__privacy {
    font-size: clamp(11px, calc(12 / 1728 * 100vw), 12px);
    color: rgba(255, 255, 255, 0.65);
    transition: color 0.25s;
}

.l-footer__copy {
    font-size: clamp(10px, calc(11 / 1728 * 100vw), 11px);
    color: rgba(255, 255, 255, 0.4);
    }

/* ----------------------------------------------------------
   SP (768px以下) — 共通パーツ上書き
   ---------------------------------------------------------- */
@media (max-width: 768px) {
    :root {
        --header-h: 60px;
    }

    body {
        font-size: calc(14 / 390 * 100vw);
    }

    .c-btn .c-btn__icon {
        width: 55px;
        height: auto;
        padding: 0 8px;
    }

    .l-header__inner {
        padding-inline: 20px;
    }

    /* フッター SP */
    .l-footer__top {
        flex-direction: column;
        gap: 24px;
        padding-bottom: 24px;
        margin-bottom: 24px;
    }

    /* PCロゴ非表示 */
    .l-footer__logo--pc {
        display: none;
    }

    .l-footer__nav {
        flex-direction: row;
        align-items: flex-start;
        gap: 16px;
    }

    .l-footer__nav-list {
        flex-direction: column;
        gap: 14px;
        flex: 1;
    }

    .l-footer__bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .l-footer__legal {
        width: 100%;
        flex-direction: row;
        justify-content: space-between;
    }

    /* SPロゴ表示（最下部） */
    .l-footer__logo--sp {
        display: block;
        margin: 0 auto;
        width: 100%;
        margin-top: 32px;
    }
}

/* ----------------------------------------------------------
   1729px以上 — 固定サイズ（等比拡縮しない）
   ---------------------------------------------------------- */
@media (min-width: 1729px) {
    :root {
        --header-h: 80px;
    }

    body {
        font-size: 16px;
    }

    .c-btn {
        gap: 10px;
        padding: 13px 28px;
        font-size: 15px;

        & .c-btn__icon {
        width: 28px;
        height: 28px;
        }
    }

    .c-btn .c-btn__icon {
        width: 28px;
        height: 28px;
    }


    .c-btn-contact {
        padding: 10px 20px;
        font-size: 14px;
    }

    .c-label {
        font-size: 13px;
    }

    .l-header__inner {
        padding-inline: 48px;
    }

    .l-header__logo-placeholder {
        width: 180px;
        height: 36px;
    }

    .l-header__right {
        gap: 18px;
    }

    .l-gnav {
        padding: 48px 40px;
    }

    .l-gnav__list {
        gap: 28px;
    }

    .l-gnav__link {
        font-size: 17px;
    }

    .l-footer__inner {
        padding-inline: 48px;
    }

    .l-footer__top {
        padding-bottom: 48px;
        margin-bottom: 40px;
        gap: 48px;
    }

    .l-footer__nav-link {
        font-size: 14px;
    }

    .l-footer__nav-list {
        gap: 14px 40px;
    }

    .l-footer__address {
        font-size: 13px;
    }
}
