/* SPI性格検査 本格版30問 [spi_seikaku_30]
   _drafts/spi-seikaku-full プロトを名前空間 #spi-seikaku30 配下に移植。
   記事/ページ本文に埋め込む前提。テーマCSSと衝突しないよう全セレクタを #spi-seikaku30 でスコープ。 */

#spi-seikaku30{font-family:'Noto Sans JP',sans-serif;color:#1f2328;font-size:15px;line-height:1.7;scroll-margin-top:80px}
#spi-seikaku30 *{box-sizing:border-box}
/* [spi_seikaku_30] 掲載ページでは集中受検のためサイト共通フッター／モバイル追従メニューを非表示（模試ページと同方針）。
   このCSSは本ショートコードのあるページでしか enqueue されないため、他ページのフッターには影響しない。 */
body .footer,body .fixed-menu{display:none !important}
/* テーマ(entry-content)の見出し余白がバッジ/見出しに乗るのを打ち消す。
   ただし #ss-gate 内は標準spi-miniゲートの余白（eyebrow下1.5em等）を活かすため除外する */
#spi-seikaku30 :is(h2,h3,p):not(:where(#ss-gate *)){margin:0}

/* Progress（記事埋め込みなので fixed でなく sticky。テーマ固定ヘッダーと被らないよう top:62px） */
#spi-seikaku30 .ss-progress-wrap{position:static;background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:10px 14px;margin-bottom:16px}
#spi-seikaku30 .ss-progress-label{font-size:12px;color:#454b4a;margin-bottom:6px}
#spi-seikaku30 .ss-progress-track{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}
#spi-seikaku30 .ss-progress-fill{height:100%;background:linear-gradient(90deg,#26A69A,#4a7fd0);border-radius:3px;transition:width .4s ease}

#spi-seikaku30 .ss-screen{max-width:760px;margin:0 auto}
/* ゲートは標準spi-miniデザインを流用。.spi-mini 基底の外枠ボックス（border/padding/margin）だけ無効化し、
   CSS変数と .spi-mini .spi-mini-gate-* 子孫ルール（タイトル等）は活かす */
#spi-seikaku30 #ss-gate.spi-mini{border:none;padding:0;margin:0 auto;background:transparent;border-radius:0}

/* Intro */
#spi-seikaku30 .ss-intro-card{background:#fff;border-radius:12px;padding:32px 24px;box-shadow:0 2px 8px rgba(0,0,0,.08)}
#spi-seikaku30 .ss-intro-title{font-size:22px;font-weight:700;color:#26A69A;margin-bottom:8px}
#spi-seikaku30 .ss-intro-subtitle{font-size:13px;color:#5f6664;margin-bottom:20px}
#spi-seikaku30 .ss-intro-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:13px}
#spi-seikaku30 .ss-intro-table th,#spi-seikaku30 .ss-intro-table td{border:1px solid #e5e5e5;padding:8px 12px;text-align:left}
#spi-seikaku30 .ss-intro-table th{background:#f0faf9;color:#26A69A;font-weight:600}
#spi-seikaku30 .ss-intro-notice{font-size:12px;color:#5f6664;background:#f9f9f9;border-radius:8px;padding:12px 16px;margin-top:16px}

/* Buttons */
#spi-seikaku30 .ss-btn-start,#spi-seikaku30 .ss-btn-next,#spi-seikaku30 .ss-btn-prev{border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;padding:14px 32px;transition:.2s}
#spi-seikaku30 .ss-btn-start{background:#26A69A;color:#fff;width:100%;margin-top:24px;font-size:17px;padding:16px}
#spi-seikaku30 .ss-btn-start:hover{background:#1f8a80}
#spi-seikaku30 .ss-btn-next{background:#4a7fd0;color:#fff}
#spi-seikaku30 .ss-btn-next:hover{background:#3a6ab8}
#spi-seikaku30 .ss-btn-prev{background:#fff;color:#454b4a;border:1px solid #ccc}
#spi-seikaku30 .ss-btn-prev:hover{background:#f5f5f5}

