/* ============================================================
   見積もり比較メモ – Claude Code 版
   カラー: アンバー / スレート（Codex版のティールと差別化）
   ============================================================ */

.artifact-body--quote-comparison-memo-claude-code {
    --artifact-header-accent: #92400e;
    --artifact-header-muted: #78716c;
    --artifact-header-border: rgba(120, 53, 15, 0.10);
    --artifact-header-surface: rgba(255, 255, 255, 0.90);
    margin: 0;
    color: #1c1917;
    background: linear-gradient(178deg, #fafaf9 0%, #f5f5f4 100%);
    font-family: "Hiragino Sans", "Yu Gothic", "Noto Sans JP", sans-serif;
    line-height: 1.7;
}

/* ---- フレーム / シェル ---- */
.qcm-frame {
    min-height: 100vh;
}

.qcm-shell {
    width: min(1120px, calc(100% - 32px));
    margin: 0 auto;
}

/* ---- ラベル ---- */
.qcm-label {
    display: inline-block;
    margin-bottom: 8px;
    padding: 3px 12px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: #92400e;
    background: rgba(146, 64, 14, 0.07);
    border-radius: 6px;
}

.qcm-label--light {
    color: #fde68a;
    background: rgba(253, 230, 138, 0.12);
}

/* ---- 見出し共通 ---- */
.qcm-hero__title,
.qcm-section-header h2,
.qcm-table-wrap__header h2,
.qcm-step h3,
.qcm-checkpoint h3,
.qcm-faq h3,
.qcm-cta h2,
.qcm-summary-card h3 {
    margin: 0;
    font-family: "Noto Serif JP", Georgia, "Yu Mincho", serif;
    font-weight: 700;
    color: #1c1917;
}

.qcm-section-header h2,
.qcm-table-wrap__header h2,
.qcm-cta h2 {
    font-size: clamp(1.2rem, 2.2vw, 1.55rem);
    line-height: 1.5;
}

/* ---- 段落共通 ---- */
.qcm-hero__lead,
.qcm-section-header p,
.qcm-step p,
.qcm-checkpoint p,
.qcm-faq p,
.qcm-cta p,
.qcm-summary-card__note,
.qcm-footer p {
    margin: 0;
    line-height: 1.85;
    color: #57534e;
}

/* ---- セクション ---- */
.qcm-section {
    padding: 48px 0;
}

.qcm-section--warm {
    background: linear-gradient(180deg, rgba(254, 243, 199, 0.25) 0%, transparent 100%);
}

.qcm-section--dark {
    background: linear-gradient(172deg, #292524 0%, #1c1917 100%);
    color: #fafaf9;
}

.qcm-section--dark h2,
.qcm-section--dark h3 {
    color: #fafaf9;
}

.qcm-section--dark p,
.qcm-section--dark .qcm-faq p {
    color: #d6d3d1;
}

.qcm-section--cta {
    padding: 56px 0 64px;
}

/* ---- セクションヘッダー ---- */
.qcm-section-header {
    max-width: 700px;
    margin: 0 auto 36px;
    text-align: center;
}

.qcm-section-header p {
    margin-top: 10px;
}

.qcm-section-header--light h2 {
    color: #fafaf9;
}

/* ============================================================
   ヒーロー
   ============================================================ */
.qcm-hero {
    padding: 48px 0 40px;
    text-align: center;
}

.qcm-hero__badge {
    display: inline-block;
    margin-bottom: 16px;
    padding: 5px 16px;
    font-size: 0.82rem;
    font-weight: 700;
    color: #92400e;
    background: rgba(146, 64, 14, 0.06);
    border: 1px solid rgba(146, 64, 14, 0.12);
    border-radius: 8px;
}

.qcm-hero__title {
    font-size: clamp(1.4rem, 3vw, 2rem);
    line-height: 1.4;
    max-width: 18ch;
    margin: 0 auto;
}

.qcm-hero__lead {
    max-width: 620px;
    margin: 14px auto 0;
    font-size: 1rem;
}

.qcm-hero__actions {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.qcm-hero__points {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    max-width: 820px;
    margin: 36px auto 0;
}

.qcm-hero__point {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 16px;
    border: 1px solid #e7e5e4;
    border-radius: 12px;
    background: #fff;
    text-align: left;
}

.qcm-hero__point strong {
    font-size: 0.9rem;
    color: #1c1917;
}

.qcm-hero__point span {
    font-size: 0.82rem;
    color: #78716c;
    line-height: 1.6;
}

/* ============================================================
   ボタン
   ============================================================ */
.qcm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 22px;
    border-radius: 10px;
    font-size: 0.95rem;
    font-weight: 700;
    text-decoration: none;
    transition: opacity 0.15s;
}

.qcm-btn:hover {
    opacity: 0.85;
}

.qcm-btn--primary {
    color: #fff;
    background: linear-gradient(135deg, #b45309 0%, #92400e 100%);
    box-shadow: 0 4px 14px rgba(146, 64, 14, 0.20);
}

.qcm-btn--outline {
    color: #92400e;
    border: 1.5px solid rgba(146, 64, 14, 0.20);
    background: #fff;
}

.qcm-btn--lg {
    min-height: 52px;
    padding: 0 28px;
    font-size: 1rem;
}

/* ============================================================
   比較フォーム
   ============================================================ */
.qcm-form {
    margin-bottom: 32px;
}

.qcm-form__cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.qcm-form__card {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 22px 20px;
    border: 1px solid #e7e5e4;
    border-radius: 14px;
    background: #fff;
}

.qcm-form__card-header {
    padding-bottom: 10px;
    border-bottom: 1px solid #f5f5f4;
}

.qcm-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.qcm-field__label {
    font-size: 0.82rem;
    font-weight: 700;
    color: #57534e;
}

.qcm-field input,
.qcm-field select,
.qcm-field textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #d6d3d1;
    border-radius: 8px;
    background: #fafaf9;
    font: inherit;
    font-size: 0.95rem;
    color: #1c1917;
    box-sizing: border-box;
    transition: border-color 0.15s;
}

.qcm-field input:focus,
.qcm-field select:focus,
.qcm-field textarea:focus {
    outline: none;
    border-color: #b45309;
    box-shadow: 0 0 0 3px rgba(180, 83, 9, 0.08);
}

/* ============================================================
   比較結果
   ============================================================ */
.qcm-results__summaries {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}

.qcm-summary-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 20px;
    border: 1px solid #e7e5e4;
    border-radius: 12px;
    background: #fff;
}

.qcm-summary-card__label {
    margin: 0;
    font-size: 0.8rem;
    font-weight: 700;
    color: #92400e;
}

.qcm-summary-card__value {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
    color: #1c1917;
}

.qcm-summary-card__note {
    font-size: 0.88rem;
}

/* ---- 比較テーブル ---- */
.qcm-table-wrap {
    padding: 24px;
    border: 1px solid #e7e5e4;
    border-radius: 14px;
    background: #fff;
}

.qcm-table-wrap__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
}

