@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+JP:wght@400;500;700&family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap');
:root{
  /* ---- neutral base (premium) ---- */
  --bg:#FAFAF8; --surface:#ffffff; --surface-2:#F5F5F1;
  --fg:#14170F; --muted:#5F6656; --faint:#9AA093;
  --line:rgba(20,23,15,.09); --line-2:rgba(20,23,15,.05);
  /* ---- CIP semantic colors (engine/mock/radar/icp reference these — keep) ---- */
  --black:#18181A; --blackGray:#4D4E52; --darkGray:#7A8072; --grayUi:#BBBDC2;
  --whiteGray:#F7F8FA; --lightGray:#F2F2F6; --white:#ffffff;
  --green:#2C6E49; --green600:#26603f; --green700:#205234;
  --lightGreen:#A0D995; --deepGreen:#0F1A14;
  --warnRed:#DC2626; --warnRedSoft:#FEE7E2; --warnBg:#FFF8F6;
  --textBody:#374151; --textHead:#111827;
  /* ---- brand（iframeモックへ mock-init で伝播。ボード側は緑固定） ---- */
  --brand:#2C6E49; --brand-ink:#0F1A14; --brand-soft:#eef6f1; --brand-line:#d7e8de; --brand-on:#ffffff;
  /* ---- type ---- */
  --f-jp:'Zen Kaku Gothic New','Noto Sans JP',ui-sans-serif,system-ui,sans-serif;
  --f-body:'Noto Sans JP','Zen Kaku Gothic New',ui-sans-serif,system-ui,sans-serif;
  --f-num:'Inter','Noto Sans JP',sans-serif;
  --radius:16px; --radius-sm:11px; --radius-xs:8px;
  --shadow-1:0 1px 2px rgba(20,23,15,.04);
  --shadow-2:0 2px 8px rgba(20,23,15,.05),0 20px 44px rgba(20,23,15,.07);
  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:860px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--f-body);color:var(--fg);background:var(--bg);line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:.005em}
h1,h2,h3,h4,h5{color:var(--fg);line-height:1.4;margin:0;font-family:var(--f-jp);letter-spacing:.01em}
p{margin:0}
a{color:var(--green);text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.num{font-family:var(--f-num);font-feature-settings:'tnum';font-variant-numeric:tabular-nums}

/* ---- header ---- */
header.site{background:var(--surface);border-bottom:1px solid var(--line)}
.site-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.brand{display:flex;align-items:center;gap:11px}
.brand .logo-mark{flex:none;width:30px;height:30px;border-radius:8px}
.brand .name{font-family:var(--f-jp);font-weight:700;letter-spacing:-.01em;color:var(--fg);font-size:19px;line-height:1.1}
.brand .tag{font-size:11px;color:var(--faint);margin-top:1px;letter-spacing:.02em}
.partner{font-size:11px;color:var(--faint);text-align:right;line-height:1.5}
.partner b{color:var(--muted);font-weight:600}

/* ---- app stage ---- */
main{padding:0 0 72px}
.stage{max-width:var(--maxw);margin:0 auto;padding:34px 20px 20px}
.notice{display:flex;gap:10px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);color:var(--muted);border-radius:var(--radius-sm);padding:12px 15px;margin:0 auto 24px;max-width:var(--maxw);font-size:12.5px;line-height:1.65}
.notice svg{flex:none;margin-top:2px}
.notice b{color:var(--fg);font-weight:600}

/* ---- panels & kicker ---- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,4vw,38px);box-shadow:var(--shadow-1)}
.kicker{font-size:12px;font-weight:600;color:var(--green700);letter-spacing:.06em;margin:0 0 12px}
.reveal{opacity:0;transform:translateY(10px);animation:up .6s var(--ease) forwards}
@keyframes up{to{opacity:1;transform:none}}

/* ---- wizard: intro ---- */
.intro-h{font-family:var(--f-jp);font-weight:700;font-size:clamp(23px,4vw,33px);line-height:1.4;letter-spacing:.01em;margin:0}
.intro-h .accent{color:var(--green700);background:linear-gradient(transparent 62%,var(--brand-soft) 62%)}
.intro-p{color:var(--muted);font-size:14.5px;margin:16px 0 28px;max-width:56ch}
.field{margin:0 0 24px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:8px}
.field input{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);font-family:inherit;font-size:16px;color:var(--fg);transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.field input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--brand-soft)}
.field .hint{font-size:11.5px;color:var(--faint);margin-top:7px}