/* Part banner（緑一色を避け、白地＋青の左アクセント＋オレンジのパートバッジ） */
#spi-seikaku30 .ss-part-banner{background:#fff;border:1px solid #e3efee;border-left:5px solid #4a7fd0;border-radius:10px;padding:14px 18px;text-align:left;margin-bottom:18px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
#spi-seikaku30 .ss-part-banner h2{display:inline-block;font-size:14px;font-weight:800;color:#fff;background:#4a7fd0;border-radius:999px;padding:3px 14px;margin:0 0 8px}
#spi-seikaku30 .ss-part-banner p{font-size:13px;color:#3d4a49;margin:0}

/* Question cards */
#spi-seikaku30 .ss-q-list{display:flex;flex-direction:column;gap:12px}
#spi-seikaku30 .ss-q-card,#spi-seikaku30 .ss-scale-card{background:#fff;border-radius:10px;padding:20px 20px 16px;box-shadow:0 1px 4px rgba(0,0,0,.07)}
#spi-seikaku30 .ss-q-num{font-size:11px;font-weight:700;color:#26A69A;letter-spacing:.05em;margin-bottom:10px}

/* Part1 A/B */
#spi-seikaku30 .ss-ab-row{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}
#spi-seikaku30 .ss-ab-text-a,#spi-seikaku30 .ss-ab-text-b{font-size:15px;line-height:1.6;color:#1f2328;font-weight:700}
#spi-seikaku30 .ss-ab-text-a{text-align:left}
#spi-seikaku30 .ss-ab-text-b{text-align:left}
#spi-seikaku30 .ss-ab-options{display:grid;grid-template-columns:repeat(4,84px);gap:6px;align-items:center;justify-items:center}
#spi-seikaku30 .ss-ab-radio-wrap{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:3px}
/* PCでは段階ラベルを各設問で繰り返さず、第1部の上部ヘッダーに1回だけ出す（冗長さ解消）。モバイルでは各列に表示 */
#spi-seikaku30 .ss-ab-optlabel{display:none}
/* PC用 回答欄ヘッダー：A｜Aに近い / どちらかといえばA / どちらかといえばB / Bに近い｜B（第1部の先頭に1回）
   中央に密に寄せる（両端に間延びさせない）。ラベル列幅は○の列(84px)と一致させ縦に整列 */
#spi-seikaku30 .ss-ab-header{display:flex;justify-content:center;align-items:flex-end;gap:12px;background:transparent;border:none;padding:4px 16px 6px;margin-bottom:0}
#spi-seikaku30 .ss-ab-hend{font-size:15px;font-weight:800;line-height:1}
#spi-seikaku30 .ss-ab-hend.a{color:#26A69A}
#spi-seikaku30 .ss-ab-hend.b{color:#4a7fd0}
#spi-seikaku30 .ss-ab-hopts{display:grid;grid-template-columns:repeat(4,84px);gap:6px;align-items:end}
#spi-seikaku30 .ss-ab-hlabel{font-size:9px;line-height:1.1;color:#3d4a49;text-align:center;white-space:nowrap}
/* ヘッダー直後の設問は上を詰めてラベルを○に近づける（ヘッダーは第1部の凡例＝Q1の真上に密着）。
   list gap(12px) を負マージンで相殺し、Q番号もインライン化して縦距離を最小に */
#spi-seikaku30 .ss-ab-header + .ss-q-card{margin-top:-8px;padding-top:8px}
#spi-seikaku30 .ss-ab-header + .ss-q-card .ss-q-num{margin-bottom:2px}
#spi-seikaku30 .ss-ab-radio-wrap label{width:18px;height:18px}
#spi-seikaku30 .ss-ab-radio-wrap:has(input:checked) .ss-ab-optlabel{color:#1f8a80;font-weight:600}
#spi-seikaku30 .ss-ab-radio-wrap input[type=radio]{display:none}
#spi-seikaku30 .ss-ab-radio-wrap label{width:30px;height:30px;border-radius:50%;border:2px solid #ccc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
#spi-seikaku30 .ss-ab-radio-wrap input[type=radio]:checked+label{background:#26A69A;border-color:#26A69A}
#spi-seikaku30 .ss-ab-radio-wrap input[type=radio]:checked+label::after{content:'';width:11px;height:11px;background:#fff;border-radius:50%;display:block}
/* ○の発散配色：A側(1,2列目)=緑 / B側(3,4列目)=青（A/Bバッジと対応） */
#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(-n+2) label{border-color:#7cc9c1}
#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(n+3) label{border-color:#9db8e4}
#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(-n+2) input[type=radio]:checked+label{background:#26A69A;border-color:#26A69A}
#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(n+3) input[type=radio]:checked+label{background:#4a7fd0;border-color:#4a7fd0}
/* ○のサイズを両端大きく・中央小さく（参考の段階サイズ）。端=1,4列目 / 中央=2,3列目 */
#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(1) label,#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(4) label{width:38px;height:38px}
#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(2) label,#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(3) label{width:28px;height:28px}
#spi-seikaku30 .ss-ab-scale-label{display:flex;justify-content:space-between;font-size:10px;color:#aaa;margin-top:6px}

