    body {margin: 0;
    }
/* --- CSS変数（スコープ内で定義） --- */
        .cl-sim {
            --cl-primary:       #335171;
            --cl-primary-dark:  #254060;
            --cl-primary-light: #e9f8ff;
            --cl-primary-pale:  #f6fcff;
            --cl-accent:        #ffd801;
            --cl-accent-dark:   #e6c200;
            --cl-bg:            #f6fcff;
            --cl-card:          #ffffff;
            --cl-text:          #335171;
            --cl-text-dark:     #1a2e42;
            --cl-text-mid:      #4a6580;
            --cl-text-light:    #6b8399;
            --cl-border:        #c8dde9;
            --cl-success:       #1e8c5a;
            --cl-badge-bg:      #dff0fa;
        }

        /* --- ベーススタイル --- */
        .cl-sim {
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
            background: var(--cl-bg);
            color: var(--cl-text);
            line-height: 1.8;
            font-size: 16px;
            box-sizing: border-box;
        }

        /* border-box をスコープ内の全要素に適用 */
        .cl-sim *,
        .cl-sim *::before,
        .cl-sim *::after {
            box-sizing: border-box;
        }

        /* =============================================
           フォーム要素の完全リセット
           WordPressテーマの input / label / button 干渉を防ぐ
           ============================================= */

        /* input（checkbox・radio・number 共通） */
        .cl-sim input[type="checkbox"],
        .cl-sim input[type="radio"],
        .cl-sim input[type="number"] {
            all: revert;           /* テーマCSSをリセット */
            box-sizing: border-box;
            margin: 0;
            padding: 0;
            border: none;
            outline: none;
            background: transparent;
            font-family: inherit;
            font-size: inherit;
            line-height: normal;
            -webkit-appearance: none;
            appearance: none;
        }

        /* checkbox・radio は accent-color のみ復元 */
        .cl-sim input[type="checkbox"],
        .cl-sim input[type="radio"] {
            -webkit-appearance: auto;
            appearance: auto;
            width: 19px;
            height: 19px;
            flex-shrink: 0;
            pointer-events: none; /* クリックはlabel全体で受ける */
            cursor: pointer;
            accent-color: var(--cl-primary);
        }

        /* 時給入力フィールド専用スタイル */
        .cl-sim input[type="number"].cl-hourly-input {
            width: 105px;
            padding: 8px 10px;
            border-radius: 4px;
            border: none;
            background: white;
            color: var(--cl-primary-dark);
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
            font-size: 0.95rem;
            font-weight: 700;
            text-align: right;
            line-height: 1.5;
            -moz-appearance: textfield; /* Firefox のスピナー非表示 */
        }
        /* Chrome・Safari のスピナー非表示 */
        .cl-sim input[type="number"].cl-hourly-input::-webkit-inner-spin-button,
        .cl-sim input[type="number"].cl-hourly-input::-webkit-outer-spin-button {
            -webkit-appearance: none;
            margin: 0;
        }
        .cl-sim input[type="number"].cl-hourly-input:focus {
            outline: 2px solid rgba(255, 255, 255, 0.55);
            outline-offset: 1px;
        }

        /* label のテーマリセット */
        .cl-sim label {
            all: revert;
            box-sizing: border-box;
            display: flex;
            align-items: center;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
            font-size: inherit;
            color: inherit;
            cursor: pointer;
            font-weight: normal;
        }

        /* button のテーマリセット */
        .cl-sim button {
            all: revert;
            box-sizing: border-box;
            display: inline-block;
            cursor: pointer;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
            border: none;
            background: none;
        }

        /* a タグのテーマリセット */
        .cl-sim a {
            text-decoration: none;
            color: inherit;
        }

        /* =============================================
           ヘッダー
           ============================================= */
        .cl-sim .cl-header {
            background: var(--cl-primary);
            color: white;
            padding: 32px 20px;
            text-align: center;
        }
        .cl-sim .cl-header-eyebrow {
            font-size: 0.78rem;
            letter-spacing: 0.12em;
            opacity: 0.72;
            margin-bottom: 10px;
            display: block;
        }
        .cl-sim .cl-header h1 {
            font-size: clamp(1.25rem, 4vw, 1.65rem);
            font-weight: 800;
            line-height: 1.4;
            margin-bottom: 10px;
            color: white;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
        }
        .cl-sim .cl-header p {
            font-size: clamp(0.875rem, 2.5vw, 0.95rem);
            opacity: 0.85;
            max-width: 520px;
            margin: 0 auto;
            line-height: 1.75;
        }

        /* =============================================
           ステップインジケーター
           ============================================= */
        .cl-sim .cl-progress {
            background: white;
            padding: 16px 20px;
            border-bottom: 1px solid var(--cl-border);
            position: sticky;
            top: 0;
            z-index: 100;
            box-shadow: 0 2px 8px rgba(51,81,113,0.08);
        }
        .cl-sim .cl-steps {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 6px;
            max-width: 480px;
            margin: 0 auto;
        }
        .cl-sim .cl-step-ind {
            display: flex;
            align-items: center;
            gap: 7px;
            font-size: 0.82rem;
            color: var(--cl-text-light);
            font-weight: 500;
            transition: color 0.2s;
        }
        .cl-sim .cl-step-ind.active { color: var(--cl-primary); font-weight: 700; }
        .cl-sim .cl-step-ind.done   { color: var(--cl-success); }
        .cl-sim .cl-step-num {
            width: 27px;
            height: 27px;
            border-radius: 50%;
            background: var(--cl-border);
            color: var(--cl-text-light);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 0.8rem;
            font-weight: 700;
            flex-shrink: 0;
            transition: background 0.2s, color 0.2s;
        }
        .cl-sim .cl-step-ind.active .cl-step-num { background: var(--cl-primary); color: white; }
        .cl-sim .cl-step-ind.done   .cl-step-num { background: var(--cl-success); color: white; }
        .cl-sim .cl-step-label { display: none; }
        @media (min-width: 400px) { .cl-sim .cl-step-label { display: inline; } }
        .cl-sim .cl-step-line {
            flex: 1;
            max-width: 44px;
            height: 2px;
            background: var(--cl-border);
            border-radius: 1px;
        }

        /* =============================================
           メインレイアウト
           ============================================= */
        .cl-sim .cl-main {
            max-width: 740px;
            margin: 0 auto;
            padding: 28px 16px 56px;
        }
        .cl-sim .cl-section { display: none; }
        .cl-sim .cl-section.active { display: block; }

        .cl-sim .cl-section-title {
            font-size: clamp(1.05rem, 3.5vw, 1.2rem);
            font-weight: 800;
            color: var(--cl-text-dark);
            margin-bottom: 6px;
            line-height: 1.4;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
        }
        .cl-sim .cl-section-desc {
            font-size: 0.95rem;
            color: var(--cl-text-mid);
            margin-bottom: 22px;
            line-height: 1.75;
        }

        /* =============================================
           カード共通
           ============================================= */
        .cl-sim .cl-card {
            background: var(--cl-card);
            border-radius: 6px;
            padding: 22px 20px;
            margin-bottom: 16px;
            border: 1px solid var(--cl-border);
            box-shadow: 0 2px 10px rgba(51,81,113,0.06);
        }
        .cl-sim .cl-card-title {
            font-size: 0.92rem;
            font-weight: 700;
            color: var(--cl-primary);
            margin-bottom: 16px;
            padding-left: 11px;
            border-left: 3px solid var(--cl-accent);
            line-height: 1.5;
            display: block;
        }

        /* =============================================
           チェックアイテム
           ============================================= */
        .cl-sim .cl-check-list {
            display: flex;
            flex-direction: column;
            gap: 9px;
            list-style: none;
            padding: 0;
            margin: 0;
        }
        .cl-sim label.cl-check-item {
            display: flex;
            align-items: center;
            gap: 13px;
            padding: 13px 16px;
            border-radius: 4px;
            border: 1.5px solid var(--cl-border);
            cursor: pointer;
            transition: border-color 0.15s, background 0.15s;
            background: white;
            font-weight: normal;
            color: var(--cl-text-dark);
        }
        .cl-sim label.cl-check-item:hover   { border-color: var(--cl-primary); background: var(--cl-primary-pale); }
        .cl-sim label.cl-check-item.checked { border-color: var(--cl-primary); background: var(--cl-primary-light); }
        .cl-sim .cl-check-text {
            font-size: 0.95rem;
            line-height: 1.6;
            color: var(--cl-text-dark);
            flex: 1;
        }

        /* =============================================
           ラジオアイテム
           ============================================= */
        .cl-sim .cl-radio-group {
            display: flex;
            flex-direction: column;
            gap: 9px;
        }
        .cl-sim label.cl-radio-item {
            display: flex;
            align-items: center;
            gap: 13px;
            padding: 13px 16px;
            border-radius: 4px;
            border: 1.5px solid var(--cl-border);
            cursor: pointer;
            transition: border-color 0.15s, background 0.15s;
            background: white;
            font-weight: normal;
            color: var(--cl-text-dark);
        }
        .cl-sim label.cl-radio-item:hover    { border-color: var(--cl-primary); background: var(--cl-primary-pale); }
        .cl-sim label.cl-radio-item.selected { border-color: var(--cl-primary); background: var(--cl-primary-light); }
        .cl-sim .cl-radio-text {
            font-size: 0.95rem;
            color: var(--cl-text-dark);
            flex: 1;
        }

        /* =============================================
           バリデーションエラー
           ============================================= */
        .cl-sim .cl-error {
            color: #c0392b;
            font-size: 0.9rem;
            margin-top: 10px;
            display: none;
            padding: 11px 14px;
            background: #fdf0ee;
            border-radius: 4px;
            border-left: 3px solid #c0392b;
        }

        /* =============================================
           ボタン
           ============================================= */
        .cl-sim .cl-btn-wrap {
            display: flex;
            justify-content: flex-end;
            gap: 10px;
            margin-top: 26px;
        }
        .cl-sim button.cl-btn {
            padding: 13px 30px;
            border-radius: 4px;
            font-size: 0.95rem;
            font-weight: 700;
            cursor: pointer;
            border: none;
            transition: all 0.15s;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
            letter-spacing: 0.03em;
            line-height: 1.4;
        }
        .cl-sim button.cl-btn-primary {
            background: var(--cl-accent);
            color: var(--cl-primary-dark);
        }
        .cl-sim button.cl-btn-primary:hover {
            background: var(--cl-accent-dark);
            transform: translateY(-1px);
        }
        .cl-sim button.cl-btn-secondary {
            background: white;
            color: var(--cl-text);
            border: 1.5px solid var(--cl-border);
        }
        .cl-sim button.cl-btn-secondary:hover { background: var(--cl-primary-pale); }

        /* =============================================
           結果：サマリーカード
           ============================================= */
        .cl-sim .cl-summary {
            background: var(--cl-primary);
            color: white;
            border-radius: 6px;
            padding: 26px 22px;
            margin-bottom: 22px;
        }
        .cl-sim .cl-summary-label {
            font-size: 0.82rem;
            opacity: 0.8;
            margin-bottom: 16px;
            letter-spacing: 0.04em;
            display: block;
        }
        .cl-sim .cl-summary-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 12px;
            margin-bottom: 14px;
        }
        .cl-sim .cl-summary-box {
            background: rgba(255,255,255,0.14);
            border-radius: 4px;
            padding: 16px 14px;
        }
        .cl-sim .cl-summary-box-label {
            font-size: 0.8rem;
            opacity: 0.82;
            margin-bottom: 6px;
            line-height: 1.5;
            display: block;
        }
        .cl-sim .cl-summary-box-value {
            font-size: 1.9rem;
            font-weight: 800;
            line-height: 1.15;
            display: block;
        }
        .cl-sim .cl-team-box {
            background: rgba(255,255,255,0.14);
            border-radius: 4px;
            padding: 16px 14px;
            margin-top: 12px;
        }
        .cl-sim .cl-team-box-label {
            font-size: 0.82rem;
            opacity: 0.82;
            margin-bottom: 7px;
            line-height: 1.65;
            display: block;
        }
        .cl-sim .cl-team-box-value {
            font-size: 1.2rem;
            font-weight: 700;
            display: block;
        }
        .cl-sim .cl-hourly-wrap {
            display: flex;
            align-items: center;
            gap: 9px;
            margin-top: 16px;
            flex-wrap: wrap;
        }
        .cl-sim .cl-hourly-label {
            font-size: 0.82rem;
            opacity: 0.82;
            white-space: nowrap;
            color: white;
        }
        .cl-sim .cl-hourly-unit {
            font-size: 0.82rem;
            opacity: 0.82;
            color: white;
        }
        .cl-sim .cl-summary-note {
            font-size: 0.76rem;
            opacity: 0.7;
            margin-top: 16px;
            line-height: 1.75;
            display: block;
        }

        /* =============================================
           結果：業務別カード
           ============================================= */
        .cl-sim .cl-result-sec-title {
            font-size: 1rem;
            font-weight: 800;
            color: var(--cl-text-dark);
            margin: 22px 0 13px;
            padding-left: 11px;
            border-left: 3px solid var(--cl-accent);
            display: block;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
        }
        .cl-sim .cl-result-card {
            background: white;
            border-radius: 6px;
            padding: 18px 18px 16px;
            margin-bottom: 12px;
            border: 1px solid var(--cl-border);
            box-shadow: 0 2px 8px rgba(51,81,113,0.05);
        }
        .cl-sim .cl-result-card-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            gap: 12px;
            margin-bottom: 11px;
        }
        .cl-sim .cl-result-task-name {
            font-size: 1rem;
            font-weight: 700;
            color: var(--cl-text-dark);
            flex: 1;
            line-height: 1.55;
        }
        .cl-sim .cl-result-badge {
            background: var(--cl-badge-bg);
            color: var(--cl-primary);
            font-size: 0.82rem;
            font-weight: 700;
            padding: 4px 11px;
            border-radius: 3px;
            white-space: nowrap;
            flex-shrink: 0;
        }
        .cl-sim .cl-result-tools {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: 10px;
        }
        .cl-sim .cl-tool-badge {
            background: var(--cl-primary-pale);
            color: var(--cl-primary);
            font-size: 0.8rem;
            font-weight: 700;
            padding: 4px 11px;
            border-radius: 3px;
            border: 1px solid var(--cl-border);
            display: inline-block;
        }
        .cl-sim .cl-result-usage {
            font-size: 0.93rem;
            color: var(--cl-text-mid);
            line-height: 1.8;
        }
        .cl-sim .cl-result-source {
            font-size: 0.76rem;
            color: var(--cl-text-light);
            margin-top: 8px;
            display: block;
        }

        /* =============================================
           ネクストアクション
           ============================================= */
        .cl-sim .cl-next-action {
            background: var(--cl-primary-light);
            border: 1px solid var(--cl-border);
            border-radius: 6px;
            padding: 28px 22px;
            margin-top: 24px;
            text-align: center;
        }
        .cl-sim .cl-next-action h3 {
            font-size: 1.1rem;
            font-weight: 800;
            color: var(--cl-text-dark);
            margin-bottom: 8px;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
        }
        .cl-sim .cl-next-action p {
            font-size: 0.93rem;
            color: var(--cl-text-mid);
            margin-bottom: 20px;
            line-height: 1.75;
        }
        .cl-sim .cl-action-btns {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }
        @media (min-width: 480px) {
            .cl-sim .cl-action-btns { flex-direction: row; justify-content: center; }
            .cl-sim .cl-action-btn  { max-width: 220px; }
        }
        .cl-sim a.cl-action-btn {
            flex: 1;
            display: block;
            padding: 14px 20px;
            border-radius: 4px;
            font-size: 0.93rem;
            font-weight: 700;
            text-decoration: none;
            text-align: center;
            border: none;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
            cursor: pointer;
            transition: all 0.15s;
            letter-spacing: 0.03em;
        }
        .cl-sim a.cl-action-btn-main { background: var(--cl-accent); color: var(--cl-primary-dark); }
        .cl-sim a.cl-action-btn-main:hover { background: var(--cl-accent-dark); }
        .cl-sim a.cl-action-btn-sub  { background: white; color: var(--cl-primary); border: 1.5px solid var(--cl-primary); }
        .cl-sim a.cl-action-btn-sub:hover  { background: var(--cl-primary-pale); }

        /* =============================================
           空の状態
           ============================================= */
        .cl-sim .cl-empty {
            text-align: center;
            padding: 36px;
            color: var(--cl-text-light);
            font-size: 0.95rem;
        }

        /* =============================================
           メール取得フォーム（結果画面）
           ============================================= */
        .cl-sim .cl-lead-form-wrap {
            background: var(--cl-primary);
            border-radius: 6px;
            padding: 26px 22px;
            margin-top: 24px;
        }
        .cl-sim .cl-lead-form-header {
            display: flex;
            align-items: center;
            gap: 10px;
            margin-bottom: 10px;
        }
        .cl-sim .cl-lead-form-icon {
            font-size: 1.8rem;
            line-height: 1;
        }
        .cl-sim .cl-lead-form-title {
            font-size: 1.6rem;
            font-weight: 800;
            color: white;
            line-height: 1.4;
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
        }
        .cl-sim .cl-lead-form-desc {
            font-size: 0.9rem;
            color: rgba(255,255,255,0.88);
            margin-bottom: 16px;
            line-height: 1.75;
            display: block;
        }
        .cl-sim .cl-lead-form-gifts {
            display: flex;
            gap: 30px;
            margin-bottom: 18px;
            justify-content: center;
        }
        .cl-sim .cl-lead-form-gift-item {
            flex: 0 1 36%;
            border-radius: 6px;
            overflow: hidden;
            box-shadow: 0 2px 8px rgba(0,0,0,0.25);
        }
        .cl-sim .cl-lead-form-gift-img {
            width: 100%;
            height: auto;
            display: block;
        }
        .cl-sim .cl-lead-form-guide {
            font-size: 0.9rem;
            font-weight: 700;
            color: rgba(255,255,255,0.9);
            text-align: center;
            margin-bottom: 16px;
            padding: 10px 0;
            border-top: 1px solid rgba(255,255,255,0.2);
            border-bottom: 1px solid rgba(255,255,255,0.2);
        }

        /* フォームのフィールドグループ */
        .cl-sim .cl-field-group {
            display: flex;
            flex-direction: column;
            gap: 10px;
            margin-bottom: 14px;
        }
        @media (min-width: 560px) {
            .cl-sim .cl-field-group { flex-direction: row; }
            .cl-sim .cl-field-group .cl-field { flex: 1; }
        }

        .cl-sim .cl-field {
            display: flex;
            flex-direction: column;
            gap: 5px;
        }
        .cl-sim .cl-field-label {
            font-size: 0.8rem;
            color: rgba(255,255,255,0.82);
            font-weight: 500;
            display: block;
        }

        /* テキスト・メール入力フィールドのリセットと再定義 */
        .cl-sim input[type="text"].cl-text-input,
        .cl-sim input[type="email"].cl-email-input {
            all: revert;
            box-sizing: border-box;
            display: block;
            width: 100%;
            padding: 11px 14px;
            border-radius: 4px;
            border: 2px solid transparent;
            background: white;
            color: var(--cl-text-dark);
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
            font-size: 0.95rem;
            line-height: 1.5;
            outline: none;
            -webkit-appearance: none;
            appearance: none;
            margin: 0;
            transition: border-color 0.15s;
        }
        .cl-sim input[type="text"].cl-text-input:focus,
        .cl-sim input[type="email"].cl-email-input:focus {
            border-color: var(--cl-accent);
            outline: none;
        }
        .cl-sim input[type="text"].cl-text-input::placeholder,
        .cl-sim input[type="email"].cl-email-input::placeholder {
            color: #aab4be;
        }
        /* バリデーションエラー時 */
        .cl-sim input[type="email"].cl-email-input.cl-invalid {
            border-color: #e74c3c;
        }

        /* 送信ボタン */
        .cl-sim button.cl-submit-btn {
            all: revert;
            box-sizing: border-box;
            display: block;
            width: 100%;
            padding: 13px 20px;
            border-radius: 4px;
            border: none;
            background: var(--cl-accent);
            color: var(--cl-primary-dark);
            font-family: 'Noto Sans JP', 'Hiragino Sans', 'Meiryo', sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    cursor: pointer;
    letter-spacing: 0.03em;
    transition: background 0.15s, transform 0.15s;
    line-height: 1.4;
    text-align: center;
    margin: 34px 0 18px;
        }
        .cl-sim button.cl-submit-btn:hover {
            background: var(--cl-accent-dark);
            transform: translateY(-1px);
        }
        .cl-sim button.cl-submit-btn:disabled {
            opacity: 0.6;
            cursor: not-allowed;
            transform: none;
        }

        /* 送信中オーバーレイ */
        .cl-sim .cl-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0, 0, 0, 0.55);
            z-index: 9999;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 18px;
        }
        .cl-sim .cl-overlay.cl-overlay--active {
            display: flex;
        }
        .cl-sim .cl-overlay-loading {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 16px;
        }
        .cl-sim .cl-overlay-spinner {
            width: 48px;
            height: 48px;
            border: 5px solid rgba(255,255,255,0.3);
            border-top-color: #fff;
            border-radius: 50%;
            animation: cl-spin 0.8s linear infinite;
        }
        @keyframes cl-spin { to { transform: rotate(360deg); } }
        .cl-sim .cl-overlay-text {
            color: #fff;
            font-size: 1rem;
            font-weight: 700;
        }
        .cl-sim .cl-overlay-complete {
            display: none;
            flex-direction: column;
            align-items: center;
            gap: 12px;
        }
        .cl-sim .cl-overlay-check {
            width: 72px;
            height: 72px;
            border-radius: 50%;
            background: #1e8c5a;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 2.2rem;
            color: #fff;
            animation: cl-pop 0.3s ease;
        }
        @keyframes cl-pop { from { transform: scale(0.5); opacity: 0; } to { transform: scale(1); opacity: 1; } }
        .cl-sim .cl-overlay-complete-title {
            color: #fff;
            font-size: 1.25rem;
            font-weight: 800;
        }
        .cl-sim .cl-overlay-complete-desc {
            color: rgba(255, 255, 255, 0.85);
            font-size: 0.9rem;
            text-align: center;
        }

        /* エラーメッセージ */
        .cl-sim .cl-form-error {
            font-size: 0.82rem;
            color: #ffd0cc;
            margin-top: 6px;
            display: none;
        }

        /* 送信完了メッセージ */
        .cl-sim .cl-form-success {
            display: none;
            background: rgba(255,255,255,0.14);
            border-radius: 6px;
            padding: 20px;
            text-align: center;
        }
        .cl-sim .cl-form-success-icon {
            font-size: 2rem;
            margin-bottom: 8px;
            display: block;
        }
        .cl-sim .cl-form-success-title {
            font-size: 1rem;
            font-weight: 700;
            color: white;
            margin-bottom: 6px;
            display: block;
        }
        .cl-sim .cl-form-success-text {
            font-size: 0.88rem;
            color: rgba(255,255,255,0.82);
            line-height: 1.7;
            display: block;
        }

        /* プライバシーポリシー同意文 */
        .cl-sim .cl-privacy-note {
            font-size: 0.75rem;
            color: rgba(255,255,255,0.6);
            margin-top: 10px;
            line-height: 1.6;
            display: block;
        }
        .cl-sim .cl-privacy-note a {
            color: rgba(255,255,255,0.8);
            text-decoration: underline;
        }
    /* フッター */
    .footer {
      background: #333;
      border-top: 1px solid rgba(255,255,255,0.08);
      padding: 36px 18px;
    }
    .footer__in {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .footer__logo {
      display: flex;
      align-items: center;
      text-decoration: none; /* リンク化してもアンダーライン非表示 */
    }
    .footer__logo-img {
      height: 28px;
      width: auto;
      display: block;
    }
    .footer__link { font-size: 13px; color: rgba(255,255,255,0.45); text-decoration: underline; text-underline-offset: 3px; }
    /* フッターナビ：中央揃えテキストリンク群 */
    .footer__nav {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 10px;
      flex-wrap: wrap;
    }
    .footer__nav-link {
      font-size: 13px;
      color: rgba(255,255,255,0.55);
      transition: color .2s;
    }
    .footer__nav-link:hover { color: #fff; }
    .footer__nav-sep {
      color: rgba(255,255,255,0.25);
      font-size: 12px;
    }
    .footer__copy { font-size: 12px; color: rgba(255,255,255,0.3); }

 @media (max-width: 640px) {
      /* フッター */
    .footer { padding: 36px 0;}
      .footer__in { flex-direction: column; gap: 12px; text-align: center; }
	 
        .cl-sim .cl-lead-form-gifts {
            display: flex;
            gap: 10px;
            margin-bottom: 18px;
            justify-content: center;
        }
        .cl-sim .cl-lead-form-gift-item {
            flex: 0 1 48%;
            border-radius: 6px;
            overflow: hidden;
            box-shadow: 0 2px 8px rgba(0,0,0,0.25);
        }
    }