/* ---- wizard: progress ---- */
.prog{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.prog .track{flex:1;height:5px;border-radius:99px;background:var(--surface-2);overflow:hidden}
.prog .fill{height:100%;width:0;border-radius:99px;background:var(--green);transition:width .5s var(--ease)}
.prog .count{font-family:var(--f-num);font-size:12px;color:var(--faint);font-weight:500;white-space:nowrap;letter-spacing:.03em}

/* ---- wizard: question ---- */
.qtitle{font-family:var(--f-jp);font-weight:700;font-size:clamp(20px,3.4vw,27px);line-height:1.45;letter-spacing:.01em;margin:0}
.qhint{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-top:8px}
.opts{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.opt{display:flex;align-items:center;gap:14px;width:100%;text-align:left;padding:15px 17px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:border-color .18s var(--ease),background .18s var(--ease),transform .18s var(--ease),box-shadow .18s var(--ease);font-family:inherit;color:inherit}
.opt:hover{border-color:var(--brand-line);transform:translateY(-1px);box-shadow:var(--shadow-1)}
.opt:focus-visible{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--brand-soft)}
.opt[aria-pressed="true"]{border-color:var(--green);background:var(--brand-soft)}
.opt .ic{flex:none;width:40px;height:40px;border-radius:10px;background:var(--surface-2);color:var(--green700);display:grid;place-items:center;transition:background .18s var(--ease)}
.opt[aria-pressed="true"] .ic{background:#fff}
.opt .ic svg{width:20px;height:20px}
.opt .tx{flex:1;min-width:0}
.opt .tx strong{display:block;font-weight:600;font-size:15px;line-height:1.45;color:var(--fg)}
.opt .tx span{display:block;font-size:12.5px;color:var(--muted);margin-top:2px}
.opt .chk{flex:none;width:22px;height:22px;border-radius:99px;border:1.5px solid var(--line);display:grid;place-items:center;color:#fff;transition:all .18s var(--ease)}
.opt[aria-pressed="true"] .chk{background:var(--green);border-color:var(--green)}
.opt .chk svg{width:12px;height:12px;opacity:0;transform:scale(.6);transition:all .18s var(--ease)}
.opt[aria-pressed="true"] .chk svg{opacity:1;transform:scale(1)}
/* grid variant (industry / dept) */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:24px}
.chip-opt{padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-family:inherit;font-size:14.5px;font-weight:500;color:var(--fg);text-align:left;transition:border-color .18s var(--ease),background .18s var(--ease),transform .18s var(--ease)}
.chip-opt:hover{border-color:var(--brand-line);transform:translateY(-1px)}
.chip-opt:focus-visible{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--brand-soft)}
.chip-opt[aria-pressed="true"]{border-color:var(--green);background:var(--brand-soft);color:var(--green700);font-weight:600}

/* ---- wizard: finish extras ---- */
.sub-h{font-family:var(--f-jp);font-weight:700;font-size:15.5px;margin:0 0 4px}
.sub-p{font-size:12.5px;color:var(--muted);margin:0 0 14px}
.block{margin-top:22px;padding-top:22px;border-top:1px solid var(--line-2)}
.block:first-of-type{margin-top:22px;padding-top:0;border-top:0}
.swatches{display:flex;gap:9px;flex-wrap:wrap}
.swatch{width:30px;height:30px;border-radius:99px;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer;transition:transform .15s var(--ease),box-shadow .15s var(--ease);padding:0}
.swatch:hover{transform:scale(1.1)}
.swatch.active{box-shadow:0 0 0 2px var(--fg);transform:scale(1.1)}
.voice-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.voice-chip{font-size:12.5px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:99px;padding:6px 13px;cursor:pointer;font-family:inherit;transition:all .16s var(--ease)}
.voice-chip:hover{border-color:var(--brand-line);color:var(--green700)}
.free{width:100%;min-height:96px;padding:13px 15px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);font-family:inherit;font-size:14.5px;color:var(--fg);resize:vertical;line-height:1.7}
.free:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--brand-soft)}
.file-zone{margin-top:12px}
.file-btn{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--green700);background:var(--brand-soft);border:1px solid var(--brand-line);border-radius:var(--radius-sm);padding:10px 15px;cursor:pointer}
.file-btn input[type=file]{display:none}
.file-note{display:flex;gap:7px;align-items:flex-start;font-size:11.5px;color:var(--faint);margin-top:9px;line-height:1.6}
.file-note b{color:var(--muted);font-weight:600}
.file-list{margin-top:10px;display:flex;flex-direction:column;gap:6px}
.file-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-xs);padding:7px 11px}
.file-item .fn{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-item .fs{color:var(--faint);font-family:var(--f-num)}
.qmemo{margin-top:22px;border-top:1px solid var(--line-2);padding-top:18px}
.qmemo summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);list-style:none;display:flex;align-items:center;gap:8px}
.qmemo summary::-webkit-details-marker{display:none}
.qmemo summary::before{content:"";width:6px;height:6px;border-right:1.5px solid var(--faint);border-bottom:1.5px solid var(--faint);transform:rotate(-45deg);transition:transform .2s var(--ease)}
.qmemo[open] summary::before{transform:rotate(45deg)}
.badge-opt{font-size:10.5px;font-weight:600;color:var(--faint);background:var(--surface-2);border-radius:99px;padding:2px 9px;letter-spacing:.02em}
.memo-note{font-size:12px;color:var(--faint);margin:10px 0 12px;line-height:1.6}
.mrow{margin-bottom:12px}
.ml{font-size:12.5px;color:var(--muted);font-weight:600;margin-bottom:7px}
.opts.compact{flex-direction:row;flex-wrap:wrap;gap:8px;margin-top:0}
.opts.compact .mini{font-size:12.5px;color:var(--muted);border:1px solid var(--line);border-radius:99px;padding:7px 13px;background:var(--surface);cursor:pointer;font-family:inherit;transition:all .16s var(--ease)}
.opts.compact .mini:hover{border-color:var(--brand-line)}
.opts.compact .mini[aria-pressed="true"]{border-color:var(--green);background:var(--brand-soft);color:var(--green700);font-weight:600}

