/* === お問い合わせページ === */
/* ヒーロー(比較ページと同じ濃紺→青トンマナ) */
.ct-hero{background:linear-gradient(135deg,#0a2540 0%,#1a6dc4 100%);color:#fff;padding:54px 0 58px;position:relative;overflow:hidden}
.ct-hero::after{content:"";position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="60" height="60"><path d="M0 30h60M30 0v60" stroke="%23ffffff" stroke-width="0.5" opacity="0.06"/></svg>')}
.ct-hero-inner{max-width:1080px;margin:0 auto;padding:0 24px;position:relative;z-index:1;text-align:center}
.ct-hero .eyebrow{font-family:var(--latin);letter-spacing:.16em;font-size:13.5px;font-weight:700;color:var(--sky);text-transform:uppercase}
.ct-hero h1{font-family:var(--serif);font-size:48px;line-height:1.3;font-weight:800;margin:12px 0 14px}
.ct-hero .ac{color:#ffd34f}
.ct-hero p{font-size:15.5px;line-height:1.9;color:rgba(255,255,255,.92);max-width:680px;margin:0 auto}
/* 安心バッジ列 */
.ct-assure{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:24px}
.ct-assure .a{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:99px;padding:8px 16px;font-size:14px;font-weight:700;color:#fff}
.ct-assure .a svg{flex:none}

/* レイアウト: 左フォーム + 右サイド */
.ct-wrap{max-width:1080px;margin:0 auto;padding:54px 24px}
.ct-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:36px;align-items:start}
@media(max-width:880px){.ct-grid{grid-template-columns:1fr;gap:28px}}

/* 連絡手段の選択(電話/フォーム) */
.ct-channels{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:34px}
@media(max-width:560px){.ct-channels{grid-template-columns:1fr}}
.ct-ch{border:1px solid var(--line);border-radius:14px;padding:22px;text-align:center;background:#fff;transition:.25s}
.ct-ch.phone{background:linear-gradient(160deg,#eaf3fb,#fff);border-color:#cfe3f7}
.ct-ch .ic{width:46px;height:46px;border-radius:12px;background:var(--blue-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.ct-ch h3{font-size:16px;color:var(--navy);font-weight:700;margin:0 0 6px}
.ct-ch .big{font-family:var(--latin);font-weight:800;font-size:26px;color:var(--blue);line-height:1.1;letter-spacing:.01em}
.ct-ch .sub{font-size:13px;color:var(--gray);margin-top:6px}

/* フォーム */
.ct-form{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 28px;box-shadow:0 12px 40px rgba(10,37,64,.06)}
.ct-progress{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--gray);margin-bottom:20px}
.ct-progress b{color:var(--blue)}
.ct-field{margin-bottom:20px}
.ct-field>label{display:block;font-size:15px;font-weight:700;color:var(--navy);margin-bottom:8px}
.ct-field .req{display:inline-block;background:var(--orange);color:#fff;font-size:11.5px;font-weight:700;border-radius:4px;padding:2px 7px;margin-left:8px;vertical-align:middle}
.ct-field .opt{display:inline-block;background:#eef2f6;color:var(--gray);font-size:11.5px;font-weight:700;border-radius:4px;padding:2px 7px;margin-left:8px;vertical-align:middle}
.ct-field input[type=text],.ct-field input[type=email],.ct-field input[type=tel],.ct-field textarea,.ct-field select{
  width:100%;border:1.5px solid var(--line);border-radius:10px;padding:13px 14px;font-size:16px;font-family:inherit;color:var(--ink);background:#fcfdff;transition:.2s;box-sizing:border-box}
.ct-field input:focus,.ct-field textarea:focus,.ct-field select:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(26,109,196,.12)}
.ct-field textarea{min-height:120px;resize:vertical}
.ct-field .hint{font-size:13px;color:var(--gray);margin-top:6px}
/* 種別をボタン選択に(心理的ハードル低減) */
.ct-types{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:560px){.ct-types{grid-template-columns:1fr}}
.ct-type{position:relative;cursor:pointer}
.ct-type input{position:absolute;opacity:0}
.ct-type span{display:flex;align-items:center;gap:9px;border:1.5px solid var(--line);border-radius:10px;padding:13px 14px;font-size:15px;font-weight:700;color:var(--ink);background:#fcfdff;transition:.18s}
.ct-type span::before{content:"";width:18px;height:18px;border-radius:50%;border:2px solid #c2d3e2;flex:none;transition:.18s}
.ct-type input:checked+span{border-color:var(--blue);background:var(--blue-pale);color:var(--blue)}
.ct-type input:checked+span::before{border-color:var(--blue);background:radial-gradient(circle,#fff 0 30%,var(--blue) 40%)}
/* 同意 */
.ct-agree{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--ink);margin:8px 0 22px;line-height:1.6}
.ct-agree input{margin-top:3px;width:17px;height:17px;flex:none}
.ct-agree a{color:var(--blue)}
/* 送信ボタン */
.ct-submit{width:100%;background:var(--orange);color:#fff;font-size:17px;font-weight:800;border:none;border-radius:12px;padding:18px;cursor:pointer;transition:.25s;box-shadow:0 12px 30px rgba(232,101,79,.32)}
.ct-submit:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(232,101,79,.42)}
.ct-submit:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.ct-submit-note{text-align:center;font-size:13px;color:var(--gray);margin-top:12px}
/* 送信完了メッセージ */
.ct-done{display:none;text-align:center;padding:40px 20px}
.ct-done.show{display:block}
.ct-done .ck{width:64px;height:64px;border-radius:50%;background:#e8f7ef;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.ct-done h3{font-size:20px;color:var(--navy);margin:0 0 10px}
.ct-done p{font-size:15px;color:var(--gray);line-height:1.9}

/* 右サイド */
.ct-side{display:flex;flex-direction:column;gap:20px}
.ct-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px}
.ct-card h3{font-size:16px;color:var(--navy);font-weight:800;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.ct-steps{list-style:none;margin:0;padding:0;counter-reset:s}
.ct-steps li{position:relative;padding:0 0 16px 38px;counter-increment:s;font-size:14.5px;color:var(--ink);line-height:1.6}
.ct-steps li::before{content:counter(s);position:absolute;left:0;top:0;width:26px;height:26px;border-radius:50%;background:var(--blue);color:#fff;font-family:var(--latin);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center}
.ct-steps li::after{content:"";position:absolute;left:12px;top:28px;bottom:2px;width:2px;background:var(--line)}
.ct-steps li:last-child{padding-bottom:0}
.ct-steps li:last-child::after{display:none}
.ct-steps li b{display:block;color:var(--navy);font-weight:700;margin-bottom:2px}
/* 実績ミニ */
.ct-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ct-stats .s b{display:block;font-family:var(--latin);font-weight:800;font-size:24px;color:var(--blue);line-height:1}
.ct-stats .s b small{font-size:55%}
.ct-stats .s span{font-size:12.5px;color:var(--gray);margin-top:4px;display:block}
/* お客様の声 */
.ct-voice p{font-size:14.5px;color:var(--ink);line-height:1.8;margin:0 0 10px;padding-left:16px;border-left:3px solid var(--sky);font-style:italic}
.ct-voice .who{font-size:13px;color:var(--gray);text-align:right;font-style:normal}
/* ミニFAQ */
.ct-faq dt{font-size:14.5px;font-weight:700;color:var(--navy);margin-bottom:5px}
.ct-faq dd{font-size:14px;color:var(--gray);line-height:1.75;margin:0 0 14px}
.ct-faq dd:last-child{margin-bottom:0}

/* スマホ ヒーローH1縮小 */
@media(max-width:640px){.ct-hero h1{font-size:clamp(24px,6.5vw,32px);line-height:1.4}}
