/* ════════════════════════════════════════════
   行政書士オフィスセレッソ — 共通スタイル
   Design System: Sincere & Refined
   曲線（温かみ）× 直線（誠実さ）
════════════════════════════════════════════ */
:root{
  --navy:    #1b3f73;
  --navy-m:  #254e8c;
  --navy-d:  #0d1e38;
  --navy-l:  #e8f0f9;
  --navy-ll: #f5f8fd;
  --blue:    #2d6cb5;
  --blue-l:  #dce8f5;
  --text:    #19253a;
  --mid:     #374f6b;
  --muted:   #607080;
  --light:   #8fa8c0;
  --border:  #d8e4f0;
  --border-l:#edf3fa;
  --white:   #ffffff;
  --bg:      #f7f9fc;
  --serif:   'Shippori Mincho B1','Hiragino Mincho ProN',serif;
  --sans:    'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  --roman:   'Cormorant Garamond',Georgia,serif;
  --r4:  4px;
  --r8:  8px;
  --r16: 16px;
  --r24: 24px;
  --r99: 999px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{font-family:var(--sans);color:var(--text);background:var(--white);line-height:1.85;-webkit-font-smoothing:antialiased;font-weight:400}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--blue-l);color:var(--navy)}

.wrap{max-width:1080px;margin:0 auto;padding:0 32px}
.sec{padding:96px 0}
.sec-bg{background:var(--bg)}
.sec-sm{padding:64px 0}

/* ── ラベル／セクションヘッダー ── */
.sec-h{font-family:var(--serif);font-size:clamp(1.75rem,2.8vw,2.4rem);font-weight:800;color:var(--text);line-height:1.32;margin-bottom:14px;letter-spacing:-.01em}
.sec-sub{font-size:.93rem;color:var(--muted);max-width:560px;line-height:2.05;margin-bottom:52px;font-weight:300}
.cx{text-align:center}
.cx .sec-sub{margin:0 auto 52px}

/* ── ボタン ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:700;cursor:pointer;transition:all .25s;border:none;letter-spacing:.04em;white-space:nowrap}
.btn-fill{background:var(--navy);color:#fff;padding:14px 36px;font-size:.86rem;border-radius:var(--r99);box-shadow:0 4px 16px rgba(27,63,115,.22)}
.btn-fill:hover{background:var(--navy-m);transform:translateY(-2px);box-shadow:0 8px 24px rgba(27,63,115,.28)}
.btn-line{background:transparent;color:var(--navy);border:1.5px solid var(--navy);padding:13px 34px;font-size:.86rem;border-radius:var(--r99)}
.btn-line:hover{background:var(--navy);color:#fff}

/* ══ HEADER ══ */
#hd{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);border-bottom:1px solid rgba(220,229,240,.8);transition:box-shadow .3s}
#hd.sc{box-shadow:0 2px 24px rgba(27,63,115,.07)}
.hd-in{display:flex;align-items:center;justify-content:space-between;height:76px;gap:0}
.logo-img{height:44px;width:auto;background:#fff;padding:3px 8px;border-radius:var(--r8);margin-right:auto}
.hd-nav{display:flex;align-items:center;gap:30px;margin:0 30px}
.hd-nav a{font-size:.78rem;font-weight:500;color:var(--mid);letter-spacing:.08em;transition:color .2s;position:relative;padding-bottom:3px}
.hd-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--blue);border-radius:var(--r99);transition:width .25s}
.hd-nav a:hover,.hd-nav a.active{color:var(--navy)}
.hd-nav a:hover::after,.hd-nav a.active::after{width:100%}
.hd-r{display:flex;align-items:center;gap:20px;flex-shrink:0}
.hd-tel-l{font-size:.56rem;color:var(--light);display:block;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px}
.hd-tel{font-size:1rem;font-weight:700;color:var(--navy);letter-spacing:.04em}
.hd-btn{padding:9px 22px;font-size:.76rem;font-weight:700;background:var(--navy);color:#fff;border:none;border-radius:var(--r99);font-family:var(--sans);cursor:pointer;transition:all .22s;letter-spacing:.06em}
.hd-btn:hover{background:var(--navy-m);transform:translateY(-1px)}
.mb-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.mb-btn span{display:block;width:20px;height:1px;background:var(--text)}

/* ══ MOBILE NAV ══ */
.mob{display:none;position:fixed;inset:0;background:var(--navy-d);z-index:200;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:40px 24px}
.mob.open{display:flex}
.mob a{font-family:var(--serif);font-size:1.2rem;color:rgba(255,255,255,.9);font-weight:700}
.mob a:hover{color:#fff}
.mob-x{position:absolute;top:22px;right:26px;background:none;border:none;color:rgba(255,255,255,.5);font-size:1.4rem;cursor:pointer}

/* ══ PAGE HEAD (下層ページ用ヒーロー) ══ */
.page-head{padding:150px 0 72px;background:linear-gradient(160deg,var(--navy-ll) 0%,var(--blue-l) 60%,var(--navy-ll) 100%);position:relative;overflow:hidden}
.page-head::before{content:'';position:absolute;top:0;right:0;width:340px;height:100%;background:radial-gradient(circle at 70% 40%,rgba(45,108,181,.12),transparent 70%);pointer-events:none}
.ph-in{position:relative;z-index:1}
.ph-h{font-family:var(--serif);font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:800;color:var(--text);line-height:1.3;letter-spacing:-.01em;margin-bottom:14px}
.ph-sub{font-size:.92rem;color:var(--mid);line-height:2;max-width:640px;font-weight:300}

/* ══ パンくず ══ */
.bc{padding:18px 0;background:var(--white);border-bottom:1px solid var(--border-l)}
.bc ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;font-size:.72rem;color:var(--light);letter-spacing:.04em}
.bc li{display:flex;align-items:center;gap:8px}
.bc li+li::before{content:'/';color:var(--light)}
.bc a{color:var(--muted);transition:color .2s}
.bc a:hover{color:var(--navy)}
.bc li:last-child{color:var(--navy);font-weight:700}

/* ══ HERO (トップ) ══ */
#hero{min-height:100vh;display:flex;align-items:center;background:var(--white);padding-top:76px;position:relative;overflow:hidden}
.hero-in{position:relative;z-index:1;padding:80px 0;max-width:680px}
h1.hero-h{font-family:var(--serif);font-size:clamp(2.2rem,4.4vw,3.7rem);font-weight:800;color:var(--text);line-height:1.25;margin-bottom:22px;letter-spacing:-.02em}
h1.hero-h em{font-style:normal;color:var(--navy)}
.hero-underline{display:block;width:64px;height:3px;background:var(--blue);border-radius:var(--r99);margin-bottom:22px}
.hero-p{font-size:.97rem;color:var(--muted);line-height:2.08;margin-bottom:36px;max-width:540px;font-weight:300}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px}
.hero-sep{width:100%;height:1px;background:var(--border);margin-bottom:36px}
.hero-stats{display:flex;gap:0;flex-wrap:nowrap}
.hs{padding:0 24px 0 0}
.hs+.hs{padding-left:24px;border-left:1px solid var(--border)}
.hs-n{font-family:var(--serif);font-size:1.65rem;font-weight:800;color:var(--navy);line-height:1;margin-bottom:4px}
.hs-n span{font-size:.85rem;font-weight:400;color:var(--muted)}
.hs-l{font-size:.78rem;color:var(--muted);letter-spacing:.08em}

