
:root{
  --paper:#19181c;--paper-2:#201e23;--surface:#242128;--panel:#2a2830;
  --ink:#ece7df;--muted:#9a948b;--soft:#bdb7ac;--line:#37343c;
  --accent:#cb7a52;--accent-dark:#b46440;--accent-soft:#33291f;--star:#c9a35a;
  --tile-1:#e9e6e1;--tile-2:#f3f1ec;
  --shadow:0 24px 52px -28px rgba(0,0,0,.72);
  --shadow-sm:0 14px 30px -22px rgba(0,0,0,.55);
  --serif-en:"Fraunces",Georgia,"Times New Roman",serif;
  --serif-jp:"Zen Old Mincho","Yu Mincho","Hiragino Mincho ProN",serif;
  --sans:"Zen Kaku Gothic New","Yu Gothic","YuGothic",Meiryo,system-ui,sans-serif;
  --r:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.85;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{display:block}
.wrap{width:min(1080px,calc(100% - 48px));margin:0 auto}
.eyebrow{margin:0 0 16px;font-family:var(--serif-en);font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(22,21,25,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-family:var(--serif-jp);font-size:21px;font-weight:700;letter-spacing:.06em}
.brand::before{content:"";display:inline-block;width:9px;height:9px;margin-right:10px;border-radius:50%;background:var(--accent);vertical-align:middle}
.nav-links{display:flex;gap:24px;font-size:13px;font-weight:500;color:var(--muted)}
.nav-links a:hover{color:var(--ink)}
.nav-back{color:var(--muted);font-size:13px;font-weight:600}
.nav-back:hover{color:var(--ink)}

/* hero */
.hero{padding:clamp(56px,8vw,104px) 0 clamp(40px,5vw,64px)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.04fr) minmax(320px,.96fr);gap:clamp(34px,5vw,72px);align-items:center}
.brandline{margin:0 0 6px;font-family:var(--serif-en);font-weight:600;font-size:15px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft)}
.hero h1{margin:0;font-family:var(--serif-jp);font-weight:700;font-size:clamp(38px,5.4vw,76px);line-height:1.18;letter-spacing:.01em;overflow-wrap:anywhere}
.hero .lead{margin:24px 0 0;max-width:46ch;color:var(--soft);font-size:clamp(15px,1.5vw,17px);line-height:2.05}
.hero .chips{display:flex;flex-wrap:wrap;gap:8px;margin:26px 0 0}
.hero .chips span{border:1px solid var(--line);border-radius:999px;background:var(--surface);padding:7px 14px;font-size:12px;font-weight:500;color:var(--soft)}
.hero-facts{display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px;margin:30px 0 0}
.hero-facts .score{display:inline-flex;align-items:baseline;gap:4px;font-family:var(--serif-en);color:var(--accent)}
.hero-facts .score b{font-size:40px;font-weight:600;line-height:1}
.hero-facts .score small{font-size:14px;color:var(--muted)}
.hero-facts .rev{font-size:13px;color:var(--ink);font-weight:700}
.hero-facts .price{font-family:var(--serif-en);font-weight:600;font-size:24px;color:var(--ink)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.btn{display:inline-flex;align-items:center;justify-content:center;height:54px;padding:0 30px;border-radius:999px;font-size:15px;font-weight:700;letter-spacing:.02em;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 14px 26px -14px rgba(124,63,41,.9)}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.hero-visual{position:relative;aspect-ratio:4/5;border-radius:var(--r);overflow:hidden;background:linear-gradient(150deg,var(--tile-1),var(--tile-2));box-shadow:var(--shadow)}
.hero-visual img{width:100%;height:100%;object-fit:contain;padding:9%;mix-blend-mode:multiply}
.hero-visual .vnum{position:absolute;left:22px;top:14px;font-family:var(--serif-en);font-weight:600;font-size:clamp(64px,9vw,120px);line-height:1;color:rgba(43,39,34,.08);pointer-events:none}

/* toc */
.toc{position:sticky;top:64px;z-index:40;background:rgba(22,21,25,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.toc-in{display:flex;gap:6px;overflow-x:auto;padding:0}
.toc a{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;padding:15px 14px;font-size:12px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;transition:color .15s ease,border-color .15s ease}
.toc a span{font-family:var(--serif-en);font-weight:600;font-size:13px;color:var(--accent)}
.toc a:hover{color:var(--ink);border-bottom-color:var(--accent)}

/* sections */
main{padding:clamp(24px,4vw,40px) 0 120px}
.section{padding:clamp(48px,6vw,82px) 0;border-bottom:1px solid var(--line)}
.section .wrap{width:min(880px,calc(100% - 48px))}
.head{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:baseline;gap:18px;margin-bottom:36px}
.head .num{font-family:var(--serif-en);font-weight:600;font-size:clamp(36px,5vw,58px);line-height:.9;color:var(--accent)}
.head h2{margin:0;font-family:var(--serif-jp);font-weight:700;font-size:clamp(24px,3.2vw,40px);line-height:1.25}
.head h2 small{display:block;margin-bottom:6px;font-family:var(--serif-en);font-weight:600;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.prose{color:var(--soft);font-size:16px;line-height:2.05}
.prose.two{columns:2;column-gap:48px}
.prose p{margin:0 0 18px;break-inside:avoid}

/* spec */
.spec-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.spec{border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:18px}
.spec .lab{display:block;margin-bottom:8px;font-family:var(--serif-en);font-weight:600;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.spec .val{font-size:16px;font-weight:500;line-height:1.5;overflow-wrap:anywhere}

/* reviews */
.review-table{display:grid;gap:14px}
.rev{display:grid;grid-template-columns:210px minmax(0,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--surface)}
.review-source{background:var(--panel);color:var(--ink);padding:20px 22px}
.review-source b{display:block;font-size:15px;line-height:1.45}
.review-source .dir{display:block;margin-top:8px;font-size:12px;color:var(--muted);line-height:1.5}
.rev-body{display:grid;grid-template-columns:1fr 1fr}
.rev-body .col{padding:18px 22px}
.rev-body .col+.col{border-left:1px solid var(--line)}
.rev-body h4{margin:0 0 8px;font-family:var(--serif-en);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase}
.rev-body .good h4{color:var(--accent)}
.rev-body .bad h4{color:var(--muted)}
.rev-body p{margin:0;color:var(--soft);font-size:14px;line-height:1.85}

/* good (highlights) */
.points{display:grid;gap:0}
.point{display:grid;grid-template-columns:96px minmax(0,1fr);gap:26px;align-items:start;padding:34px 0;border-top:1px solid var(--line)}
.point:last-child{border-bottom:1px solid var(--line)}
.point .pn{font-family:var(--serif-en);font-weight:600;font-size:60px;line-height:.9;color:var(--accent);opacity:.85}
.point h3{margin:0 0 12px;font-family:var(--serif-jp);font-weight:700;font-size:23px;line-height:1.4}
.point p{margin:0;color:var(--soft);line-height:1.95}
.point .point-extra{margin-top:12px;font-size:14px;color:var(--muted)}

/* weak (trade-offs) */
.cons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.con{border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:24px}
.con .mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-family:var(--serif-en);font-weight:700;font-size:18px;margin-bottom:14px}
.con h3{margin:0 0 10px;font-family:var(--serif-jp);font-weight:700;font-size:18px;line-height:1.4}
.con p{margin:0;color:var(--soft);font-size:14px;line-height:1.9}

/* score */
.scores{display:grid;grid-template-columns:200px minmax(0,1fr);gap:48px;align-items:center}
.overall{display:grid;place-items:center;gap:14px;background:var(--panel);border-radius:14px;padding:32px 24px;color:var(--ink)}
.ov-label{font-family:var(--serif-en);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#d7a98e}
.ring-wrap{position:relative;width:160px;height:160px}
.ring-wrap svg{width:160px;height:160px;display:block;overflow:visible}
.ring-bg{fill:none;stroke:rgba(255,255,255,.12);stroke-width:9}
.ring-fg{fill:none;stroke:var(--accent);stroke-width:9;stroke-linecap:round;transform:rotate(-90deg);transform-origin:100px 100px}
.ring-num{position:absolute;inset:0;display:grid;place-items:center;text-align:center;line-height:1}
.ring-num span{font-family:var(--serif-en);font-weight:600;font-size:48px;color:var(--ink)}
.ring-num small{display:block;margin-top:2px;font-size:11px;color:var(--muted)}
.bars{display:grid;gap:18px}
.bar-row{display:grid;grid-template-columns:120px minmax(0,1fr) 46px;gap:14px;align-items:center}
.bar-row .bl{font-size:13px;font-weight:700;color:var(--soft)}
.bar-track{height:10px;border-radius:999px;background:var(--accent-soft);overflow:hidden}
.bar-fill{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--accent),#c0784f)}
.bar-row .bv{font-family:var(--serif-en);font-weight:600;font-size:18px;color:var(--ink);text-align:right}

/* verdict */
.quote{margin:0;font-family:var(--serif-jp);font-weight:700;font-size:clamp(22px,3vw,32px);line-height:1.6;color:var(--ink);border-left:3px solid var(--accent);padding:6px 0 6px 24px}
.verdict{margin:26px 0 0;color:var(--soft);font-size:16px;line-height:2.05}
.fit-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:32px 0 0}
.fit-col{border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:22px 24px}
.fit-col h4{margin:0 0 12px;font-family:var(--serif-jp);font-weight:700;font-size:16px;color:var(--ink)}
.fit-col.good h4{color:var(--accent)}
.fit-col ul{margin:0;padding-left:1.15em;color:var(--soft);font-size:14px;line-height:1.85}
.fit-col li{margin:0 0 9px}
.fit-col.good li::marker{color:var(--accent)}
.fit-col.weak li::marker{color:var(--muted)}
.verdict-meta{display:flex;flex-wrap:wrap;gap:10px 26px;margin:26px 0 0;padding-top:20px;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
.verdict-meta span{display:inline-flex;align-items:baseline;gap:7px}
.verdict-meta b{font-family:var(--serif-en);font-weight:600;font-size:19px;color:var(--ink);line-height:1}
@media(max-width:680px){.fit-grid{grid-template-columns:1fr}}
.score-note{margin:22px 0 0;padding:14px 16px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--muted);font-size:12.5px;line-height:1.85}
.srcbox{margin:0;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);padding:clamp(22px,3vw,30px)}
.srcbox+.srcbox{margin-top:16px}
.srcbox>.lab{display:block;margin-bottom:14px;font-family:var(--serif-en);font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.srclist{list-style:none;margin:0;padding:0;display:grid;gap:0}
.srclist li{border-top:1px solid var(--line);padding:13px 0}
.srclist li:first-child{border-top:0}
.srclist a{color:var(--ink);font-weight:700;font-size:15px}
.srclist a:hover{color:var(--accent)}
.srclist em{display:block;margin-top:3px;font-style:normal;color:var(--muted);font-size:12.5px}
.src-note{margin:16px 0 0;color:var(--muted);font-size:12.5px;line-height:1.85}
.src-note a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.score-note strong{color:var(--ink)}
.score-note a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* sources + cta */
.reference-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 36px;margin-bottom:8px}
.reference-list a{display:flex;align-items:center;gap:16px;min-height:54px;border-bottom:1px solid var(--line);color:var(--soft);font-size:14px}
.reference-list a:hover{color:var(--ink)}
.reference-list .src-n{font-family:var(--serif-en);font-weight:600;font-size:15px;color:var(--accent)}
.link-foot{margin-top:40px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface);box-shadow:var(--shadow-sm);padding:clamp(26px,4vw,40px)}
.link-foot>span{display:block;margin-bottom:10px;font-family:var(--serif-en);font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.link-foot h3{margin:0 0 12px;font-family:var(--serif-jp);font-weight:700;font-size:clamp(22px,3vw,32px);line-height:1.35}
.link-foot p{margin:0 0 22px;color:var(--soft);line-height:1.95}
.buy{display:flex;flex-wrap:wrap;gap:14px}
.buy a{display:inline-flex;align-items:center;justify-content:center;height:54px;padding:0 28px;border-radius:999px;font-weight:700;font-size:15px;transition:transform .18s ease,background .18s ease,border-color .18s ease}
.buy-main{background:var(--accent);color:#fff;box-shadow:0 14px 26px -14px rgba(124,63,41,.9)}
.buy-main:hover{background:var(--accent-dark);transform:translateY(-2px)}
.buy-sub{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.buy-sub:hover{border-color:var(--ink)}
.note{margin:18px 0 0;color:var(--muted);font-size:13px;line-height:1.8}

/* footer */
.foot{background:var(--ink);color:#c9bfb0;padding:60px 0}
.foot .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:22px;align-items:flex-end;width:min(1080px,calc(100% - 48px))}
.foot .fbrand{margin:0 0 8px;font-family:var(--serif-jp);font-weight:700;font-size:23px;color:var(--ink)}
.foot p{margin:0;font-size:13px;line-height:1.9}
.foot a{color:var(--accent)}

/* sticky buy bar */
.buybar{position:fixed;left:0;right:0;bottom:0;z-index:60;background:rgba(20,19,23,.96);backdrop-filter:blur(10px);box-shadow:0 -10px 30px -18px rgba(0,0,0,.6)}
.buybar-in{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0;width:min(1080px,calc(100% - 48px))}
.bb-info{min-width:0;color:var(--ink)}
.bb-info b{display:block;font-family:var(--serif-jp);font-weight:700;font-size:15px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bb-info span{display:block;font-size:12px;color:var(--muted)}
.bb-cta{flex:none;display:inline-flex;align-items:center;justify-content:center;height:46px;padding:0 26px;border-radius:999px;background:var(--accent);color:#fff;font-weight:700;font-size:14px;transition:background .18s ease}
.bb-cta:hover{background:var(--accent-dark)}
body{padding-bottom:74px}

/* responsive */
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}.hero-visual{order:-1;aspect-ratio:4/3}.scores{grid-template-columns:1fr;gap:28px;justify-items:center}.bars{width:100%}.cons{grid-template-columns:1fr}.spec-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.rev{grid-template-columns:1fr}.rev-body .col+.col{border-left:0;border-top:1px solid var(--line)}.reference-list{grid-template-columns:1fr}.prose.two{columns:1}}
@media(max-width:620px){.nav-links{display:none}.point{grid-template-columns:1fr;gap:8px}.head{grid-template-columns:1fr;gap:6px}.spec-grid{grid-template-columns:1fr}.bb-info span{display:none}.bb-info b{font-size:13px}}
