/*
Theme Name: Nagi（凪）— 福島交通事故サポートセンター
Theme URI: https://example.com/
Author: ももの花整骨院
Description: 交通事故相談窓口のためのカスタムテーマ。和の余白とエディトリアル設計（凪デザインシステム）。相談事例・エリア(市別)・ブログをカスタム投稿で管理。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: nagi
*/

/* =========================================================
   凪 (Nagi) Design System — 福島交通事故サポートセンター
   嵐のあとの、静けさ。
   ========================================================= */
:root{
  /* — color tokens — */
  --c-surface:#f4f1e9;     /* 和紙白 */
  --c-surface-2:#fbf9f3;   /* raised */
  --c-ink:#1f262a;         /* 墨 */
  --c-ink-2:#5b676c;
  --c-ink-3:#8b9499;
  --c-line:#e4ded1;        /* 極細罫線 */
  --c-line-2:#d3ccbb;
  --c-brand:#1b3a47;       /* 藍 */
  --c-brand-2:#2c5364;
  --c-on-brand:#eef1ea;
  --c-accent:#9c7a33;      /* 金（面少なく） */
  --c-signal:#9a4327;      /* 柿渋朱（ごく少量） */
  --c-green:#06c755;
  /* — spacing (4px base) — */
  --s2:8px;--s3:12px;--s4:16px;--s5:24px;--s6:32px;--s7:48px;--s8:64px;--s9:96px;
  /* — type scale — */
  --t-xs:.72rem;--t-sm:.82rem;--t-base:1rem;--t-md:1.06rem;--t-lg:1.28rem;
  --t-xl:clamp(1.5rem,1rem + 2.4vw,1.95rem);
  --t-2xl:clamp(2.1rem,1.3rem + 3.8vw,2.95rem);
  /* — radius / motion — */
  --r1:2px;--r2:4px;
  --ease:cubic-bezier(.22,.61,.36,1);--dur:.75s;
  --measure:680px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Noto Sans JP",sans-serif;color:var(--c-ink);background:var(--c-surface);
  font-size:16px;line-height:1.85;letter-spacing:.01em;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;padding-bottom:68px}
.min{font-family:"Shippori Mincho B1",serif}
h1,h2,h3{font-family:"Shippori Mincho B1",serif;font-weight:700;line-height:1.5;letter-spacing:.025em;color:var(--c-brand)}
.wrap{max-width:var(--measure);margin:0 auto;padding:0 26px}
a{color:inherit}
svg.i{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;display:block}
:focus-visible{outline:2px solid var(--c-brand);outline-offset:3px;border-radius:var(--r1)}
.tnum{font-feature-settings:"tnum" 1;font-variant-numeric:tabular-nums}

/* — section + editorial header — */
section{padding:var(--s9) 0;border-top:1px solid var(--c-line)}
.shead{margin-bottom:var(--s7)}
.shead .idx{display:block;font-family:"Shippori Mincho B1";font-size:var(--t-sm);color:var(--c-accent);
  letter-spacing:.18em;margin-bottom:var(--s4)}
.shead .idx i{font-style:normal;color:var(--c-line-2);margin:0 .5em}
.shead h2{font-size:var(--t-xl);font-weight:800}
.shead p{color:var(--c-ink-2);font-size:.95rem;margin-top:var(--s4);max-width:32em}

