@charset "UTF-8";
/* ============================================================
   CCA Theme - Document Page (Site Policy / Privacy Policy 等)
   - 文書系ページ共通の書式
   ============================================================ */

/* ============================================================
   Page Wrapper
   ============================================================ */
.policy-page {
    background-color: #000000;
    color: #FFFFFF;
    padding: 150px 40px 120px;
    min-height: 100vh;
        text-align: justify;
}
@media screen and (max-width: 1024px) {
    .policy-page {
        padding: 80px 32px 80px;
    }
}
@media screen and (max-width: 757px) {
    .policy-page {
        padding: 90px 20px 50px;
    }
}

.policy {
    max-width: 1200px;
    margin: 0 auto;
}

/* ============================================================
   Page Header
   ============================================================ */
.policy__header {
    text-align: left;
    margin-bottom: 40px;
    padding-bottom: 40px;
}
@media screen and (max-width: 757px) {
    .policy__header {
        margin-bottom: 10px;
        padding-bottom: 10px;
    }
}

.policy__title {
color:#777;
font-size:18px;
font-weight:700;
margin-bottom:50px;
}
@media screen and (max-width:757px) {
.policy__title {
font-size:16px;
margin-bottom:20px;
}
}

.policy__subtitle {
font-size:40px;
font-weight:200;
line-height:1.1;
letter-spacing:-0.1em;
color:#FFFFFF;
}
@media screen and (max-width:757px) {
.policy__subtitle {
font-size:28px;
margin-bottom:30px;
}
}


/* ============================================================
   Body
   ============================================================ */
.policy__body {
    font-size: 16px;
    line-height: 2;
    letter-spacing: 0.04em;

margin:0 auto;
background-color:#191919;
border: solid 1px #777;
padding:100px 100px 50px 100px;
}
@media screen and (max-width: 757px) {
    .policy__body {
        font-size: 14px;
        line-height: 1.9;
        padding:20px 20px;
    }
}

/* ============================================================
   Section (第X条)
   ============================================================ */
.policy-section {
    margin-bottom: 70px;
}
@media screen and (max-width: 757px) {
    .policy-section {
        margin-bottom: 40px;
    }
}

.policy-section.first {
    margin-top: 70px;
}
@media screen and (max-width: 757px) {
.policy-section.first {
        margin-top: 40px;
    }
}

.policy-section__title {
    display: flex;
    flex-direction: column;   /* 横並び → 縦並び */
    align-items: flex-start;
    gap: 6px;
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid #777;
}
@media screen and (max-width: 757px) {
    .policy-section__title {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
        margin-bottom: 16px;
    }
}

.policy-section__label {
    font-size: 23px;
    font-weight: 700;
    color: #6A9070;
    white-space: nowrap;
    order: 2;
}
@media screen and (max-width: 757px) {
.policy-section__label {
        font-size: 20px;
    }
}


.policy-section__name {
    font-size: 20px;
    font-weight: 500;
    color: #FFFFFF;
    order: 1; 
}
@media screen and (max-width: 757px) {
    .policy-section__name {
        font-size: 17px;
    }
}

.policy-section__text {
    margin: 0 0 8px;
    color: #DDDDDD;
}

.policy-section__text--end {
    text-align: right;
    color: #777777;
    margin-top: 24px;
}

/* 附則などの補足セクション */
.policy-section--supplementary {
    margin-top: 72px;
    padding: 24px 28px;
    background-color: #191919;
    border-left: 3px solid #6A9070;
}
@media screen and (max-width: 757px) {
    .policy-section--supplementary {
        padding: 20px;
    }
}

.policy-section--supplementary .policy-section__title {
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 12px;
}

.policy-section--supplementary .policy-section__name {
    font-size: 16px;
}

/* ============================================================
   Numbered List (１、２、３...)
   ============================================================ */
.policy-list {
    list-style: none;
    counter-reset: policy-item 1;  /* ← 初期値1に設定（最初の項目が2になる） */
    padding: 0;
    margin: 0;
}

.policy-list > li {
    position: relative;
    counter-increment: policy-item;
    padding-left: 2.4em;
    margin-bottom: 18px;
}
@media screen and (max-width: 757px) {
    .policy-list > li {
        padding-left: 2em;
        margin-bottom: 14px;
    }
}

.policy-list > li::before {
    content: counter(policy-item);
    position: absolute;
    left: 0;
    top: 0;
    min-width: 1.8em;
    font-size: 16px;
    font-weight: 700;
    color: #6A9070;
    text-align: center;
}

/* ============================================================
   Sub List ((1)(2)(3)...)
   ============================================================ */
.policy-sublist {
    list-style: none;
    counter-reset: sub-item;
    padding: 10px 0 0;
    margin: 12px 0 0;
}

.policy-sublist > li {
    counter-increment: sub-item;
    position: relative;
    padding-left: 2em;
    margin-bottom: 8px;
    color: #DDDDDD;
    font-size: 16px;
}
@media screen and (max-width: 757px) {
.policy-sublist {
        font-size: 13px;
    }
}

.policy-sublist > li::before {
    content: "(" counter(sub-item) ")";
    position: absolute;
    left: 0;
    top: 0;
    color: #777777;
}

/* ============================================================
   Sub List (・・・)...)
   ============================================================ */
.policy-sublist-2 {
    list-style: none;
    counter-reset: sub-item;
    padding: 10px 0 0;
    margin: 12px 0 0;
}

.policy-sublist-2 > li {
    counter-increment: sub-item;
    position: relative;
    padding-left: 2em;
    margin-bottom: 8px;
    color: #DDDDDD;
    font-size: 16px;
}
@media screen and (max-width: 757px) {
.policy-sublist-2 {
        font-size: 13px;
    }
}

.policy-sublist-2 > li::before {
    content: "・";
    position: absolute;
    left: 0;
    top: 0;
    color: #777777;
}

/* ============================================================
   Footer (連絡先)
   ============================================================ */
.policy__footer {
    margin-top: 50px;
    text-align: left;
}
@media screen and (max-width: 757px) {
    .policy__footer {
        margin-top: 64px;
        padding-top: 28px;
    }
}

.policy__footer-text {
    font-size: 16px;
    color: #fff;
    margin: 0 0 20px;
}
@media screen and (max-width: 757px) {
.policy__footer-text {
    font-size: 14px;
    }
}

.policy__contact {
    font-style: normal;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.5;
}
@media screen and (max-width: 757px) {
.policy__contact {
    font-size: 16px;
    }
}

.policy__contact-name {
    display: block;
    margin-bottom: 8px;
    color: #FFFFFF;
}

.policy__contact-mail {
   font-size: 16px;
   font-weight: 200;
    text-decoration: underline;
    transition: opacity 0.3s ease;
    color:#6A9070;
}
@media screen and (max-width: 757px) {
.policy__contact-mail {
    font-size: 14px;
    }
}

.policy__contact-mail:hover {
    opacity: 0.7;
}