/* Part2 Scale（本番同様に横並び：文左＋4○右） */
#spi-seikaku30 .ss-scale-row{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center}
#spi-seikaku30 .ss-scale-q{font-size:15px;line-height:1.6;color:#1f2328;font-weight:700}
#spi-seikaku30 .ss-scale-options{display:grid;grid-template-columns:repeat(4,96px);gap:6px;align-items:center;justify-items:center}
#spi-seikaku30 .ss-scale-radio-wrap{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:3px}
/* PCではラベルを上部ヘッダーに1回だけ。各設問での繰り返しは非表示。モバイルは各列に表示 */
#spi-seikaku30 .ss-scale-optlabel{display:none}
#spi-seikaku30 .ss-scale-radio-wrap input[type=radio]{display:none}
#spi-seikaku30 .ss-scale-radio-wrap label{width:30px;height:30px;border-radius:50%;border:2px solid #ccc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
#spi-seikaku30 .ss-scale-radio-wrap input[type=radio]:checked+label{background:#26A69A;border-color:#26A69A}
#spi-seikaku30 .ss-scale-radio-wrap input[type=radio]:checked+label::after{content:'';width:11px;height:11px;background:#fff;border-radius:50%;display:block}
/* ○の発散配色：あてはまる側(1,2列目)=緑 / あてはまらない側(3,4列目)=青 */
#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(-n+2) label{border-color:#7cc9c1}
#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(n+3) label{border-color:#9db8e4}
#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(-n+2) input[type=radio]:checked+label{background:#26A69A;border-color:#26A69A}
#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(n+3) input[type=radio]:checked+label{background:#4a7fd0;border-color:#4a7fd0}
/* ○のサイズを両端大きく・中央小さく。端=1,4列目 / 中央=2,3列目 */
#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(1) label,#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(4) label{width:38px;height:38px}
#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(2) label,#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(3) label{width:28px;height:28px}
/* PC用 第2部 回答欄ヘッダー（第2部の先頭に1回・○列と整列） */
#spi-seikaku30 .ss-scale-header{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:end;padding:4px 20px 6px}
#spi-seikaku30 .ss-scale-hopts{display:grid;grid-template-columns:repeat(4,96px);gap:6px}
#spi-seikaku30 .ss-scale-hlabel{font-size:9px;line-height:1.2;color:#3d4a49;text-align:center}
#spi-seikaku30 .ss-scale-header + .ss-scale-card{margin-top:-8px;padding-top:8px}
#spi-seikaku30 .ss-scale-header + .ss-scale-card .ss-q-num{margin-bottom:2px}

/* Nav */
#spi-seikaku30 .ss-nav-row{display:flex;justify-content:space-between;align-items:center;margin-top:20px}
#spi-seikaku30 .ss-nav-count{font-size:12px;color:#999}

/* Gate（overlay。結果より先・解除前は結果を隠す） */
#spi-seikaku30 .ss-gate{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9999;align-items:center;justify-content:center;padding:16px}
#spi-seikaku30 .ss-gate.is-active{display:flex}
#spi-seikaku30 .ss-gate-box{background:#fff;border-radius:16px;padding:32px 24px;max-width:420px;width:100%;text-align:center;box-shadow:0 8px 32px rgba(0,0,0,.2)}
#spi-seikaku30 .ss-gate-icon{font-size:48px;margin-bottom:12px}
#spi-seikaku30 .ss-gate-title{font-size:19px;font-weight:700;color:#1a1a1a;margin-bottom:8px}
#spi-seikaku30 .ss-gate-desc{font-size:13px;color:#454b4a;margin-bottom:20px;line-height:1.7}
#spi-seikaku30 .ss-gate-line{display:block;background:#06C755;color:#fff;border:none;border-radius:10px;padding:16px;width:100%;font-size:16px;font-weight:700;cursor:pointer;margin-bottom:12px;text-decoration:none}
#spi-seikaku30 .ss-gate-line:hover{background:#05b14c}
#spi-seikaku30 .ss-gate-note{font-size:12px;color:#999;margin-bottom:8px}
#spi-seikaku30 .ss-gate-kw-row{display:flex;gap:8px;margin-top:4px}
#spi-seikaku30 .ss-gate-kw-input{flex:1;border:1.5px solid #ddd;border-radius:8px;padding:10px 12px;font-size:14px}
#spi-seikaku30 .ss-gate-kw-input:focus{outline:none;border-color:#26A69A}
#spi-seikaku30 .ss-gate-kw-btn{background:#26A69A;color:#fff;border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap}
#spi-seikaku30 .ss-gate-kw-btn:hover{background:#1f8a80}
#spi-seikaku30 .ss-gate-error{font-size:12px;color:#e04e4e;margin-top:6px;min-height:18px}

