@charset "utf-8";

/* =========================================
   FAQ13 SP版：納品書・請求書・領収書・インボイス対応
   PC版とは別ページ運用想定
========================================= */

:root {
    --docfaq-orange: #ff6200;
    --docfaq-orange-dark: #e05000;
    --docfaq-orange-soft: #fff4eb;
    --docfaq-orange-pale: #fffaf5;
    --docfaq-gold: #ffb84d;
    --docfaq-yellow: #ffd200;
    --docfaq-text: #222;
    --docfaq-sub: #555;
    --docfaq-border: #ececec;
    --docfaq-white: #fff;
    --docfaq-shadow: 0 8px 22px rgba(0, 0, 0, .07);
    --docfaq-orange-shadow: 0 10px 26px rgba(255, 98, 0, .16);
}

#faq-documents-sp,
#faq-documents-sp * {
    box-sizing: border-box;
}

#faq-documents-sp {
    width: 100%;
    padding: 0 10px 28px;
    color: var(--docfaq-text);
    font-family: inherit;
}

#faq-documents-sp img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}

#faq-documents-sp a {
    color: inherit;
}

.docfaq-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    align-items: center;
    margin: 8px 0 12px;
    font-size: 11px;
    line-height: 1.6;
    color: #777;
}

.docfaq-breadcrumb a {
    color: #666;
    text-decoration: underline;
}

.docfaq-breadcrumb em {
    font-style: normal;
    color: #888;
}

.docfaq-sp {
    width: 100%;
    margin: 0 auto;
}

