@charset "utf-8";
/*
+----------------------------------------------------------------------+
| Copyright (c) 2010-2026 SPEAKINGMAX @ WEAVERSBRAIN.Co.Ltd
+----------------------------------------------------------------------+
| 작업일 : 2026-05-14
| 파일설명 : 판매약관 개정 안내 페이지 CSS (MAX AI 반응형)
+----------------------------------------------------------------------+
| 작업자 : 최진영(Kcarl)
+----------------------------------------------------------------------+
*/

:root {
    --strp-bg:             #ffffff;
    --strp-bg-card:        #f5f5f7;
    --strp-bg-card-strong: #ececef;
    --strp-text-primary:   #1d1d1f;
    --strp-text-secondary: #6e6e73;
    --strp-text-tertiary:  #86868b;
    --strp-border:         #d2d2d7;
    --strp-accent:         #1d1d1f;
    --strp-radius-lg:      14px;
    --strp-radius-md:      10px;
    --strp-radius-sm:      8px;
    --strp-space-1:        8px;
    --strp-space-2:        16px;
    --strp-space-3:        20px;
    --strp-space-4:        24px;
    --strp-space-5:        32px;
    --strp-space-6:        40px;
    --strp-transition:     200ms ease;
}

html, body { margin: 0; padding: 0; background: var(--strp-bg); color: var(--strp-text-primary); font-family: 'NotoSansKR-Regular', -apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', sans-serif; overflow-x: hidden; }
.strpPage, .strpPage * { box-sizing: border-box; min-width: 0; }

/* ─────────────────────────────────────────
   Base (mobile first)
   ───────────────────────────────────────── */
.strpPage {
    width: 100%;
    max-width: 100vw;
    margin: 0 auto;
    padding: var(--strp-space-4) var(--strp-space-3) var(--strp-space-5);
    overflow-x: hidden;
    word-break: break-word;
    overflow-wrap: anywhere;
}

.strpPageTitle {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.4px;
    margin: 0 0 var(--strp-space-2);
    line-height: 1.35;
}

.strpIntro {
    font-size: 14px;
    line-height: 1.65;
    color: var(--strp-text-secondary);
    margin: 0 0 var(--strp-space-4);
}

.strpIntro strong {
    color: var(--strp-text-secondary);
    font-size: 14px;
    font-weight: 400;
    border-bottom: 0;
}

/* 헤더 카드 */
.strpHeaderCard {
    background: var(--strp-bg-card);
    border-radius: var(--strp-radius-lg);
    padding: var(--strp-space-3);
    margin-bottom: var(--strp-space-2);
}

.strpHeaderCardTitle {
    font-size: 15px;
    font-weight: 600;
    margin: 0 0 var(--strp-space-1);
    color: var(--strp-text-primary);
}

.strpHeaderCardBody {
    font-size: 13px;
    color: var(--strp-text-secondary);
    line-height: 1.7;
}

.strpHeaderCardBody ul,
.strpHeaderCardBody ol {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* 1단계: 점(•) */
.strpHeaderCardBody > ul > li {
    position: relative;
    padding-left: 12px;
    margin-bottom: 2px;
}
.strpHeaderCardBody > ul > li::before {
    content: "";
    position: absolute;
    left: 3px;
    top: 0.7em;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--strp-text-secondary);
}

/* 2단계: a. b. c. d. */
.strpHeaderCardBody li > ol {
    counter-reset: strp-alpha;
    margin-top: 4px;
    padding-left: 12px;
}
.strpHeaderCardBody li > ol > li {
    counter-increment: strp-alpha;
    position: relative;
    padding-left: 16px;
    margin-bottom: 2px;
}
.strpHeaderCardBody li > ol > li::before {
    content: counter(strp-alpha, lower-alpha) ".";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--strp-text-secondary);
}

/* 3단계: i. ii. iii. */
.strpHeaderCardBody li > ol > li > ol {
    counter-reset: strp-roman;
    margin-top: 4px;
    padding-left: 12px;
}
.strpHeaderCardBody li > ol > li > ol > li {
    counter-increment: strp-roman;
    position: relative;
    padding-left: 20px;
    margin-bottom: 2px;
}
.strpHeaderCardBody li > ol > li > ol > li::before {
    content: counter(strp-roman, lower-roman) ".";
    position: absolute;
    left: 0;
    top: 0;
    color: var(--strp-text-secondary);
}

/* 전문 보기 */
.strpTermsSection { margin-top: var(--strp-space-5); }

.strpTermsSectionTitle {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.3px;
    margin: 0 0 var(--strp-space-2);
}

.strpAccordion { border-bottom: 1px solid var(--strp-border); }
.strpAccordionItem { border-top: 1px solid var(--strp-border); }

.strpAccordionHead {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: transparent;
    border: 0;
    cursor: pointer;
    padding: var(--strp-space-2) 4px;
    font-weight: 500;
    color: var(--strp-text-primary);
    text-align: left;
    min-height: 44px;
    transition: color var(--strp-transition);
}

.strpAccordionHead:focus-visible { outline: 2px solid var(--strp-accent); outline-offset: 2px; }
.strpAccordionHead > span:first-child { font-size: 16px; }

.strpAccordionHead .strpAccordionArrow {
    display: inline-block;
    width: 10px; height: 10px;
    border-right: 2px solid var(--strp-text-secondary);
    border-bottom: 2px solid var(--strp-text-secondary);
    transform: rotate(45deg);
    transition: transform var(--strp-transition);
    margin-right: 6px;
    flex-shrink: 0;
}

