:root{
  --ink:#0b0c0e;--panel:#141619;--panel2:#1b1e22;--paper:#ece6da;--paper2:#b8b3a8;--mut:#7e7a72;
  --line:rgba(236,230,218,.12);--gold:#e3a94d;--gold2:#caa15f;--live:#5fc9a3;--down:#e0705e;
  --g1:rgba(227,169,77,.16);--g2:rgba(95,201,163,.07);--featbg:linear-gradient(160deg,rgba(227,169,77,.13),rgba(20,22,25,.55));
  --ui:"Hanken Grotesk","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;--mono:"JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;
}
:root[data-theme="light"]{
  --ink:#f4f0e7;--panel:#fffdf8;--panel2:#faf6ec;--paper:#1b1813;--paper2:#574f42;--mut:#8a836f;
  --line:rgba(20,18,14,.13);--gold:#a9741b;--gold2:#8f6219;--live:#1c8c63;--down:#c0392b;
  --g1:rgba(169,116,27,.10);--g2:rgba(28,140,99,.06);--featbg:linear-gradient(160deg,rgba(169,116,27,.12),rgba(255,253,248,.5));
}
@media(prefers-color-scheme:light){:root[data-theme="system"]{
  --ink:#f4f0e7;--panel:#fffdf8;--panel2:#faf6ec;--paper:#1b1813;--paper2:#574f42;--mut:#8a836f;
  --line:rgba(20,18,14,.13);--gold:#a9741b;--gold2:#8f6219;--live:#1c8c63;--down:#c0392b;
  --g1:rgba(169,116,27,.10);--g2:rgba(28,140,99,.06);--featbg:linear-gradient(160deg,rgba(169,116,27,.12),rgba(255,253,248,.5));
}}
*{box-sizing:border-box;font-style:normal}
body{margin:0;background:var(--ink);color:var(--paper);font:16px/1.7 var(--ui);-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
.bg{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(900px 600px at 82% -6%,var(--g1),transparent 60%),radial-gradient(700px 500px at 6% 108%,var(--g2),transparent 60%)}
.bg:before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(circle at 50% 24%,#000,transparent 76%);opacity:.45;animation:drift 26s ease-in-out infinite alternate}
@keyframes drift{to{transform:translate3d(-26px,18px,0)}}
.wrap{max-width:1080px;margin:0 auto;padding:0 28px;position:relative;z-index:1}
a{color:var(--gold);text-decoration:none}a:hover{text-decoration:underline}
.top{position:sticky;top:0;z-index:6;backdrop-filter:blur(10px);background:color-mix(in srgb,var(--ink) 78%,transparent);border-bottom:1px solid var(--line)}
.top .wrap{display:flex;align-items:center;justify-content:space-between;height:64px;padding-top:0;padding-bottom:0}
.brand{font-weight:700;font-size:20px;letter-spacing:-.02em;color:var(--paper)}.brand b{color:var(--gold);font-weight:700}.brand:hover{text-decoration:none}
.navr{display:flex;align-items:center;gap:18px}
nav a{color:var(--paper2);font-size:14px;margin-left:20px}nav a:hover{color:var(--paper);text-decoration:none}
nav .pill{border:1px solid var(--gold);color:var(--gold);padding:7px 14px;border-radius:999px}nav .pill:hover{background:var(--gold);color:var(--ink)}
.theme{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.theme button{background:transparent;border:0;color:var(--mut);width:32px;height:28px;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:var(--mono);transition:color .2s,background .2s}
.theme button:hover{color:var(--paper)}.theme button.on{background:var(--gold);color:var(--ink)}
main{padding:34px 0 64px}
.reveal{}
@keyframes rise{to{opacity:1;transform:none}}
.hero{padding:42px 0 12px;max-width:940px}
.eyebrow{font-family:var(--mono);font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold2);display:flex;align-items:center;gap:14px}
.eyebrow:after{content:"";height:1px;width:80px;background:linear-gradient(90deg,var(--gold2),transparent)}
.hero h1{font-weight:700;font-size:clamp(34px,5.6vw,66px);line-height:1.12;letter-spacing:-.025em;margin:20px 0 0;color:var(--paper)}
.hero h1 .en{color:var(--gold)}
.line{display:block;overflow:hidden;padding-bottom:.05em}
.clip{display:block}
@keyframes clipup{to{transform:none}}
.rule{height:2px;width:220px;background:linear-gradient(90deg,var(--gold),transparent);margin:26px 0 22px}
@keyframes draw{to{width:220px}}
.lead{font-size:18.5px;line-height:1.72;color:var(--paper2);max-width:60ch}.lead b{color:var(--paper);font-weight:600}
.cta{display:flex;gap:14px;flex-wrap:wrap;margin:26px 0 0}
.board{margin:38px 0 0;border:1px solid var(--line);border-radius:12px;background:var(--panel);display:flex;align-items:stretch;overflow:hidden}
.blabel{flex:none;display:flex;align-items:center;gap:8px;padding:0 16px;border-right:1px solid var(--line);font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--gold2);text-transform:uppercase}
.dot{width:7px;height:7px;border-radius:50%;background:var(--live);animation:pulse 1.7s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.65)}}
.rows{flex:1;min-width:0;padding:9px 0}
.tkwrap{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}.tkwrap+.tkwrap{margin-top:5px}
.tktrack{display:flex;gap:34px;white-space:nowrap;width:max-content;font-family:var(--mono);font-size:12.5px;color:var(--paper2);animation:scrollL 46s linear infinite}
.tktrack.rev{animation:scrollR 52s linear infinite}
@keyframes scrollL{to{transform:translateX(-50%)}}@keyframes scrollR{from{transform:translateX(-50%)}to{transform:none}}
.itm{display:inline-flex;align-items:center;gap:6px}.itm b{color:var(--gold);font-weight:500}
.up{color:var(--live);font-size:10px}.down{color:var(--down);font-size:10px}.new{color:var(--gold);font-size:11px}
.stats{display:flex;gap:40px;margin:34px 0 0;flex-wrap:wrap}
.stat .n{font-size:38px;font-weight:700;letter-spacing:-.03em;color:var(--paper);line-height:1}.stat .n b{color:var(--gold);font-weight:700}
.stat .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);margin-top:7px}
.products{display:grid;grid-template-columns:1.35fr 1fr 1fr;gap:18px;margin:50px 0 18px}
.pcard{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px 22px;color:var(--paper);overflow:hidden;transition:transform .22s,border-color .22s,background .22s}
.pcard:hover{transform:translateY(-4px);border-color:var(--gold);background:var(--panel2);text-decoration:none}
.pcard .tag{font-family:var(--mono);font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--mut)}
.pcard.feat{background:var(--featbg);border-color:var(--gold)}.pcard.feat .tag{color:var(--gold2)}
.pcard h3{font-weight:600;font-size:21px;letter-spacing:-.01em;margin:13px 0 8px;line-height:1.34;color:var(--paper)}
.pcard p{font-size:14px;color:var(--paper2);margin:0;line-height:1.62}
.pprice{font-family:var(--mono);font-size:13px;color:var(--paper);margin-top:16px}.pprice .free{color:var(--live)}
.pcard .go{position:absolute;right:20px;bottom:20px;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--paper2);transition:all .22s;font-size:16px}
.pcard:hover .go{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.btn{display:inline-block;font-family:var(--ui);font-size:15px;font-weight:600;padding:13px 22px;border-radius:11px;border:1px solid transparent;cursor:pointer;transition:transform .18s,background .2s,border-color .2s}
.btn.primary,.btn.gold{background:var(--gold);color:var(--ink)}.btn.primary:hover,.btn.gold:hover{transform:translateY(-2px);filter:brightness(1.07);text-decoration:none}
.btn.ghost,.btn.lineb{border-color:var(--line);color:var(--paper);background:transparent}.btn.ghost:hover,.btn.lineb:hover{border-color:var(--paper2);transform:translateY(-2px);text-decoration:none}
.board-sec{margin:46px 0 0}.seclabel{font-size:18px;font-weight:600;color:var(--paper);margin:0 0 14px}
.filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.chip{border:1px solid var(--line);background:transparent;color:var(--paper2);padding:5px 12px;border-radius:999px;font-size:13px;cursor:pointer;font-family:var(--ui)}
.chip:hover{border-color:var(--gold);color:var(--paper)}.chip.on{background:var(--gold);color:var(--ink);border-color:var(--gold)}
#q{margin-left:auto;border:1px solid var(--line);border-radius:8px;padding:8px 11px;font-size:13px;min-width:190px;background:var(--panel);color:var(--paper);font-family:var(--ui)}
.tbl{overflow-x:auto;border:1px solid var(--line);border-radius:12px;background:var(--panel)}
table{border-collapse:collapse;width:100%;font-size:14px}
th,td{text-align:left;padding:11px 13px;border-bottom:1px solid var(--line);white-space:nowrap;color:var(--paper)}
.board-tbl td.t{white-space:normal}
thead th{font:500 11px/1.2 var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--mut);cursor:pointer;background:transparent}
tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--panel2)}
td.num,th.num{font-family:var(--mono);text-align:right;color:var(--paper2)}
td.t a{font-weight:600;color:var(--paper)}td.price{color:var(--gold);font-weight:600;font-family:var(--mono)}
.mini{font-size:13px;color:var(--gold)}
.b{font:10px var(--mono);padding:1px 6px;border-radius:4px;margin-left:8px;vertical-align:middle}
.b.demo{background:var(--down);color:#fff}.b.guide{background:var(--gold);color:var(--ink)}
.cnt{font:12px var(--mono);color:var(--mut);margin-top:10px}
.board-tbl tbody tr td.t{border-left:2px solid transparent;transition:border-color .12s}.board-tbl tbody tr:hover td.t{border-left-color:var(--gold)}
.crumb{font-size:12px;color:var(--mut);margin-bottom:14px}.crumb a{color:var(--mut)}.crumb span{color:var(--paper)}
.report h1{font-size:30px;letter-spacing:-.02em;line-height:1.22;margin:.1em 0 .4em;color:var(--paper)}
.report h2{font-size:20px;margin:1.6em 0 .4em;padding-top:.5em;border-top:1px solid var(--line);color:var(--paper)}
.report h3{font-size:16px;margin:1.2em 0 .3em;color:var(--paper)}
.summary{font-size:16px;color:var(--paper);background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 16px}
.trust{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--mut);margin:10px 0 18px;align-items:center}.trust b{color:var(--paper)}
.badge-ai,.badge-noadv{font:11px var(--mono);padding:2px 8px;border-radius:5px}
.badge-ai{background:var(--gold);color:var(--ink)}.badge-noadv{border:1px solid var(--down);color:var(--down)}
.demo-banner{background:var(--gold);color:var(--ink);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px}
blockquote{margin:1em 0;padding:.5em 1em;border-left:3px solid var(--gold);color:var(--paper2);background:var(--panel)}
code{font:13px var(--mono);background:var(--panel2);color:var(--paper);padding:1px 5px;border-radius:4px}
.paywall{position:relative;margin:26px 0;padding:28px 22px;border:1px solid var(--line);border-radius:14px;background:var(--panel);text-align:center}
.lock{font-size:26px}.paywall h3{margin:.3em 0;color:var(--paper)}
.buy{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:16px 0 6px}
.guide-cta .buy{justify-content:flex-start;margin:14px 0 0}
.tiny{font-size:12px;color:var(--mut)}
.devunlock{margin-top:10px;background:var(--paper);color:var(--ink);border:0;padding:7px 12px;border-radius:6px;font:12px var(--mono);cursor:pointer}
.premium-content{animation:fade .3s ease}@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1}}
.meta-block{margin-top:32px;font-size:14px}.meta-block h2{font-size:18px;border-top:1px solid var(--line);padding-top:.6em;color:var(--paper)}
.sources li{color:var(--paper2);margin:.2em 0}
.guide-cta{margin:28px 0;padding:22px;border-radius:12px;background:var(--panel);border:1px solid var(--line)}.guide-cta h3{margin:.1em 0 .3em;color:var(--paper)}
h1,h2,h3{color:var(--paper)}
.plans{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}
.plan{border:1px solid var(--line);border-radius:14px;padding:24px;background:var(--panel)}
.plan.feat{border-color:var(--gold)}
.plan .p{font-size:24px;font-weight:700;font-family:var(--mono);color:var(--gold)}
.plan ul{padding-left:18px;color:var(--paper2)}.plan li{margin:.3em 0}
.live{color:var(--live);font-weight:600}.live i{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--live);margin-right:5px;vertical-align:middle;animation:pulse 1.8s ease-in-out infinite}
.foot{border-top:1px solid var(--line);margin-top:48px}
.foot .wrap{padding:24px 28px;font-size:12px;color:var(--mut)}
.foot .disc{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px 12px}
.foot a{color:var(--gold2)}
@media(max-width:820px){.products{grid-template-columns:1fr}.plans{grid-template-columns:1fr}nav a:not(.pill){display:none}.hero h1{font-size:38px}.blabel{display:none}}
@media (prefers-reduced-motion:no-preference){
.reveal{opacity:0;transform:translateY(22px);animation:rise .9s cubic-bezier(.2,.75,.2,1) both}
.clip{transform:translateY(116%);animation:clipup 1s cubic-bezier(.2,.85,.2,1) both;animation-delay:inherit}
.rule{width:0;animation:draw 1.1s cubic-bezier(.2,.8,.2,1) .55s both}
}
.more{display:inline-block;margin-top:8px;border:1px solid var(--line);padding:9px 18px;border-radius:10px;color:var(--paper);font-weight:600;font-size:14px}
.more:hover{border-color:var(--gold);color:var(--gold);text-decoration:none}

/* --- report readability + data viz (v4) --- */
.report p,.report ul,.report ol{max-width:74ch}
.report blockquote{max-width:74ch;font-size:15.5px;border-left-width:4px;border-radius:0 10px 10px 0;padding:.7em 1.1em}
.report blockquote strong{color:var(--gold)}
.report .tbl,.report figure.viz{max-width:none;margin:18px 0}
.report td,.report th{white-space:normal}
.report table{font-size:13.5px}
.report h2{margin-top:1.9em}
figure.viz{border:1px solid var(--line);border-radius:12px;background:var(--panel);padding:14px 16px}
figure.viz svg{width:100%;height:auto;display:block;overflow:visible}
.viz figcaption{font:11px/1.2 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--mut);margin-bottom:9px}
.vz-cap{font:600 11px var(--mono);fill:var(--paper2)}
.vz-seg{font:11px var(--ui);fill:var(--paper2)}
.vz-track{fill:var(--line)}
.vz-band{fill:var(--gold);opacity:.5}
.vz-mid{fill:var(--gold)}
.vz-lab{font:10px var(--mono);fill:var(--mut)}
.vz-midlab{font:600 11px var(--mono);fill:var(--gold)}
.vz-segval{font:10px var(--mono);fill:var(--mut)}