/* ══ SERVICES ══ */
.svc-rows{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r16);overflow:hidden;box-shadow:0 2px 20px rgba(27,63,115,.06);background:var(--white)}
.svc-row{display:grid;grid-template-columns:140px 1fr 190px;background:var(--white);transition:background .2s}
.svc-row+.svc-row{border-top:1px solid var(--border)}
.svc-row:hover{background:var(--navy-ll)}
.sr-side{background:var(--navy);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 10px;gap:8px}
.sr-no{font-family:var(--roman);font-size:.65rem;color:rgba(255,255,255,.6);letter-spacing:.16em;text-transform:uppercase}
.sr-name{font-family:var(--serif);font-size:.82rem;font-weight:700;color:#fff;letter-spacing:.1em;line-height:1.5;text-align:center}
.sr-body{padding:32px 36px;border-right:1px solid var(--border)}
.sr-brand{font-family:var(--roman);font-size:.66rem;letter-spacing:.18em;color:var(--blue);text-transform:uppercase;margin-bottom:6px;display:block;font-weight:600}
.sr-title{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.4}
.sr-desc{font-size:.84rem;color:var(--muted);line-height:1.95;margin-bottom:14px;font-weight:300;max-width:480px}
.sr-pts{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:5px 16px}
.sr-pts li{font-size:.77rem;color:var(--mid);display:flex;align-items:flex-start;gap:6px;line-height:1.65;font-weight:300}
.sr-pts li::before{content:'';width:3px;height:3px;background:var(--blue);border-radius:50%;flex-shrink:0;margin-top:8px}
.sr-aside{padding:32px 24px;display:flex;flex-direction:column;justify-content:space-between;gap:14px}
.sr-fee-l{font-family:var(--roman);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--light);display:block;margin-bottom:3px}
.sr-fee{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--navy);line-height:1.3;display:block}
.sr-fee small{font-size:.64rem;font-weight:300;color:var(--muted);display:block;margin-top:2px}
.sr-btn{font-size:.77rem;padding:10px 16px;width:100%;justify-content:center;border-radius:var(--r8);background:var(--navy);color:#fff;border:none;font-family:var(--sans);font-weight:700;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:6px;text-decoration:none}
.sr-btn:hover{background:var(--navy-m)}
.sr-btn::after{content:'→';font-size:.8rem}

/* ══ FEATURES ══ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border-radius:var(--r16);overflow:hidden;box-shadow:0 2px 20px rgba(27,63,115,.06)}
.feat-cell{background:var(--white);padding:36px 28px;transition:background .22s;position:relative}
.feat-cell:hover{background:var(--navy-ll)}
.feat-cell::before{content:'';position:absolute;top:0;left:0;right:0;height:0;background:var(--blue);transition:height .25s}
.feat-cell:hover::before{height:2px}
.feat-n{font-family:var(--roman);font-size:2.8rem;font-weight:600;color:rgba(27,63,115,.07);line-height:1;margin-bottom:16px;letter-spacing:-.02em}
.feat-t{font-family:var(--serif);font-size:.96rem;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.45}
.feat-b{font-size:.82rem;color:var(--muted);line-height:1.95;font-weight:300}

/* ══ CASES ══ */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.case-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r16);overflow:hidden;transition:all .28s;position:relative}
.case-card:hover{box-shadow:0 12px 40px rgba(27,63,115,.1);transform:translateY(-4px);border-color:var(--blue-l)}
.case-top{padding:18px 24px;border-bottom:1px solid var(--border-l);display:flex;align-items:center;gap:10px}
.case-n{font-family:var(--roman);font-size:.65rem;letter-spacing:.14em;color:var(--light);text-transform:uppercase}
.case-body{padding:22px 24px}
.case-ql{font-family:var(--roman);font-size:.64rem;font-weight:600;color:var(--light);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;display:block}
.case-q{font-size:.84rem;color:var(--muted);line-height:1.88;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border-l);font-weight:300}
.case-rl{font-family:var(--roman);font-size:.64rem;font-weight:600;color:var(--blue);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px;display:block}
.case-r{font-family:var(--serif);font-size:.9rem;font-weight:700;color:var(--text);line-height:1.6}

/* ══ VOICES ══ */
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.voice-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r16);padding:30px;position:relative;transition:all .28s;display:flex;flex-direction:column}
.voice-card:hover{box-shadow:0 8px 32px rgba(27,63,115,.09);transform:translateY(-3px);border-color:var(--blue-l)}
.v-q{font-family:var(--roman);font-size:4rem;color:var(--blue-l);line-height:1;position:absolute;top:12px;right:20px;font-style:italic;pointer-events:none}
.v-stars{color:var(--blue);font-size:.84rem;letter-spacing:2px;margin-bottom:11px}
.v-txt{font-size:.84rem;color:var(--muted);line-height:1.95;margin-bottom:18px;font-weight:300}
.v-meta{display:flex;align-items:center;gap:10px;border-top:1px solid var(--border-l);padding-top:14px;margin-top:auto}
.v-av{width:38px;height:38px;background:var(--navy-ll);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.88rem;flex-shrink:0;border:1px solid var(--border);color:var(--navy);font-weight:700;font-family:var(--serif)}
.v-nm{font-size:.79rem;font-weight:700;color:var(--text);margin-bottom:1px}
.v-tp{font-size:.67rem;color:var(--light)}

