@charset "UTF-8";

/* ===================================
 * privacyページ専用スタイル
 * =================================== */

.p-privacy {
    background-color: var(--service-color-white);
    color: var(--service-color-text);
}

/* 本文サイズをguide子ページと同じに */
.p-privacy .p-service-section-text {
    font-size: clamp(20px, calc(0.35vw + 17.3px), 24px);
    line-height: 1.6;
    font-weight: 500;
}

@media (max-width: 768px) {
    .p-privacy .p-service-section-text {
        font-size: clamp(18px, calc(0.96vw + 14.65px), 22px);
        letter-spacing: 0.05em;
    }
}

/* 共通ページタイトル非表示 */
.page-title--privacy {
    display: none;
}

/* ===================================
 * ページタイトル（中央寄せ・三角ノッチ付き下線）
 * =================================== */
.p-privacy-page-title {
    text-align: center;
    color: var(--service-color-text);
    font-weight: 700;
    font-size: clamp(35px, calc(1.30vw + 25px), 50px);
    line-height: 1.4;
    padding-bottom: clamp(24px, calc(1.04vw + 16px), 36px);
    margin: 0 0 clamp(40px, calc(1.39vw + 29.31px), 56px);
    background-image:
        linear-gradient(#01913a, #01913a),
        linear-gradient(#01913a, #01913a);
    background-position:
        left bottom,
        right bottom;
    background-size:
        calc(50% - 0.4em + 2px) 2px,
        calc(50% - 0.4em + 2px) 2px;
    background-repeat: no-repeat;
    position: relative;
}

.p-privacy-page-title::before {
    content: '';
    position: absolute;
    bottom: calc(2px - 0.55em);
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 0.5em solid transparent;
    border-right: 0.5em solid transparent;
    border-top: 0.55em solid #01913a;
}

.p-privacy-page-title::after {
    content: '';
    position: absolute;
    bottom: calc(4px - 0.495em);
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 0.45em solid transparent;
    border-right: 0.45em solid transparent;
    border-top: 0.495em solid var(--service-color-white);
}

@media (max-width: 768px) {
    .p-privacy-page-title {
        font-size: clamp(24px, calc(2.87vw + 13.95px), 36px);
        padding-bottom: clamp(16px, calc(1.43vw + 11px), 24px);
        margin-bottom: clamp(28px, calc(1.91vw + 21.31px), 40px);
    }
}

/* ===================================
 * 概要セクション
 * =================================== */
.p-privacy-overview__inner {
    max-width: 1140px;
    margin-inline: auto;
    padding-inline: var(--margin--use--outside);
    padding-block: var(--section) calc(var(--section) / 2);
}

.p-privacy-overview__lead {
    margin-bottom: clamp(20px, calc(1.04vw + 12px), 32px);
}

.p-privacy-overview__after {
    margin-block-start: clamp(28px, calc(1.04vw + 20px), 40px);
    margin-block-end: clamp(56px, calc(2.08vw + 40px), 80px);
}

/* ===================================
 * 4つのお約束ボックス
 * =================================== */
.p-privacy-promise {
    border: 2px solid #01913a;
    border-radius: 20px;
    padding-block: clamp(14px, calc(0.69vw + 8.69px), 22px);
    padding-inline: clamp(28px, calc(1.74vw + 14.64px), 48px);
    margin-block: clamp(20px, calc(1.04vw + 12px), 32px);
    background-color: #fdfff2;
}

.p-privacy-promise__title {
    text-align: center;
    color: #01913a;
    font-weight: 700;
    font-size: clamp(26.6px, calc(0.99vw + 19px), 38px);
    line-height: 1.4;
    padding-bottom: clamp(12px, calc(0.69vw + 6.69px), 20px);
    margin: 0 0 clamp(12px, calc(0.69vw + 6.69px), 20px);
    border-bottom: 1px dashed #01913a;
}

.p-privacy-promise__list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: privacy-promise;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.p-privacy-promise__item {
    counter-increment: privacy-promise;
    position: relative;
    padding-left: 1.35em;
    padding-bottom: 12px;
    border-bottom: 1px dashed #75cd27;
    font-size: clamp(20px, calc(0.35vw + 17.3px), 24px);
    line-height: 1.6;
    color: var(--service-color-text);
}

.p-privacy-promise__item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.p-privacy-promise__item::before {
    content: counter(privacy-promise);
    position: absolute;
    left: 0;
    top: 0.5em;
    width: 1.3em;
    height: 1.3em;
    padding-bottom: 0.12em;
    background-color: #01913a;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75em;
    font-weight: 700;
    line-height: 1;
}

/* ===================================
 * 各セクション
 * =================================== */
.p-privacy-overview__sections {
    display: flex;
    flex-direction: column;
    gap: clamp(40px, calc(4.87vw + 2.58px), 96px);
}

.p-privacy-section__heading {
    color: #01913a;
    font-weight: 700;
    font-size: clamp(25.2px, calc(0.82vw + 20.32px), 36px);
    line-height: 1.4;
    border-bottom: 1.5px solid #01913a;
    padding-bottom: clamp(10px, calc(0.35vw + 7.31px), 14px);
    margin-bottom: clamp(16px, calc(0.69vw + 10.69px), 24px);
}

.p-privacy-section a {
    color: var(--service-color-link);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.p-privacy-contact a {
    color: inherit;
    text-decoration: none;
}

/* 強調情報ボックス（背景色のみ・枠線なし）— 何度も出てくるパターン */
.p-privacy-info {
    width: fit-content;
    max-width: 100%;
    background-color: #fdfff2;
    border-radius: 20px;
    padding-block: clamp(14px, calc(0.69vw + 8.69px), 22px);
    padding-inline: clamp(28px, calc(1.74vw + 14.64px), 48px);
}

.p-privacy-info .pc-only,
.p-privacy-contact .pc-only {
    display: inline;
}

/* ===================================
 * アコーディオン: 詳しいプライバシーポリシー
 * =================================== */
.p-privacy-policy {
    margin-top: clamp(32px, calc(1.74vw + 18.62px), 52px);
}

.p-privacy-policy__toggle {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
    width: 100%;
    max-width: clamp(460px, calc(13.9vw + 353.11px), 620px);
    margin-inline: auto;
    height: clamp(64px, calc(1.39vw + 53.31px), 80px);
    padding: 0 24px;
    background-color: var(--service-color-white);
    border: 2px solid #01913a;
    border-radius: 20px;
    color: #01913a;
    font-weight: 500;
    font-size: clamp(20px, calc(0.87vw + 13.32px), 30px);
    cursor: pointer;
    list-style: none;
    box-shadow: 4px 4px 5px 2px rgba(0, 0, 0, 0.2);
    transition: opacity 0.3s ease;
}

.p-privacy-policy__toggle::-webkit-details-marker {
    display: none;
}

.p-privacy-policy__toggle:hover {
    opacity: 0.85;
}

.p-privacy-policy__toggle-icon {
    width: 0;
    height: 0;
    border-left: 0.4em solid transparent;
    border-right: 0.4em solid transparent;
    border-top: 0.7em solid #01913a;
    transition: transform 0.3s ease;
    flex-shrink: 0;
}

.p-privacy-policy[open] .p-privacy-policy__toggle-icon {
    transform: rotate(180deg);
}

/* アコーディオン中身 */
.p-privacy-policy__body {
    margin-top: clamp(20px, calc(1.04vw + 12px), 32px);
    padding-block: clamp(20px, calc(1.04vw + 12px), 32px) 0;
    animation: p-privacy-fadeIn 0.4s ease;
}

@keyframes p-privacy-fadeIn {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}

.p-privacy .p-privacy-policy__title {
    text-align: center;
    font-weight: 600;
    font-size: clamp(28px, calc(0.52vw + 24px), 34px);
    margin-bottom: clamp(24px, calc(1.39vw + 13.31px), 40px);
}

@media (max-width: 768px) {
    .p-privacy .p-privacy-policy__title {
        font-size: clamp(22px, calc(0.96vw + 18.65px), 26px);
        letter-spacing: 0.025em;
    }
}

.p-privacy-policy__heading {
    color: var(--service-color-text);
    font-weight: 600;
    font-size: clamp(20px, calc(0.35vw + 17.3px), 24px);
    line-height: 1.5;
    margin-top: clamp(32px, calc(5.21vw - 8.09px), 92px);
    margin-bottom: clamp(24px, calc(1.04vw + 15.98px), 36px);
}

@media (max-width: 768px) {
    .p-privacy-policy__heading {
        font-size: clamp(18px, calc(0.96vw + 14.65px), 22px);
    }
}

.p-privacy-policy__body a:not(.p-privacy-back-btn) {
    color: var(--service-color-link);
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ===================================
 * クロージング: 縦2並びCTA + lead text
 * =================================== */
.p-privacy-closing .p-service-closing__bg {
    background-color: var(--service-color-white);
}

.p-privacy-closing .p-service-closing__inner {
    max-width: 1140px;
    padding-inline: var(--margin--use--outside);
    padding-block: calc(var(--section) / 2);
    text-align: left;
}

.p-privacy-closing__lead {
    margin-top: clamp(12px, calc(0.69vw + 6.69px), 20px);
}

.p-privacy-closing__cta {
    margin-top: clamp(20px, calc(1.04vw + 12px), 32px);
    width: 100%;
    max-width: clamp(460px, calc(13.9vw + 353.11px), 620px);
    gap: 17px;
}

/* CTAボタン: 塗り＋角丸20px */
.p-privacy-closing__cta .p-service-cta-btn {
    position: relative;
    width: 100%;
    height: clamp(64px, calc(1.39vw + 53.31px), 80px);
    border: none;
    border-radius: 20px;
    color: var(--service-color-white);
    font-size: clamp(20px, calc(0.87vw + 13.32px), 30px);
    font-weight: 500;
    box-shadow: 4px 4px 5px 2px rgba(0, 0, 0, 0.2);
}

.p-privacy-closing__cta .p-service-cta-btn__main {
    font-size: clamp(20px, calc(0.87vw + 13.32px), 30px);
    font-weight: 500;
}

.p-privacy-closing__cta .p-service-cta-btn::after {
    content: '';
    position: absolute;
    right: 24px;
    top: 50%;
    width: 0.8em;
    height: 0.8em;
    border-top: 3px solid currentColor;
    border-right: 3px solid currentColor;
    transform: translateY(-50%) rotate(45deg);
}

.p-privacy-closing__cta .p-service-cta-btn--green {
    background-color: #01913a;
}

.p-privacy-closing__cta .p-service-cta-btn:not(.p-service-cta-btn--green) {
    background-color: #f09e32;
}

@media (max-width: 768px) {
    .p-privacy-closing__cta {
        max-width: 500px;
        gap: 10px;
    }

    .p-privacy-closing__cta .p-service-cta-btn {
        max-width: none;
        height: clamp(48px, calc(2.87vw + 37.95px), 60px);
        font-size: clamp(17px, calc(1.44vw + 11.98px), 23px);
        border-radius: 15px;
        box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.2);
    }

    .p-privacy-closing__cta .p-service-cta-btn__main {
        font-size: clamp(17px, calc(1.44vw + 11.98px), 23px);
    }
}

/* ===================================
 * SP対応
 * =================================== */
@media (max-width: 768px) {
    .p-privacy-overview__inner {
        padding-block: var(--section-s);
    }

    .p-privacy-promise {
        padding: 14px;
        border-radius: 15px;
        border-width: 1.5px;
    }

    .p-privacy-promise__title {
        font-size: clamp(19px, calc(2.39vw + 10.63px), 29px);
    }

    .p-privacy-promise__item {
        font-size: clamp(18px, calc(0.96vw + 14.65px), 22px);
        line-height: 1.6;
        letter-spacing: 0.05em;
    }

    .p-privacy-section__heading {
        font-size: clamp(20px, calc(2.15vw + 12.46px), 29px);
        border-bottom-width: 1px;
        padding-bottom: 8px;
        margin-bottom: 14px;
    }

    .p-privacy-info {
        width: 100%;
        border-radius: 15px;
        padding-inline: 18px;
    }

    .p-privacy-info--center-sp {
        text-align: center;
    }

    .p-privacy-info--tight-sp {
        padding-inline: 12px;
    }

    .p-privacy-info .pc-only,
    .p-privacy-contact .pc-only {
        display: none;
    }

    .p-privacy-policy__toggle {
        max-width: 500px;
        height: clamp(48px, calc(2.87vw + 37.95px), 60px);
        font-size: clamp(16px, calc(1.44vw + 10.98px), 22px);
        border-radius: 15px;
        border-width: 2px;
        padding: 0 16px;
        box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.2);
    }
}

/* ===================================
 * 前のページに戻るボタン
 * 白地・緑線2px・緑文字・角丸20px
 * =================================== */
.p-privacy-back-wrap {
    margin-inline: auto;
    width: 100%;
    max-width: clamp(460px, calc(13.9vw + 353.11px), 620px);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(16px, calc(0.7vw + 10.6px), 24px);
}

.p-privacy-back-wrap--top {
    margin-block: clamp(28px, calc(1.39vw + 17.31px), 44px);
    max-width: none;
    border-radius: 20px;
    padding-block: clamp(36px, calc(1.74vw + 22.64px), 56px);
    padding-inline: clamp(40px, calc(2.09vw + 23.97px), 64px);
    background-color: #f6f9f2;
}

.p-privacy-back-wrap--summary {
    margin-top: 0;
}

.p-privacy-back-msg {
    text-align: left;
    margin: 0;
}

.p-privacy-back-msg--summary {
    margin-block: clamp(40px, calc(2.09vw + 23.97px), 64px);
}

/* アコーディオン展開中は、外側の #2 ブロック（メッセージ + 戻るボタン）を非表示にする */
.p-privacy-policy[open] ~ .p-privacy-back-msg--summary,
.p-privacy-policy[open] ~ .p-privacy-back-wrap--summary {
    display: none;
}

.p-privacy-back-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: clamp(460px, calc(13.9vw + 353.11px), 620px);
    height: clamp(64px, calc(1.39vw + 53.31px), 80px);
    background-color: var(--service-color-white);
    border: 2px solid #01913a;
    border-radius: 20px;
    color: #ffffff;
    background-color: #01913a;
    font-weight: 500;
    font-size: clamp(20px, calc(0.87vw + 13.32px), 30px);
    text-decoration: none;
    box-shadow: 4px 4px 5px 2px rgba(0, 0, 0, 0.2);
    transition: opacity 0.3s ease;
    cursor: pointer;
}

.p-privacy-back-btn:hover {
    opacity: 0.85;
}

.p-privacy-back-btn:active {
    transform: scale(0.96);
    transition: transform 0.15s ease;
}

/* ===================================
 * アコーディオン内 終点ブロック
 * =================================== */
.p-privacy-policy-end {
    margin-top: 0;
    margin-inline: auto;
    width: 100%;
    max-width: clamp(460px, calc(13.9vw + 353.11px), 620px);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(24px, calc(1.04vw + 16px), 36px);
}

/* ===================================
 * 詳しいプライバシーポリシーを閉じるボタン
 * =================================== */
.p-privacy-policy-close-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    height: clamp(64px, calc(1.39vw + 53.31px), 80px);
    background-color: var(--service-color-white);
    border: 2px solid #01913a;
    border-radius: 20px;
    color: #01913a;
    font-weight: 500;
    font-size: clamp(20px, calc(0.87vw + 13.32px), 30px);
    box-shadow: 4px 4px 5px 2px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    transition: opacity 0.3s ease;
}

.p-privacy-policy-close-btn:hover {
    opacity: 0.85;
}

.p-privacy-policy-close-btn__icon {
    width: 0;
    height: 0;
    border-left: 0.4em solid transparent;
    border-right: 0.4em solid transparent;
    border-bottom: 0.7em solid #01913a;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .p-privacy-back-wrap,
    .p-privacy-policy-end {
        max-width: 500px;
    }

    .p-privacy-back-wrap--top {
        max-width: none;
        padding: 36px;
        border-radius: 15px;
    }

    .p-privacy-back-btn,
    .p-privacy-policy-close-btn {
        height: clamp(48px, calc(2.87vw + 37.95px), 60px);
        font-size: clamp(17px, calc(1.44vw + 11.98px), 23px);
        border-radius: 15px;
        border-width: 2px;
        box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.2);
    }

    .p-privacy-back-btn {
        max-width: 500px;
    }

    /* 「詳しいプライバシーポリシーを閉じる ▲」: 344px幅で折り返さないよう最小サイズを下げる */
    .p-privacy-policy-close-btn {
        font-size: clamp(14px, calc(2.15vw + 6.46px), 23px);
    }
}