.docfaq-sp__hero {
    position: relative;
    overflow: hidden;
    padding: 22px 18px 24px;
    background:
        radial-gradient(circle at 92% 12%, rgba(255, 210, 0, .34) 0 18%, transparent 34%),
        linear-gradient(135deg, #fff4eb 0%, #ffffff 56%, #fff9f2 100%);
    border: 1px solid #ffd9bf;
    border-radius: 18px;
    box-shadow: var(--docfaq-orange-shadow);
}

.docfaq-sp__eyebrow {
    margin: 0 0 7px;
    color: var(--docfaq-orange);
    font-size: 11px;
    font-weight: bold;
    letter-spacing: .12em;
}

.docfaq-sp__hero h1 {
    margin: 0;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.45;
    letter-spacing: .01em;
    color: var(--docfaq-text);
}

.docfaq-sp__lead {
    margin: 12px 0 0;
    font-size: 14px;
    line-height: 1.85;
    color: #333;
}

.docfaq-sp__summary,
.docfaq-section-sp,
.docfaq-contact-sp {
    margin-top: 20px;
}

.docfaq-sp__summary {
    padding: 18px;
    background: linear-gradient(180deg, #fffaf5 0%, #ffffff 100%);
    border: 1px solid #ffd9bf;
    border-radius: 16px;
    box-shadow: var(--docfaq-shadow);
}

.docfaq-sp__summary h2,
.docfaq-section-sp h2,
.docfaq-contact-sp h2 {
    position: relative;
    margin: 0 0 14px;
    padding-left: 14px;
    font-size: 20px;
    font-weight: bold;
    line-height: 1.45;
    color: var(--docfaq-text);
}

.docfaq-sp__summary h2::before,
.docfaq-section-sp h2::before,
.docfaq-contact-sp h2::before {
    content: "";
    position: absolute;
    left: 0;
    top: .28em;
    width: 5px;
    height: 1.2em;
    background: linear-gradient(180deg, var(--docfaq-orange) 0%, var(--docfaq-gold) 100%);
    border-radius: 999px;
}

.docfaq-checklist-sp {
    margin: 0;
    padding: 0;
    list-style: none;
}

.docfaq-checklist-sp li {
    position: relative;
    padding: 10px 0 10px 30px;
    border-top: 1px solid #ffe6d2;
    font-size: 14px;
    line-height: 1.7;
}

.docfaq-checklist-sp li:first-child {
    border-top: 0;
}

.docfaq-checklist-sp li::before {
    content: "✓";
    position: absolute;
    left: 0;
    top: 10px;
    display: grid;
    place-items: center;
    width: 21px;
    height: 21px;
    background: var(--docfaq-orange);
    border-radius: 50%;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
}

.docfaq-card-list-sp,
.docfaq-payment-list-sp,
.docfaq-image-list-sp,
.docfaq-faqs-sp {
    display: grid;
    gap: 12px;
}

.docfaq-card-sp,
.docfaq-payment-sp,
.docfaq-image-card-sp,
.docfaq-steps-sp li,
.docfaq-faqs-sp details {
    background: #fff;
    border: 1px solid var(--docfaq-border);
    border-radius: 16px;
    box-shadow: var(--docfaq-shadow);
}

.docfaq-card-sp,
.docfaq-image-card-sp,
.docfaq-steps-sp li {
    padding: 17px;
}

.docfaq-card-sp--invoice {
    border-color: #ffd9bf;
    background: linear-gradient(180deg, #fffaf5 0%, #fff 100%);
}

.docfaq-card-sp h3,
.docfaq-payment-sp h3,
.docfaq-image-card-sp h3,
.docfaq-steps-sp h3 {
    margin: 0 0 9px;
    font-size: 17px;
    font-weight: bold;
    line-height: 1.45;
    color: var(--docfaq-orange);
}

.docfaq-card-sp p,
.docfaq-card-sp li,
.docfaq-payment-sp p,
.docfaq-image-card-sp p,
.docfaq-steps-sp p,
.docfaq-lead-sp,
.docfaq-faqs-sp p,
.docfaq-contact-sp p {
    font-size: 14px;
    line-height: 1.85;
}

.docfaq-card-sp p,
.docfaq-payment-sp p,
.docfaq-image-card-sp p,
.docfaq-steps-sp p,
.docfaq-lead-sp,
.docfaq-faqs-sp p,
.docfaq-contact-sp p {
    margin: 0;
}

.docfaq-card-sp ul {
    margin: 10px 0 0;
    padding-left: 1.2em;
}

.docfaq-card-sp li+li {
    margin-top: 4px;
}

.docfaq-note-sp {
    margin-top: 10px !important;
    padding: 9px 10px;
    background: #fff4eb;
    border-radius: 10px;
    color: #5c4a36;
    font-weight: bold;
}

.docfaq-payment-sp {
    overflow: hidden;
}

.docfaq-payment-sp h3 {
    margin: 0;
    padding: 11px 14px;
    background: linear-gradient(135deg, #ff8c1a 0%, #ff6200 100%);
    color: #fff;
    font-size: 15px;
}

.docfaq-payment-sp p {
    padding: 14px;
    color: #333;
}

.docfaq-steps-sp {
    counter-reset: step;
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.docfaq-steps-sp li {
    position: relative;
}

.docfaq-steps-sp span {
    display: inline-block;
    margin-bottom: 9px;
    padding: 5px 11px;
    background: var(--docfaq-orange);
    border-radius: 999px;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    line-height: 1;
}

.docfaq-image-card-sp {
    padding: 16px;
}

.docfaq-image-link-sp {
    position: relative;
    display: block;
    margin: 0;
    padding: 10px;
    background: linear-gradient(180deg, #fffaf5 0%, #fff4eb 100%);
    border: 1px dashed var(--docfaq-gold);
    border-radius: 14px;
    text-decoration: none;
}

.docfaq-image-link-sp img {
    display: block;
    width: 100%;
    border-radius: 10px;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .10);
}

.docfaq-image-link-sp span {
    position: absolute;
    right: 18px;
    bottom: 18px;
    padding: 6px 10px;
    background: rgba(255, 98, 0, .93);
    border-radius: 999px;
    color: #fff;
    font-size: 11px;
    font-weight: bold;
    line-height: 1;
}

.docfaq-image-card-sp p {
    margin-top: 10px;
    color: var(--docfaq-sub);
}

.docfaq-faqs-sp details {
    overflow: hidden;
}

.docfaq-faqs-sp summary {
    position: relative;
    padding: 16px 44px 16px 15px;
    cursor: pointer;
    list-style: none;
    font-size: 15px;
    font-weight: bold;
    line-height: 1.65;
    color: var(--docfaq-text);
}

.docfaq-faqs-sp summary::-webkit-details-marker {
    display: none;
}

.docfaq-faqs-sp summary::after {
    content: "+";
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    color: var(--docfaq-orange);
    font-size: 24px;
    font-weight: bold;
    line-height: 1;
}

.docfaq-faqs-sp details[open] summary::after {
    content: "−";
}

.docfaq-faqs-sp details>div {
    padding: 13px 15px 16px;
    border-top: 1px solid #ffe5d2;
    background: #fffaf7;
}

.docfaq-contact-sp {
    padding: 22px 18px;
    background:
        radial-gradient(circle at 92% 8%, rgba(255, 210, 0, .28) 0 18%, transparent 35%),
        linear-gradient(135deg, #ff8c1a 0%, #ff6200 70%, #ff7a00 100%);
    border-radius: 18px;
    box-shadow: var(--docfaq-orange-shadow);
    color: #fff;
}

.docfaq-contact-sp h2,
.docfaq-contact-sp p {
    color: #fff;
}

.docfaq-contact-sp h2::before {
    background: #fff;
}

.docfaq-contact-box-sp {
    margin-top: 15px;
    padding: 16px;
    background: rgba(255, 255, 255, .14);
    border: 1px solid rgba(255, 255, 255, .36);
    border-radius: 14px;
}

.docfaq-contact-label-sp,
.docfaq-contact-hours-sp {
    font-size: 12px !important;
    opacity: .94;
}

.docfaq-contact-number-sp {
    margin: 4px 0 !important;
    font-size: 28px !important;
    font-weight: bold;
    line-height: 1.2 !important;
}

.docfaq-contact-number-sp a {
    color: #fff !important;
    text-decoration: none;
}

.docfaq-btn-sp {
    display: block;
    width: 100%;
    margin-top: 14px;
    padding: 14px 16px;
    background: #fff;
    border-radius: 999px;
    color: var(--docfaq-orange) !important;
    font-size: 15px;
    font-weight: bold;
    line-height: 1.3;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .12);
}

body.is-docfaq-lightbox-open-sp {
    overflow: hidden;
}

.docfaq-lightbox-sp {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    padding: 30px 10px;
    background: rgba(34, 34, 34, .74);
}

.docfaq-lightbox-sp.is-open {
    display: flex;
    align-items: center;
    justify-content: center;
}

.docfaq-lightbox-sp__inner {
    position: relative;
    max-width: 94vw;
    max-height: 88vh;
}

.docfaq-lightbox-sp__image {
    display: block;
    max-width: 100%;
    max-height: 88vh;
    width: auto;
    height: auto;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 16px 40px rgba(0, 0, 0, .35);
}

.docfaq-lightbox-sp__close {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 2;
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 50%;
    background: rgba(255, 255, 255, .96);
    color: var(--docfaq-orange);
    font-size: 24px;
    font-weight: bold;
    line-height: 1;
    cursor: pointer;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .22);
}

@media only screen and (max-width: 360px) {
    #faq-documents-sp {
        padding-left: 8px;
        padding-right: 8px;
    }

    .docfaq-sp__hero h1 {
        font-size: 22px;
    }

    .docfaq-sp__summary h2,
    .docfaq-section-sp h2,
    .docfaq-contact-sp h2 {
        font-size: 19px;
    }

    .docfaq-contact-number-sp {
        font-size: 25px !important;
    }
}