/* ══ PROFILE ══ */
.prof-wrap{display:grid;grid-template-columns:300px 1fr;gap:64px;align-items:start}
.prof-img-wrap{position:relative}
.prof-img{width:100%;aspect-ratio:3/4;border-radius:var(--r16);overflow:hidden;box-shadow:0 20px 56px rgba(27,63,115,.16);background:var(--bg)}
.prof-img img{width:100%;height:100%;object-fit:cover;object-position:center top}
.prof-badge{background:var(--navy);color:#fff;padding:14px 20px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;border-radius:0 0 var(--r16) var(--r16);margin-top:0}
.pb-t{font-family:var(--roman);font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.pb-n{font-family:var(--serif);font-size:1rem;font-weight:700;color:#fff}
.prof-name{font-family:var(--serif);font-size:2rem;font-weight:800;color:var(--text);margin-bottom:16px;letter-spacing:-.01em}
.prof-lic{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;color:var(--navy);background:var(--navy-ll);border:1px solid var(--border);padding:5px 14px;border-radius:var(--r99);margin-bottom:20px;letter-spacing:.03em}
.prof-msg{font-size:.88rem;color:var(--muted);line-height:2.05;margin-bottom:0;padding:16px 20px;border-left:3px solid var(--blue);background:var(--bg);border-radius:0 var(--r8) var(--r8) 0;font-weight:300}

/* ══ HISTORY ══ */
.ch-wrap{max-width:800px;margin:0 auto}
.ch-row{display:grid;grid-template-columns:160px 1px 1fr;min-height:96px;position:relative;transition:background .22s;border-radius:var(--r8)}
.ch-row:hover{background:var(--navy-ll)}
.ch-year-col{display:flex;align-items:center;justify-content:flex-end;padding:28px 32px 28px 0}
.ch-year{font-family:var(--roman);font-size:clamp(2.2rem,3.8vw,3.2rem);font-weight:700;color:var(--navy);letter-spacing:-.04em;line-height:1;transition:color .3s}
.ch-row:hover .ch-year{color:var(--blue)}
.ch-year-now{color:var(--blue)}
.ch-line-col{display:flex;flex-direction:column;align-items:center;position:relative}
.ch-spine{position:absolute;top:0;left:50%;transform:translateX(-50%);width:1px;bottom:0;background:var(--border)}
.ch-dot{width:12px;height:12px;border-radius:50%;background:var(--white);border:2px solid var(--border);position:relative;z-index:2;flex-shrink:0;margin-top:36px;transition:border-color .3s,background .3s}
.ch-row.ch-in .ch-dot{border-color:var(--blue)}
.ch-dot-now{background:var(--blue) !important;border-color:var(--blue) !important;width:14px;height:14px}
.ch-dot-now::after{content:'';position:absolute;inset:-5px;border-radius:50%;border:1px solid var(--blue);opacity:.4;animation:dotpulse 2.2s ease-in-out infinite}
@keyframes dotpulse{0%{transform:scale(1);opacity:.4}100%{transform:scale(1.7);opacity:0}}
.ch-content{padding:28px 0 28px 32px;opacity:0;transform:translateX(-12px);transition:opacity .65s ease,transform .65s ease}
.ch-row.ch-in .ch-content{opacity:1;transform:translateX(0)}
.ch-title{font-family:var(--serif);font-size:.98rem;font-weight:700;color:var(--text);line-height:1.45;margin-bottom:5px}
.ch-desc{font-size:.82rem;color:var(--muted);line-height:1.9;font-weight:300}

/* ══ OFFICE INFO ══ */
.oi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.oi-full{grid-column:1/-1}
.oi-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r16);padding:24px 22px;display:flex;flex-direction:column;gap:5px;transition:all .25s}
.oi-card:hover{box-shadow:0 6px 24px rgba(27,63,115,.08);border-color:var(--blue-l)}
.oi-card-full{flex-direction:row;align-items:center;gap:18px;padding:26px 28px;border-radius:var(--r16)}
.oi-ico{width:44px;height:44px;background:var(--navy);border-radius:var(--r8);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.oi-ico svg{stroke:#fff;width:20px;height:20px}
.oi-ico-sm{width:34px;height:34px;background:var(--navy-ll);border-radius:var(--r8);display:flex;align-items:center;justify-content:center;margin-bottom:4px;flex-shrink:0}
.oi-ico-sm svg{stroke:var(--navy);opacity:.7;width:18px;height:18px}
.oi-lbl{font-family:var(--roman);font-size:.63rem;letter-spacing:.16em;text-transform:uppercase;color:var(--light);font-weight:600}
.oi-val{font-family:var(--serif);font-size:.95rem;font-weight:700;color:var(--text);line-height:1.4}
.oi-val-lg{font-size:1.25rem}
.oi-sub{font-size:.72rem;color:var(--muted);font-weight:300;line-height:1.55}
.oi-tel-v{color:var(--navy);font-family:var(--serif);font-weight:700;letter-spacing:.04em;font-size:1.3rem}
.oi-svc-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px;width:100%}
.oi-svc-a{display:flex;align-items:center;gap:10px;padding:11px 14px;border:1px solid var(--border);border-radius:var(--r8);background:var(--bg);transition:all .22s}
.oi-svc-a:hover{background:var(--navy);border-color:var(--navy)}
.oi-svc-a:hover .oi-svc-no,.oi-svc-a:hover .oi-svc-name{color:#fff}
.oi-svc-no{font-family:var(--roman);font-size:.63rem;letter-spacing:.14em;color:var(--light);font-weight:600;flex-shrink:0;transition:color .22s}
.oi-svc-name{font-size:.79rem;font-weight:700;color:var(--text);line-height:1.4;transition:color .22s}

/* ══ CTA BAND ══ */
.cta-band{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-m) 100%);color:#fff;padding:72px 0;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.08),transparent 50%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.05),transparent 50%);pointer-events:none}
.cta-in{position:relative;z-index:1}
.cta-h{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.1rem);font-weight:800;color:#fff;line-height:1.4;margin-bottom:14px}
.cta-p{font-size:.88rem;color:rgba(255,255,255,.82);line-height:2;max-width:560px;margin:0 auto 32px;font-weight:300}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-btns .btn-fill{background:#fff;color:var(--navy)}
.cta-btns .btn-fill:hover{background:var(--navy-ll)}
.cta-btns .btn-line{color:#fff;border-color:rgba(255,255,255,.5)}
.cta-btns .btn-line:hover{background:rgba(255,255,255,.1);border-color:#fff;color:#fff}
.cta-tel{display:inline-flex;flex-direction:column;align-items:center;margin-top:22px}
.cta-tel-l{font-family:var(--roman);font-size:.64rem;color:rgba(255,255,255,.55);letter-spacing:.18em;text-transform:uppercase;margin-bottom:4px}
.cta-tel-n{font-family:var(--serif);font-size:1.8rem;font-weight:800;color:#fff;letter-spacing:.06em}

/* ══ 本文用 ══ */
.rich-text{max-width:760px}
.rich-text h2{font-family:var(--serif);font-size:1.4rem;font-weight:800;color:var(--text);margin:42px 0 16px;padding-bottom:10px;border-bottom:2px solid var(--blue);line-height:1.4}
.rich-text h2:first-child{margin-top:0}
.rich-text h3{font-family:var(--serif);font-size:1.08rem;font-weight:700;color:var(--navy);margin:28px 0 12px;line-height:1.5;padding-left:14px;border-left:3px solid var(--blue)}
.rich-text p{font-size:.9rem;color:var(--mid);line-height:2.05;margin-bottom:14px;font-weight:300}
.rich-text ul,.rich-text ol{padding-left:1.4em;margin-bottom:14px}
.rich-text li{font-size:.9rem;color:var(--mid);line-height:2;margin-bottom:4px;font-weight:300}
.rich-text strong{color:var(--navy);font-weight:700}
.rich-text .note{background:var(--navy-ll);border-left:3px solid var(--blue);padding:16px 22px;border-radius:0 var(--r8) var(--r8) 0;font-size:.86rem;color:var(--mid);line-height:2;margin:18px 0}

/* ══ TABLE ══ */
.tbl{width:100%;border-collapse:collapse;font-size:.86rem;background:var(--white);border:1px solid var(--border);border-radius:var(--r8);overflow:hidden}
.tbl th,.tbl td{padding:16px 20px;text-align:left;vertical-align:top;border-bottom:1px solid var(--border-l);line-height:1.8}
.tbl th{background:var(--navy-ll);color:var(--navy);font-weight:700;font-family:var(--serif);width:220px;font-size:.84rem}
.tbl td{color:var(--mid);font-weight:300}
.tbl tr:last-child th,.tbl tr:last-child td{border-bottom:none}

/* ══ FAQ ══ */
.faq-list{display:flex;flex-direction:column;gap:14px;max-width:820px;margin:0 auto}
.faq-item{background:var(--white);border:1px solid var(--border);border-radius:var(--r16);overflow:hidden;transition:box-shadow .25s}
.faq-item[open]{box-shadow:0 8px 28px rgba(27,63,115,.08);border-color:var(--blue-l)}
.faq-q{padding:22px 26px;font-family:var(--serif);font-size:.98rem;font-weight:700;color:var(--text);cursor:pointer;list-style:none;display:flex;align-items:flex-start;gap:14px;line-height:1.55}
.faq-q::-webkit-details-marker{display:none}
.faq-q::before{content:'Q';flex-shrink:0;width:26px;height:26px;background:var(--navy);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--roman);font-size:.78rem;font-weight:700;margin-top:1px}
.faq-q::after{content:'+';margin-left:auto;font-size:1.3rem;color:var(--navy);font-weight:400;line-height:1;transition:transform .25s;flex-shrink:0}
.faq-item[open] .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:4px 26px 24px 66px;font-size:.86rem;color:var(--muted);line-height:2.05;font-weight:300;border-top:1px solid var(--border-l);margin-top:0;padding-top:20px}
.faq-a p+p{margin-top:10px}

/* ══ CONTACT FORM ══ */
.form-wrap{max-width:760px;margin:0 auto;background:var(--white);border:1px solid var(--border);border-radius:var(--r16);padding:44px 44px;box-shadow:0 4px 24px rgba(27,63,115,.06)}
.form-row{margin-bottom:22px}
.form-lbl{display:block;font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:.04em}
.form-lbl .req{color:#c83e3e;font-size:.72rem;margin-left:5px}
.form-input,.form-ta,.form-sel{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--r8);font-family:var(--sans);font-size:.92rem;color:var(--text);background:var(--white);transition:border-color .2s,box-shadow .2s}
.form-input:focus,.form-ta:focus,.form-sel:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(45,108,181,.12)}
.form-ta{min-height:150px;resize:vertical;line-height:1.75}
.form-sub{text-align:center;margin-top:8px}
.form-note{font-size:.76rem;color:var(--muted);line-height:1.8;margin-top:22px;padding:14px 18px;background:var(--bg);border-radius:var(--r8)}

/* ══ ABOUT IDEAL ══ */
.ideal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.ideal-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r16);padding:34px 28px;text-align:center;transition:all .25s}
.ideal-card:hover{box-shadow:0 10px 32px rgba(27,63,115,.08);border-color:var(--blue-l);transform:translateY(-3px)}
.ideal-no{font-family:var(--roman);font-size:.72rem;letter-spacing:.22em;color:var(--blue);text-transform:uppercase;font-weight:600;display:block;margin-bottom:14px}
.ideal-t{font-family:var(--serif);font-size:1.1rem;font-weight:800;color:var(--text);line-height:1.5;margin-bottom:12px}
.ideal-b{font-size:.85rem;color:var(--muted);line-height:2;font-weight:300}

/* ══ PRICE TABLE ══ */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.price-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r16);overflow:hidden;transition:all .28s;display:flex;flex-direction:column}
.price-card:hover{box-shadow:0 12px 36px rgba(27,63,115,.1);border-color:var(--blue-l);transform:translateY(-3px)}
.price-hd{background:var(--navy);color:#fff;padding:26px 24px;text-align:center}
.price-no{font-family:var(--roman);font-size:.66rem;letter-spacing:.2em;color:rgba(255,255,255,.6);text-transform:uppercase;font-weight:600;display:block;margin-bottom:6px}
.price-name{font-family:var(--serif);font-size:1.08rem;font-weight:800;line-height:1.4}
.price-body{padding:28px 26px;flex:1;display:flex;flex-direction:column}
.price-fee{font-family:var(--serif);font-size:1.9rem;font-weight:800;color:var(--navy);line-height:1;margin-bottom:6px;text-align:center}
.price-fee small{font-size:.74rem;color:var(--muted);font-weight:400;display:block;margin-top:6px}
.price-desc{font-size:.82rem;color:var(--muted);line-height:1.95;font-weight:300;margin:14px 0;padding:14px 0;border-top:1px solid var(--border-l);border-bottom:1px solid var(--border-l)}
.price-pts{list-style:none;margin:0 0 18px;flex:1}
.price-pts li{font-size:.8rem;color:var(--mid);line-height:1.8;padding-left:18px;position:relative;margin-bottom:6px;font-weight:300}
.price-pts li::before{content:'';position:absolute;left:0;top:10px;width:8px;height:2px;background:var(--blue);border-radius:var(--r99)}
.price-btn{display:flex;justify-content:center;align-items:center;gap:6px;padding:12px 16px;background:var(--navy);color:#fff;border-radius:var(--r8);font-size:.82rem;font-weight:700;transition:background .2s;margin-top:auto}
.price-btn:hover{background:var(--navy-m);color:#fff}
.price-btn::after{content:'→'}

/* ══ FLOW (申請の流れ) ══ */
.flow{position:relative;padding-left:0;list-style:none;counter-reset:flow}
.flow li{position:relative;padding:24px 26px 24px 86px;background:var(--white);border:1px solid var(--border);border-radius:var(--r16);margin-bottom:14px;transition:all .22s;counter-increment:flow}
.flow li:hover{box-shadow:0 6px 24px rgba(27,63,115,.07);border-color:var(--blue-l)}
.flow li::before{content:counter(flow,decimal-leading-zero);position:absolute;left:22px;top:50%;transform:translateY(-50%);width:48px;height:48px;background:var(--navy);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--roman);font-size:.96rem;font-weight:700;letter-spacing:.04em}
.flow-t{font-family:var(--serif);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.5}
.flow-b{font-size:.84rem;color:var(--muted);line-height:1.9;font-weight:300}

/* ══ FOOTER ══ */
footer{background:var(--navy-d);color:#fff;padding:64px 0 32px}
.ft-in{display:grid;grid-template-columns:1.6fr 1.4fr 1fr;gap:56px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:28px;align-items:start}
.ft-brand-name{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:4px;letter-spacing:.04em}
.ft-addr{font-size:.8rem;line-height:1.95;color:rgba(255,255,255,.7);font-weight:300;font-style:normal}
.ft-nh{font-family:var(--roman);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:18px;font-weight:600;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.ft-nl{list-style:none;display:flex;flex-direction:column;gap:0}
.ft-col-services .ft-nl li{border-bottom:1px solid rgba(255,255,255,.06)}
.ft-col-services .ft-nl a{display:flex;flex-direction:column;gap:2px;padding:12px 0;transition:opacity .2s}
.ft-svc-no{font-family:var(--roman);font-size:.6rem;letter-spacing:.14em;color:rgba(255,255,255,.35);font-weight:600;margin-right:6px}
.ft-col-services .ft-nl a > span:not(.ft-svc-no){font-size:.84rem;font-weight:500;color:#fff;display:inline}
.ft-col-sitemap .ft-nl li{border-bottom:1px solid rgba(255,255,255,.06)}
.ft-col-sitemap .ft-nl a{display:block;padding:10px 0;font-size:.82rem;color:rgba(255,255,255,.78);font-weight:300;transition:color .2s}
.ft-col-sitemap .ft-nl a:hover{color:#fff}
.ft-bot{display:flex;flex-direction:column;align-items:center;text-align:center}
.ft-copy{font-size:.68rem;color:rgba(255,255,255,.38);font-family:var(--roman);letter-spacing:.06em}

/* ── scroll top ── */
.stb{position:fixed;bottom:24px;right:24px;width:44px;height:44px;background:var(--navy);color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transform:translateY(8px);transition:all .28s;z-index:50;box-shadow:0 4px 16px rgba(27,63,115,.22)}
.stb.vis{opacity:1;transform:translateY(0)}
.stb:hover{background:var(--navy-m);transform:translateY(-2px)}

/* ── fade in ── */
.fi{opacity:0;transform:translateY(16px);transition:opacity .65s ease,transform .65s ease}
.fi.vis{opacity:1;transform:translateY(0)}
.fi2{transition-delay:.1s}
.fi3{transition-delay:.18s}

/* ── responsive ── */
@media(max-width:1024px){
  html{font-size:16px}
  .svc-row{grid-template-columns:48px 1fr}
  .sr-aside{display:none}
  .sr-pts{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .case-grid,.voice-grid{grid-template-columns:repeat(2,1fr)}
  .prof-wrap{grid-template-columns:260px 1fr;gap:44px}
  .oi-grid{grid-template-columns:repeat(2,1fr)}
  .oi-svc-list{grid-template-columns:1fr}
  .ft-in{grid-template-columns:1fr 1fr;gap:36px}
  .ft-col-brand{grid-column:1/-1}
  .ideal-grid{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}
}
@media(max-width:768px){
  html{font-size:15px}
  .sec{padding:68px 0}
  .wrap{padding:0 20px}
  .hd-nav,.hd-r{display:none}
  .mb-btn{display:flex}
  .feat-grid,.case-grid,.voice-grid{grid-template-columns:1fr}
  .prof-wrap{grid-template-columns:1fr}
  .oi-grid{grid-template-columns:1fr}
  .oi-full{grid-column:auto}
  .ft-in{grid-template-columns:1fr;gap:28px}
  .ft-col-brand{grid-column:auto}
  .hero-stats{flex-wrap:wrap;gap:16px}
  .hs+.hs{border-left:none;padding-left:0;border-top:1px solid var(--border);padding-top:16px}
  .ch-row{grid-template-columns:80px 1px 1fr}
  .ch-year{font-size:1.9rem}
  .ch-year-col{padding-right:16px}
  .ch-content{padding-left:20px}
  .page-head{padding:120px 0 52px}
  .ideal-grid{grid-template-columns:1fr}
  .form-wrap{padding:28px 24px}
  .tbl th{width:120px;font-size:.78rem;padding:12px 14px}
  .tbl td{padding:12px 14px;font-size:.82rem}
  .cta-tel-n{font-size:1.5rem}
  .flow li{padding:22px 20px 22px 72px}
  .flow li::before{width:40px;height:40px;font-size:.82rem;left:16px}
}

/* ════════════════════════════════════════════
   2026-05-17 監査パッチ（最終デバッグ修正）
   ── 既存スタイルを上書きし、致命的バグを修正
════════════════════════════════════════════ */

/* CRIT-01 / NH-04: JavaScript無効環境でも本文を表示（fade-inのフェイルセーフ）
   .fi { opacity:0 } のままだとJS無効・JSエラー時にコンテンツ非表示
   NH-04: prefers-reduced-motion ブロックは「.fi animation」宣言の後ろに移動し、
          animation: none !important を追加。減モーション環境でも完全に揺れ無し。 */
.no-js .fi, .no-js .ch-content { opacity: 1 !important; transform: none !important; }
/* 6秒後にIntersectionObserverが反応しなかった要素も強制表示（フェイルセーフ） */
@keyframes fi-safety-show { to { opacity: 1; transform: none; } }
.fi { animation: fi-safety-show 0s 6s forwards; }
.fi.vis { animation: none; }
@media (prefers-reduced-motion: reduce) {
  .hero-slide{transition:none!important}
  .fi, .ch-content {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
  }
  .ch-dot-now::after { animation: none !important; }
  html { scroll-behavior: auto !important; }
}

/* CRIT-02: タブレット〜モバイルで料金・CTAボタンが消えるバグを修正
   元: @media(max-width:1024px) { .sr-aside { display:none } }
   → 表示し、レイアウトを縦組みに切り替え */
@media (max-width: 1024px) {
  .svc-row { grid-template-columns: 1fr !important; }
  .sr-side { flex-direction: row; padding: 14px 18px; gap: 14px; grid-row: auto; }
  .sr-name { font-size: .92rem; letter-spacing: .04em; }
  .sr-body { border-right: none; border-bottom: 1px solid var(--border); padding: 24px 22px; }
  .sr-aside {
    display: flex !important;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
    background: var(--navy-ll);
    grid-column: 1;
  }
  .sr-aside .sr-fee { font-size: 1rem; }
  .sr-aside .sr-btn { width: auto; padding: 11px 22px; flex-shrink: 0; }
}
@media (max-width: 600px) {
  .sr-no { font-size: .7rem; }
  .sr-body { padding: 22px 20px; }
  .sr-pts { grid-template-columns: 1fr !important; }
  .sr-aside { flex-direction: column; align-items: stretch; gap: 12px; }
  .sr-aside .sr-btn { width: 100%; }
}

/* CRIT-03: hero `min-height:100vh` がiOS Safariでアドレスバー含めて誤計算
   small viewport unit（svh）にフォールバック付きで対応 */
#hero { min-height: 100vh; min-height: 100svh; }

/* CRIT-04: WCAG AAコントラスト不足の修正（--light #8fa8c0 → #567593 ＝白地で4.8:1） */
:root { --light: #567593; }
/* navy上では明度を上げる（紺地で6.6:1以上を確保） */
.sr-no, .pb-t, .price-no, .cta-tel-l { color: rgba(255,255,255,.75); }
.ft-svc-no { color: rgba(255,255,255,.6); }
.ft-nh { color: rgba(255,255,255,.55); }
.ft-copy { color: rgba(255,255,255,.55); }

/* CRIT-05: 本文の薄すぎるweight 300 を 400 に底上げ（士業の権威性確保） */
body { font-weight: 400; }
.hero-p, .sec-sub, .feat-b, .sr-desc, .case-q, .v-txt, .prof-msg, .ch-desc,
.ideal-b, .price-desc, .price-pts li, .flow-b, .rich-text p, .rich-text li,
.rich-text .note, .ph-sub, .oi-sub, .form-note, .ft-addr, .ft-col-sitemap .ft-nl a {
  font-weight: 400;
}
.cta-p { font-weight: 400; color: rgba(255,255,255,.92) !important; }
/* CRIT-05追補: 底上げから漏れていた4クラス（FAQ回答・サービス箇条書き・比較表・料金注記） */
.faq-a, .sr-pts li, .tbl td, .sr-fee small { font-weight: 400; }

/* CRIT-06: Cases ページで4件目が孤立する崩れを修正（3列→auto-fit） */
.case-grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

/* CRIT-07: details/summary marker のChrome/Firefox残存マーカー除去（基本定義はFAQブロック側に統合済み） */
details > summary::-webkit-details-marker { display: none; }

/* CRIT-08 / NH-01: 横スクロール完全排除
   NH-01: Safari 14/15 は overflow-x:clip 非対応のため、hidden を先に書いて
          progressive enhancement で clip に上書きする */
html, body { overflow-x: hidden; overflow-x: clip; max-width: 100%; }

/* CRIT-09: 大きな装飾電話番号にタップ機能を確保（.cta-tel全体をtel:リンクへ） */
a.cta-tel-link { color: inherit; text-decoration: none; display: inline-flex; flex-direction: column; align-items: center; }
a.cta-tel-link:hover .cta-tel-n { color: var(--blue-l); transition: color .2s; }

/* CRIT-10: ヘッダー1024〜1100pxレンジでのオーバーフロー対策 */
@media (max-width: 1100px) and (min-width: 769px) {
  .hd-nav { gap: 18px; margin: 0 16px; }
  .hd-nav a { font-size: .74rem; letter-spacing: .04em; }
  .hd-r { gap: 12px; }
  .hd-tel { font-size: .9rem; }
  .hd-btn { padding: 8px 16px; font-size: .72rem; }
}

/* CRIT-11: タブレット時のtimeline細線対策 */
@media (max-width: 768px) {
  .ch-row { grid-template-columns: 64px 16px 1fr; }
  .ch-line-col { width: 16px; }
  .ch-content { padding: 22px 0 22px 14px; }
  .ch-year-col { padding: 24px 12px 24px 0; }
}

/* CRIT-12: ロゴ・代表画像のCLS対策（高さ固定済みなので width:auto を明示） */
.logo-img { height: 44px; width: auto; max-width: 200px; }
.prof-img img { width: 100%; height: 100%; }

/* CRIT-13: スキップリンク（キーボード・スクリーンリーダー対応） */
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--navy);
  color: #fff;
  padding: 12px 20px;
  z-index: 9999;
  border-radius: 0 0 var(--r8) 0;
  font-weight: 700;
  font-size: .86rem;
  transition: top .2s;
}
.skip-link:focus { top: 0; outline: 3px solid var(--blue-l); }

/* CRIT-14: フォーカスリングを明確化（アクセシビリティ） */
a:focus-visible, button:focus-visible, summary:focus-visible,
input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 3px solid var(--blue);
  outline-offset: 2px;
  border-radius: var(--r4);
}

/* CRIT-15: ダークモード対応（最低限） */
@media (prefers-color-scheme: dark) {
  /* 行政書士サイトとして純粋なdarkは混乱を招くため白基調を維持
     ただしOS設定で読み上げソフト等が想定する場合に備えて軽い調整 */
  html { color-scheme: light; }
}

/* CRIT-16 / NH-03: ヘッダー固定によるアンカーリンクのスクロール先ズレ防止
   NH-03: skip-link の <a id="main"> や JSON-LD 用の <a id="..."> にも適用させるため
          [id] セレクタで網羅。固定ヘッダー76pxに14px余白を足して90px */
[id] { scroll-margin-top: 90px; }

/* CRIT-17: モバイル時のCTAバンド電話番号タップ領域を最低44pxに */
@media (max-width: 768px) {
  .cta-tel-n { font-size: 1.5rem; padding: 10px 0; }
  .cta-tel-link { padding: 4px 12px; min-height: 44px; justify-content: center; }
}

/* CRIT-18: モバイル時のヒーロー統計を2x2グリッドに整理 */
@media (max-width: 768px) {
  .hero-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; flex-wrap: initial; }
  .hs { padding: 0; }
  .hs+.hs { border-left: none; border-top: none; padding-left: 0; padding-top: 0; }
  .hs:nth-child(n+3) { padding-top: 14px; border-top: 1px solid var(--border); }
}

/* CRIT-19: サービス名は全幅で横書きに統一（縦書き廃止） */
.sr-name { writing-mode: horizontal-tb; -webkit-writing-mode: horizontal-tb; }

/* CRIT-20: モバイルメニューの背景遷移とフォーカストラップ視認性 */
.mob { transition: opacity .25s; }
.mob.open { opacity: 1; }
.mob a:focus-visible { outline: 2px solid #fff; outline-offset: 4px; }
.mob-x { color: rgba(255,255,255,.85) !important; font-size: 1.6rem; padding: 8px 14px; min-width: 44px; min-height: 44px; }

/* CRIT-21: テキストの長い英数字（URL等）のオーバーフロー対策 */
.sr-brand, .ft-addr, .oi-sub { word-break: break-word; overflow-wrap: anywhere; }

/* CRIT-22: フォーム入力のiOS自動ズーム防止（16px以上を確保） */
.form-input, .form-ta, .form-sel { font-size: 16px; }

/* CRIT-23: cases-card の "Result" が h3 ではなく <p> なので、視覚階層を明確化 */
.case-r { font-weight: 700; }

/* CRIT-24: 解決事例 4件目以降の孤立対策（auto-fit + 2列センタリング） */
@media (min-width: 769px) and (max-width: 1024px) {
  .case-grid, .voice-grid { grid-template-columns: repeat(2, 1fr); }
}

/* CRIT-25: 印刷時の余計な要素を非表示 */
@media print {
  #hd, .mob, .cta-band, .stb, .hd-btn, .mb-btn { display: none !important; }
  .fi { opacity: 1 !important; transform: none !important; }
  body { color: #000; background: #fff; }
}

/* CRIT-26: 内部リンクのアクセシブルなホバー */
.bc a:hover, .ft-nl a:hover { text-decoration: underline; text-underline-offset: 3px; }

/* CRIT-27: 大きい数字の `.hs-n span` の最小読み取りサイズ */
.hs-n span { font-size: .9rem; vertical-align: baseline; }

/* CRIT-28: stbボタン（戻るボタン）のz-indexと小さい画面位置 */
@media (max-width: 768px) {
  .stb { bottom: 16px; right: 16px; width: 42px; height: 42px; }
}
/* CRIT-29: フッター法令リンク（privacy / legal）のスタイル */
.ft-legal {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  margin-bottom: 14px;
  padding: 0;
}
.ft-legal li { display: flex; align-items: center; }
.ft-legal li + li::before {
  content: '';
  display: inline-block;
  width: 1px;
  height: 12px;
  background: rgba(255,255,255,.2);
  margin: 0 16px;
}
.ft-legal a {
  font-size: .76rem;
  color: rgba(255,255,255,.7);
  letter-spacing: .04em;
  transition: color .2s;
}
.ft-legal a:hover { color: #fff; text-decoration: underline; text-underline-offset: 3px; }
@media (max-width: 600px) {
  .ft-legal { gap: 0 12px; }
  .ft-legal li + li::before { margin: 0 12px; }
  .ft-legal a { font-size: .74rem; }
}

/* CRIT-30: モバイルナビ最下部の法令リンク */
.mob-legal {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.12);
  font-size: .78rem;
  color: rgba(255,255,255,.55);
  text-align: center;
  font-family: var(--sans);
  letter-spacing: .04em;
  width: 100%;
  max-width: 320px;
}
.mob-legal a {
  font-family: var(--sans);
  font-size: .78rem;
  font-weight: 400;
  color: rgba(255,255,255,.7);
  transition: color .2s;
}
.mob-legal a:hover { color: #fff; }
.mob-legal span { color: rgba(255,255,255,.3); margin: 0 6px; }

/* NM-02: .wrap padding-inline を流動化（大画面で窮屈感を緩和、小画面で詰まりすぎない）
   clamp(下限, 推奨, 上限) で 20px〜40px の間で 4vw 連動 */
.wrap { padding-inline: clamp(20px, 4vw, 40px); padding-left: clamp(20px, 4vw, 40px); padding-right: clamp(20px, 4vw, 40px); }

/* === パッチ終 === */


/* ── 添削対応: ヒーロー背景スライドショー ── */
.hero-slides{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.8s ease-in-out;transform:scale(1.04)}
.hero-slide.on{opacity:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.97) 0%,rgba(255,255,255,.9) 38%,rgba(255,255,255,.6) 68%,rgba(255,255,255,.3) 100%)}
@media(max-width:760px){.hero-overlay{background:rgba(255,255,255,.92)}}

/* ── 添削対応: 解決事例 分野別グループ ── */
.case-group{margin-bottom:48px}
.case-group:last-child{margin-bottom:0}
.case-group-h{font-family:var(--serif);font-size:1.18rem;font-weight:700;color:var(--navy);margin-bottom:18px;padding-left:12px;border-left:3px solid var(--blue)}
.case-client{font-size:.84rem;font-weight:700;color:var(--text);margin-bottom:10px;line-height:1.5}
.case-client span{display:block;font-size:.78rem;font-weight:400;color:var(--mid);margin-top:4px}

/* ── 添削対応: 代表プロフィール項目 ── */
.prof-bio{font-size:.88rem;color:var(--muted);line-height:2.05;margin-top:18px}
.prof-data{display:grid;grid-template-columns:1fr 1fr;gap:10px 28px;margin:18px 0 0}
.prof-data div{display:flex;gap:14px;align-items:baseline;border-bottom:1px solid var(--border-l);padding-bottom:8px}
.prof-data dt{font-size:.78rem;font-weight:700;color:var(--navy);white-space:nowrap;min-width:60px}
.prof-data dd{font-size:.84rem;color:var(--mid);margin:0}
@media(max-width:760px){.prof-data{grid-template-columns:1fr}}


/* ── 棚卸し対応: 中間CTA・モバイル電話・contact関連リンク ── */
.mini-cta{margin:44px auto 0;max-width:760px;background:var(--navy-ll);border:1px solid var(--border);border-radius:16px;padding:30px 28px;text-align:center}
.mini-cta p{font-size:.9rem;color:var(--mid);margin-bottom:18px;line-height:1.9}
.mini-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hd-tel-mb{display:none}
@media(max-width:768px){.hd-tel-mb{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;flex-shrink:0}}
.contact-related{margin-top:44px;text-align:center;font-size:.84rem;color:var(--muted)}
.contact-related span{display:inline-block;margin-right:6px}
.contact-related a{color:var(--blue);text-decoration:underline;text-underline-offset:3px;margin:0 10px;display:inline-block;padding:6px 0}

/* ───────────── EFO（入力フォーム最適化） ───────────── */
/* 進捗インジケーター */
.efo-progress{max-width:760px;margin:0 auto 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.efo-bar{flex:1 1 200px;height:8px;background:var(--navy-l);border-radius:var(--r99);overflow:hidden}
.efo-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--navy-m));border-radius:var(--r99);transition:width .35s ease}
.efo-txt{font-size:.8rem;font-weight:700;color:var(--mid);white-space:nowrap}
.efo-txt .efo-done{color:var(--blue);font-size:.95rem}
.efo-progress.is-complete .efo-bar span{background:#1e9e63}
.efo-progress.is-complete .efo-txt{color:#1e9e63}

/* 必須/任意バッジ */
.form-lbl .opt{color:var(--muted);font-size:.7rem;margin-left:5px;font-weight:500;border:1px solid var(--border);border-radius:var(--r4);padding:1px 6px}

/* ヒント文 */
.form-hint{font-size:.74rem;color:var(--muted);margin:6px 0 0;line-height:1.6}

/* 入力状態（成功/エラー） */
.form-input.is-ok,.form-ta.is-ok,.form-sel.is-ok{border-color:#3aa776;background:#fbfffd}
.form-input.is-err,.form-ta.is-err,.form-sel.is-err{border-color:#d9534f;background:#fffafa}
.form-input.is-err:focus,.form-ta.is-err:focus,.form-sel.is-err:focus{box-shadow:0 0 0 3px rgba(217,83,79,.14)}

/* 入力欄ラッパ（チェックアイコン配置用） */
.in-wrap{position:relative}
.in-wrap .in-tick{position:absolute;right:14px;top:50%;transform:translateY(-50%) scale(.4);width:20px;height:20px;border-radius:50%;background:#3aa776;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
.in-wrap.ok .in-tick{opacity:1;transform:translateY(-50%) scale(1)}
.in-wrap .in-tick svg{width:11px;height:11px;stroke:#fff;stroke-width:3;fill:none}

/* フィールド別メッセージ */
.field-msg{font-size:.76rem;line-height:1.6;margin:7px 0 0;min-height:0;color:var(--muted)}
.field-msg.err{color:#c0392b;font-weight:500}
.field-msg.ok{color:#1e9e63}

/* 文字数カウンタ */
.ta-meta{display:flex;justify-content:flex-end;margin-top:6px;font-size:.74rem;color:var(--muted)}
.ta-meta.warn{color:#c0392b}

/* 送信ボタンまわり */
.sub-rea{font-size:.78rem;color:var(--muted);margin-top:14px;line-height:1.7}
.btn-fill.is-loading{position:relative;color:transparent!important;pointer-events:none;opacity:.85}
.btn-fill.is-loading::after{content:"";position:absolute;top:50%;left:50%;width:18px;height:18px;margin:-9px 0 0 -9px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:efo-spin .7s linear infinite}
@keyframes efo-spin{to{transform:rotate(360deg)}}

@media(prefers-reduced-motion:reduce){
  .efo-bar span,.in-wrap .in-tick{transition:none}
  .btn-fill.is-loading::after{animation:none}
}