/* ===== Results（報告書風・青基調） ===== */
#spi-seikaku30 .ss-sheet{background:#fff;border:1px solid #d9e6e4;border-radius:8px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.08)}
/* 報告書ヘッダー（緑→青のグラデ＝承認済み配色） */
#spi-seikaku30 .ss-sheet-head{background:linear-gradient(135deg,#1f8a80,#4a7fd0);color:#fff;padding:20px 22px}
#spi-seikaku30 .ss-sheet-kicker{font-size:11px;letter-spacing:.1em;opacity:.9}
/* SANGOテーマの .entry-content h2 装飾（背景帯/枠/擬似要素）が漏れるのを打ち消す */
#spi-seikaku30 .ss-sheet-head h2{font-size:20px;font-weight:800;margin:2px 0 4px;color:#fff;background:none;border:none;box-shadow:none;padding:0}
#spi-seikaku30 .ss-sheet-head h2::before,#spi-seikaku30 .ss-sheet-head h2::after{content:none;display:none;background:none;border:none}
#spi-seikaku30 .ss-sheet-head p{font-size:12px;opacity:.9}
#spi-seikaku30 .ss-sheet-body{padding:16px}
#spi-seikaku30 .ss-sheet-foot{padding:0 16px 16px}

/* セクション（見出し帯＋枠） */
#spi-seikaku30 .ss-sec{border:1px solid #e0e9e8;border-radius:6px;margin-bottom:14px;overflow:hidden}
#spi-seikaku30 .ss-sec-head{background:#eafaf8;color:#1f8a80;font-weight:800;font-size:14px;padding:9px 14px;border-left:5px solid #26A69A;display:flex;align-items:center;gap:8px}
#spi-seikaku30 .ss-sec-head .ss-tag{font-size:10px;background:#4a7fd0;color:#fff;border-radius:3px;padding:1px 6px;font-weight:700}
#spi-seikaku30 .ss-sec-body{padding:14px}

/* 受検概要 */
#spi-seikaku30 .ss-meta-row{display:flex;flex-wrap:wrap;gap:10px}
#spi-seikaku30 .ss-meta-item{flex:1;min-width:110px;background:#f7f9f9;border:1px solid #e0e9e8;border-radius:4px;padding:8px 12px}
#spi-seikaku30 .ss-meta-lbl{font-size:11px;color:#8a908e}
#spi-seikaku30 .ss-meta-val{font-size:15px;font-weight:700}

/* 性格特徴（4側面バー） */
#spi-seikaku30 .ss-axis{margin-bottom:14px}
#spi-seikaku30 .ss-axis:last-child{margin-bottom:0}
#spi-seikaku30 .ss-axis-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
#spi-seikaku30 .ss-axis-name{font-size:14px;font-weight:700}
#spi-seikaku30 .ss-axis-score{font-size:15px;font-weight:800;color:#1f8a80}
#spi-seikaku30 .ss-poles{display:flex;justify-content:space-between;font-size:10px;color:#aaa;margin-bottom:4px}
#spi-seikaku30 .ss-track{height:12px;background:#e8f5f4;border-radius:6px;overflow:hidden}
#spi-seikaku30 .ss-fill{height:100%;background:linear-gradient(90deg,#26A69A,#4a7fd0);border-radius:6px;transition:width 1s cubic-bezier(.4,0,.2,1)}
#spi-seikaku30 .ss-axis-desc{font-size:12px;color:#454b4a;line-height:1.6;margin-top:5px}