/* ---- wizard: nav / buttons ---- */
.nav{display:flex;align-items:center;gap:12px;margin-top:30px}
.nav .spacer{flex:1}
.btn{font-family:var(--f-jp);font-weight:600;font-size:15px;border-radius:var(--radius-sm);padding:13px 22px;cursor:pointer;border:1px solid transparent;transition:background .18s var(--ease),border-color .18s var(--ease),transform .12s var(--ease),opacity .18s var(--ease);display:inline-flex;align-items:center;gap:8px}
.btn:active{transform:translateY(1px)}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green700)}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brand-line);color:var(--fg)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.center{text-align:center;margin-top:26px}
.restart{background:none;border:none;color:var(--faint);font-size:12px;cursor:pointer;font-family:inherit;text-decoration:underline;text-underline-offset:3px}
.restart:hover{color:var(--muted)}
.err-inline{font-size:12.5px;color:var(--warnRed);margin-top:12px;display:none}
.err-inline.show{display:block}

/* ---- suspense ---- */
.loading{display:grid;place-items:center;gap:22px;padding:64px 20px;text-align:center}
.ring{width:46px;height:46px;border-radius:99px;border:3px solid var(--brand-soft);border-top-color:var(--green);animation:spin 1s linear infinite}
.loading p{margin:0;color:var(--muted);font-size:14.5px}
.loading b{display:block;font-weight:700;color:var(--fg);font-size:16.5px;margin-bottom:4px;font-family:var(--f-jp)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ================= RESULT ================= */
#result{display:none}
#result.show{display:block}
.rz{display:flex;flex-direction:column;gap:20px;max-width:var(--maxw);margin:0 auto}
.sec-k{font-size:11.5px;font-weight:600;letter-spacing:.06em;color:var(--faint);margin:0 0 10px}

/* 1 · 現在地 */
.track-badge{display:inline-block;font-size:12px;font-weight:700;color:var(--green700);background:var(--brand-soft);border:1px solid var(--brand-line);border-radius:99px;padding:4px 12px}
.track-badge.warn{color:#B42318;background:var(--warnBg);border-color:var(--warnRedSoft)}
.track-badge.foundation{color:#8a5a12;background:#FBF4E6;border-color:#F0E2C2}
.now-lead{font-family:var(--f-jp);font-weight:700;font-size:clamp(18px,2.9vw,23px);line-height:1.6;letter-spacing:.01em;margin:14px 0 0;color:var(--fg)}
.now-lead b{color:var(--green700)}
.now-market{display:flex;gap:9px;align-items:flex-start;margin-top:16px;font-size:13px;color:var(--muted);line-height:1.65}
.now-market svg{flex:none;margin-top:3px}
.stat{display:flex;align-items:baseline;gap:14px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line-2)}
.stat .big{font-family:var(--f-num);font-weight:700;font-size:34px;line-height:1;color:var(--green700);letter-spacing:-.02em;white-space:nowrap}
.stat .lab{font-size:12.5px;color:var(--muted);line-height:1.5}
.stat .src{font-size:11px;color:var(--faint);margin-top:3px;line-height:1.5}
.tag-est{font-size:11px;font-weight:600;color:var(--faint);background:var(--surface-2);border-radius:99px;padding:3px 10px}
.card-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:2px}

/* flags (icp) */
.flag{display:flex;gap:10px;align-items:flex-start;border-radius:var(--radius-sm);padding:12px 15px;margin-top:16px;font-size:12.5px;line-height:1.65}
.flag svg{flex:none;margin-top:2px}
.flag.out{background:var(--warnBg);border:1px solid var(--warnRedSoft);color:#B42318}
.flag.check{background:#FBF4E6;border:1px solid #F0E2C2;color:#8a5a12}
.flag b{font-weight:700}

/* 2 · mock (star) */
.opp-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);padding:12px 14px;cursor:pointer;transition:border-color .18s var(--ease),background .18s var(--ease),transform .18s var(--ease);min-width:0}
.opp-card:hover{border-color:var(--brand-line);transform:translateY(-1px)}
.opp-card.active{border-color:var(--green);background:var(--brand-soft)}
.opp-card.lead{}
.opp-top{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.opp-code{font-family:var(--f-num);font-size:11.5px;font-weight:700;color:var(--green700);background:#fff;border:1px solid var(--brand-line);border-radius:6px;padding:1px 7px}
.opp-nm{font-size:13.5px;font-weight:600;color:var(--fg)}
.opp-star{font-size:10.5px;font-weight:700;color:#b8860b}
.opp-lead-rib{font-size:10px;font-weight:700;color:#fff;background:var(--green);border-radius:5px;padding:1px 7px}
.opp-why{font-size:12px;color:var(--muted);margin-top:7px;line-height:1.55}
.opp-why b{color:var(--fg);font-weight:600}
.opp-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.opp-pill{font-size:11px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);border-radius:99px;padding:2px 9px;font-family:var(--f-num)}
.opp-pill.pos{color:var(--green700);background:var(--brand-soft);border-color:var(--brand-line)}
.opps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-bottom:16px}

/* mock chrome */
.mockwrap{margin-top:2px;position:relative}
.mock{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-2);background:var(--surface)}
.mock-bar{display:flex;align-items:center;gap:7px;padding:11px 15px;background:var(--surface-2);border-bottom:1px solid var(--line)}
.mock-bar .tl{width:10px;height:10px;border-radius:99px;background:#D8D8D2}
.mock-url{flex:1;margin-left:8px;background:#fff;border:1px solid var(--line);border-radius:7px;padding:5px 12px;font-family:var(--f-num);font-size:12px;color:var(--faint);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.mock-imgtag{font-size:11px;font-weight:600;color:var(--green700);background:var(--brand-soft);border-radius:99px;padding:4px 11px;letter-spacing:.02em}
.mock-foot{display:flex;gap:9px;align-items:flex-start;padding:12px 16px;background:var(--surface-2);border-top:1px solid var(--line);font-size:11.5px;color:var(--faint);line-height:1.6}
.mock-foot b{color:var(--muted);font-weight:600}
/* mk: rag */
/* mk: flow (auto) */
/* mk: chat */
/* mk: data */
/* mk: predict */
.as.ok{color:#166534;background:#DCFCE7}.as.warn{color:#92400e;background:#FEF3C7}.as.bad{color:#B42318;background:var(--warnRedSoft)}

/* mock brand tuner */
.tune{display:flex;align-items:center;gap:12px;margin-top:14px;padding:13px 16px;border:1px dashed var(--line);border-radius:var(--radius-sm);background:var(--surface);flex-wrap:wrap}
.tune .t-lab{font-size:12.5px;color:var(--muted);font-weight:600}
.tune .swatches{margin-left:auto}
.hs-note{display:flex;align-items:flex-start;gap:8px;margin-top:12px;font-size:12px;color:var(--faint);line-height:1.6}
.hs-note svg{flex:none;margin-top:2px;color:var(--brand);width:15px;height:15px}

/* 3 · steps */
.steps{position:relative}
.steps::before{content:"";position:absolute;left:15px;top:20px;bottom:20px;width:1.5px;background:var(--line)}
.step{display:flex;gap:15px;padding:9px 0;position:relative}
.step .badge{flex:none;width:30px;height:30px;border-radius:99px;background:var(--brand-soft);color:var(--green700);font-family:var(--f-num);font-weight:700;font-size:12.5px;display:grid;place-items:center;position:relative;z-index:1}
.step.mvp .badge{background:var(--green);color:#fff}
.st-t{font-size:15px;font-weight:600;color:var(--fg)}
.st-d{font-size:13px;color:var(--muted);margin-top:1px;line-height:1.55}
.st-val{display:inline-block;font-family:var(--f-num);font-size:11.5px;font-weight:600;color:var(--green700);background:var(--brand-soft);border-radius:6px;padding:2px 9px;margin-top:7px}
.addon{display:flex;gap:9px;align-items:flex-start;margin-top:16px;padding:12px 15px;border:1px solid var(--brand-line);background:var(--brand-soft);border-radius:var(--radius-sm);font-size:12.5px;color:var(--green700);line-height:1.6}
.addon .ic{font-weight:700;flex:none}
.addon b{font-weight:700}
.notes{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.note{display:flex;gap:9px;align-items:flex-start;font-size:12.5px;color:var(--muted);line-height:1.6}
.note svg,.note .ic{flex:none;margin-top:2px;color:var(--brand)}
.note b{color:var(--fg);font-weight:600}
.use-note{font-size:12px;color:var(--muted);margin-top:12px;line-height:1.6}
.use-note b{color:var(--fg);font-weight:600}

/* 4 · trust */
.trust h3{font-size:15px;font-weight:700;margin:0}
.cond{font-size:11px;color:var(--faint);margin:6px 0 14px;line-height:1.55}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.trust-item{border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 15px;background:var(--surface);transition:border-color .18s var(--ease),background .18s var(--ease)}
.trust-item.hl{border-color:var(--brand-line);background:var(--brand-soft)}
.trust-item .big{font-size:14.5px;font-weight:700;color:var(--fg);line-height:1.4}
.trust-item .cap{font-size:11.5px;color:var(--muted);margin-top:5px;line-height:1.55}

/* 5 · CTA */
.cta{background:var(--fg);color:#fff;border-radius:var(--radius);padding:clamp(24px,4vw,32px);text-align:center}
.cta .ct-t{font-family:var(--f-jp);font-weight:700;font-size:clamp(17px,2.7vw,22px);margin:0 0 8px;line-height:1.5}
.cta .ct-d{margin:0 auto 22px;color:rgba(255,255,255,.72);font-size:13.5px;max-width:52ch;line-height:1.7}
.cta .row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-cta{font-family:var(--f-jp);font-weight:600;font-size:15.5px;border-radius:var(--radius-sm);padding:14px 26px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;background:var(--green);color:#fff;border:1px solid transparent;transition:background .18s var(--ease)}
.btn-cta:hover{background:var(--green700)}
.btn-cta svg{width:16px;height:16px}
.btn-cta.sec{background:transparent;color:#fff;border-color:rgba(255,255,255,.28)}
.btn-cta.sec:hover{border-color:#fff}
.cta .price{font-size:11.5px;color:rgba(255,255,255,.6);margin-top:16px}

/* details (progressive disclosure) */
.rz-det{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden}
.rz-det>summary{cursor:pointer;padding:16px 20px;font-size:13.5px;font-weight:600;color:var(--muted);list-style:none;display:flex;align-items:center;gap:10px}
.rz-det>summary::-webkit-details-marker{display:none}
.rz-det>summary::before{content:"";width:7px;height:7px;border-right:1.5px solid var(--faint);border-bottom:1.5px solid var(--faint);transform:rotate(-45deg);transition:transform .2s var(--ease)}
.rz-det[open]>summary::before{transform:rotate(45deg)}
.rz-det .det-body{padding:0 20px 20px}

/* detail: radar + oppmap */
.now-wrap{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center}
.radar-box{text-align:center}
.radar-svg{width:180px;height:176px}
.radar-cap{font-size:11px;color:var(--faint);margin-top:2px}
.oppmap{margin-top:4px}
.oppmap-plot{position:relative;height:190px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(0deg,var(--surface-2),transparent 60%)}
.oppmap-plot .axl{position:absolute;left:50%;top:8px;bottom:8px;width:1px;background:var(--line)}
.oppmap-plot .axl.h{left:8px;right:8px;top:50%;height:1px;width:auto}
.oppmap-cnr{position:absolute;font-size:10px;color:var(--faint)}
.oppmap-dot{position:absolute;transform:translate(-50%,50%);width:26px;height:26px;border-radius:99px;background:var(--brand-soft);border:1.5px solid var(--brand-line);color:var(--green700);font-family:var(--f-num);font-size:11px;font-weight:700;display:grid;place-items:center}
.oppmap-dot.lead{background:var(--green);border-color:var(--green);color:#fff}
.oppmap-lab{font-size:11px;color:var(--faint);margin-top:8px;text-align:center}

/* detail: sdr memo */
.sdrmemo{}
.qual{display:flex;flex-direction:column;gap:8px}
.qual-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;padding:8px 0;border-bottom:1px solid var(--line-2)}
.qual-k{color:var(--muted)}
.qual-v{font-weight:600;border-radius:6px;padding:2px 10px;font-size:12px}
.qual-v.ok{color:#166534;background:#DCFCE7}.qual-v.mid{color:#8a5a12;background:#FBF4E6}.qual-v.no{color:#B42318;background:var(--warnRedSoft)}
.verdict{margin-top:12px;padding:12px 14px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:600;line-height:1.6}
.verdict.ok{color:#166534;background:#DCFCE7}.verdict.mid{color:#8a5a12;background:#FBF4E6}.verdict.no{color:#B42318;background:var(--warnBg)}

.result-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:8px}

/* footer */
footer.site{background:var(--surface);border-top:1px solid var(--line);margin-top:20px}
.disc{padding:26px 20px 34px;font-size:12px;color:var(--muted)}
.disc>b{font-size:12.5px;color:var(--fg)}
.disc ul{margin:12px 0 0;padding-left:18px;line-height:1.75}
.disc li{margin-bottom:5px}
.disc li b{color:var(--fg);font-weight:600}

@media (max-width:640px){
  .grid{grid-template-columns:1fr}
  .now-wrap{grid-template-columns:1fr}
  .stat .big{font-size:28px}
  .partner{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
  .reveal{opacity:1;transform:none}
}
/* ---- guided hotspots on mock (Arcade-style) ---- */
.hot-hint{display:inline-flex;align-items:center;gap:6px;margin:9px 2px 0;font-size:11.5px;font-weight:500;color:var(--faint)}
.hot-hint svg{width:13px;height:13px;flex:none}
@media (prefers-reduced-motion:reduce){.hot::after{animation:none;opacity:.3}}
@media print{
  header.site,.mock-bar,.tune,.result-actions,.restart,.rz-det>summary::before,.hot-layer,.hot-hint{display:none}
  .rz-det[open] .det-body{display:block}
  body{background:#fff}
  .panel,.mock,.trust-item,.opp-card{box-shadow:none}
}

/* ---- v0.8: iframe モック ---- */
.mock-frame{width:100%;border:0;display:block;background:#F6F7F5}

/* ---- v0.8: intro 会社名インクリメンタルサーチ ---- */
.co-hits{position:absolute;left:0;right:0;top:100%;margin-top:6px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:0 10px 30px rgba(20,23,15,.10);overflow:hidden;z-index:30}
.co-hit{display:block;width:100%;text-align:left;padding:10px 14px;background:var(--surface);border:0;border-top:1px solid var(--line-2);cursor:pointer;font-family:inherit}
.co-hit:first-child{border-top:0}
.co-hit:hover{background:var(--surface-2)}
.co-hit .nm{display:block;font-size:14px;font-weight:600;color:var(--fg)}
.co-hit .mt{display:block;font-size:11px;color:var(--faint);font-family:var(--f-num);margin-top:1px}

/* ---- v0.8.2: design-qa Info対応 ---- */
.brand .tag{margin-left:10px}
.notice-more{display:inline}
.notice-more summary{display:inline;cursor:pointer;color:var(--green700);font-weight:600;font-size:12px;text-decoration:underline;text-underline-offset:2px}
.notice-more[open] summary{display:block;margin:4px 0 2px}
.voice-chip.aru{flex-basis:100%;text-align:left;background:#fff;border-style:dashed}
.opp-why{text-wrap:pretty}

/* ---- v0.8.3: intro LP＋slim notice ---- */
.notice.slim{padding:9px 16px;font-size:12px}
.notice .nlink{color:var(--green700);font-weight:600;text-decoration:underline;text-underline-offset:2px;margin-left:4px}
.intro-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:20px 0 24px}
.istep{border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 15px;background:var(--surface);display:flex;flex-direction:column;gap:1px}
.istep .ino{width:24px;height:24px;border-radius:99px;background:var(--brand-soft);color:var(--green700);font-family:var(--f-num);font-weight:700;font-size:12px;display:grid;place-items:center;margin-bottom:8px}
.istep b{font-size:13.5px;font-weight:700}
.istep span:last-child{font-size:11.5px;color:var(--faint)}
@media (max-width:720px){.intro-steps{grid-template-columns:1fr}}

/* ---- v0.9: モック全画面モード ---- */
.mock-fs{display:inline-flex;align-items:center;gap:5px;margin-left:8px;border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:7px;padding:4px 10px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;flex:none;transition:border-color .15s var(--ease),color .15s var(--ease)}
.mock-fs:hover{border-color:var(--green);color:var(--green700)}
.mock:fullscreen{display:flex;flex-direction:column;background:var(--bg);padding:0}
.mock:fullscreen .mock-frame{flex:1;height:auto !important}
.mock.fsov{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;background:var(--bg);border-radius:0;margin:0}
.mock.fsov .mock-frame{flex:1;height:auto !important}

/* ---- v0.9.2: 仕上げステップのメリハリ（工藤FB: 認知負荷） ---- */
.chips-lab{font-size:11.5px;font-weight:700;color:var(--muted);margin-bottom:8px}
.chips-lab span{font-weight:500;color:var(--faint)}
.voice-chips{margin-bottom:10px}
.voice-chip{font-size:12px;padding:5px 12px}
.voice-chip.aru{border-style:dashed;color:var(--muted)}
.free{margin-top:0}
.file-zone.slim{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--line-2)}
.file-zone.slim .file-btn{margin:0}
.file-note-inline{font-size:11px;color:var(--faint)}
.file-zone.slim .file-list{flex-basis:100%}

/* ---- v0.9.2: 御社カラー自動取得 ---- */
.sw-auto{flex-basis:100%;font-size:10.5px;color:var(--faint);margin-top:4px}
.tune{flex-wrap:wrap}

/* ---- v0.13: 選択肢が多い質問は2列（pain 9択の認知負荷対策） ---- */
.opts.two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.opts.two .opt{margin:0}
@media (max-width:720px){.opts.two{grid-template-columns:1fr}}

/* ---- v0.14: 結果のメール受け取り（任意・価値交換型） ---- */
.lead-mail{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.14);max-width:420px;margin-left:auto;margin-right:auto}
.lead-mail label{display:block;font-size:12px;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:7px}
.lm-row{display:flex;gap:8px}
.lm-row input{flex:1;min-width:0;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff;border-radius:9px;padding:9px 13px;font:inherit;font-size:13px;outline:none}
.lm-row input::placeholder{color:rgba(255,255,255,.4)}
.lm-row input:focus{border-color:var(--green)}
.lm-btn{flex:none;border:0;background:#fff;color:#18321F;border-radius:9px;padding:9px 18px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:inherit}
.lm-btn[disabled]{opacity:.6;cursor:default}
.lm-note{font-size:10.5px;color:rgba(255,255,255,.5);margin-top:7px}
.lm-done{font-size:13px;color:#A0D995;font-weight:600;text-align:center}

/* ---- v0.14.1: pain カテゴリ見出し（2段階スキャン） ---- */
.og-label{font-size:11.5px;font-weight:700;color:var(--faint);letter-spacing:.04em;margin:18px 2px 8px}
.og-label:first-of-type{margin-top:4px}
.og-label.none{margin:10px 0 0}
.og-label + .opts{margin-top:0}

/* ---- v0.15: CTA橋渡し＋メール欄の位置づけ（転換設計） ---- */
.cta-bridge{font-size:11.5px;color:rgba(255,255,255,.62);line-height:1.75;max-width:460px;margin:12px auto 0;text-align:center}
.lm-intro{font-size:12px;color:rgba(255,255,255,.7);margin-bottom:8px}