.strpAccordionItem.on .strpAccordionArrow { transform: rotate(-135deg); }

.strpAccordionBody {
    display: none;
    padding: var(--strp-space-2);
    background: var(--strp-bg-card);
    border-radius: var(--strp-radius-md);
    margin-bottom: var(--strp-space-2);
}

.strpAccordionItem.on .strpAccordionBody { display: block; }

.strpTermsBody {
    font-size: 12px;
    line-height: 1.7;
    color: var(--strp-text-secondary);
    max-height: 60vh;
    overflow-y: auto;
    padding-right: 4px;
}

.strpTermsBody p  { margin: 0 0 var(--strp-space-1); }
.strpTermsBody h4 { font-size: 14px; font-weight: 600; color: var(--strp-text-primary); margin: var(--strp-space-2) 0 4px; }
.strpTermsBody h4:first-child { margin-top: 0; }
.strpTermsBody .strpTermsHeading { font-size: 15px; font-weight: 700; text-align: center; color: var(--strp-text-primary); margin: 0 0 var(--strp-space-2); }
.strpTermsBody ul,
.strpTermsBody ol {
    list-style: none;
    margin: 0;
    padding: 0;
}
.strpTermsBody ul { margin: 0 0 var(--strp-space-1); }
.strpTermsBody ul ul { margin-top: 3px; margin-bottom: 4px; padding-left: 12px; }
.strpTermsBody li {
    position: relative;
    padding-left: 12px;
    margin-bottom: 3px;
}
.strpTermsBody li::before {
    content: "";
    position: absolute;
    left: 3px;
    top: 0.7em;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--strp-text-secondary);
}

/* 이의제기 영역 */
.strpInquiry {
    margin-top: var(--strp-space-5);
    padding: var(--strp-space-3);
    background: var(--strp-bg-card);
    border-radius: var(--strp-radius-lg);
}

.strpInquiryTitle {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 var(--strp-space-1);
}

.strpInquiry p {
    font-size: 13px;
    line-height: 1.7;
    color: var(--strp-text-secondary);
    margin: 0 0 4px;
}

.strpInquiry p:last-child { margin-bottom: 0; }

/* ─────────────────────────────────────────
   PC (≥ 1024px)
   ───────────────────────────────────────── */
@media only screen and (min-width: 1024px) {
    .strpPage {
        max-width: 880px;
        padding: var(--strp-space-6) var(--strp-space-5) var(--strp-space-6);
    }

    .strpPageTitle {
        font-size: 28px;
        letter-spacing: -0.4px;
        margin: 0 0 var(--strp-space-4);
    }

    .strpIntro {
        font-size: 15px;
        margin: 0 0 var(--strp-space-6);
    }

    .strpIntro strong { font-size: 15px; }

    .strpHeaderCard {
        border-radius: 16px;
        padding: var(--strp-space-5);
        margin-bottom: var(--strp-space-4);
    }

    .strpHeaderCardTitle { font-size: 17px; margin: 0 0 var(--strp-space-2); }
    .strpHeaderCardBody { font-size: 14px; }
    .strpHeaderCardBody > ul > li { padding-left: 14px; }
    .strpHeaderCardBody > ul > li::before { left: 4px; }
    .strpHeaderCardBody li > ol { padding-left: 14px; }
    .strpHeaderCardBody li > ol > li { padding-left: 18px; }
    .strpHeaderCardBody li > ol > li > ol { padding-left: 14px; }
    .strpHeaderCardBody li > ol > li > ol > li { padding-left: 22px; }

    .strpTermsSection      { margin-top: var(--strp-space-6); }
    .strpTermsSectionTitle { font-size: 22px; margin: 0 0 var(--strp-space-4); }

    .strpAccordionHead {
        padding: var(--strp-space-4) var(--strp-space-1);
        min-height: 56px;
    }

    .strpAccordionHead:hover { color: var(--strp-accent); }
    .strpAccordionHead > span:first-child { font-size: 18px; }

    .strpAccordionHead .strpAccordionArrow {
        width: 12px; height: 12px;
        margin-right: 4px;
    }

    .strpAccordionBody {
        padding: var(--strp-space-4);
        border-radius: 12px;
    }

    .strpTermsBody  { font-size: 13px; line-height: 1.75; max-height: 600px; padding-right: var(--strp-space-1); }
    .strpTermsBody p  { margin: 0 0 var(--strp-space-2); }
    .strpTermsBody h4 { font-size: 15px; margin: var(--strp-space-4) 0 var(--strp-space-1); }
    .strpTermsBody h4:first-child { margin-top: 0; }
    .strpTermsBody .strpTermsHeading { font-size: 17px; margin: 0 0 var(--strp-space-4); }
    .strpTermsBody ul { margin: 0 0 var(--strp-space-2); }
    .strpTermsBody li { padding-left: 14px; margin-bottom: 4px; }
    .strpTermsBody li::before { left: 4px; }
    .strpTermsBody ul ul { padding-left: 14px; margin-bottom: var(--strp-space-1); }

    .strpInquiry {
        margin-top: var(--strp-space-6);
        padding: var(--strp-space-5);
        border-radius: 16px;
    }

    .strpInquiryTitle { font-size: 16px; margin: 0 0 var(--strp-space-2); }
    .strpInquiry p    { font-size: 14px; margin: 0 0 var(--strp-space-1); }
}

@media (prefers-reduced-motion: reduce) {
    .strpAccordionHead, .strpAccordionArrow { transition: none; }
}