.qcm-table-wrap__hint {
    margin: 0;
    font-size: 0.85rem;
    font-weight: 600;
    color: #a8a29e;
}

.qcm-table {
    display: grid;
    gap: 6px;
}

.qcm-table__row {
    display: grid;
    grid-template-columns: 130px repeat(3, minmax(0, 1fr));
    gap: 6px;
}

.qcm-table__row--head {
    font-weight: 800;
}

.qcm-table__row--head .qcm-table__cell {
    color: #92400e;
    background: rgba(254, 243, 199, 0.35);
    border-color: rgba(146, 64, 14, 0.08);
}

.qcm-table__th,
.qcm-table__cell {
    padding: 12px 14px;
    border-radius: 8px;
    border: 1px solid #f5f5f4;
    background: #fafaf9;
    font-size: 0.92rem;
    line-height: 1.65;
}

.qcm-table__th {
    font-weight: 700;
    color: #78716c;
    background: #f5f5f4;
}

.qcm-table__cell--best {
    background: rgba(254, 243, 199, 0.4);
    border-color: rgba(180, 83, 9, 0.18);
    font-weight: 600;
}

/* ============================================================
   比較観点
   ============================================================ */
.qcm-checkpoints {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.qcm-checkpoint {
    display: flex;
    gap: 16px;
    padding: 24px;
    border: 1px solid #e7e5e4;
    border-radius: 14px;
    background: #fff;
}

.qcm-checkpoint__icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    font-size: 1.15rem;
    font-weight: 800;
    color: #92400e;
    background: rgba(254, 243, 199, 0.5);
    border-radius: 10px;
}