/* 職務/組織適応性（★） */
#spi-seikaku30 .ss-fit-grid{display:flex;flex-wrap:wrap;gap:8px}
#spi-seikaku30 .ss-fit{flex:1;min-width:150px;border:1px solid #e0e9e8;border-radius:5px;padding:8px 12px;display:flex;justify-content:space-between;align-items:center}
#spi-seikaku30 .ss-fit-n{font-size:13px;font-weight:600}
#spi-seikaku30 .ss-stars{font-size:13px;letter-spacing:1px;white-space:nowrap}
#spi-seikaku30 .ss-star-on{color:#f5a623}
#spi-seikaku30 .ss-star-off{color:#ddd}
#spi-seikaku30 .ss-simple-note{font-size:11px;color:#aaa;margin-top:8px}

/* 企業からどう見えるか */
#spi-seikaku30 .ss-cv-list{display:flex;flex-direction:column;gap:10px}
#spi-seikaku30 .ss-cv{background:#E4F8F6;border-left:4px solid #26A69A;border-radius:0 8px 8px 0;padding:11px 14px}
#spi-seikaku30 .ss-cv-ax{font-size:12px;font-weight:700;color:#1f8a80;margin-bottom:4px}
#spi-seikaku30 .ss-cv-imp{font-size:14px;line-height:1.7;margin-bottom:5px}
#spi-seikaku30 .ss-cv-fit{font-size:13px;line-height:1.7;color:#555}
#spi-seikaku30 .ss-cv-fit-lbl{display:inline-block;background:#26A69A;color:#fff;font-size:11px;font-weight:700;border-radius:4px;padding:1px 7px;margin-right:6px}

/* 回答の一貫性 */
#spi-seikaku30 .ss-consistency-val{font-size:18px;font-weight:700;color:#1f8a80}
#spi-seikaku30 .ss-consistency-note{font-size:13px;line-height:1.75;color:#555;margin:6px 2px 0}
#spi-seikaku30 .ss-cc{margin-top:12px;background:#fdf6ec;border:1px solid #f3e3c7;border-radius:8px;padding:12px 14px}
#spi-seikaku30 .ss-cc-head{font-size:13px;font-weight:700;color:#c9860a;margin-bottom:10px}
#spi-seikaku30 .ss-cc-item{background:#fff;border:1px solid #f0e6d2;border-radius:8px;padding:10px 12px;margin-bottom:10px}
#spi-seikaku30 .ss-cc-item:last-child{margin-bottom:0}
#spi-seikaku30 .ss-cc-trait{display:inline-block;font-size:11px;font-weight:700;color:#c9860a;background:#fdf0d8;border-radius:4px;padding:2px 8px;margin-bottom:6px}
#spi-seikaku30 .ss-cc-q{font-size:13px;line-height:1.6;color:#1f2328;margin:3px 0}
#spi-seikaku30 .ss-cc-qno{font-weight:700;color:#26A69A;margin-right:5px}
#spi-seikaku30 .ss-cc-qt{color:#444}
#spi-seikaku30 .ss-cc-ans{display:inline-block;color:#1f8a80;font-weight:700;margin-left:4px;white-space:nowrap}
#spi-seikaku30 .ss-cc-note{font-size:12px;color:#999;margin-top:6px;line-height:1.6}

/* 人物イメージ / 注意点 */
#spi-seikaku30 .ss-persona{font-size:14px;line-height:1.9}
#spi-seikaku30 .ss-persona b{color:#1f8a80}
#spi-seikaku30 .ss-caution{background:#fff8f0;border-left:4px solid #f5a623;border-radius:0 6px 6px 0;padding:10px 14px;font-size:13px}
#spi-seikaku30 .ss-caution-list li{margin-left:18px;margin-bottom:4px}

#spi-seikaku30 .ss-result-note{font-size:11px;color:#999;background:#f7f7f7;border-radius:6px;padding:12px 14px;margin:14px 0 12px;line-height:1.7}
#spi-seikaku30 .ss-result-cta{background:#06C755;color:#fff;display:block;text-align:center;border-radius:10px;padding:16px;font-size:16px;font-weight:800;text-decoration:none}
#spi-seikaku30 .ss-result-cta:hover{background:#05b14c}
#spi-seikaku30 .ss-result-home{display:block;text-align:center;border:1px solid #26A69A;color:#26A69A;background:#fff;border-radius:10px;padding:14px;font-size:15px;font-weight:700;text-decoration:none}
#spi-seikaku30 .ss-result-home:hover{background:#E4F8F6}