.reveal{opacity:0;transform:translateY(18px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* — topbar — */
.topbar{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--c-surface) 90%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--c-line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;padding:12px 26px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand .nm{font-family:"Shippori Mincho B1";font-weight:700;font-size:.94rem;color:var(--c-brand);line-height:1.25}
.brand .nm small{display:block;font-family:"Noto Sans JP";font-size:.57rem;color:var(--c-ink-2);font-weight:500;letter-spacing:.08em}
.enso{width:30px;height:30px;flex-shrink:0;color:var(--c-brand)}
.topbar .tel{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--c-brand)}
.topbar .tel .min{font-weight:700;font-size:1rem;line-height:1}
.topbar .tel small{display:block;font-size:.55rem;color:var(--c-ink-2);letter-spacing:.04em}

/* — hero — */
.hero{position:relative;border-top:none;padding:calc(var(--s9) + var(--s5)) 0 calc(var(--s9) + var(--s6));overflow:hidden;background:var(--c-brand)}
.hero .herobg{position:absolute;inset:0;z-index:0}
.hero .herobg img{width:100%;height:100%;object-fit:cover;object-position:center 60%;display:block}
.hero .herobg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(177deg,rgba(16,40,52,.58) 0%,rgba(16,40,52,.72) 52%,rgba(16,40,52,.88) 100%)}
.hero .wrap{position:relative;z-index:2}
.hero .eyebrow{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.24em;color:#e6cd92;margin-bottom:var(--s6)}
.hero .eyebrow::before{content:"";display:inline-block;width:30px;height:1px;background:#e6cd92;vertical-align:middle;margin-right:12px;margin-bottom:4px}
.hero h1{color:#fff;font-size:var(--t-2xl);font-weight:800;letter-spacing:.03em;line-height:1.42;margin-bottom:var(--s5);text-shadow:0 1px 24px rgba(10,28,38,.35)}
.hero h1 .a{color:#f0cfa0}
.hero .htxt{color:rgba(255,255,255,.86);font-size:1rem;line-height:2;margin-bottom:var(--s7)}
.hero .htxt b{color:#fff;font-weight:700}
.hero .stats{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.28);backdrop-filter:blur(2px)}
.hero .stats div+div{border-left-color:rgba(255,255,255,.28)}
.hero .stats b{color:#fff}
.hero .stats span{color:rgba(255,255,255,.74)}
.hero .cta-note{color:rgba(255,255,255,.82)}
.hero .btn-tel{background:#fff;color:var(--c-brand)}

.stats{display:flex;border-block:1px solid var(--c-line);margin-bottom:var(--s7)}
.stats div{flex:1;text-align:center;padding:var(--s4) var(--s2)}
.stats div+div{border-left:1px solid var(--c-line)}
.stats b{display:block;font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);font-size:1.05rem;line-height:1.2}
.stats span{font-size:.6rem;color:var(--c-ink-2);letter-spacing:.02em}

.cta-group{display:flex;flex-direction:column;gap:var(--s3)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;text-decoration:none;font-family:"Noto Sans JP";
  font-weight:700;font-size:1.02rem;padding:16px 20px;border-radius:var(--r2);transition:transform .14s var(--ease),opacity .14s}
.btn:active{transform:translateY(1px)}
.btn svg.i{width:20px;height:20px}
.btn-line{background:var(--c-green);color:#fff;box-shadow:0 12px 26px -14px rgba(6,199,85,.65)}
.btn-tel{background:var(--c-brand);color:#fff}
.btn-tel small{font-weight:500;font-size:.7rem;opacity:.82}
.cta-note{font-size:.76rem;color:var(--c-ink-2);margin-top:var(--s4)}

.hero-fig{margin-top:var(--s8);border:1px solid var(--c-line-2);background:
  linear-gradient(0deg,rgba(27,58,71,.04),rgba(27,58,71,.04)),var(--c-surface-2);
  aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;color:var(--c-ink-3);
  font-size:.78rem;text-align:center;position:relative}
.hero-fig::after{content:"";position:absolute;inset:10px;border:1px solid rgba(255,255,255,.45);z-index:2;pointer-events:none}
.hero-fig img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
/* figures / bands */
.band{margin:0;height:180px;overflow:hidden;border-top:1px solid var(--c-line)}
.band img{width:100%;height:100%;object-fit:cover;object-position:center 42%;display:block}
.afig{margin-top:var(--s6);border:1px solid rgba(255,255,255,.16);position:relative}
.afig img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}
.afig figcaption{font-size:.72rem;color:#9fb3b8;padding:10px 2px 0}

/* — worry — */
.worry{background:var(--c-surface-2)}
.qlist{border-top:1px solid var(--c-line)}
.qrow{display:flex;gap:var(--s4);align-items:baseline;padding:16px 2px;border-bottom:1px solid var(--c-line)}
.qrow .qn{font-family:"Shippori Mincho B1";color:var(--c-accent);font-weight:700;font-size:.95rem;flex-shrink:0}
.qrow p{font-size:.98rem;font-weight:500}

/* — timeline — */
.tl{position:relative}
.tl::before{content:"";position:absolute;left:14px;top:8px;bottom:8px;width:1px;background:var(--c-line-2)}
.ti{position:relative;padding:0 0 var(--s6) 48px}
.ti:last-child{padding-bottom:0}
.ti .n{position:absolute;left:0;top:-2px;width:29px;height:29px;border-radius:50%;background:var(--c-surface);
  border:1px solid var(--c-brand);color:var(--c-brand);font-family:"Shippori Mincho B1";font-weight:700;
  display:grid;place-items:center;font-size:.9rem;z-index:2}
.ti h3{font-size:var(--t-md);margin-bottom:4px}
.ti p{font-size:.88rem;color:var(--c-ink-2)}
.ti .tag{display:inline-block;margin-top:8px;font-size:.67rem;color:var(--c-signal);border:1px solid #e3cabf;border-radius:var(--r1);padding:2px 9px;letter-spacing:.04em}

/* — symptoms — */
.symp{background:var(--c-surface-2)}
.sgrid{border:1px solid var(--c-line);border-radius:var(--r2);overflow:hidden;display:grid;grid-template-columns:1fr 1fr}
.sc{padding:18px 16px;border-bottom:1px solid var(--c-line)}
.sc:nth-child(odd){border-right:1px solid var(--c-line)}
.sc:nth-last-child(-n+2){border-bottom:none}
.sc .min{display:block;font-size:1.02rem;font-weight:700;color:var(--c-brand)}
.sc span{font-size:.76rem;color:var(--c-ink-2)}

/* — directory — */
.dirflow{display:flex;align-items:center;flex-wrap:wrap;gap:9px;margin-bottom:var(--s6);padding-bottom:var(--s5);border-bottom:1px solid var(--c-line)}
.dirflow b{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);font-size:.85rem}
.dirflow svg.i{width:15px;height:15px;color:var(--c-accent)}
.dnote{border-left:2px solid var(--c-accent);padding:4px 0 4px 16px;color:var(--c-ink-2);font-size:.84rem;margin-bottom:var(--s6)}
.dnote b{color:var(--c-ink);font-weight:700}
.drow{display:flex;gap:16px;align-items:flex-start;padding:var(--s5) 2px;border-bottom:1px solid var(--c-line)}
.drow:first-of-type{border-top:1px solid var(--c-line)}
.drow .di{color:var(--c-brand);margin-top:2px}
.drow .dc{flex:1}
.drow h3{font-size:var(--t-md);margin-bottom:3px}
.drow p{font-size:.85rem;color:var(--c-ink-2);margin-bottom:10px}
.drow .ask{display:inline-flex;align-items:center;gap:6px;color:var(--c-brand);font-weight:700;font-size:.84rem;text-decoration:none;border-bottom:1px solid var(--c-brand);padding-bottom:2px}
.drow .ask svg.i{width:15px;height:15px}

/* — money — */
.money{background:var(--c-surface-2)}
.basis{border:1px solid var(--c-line);border-radius:var(--r2);overflow:hidden;margin-bottom:var(--s6)}
.basis .b{display:flex;align-items:baseline;gap:14px;padding:14px 16px;border-bottom:1px solid var(--c-line)}
.basis .b:last-child{border-bottom:none}
.basis .b .k{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-ink-2);font-size:.72rem;letter-spacing:.1em;flex-shrink:0;width:62px}
.basis .b.top{background:#faf6ec}
.basis .b.top .k{color:var(--c-accent)}
.basis .b .min{color:var(--c-brand);font-weight:700;font-size:1rem}
.basis .b span{font-size:.78rem;color:var(--c-ink-2)}
.ktbl{width:100%;border-collapse:collapse;margin-bottom:var(--s4);font-size:.88rem;border:1px solid var(--c-line)}
.ktbl caption{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);text-align:left;padding:0 0 12px;font-size:.96rem;caption-side:top}
.ktbl th,.ktbl td{padding:11px 16px;text-align:left;border-bottom:1px solid var(--c-line)}
.ktbl thead th{font-family:"Noto Sans JP";font-weight:700;font-size:.74rem;color:var(--c-ink-2);letter-spacing:.06em;background:var(--c-surface)}
.ktbl td.amt{text-align:right;font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-accent)}
.ktbl tr:last-child td{border-bottom:none}
.tnote{font-size:.72rem;color:var(--c-ink-2);margin:8px 0 var(--s6)}
.cmp{border:1px solid var(--c-line);border-radius:var(--r2);padding:18px 20px;margin-bottom:var(--s4);background:var(--c-surface)}
.cmp h3{font-size:.98rem;margin-bottom:12px}
.cmp .r{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px dotted var(--c-line-2)}
.cmp .r span{font-size:.85rem;color:var(--c-ink-2)}
.cmp .r .min{font-size:1.08rem;font-weight:700;color:var(--c-brand)}
.cmp .diff{margin-top:11px;text-align:right;font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-signal);font-size:.95rem}
.plus{display:flex;flex-wrap:wrap;gap:8px;margin:var(--s4) 0 var(--s5)}
.plus span{border:1px solid var(--c-line-2);border-radius:var(--r1);padding:6px 12px;font-size:.78rem;color:var(--c-brand)}
.safenote{border:1px solid var(--c-line-2);background:var(--c-surface);border-radius:var(--r2);padding:16px 18px;font-size:.85rem;color:var(--c-ink-2)}
.safenote b{color:var(--c-brand)}

/* — area — */
.agrid{display:flex;flex-wrap:wrap;gap:12px}
.agrid a{flex:1;min-width:96px;text-align:center;border:1px solid var(--c-line-2);border-radius:var(--r1);padding:16px 10px;text-decoration:none;background:var(--c-surface-2);transition:border-color .15s,background .15s}
.agrid a:hover{border-color:var(--c-brand);background:#fff}
.agrid a .min{display:block;color:var(--c-brand);font-weight:700;font-size:.96rem}
.agrid a small{font-size:.56rem;color:var(--c-ink-3);letter-spacing:.1em}
.areanote{border-left:2px solid var(--c-accent);padding:6px 0 6px 16px;color:var(--c-ink-2);font-size:.85rem;margin-bottom:var(--s6)}
.areanote b{color:var(--c-ink);font-weight:700}
.region+.region{margin-top:var(--s6)}
.rlabel{display:flex;align-items:baseline;gap:11px;font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);font-size:1.02rem;margin-bottom:var(--s3)}
.rlabel span{font-family:"Noto Sans JP";font-weight:500;font-size:.7rem;color:var(--c-ink-2);letter-spacing:.04em}
.agrid.soon a{background:var(--c-surface);border-style:dashed}
.agrid.soon a .min{color:var(--c-ink-2)}
.deflist{border:1px solid var(--c-line);border-radius:var(--r2);overflow:hidden;margin-bottom:var(--s7)}
.deflist .d{display:flex;gap:16px;padding:14px 16px;border-bottom:1px solid var(--c-line);font-size:.9rem;align-items:baseline}
.deflist .d:last-child{border-bottom:none}
.deflist dt{flex-shrink:0;width:78px;font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-ink-2);font-size:.8rem;letter-spacing:.04em}
.deflist dd{color:var(--c-ink);font-weight:500}
.deflist dd b{color:var(--c-brand);font-weight:700}
/* accident types */
.notice{background:var(--c-brand);color:#fff;border-radius:var(--r2);padding:18px 20px;margin-bottom:var(--s6);font-family:"Shippori Mincho B1";font-weight:700;font-size:1.06rem;line-height:1.72}
.notice em{font-style:normal;color:#f0cfa0}
.types{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:var(--s6)}
.type{position:relative;border:1px solid var(--c-line);border-radius:var(--r2);padding:15px 30px 15px 16px;background:var(--c-surface-2);text-decoration:none;display:block;transition:border-color .15s,background .15s}
.type:hover{border-color:var(--c-brand);background:#fff}
.type b{display:block;font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);font-size:1.02rem;margin-bottom:1px}
.type span{font-size:.73rem;color:var(--c-ink-2)}
.type::after{content:"";position:absolute;right:15px;top:50%;width:7px;height:7px;border-right:1.4px solid var(--c-line-2);border-bottom:1.4px solid var(--c-line-2);transform:translateY(-50%) rotate(-45deg);transition:border-color .15s}
.type:hover::after{border-color:var(--c-brand)}
.hooks{border:1px solid var(--c-line-2);border-radius:var(--r2);overflow:hidden;margin-bottom:var(--s6)}
.hk{display:flex;gap:12px;align-items:flex-start;padding:15px 16px;border-bottom:1px solid var(--c-line)}
.hk:last-child{border-bottom:none}
.hk .hm{color:var(--c-signal);font-family:"Shippori Mincho B1";font-weight:700;flex-shrink:0;line-height:1.5}
.hk b{display:block;font-family:"Shippori Mincho B1";color:var(--c-brand);font-weight:700;font-size:.96rem;line-height:1.55}
.hk span{font-size:.75rem;color:var(--c-ink-2)}
.hero-cover{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.34);border-radius:var(--r1);padding:9px 15px;color:#fff;font-size:.82rem;font-weight:700;margin-bottom:var(--s6);font-family:"Shippori Mincho B1";line-height:1.45}
.hero-cover svg.i{width:18px;height:18px;color:#e6cd92}
.sendguide{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.2);border-radius:var(--r2);padding:18px 20px;margin-bottom:var(--s6);text-align:left}
.sendguide .sg-h{font-family:"Shippori Mincho B1";font-weight:700;color:#fff;font-size:.95rem;margin-bottom:10px}
.sendguide ul{list-style:none}
.sendguide li{display:flex;gap:10px;align-items:flex-start;color:#dbe7ea;font-size:.88rem;padding:4px 0}
.sendguide li svg.i{width:17px;height:17px;color:#e6cd92;margin-top:4px}
.corp-q{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);text-align:center;font-size:1rem;margin-bottom:var(--s4)}
/* empathy checklist */
.qrow{align-items:flex-start}
.qrow svg.chk{width:19px;height:19px;color:var(--c-accent);flex-shrink:0;margin-top:3px;stroke-width:2}
/* cases */
.case{border:1px solid var(--c-line);border-radius:var(--r2);padding:18px;margin-bottom:12px;background:var(--c-surface-2)}
.case .cm{display:flex;gap:9px;flex-wrap:wrap;align-items:center;margin-bottom:9px}
.case .typ{font-size:.66rem;color:#fff;background:var(--c-brand);border-radius:var(--r1);padding:3px 10px;font-weight:700}
.case .who{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);font-size:.92rem}
.case p{font-size:.87rem;color:var(--c-ink-2);line-height:1.8}
.case p b{color:var(--c-ink);font-weight:700}
.case .res{margin-top:11px;padding-top:11px;border-top:1px solid var(--c-line);font-size:.87rem;color:var(--c-ink)}
.case .res .amt{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-accent)}
.cases-note{font-size:.72rem;color:var(--c-ink-2);margin-top:10px;line-height:1.75}
.case .cf{font-family:"Shippori Mincho B1";color:var(--c-brand);font-weight:700;font-size:.78rem;letter-spacing:.04em;margin:13px 0 3px}
.case .cb{font-size:.87rem;color:var(--c-ink-2);line-height:1.8}
.case ul.cl{list-style:none;margin:2px 0}
.case ul.cl li{position:relative;padding-left:15px;font-size:.86rem;color:var(--c-ink-2);line-height:1.75}
.case ul.cl li::before{content:"";position:absolute;left:2px;top:11px;width:4px;height:4px;border-radius:50%;background:var(--c-accent)}
.comp{margin-top:6px;border:1px solid var(--c-line);border-radius:var(--r1);overflow:hidden}
.comp .cr{display:flex;justify-content:space-between;gap:12px;align-items:baseline;padding:9px 13px;border-bottom:1px solid var(--c-line)}
.comp .cr:last-child{border-bottom:none}
.comp dt{font-size:.83rem;color:var(--c-ink-2)}
.comp dd{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);text-align:right;font-size:.92rem}
.comp dd.amt{color:var(--c-accent)}
.comp dd small{display:block;font-family:"Noto Sans JP";font-weight:500;font-size:.62rem;color:var(--c-ink-3)}
.voice2{margin-top:12px;background:var(--c-surface);border-left:2px solid var(--c-accent);padding:11px 14px}
.voice2 .vl{font-size:.66rem;color:var(--c-ink-2);display:block;margin-bottom:3px;letter-spacing:.06em}
.voice2 p{font-size:.87rem;color:var(--c-ink);line-height:1.7}
.case .cnote{font-size:.7rem;color:var(--c-ink-3);margin-top:10px;line-height:1.65}
/* lead magnet */
.lm{background:var(--c-brand);border-top:none;color:#fff}
.lm .label{color:#e6cd92}.lm .label::before{background:#e6cd92}
.lm h2{color:#fff;font-size:var(--t-xl)}
.lm p{color:#c4d2d6;font-size:.93rem;margin:var(--s4) 0 var(--s5)}
.lm ul{list-style:none;margin-bottom:var(--s6)}
.lm li{display:flex;gap:10px;align-items:flex-start;color:#dbe7ea;font-size:.9rem;padding:5px 0}
.lm li svg.i{width:18px;height:18px;color:#e6cd92;margin-top:4px}
.lm .btn-line{display:inline-flex}
.lm small{display:block;color:#9fb3b8;font-size:.72rem;margin-top:14px}
.corp-manual{border:1px solid var(--c-line-2);border-radius:var(--r2);padding:22px 20px;margin-top:var(--s7);background:var(--c-surface-2);text-align:center}
.corp-manual .label{display:block;font-family:"Shippori Mincho B1";font-size:.72rem;color:var(--c-accent);letter-spacing:.16em;margin-bottom:10px}
.corp-manual h3{font-size:1.08rem;margin-bottom:10px;line-height:1.5}
.corp-manual p{font-size:.87rem;color:var(--c-ink-2);margin-bottom:var(--s5);line-height:1.8}
.corp-manual .btn-line{display:inline-flex}

/* — faq — */
.faq{background:var(--c-surface-2)}
.qa{border-bottom:1px solid var(--c-line)}
.qa:first-of-type{border-top:1px solid var(--c-line)}
.qa summary{list-style:none;cursor:pointer;padding:18px 40px 18px 4px;font-weight:700;font-size:.95rem;position:relative;color:var(--c-brand);font-family:"Shippori Mincho B1"}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"";position:absolute;right:8px;top:23px;width:8px;height:8px;border-right:1.4px solid var(--c-accent);border-bottom:1.4px solid var(--c-accent);transform:rotate(45deg);transition:transform .25s var(--ease)}
.qa[open] summary::after{transform:rotate(-135deg)}
.qa .a{padding:0 4px 20px;font-size:.86rem;color:var(--c-ink-2)}
.faq .more{margin-top:var(--s4);font-size:.76rem;color:var(--c-ink-2)}

/* — about (dark) — */
.about{background:var(--c-brand);border-top:none}
.about .shead .idx{color:#cdb37e}.about .shead .idx i{color:rgba(255,255,255,.25)}
.about h2{color:#fff}
.about p{color:#c4d2d6;font-size:.95rem;margin-bottom:var(--s4)}
.about p b{color:#fff;font-weight:700}
.about .quote{border-left:2px solid #cdb37e;padding:8px 0 8px 20px;margin:var(--s6) 0;font-family:"Shippori Mincho B1";font-size:1.16rem;color:#fff;line-height:1.75}
.about .by{font-size:.8rem;color:#9fb3b8;margin-top:var(--s2)}
.profile{display:flex;gap:16px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--r2);padding:18px;margin-top:var(--s6)}
.profile img{width:92px;height:92px;border-radius:50%;object-fit:cover;object-position:40% 35%;flex-shrink:0;border:2px solid rgba(255,255,255,.22)}
.profile .prole{color:#cdb37e;font-size:.74rem;letter-spacing:.08em;margin-bottom:2px}
.profile .pname{font-family:"Shippori Mincho B1";color:#fff;font-weight:700;font-size:1.14rem;margin-bottom:4px}
.profile .pq{color:#c4d2d6;font-size:.8rem;margin-bottom:9px}
.profile .pstat{font-size:.82rem;color:#dbe7ea}
.profile .pstat b{font-family:"Shippori Mincho B1";color:#e6cd92;font-weight:700;font-size:1.02rem}
.profile .pstat .yr{display:block;font-size:.68rem;color:#9fb3b8;margin-top:2px}

/* — corp — */
.corp{background:var(--c-surface)}
.corp .clead{font-size:.95rem;color:var(--c-ink-2);margin-bottom:var(--s6)}
.cwbox{border:1px solid var(--c-line-2);border-radius:var(--r2);padding:20px;margin-bottom:var(--s6);background:var(--c-surface-2)}
.cwbox h3{font-size:1rem;margin-bottom:13px}
.cwbox .ci{display:flex;gap:11px;align-items:flex-start;padding:7px 0;font-size:.9rem;font-weight:500}
.cwbox .ci svg.i{width:19px;height:19px;color:var(--c-accent);margin-top:3px}
.cserv{border-top:1px solid var(--c-line);margin-bottom:var(--s6)}
.cserv .s{display:flex;gap:16px;padding:18px 2px;border-bottom:1px solid var(--c-line)}
.cserv .s .n{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-accent);font-size:1.05rem;flex-shrink:0;width:28px}
.cserv .s h3{font-size:var(--t-md);margin-bottom:2px}
.cserv .s p{font-size:.84rem;color:var(--c-ink-2)}
.ctarget{background:var(--c-brand);border-radius:var(--r2);padding:22px;margin-bottom:var(--s6)}
.ctarget h3{color:#fff;font-size:1.04rem;margin-bottom:8px}
.ctarget p{color:#c4d2d6;font-size:.86rem}
.ctarget .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.ctarget .tags span{border:1px solid rgba(255,255,255,.25);color:#e7eef0;border-radius:var(--r1);padding:5px 12px;font-size:.76rem}
.servmsg{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-brand);font-size:1.18rem;line-height:1.75;margin-bottom:var(--s6);text-align:center}
.servmsg em{font-style:normal;color:var(--c-signal)}
.ccta{text-align:center}

/* — final — */
.final{background:var(--c-brand);border-top:none;text-align:center}
.final h2{color:#fff;font-size:var(--t-xl);margin-bottom:var(--s4)}
.final p{color:#c4d2d6;margin-bottom:var(--s6);font-size:.94rem}
.final .btn-tel{background:#fff;color:var(--c-brand)}
.final .cta-note{color:#9fb3b8}

/* — disclaimer + footer — */
.disc{background:#13303b;color:#8ba4ab;font-size:.74rem;padding:var(--s7) 0;border-top:1px solid rgba(255,255,255,.07)}
.disc h4{font-family:"Shippori Mincho B1";color:#c6d4d7;font-size:.84rem;margin-bottom:12px}
.disc p{margin-bottom:9px;line-height:1.85}
footer{background:#0e2730;color:#7c949b;padding:var(--s7) 0 var(--s8);text-align:center;font-size:.76rem}
footer .fb{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:12px;color:#fff}
footer .fb .enso{width:24px;height:24px;color:#cdb37e}
footer .fb .min{font-weight:700;font-size:.9rem}

/* — sticky — */
.sticky{position:fixed;bottom:0;left:0;right:0;z-index:80;display:flex;gap:1px;background:var(--c-line);
  box-shadow:0 -4px 18px -10px rgba(27,58,71,.4)}
.sticky a{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;text-decoration:none;
  padding:14px 6px;font-family:"Noto Sans JP";font-weight:700;color:#fff;font-size:.92rem}
.sticky svg.i{width:18px;height:18px}
.sticky .s-tel{background:var(--c-brand)}
.sticky .s-line{background:var(--c-green)}

@media(min-width:560px){
  .hero h1{line-height:1.4}
  .cta-group{flex-direction:row}.cta-group .btn{flex:1}
  .sgrid{grid-template-columns:1fr 1fr 1fr}
  .sc:nth-child(odd){border-right:none}
  .sc{border-right:1px solid var(--c-line)}
  .sc:nth-child(3n){border-right:none}
  .sc:nth-last-child(-n+3){border-bottom:none}
}

/* ===== blog / area / post (theme additions) ===== */
.bc{font-size:.74rem;color:var(--c-ink-2);padding:14px 0 0}
.bc a{text-decoration:none;border-bottom:1px solid var(--c-line-2)}
.bc span{color:var(--c-ink-3);margin:0 .4em}
.pagehead{padding:var(--s8) 0 var(--s5)}
.pagehead .lbl{display:block;font-family:"Shippori Mincho B1";font-size:.8rem;color:var(--c-accent);letter-spacing:.18em;margin-bottom:var(--s4)}
.pagehead h1{font-size:1.7rem;font-weight:800;color:var(--c-brand);font-family:"Shippori Mincho B1";line-height:1.5}
.pagehead p{color:var(--c-ink-2);font-size:.94rem;margin-top:var(--s4)}
.artlist{border-top:1px solid var(--c-line);margin-bottom:var(--s8)}
.artlist .art{display:block;text-decoration:none;padding:22px 4px;border-bottom:1px solid var(--c-line)}
.artlist .art .cat{font-size:.68rem;color:var(--c-accent);font-weight:700;letter-spacing:.08em}
.artlist .art h2{font-size:1.12rem;margin:5px 0 4px;font-weight:700;color:var(--c-brand);font-family:"Shippori Mincho B1"}
.artlist .art p{font-size:.85rem;color:var(--c-ink-2)}
.post{padding:var(--s7) 0 var(--s8)}
.post .cat{font-family:"Shippori Mincho B1";font-size:.76rem;color:var(--c-accent);letter-spacing:.1em}
.post h1{font-size:1.6rem;font-weight:800;line-height:1.5;margin:10px 0 var(--s5);color:var(--c-brand);font-family:"Shippori Mincho B1"}
.post .byline{font-size:.76rem;color:var(--c-ink-2);border-bottom:1px solid var(--c-line);padding-bottom:var(--s5);margin-bottom:var(--s6)}
.post .body{font-size:.95rem;line-height:1.95}
.post .body h2{font-size:1.2rem;margin:var(--s7) 0 var(--s4);padding-top:var(--s5);border-top:1px solid var(--c-line);color:var(--c-brand);font-family:"Shippori Mincho B1"}
.post .body h3{font-size:1.05rem;margin:var(--s5) 0 var(--s3);color:var(--c-brand);font-family:"Shippori Mincho B1"}
.post .body p{margin-bottom:var(--s4)}
.post .body ul,.post .body ol{margin:var(--s4) 0 var(--s4) 1.3em}
.post .body li{margin-bottom:6px}
.post .body blockquote{border-left:2px solid var(--c-accent);background:var(--c-surface-2);padding:14px 18px;margin:var(--s5) 0;font-size:.92rem}
.post .body table{width:100%;border-collapse:collapse;border:1px solid var(--c-line);font-size:.88rem;margin:var(--s4) 0}
.post .body th,.post .body td{padding:10px 14px;border-bottom:1px solid var(--c-line);text-align:left}
.post .body img{max-width:100%;height:auto;border-radius:var(--r2)}
.postcta{background:var(--c-brand);color:#fff;border-radius:var(--r2);padding:24px 22px;margin:var(--s7) 0 0;text-align:center}
.postcta h3{color:#fff;font-size:1.1rem;margin-bottom:8px}
.postcta p{color:#c4d2d6;font-size:.86rem;margin-bottom:var(--s5)}
.backlink{text-align:center;padding:var(--s7) 0;border-top:1px solid var(--c-line);font-size:.85rem}
.backlink a{color:var(--c-brand);font-weight:700;text-decoration:none;border-bottom:1px solid var(--c-brand)}
.local{background:var(--c-surface-2)}
.lrow{display:flex;gap:16px;padding:18px 2px;border-bottom:1px solid var(--c-line)}
.lrow:first-of-type{border-top:1px solid var(--c-line)}
.lrow .ln{font-family:"Shippori Mincho B1";font-weight:700;color:var(--c-accent);font-size:1rem;flex-shrink:0;width:26px}
.lrow h3{font-size:1.04rem;margin-bottom:2px;color:var(--c-brand);font-family:"Shippori Mincho B1"}
.lrow p{font-size:.86rem;color:var(--c-ink-2)}