.qcm-checkpoint__body {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.qcm-checkpoint h3 {
    font-size: 1rem;
}

.qcm-checkpoint p {
    font-size: 0.92rem;
}

/* ============================================================
   使い方ステップ
   ============================================================ */
.qcm-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.qcm-step {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 24px;
    border: 1px solid #e7e5e4;
    border-radius: 14px;
    background: #fff;
}

.qcm-step__number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    font-size: 1rem;
    font-weight: 800;
    color: #92400e;
    background: rgba(254, 243, 199, 0.5);
    border-radius: 8px;
}

.qcm-step__body {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.qcm-step h3 {
    font-size: 1rem;
}

.qcm-step p {
    font-size: 0.92rem;
}

/* ============================================================
   FAQ
   ============================================================ */
.qcm-faq-list {
    max-width: 740px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.qcm-faq {
    padding: 18px 22px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.04);
}

.qcm-faq summary {
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 10px;
}

.qcm-faq summary::-webkit-details-marker {
    display: none;
}

.qcm-faq summary::before {
    content: "+";
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    font-size: 1rem;
    font-weight: 700;
    color: #fbbf24;
    border: 1.5px solid rgba(251, 191, 36, 0.25);
    border-radius: 6px;
}

.qcm-faq[open] summary::before {
    content: "−";
    background: rgba(251, 191, 36, 0.10);
}

.qcm-faq summary h3 {
    font-size: 0.95rem;
    font-weight: 600;
}

.qcm-faq p {
    margin: 12px 0 0 36px;
    font-size: 0.9rem;
}

/* ============================================================
   CTA
   ============================================================ */
.qcm-cta {
    max-width: 640px;
    margin: 0 auto;
    padding: 40px 36px;
    text-align: center;
    border: 1px solid #e7e5e4;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 16px 48px rgba(28, 25, 23, 0.05);
}

.qcm-cta p {
    margin-top: 10px;
}

.qcm-cta__actions {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

/* ============================================================
   フッター
   ============================================================ */
.qcm-footer {
    padding: 24px 0 48px;
}

.qcm-footer__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 20px 24px;
    border: 1px solid #e7e5e4;
    border-radius: 12px;
    background: #fff;
}

.qcm-footer__links {
    display: flex;
    gap: 16px;
}

.qcm-footer a {
    color: #92400e;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 960px) {
    .qcm-form__cards,
    .qcm-results__summaries,
    .qcm-steps,
    .qcm-hero__points {
        grid-template-columns: 1fr;
    }

    .qcm-checkpoints {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .qcm-table__row {
        grid-template-columns: 1fr;
    }

    .qcm-table__row--head {
        display: none;
    }
}

@media (max-width: 640px) {
    .qcm-shell {
        width: min(100% - 20px, 1120px);
    }

    .qcm-hero {
        padding: 36px 0 28px;
    }

    .qcm-section {
        padding: 36px 0;
    }

    .qcm-hero__actions,
    .qcm-cta__actions {
        flex-direction: column;
        align-items: center;
    }

    .qcm-btn {
        width: 100%;
        max-width: 320px;
    }

    .qcm-form__card,
    .qcm-summary-card,
    .qcm-checkpoint,
    .qcm-step,
    .qcm-table-wrap,
    .qcm-cta {
        padding: 18px 16px;
        border-radius: 10px;
    }

    .qcm-faq {
        padding: 14px 16px;
    }

    .qcm-faq p {
        margin-left: 0;
    }

    .qcm-footer__inner {
        flex-direction: column;
        text-align: center;
    }

    .qcm-footer__links {
        flex-direction: column;
        gap: 8px;
    }
}