@media(max-width:600px){
  /* モバイルはカード左右余白を詰めてA/B文の1行幅を稼ぐ */
  #spi-seikaku30 .ss-q-card,#spi-seikaku30 .ss-scale-card{padding:16px 12px 14px}
  /* 第1部A/B：A文→B文を縦に隣接させ、その下に4○を全幅（Bが○の後ろに離れる違和感を解消）。DOM順(A/○/B)はgrid-template-areasで再配置 */
  #spi-seikaku30 .ss-ab-row{grid-template-columns:1fr;grid-template-areas:"a" "b" "opts";gap:8px}
  #spi-seikaku30 .ss-ab-text-a{grid-area:a}
  #spi-seikaku30 .ss-ab-text-b{grid-area:b}
  #spi-seikaku30 .ss-ab-options{grid-area:opts;margin-top:4px}
  /* A文/B文カードは同じ最小高さで揃える＋縦中央。長文でも1行に収まるようフォント/字間/余白を調整（大きさより1行を優先） */
  #spi-seikaku30 .ss-ab-text-a,#spi-seikaku30 .ss-ab-text-b{font-size:13px;letter-spacing:-.01em;line-height:1.5;text-align:left;background:#f5faf9;border-radius:8px;padding:9px 8px 9px 36px;position:relative;min-height:56px;display:flex;align-items:center}
  #spi-seikaku30 .ss-ab-text-a::before,#spi-seikaku30 .ss-ab-text-b::before{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}
  #spi-seikaku30 .ss-ab-text-a::before{content:'A';background:#26A69A}
  #spi-seikaku30 .ss-ab-text-b::before{content:'B';background:#4a7fd0}
  #spi-seikaku30 .ss-ab-options{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2px;width:100%}
  #spi-seikaku30 .ss-ab-radio-wrap{min-width:0}
  /* モバイルはヘッダーを出さず、各列にラベルを表示（縦積みで上部ヘッダーと列がずれるため）。長いラベルは折り返す */
  #spi-seikaku30 .ss-ab-header{display:none}
  #spi-seikaku30 .ss-ab-optlabel{display:flex;align-items:flex-end;justify-content:center;text-align:center;width:100%;min-width:0;min-height:2.6em;font-size:9px;line-height:1.15;color:#525859;white-space:normal;word-break:break-all;overflow-wrap:anywhere;margin-bottom:2px}
  #spi-seikaku30 .ss-ab-radio-wrap label{width:34px;height:34px}
  #spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(1) label,#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(4) label{width:42px;height:42px}
  #spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(2) label,#spi-seikaku30 .ss-ab-options .ss-ab-radio-wrap:nth-child(3) label{width:32px;height:32px}
  /* 第2部scale：縦積み（文の下に4○）＋各列ラベル。ヘッダーは非表示 */
  #spi-seikaku30 .ss-scale-header{display:none}
  #spi-seikaku30 .ss-scale-row{grid-template-columns:1fr;gap:10px}
  #spi-seikaku30 .ss-scale-options{grid-template-columns:repeat(4,minmax(0,1fr));gap:2px;width:100%}
  #spi-seikaku30 .ss-scale-radio-wrap{min-width:0}
  #spi-seikaku30 .ss-scale-optlabel{display:flex;align-items:flex-end;justify-content:center;text-align:center;width:100%;min-width:0;min-height:2.8em;font-size:9px;line-height:1.15;color:#525859;white-space:normal;word-break:break-all;overflow-wrap:anywhere;margin-bottom:2px}
  #spi-seikaku30 .ss-scale-radio-wrap label{width:34px;height:34px}
  #spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(1) label,#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(4) label{width:42px;height:42px}
  #spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(2) label,#spi-seikaku30 .ss-scale-options .ss-scale-radio-wrap:nth-child(3) label{width:32px;height:32px}
  #spi-seikaku30 .ss-intro-card{padding:24px 16px}
  #spi-seikaku30 .ss-gate-box{padding:24px 16px}
  #spi-seikaku30 .ss-progress-wrap{top:56px}
}
