
/* 笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊・   Askive DESIGN SYSTEM v3.0
   險ｭ險域嶌v6.1螳悟・貅匁侠
笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊絶武笊・*/
:root {
  /* Brand */
  --coral: #E86248; --coral-h: #D4503A; --coral-l: #F0806A;
  --coral-pale: #FBE8E4; --coral-paler: #FEF4F2;
  /* Neutral */
  --cream: #F6F1EB; --cream-2: #EDE6DB; --cream-3: #E2D9CC;
  /* Ink */
  --ink: #1E1916; --ink-2: #3D3330; --ink-3: #6B5E59; --ink-4: #A09590; --ink-5: #C9C0BB;
  /* Surface */
  --surface: #FDFAF7; --surface-2: #F9F5F0; --surface-3: #F3EDE5;
  /* Panel Dark (fixed — never inverted in dark mode) */
  --panel-dark: #181412; --panel-dark-2: #241E1B; --panel-dark-3: #2E2622;
  /* Backward compat aliases */
  --dark: #181412; --dark-2: #241E1B; --dark-3: #2E2622;
  /* Semantic */
  --success: #2D8659; --warning: #C97A1F; --info: #2563EB; --danger: #C53030;
  /* Article types */
  --type-compare: #E86248; --type-deep: #2563EB; --type-monthly: #2D8659; --type-news: #7C3AED;
  /* Shadows */
  --sh-xs: 0 1px 2px rgba(30,25,22,0.06);
  --sh-sm: 0 2px 8px rgba(30,25,22,0.08), 0 1px 3px rgba(30,25,22,0.04);
  --sh-md: 0 8px 24px rgba(30,25,22,0.10), 0 3px 6px rgba(30,25,22,0.06);
  --sh-lg: 0 16px 48px rgba(30,25,22,0.14), 0 6px 16px rgba(30,25,22,0.08);
  /* Radii */
  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 20px; --r-2xl: 28px; --r-pill: 9999px;
  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-io: cubic-bezier(0.45, 0, 0.55, 1);
  --dur-f: 150ms; --dur-b: 250ms; --dur-s: 400ms;
  /* Fluid type */
  --fs-xs:  clamp(12px, 0.5vw + 11px, 13px);
  --fs-sm:  clamp(13px, 0.5vw + 12px, 14px);
  --fs-base:clamp(15px, 0.5vw + 14px, 17px);
  --fs-lg:  clamp(17px, 0.7vw + 15px, 19px);
  --fs-xl:  clamp(20px, 1vw + 17px, 24px);
  --fs-2xl: clamp(24px, 1.5vw + 19px, 32px);
  --fs-3xl: clamp(28px, 2.5vw + 20px, 40px);
  --fs-4xl: clamp(36px, 3.5vw + 22px, 56px);
  /* Spacing */
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;
  --sp-8:32px;--sp-10:40px;--sp-12:48px;--sp-16:64px;--sp-20:80px;--sp-24:96px;
  /* Section gap */
  --sec-gap: clamp(64px, 10vw, 128px);
  /* Fonts */
  --f-jp: 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Arial, 'Noto Sans JP', Meiryo, sans-serif;
  --f-en: 'Inter', 'Helvetica Neue', Arial, sans-serif;
  --f-heading-jp: 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Arial, 'Noto Sans JP', Meiryo, sans-serif;
  --f-heading-en: 'Inter', 'Helvetica Neue', Arial, sans-serif;
}

/* 笊絶武笊・RESET 笊絶武笊・*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--f-jp);background:var(--cream);color:var(--ink);line-height:1.8;font-size:var(--fs-base);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
img{display:block;max-width:100%}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* 笊絶武笊・FOCUS 笊絶武笊・*/
:focus-visible{outline:2px solid var(--coral);outline-offset:3px;border-radius:4px}

/* 笊絶武笊・SKIP LINK 笊絶武笊・*/
.skip-link{position:absolute;top:-100%;left:16px;background:var(--coral);color:#fff;padding:8px 16px;border-radius:0 0 var(--r-sm) var(--r-sm);z-index:999;font-size:var(--fs-sm);font-weight:600;transition:top 0.2s}
.skip-link:focus{top:0}

/* 笊絶武笊・SCROLL PROGRESS 笊絶武笊・*/
.scroll-progress{position:fixed;top:0;left:0;height:3px;background:var(--coral);z-index:301;width:0%;transition:none}

/* 笊絶武笊・LAYOUT 笊絶武笊・*/
.w{max-width:1240px;margin:0 auto;padding:0 var(--sp-6)}
section{padding:var(--sec-gap) 0}
@media(max-width:768px){section{padding:var(--sp-16) 0}}

/* 笊絶武笊・MOTION 笊絶武笊・*/
@media(prefers-reduced-motion:no-preference){
  .fu{opacity:0;transform:translateY(28px);transition:opacity 0.65s var(--ease-out),transform 0.65s var(--ease-out)}
  .fu.v{opacity:1;transform:translateY(0)}
  .fu:nth-child(2){transition-delay:.07s}.fu:nth-child(3){transition-delay:.14s}
  .fu:nth-child(4){transition-delay:.21s}.fu:nth-child(5){transition-delay:.28s}
  .fu:nth-child(6){transition-delay:.35s}
}
@media(prefers-reduced-motion:reduce){.fu{opacity:1!important;transform:none!important}}

/* 笊絶武笊・COMMON ELEMENTS 笊絶武笊・*/
.eyebrow{font-family:var(--f-heading-en);font-size:var(--fs-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--coral)}
.sec-title{font-family:var(--f-heading-jp);font-size:var(--fs-3xl);font-weight:700;line-height:1.35;letter-spacing:-.02em;color:var(--ink);text-wrap:balance}
.sec-desc{font-size:var(--fs-base);color:var(--ink-3);line-height:1.85;max-width:560px;text-wrap:pretty}
.sec-hd{margin-bottom:var(--sp-10)}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs);font-weight:700;padding:3px 10px;border-radius:var(--r-pill);font-family:var(--f-en)}
.badge-compare{background:rgba(232,98,72,.12);color:var(--type-compare)}
.badge-deep{background:rgba(37,99,235,.1);color:var(--type-deep)}
.badge-monthly{background:rgba(45,134,89,.1);color:var(--type-monthly)}
.badge-news{background:rgba(124,58,237,.1);color:var(--type-news)}

/* Buttons */
.btn-p{display:inline-flex;align-items:center;gap:6px;background:var(--coral);color:#fff;font-size:var(--fs-sm);font-weight:700;padding:14px 28px;border-radius:var(--r-pill);box-shadow:0 4px 20px rgba(232,98,72,.3);transition:background var(--dur-b),transform var(--dur-f),box-shadow var(--dur-b);min-height:44px}
.btn-s{display:inline-flex;align-items:center;gap:6px;background:var(--cream);color:var(--ink-2);font-size:var(--fs-sm);font-weight:600;padding:14px 28px;border-radius:var(--r-pill);border:1.5px solid var(--cream-2);transition:background var(--dur-b),transform var(--dur-f);min-height:44px}
@media(hover:hover){
  .btn-p:hover{background:var(--coral-h);transform:translateY(-2px);box-shadow:0 6px 28px rgba(232,98,72,.38)}
  .btn-s:hover{background:var(--cream-2);transform:translateY(-2px)}
}
.btn-p:active,.btn-s:active{transform:scale(.98)}

/* Card base */
.card{background:var(--surface);border-radius:var(--r-xl);transition:transform var(--dur-b) var(--ease-out),box-shadow var(--dur-b)}
@media(hover:hover){.card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}}

/* ───────────────── HEADER (site-hd unified) ───────────────── */
.site-hd{position:sticky;top:0;z-index:200;background:var(--surface);border-bottom:1px solid var(--cream-2);transition:box-shadow .3s}
.site-hd.scrolled{box-shadow:none}
/* PC/タブレット 60px / スマホ 40px（旧56px比 約71%）。横padding は 14px（モバイル）→ var(--sp-6)（PC） */
.hd-inner{max-width:1240px;margin:0 auto;padding:0 var(--sp-6);height:60px;display:flex;align-items:center;gap:var(--sp-8)}
@media(max-width:768px){.hd-inner{height:40px !important;padding:0 14px;gap:10px}}
/* ロゴ画像。PC=32px / スマホ=24px */
.site-hd .logo{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0;min-height:36px}
.site-hd .hd-logo-img{height:32px;width:auto;object-fit:contain;display:block;transition:height .2s}
@media(max-width:768px){.site-hd .hd-logo-img{height:24px !important;max-height:24px !important}.site-hd .logo{min-height:0}}

/* ─── 安全装置：ヘッダー領域内の <img> は CSS の読込/キャッシュ状態によらず強制的に上限値に制限 ───
   2026-04-29 ロゴ巨大化バグの再発防止。.hd-logo-img クラスが当たらなくても、
   header / .hd / .site-hd / .hd-inner 内のあらゆる img は最大高さに圧縮する。 */
header img,
.site-hd img,
.hd img,
.hd-inner img,
.hd-logo img,
img.hd-logo-img{max-height:40px;width:auto;object-fit:contain}
@media(max-width:768px){
  header img, .site-hd img, .hd img, .hd-inner img, .hd-logo img, img.hd-logo-img{max-height:24px !important;height:auto !important}
}
.logo-wm{font-family:var(--f-en);font-size:21px;font-weight:700;color:var(--coral);letter-spacing:-.03em}
.hd-nav{display:flex;gap:var(--sp-6);flex:1;white-space:nowrap}
.hd-nav a{font-size:var(--fs-sm);font-weight:500;color:var(--ink-3);position:relative;padding:4px 0;min-height:44px;display:flex;align-items:center;transition:color .2s;flex-shrink:0}
.hd-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1.5px;background:var(--coral);border-radius:2px;transition:width .25s var(--ease-out)}
@media(hover:hover){.hd-nav a:hover{color:var(--coral)}.hd-nav a:hover::after{width:100%}}
@media(max-width:1200px){.hd-nav{gap:16px}.hd-nav a{font-size:13px}}
@media(max-width:1060px){.hd-nav{gap:10px}.hd-nav a{font-size:13px}}

/* ─── メガメニュー（askive-nav.js / React SiteHeader 共通） ─── */
.mega-root{flex:1;display:flex;justify-content:flex-end;min-width:0}
.mega-nav{display:flex;align-items:center;justify-content:flex-end}
.mega-triggers{display:flex;align-items:center;gap:2px;flex-wrap:nowrap}
.mega-item{position:relative}
.mega-trigger{font-size:var(--fs-sm);font-weight:600;color:var(--ink-3);padding:8px 14px;border:none;background:transparent;cursor:pointer;border-radius:8px;transition:color .2s,background .2s;font-family:inherit;white-space:nowrap}
.mega-trigger:hover,.mega-trigger:focus-visible{color:var(--coral);background:var(--coral-paler);outline:none}
.mega-item.mega-open > .mega-trigger{color:var(--coral);background:var(--coral-paler)}
.mega-item .mega-drop{display:none;position:absolute;left:50%;transform:translateX(-50%);top:100%;padding-top:6px;z-index:220;pointer-events:none;min-width:0}
.mega-item.mega-open .mega-drop{display:block;pointer-events:auto}
.mega-item:first-child .mega-drop{left:0;transform:none}
.mega-item:last-child .mega-drop{left:auto;right:0;transform:none}
.mega-drop-inner{background:var(--surface);border:1px solid var(--cream-2);border-radius:var(--r-xl);box-shadow:0 20px 48px rgba(30,25,22,.12);padding:16px 18px 18px;animation:megaFade .2s ease-out;min-width:240px;max-width:min(320px,calc(100vw - 24px))}
@keyframes megaFade{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.mega-col-h{font-size:13px;font-weight:800;letter-spacing:.06em;color:var(--ink-4);text-transform:uppercase;font-family:var(--f-en);margin:0 0 10px;padding-bottom:8px;border-bottom:1px dashed var(--cream-2)}
.mega-link{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:var(--r-md);text-decoration:none;color:var(--ink);transition:background .15s,border-color .15s;border:1px solid transparent}
.mega-link:hover{background:var(--cream);border-color:var(--cream-2)}
.mega-link-t{font-size:14px;font-weight:700}
.mega-link-d{font-size:13px;color:var(--ink-3);line-height:1.45;font-weight:500}

.hd-actions{display:flex;align-items:center;gap:var(--sp-3);margin-left:auto}
.hd-search-btn{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:background .2s}
@media(max-width:768px){.hd-search-btn{width:30px;height:30px}.hd-search-btn svg{width:16px;height:16px}}
@media(hover:hover){.hd-search-btn:hover{background:var(--cream)}}
.hd-search-btn svg{width:18px;height:18px;stroke:var(--ink-3);fill:none;stroke-width:2;stroke-linecap:round}
.hd-search-modal{position:fixed;inset:0;background:rgba(20,15,12,.45);z-index:300;display:none;align-items:flex-start;justify-content:center;padding:80px 16px 16px}
.hd-search-modal.open{display:flex}
.hd-search-card{background:var(--surface);border-radius:16px;padding:18px;width:100%;max-width:560px;box-shadow:0 24px 48px rgba(0,0,0,.18)}
.hd-search-card form{display:flex;gap:8px}
.hd-search-card input{flex:1;padding:14px 16px;font-size:16px;border:2px solid var(--cream-2);border-radius:12px;outline:none;background:var(--surface-3);color:var(--ink)}
.hd-search-card input:focus{border-color:var(--coral)}
.hd-search-card button{padding:14px 20px;font-size:14px;font-weight:700;background:var(--coral);color:#fff;border:none;border-radius:12px;cursor:pointer}
.hd-search-card .hd-search-hint{margin:10px 4px 0;font-size:13px;color:var(--ink-3);line-height:1.6}
.btn-nl{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:600;color:var(--coral);border:1.5px solid var(--coral);padding:7px 14px;border-radius:var(--r-pill);transition:background .2s,color .2s;min-height:36px;display:flex;align-items:center}
@media(max-width:768px){.btn-nl{padding:5px 10px;min-height:28px;font-size:13px}}
@media(hover:hover){.btn-nl:hover{background:var(--coral);color:#fff}}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
@media(max-width:768px){.hamburger{min-width:36px;min-height:36px;padding:6px;gap:4px}.hamburger span{width:18px}}
.hamburger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mob-overlay{display:none;position:fixed;inset:40px 0 0;z-index:190;background:var(--surface);flex-direction:column;padding:var(--sp-6);gap:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
@media(min-width:769px){.mob-overlay{inset:60px 0 0}}
.mob-overlay.open{display:flex}
.mob-overlay a{font-size:var(--fs-lg);font-weight:500;color:var(--ink-2);padding:var(--sp-4) 0;border-bottom:1px solid var(--cream-2);min-height:44px;display:flex;align-items:center}
.mob-overlay form{margin:0 0 16px;display:flex;gap:8px}
.mob-overlay form input{flex:1;padding:12px 14px;font-size:15px;border:2px solid var(--cream-2);border-radius:10px;background:var(--surface);color:var(--ink);outline:none}
.mob-overlay form button{padding:12px 16px;font-size:14px;font-weight:700;background:var(--coral);color:#fff;border:none;border-radius:10px}
.mob-acc{border-bottom:1px solid var(--cream-2)}
.mob-acc summary{list-style:none;font-size:16px;font-weight:700;color:var(--ink);padding:14px 0;cursor:pointer;display:flex;align-items:center;justify-content:space-between}
.mob-acc summary::-webkit-details-marker{display:none}
.mob-acc summary::after{content:"+";font-weight:800;color:var(--coral);font-size:18px}
.mob-acc[open] summary::after{content:"−"}
.mob-acc-links{display:flex;flex-direction:column;padding:0 0 12px 8px;gap:4px}
.mob-acc-links a{font-size:15px;font-weight:500;color:var(--ink-2);padding:10px 8px;text-decoration:none;border-radius:8px}
.mob-acc-links a:hover{background:var(--cream);color:var(--coral)}
.mob-overlay .mob-extra{font-size:15px;font-weight:500;color:var(--ink-2);padding:16px 0;border-bottom:1px solid var(--cream-2);min-height:44px;display:flex;align-items:center;text-decoration:none}

/* 笊絶武笊・HERO v5 LIGHT 笊絶武笊・*/
.hero{background:var(--surface);padding:0;overflow:hidden;position:relative;min-height:min(92dvh,860px);display:flex;align-items:center}
.hero::before{display:none}
.hero::after{display:none}
@keyframes hero-glow{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-20px,15px) scale(1.05)}}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-12);align-items:center;position:relative;z-index:1;padding:var(--sp-24) 0 var(--sp-16)}
.hero-left{max-width:540px}
.hero-ey-v5{display:inline-flex;align-items:center;gap:var(--sp-2);background:transparent;color:var(--coral);font-size:var(--fs-xs);font-weight:700;letter-spacing:.06em;padding:6px 16px;border-radius:var(--r-pill);margin-bottom:var(--sp-6);border:1px solid var(--coral-pale)}
.hero h1{font-size:clamp(36px,5vw,58px);font-weight:700;line-height:1.15;letter-spacing:-.035em;color:var(--ink);margin-bottom:var(--sp-5);text-wrap:balance}
.hero h1 em{font-style:normal;color:var(--coral)}
.hero-sub-v5{font-size:var(--fs-lg);color:var(--ink-3);line-height:1.85;margin-bottom:var(--sp-8);text-wrap:pretty}
.hero-ctas{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-8)}
.hero .btn-p{font-size:var(--fs-base);padding:16px 32px}
.hero .btn-s{font-size:var(--fs-base);padding:16px 32px}
.hero-badges{display:flex;gap:var(--sp-5);flex-wrap:wrap}
.hero-badge{display:flex;align-items:center;gap:6px;font-size:var(--fs-xs);color:var(--ink-4)}
.hero-dot{width:6px;height:6px;border-radius:50%;background:var(--coral);flex-shrink:0}
.hero-right{position:relative;display:flex;justify-content:center;align-items:center}
.hero-card{background:var(--surface);border:1px solid var(--cream-2);border-radius:var(--r-2xl);padding:var(--sp-6);width:100%;max-width:400px;box-shadow:var(--sh-lg),0 0 0 1px var(--cream-2);animation:hero-card-in 1s .3s both var(--ease-out)}
@keyframes hero-card-in{from{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:none}}
.hero-card-title{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;letter-spacing:.1em;color:var(--coral);text-transform:uppercase;margin-bottom:var(--sp-4)}
.hero-card-tool{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}
.hero-card-tool-name{font-size:var(--fs-xl);font-weight:700;color:var(--ink)}

.hero-score-rows{display:flex;flex-direction:column;gap:10px}
.hero-score-item{display:flex;align-items:center;gap:var(--sp-2)}
.hero-score-label{font-size:13px;color:var(--ink-2);width:80px;flex-shrink:0;font-weight:600}
.hero-score-bar{flex:1;height:16px;background:var(--cream-2);border-radius:var(--r-pill);overflow:hidden}
.hero-score-fill{height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--coral),var(--coral-l));transition:width 1.2s var(--ease-out)}
.hero-score-num{font-family:var(--f-en);font-size:14px;font-weight:800;color:var(--ink);width:28px;text-align:right;font-variant-numeric:tabular-nums}
.hero-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--sp-5);padding-top:var(--sp-4);border-top:1px solid var(--cream-2)}
.hero-card-price{font-size:var(--fs-sm);color:var(--ink-4)}
.hero-card-price strong{color:var(--ink);font-weight:700}
.hero-card-link{font-size:var(--fs-xs);color:var(--coral);font-weight:600;display:flex;align-items:center;gap:4px}



}


.hero-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}
.hero-card-dots{display:flex;gap:6px}
.hero-dot-ind{width:8px;height:8px;border-radius:50%;background:var(--cream-2);cursor:pointer;transition:background .3s,transform .2s}
.hero-dot-ind.active{background:var(--coral);transform:scale(1.25)}
.hero-dot-ind:hover{background:var(--coral-l)}
.hero-card-tool-cat{display:block;font-size:var(--fs-xs);color:var(--ink-4);margin-top:2px}
.hero-card-chip{font-family:var(--f-en);font-size:var(--fs-2xl);font-weight:700;color:var(--coral);display:flex;align-items:baseline;gap:2px;line-height:1}
.hero-chip-label{font-size:var(--fs-xs);font-weight:600;color:var(--ink-4)}

@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;text-align:center;padding:var(--sp-16) 0 var(--sp-12)}
  .hero-left{max-width:640px;margin:0 auto}
  .hero-ctas,.hero-badges{justify-content:center}
  .hero-right{margin-top:var(--sp-8)}
  .hero-card{max-width:360px;margin:0 auto}
  
}
@media(max-width:768px){
  .hero h1{font-size:clamp(28px,6vw,40px)}
  .hero-right{display:none}
  .hero{min-height:auto}
}

/* 笊絶武笊・STATS BAR v5 笊絶武笊・*/
.stats-bar{background:var(--surface-2);border-top:1px solid var(--cream-2);border-bottom:1px solid var(--cream-2);padding:var(--sp-5) 0}
.stats-inner{display:flex;justify-content:center;gap:clamp(24px,5vw,64px);flex-wrap:wrap}
.stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}
.stat-num{font-family:var(--f-en);font-weight:700;font-variant-numeric:tabular-nums;color:var(--coral);font-size:var(--fs-2xl)}
.stat-label{font-size:var(--fs-xs);color:var(--ink-4)}

/* 笊絶武笊・SEARCH 笊絶武笊・*/
.search-sec{background:var(--surface);padding:var(--sp-8) 0 var(--sp-16)}
.search-wrap{max-width:680px;margin:0 auto;position:relative;padding:0 var(--sp-6)}
.search-box{width:100%;display:flex;align-items:center;background:var(--cream);border:2px solid var(--cream-2);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-5);gap:var(--sp-3);transition:border-color .2s,box-shadow .2s,background .2s}
.search-box:focus-within{border-color:var(--coral);background:var(--surface);box-shadow:0 0 0 4px rgba(232,98,72,.12)}
.search-box svg{width:20px;height:20px;stroke:var(--ink-4);flex-shrink:0;fill:none;stroke-width:2;stroke-linecap:round}
.search-input{flex:1;font-family:var(--f-jp);font-size:var(--fs-base);color:var(--ink);border:none;background:transparent;outline:none;min-height:28px}
.search-input::placeholder{color:var(--ink-4)}
.search-kbd{font-family:var(--f-en);font-size:13px;color:var(--ink-4);background:var(--surface);border:1px solid var(--cream-2);border-radius:5px;padding:2px 7px;flex-shrink:0}
.search-chips-label{font-size:var(--fs-sm);color:var(--ink-4);font-weight:500;margin-right:4px}.search-chips{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-top:var(--sp-3);justify-content:center}
.search-chip{font-size:var(--fs-xs);color:var(--ink-3);background:var(--cream);border:1px solid var(--cream-2);border-radius:var(--r-pill);padding:4px 12px;transition:background .2s,border-color .2s;cursor:pointer}
@media(hover:hover){.search-chip:hover{background:var(--coral-paler);border-color:var(--coral-pale);color:var(--coral)}}
.search-suggests{position:absolute;top:calc(100% - 24px);left:var(--sp-6);right:var(--sp-6);background:var(--surface);border:1.5px solid var(--cream-2);border-radius:var(--r-lg);box-shadow:var(--sh-md);display:none;z-index:50;overflow:hidden;margin-top:var(--sp-2)}
.search-wrap:focus-within .search-suggests{display:block}
.sug-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);font-size:var(--fs-sm);color:var(--ink-2);transition:background .15s;cursor:pointer;min-height:44px}
@media(hover:hover){.sug-item:hover{background:var(--cream)}}
.sug-cat{margin-left:auto;font-size:var(--fs-xs);font-family:var(--f-en)}

/* 笊絶武笊・PERSONA 笊絶武笊・*/
.persona-sec{background:var(--cream);padding:var(--sec-gap) 0}
.persona-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(240px,100%),1fr));gap:var(--sp-4)}
.persona-card{background:var(--surface);border-radius:var(--r-xl);padding:var(--sp-6);cursor:pointer;border:2px solid transparent;transition:transform var(--dur-b) var(--ease-out),box-shadow var(--dur-b),border-color var(--dur-b);min-height:44px}
@media(hover:hover){.persona-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--coral-pale)}}
.persona-icon{width:48px;height:48px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-4)}
.persona-label{font-size:var(--fs-sm);font-weight:700;color:var(--ink);margin-bottom:var(--sp-1)}
.persona-desc{font-size:var(--fs-xs);color:var(--ink-4);line-height:1.6}
.persona-arrow{font-size:var(--fs-sm);color:var(--coral);font-weight:600;margin-top:var(--sp-3);display:flex;align-items:center;gap:4px}

/* 笊絶武笊・COMPARE 笊絶武笊・*/
.compare-sec{background:var(--surface);padding:var(--sec-gap) 0}
.cmp-card{background:var(--cream);border-radius:var(--r-2xl);padding:var(--sp-8);box-shadow:var(--sh-sm)}
.cmp-selects{display:grid;grid-template-columns:1fr 44px 1fr;gap:var(--sp-4);align-items:center;margin-bottom:var(--sp-6)}
.vs-badge{width:44px;height:44px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;color:var(--ink-4);justify-self:center}
.tool-sel{width:100%;padding:var(--sp-3) var(--sp-4);padding-right:36px;border:1.5px solid var(--cream-2);border-radius:var(--r-md);font-family:var(--f-jp);font-size:var(--fs-base);color:var(--ink);background:var(--surface);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%23A09590' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:border-color .2s;min-height:44px}
.tool-sel:focus{outline:none;border-color:var(--coral)}
.cmp-btn{width:100%;background:var(--coral);color:#fff;font-size:var(--fs-base);font-weight:700;padding:var(--sp-4);border-radius:var(--r-md);transition:background .2s,transform .15s;margin-bottom:var(--sp-6);min-height:48px}
@media(hover:hover){.cmp-btn:hover{background:var(--coral-h);transform:translateY(-1px)}}
.cmp-btn:active{transform:scale(.98)}
.cmp-results{display:none}
.cmp-results.show{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(300px,100%),1fr));gap:var(--sp-5)}
.cmp-tool{border:1.5px solid var(--cream-2);border-radius:var(--r-xl);padding:var(--sp-5);background:var(--surface);transition:border-color .2s}
@media(hover:hover){.cmp-tool:hover{border-color:var(--coral-pale)}}
.cmp-tool-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}
.cmp-tool-name{font-size:var(--fs-lg);font-weight:700}
.score-chip{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;background:var(--coral-pale);color:var(--coral);padding:3px 10px;border-radius:var(--r-pill)}
.score-rows{display:flex;flex-direction:column;gap:var(--sp-2)}
.score-row{display:flex;align-items:center;gap:var(--sp-2)}
.score-lbl{font-size:var(--fs-xs);color:var(--ink-3);width:80px;flex-shrink:0}
.score-bar-bg{flex:1;height:16px;background:var(--cream-2);border-radius:var(--r-pill);overflow:hidden}
.score-bar-fill{height:100%;border-radius:var(--r-pill);transition:width .6s var(--ease-out)}
.score-val{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:600;width:24px;text-align:right;font-variant-numeric:tabular-nums}
.cmp-comment{margin-top:var(--sp-4);font-size:var(--fs-xs);color:var(--ink-3);line-height:1.7;padding:var(--sp-3);background:var(--cream);border-radius:var(--r-sm)}
.cmp-comment strong{color:var(--ink-2)}
.cmp-detail-btn{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs);font-weight:600;color:var(--coral);margin-top:var(--sp-3);min-height:44px}

/* ── Home Compare v2 (data-driven, parity with compare.html) ── */
.cmp-verdict-bar{background:var(--ink);color:#fff;padding:var(--sp-4) var(--sp-6);border-radius:var(--r-lg);margin-bottom:var(--sp-6);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-3)}
.cmp-verdict-bar-l{font-family:var(--f-en);font-size:13px;font-weight:700;color:rgba(255,255,255,.78);letter-spacing:.08em;text-transform:uppercase}
.cmp-verdict-bar-r{font-size:var(--fs-base);font-weight:600;color:#fff}
.cmp-verdict-bar-r strong{color:var(--coral-l);font-weight:800}

/* ── ホーム CompareSection v2: ヘッド・トゥ・ヘッド比較レイアウト ── */

/* 1. ツールヘッダー（左右並列） */
.cmp-headers-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);margin-bottom:var(--sp-6)}
.cmp-head-card{background:var(--surface);border:1.5px solid var(--cream-2);border-radius:var(--r-xl);padding:var(--sp-5);position:relative;display:flex;flex-direction:column;gap:6px;transition:border-color .25s,box-shadow .25s,transform .25s}
.cmp-head-card.is-winner{border-color:var(--coral);box-shadow:0 14px 36px rgba(232,98,72,.14);transform:translateY(-2px);background:linear-gradient(135deg,#fff 0%,rgba(232,98,72,.03) 100%)}
.cmp-head-card.cmp-head-a{border-left:4px solid var(--coral)}
.cmp-head-card.cmp-head-b{border-left:4px solid #3B8FA1}
.cmp-head-card.cmp-head-a.is-winner{border-left-color:var(--coral)}
.cmp-head-card.cmp-head-b.is-winner{border-left-color:#3B8FA1}
.cmp-winner-flag{position:absolute;top:-10px;right:14px;background:var(--coral);color:#fff;font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.08em;padding:5px 12px;border-radius:99px;box-shadow:0 4px 12px rgba(232,98,72,.3);text-transform:uppercase}
.cmp-head-side{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.12em;color:var(--ink-4);text-transform:uppercase;margin-bottom:2px}
.cmp-head-card.cmp-head-a .cmp-head-side{color:var(--coral)}
.cmp-head-card.cmp-head-b .cmp-head-side{color:#3B8FA1}
.cmp-head-card .cmp-tool-name{font-size:var(--fs-xl);font-weight:800;color:var(--ink);letter-spacing:-.01em;line-height:1.25}
.cmp-tool-vendor{font-size:13px;color:var(--ink-4);margin-top:2px;font-weight:500}
.cmp-head-card .cmp-tool-score{display:flex;flex-direction:row;align-items:center;gap:8px;margin-top:8px}
.cmp-tier-label{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:99px}
.cmp-tier-excellent{background:#E5F0E8;color:#2D8659;border:1px solid rgba(45,134,89,.25)}
.cmp-tier-good{background:#FCE9E3;color:#C04936;border:1px solid rgba(232,98,72,.3)}
.cmp-tier-fair{background:#FAEBD3;color:#8C5512;border:1px solid rgba(195,124,33,.3)}
.cmp-tier-review{background:#EFE6E0;color:#6E4D3F;border:1px solid rgba(110,77,63,.25)}

/* 2. 6軸ヘッド・トゥ・ヘッドバー */
.cmp-h2h{background:var(--cream);border-radius:var(--r-xl);padding:var(--sp-6);margin-bottom:var(--sp-6);border:1px solid var(--cream-2)}
.cmp-h2h-legend{display:flex;align-items:center;justify-content:center;gap:24px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px dashed var(--cream-2);flex-wrap:wrap}
.cmp-h2h-leg{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-2)}
.cmp-h2h-dot{width:10px;height:10px;border-radius:99px;display:inline-block}
.cmp-h2h-leg-a .cmp-h2h-dot{background:linear-gradient(90deg,#FFB8A0,#E86248)}
.cmp-h2h-leg-b .cmp-h2h-dot{background:linear-gradient(90deg,#A4D8E1,#3B8FA1)}
.cmp-h2h-row{display:grid;grid-template-columns:84px 1fr;gap:14px;align-items:center;padding:8px 0}
.cmp-h2h-row + .cmp-h2h-row{border-top:1px dashed rgba(232,217,206,.6)}
.cmp-h2h-label{font-size:13px;font-weight:700;color:var(--ink);text-align:right}
.cmp-h2h-bars{display:flex;flex-direction:column;gap:6px}
.cmp-h2h-bar{position:relative;background:rgba(255,255,255,.85);border-radius:8px;height:26px;overflow:hidden;border:1px solid var(--cream-2);transition:box-shadow .25s,border-color .25s}
.cmp-h2h-fill{height:100%;border-radius:7px 0 0 7px;transition:width .8s cubic-bezier(.4,0,.2,1)}
.cmp-h2h-bar-a .cmp-h2h-fill{background:linear-gradient(90deg,#FFB8A0,#E86248)}
.cmp-h2h-bar-b .cmp-h2h-fill{background:linear-gradient(90deg,#A4D8E1,#3B8FA1)}
.cmp-h2h-bar.is-winner{box-shadow:0 0 0 2px rgba(232,98,72,.2);border-color:transparent}
.cmp-h2h-bar-b.is-winner{box-shadow:0 0 0 2px rgba(59,143,161,.25)}
.cmp-h2h-val{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-family:var(--f-en);font-size:13px;font-weight:800;color:var(--ink);z-index:1;pointer-events:none;text-shadow:0 1px 2px rgba(255,255,255,.6)}

/* 3. 分析コメント（左右） */
.cmp-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);margin-bottom:var(--sp-6)}
.cmp-summary-box{background:var(--surface);border:1px solid var(--cream-2);border-radius:var(--r-lg);padding:16px 18px;position:relative}
.cmp-summary-grid > .cmp-summary-box:nth-child(1){border-left:3px solid var(--coral)}
.cmp-summary-grid > .cmp-summary-box:nth-child(2){border-left:3px solid #3B8FA1}
.cmp-summary-hd{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.cmp-summary-grid > .cmp-summary-box:nth-child(1) .cmp-summary-hd{color:var(--coral)}
.cmp-summary-grid > .cmp-summary-box:nth-child(2) .cmp-summary-hd{color:#3B8FA1}
.cmp-summary-body{font-size:13px;line-height:1.75;color:var(--ink-2)}

/* 4. 強み・弱み 4ボックス（2x2） */
.cmp-procon-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:var(--sp-6)}
.cmp-procon-cell{padding:14px 16px;border-radius:12px;display:flex;flex-direction:column;gap:8px}
.cmp-procon-pro{background:rgba(45,134,89,.05);border:1px solid rgba(45,134,89,.18)}
.cmp-procon-con{background:rgba(232,98,72,.04);border:1px solid rgba(232,98,72,.18)}
.cmp-procon-hd{font-size:13px;font-weight:800;letter-spacing:.02em;display:flex;align-items:center;gap:6px}
.cmp-procon-pro .cmp-procon-hd{color:#1F5A3D}
.cmp-procon-con .cmp-procon-hd{color:#9A3920}
.cmp-procon-icon{font-size:13px;font-weight:900}
.cmp-procon-pro .cmp-procon-icon{color:#2D8659}
.cmp-procon-con .cmp-procon-icon{color:#C84B30}
.cmp-procon-body{font-size:13px;line-height:1.7;color:var(--ink-2)}

/* 5. 料金・公式（左右） */
.cmp-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5);padding-top:var(--sp-5);border-top:1px dashed var(--cream-2);margin-bottom:var(--sp-3)}
.cmp-bottom-cell{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}
.cmp-bottom-cell:nth-child(1){border-left:3px solid var(--coral);padding-left:14px}
.cmp-bottom-cell:nth-child(2){border-left:3px solid #3B8FA1;padding-left:14px}

/* レスポンシブ */
@media(max-width:820px){
  .cmp-headers-grid,.cmp-summary-grid,.cmp-bottom-grid{grid-template-columns:1fr;gap:14px}
  .cmp-procon-grid{grid-template-columns:1fr}
  .cmp-h2h{padding:var(--sp-5)}
  .cmp-h2h-row{grid-template-columns:64px 1fr;gap:10px}
  .cmp-h2h-label{font-size:13px}
}
@media(max-width:520px){
  .cmp-h2h-row{grid-template-columns:1fr;gap:6px}
  .cmp-h2h-label{text-align:left;padding-bottom:2px}
  .cmp-bottom-cell{padding-left:10px}
}

/* 旧スタイル互換（compare.html / 他で使用継続） */
.cmp-results-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5)}
@media(max-width:768px){.cmp-results-grid{grid-template-columns:1fr}}
.cmp-tool-card{background:var(--surface);border:1.5px solid var(--cream-2);border-radius:var(--r-xl);padding:var(--sp-6);position:relative;display:flex;flex-direction:column;gap:14px;transition:border-color .25s,box-shadow .25s,transform .25s}
.cmp-tool-card.is-winner{border-color:var(--coral);box-shadow:0 14px 36px rgba(232,98,72,.14);transform:translateY(-3px)}
.cmp-tool-card .cmp-tool-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:0}
.cmp-tool-card .cmp-tool-name{font-size:var(--fs-lg);font-weight:700;color:var(--ink);letter-spacing:-.005em;line-height:1.3}
.cmp-tool-card .cmp-tool-score{display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.cmp-tool-summary{font-size:13px;color:var(--ink-3);line-height:1.7;background:var(--cream);padding:12px 14px;border-radius:var(--r-md);border-left:3px solid var(--coral-pale)}
.cmp-tool-summary strong{color:var(--coral);font-weight:700}
.cmp-procon{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:520px){.cmp-procon{grid-template-columns:1fr}}
.cmp-pro,.cmp-con{padding:10px 12px;border-radius:10px;font-size:13px;line-height:1.55;background:var(--cream);border:1px solid var(--cream-2);color:var(--ink-2)}
.cmp-pro{border-left:3px solid #2D8659}
.cmp-con{border-left:3px solid #B85949}
.cmp-pc-lbl{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.08em;color:var(--ink-4);text-transform:uppercase;margin-bottom:5px;display:flex;align-items:center;gap:4px}
.cmp-pc-icon{font-size:13px;color:#2D8659;font-weight:800}
.cmp-con .cmp-pc-icon{color:#B85949}
.cmp-tool-bottom{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding-top:12px;border-top:1px dashed var(--cream-2);margin-top:auto}
.cmp-chip-free{font-size:13px;font-weight:800;color:#2D8659;background:rgba(45,134,89,.1);padding:4px 10px;border-radius:99px;border:1px solid rgba(45,134,89,.25)}
.cmp-tool-price{font-size:13px;color:var(--ink-3);flex:1;min-width:0}
.cmp-tool-link{font-family:var(--f-en);font-size:13px;font-weight:700;color:var(--coral);background:var(--surface);border:1px solid var(--coral-pale);padding:6px 12px;border-radius:99px;text-decoration:none;letter-spacing:.04em;transition:all .2s}
.cmp-tool-link:hover{background:var(--coral);color:#fff;border-color:var(--coral)}

.cmp-data-note{margin:18px 0 0;font-size:13px;color:var(--ink-4);display:flex;align-items:center;gap:8px;flex-wrap:wrap;line-height:1.7}
.cmp-data-note a{color:var(--coral);text-decoration:underline;text-underline-offset:2px}
.cmp-data-dot{width:8px;height:8px;background:#2D8659;border-radius:50%;flex-shrink:0;animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}

/* 笊絶武笊・ARTICLES 笊絶武笊・*/
.articles-sec{background:var(--cream);padding:var(--sec-gap) 0}
.feat-grid{display:grid;grid-template-columns:7fr 5fr;gap:var(--sp-5)}
.art-hero{background:var(--surface);border-radius:var(--r-xl);overflow:hidden;cursor:pointer;transition:transform .25s var(--ease-out),box-shadow .25s}
@media(hover:hover){.art-hero:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}}
.thumb-h{aspect-ratio:16/9;width:100%;overflow:hidden;background:var(--cream)}.thumb-h>svg{width:100%;height:100%;display:block}
.art-hero-body{padding:var(--sp-5) var(--sp-6) var(--sp-6)}
.art-sub-stack{display:flex;flex-direction:column;gap:var(--sp-3)}
.art-sm{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;display:flex;gap:0;cursor:pointer;flex:1;transition:transform .2s var(--ease-out),box-shadow .2s}
@media(hover:hover){.art-sm:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}}
.thumb-s{width:140px;flex-shrink:0;overflow:hidden;background:var(--cream);aspect-ratio:16/9}.thumb-s>svg{width:100%;height:100%;display:block;min-height:120px}
.art-sm-body{padding:var(--sp-3) var(--sp-4);flex:1}
.art-title-l{font-size:var(--fs-lg);font-weight:700;line-height:1.55;color:var(--ink);margin-bottom:var(--sp-2)}
.art-title-s{font-size:var(--fs-sm);font-weight:700;line-height:1.5;color:var(--ink);margin-bottom:4px}
.art-meta{display:flex;align-items:center;gap:var(--sp-3);font-size:var(--fs-xs);color:var(--ink-4);font-family:var(--f-en);flex-wrap:wrap}
.art-score{color:var(--coral);font-weight:700}
.art-editor{font-weight:600}
.ai-tag{display:inline-block;font-family:var(--f-en);font-size:.72em;font-weight:500;color:var(--ink-4);background:var(--cream);padding:1px 7px;border-radius:99px;letter-spacing:.02em;vertical-align:middle;line-height:1.6;border:1px solid var(--cream-2);margin:0 2px}
.ai-tag::before{content:"AI";font-size:.85em;font-weight:700;color:var(--coral);margin-right:3px;letter-spacing:.04em}

/* 笊絶武笊・A-SCORE (6-axis) 笊絶武笊・*/
.ascore-sec{background:var(--surface);padding:var(--sec-gap) 0}
.ascore-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-16);align-items:start}
.radar-wrap{display:flex;justify-content:center;position:sticky;top:100px}
.radar-svg{width:100%;max-width:360px;height:auto}
.ascore-axes{display:flex;flex-direction:column;gap:var(--sp-4)}
.axis-row{display:flex;align-items:center;gap:var(--sp-4)}
.axis-icon{width:40px;height:40px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--sh-xs)}
.axis-icon svg{width:18px;height:18px;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;fill:none}
.axis-info{flex:1}
.axis-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.axis-nm{font-size:15px;font-weight:700;color:var(--ink)}
.axis-abbr{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;color:var(--coral);margin-left:4px}
.axis-d{font-size:13px;color:var(--ink-4);line-height:1.5}
.axis-num{font-family:var(--f-en);font-size:18px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--ink)}
.axis-bar{width:100%;height:5px;background:var(--cream-2);border-radius:var(--r-pill)}
.axis-fill{height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--coral-l),var(--coral))}
.total-score{margin-top:var(--sp-5);padding:var(--sp-5) var(--sp-6);background:var(--cream);border-radius:var(--r-xl);display:flex;align-items:center;gap:var(--sp-4)}
.total-num{font-family:var(--f-en);font-size:48px;font-weight:700;color:var(--coral);line-height:1;font-variant-numeric:tabular-nums}
.total-label{font-size:var(--fs-sm);font-weight:700;color:var(--ink);margin-bottom:4px}
.total-tiers{font-size:var(--fs-xs);color:var(--ink-4);line-height:1.7}

/* 笊絶武笊・CONTENT STRATEGY 笊絶武笊・*/
.content-sec{background:var(--cream);padding:var(--sec-gap) 0}
.content-layers{display:flex;flex-direction:column;gap:var(--sp-4);max-width:800px}
.layer{border-radius:var(--r-xl);padding:var(--sp-6);position:relative;overflow:hidden}
.layer-flag{background:var(--surface);border:2px solid var(--coral-pale)}
.layer-seo{background:var(--surface);border:2px solid var(--cream-2)}
.layer-col{background:var(--coral-paler);border:2px solid var(--coral-pale)}
.layer-tag{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--sp-2)}
.layer-title{font-size:var(--fs-lg);font-weight:700;color:var(--ink);margin-bottom:var(--sp-2)}
.layer-desc{font-size:var(--fs-sm);color:var(--ink-3);line-height:1.8}
.layer-meta{display:flex;gap:var(--sp-4);margin-top:var(--sp-3);flex-wrap:wrap}
.layer-meta span{font-size:var(--fs-xs);color:var(--ink-4);display:flex;align-items:center;gap:4px}

/* 笊絶武笊・CORPORATE REPORTS 笊絶武笊・*/
.reports-sec{background:var(--surface);padding:var(--sec-gap) 0}
.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));gap:var(--sp-5)}
.report-card{background:var(--cream);border-radius:var(--r-xl);padding:var(--sp-6);display:flex;flex-direction:column;border:2px solid transparent;transition:border-color .2s,transform .25s var(--ease-out),box-shadow .25s}
@media(hover:hover){.report-card:hover{border-color:var(--coral-pale);transform:translateY(-4px);box-shadow:var(--sh-md)}}
.report-card.recommended{border-color:var(--coral);position:relative}
.report-pop{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--coral);color:#fff;font-size:var(--fs-xs);font-weight:700;padding:3px 12px;border-radius:var(--r-pill);white-space:nowrap}
.report-type{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;color:var(--coral);letter-spacing:.08em;margin-bottom:var(--sp-2)}
.report-name{font-family:var(--f-heading-jp);font-size:var(--fs-xl);font-weight:700;color:var(--ink);margin-bottom:var(--sp-2)}
.report-price{font-family:var(--f-en);font-size:var(--fs-2xl);font-weight:700;color:var(--ink);margin-bottom:var(--sp-1)}
.report-price-note{font-size:var(--fs-xs);color:var(--ink-4);margin-bottom:var(--sp-4)}
.report-features{display:flex;flex-direction:column;gap:var(--sp-2);margin-bottom:var(--sp-5);flex:1}
.report-feat{display:flex;align-items:flex-start;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--ink-2);line-height:1.6}
.report-feat svg{width:16px;height:16px;stroke:var(--success);flex-shrink:0;margin-top:3px;fill:none;stroke-width:2;stroke-linecap:round}
.report-btn{width:100%;text-align:center;justify-content:center}
.report-trust{display:flex;flex-direction:column;gap:var(--sp-2);margin-top:var(--sp-3)}
.trust-badge{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--success);background:rgba(45,134,89,.08);padding:3px 8px;border-radius:var(--r-pill)}

/* 笊絶武笊・SOCIAL 笊絶武笊・*/
.social-sec{background:var(--cream);padding:var(--sp-12) 0}
.social-bar{display:flex;gap:var(--sp-4);flex-wrap:wrap;justify-content:center;align-items:stretch}
.social-card{background:var(--surface);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-5);display:flex;align-items:center;gap:var(--sp-3);font-size:var(--fs-sm);color:var(--ink-2);transition:transform .2s var(--ease-out),box-shadow .2s;cursor:pointer;min-height:44px}
@media(hover:hover){.social-card:hover{transform:translateY(-2px);box-shadow:var(--sh-sm)}}
.social-card svg{width:20px;height:20px;flex-shrink:0}
.social-card strong{font-weight:600}

/* 笊絶武笊・TEAM 笊絶武笊・*/
.team-sec{background:var(--surface);padding:var(--sec-gap) 0}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));gap:var(--sp-4)}
.team-card{background:var(--cream);border-radius:var(--r-xl);padding:var(--sp-6) var(--sp-4);text-align:center;transition:transform .2s var(--ease-out),box-shadow .2s}
@media(hover:hover){.team-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}}
.team-card.chief{background:var(--coral-paler)}
.team-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto var(--sp-3);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 6px 20px oklch(10% .05 25/.15)}


.team-role{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-family:var(--f-en);color:var(--coral);margin-bottom:4px}
.team-nm{font-size:var(--fs-sm);font-weight:700;color:var(--ink);margin-bottom:2px}
.team-nm-en{font-family:var(--f-en);font-size:var(--fs-xs);color:var(--ink-4);margin-bottom:var(--sp-2)}
.team-info{font-size:var(--fs-xs);color:var(--ink-3);line-height:1.6}




/* 笊絶武笊・WHY Askive 笊絶武笊・*/
.why-sec{background:var(--panel-dark);padding:var(--sec-gap) 0}
.why-sec .eyebrow{color:var(--coral-l)}
.why-sec .sec-title{color:#fff}
.why-sec .sec-desc{color:oklch(65% .02 30)}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(300px,100%),1fr));gap:var(--sp-5)}
.why-card{background:var(--panel-dark-2);border-radius:var(--r-xl);padding:var(--sp-6);border:1px solid var(--panel-dark-3);transition:transform .2s var(--ease-out),border-color .2s}
@media(hover:hover){.why-card:hover{transform:translateY(-4px);border-color:oklch(40% .1 25)}}
.why-num{font-family:var(--f-en);font-size:48px;font-weight:800;line-height:1;color:transparent;-webkit-text-stroke:1.5px var(--coral);margin-bottom:var(--sp-4);letter-spacing:-.02em;display:block}
.why-title{font-family:var(--f-heading-jp);font-size:var(--fs-xl);font-weight:700;color:#fff;line-height:1.5;margin-bottom:var(--sp-2)}
.why-body{font-size:var(--fs-sm);color:oklch(60% .02 30);line-height:1.85}

/* 笊絶武笊・AI DASHBOARD 笊絶武笊・*/
.dash-sec{background:var(--panel-dark-2);padding:var(--sec-gap) 0}
.dash-sec .eyebrow{color:var(--coral-l)}
.dash-sec .sec-title{color:#fff}
.dash-sec .sec-desc{color:oklch(65% .02 30)}
.dash-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:var(--sp-8);align-items:start}
.dash-big{text-align:center}
.dash-pct{font-family:var(--f-en);font-size:clamp(56px,8vw,80px);font-weight:700;color:var(--coral);line-height:1;font-variant-numeric:tabular-nums}
.dash-pct-label{font-size:var(--fs-sm);color:oklch(60% .02 30);margin-top:var(--sp-2)}
.dash-delta{font-family:var(--f-en);font-size:var(--fs-sm);font-weight:700;color:var(--success);margin-top:var(--sp-1)}
.dash-bars{display:flex;flex-direction:column;gap:var(--sp-4)}
.dash-bar-row{display:flex;align-items:center;gap:var(--sp-3)}
.dash-bar-name{font-size:var(--fs-sm);color:oklch(75% .02 30);width:100px;flex-shrink:0;font-family:var(--f-en);font-weight:500}
.dash-bar-bg{flex:1;height:8px;background:var(--panel-dark-3);border-radius:var(--r-pill);overflow:hidden}
.dash-bar-fill{height:100%;border-radius:var(--r-pill);background:var(--coral);transition:width .8s var(--ease-out)}
.dash-bar-val{font-family:var(--f-en);font-size:var(--fs-sm);font-weight:600;color:#fff;width:36px;text-align:right;font-variant-numeric:tabular-nums}
.dash-note{font-size:var(--fs-xs);color:oklch(50% .02 30);margin-top:var(--sp-5);line-height:1.7}

/* 笊絶武笊・POLICY 笊絶武笊・*/
.policy-sec{background:var(--cream);padding:var(--sec-gap) 0}
.policy-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(280px,100%),1fr));gap:var(--sp-5)}
.pol-card{background:var(--surface);border-radius:var(--r-xl);padding:var(--sp-6);box-shadow:var(--sh-xs)}
.pol-icon{width:40px;height:40px;background:var(--coral-pale);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-4)}
.pol-icon svg{width:20px;height:20px;stroke:var(--coral);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.pol-title{font-size:var(--fs-base);font-weight:700;color:var(--ink);margin-bottom:var(--sp-1)}
.pol-body{font-size:var(--fs-sm);color:var(--ink-3);line-height:1.85}
.pol-badge{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs);font-weight:700;color:var(--success);background:rgba(45,134,89,.08);padding:4px 10px;border-radius:var(--r-pill);margin-top:var(--sp-3)}

/* 笊絶武笊・PILLAR 笊絶武笊・*/
.pillar-sec{background:var(--surface);padding:var(--sec-gap) 0}
.pillar-card{background:var(--cream);border-radius:var(--r-2xl);padding:var(--sp-8);max-width:800px}
.pillar-title{font-family:var(--f-heading-jp);font-size:var(--fs-2xl);font-weight:700;color:var(--ink);margin-bottom:var(--sp-4);text-wrap:balance}
.pillar-desc{font-size:var(--fs-base);color:var(--ink-3);line-height:1.85;margin-bottom:var(--sp-5)}
.cluster-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));gap:var(--sp-3)}
.cluster-item{background:var(--surface);border-radius:var(--r-md);padding:var(--sp-3) var(--sp-4);font-size:var(--fs-sm);color:var(--ink-2);display:flex;align-items:center;gap:var(--sp-2);border:1px solid var(--cream-2)}
.cluster-item svg{width:14px;height:14px;stroke:var(--coral);flex-shrink:0;fill:none;stroke-width:2}

/* 笊絶武笊・NEWSLETTER 笊絶武笊・*/
.nl-sec{background:var(--coral);padding:var(--sp-16) 0;text-align:center}
.nl-inner{max-width:560px;margin:0 auto;padding:0 var(--sp-6)}
.nl-ey{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;letter-spacing:.12em;color:oklch(92% .05 25);text-transform:uppercase;margin-bottom:var(--sp-4)}
.nl-title{font-family:var(--f-heading-jp);font-size:var(--fs-2xl);font-weight:700;color:#fff;line-height:1.4;margin-bottom:var(--sp-2);text-wrap:balance}
.nl-sub{font-size:var(--fs-base);color:oklch(92% .05 25);margin-bottom:var(--sp-2)}
.nl-hook{font-size:var(--fs-sm);font-weight:700;color:#fff;margin-bottom:var(--sp-6);background:oklch(100% 0 0/.12);display:inline-block;padding:4px 14px;border-radius:var(--r-pill)}
.nl-form{display:flex;gap:var(--sp-2)}
.nl-input{flex:1;padding:14px 20px;border-radius:var(--r-pill);border:none;font-family:var(--f-jp);font-size:var(--fs-base);background:oklch(100% 0 0/.18);color:#fff;transition:background .2s;min-height:48px}
.nl-input::placeholder{color:oklch(92% .05 25)}
.nl-input:focus{outline:none;background:oklch(100% 0 0/.28)}
.nl-btn-sub{background:var(--ink);color:#fff;font-size:var(--fs-sm);font-weight:700;padding:14px 24px;border-radius:var(--r-pill);flex-shrink:0;transition:background .2s,transform .15s;min-height:48px}
@media(hover:hover){.nl-btn-sub:hover{background:var(--ink-2);transform:translateY(-1px)}}
.nl-meta{font-size:var(--fs-xs);color:oklch(88% .04 25);margin-top:var(--sp-4)}
.nl-count{font-family:var(--f-en);font-weight:700}

/* 笊絶武笊・FOOTER 笊絶武笊・*/
footer{background:var(--panel-dark);padding:var(--sp-16) 0 var(--sp-8)}
.ft-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:var(--sp-10);margin-bottom:var(--sp-12)}
.ft-brand .ft-logo{font-family:var(--f-heading-en);font-size:20px;font-weight:700;color:var(--coral-l);margin-bottom:var(--sp-2)}
.ft-brand p{font-size:var(--fs-sm);color:oklch(55% .02 30);line-height:1.8;max-width:260px;margin-bottom:var(--sp-5)}
.ft-social{display:flex;gap:var(--sp-3)}
.soc-btn{width:36px;height:36px;border-radius:var(--r-sm);background:var(--panel-dark-2);display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,transform .15s;min-width:36px;min-height:36px;color:oklch(78% .02 30);text-decoration:none}
@media(hover:hover){.soc-btn:hover{background:var(--coral);color:#fff;transform:translateY(-2px)}}
.soc-btn svg{width:16px;height:16px;fill:currentColor;stroke:none}
.ft-col-title{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-family:var(--f-en);color:oklch(55% .02 30);margin-bottom:var(--sp-4)}
.ft-links{display:flex;flex-direction:column;gap:var(--sp-2)}
.ft-links a{font-size:var(--fs-sm);color:oklch(50% .02 30);transition:color .2s;padding:2px 0;min-height:28px;display:flex;align-items:center}
@media(hover:hover){.ft-links a:hover{color:var(--coral-l)}}
.ft-compliance{display:flex;gap:var(--sp-3);flex-wrap:wrap;padding:var(--sp-5) 0;border-top:1px solid var(--panel-dark-2);margin-bottom:var(--sp-5)}
.comp-badge{font-size:13px;font-weight:600;padding:3px 10px;border-radius:var(--r-pill);border:1px solid var(--panel-dark-3);color:oklch(60% .02 30);display:flex;align-items:center;gap:4px}
.comp-badge svg{width:12px;height:12px;stroke:var(--success);fill:none;stroke-width:2}
.ft-bottom{border-top:1px solid var(--panel-dark-2);padding-top:var(--sp-5);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.ft-copy{font-family:var(--f-en);font-size:var(--fs-xs);color:oklch(40% .02 30)}
.ft-bottom-links{display:flex;gap:var(--sp-5)}
.ft-bottom-links a{font-size:var(--fs-xs);color:oklch(45% .02 30);transition:color .2s}
@media(hover:hover){.ft-bottom-links a:hover{color:var(--coral-l)}}

/* 笊絶武笊・CATEGORIES 笊絶武笊・*/
.cat-sec{padding:var(--sec-gap) 0}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr));gap:clamp(12px,2vw,20px)}
.cat-card{background:var(--surface);border-radius:var(--r-xl);padding:var(--sp-6) var(--sp-4);text-align:center;cursor:pointer;border:2px solid transparent;transition:transform .2s var(--ease-out),box-shadow .2s,border-color .2s}
@media(hover:hover){.cat-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--coral-pale)}}
.cat-pill{display:inline-flex;width:48px;height:48px;border-radius:var(--r-md);align-items:center;justify-content:center;margin:0 auto var(--sp-3);box-shadow:var(--sh-xs)}
.cat-pill svg{width:22px;height:22px;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;fill:none}
.cat-nm{font-size:var(--fs-sm);font-weight:700;color:var(--ink);line-height:1.45}
.cat-count{font-family:var(--f-en);font-size:var(--fs-xs);color:var(--ink-4);margin-top:2px}

/* 笊絶武笊・RESPONSIVE 笊絶武笊・*/
@media(max-width:1024px){
  .ft-top{grid-template-columns:1fr 1fr 1fr;gap:var(--sp-8)}
  .ft-top>:first-child{grid-column:1/-1}
  .dash-layout{grid-template-columns:1fr}
  .dash-big{margin-bottom:var(--sp-4)}
}
@media(max-width:960px){
  .hd-nav,.mega-root{display:none}
  .hamburger{display:flex}
  .hd-search-btn{display:none}
  .btn-nl{font-size:13px;padding:6px 14px;min-height:32px;white-space:nowrap;background:var(--coral);color:#fff;border-color:var(--coral)}
}
@media(max-width:768px){
  .feat-grid{grid-template-columns:1fr}
  .ascore-layout{grid-template-columns:1fr}
  .radar-wrap{position:static;margin-bottom:var(--sp-8)}
  .cmp-selects{grid-template-columns:1fr;gap:var(--sp-3)}
  .vs-badge{display:none}
  .ft-top{grid-template-columns:1fr 1fr;gap:var(--sp-6)}
  .nl-form{flex-direction:column}
}
@media(max-width:480px){
  .ft-top{grid-template-columns:1fr}
  .hero-badges{flex-direction:column;align-items:center}
}

/* 笊絶武笊・ADDICTIVE MICRO-INTERACTIONS 笊絶武笊・*/

/* CTA breathing glow */
@keyframes cta-breathe{0%,100%{box-shadow:0 4px 20px rgba(232,98,72,.3)}50%{box-shadow:0 4px 32px rgba(232,98,72,.5),0 0 60px rgba(232,98,72,.15)}}
.btn-p{animation:cta-breathe 3s ease-in-out infinite}
.btn-p:hover{animation:none}

/* Card shine sweep on hover */
.card-shine{position:relative;overflow:hidden}
.card-shine::after{content:'';position:absolute;top:-50%;left:-60%;width:40%;height:200%;background:linear-gradient(90deg,transparent,oklch(99% .01 60/.12),transparent);transform:rotate(25deg);transition:none;pointer-events:none;opacity:0}
@media(hover:hover){.card-shine:hover::after{opacity:1;animation:shine-sweep .6s ease-out forwards}}
@keyframes shine-sweep{0%{left:-60%}100%{left:120%}}

/* Score bar shimmer */
@keyframes bar-shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.hero-score-fill,.score-bar-fill,.axis-fill{background:linear-gradient(90deg,var(--coral),var(--coral-l),var(--coral));background-size:200% 100%;animation:bar-shimmer 2.5s ease-in-out infinite}

/* Hero card 3D tilt 窶・applied via JS */
.hero-card{transition:transform .15s ease-out,box-shadow .3s;transform-style:preserve-3d;perspective:800px}
.hero-card:hover{box-shadow:0 40px 80px oklch(10% .05 25/.12),0 0 0 1px var(--cream-2)}

/* Enhanced stagger for grid items */
.stagger-grid>*:nth-child(1){transition-delay:.0s}
.stagger-grid>*:nth-child(2){transition-delay:.08s}
.stagger-grid>*:nth-child(3){transition-delay:.16s}
.stagger-grid>*:nth-child(4){transition-delay:.24s}
.stagger-grid>*:nth-child(5){transition-delay:.32s}
.stagger-grid>*:nth-child(6){transition-delay:.4s}

/* Article card hover zoom on thumbnail */
.thumb-h,.thumb-s{transition:transform .4s var(--ease-out)}
@media(hover:hover){
  .art-hero:hover .thumb-h{transform:scale(1.04)}
  .art-sm:hover .thumb-s{transform:scale(1.06)}
}

/* Category card icon bounce */
@media(hover:hover){
  .cat-card:hover .cat-pill{animation:icon-bounce .5s var(--ease-out)}
}
@keyframes icon-bounce{0%{transform:scale(1)}40%{transform:scale(1.2)}70%{transform:scale(.95)}100%{transform:scale(1)}}

/* Stat number pulse on count complete */
@keyframes num-pop{0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}}
.stat-num{animation:num-pop .4s 1.5s both var(--ease-out)}

/* Score chip subtle pulse */
}


/* Smooth section color transitions using pseudo-elements */
.compare-sec{position:relative;overflow:hidden}

/* Why section ambient glow */
.why-sec{position:relative;overflow:hidden}
.why-sec::before{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;border-radius:50%;background:radial-gradient(ellipse,oklch(30% .12 25/.15),transparent 60%);transform:translate(-50%,-50%);pointer-events:none}

/* Newsletter section subtle gradient shift */
@keyframes nl-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.nl-sec{background:linear-gradient(135deg,#E86248,#D4503A,#E86248);background-size:200% 200%;animation:nl-shift 8s ease infinite}

/* Link underline slide-in */
.animated-link{position:relative;display:inline}
.animated-link::after{content:'';position:absolute;bottom:-1px;left:0;width:0;height:1.5px;background:var(--coral);transition:width .3s var(--ease-out)}
@media(hover:hover){.animated-link:hover::after{width:100%}}


/* 笊絶武笊・COMPARE FIXES 笊絶武笊・*/
.score-lbl{font-size:var(--fs-xs);color:var(--ink-3);width:56px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tool-sel{width:100%;padding:14px 44px 14px 16px;border:2px solid var(--cream-2);border-radius:var(--r-lg);font-family:var(--f-jp);font-size:var(--fs-base);color:var(--ink);background:var(--surface);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%236B5E59' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;transition:border-color .2s,box-shadow .2s;min-height:52px;font-weight:500}
.tool-sel:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(232,98,72,.1)}
.tool-sel:hover{border-color:var(--ink-5)}
.cmp-btn{width:100%;background:var(--coral);color:#fff;font-size:var(--fs-base);font-weight:700;padding:16px;border-radius:var(--r-lg);transition:background .2s,transform .15s;margin-bottom:var(--sp-6);min-height:52px;letter-spacing:.01em}
.score-bar-bg{flex:1;height:16px;background:var(--cream-2);border-radius:var(--r-pill);overflow:hidden}
.cmp-tool{border:2px solid var(--cream-2);border-radius:var(--r-xl);padding:var(--sp-6);background:var(--surface);transition:border-color .2s}
.score-val{font-family:var(--f-en);font-size:var(--fs-sm);font-weight:700;width:32px;text-align:right;font-variant-numeric:tabular-nums;color:var(--ink)}
.cmp-tool-name{font-size:var(--fs-xl);font-weight:700}
.score-chip{font-family:var(--f-en);font-size:var(--fs-sm);font-weight:700;background:var(--coral);color:#fff;padding:6px 14px;border-radius:var(--r-pill)}

/* 笊絶武笊・A-SCORE FIXES 笊絶武笊・*/
.axis-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--cream);border:1px solid var(--cream-2)}
.total-score{margin-top:var(--sp-6);padding:var(--sp-6);background:var(--cream);border-radius:var(--r-xl);display:flex;align-items:center;gap:var(--sp-5)}
.total-num{font-family:var(--f-en);font-size:56px;font-weight:700;color:var(--coral);line-height:1;font-variant-numeric:tabular-nums}
.total-label{font-size:var(--fs-lg);font-weight:700;color:var(--ink);margin-bottom:4px}
.total-tier{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-en);font-size:var(--fs-sm);font-weight:700;padding:4px 12px;border-radius:var(--r-pill);margin-top:6px}
.total-tier.excellent{background:rgba(45,134,89,.1);color:var(--success)}
.total-tier.good{background:var(--coral-pale);color:var(--coral)}
.total-tier.fair{background:rgba(201,122,31,.1);color:var(--warning)}
.total-tiers{font-size:var(--fs-xs);color:var(--ink-4);line-height:1.7;margin-top:var(--sp-3)}
.axis-bar{width:100%;height:6px;background:var(--cream-2);border-radius:var(--r-pill);margin-top:8px}

/* 笊絶武笊・RADAR FIXES 笊絶武笊・*/
.radar-wrap{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;position:sticky;top:100px;padding:var(--sp-6)}
.radar-svg{width:100%;max-width:380px;height:auto;overflow:visible}

/* 笊絶武笊・CATEGORY FIXES 笊絶武笊・*/
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(200px,100%),1fr));gap:var(--sp-4)}
.cat-card{background:var(--surface);border-radius:var(--r-xl);padding:var(--sp-6);cursor:pointer;border:2px solid transparent;transition:transform .2s var(--ease-out),box-shadow .2s,border-color .2s;display:flex;align-items:center;gap:var(--sp-4);text-align:left}
.cat-pill{display:inline-flex;width:52px;height:52px;border-radius:var(--r-lg);align-items:center;justify-content:center;flex-shrink:0;background:var(--cream);border:1px solid var(--cream-2)}
.cat-pill svg{width:24px;height:24px;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;fill:none}
.cat-nm{font-size:var(--fs-base);font-weight:700;color:var(--ink);line-height:1.35}
.cat-count{font-family:var(--f-en);font-size:var(--fs-xs);color:var(--ink-4);margin-top:2px}
.cat-info{flex:1}


.team-avatar-initial{font-size:34px;font-weight:700;font-family:var(--f-jp);line-height:1;color:#fff}
.team-avatar-badge{position:absolute;bottom:-4px;right:-4px;background:var(--surface);color:var(--ink);font-family:var(--f-en);font-size:13px;font-weight:700;padding:3px 7px;border-radius:var(--r-pill);box-shadow:var(--sh-sm);letter-spacing:.05em}


/* Compare verdict bar */
.cmp-verdict{display:flex;align-items:center;justify-content:center;gap:var(--sp-3);padding:14px var(--sp-5);background:linear-gradient(135deg,var(--coral-pale),var(--coral-paler));border-radius:var(--r-lg);margin-bottom:var(--sp-6)}
.cmp-verdict-label{font-size:var(--fs-xs);font-weight:600;color:var(--ink-3);letter-spacing:.05em}
.cmp-verdict-winner{font-size:var(--fs-base);font-weight:700;color:var(--coral)}
@media(max-width:600px){.cmp-verdict{flex-direction:column;gap:4px;padding:12px}.cmp-verdict-winner{font-size:var(--fs-sm)}}


.ascore-toolbar{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-7);flex-wrap:wrap;justify-content:center}
.ascore-toolbar-label{font-size:var(--fs-sm);font-weight:600;color:var(--ink-3)}
.ascore-tool-tabs{display:flex;gap:8px;flex-wrap:wrap}
.ascore-tab{padding:8px 16px;border-radius:var(--r-pill);border:none;background:var(--cream);color:var(--ink-3);font-family:var(--f-jp);font-size:var(--fs-sm);font-weight:600;cursor:pointer;transition:all .2s;min-height:36px}
.ascore-tab:hover{border-color:var(--coral);color:var(--coral)}
.ascore-tab.active{background:var(--coral);color:#fff;border-color:var(--coral);box-shadow:0 4px 12px rgba(232,98,72,.25)}
@media(max-width:600px){.ascore-toolbar{flex-direction:column;align-items:flex-start}.ascore-tool-tabs{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:6px}.ascore-tab{flex-shrink:0}}

/* 笊絶武笊・A-SCORE LIVE ENGINE 笊絶武笊・*/
.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#E63946;margin-right:8px;vertical-align:middle;box-shadow:0 0 0 0 rgba(230,57,70,.7);animation:livePulse 1.8s ease-out infinite;position:relative;top:-1px}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(230,57,70,.6)}70%{box-shadow:0 0 0 10px rgba(230,57,70,0)}100%{box-shadow:0 0 0 0 rgba(230,57,70,0)}}

.live-search-wrap{margin-bottom:var(--sp-12);max-width:780px;margin-left:auto;margin-right:auto}
.live-search{display:flex;align-items:center;gap:0;background:var(--surface);border:2px solid var(--cream-2);border-radius:var(--r-pill);padding:6px 6px 6px 24px;box-shadow:0 8px 32px rgba(232,98,72,.08);transition:border-color .2s,box-shadow .2s}
.live-search:focus-within{border-color:var(--coral);box-shadow:0 8px 40px rgba(232,98,72,.18)}
.live-search-icon{color:var(--ink-3);flex-shrink:0}
.live-search-input{flex:1;border:none;outline:none;background:transparent;padding:14px 16px;font-family:var(--f-jp);font-size:var(--fs-base);color:var(--ink-1);min-width:0}
.live-search-input::placeholder{color:var(--ink-4)}
.live-search-input:disabled{opacity:.5}
.live-search-btn{display:inline-flex;align-items:center;gap:8px;background:var(--coral);color:#fff;border:none;border-radius:var(--r-pill);padding:12px 24px;font-family:var(--f-jp);font-size:var(--fs-sm);font-weight:700;cursor:pointer;transition:transform .15s,background .2s;flex-shrink:0;min-height:44px;white-space:nowrap}
.live-search-btn:hover:not(:disabled){background:var(--coral-d);transform:translateY(-1px)}
.live-search-btn:disabled{opacity:.5;cursor:not-allowed}

.live-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:var(--sp-5);justify-content:center}
.live-chips-label{font-size:var(--fs-xs);font-weight:600;color:var(--ink-3);letter-spacing:.05em}
.live-chip{padding:7px 14px;border-radius:var(--r-pill);border:none;background:var(--cream);color:var(--ink-2);font-family:var(--f-jp);font-size:var(--fs-xs);font-weight:600;cursor:pointer;transition:all .2s}
.live-chip:hover:not(:disabled){border-color:var(--coral);color:var(--coral);background:var(--coral-paler)}
.live-chip.active{background:var(--coral);color:#fff;border-color:var(--coral)}
.live-chip.recent{border-style:dashed}
.live-chip:disabled{opacity:.4;cursor:not-allowed}

.live-error{margin-top:var(--sp-4);padding:12px 16px;background:var(--coral-paler);border:1px solid var(--coral-pale);border-radius:var(--r-md);color:var(--danger);font-size:var(--fs-sm);text-align:center}

.live-layout{position:relative;transition:opacity .3s}
.radar-stage{position:relative;display:inline-block}
.radar-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.radar-pulse{position:absolute;width:120px;height:120px;border:2px solid var(--coral);border-radius:50%;opacity:0;animation:radarPulse 1.8s ease-out infinite}
@keyframes radarPulse{0%{transform:scale(.4);opacity:.7}100%{transform:scale(2.2);opacity:0}}

.active-tool-name{font-family:var(--f-heading-jp);font-size:var(--fs-2xl);font-weight:800;color:var(--ink-1);margin-top:var(--sp-5);text-align:center;letter-spacing:-.01em;line-height:1.2}
.loading-tool{display:inline-flex;align-items:center;gap:10px;color:var(--ink-3)}
.dot-flash{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--coral);animation:dotFlash 1s ease-in-out infinite}
@keyframes dotFlash{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}

.phase-label{font-size:var(--fs-xs);color:var(--ink-3);text-align:center;margin-top:var(--sp-3);font-weight:600;letter-spacing:.05em;animation:fadeInPhase .3s ease-out}
@keyframes fadeInPhase{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

.num-shimmer{display:inline-block;color:var(--ink-4);font-family:var(--f-en);letter-spacing:-.04em;animation:dotFlash 1s ease-in-out infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.axis-row.is-loading .axis-nm,.axis-row.is-loading .axis-d,.axis-row.is-loading .axis-abbr{opacity:.5}
.axis-row{transition:opacity .3s}

.live-verdict{transition:all .4s var(--ease-out)}
.live-verdict.is-loading{opacity:.5}
.live-verdict .verdict-body{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}
.verdict-summary{font-size:var(--fs-sm);color:var(--ink-2);line-height:1.7;margin-top:6px;font-weight:500;letter-spacing:.005em}

.verdict-pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3);margin-top:var(--sp-4)}
.verdict-card{padding:var(--sp-4) var(--sp-5);border-radius:var(--r-lg);border:1px solid var(--cream-2);background:var(--surface)}
.verdict-card.pros{border-left:3px solid #2E7D5B}
.verdict-card.cons{border-left:3px solid #C44B3A}
.verdict-card-label{font-family:var(--f-en);font-size:var(--fs-xs);font-weight:700;letter-spacing:.08em;display:flex;align-items:center;gap:6px;margin-bottom:6px}
.verdict-card.pros .verdict-card-label{color:#2E7D5B}
.verdict-card.cons .verdict-card-label{color:#C44B3A}
.verdict-card-body{font-size:var(--fs-sm);color:var(--ink-1);line-height:1.6;font-weight:500}

@media(max-width:768px){
  .live-search{flex-direction:column;border-radius:var(--r-xl);padding:8px;align-items:stretch}
  .live-search-icon{display:none}
  .live-search-input{padding:12px 16px;border-radius:var(--r-lg);background:#FAF7F1}
  .live-search-btn{width:100%;justify-content:center;margin-top:6px}
  .verdict-pros-cons{grid-template-columns:1fr}
  .active-tool-name{font-size:var(--fs-xl)}
}


.social-logo{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}
.social-logo svg{width:18px;height:18px}
.social-logo-x{background:#000}
.social-logo-note{background:#41C9B4}
.soc-btn svg{width:16px;height:16px;fill:currentColor;stroke:none}
.soc-btn{padding:8px}


.cat-desc{font-size:var(--fs-xs);color:var(--ink-3);margin-top:4px;line-height:1.5}
.cat-arrow{font-family:var(--f-en);font-size:18px;color:var(--ink-4);transition:transform .2s,color .2s;flex-shrink:0;align-self:center}
.cat-card:hover{border-color:var(--coral);transform:translateY(-2px);box-shadow:var(--sh-md)}
.cat-card:hover .cat-arrow{color:var(--coral);transform:translateX(4px)}
.cat-card{text-decoration:none;color:inherit}


/* ═══ PAGE LAYOUT (for sub-pages) ═══ */
.page-main{max-width:800px;margin:0 auto;padding:var(--sp-16) var(--sp-6)}
.page-hero{background:var(--surface);padding:var(--sp-16) 0 var(--sp-12);border-bottom:1px solid var(--cream-2)}
.page-hero .w{max-width:800px}
.page-hero-ey{display:inline-flex;align-items:center;gap:var(--sp-2);background:var(--coral-paler);color:var(--coral);font-size:var(--fs-xs);font-weight:700;letter-spacing:.06em;padding:5px 14px;border-radius:var(--r-pill);margin-bottom:var(--sp-4);border:1px solid var(--coral-pale)}
.page-h1{font-size:var(--fs-3xl);font-weight:700;line-height:1.3;color:var(--ink);margin-bottom:var(--sp-4);text-wrap:balance}
.page-desc{font-size:var(--fs-base);color:var(--ink-3);line-height:1.85;max-width:560px}
.page-content{padding:var(--sp-12) 0;max-width:1240px;margin:0 auto;padding-left:var(--sp-6);padding-right:var(--sp-6)}
.prose{max-width:720px}
.prose h2{font-size:var(--fs-2xl);font-weight:700;color:var(--ink);margin:var(--sp-10) 0 var(--sp-4);line-height:1.4}
.prose h3{font-size:var(--fs-xl);font-weight:700;color:var(--ink);margin:var(--sp-8) 0 var(--sp-3)}
.prose p{font-size:var(--fs-base);color:var(--ink-2);line-height:1.9;margin-bottom:var(--sp-4)}
.prose ul,.prose ol{margin:var(--sp-4) 0 var(--sp-4) var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-2)}
.prose li{font-size:var(--fs-base);color:var(--ink-2);line-height:1.8}
.prose a{color:var(--coral);text-decoration:underline;text-underline-offset:3px}
.prose strong{font-weight:700;color:var(--ink)}
.info-box{background:var(--cream);border-left:3px solid var(--coral);border-radius:0 var(--r-md) var(--r-md) 0;padding:var(--sp-4) var(--sp-5);margin:var(--sp-6) 0}
.info-box p{margin:0;font-size:var(--fs-sm);color:var(--ink-2);line-height:1.8}
.table-wrap{overflow-x:auto;margin:var(--sp-6) 0;border-radius:var(--r-lg);border:1px solid var(--cream-2)}
table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
th{background:var(--cream);padding:12px 16px;text-align:left;font-weight:700;color:var(--ink-2);border-bottom:2px solid var(--cream-2)}
td{padding:12px 16px;border-bottom:1px solid var(--cream-2);color:var(--ink-2);line-height:1.6}
tr:last-child td{border-bottom:none}
.tag-list{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin:var(--sp-4) 0}
.tag{background:var(--cream);color:var(--ink-3);font-size:var(--fs-xs);padding:4px 10px;border-radius:var(--r-pill);border:1px solid var(--cream-2)}


/* ═══════════════════════════════════════
   MOBILE-FIRST RESPONSIVE HARDENING (v3.1)
   - 横スクロール完全防止
   - タッチターゲット最低48px
   - iOS Safari 100vh問題対応(dvh)
   - フォントサイズ最適化(iOS拡大防止)
═══════════════════════════════════════ */

/* 横スクロール完全防止 */
html,body{overflow-x:hidden;max-width:100vw}
*{box-sizing:border-box}
img,video,iframe{max-width:100%;height:auto}

/* iOS Safari 100vh対策 */
.hero,.hero-v5,.fullscreen{min-height:100vh;min-height:100dvh}

/* タッチターゲット最低48px(WCAG 2.2 AAA) */
@media(max-width:768px){
  button,a.btn,a.btn-p,a.btn-s,a.btn-nl,.cta,.live-search-btn,.cmp-btn,
  .live-chip,.search-chip,.tag-pill,.tab-btn{min-height:48px;min-width:48px;padding:14px 18px}
  .hd-actions .theme-toggle{min-height:28px;min-width:28px;padding:0}
  .hd-actions .btn-nl{min-height:28px;min-width:auto;padding:5px 10px;font-size:13px}
  input,textarea,select{min-height:48px;font-size:16px!important;padding:12px 14px}
  .hd-nav a{min-height:48px}
  .hamburger{min-width:48px;min-height:48px}
  .mob-overlay a{min-height:52px;font-size:18px}
}

/* スマホでの基本余白調整 */
@media(max-width:768px){
  .w{padding-left:16px;padding-right:16px}
  section{padding:48px 0}
  .sec-hd{margin-bottom:32px}
  .sec-title{font-size:clamp(24px,6vw,32px);line-height:1.3}
  .sec-desc{font-size:15px;line-height:1.65}
  .hero-title{font-size:clamp(28px,8vw,40px);line-height:1.2}
  .hero-sub-v5{font-size:15px;line-height:1.6}
}

/* スマホでのカード/グリッド調整 */
@media(max-width:480px){
  .feat-grid,.cat-grid,.art-grid,.cmp-grid,.team-grid,.why-grid,.report-grid,
  .feat-grid-v2,.type-grid,.scene-grid,.tier-grid,.ai-grid,.process-grid,.promise-grid,.mini-grid{
    grid-template-columns:1fr!important;gap:16px
  }
  .ascore-layout,.live-layout{grid-template-columns:1fr!important;gap:20px}
  .compare-widget,.cmp-table-v2 table{font-size:13px}
  .cards-3,.cards-2{grid-template-columns:1fr!important}
  .card,.card-shine,.feat-card,.cat-card,.art-sm,.team-card,.why-card,.report-card{padding:20px}
  .mega-cta{padding:32px 20px}
  .mega-cta h2{font-size:24px;line-height:1.3}
  .mega-cta p{font-size:14px}
  .page-hero-v2{padding:40px 16px}
  .page-hero-v2 h1{font-size:clamp(26px,7vw,36px)}
  .hero-stats{flex-wrap:wrap;gap:12px;justify-content:center}
  .hero-stat .num{font-size:28px}
  .pull-quote{padding:24px 20px;font-size:16px}
  .editor-profile{padding:24px 20px;flex-direction:column;text-align:center}
  .editor-profile .avatar-lg{margin:0 auto}
  .ft-top{grid-template-columns:1fr!important;gap:32px}
  .ft-bottom{flex-direction:column;gap:8px;text-align:center}
}

/* スマホで邪魔になりがちな要素 */
@media(max-width:768px){
  .hero-badges{display:none}
  .stats-bar{padding:24px 0;font-size:13px}
  .stats-bar .stat-num{font-size:22px}
  .floating-cta,.scroll-hint{display:none}
}

/* スマホでの比較ウィジェット最適化 */
@media(max-width:768px){
  .cmp-selects{grid-template-columns:1fr!important;gap:12px}
  .vs-badge{display:none}
  .cmp-tool{padding:14px}
  .compare-result{flex-direction:column;gap:16px}
  .axis-label,.axis-name{font-size:13px}
}

/* スマホでフォーム最適化 */
@media(max-width:768px){
  .live-search{flex-direction:column;gap:12px;padding:12px}
  .live-search-input{width:100%;border-radius:12px}
  .live-search-btn{width:100%;border-radius:12px;justify-content:center}
  .nl-form{flex-direction:column;gap:8px}
  .nl-input,.nl-btn-sub{width:100%}
}

/* セーフエリア対応(iPhone X以降のノッチ/ホームバー) */
@supports(padding:max(0px)){
  body{
    padding-left:env(safe-area-inset-left);
    padding-right:env(safe-area-inset-right);
  }
  .site-hd{padding-top:env(safe-area-inset-top,0px)}
  footer{padding-bottom:max(24px,env(safe-area-inset-bottom))}
}

/* リンクのフォーカスリング(キーボード操作対応) */
:focus-visible{outline:3px solid var(--coral);outline-offset:2px;border-radius:4px}
.btn-p:focus-visible,.btn-s:focus-visible{outline-offset:4px}

/* スクリーンリーダー専用 */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* スキップリンク強化 */
.skip-link{position:absolute;left:-9999px;top:8px;background:var(--coral);color:#fff;padding:12px 20px;border-radius:8px;text-decoration:none;font-weight:600;z-index:9999}
.skip-link:focus{left:8px}


/* ─────────────── COMPARE PRO/CON CHIPS (v3.2) ─────────────── */
.cmp-pro-con{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.cmp-pro,.cmp-con{font-size:13px;line-height:1.5;padding:8px 10px;border-radius:8px;display:flex;align-items:flex-start;gap:6px}
.cmp-pro{background:rgba(45,134,89,0.08);color:#1F5A3D;border:1px solid rgba(45,134,89,0.18)}
.cmp-con{background:rgba(232,98,72,0.06);color:#9A3920;border:1px solid rgba(232,98,72,0.18)}
.cmp-pro span,.cmp-con span{font-weight:700;flex:0 0 auto}
@media(max-width:600px){.cmp-pro-con{grid-template-columns:1fr}}


/* ─────────────── CONTACT FORM (v3.2) ─────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start;max-width:1000px}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:32px}}
.cf-label{display:block;font-size:14px;font-weight:700;color:var(--ink-2);margin-bottom:6px}
.cf-input{width:100%;padding:12px 16px;border:2px solid var(--cream-2);border-radius:10px;font-family:var(--f-jp);font-size:15px;color:var(--ink);background:var(--surface);outline:none;transition:border-color .2s;appearance:none}
.cf-input:focus{border-color:var(--coral)}
select.cf-input{background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="none" stroke="%232A1E1A" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" d="M2 4l4 4 4-4"/></svg>');background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}


/* ─────────────── ARTICLE LAYOUT (v3.2) ─────────────── */
.article-wrap{padding:60px 0 80px;background:var(--surface)}
.article-wrap .breadcrumb{margin-bottom:12px;font-size:13px;color:var(--ink-3)}
.art-h1{font-size:clamp(28px,5vw,40px);line-height:1.3;font-weight:800;color:var(--ink);margin:8px 0 16px;letter-spacing:-.01em}
.art-meta-bar{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;color:var(--ink-3);margin-bottom:24px}
.art-meta-bar span{display:inline-flex;align-items:center}
.art-lead{font-size:17px;line-height:1.85;color:var(--ink-2);margin:24px 0 32px;padding:18px 22px;background:var(--cream);border-left:3px solid var(--coral);border-radius:0 8px 8px 0}
.article-wrap h2{font-size:24px;font-weight:800;color:var(--ink);margin:48px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--cream-2);letter-spacing:-.005em}
.article-wrap h3{font-size:19px;font-weight:700;color:var(--ink);margin:28px 0 12px}
.article-wrap p{font-size:16px;line-height:1.85;color:var(--ink-2);margin:0 0 16px}
.article-wrap ul,.article-wrap ol{font-size:16px;line-height:1.85;color:var(--ink-2);margin:0 0 16px;padding-left:24px}
.article-wrap li{margin-bottom:6px}
.article-wrap table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px}
.article-wrap th,.article-wrap td{padding:10px 12px;border-bottom:1px solid var(--cream-2);text-align:left;vertical-align:top}
.article-wrap th{background:var(--cream);font-weight:700;color:var(--ink)}
.article-wrap td.num,.article-wrap th.num{text-align:right;font-variant-numeric:tabular-nums}

.affiliate-disclosure{font-size:13px;line-height:1.6;color:var(--ink-4,#A09890);background:transparent;border:none;border-top:1px solid var(--cream-2,#EDE5DB);padding:10px 0 0;margin:8px 0 20px}
.affiliate-disclosure strong{color:var(--ink-3,#8A8078);font-weight:600}
.affiliate-disclosure a{color:var(--ink-3,#8A8078);text-decoration:underline;text-underline-offset:2px}

.cmp-summary-card{border:2px solid var(--cream-2);border-radius:16px;padding:24px;margin:16px 0 32px;background:linear-gradient(135deg,var(--cream) 0%,var(--surface) 100%)}
.cmp-summary-tot{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;text-align:center}
.cmp-summary-tot-block{padding:8px}
.cmp-summary-name{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:6px}
.cmp-summary-score{font-size:48px;font-weight:800;color:var(--coral);line-height:1;font-variant-numeric:tabular-nums}
.cmp-summary-score span{font-size:18px;color:var(--ink-3);font-weight:600;margin-left:4px}
.cmp-summary-tier{font-size:13px;font-weight:600;color:var(--ink-2);margin-top:6px}
.cmp-vs{font-size:24px;font-weight:800;color:var(--ink-3);letter-spacing:.05em}
.cmp-summary-verdict{margin:16px 0 0;padding-top:16px;border-top:1px solid var(--cream-2);font-size:15px;color:var(--ink-2)}
@media(max-width:600px){.cmp-summary-tot{grid-template-columns:1fr;gap:16px}.cmp-vs{font-size:18px}}

/* ── 比較記事の各軸スコア比較テーブル：ヘッダーとセルを揃える ── */
.article-wrap .cmp-axis-table{table-layout:fixed}
.article-wrap .cmp-axis-table th,
.article-wrap .cmp-axis-table td{text-align:center;vertical-align:middle}
.article-wrap .cmp-axis-table th:first-child,
.article-wrap .cmp-axis-table td:first-child{text-align:left;width:30%;color:var(--ink-2);font-weight:600}
.article-wrap .cmp-axis-table th:last-child,
.article-wrap .cmp-axis-table td:last-child{width:18%}
.article-wrap .cmp-axis-table th:not(:first-child):not(:last-child),
.article-wrap .cmp-axis-table td:not(:first-child):not(:last-child){width:26%}
.article-wrap .cmp-axis-table td.num{text-align:center;font-variant-numeric:tabular-nums;font-family:var(--f-en);font-size:16px}
.cmp-axis-table .num{font-weight:700;color:var(--ink)}
@media(max-width:540px){
  .article-wrap .cmp-axis-table th:first-child,
  .article-wrap .cmp-axis-table td:first-child{width:34%}
  .article-wrap .cmp-axis-table td.num{font-size:15px}
}

/* ── 6軸詳細評価セクション（採点根拠カード） ── */
.cmp-axis-detail{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:12px 0 24px}
@media(max-width:680px){.cmp-axis-detail{grid-template-columns:1fr}}
.cmp-axis-detail-block{padding:14px 16px;border-radius:var(--r-md);background:var(--cream);border-left:3px solid var(--cream-2)}
.cmp-axis-detail-block.cmp-axis-strong{background:rgba(45,134,89,.06);border-left-color:#2D8659}
.cmp-axis-detail-block.cmp-axis-mid{background:var(--cream);border-left-color:var(--ink-4)}
.cmp-axis-detail-block.cmp-axis-weak{background:rgba(232,98,72,.06);border-left-color:var(--coral)}
.cmp-axis-detail-hd{font-size:13px;margin-bottom:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cmp-axis-detail-hd strong{color:var(--ink)}
.cmp-axis-detail-tag{display:inline-block;font-size:13px;font-weight:800;letter-spacing:.05em;padding:2px 8px;border-radius:99px;background:var(--ink-4);color:#fff;font-family:var(--f-en)}
.cmp-axis-strong .cmp-axis-detail-tag{background:#2D8659}
.cmp-axis-weak .cmp-axis-detail-tag{background:var(--coral)}
.cmp-axis-detail-num{font-family:var(--f-en);font-weight:800;color:var(--coral);margin-left:auto}
.cmp-axis-strong .cmp-axis-detail-num{color:#2D8659}
.cmp-axis-detail-block p{margin:0;font-size:13px;line-height:1.75;color:var(--ink-2)}

/* ── 料金体系比較表 ── */
.article-wrap .cmp-pricing-table{table-layout:fixed}
.article-wrap .cmp-pricing-table th:first-child,
.article-wrap .cmp-pricing-table td:first-child{width:25%;text-align:left;font-weight:600;color:var(--ink-2)}
.article-wrap .cmp-pricing-table th,
.article-wrap .cmp-pricing-table td{text-align:center;vertical-align:middle}
.article-wrap .cmp-pricing-table td.num{font-family:var(--f-en);font-weight:700}

/* ── 注意点リスト ── */
.cmp-quick-check{margin:16px 0;padding:14px 16px;background:rgba(45,134,89,.06);border-left:4px solid #2D8659;border-radius:var(--r-md)}.cmp-quick-check p{font-size:13px;font-weight:700;color:#1F5A3D;margin-bottom:8px}.cmp-quick-check ul{margin:0;padding-left:18px}.cmp-quick-check li{font-size:14px;line-height:1.9;margin-bottom:2px}.cmp-cautions{margin:12px 0;padding:0;list-style:none}
.cmp-cautions li{position:relative;padding:12px 14px 12px 36px;background:var(--cream-l);border-left:3px solid var(--coral);border-radius:var(--r-md);margin-bottom:10px;font-size:14px;line-height:1.8}
.cmp-cautions li::before{content:"!";position:absolute;left:10px;top:11px;width:18px;height:18px;background:var(--coral);color:#fff;border-radius:50%;text-align:center;font-weight:800;font-size:13px;line-height:18px;font-family:var(--f-en)}
.cmp-cautions li strong{color:var(--ink);font-weight:800}

/* ── 判断フロー（順序付きリスト・整形版） ── */
.cmp-decision-flow{counter-reset:flow;list-style:none;padding:0;margin:12px 0}
.cmp-decision-flow li{counter-increment:flow;position:relative;padding:14px 16px 14px 56px;background:var(--surface);border:1px solid var(--cream-2);border-radius:var(--r-md);margin-bottom:10px;font-size:14px;line-height:1.8;color:var(--ink-2)}
.cmp-decision-flow li::before{content:counter(flow);position:absolute;left:14px;top:13px;width:30px;height:30px;background:var(--coral);color:#fff;border-radius:50%;text-align:center;font-weight:800;font-size:14px;line-height:30px;font-family:var(--f-en)}
.cmp-decision-flow li strong{color:var(--ink);font-weight:800}
.art-win{display:inline-block;font-size:13px;font-weight:700;padding:3px 8px;border-radius:99px;background:rgba(45,134,89,.15);color:#1F5A3D}
.art-win-b{display:inline-block;font-size:13px;font-weight:700;padding:3px 8px;border-radius:99px;background:rgba(232,98,72,.15);color:#9A3920}
.art-tie{display:inline-block;font-size:13px;font-weight:600;padding:3px 8px;border-radius:99px;background:var(--cream-2);color:var(--ink-3)}

/* ── 比較記事 v3：比較方法テーブル（読者向け軸名と評価内容） ── */
.article-wrap .cmp-method-table{table-layout:fixed;margin:12px 0}
.article-wrap .cmp-method-table th{text-align:left;background:var(--cream);font-size:13px;letter-spacing:.02em;color:var(--ink-2);padding:10px 14px}
.article-wrap .cmp-method-table td{text-align:left;font-size:14px;line-height:1.75;padding:10px 14px;vertical-align:top}
.article-wrap .cmp-method-table td strong{color:var(--ink);font-weight:700}
.article-wrap .cmp-method-table tbody tr:nth-child(even){background:rgba(245,232,224,.4)}

/* ── 比較記事 v3：軸内サブヘッダ（観点／評価／判定） ── */
.cmp-subhead{font-size:13px;font-weight:800;color:var(--coral);margin:14px 0 6px;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.cmp-subhead::before{content:"";display:inline-block;width:14px;height:2px;background:var(--coral);border-radius:2px}

/* ── 比較記事 v3：観点表（軸ごとの内訳） ── */
.article-wrap .cmp-viewpoint-table{table-layout:fixed;margin:6px 0 12px;font-size:13px}
.article-wrap .cmp-viewpoint-table th{text-align:center;background:var(--cream);font-size:13px;letter-spacing:.02em;color:var(--ink-2);padding:8px 10px;font-weight:700}
.article-wrap .cmp-viewpoint-table th:first-child{text-align:left}
.article-wrap .cmp-viewpoint-table td{text-align:center;font-size:13px;line-height:1.7;padding:8px 10px;vertical-align:middle}
.article-wrap .cmp-viewpoint-table td:first-child{text-align:left;font-weight:600;color:var(--ink-2);background:rgba(245,232,224,.3)}
.article-wrap .cmp-viewpoint-table tbody tr:hover td{background:rgba(232,98,72,.04)}
.article-wrap .cmp-viewpoint-table tbody tr:hover td:first-child{background:rgba(245,232,224,.55)}

/* ── 比較記事 v3：評価ブロック（既存 cmp-axis-detail のリネーム版） ── */
.cmp-axis-eval{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:6px 0 12px}
@media(max-width:680px){.cmp-axis-eval{grid-template-columns:1fr}}
.cmp-axis-eval-block{padding:14px 16px;border-radius:var(--r-md);background:var(--cream);border-left:3px solid var(--cream-2)}
.cmp-axis-eval-block.cmp-axis-strong{background:rgba(45,134,89,.06);border-left-color:#2D8659}
.cmp-axis-eval-block.cmp-axis-mid{background:var(--cream);border-left-color:var(--ink-4)}
.cmp-axis-eval-block.cmp-axis-weak{background:rgba(232,98,72,.06);border-left-color:var(--coral)}
.cmp-axis-eval-hd{font-size:13px;margin-bottom:6px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cmp-axis-eval-hd strong{color:var(--ink)}
.cmp-axis-eval-tag{display:inline-block;font-size:13px;font-weight:800;letter-spacing:.05em;padding:2px 8px;border-radius:99px;background:var(--ink-4);color:#fff;font-family:var(--f-en)}
.cmp-axis-eval-block.cmp-axis-strong .cmp-axis-eval-tag{background:#2D8659}
.cmp-axis-eval-block.cmp-axis-weak .cmp-axis-eval-tag{background:var(--coral)}
.cmp-axis-eval-num{font-family:var(--f-en);font-weight:800;color:var(--coral);margin-left:auto}
.cmp-axis-eval-block.cmp-axis-strong .cmp-axis-eval-num{color:#2D8659}
.cmp-axis-eval-block p{margin:0;font-size:13px;line-height:1.75;color:var(--ink-2)}

/* ── 比較記事 v3：軸の判定行 ── */
.cmp-axis-verdict{margin:8px 0 28px;padding:10px 14px;background:linear-gradient(90deg, rgba(232,98,72,.08), rgba(232,98,72,0));border-left:3px solid var(--coral);border-radius:var(--r-md);font-size:14px;line-height:1.75;color:var(--ink-2)}
.cmp-axis-verdict strong{color:var(--ink);font-weight:800}

/* ── 比較記事 v3：個別の強み・弱み（A / B 別カード） ── */
.cmp-tool-pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:12px 0 24px}
@media(max-width:680px){.cmp-tool-pros-cons{grid-template-columns:1fr}}
.cmp-pros, .cmp-cons{padding:14px 16px;border-radius:var(--r-md)}
.cmp-pros{background:rgba(45,134,89,.06);border-left:3px solid #2D8659}
.cmp-cons{background:rgba(232,98,72,.06);border-left:3px solid var(--coral)}
.cmp-pros h4, .cmp-cons h4{margin:0 0 8px;font-size:13px;font-weight:800;letter-spacing:.04em}
.cmp-pros h4{color:#1F5A3D}
.cmp-cons h4{color:#9A3920}
.cmp-pros h4::before{content:"+ ";font-family:var(--f-en);font-weight:900}
.cmp-cons h4::before{content:"- ";font-family:var(--f-en);font-weight:900}
.cmp-pros ul, .cmp-cons ul{margin:0;padding-left:20px}
.cmp-pros li, .cmp-cons li{font-size:13px;line-height:1.75;color:var(--ink-2);margin-bottom:6px}

/* ── 比較記事 v3：A-SCORE 総合表の総合行を強調 ── */
.article-wrap .cmp-axis-table tr.cmp-axis-total td{background:rgba(232,98,72,.08);border-top:2px solid var(--coral);font-size:15px}
.article-wrap .cmp-axis-table tr.cmp-axis-total td.num{font-size:17px;color:var(--coral)}

.cta-card{display:flex;flex-direction:column;gap:12px;align-items:flex-start;background:var(--surface);border:2px solid var(--coral);border-radius:14px;padding:20px;margin:20px 0}
.cta-text strong{font-size:17px;color:var(--ink);display:block;margin-bottom:4px}
.cta-text p{font-size:14px;color:var(--ink-3);margin:0;line-height:1.7}

.art-axes{display:flex;flex-direction:column;gap:8px;margin:16px 0;padding:16px;background:var(--cream);border-radius:10px}
.art-axis-row{display:grid;grid-template-columns:140px 1fr 48px;gap:12px;align-items:center;font-size:14px}
.art-axis-label{color:var(--ink-2);font-weight:600}
.art-axis-bar{height:10px;background:var(--cream-2);border-radius:99px;overflow:hidden}
.art-axis-fill{height:100%;background:linear-gradient(90deg,var(--coral),var(--coral-l));border-radius:99px;transition:width .8s ease}
.art-axis-num{font-weight:800;color:var(--coral);text-align:right;font-variant-numeric:tabular-nums}
@media(max-width:540px){.art-axis-row{grid-template-columns:100px 1fr 40px;font-size:13px}}

.art-steps{counter-reset:step;list-style:none;padding-left:0}
.art-steps>li{counter-increment:step;position:relative;padding-left:48px;margin-bottom:18px;font-size:16px;line-height:1.85}
.art-steps>li::before{content:counter(step);position:absolute;left:0;top:0;width:32px;height:32px;border-radius:50%;background:var(--coral);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px}

.art-update{font-size:13px;color:var(--ink-4);margin-top:48px;padding-top:16px;border-top:1px solid var(--cream-2)}

/* ─────────────── HEADER (legacy .hd-* DELETED — site-hd 系に統一) ─────────────── */
/* 古い .hd / .hd-inner / .hd-nav の重複定義は 2026-04-29 に削除しました。
   site-hd 系（行114以降）が単一の真実です。 */

.ft{background:var(--ink);color:rgba(255,255,255,.85);padding:48px 0 32px;margin-top:48px}
.ft-inner{max-width:1200px;margin:0 auto;padding:0 24px}
.ft-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.ft-cols a{display:block;color:rgba(255,255,255,.7);text-decoration:none;font-size:14px;padding:4px 0;transition:color .2s}
.ft-cols a:hover{color:#fff}
@media(max-width:768px){.ft-cols{grid-template-columns:1fr 1fr;gap:24px}}


/* ═══════════════════════════════════════
   FEATURED TOOLS SECTION（編集長ピック・商品棚プレビュー）
   ai-pricing.html と同じデザイン言語
═══════════════════════════════════════ */
.featured-sec{background:var(--cream-l);padding:var(--sec-gap) 0;border-top:1px solid var(--cream-2)}
.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(320px,100%),1fr));gap:16px;margin-top:var(--sp-6)}
.feat-card-w{display:flex}
.feat-card{background:var(--surface);border:1.5px solid var(--cream-2);border-radius:var(--r-xl);padding:18px;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;transition:all .25s var(--ease-out);text-decoration:none;color:inherit;width:100%;cursor:pointer}
.feat-card:hover{border-color:var(--coral);transform:translateY(-4px);box-shadow:0 12px 28px rgba(232,98,72,.12)}

/* リボン */
.feat-ribbon{position:absolute;top:0;right:14px;padding:5px 11px 7px;font-size:13px;font-weight:800;color:#fff;letter-spacing:.04em;font-family:var(--f-jp);border-radius:0 0 8px 8px;z-index:1}
.feat-ribbon-pick{background:linear-gradient(180deg,#F4D03F,#E8A440)}
.feat-ribbon-cost{background:linear-gradient(180deg,#2D8659,#1F6B45)}
.feat-ribbon-jp{background:linear-gradient(180deg,#2563EB,#1E40AF)}
.feat-ribbon-sme{background:linear-gradient(180deg,#7C3AED,#5B21B6)}

/* カードヘッダ */
.feat-card-hd{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;padding-right:80px;min-height:44px}
.feat-card-hd-l{flex:1;min-width:0}
.feat-card-name{font-size:16px;font-weight:800;color:var(--ink);line-height:1.3;letter-spacing:-.01em;margin:0}
.feat-card-vendor{font-size:13px;color:var(--ink-4);margin-top:3px}
.feat-card-sep{margin:0 4px;color:var(--cream-3)}

/* スコア */
.feat-card-score{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}
.feat-score-num{font-family:var(--f-en);font-size:26px;font-weight:800;color:var(--coral);line-height:1;letter-spacing:-.02em}
.feat-score-num small{font-size:13px;color:var(--ink-4);font-weight:600;font-family:var(--f-jp);margin-left:1px}
.feat-score-tier{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4)}
.feat-tier-excellent{color:#2D8659}
.feat-tier-good{color:#0EA5E9}
.feat-tier-fair{color:#C97A1F}

/* 6軸ミニバー */
.feat-axes{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;padding:10px 0;border-top:1px dashed var(--cream-2);border-bottom:1px dashed var(--cream-2)}
.feat-axis{display:flex;flex-direction:column;align-items:center;gap:4px;font-family:var(--f-jp)}
.feat-axis-bar{width:80%;height:64px;background:var(--cream);border-radius:4px;position:relative;overflow:hidden}
.feat-axis-fill{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,var(--coral-l),var(--coral));border-radius:4px}
.feat-axis-num{font-family:var(--f-en);font-size:14px;font-weight:800;color:var(--ink);line-height:1}
.feat-axis-lbl{font-size:13px;color:var(--ink-2);font-weight:700}
@media(max-width:768px){.feat-axis-bar{height:48px}.feat-axis-num{font-size:13px}.feat-axis-lbl{font-size:13px}}

/* 強み行 */
.feat-strength{font-size:13px;color:var(--ink-2);line-height:1.65;display:flex;gap:5px;align-items:flex-start}
.feat-strength-ic{flex-shrink:0;color:#2D8659;font-weight:800;font-size:13px}
.feat-strength-tx{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* best_for タグ */
.feat-bestfor{display:flex;flex-wrap:wrap;gap:4px}
.feat-bf-chip{font-size:13px;font-weight:600;color:var(--coral);background:var(--coral-paler);padding:3px 8px;border-radius:99px;font-family:var(--f-jp)}

/* 価格・日本語 */
.feat-meta-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--ink-3);margin-top:2px}
.feat-price{font-family:var(--f-en);font-size:13px;font-weight:800;color:var(--ink-2)}
.feat-jp-stars{color:#F4D03F;letter-spacing:1px;font-size:13px}

/* CTA */
.feat-cta-row{display:flex;justify-content:flex-end;margin-top:auto;padding-top:8px;border-top:1px dashed var(--cream-2)}
.feat-cta-detail{font-size:13px;font-weight:700;color:var(--coral);font-family:var(--f-jp)}

/* セクション末尾CTA */
.featured-cta{display:flex;gap:10px;justify-content:center;margin-top:var(--sp-8);flex-wrap:wrap}

@media(max-width:640px){
  .featured-grid{grid-template-columns:1fr}
}

/* ガイド記事 — 判断ポイントボックス */
.guide-point{background:linear-gradient(135deg,#FFF8F5 0%,#FFF0EB 100%);border-left:4px solid var(--coral);border-radius:0 12px 12px 0;padding:16px 20px;margin:24px 0}
.guide-point__label{font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);margin:0 0 8px}
.guide-point__body{font-size:15px;line-height:1.85;color:var(--ink-2);margin:0}
.guide-point ul{margin:8px 0 0;padding-left:20px}
.guide-point li{margin-bottom:6px;font-size:14px;color:var(--ink-2);line-height:1.75}
.guide-point li::marker{color:var(--coral)}

/* ガイド記事 — 比較ハイライト行 */
.guide-highlight{display:inline-block;background:linear-gradient(transparent 58%,rgba(232,98,72,.18) 58%);font-weight:700;color:#C84B30;padding:0 3px}

/* ガイド記事 — h3 装飾 */
.guide-body h3{font-size:18px;font-weight:700;color:var(--ink);margin:28px 0 12px;padding-left:12px;border-left:3px solid var(--coral)}

/* ガイド記事 FAQ */
.guide-faq{margin:0;padding:0}
.guide-faq dt{font-weight:700;color:var(--ink);margin:18px 0 4px;padding:10px 14px;background:var(--cream);border-left:3px solid var(--coral);border-radius:0 var(--r) var(--r) 0;font-size:14px;line-height:1.55}
.guide-faq dd{margin:0 0 0 0;padding:10px 14px 16px;font-size:13px;color:var(--ink-2);line-height:1.8;border-bottom:1px solid var(--cream-2)}

/* ガイド記事 注意・警告ブロック */
.art-caution{background:var(--coral-paler);border:1.5px solid var(--coral-pale);border-radius:var(--r-xl);padding:16px 20px;margin:20px 0}
.art-caution p{margin:0;font-size:13px;color:var(--ink-2);line-height:1.8}

/* ガイド記事 導入前チェックリスト */
.guide-checklist{margin:0;padding:0 0 0 22px;list-style:none}
.guide-checklist li{position:relative;padding:6px 0 6px 28px;font-size:13px;color:var(--ink-2);line-height:1.75;border-bottom:1px dashed var(--cream-2)}
.guide-checklist li::before{content:"☐";position:absolute;left:0;top:6px;font-size:16px;color:var(--coral)}

/* ═══════════════════════════════════════════════════════════
   MONTHLY REPORT v2 — 日本人向け読みやすさ最適化
   ・白い「紙」カードで本文を浮かす
   ・右サイドsticky TOC + モバイル折りたたみ
   ・本文最大720px・行間2.0
   ・黄色マーカー風ハイライト
   ═══════════════════════════════════════════════════════════ */

/* ── ページ全体レイアウト（紙＋TOCの2カラム） ── */
.mr-page{background:var(--cream);padding:40px 0 80px}
.mr-layout{display:grid;grid-template-columns:1fr;gap:24px;max-width:1080px;margin:0 auto;padding:0 16px;align-items:start}
@media(min-width:1024px){
  .mr-layout{grid-template-columns:minmax(0,720px) 240px;gap:40px;padding:0 24px}
}

/* ── 紙カード（本文を白く浮かせる） ── */
.mr-paper{background:var(--surface);border-radius:16px;padding:36px 36px 48px;box-shadow:0 1px 3px rgba(30,25,22,.06),0 8px 24px rgba(30,25,22,.06);min-width:0}
@media(max-width:640px){.mr-paper{padding:24px 20px 32px;border-radius:12px}}

/* ── パンくず ── */
.mr-paper .breadcrumb{margin:0 0 16px;font-size:13px;color:var(--ink-4)}

/* ── ヘッダ（号数・タイトル・著者） ── */
.mr-issue{display:inline-flex;align-items:center;gap:8px;font-family:var(--f-en);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);background:var(--cream);padding:5px 14px;border-radius:20px;margin-bottom:12px}
.mr-issue-dot{width:7px;height:7px;border-radius:50%;background:var(--coral);display:inline-block}

.mr-paper h1.art-h1{font-size:clamp(24px,3.5vw,32px);line-height:1.45;letter-spacing:-.01em;font-weight:800;color:var(--ink);margin:4px 0 16px;text-wrap:balance}

.mr-byline{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--ink-3);padding-bottom:24px;border-bottom:1px solid var(--cream-2);margin-bottom:28px}
.mr-byline .ai-tag{margin-left:0}
.mr-byline-sep{color:var(--ink-5)}

/* ── キービジュアル（ヘッドライン） ── */
.mr-kv{background:linear-gradient(135deg,#0F172A 0%,#1E293B 100%);color:#F8FAFC;border-radius:14px;padding:28px 28px 24px;margin:0 0 36px}
.mr-kv-label{font-family:var(--f-en);font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:8px}
.mr-kv-head{font-size:22px;font-weight:800;line-height:1.55;letter-spacing:-.01em;margin:0 0 14px;text-wrap:balance}
.mr-kv-lead{font-size:14px;line-height:2;color:rgba(255,255,255,.82)}
@media(max-width:640px){
  .mr-kv{padding:20px 18px 18px;border-radius:12px}
  .mr-kv-head{font-size:18px;line-height:1.5}
  .mr-kv-lead{font-size:13px;line-height:1.9}
}

/* ── セクション ── */
.mr-section{margin:48px 0 0;scroll-margin-top:80px}
.mr-section:first-of-type{margin-top:0}
.mr-section-tag{display:inline-block;font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:4px 10px;border-radius:4px;margin-bottom:10px}
.mr-section-tag--trend{background:#EFF6FF;color:#1D4ED8}
.mr-section-tag--rank{background:#F0FDF4;color:#15803D}
.mr-section-tag--money{background:rgba(180,83,9,.08);color:#B45309}
.mr-section-tag--sme{background:#FEF2F2;color:#B91C1C}
.mr-section-tag--editor{background:#F5F3FF;color:#6D28D9}
.mr-section-tag--verdict{background:rgba(154,52,18,.08);color:#9A3412}

.mr-paper h2{font-size:22px;font-weight:800;color:var(--ink);line-height:1.5;letter-spacing:-.005em;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid var(--cream-2);position:relative}
.mr-paper h2::before{content:"";position:absolute;left:0;bottom:-2px;width:48px;height:2px;background:var(--coral)}

/* ── 本文 ── */
.mr-paper p{font-size:16px;line-height:2;color:var(--ink-2);margin:0 0 20px;text-align:left;font-feature-settings:"palt" 1}
.mr-paper p:last-child{margin-bottom:0}
.mr-paper ul,.mr-paper ol{font-size:16px;line-height:2;color:var(--ink-2);margin:0 0 20px;padding-left:24px}
.mr-paper li{margin-bottom:8px}
.mr-paper strong{font-weight:700;color:#C84B30;background:linear-gradient(transparent 62%,rgba(232,98,72,.15) 62%);padding:0 2px}

/* ── 黄色マーカー風ハイライト（白背景の本文用） ── */
.mr-paper mark,.mr-paper .mr-mark{background:linear-gradient(transparent 60%,#FFE56F 60%);color:var(--ink);padding:0 2px;font-weight:700;border-radius:0}
/* 暗い背景上のマーカー（キービジュアル等）— コーラル下線で可読性確保 */
.mr-kv mark,.mr-kv .mr-mark{background:linear-gradient(transparent 62%,rgba(232,98,72,.85) 62%,rgba(232,98,72,.85) 92%,transparent 92%);color:#FFFFFF;padding:0 4px;font-weight:700;border-radius:0}

/* ── トレンドカード（テキストファーストの読みやすさ重視） ── */
.mr-trend-card{background:#FCFAF7;border:1px solid var(--cream-2);border-left:4px solid var(--coral);border-radius:8px;padding:22px 24px;margin:16px 0}
.mr-trend-card:hover{box-shadow:0 4px 12px rgba(30,25,22,.06)}
.mr-trend-head{display:flex;align-items:baseline;gap:14px;margin-bottom:10px}
.mr-trend-num{font-family:var(--f-en);font-size:24px;font-weight:900;color:var(--coral);line-height:1;flex-shrink:0}
.mr-trend-title{font-size:17px;font-weight:800;color:var(--ink);line-height:1.55;text-wrap:balance}
.mr-trend-body{font-size:15px;color:var(--ink-2);line-height:2;font-feature-settings:"palt" 1}
.mr-trend-body strong{color:var(--ink);font-weight:700}
.mr-trend-source{display:inline-block;font-size:13px;color:var(--ink-4);margin-top:12px;padding:3px 10px;background:var(--cream);border-radius:99px}

/* ── 判断ポイント（暖色系の囲み） ── */
.mr-verdict{background:linear-gradient(135deg,#FFFBF5 0%,#FFF7ED 100%);border:1.5px solid #FCD9A6;border-radius:12px;padding:24px 26px;margin:24px 0}
.mr-verdict-title{font-size:16px;font-weight:800;color:#9A3412;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.mr-verdict-title::before{content:"⚑";font-size:18px}
.mr-verdict-body{font-size:15px;color:var(--ink-2);line-height:2}
.mr-verdict-body strong{color:#7C2D12}

/* ── 編集長コラム ── */
.mr-editor{border-top:2px solid var(--cream-2);padding-top:32px;margin-top:48px}
.mr-editor-card{background:#FCFAF7;border-radius:12px;padding:24px;margin-top:16px}
.mr-editor-name{font-size:15px;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:10px;margin-bottom:14px}
.mr-editor-name::before{content:"✎";color:var(--coral);font-size:18px}
.mr-editor-body{font-size:15px;color:var(--ink-2);line-height:2}
.mr-editor-body p{margin:0 0 14px;font-size:15px;line-height:2}
.mr-editor-body p:last-child{margin-bottom:0}
.mr-editor-next{margin-top:18px;padding:14px 16px;background:var(--white);border-left:3px solid var(--coral);border-radius:0 6px 6px 0;font-size:13px;color:var(--ink-3);line-height:1.85}
.mr-editor-next strong{color:var(--ink-2)}

/* ── ランキングテーブル（順位/ツール/A-SCORE） ── */
.mr-paper table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px;table-layout:fixed}
.mr-paper th{background:var(--cream);font-weight:700;color:var(--ink);padding:12px 14px;text-align:left;font-size:13px;letter-spacing:.02em;vertical-align:middle}
.mr-paper td{padding:14px;border-bottom:1px solid var(--cream-2);text-align:left;vertical-align:middle;line-height:1.7}
.mr-paper tr:hover td{background:var(--surface)}
.mr-paper td.num,.mr-paper th.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--f-en);vertical-align:middle}

/* ランキング表の列幅 */
.mr-rank-table th:nth-child(1),.mr-rank-table td:nth-child(1){width:48px;text-align:center}
.mr-rank-table th:nth-child(3),.mr-rank-table td:nth-child(3){width:80px;text-align:right}
.mr-rank-table td:nth-child(2){line-height:1.6}
.mr-rank-name{font-size:15px;font-weight:800;color:var(--ink);display:block;margin-bottom:4px}
.mr-rank-name a{color:var(--ink);text-decoration:none;border-bottom:1px dashed var(--cream-2)}
.mr-rank-name a:hover{border-bottom-color:var(--coral);color:var(--coral)}
.mr-rank-tags{font-size:13px;color:var(--ink-3);line-height:1.6}
.mr-rank-tag{display:inline-block;background:var(--cream);color:var(--ink-3);font-size:13px;padding:2px 8px;border-radius:99px;margin-right:4px;margin-top:2px;font-weight:600}
.mr-rank-score{font-size:22px;font-weight:900;color:var(--coral);line-height:1;font-family:var(--f-en);display:inline-block}
.mr-rank-score-total{font-size:13px;color:var(--ink-4);font-weight:600;margin-left:2px}
@media(max-width:540px){
  .mr-rank-name{font-size:14px}
  .mr-rank-score{font-size:18px}
  .mr-paper th,.mr-paper td{padding:10px 8px}
}

/* ── CTAブロック ── */
.mr-cta-block{background:var(--cream);border-radius:14px;padding:28px 24px;margin:40px 0 0;text-align:center}
.mr-cta-block p{font-size:14px;color:var(--ink-2);line-height:1.85;margin:0 0 16px}
.mr-cta-links{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.mr-cta-links a{display:inline-block;padding:10px 22px;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s}
.mr-cta-links a:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(30,25,22,.1)}
.mr-cta-primary{background:var(--coral);color:#FFFFFF}
.mr-cta-secondary{background:var(--surface);color:var(--coral);border:1.5px solid var(--coral)}

.mr-paper .art-update{font-size:13px;color:var(--ink-4);margin-top:32px;padding-top:16px;border-top:1px solid var(--cream-2);line-height:1.7}

/* ═══════════════════════════════════════════════════════════
   TOC（目次）— Sticky右サイド + モバイル折りたたみ
   ═══════════════════════════════════════════════════════════ */
.mr-toc{display:none}
@media(min-width:1024px){
  .mr-toc{display:block;position:sticky;top:88px;align-self:start;max-height:calc(100vh - 120px);overflow-y:auto;font-size:13px;padding:20px 16px;background:rgba(255,255,255,.6);backdrop-filter:blur(8px);border:1px solid var(--cream-2);border-radius:12px}
}
.mr-toc-title{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--cream-2)}
.mr-toc-list{list-style:none;padding:0;margin:0}
.mr-toc-list li{margin:0;padding:0}
.mr-toc-list a{display:block;padding:8px 10px;color:var(--ink-3);font-size:13px;line-height:1.55;text-decoration:none;border-radius:6px;border-left:2px solid transparent;transition:all .15s}
.mr-toc-list a:hover{background:var(--cream);color:var(--ink-2)}
/* 目次の現在地：コーラルは収益CTA専用のため、ニュートラルなスレート系で区別 */
.mr-toc-list a.active{background:rgba(30,25,22,.06);color:var(--ink);border-left-color:#334155;font-weight:600}

/* ── モバイル用：折りたたみTOC ── */
.mr-toc-mobile{display:block;margin:0 0 24px;background:#FCFAF7;border:1px solid var(--cream-2);border-radius:10px;overflow:hidden}
@media(min-width:1024px){.mr-toc-mobile{display:none}}
.mr-toc-mobile summary{cursor:pointer;padding:14px 18px;font-size:14px;font-weight:700;color:var(--ink-2);display:flex;align-items:center;gap:8px;list-style:none;user-select:none}
.mr-toc-mobile summary::-webkit-details-marker{display:none}
.mr-toc-mobile summary::before{content:"▶";font-size:13px;color:var(--coral);transition:transform .2s}
.mr-toc-mobile[open] summary::before{transform:rotate(90deg)}
.mr-toc-mobile .mr-toc-list{padding:4px 12px 12px}
.mr-toc-mobile .mr-toc-list a{padding:8px 12px;font-size:13px}

/* ═══════════════════════════════════════════════════════════
   Back to Top ボタン
   ═══════════════════════════════════════════════════════════ */
.mr-totop{position:fixed;bottom:24px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--coral);color:#FFFFFF;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 16px rgba(232,98,72,.35);cursor:pointer;opacity:0;transform:translateY(8px);transition:opacity .25s,transform .25s;z-index:50;border:none}
.mr-totop.visible{opacity:1;transform:translateY(0)}
.mr-totop:hover{background:var(--coral-h)}
@media(max-width:640px){.mr-totop{bottom:16px;right:16px;width:40px;height:40px}}

/* ═══════════════════════════════════════════════════════════
   読了プログレスバー（スリム）
   ═══════════════════════════════════════════════════════════ */
.mr-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--coral),var(--coral-l));width:0%;z-index:301;transition:width .1s linear}

/* ═══════════════════════════════════════════════════════════
   Article Credits（記事末「制作チーム」ボックス）
   ─ 顔アイコン付きで監修・編集・リサーチを表示
   ═══════════════════════════════════════════════════════════ */
.ar-credits{margin:48px 0 16px;background:linear-gradient(135deg,#FCFAF7 0%,#F8F4EE 100%);border:1px solid var(--cream-2);border-radius:14px;padding:28px 28px 24px;position:relative;overflow:hidden}
.ar-credits::before{content:"";position:absolute;top:0;left:0;width:60px;height:3px;background:linear-gradient(90deg,var(--coral),var(--coral-l))}
.ar-credits-ey{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--coral);margin-bottom:6px}
.ar-credits-h{font-size:17px;font-weight:800;color:var(--ink);margin:0 0 4px;letter-spacing:-.005em}
.ar-credits-desc{font-size:13px;color:var(--ink-3);line-height:1.7;margin:0 0 22px}
.ar-credits-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin:0;padding:0;list-style:none}
.ar-credit{display:flex;align-items:flex-start;gap:14px;padding:14px;background:var(--surface);border:1px solid var(--cream-2);border-radius:12px;transition:transform .2s,box-shadow .2s,border-color .2s}
.ar-credit:hover{transform:translateY(-2px);border-color:var(--coral-pale);box-shadow:0 6px 16px rgba(30,25,22,.06)}
.ar-credit-avatar{flex-shrink:0;width:52px;height:52px;border-radius:50%;background:var(--cream);overflow:hidden;display:flex;align-items:center;justify-content:center;border:2px solid #FFFFFF;box-shadow:0 2px 6px rgba(30,25,22,.08)}
.ar-credit-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.ar-credit-body{min-width:0;flex:1}
.ar-credit-role{display:inline-block;font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--coral);background:var(--coral-paler);padding:2px 8px;border-radius:4px;margin-bottom:4px}
.ar-credit-name{font-size:14px;font-weight:700;color:var(--ink);line-height:1.4;margin:0 0 4px;letter-spacing:-.005em}
.ar-credit-name-en{font-family:var(--f-en);font-size:13px;color:var(--ink-4);font-weight:600;margin-left:6px;letter-spacing:.02em}
.ar-credit-bio{font-size:13px;color:var(--ink-3);line-height:1.65;margin:0}
.ar-credits-meta{margin-top:18px;padding-top:14px;border-top:1px dashed var(--cream-2);font-size:13px;color:var(--ink-4);line-height:1.7;display:flex;flex-wrap:wrap;gap:6px 14px}
.ar-credits-meta strong{color:var(--ink-2);font-weight:600}
@media(max-width:640px){
  .ar-credits{padding:22px 18px 18px;border-radius:12px;margin:36px 0 12px}
  .ar-credits-h{font-size:16px}
  .ar-credits-list{grid-template-columns:1fr;gap:12px}
  .ar-credit{padding:12px}
  .ar-credit-avatar{width:46px;height:46px}
}

/* ═══════════════════════════════════════════════════════════
   PageTOC（共通：長尺ページ用 sticky 目次 / 進捗バー / Back-to-top）
   ─ askive-pagetoc.js が動的に DOM 注入。クラス名は pg-* で統一。
   ═══════════════════════════════════════════════════════════ */
/* 上部プログレスバー */
.pg-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--coral),var(--coral-l));width:0%;z-index:301;transition:width .12s linear;pointer-events:none}

/* デスクトップ右側 sticky TOC */
.pg-toc{display:none;position:fixed;top:96px;right:max(20px,calc((100vw - 1180px) / 2 - 224px));width:200px;max-height:calc(100vh - 140px);overflow-y:auto;background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(10px);-webkit-backdrop-filter:saturate(180%) blur(10px);border:1px solid var(--cream-2);border-radius:12px;padding:14px 12px 12px;font-family:var(--f-jp);box-shadow:0 6px 24px rgba(30,25,22,.06);z-index:90;font-size:13px}
@media(min-width:1440px){.pg-toc{display:block}}
.pg-toc-head{display:flex;flex-direction:column;gap:2px;padding:0 4px 10px;margin-bottom:6px;border-bottom:1px dashed var(--cream-2)}
.pg-toc-ey{font-family:var(--f-en);font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4)}
.pg-toc-count{font-size:13px;color:var(--ink-3);font-weight:600}
.pg-toc-list{list-style:none;margin:0;padding:0}
.pg-toc-list li{margin:0;padding:0}
.pg-toc-list a{display:block;padding:7px 10px;font-size:13px;line-height:1.5;color:var(--ink-3);text-decoration:none;border-radius:6px;border-left:2px solid transparent;transition:background .15s,color .15s,border-color .15s;letter-spacing:-.005em;word-break:break-word}
.pg-toc-list a:hover{background:var(--cream);color:var(--ink-2)}
.pg-toc-list a.active{background:rgba(30,25,22,.06);color:var(--ink);border-left-color:#334155;font-weight:600}

/* スクロールバー（控えめ） */
.pg-toc::-webkit-scrollbar{width:6px}
.pg-toc::-webkit-scrollbar-thumb{background:rgba(30,25,22,.16);border-radius:3px}
.pg-toc::-webkit-scrollbar-track{background:transparent}

/* Back-to-top（PCで右上目次の下、モバイルでは右下） */
.pg-totop{position:fixed;bottom:24px;right:24px;width:46px;height:46px;border-radius:50%;background:var(--ink);color:#FFFFFF;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;opacity:0;transform:translateY(8px) scale(.95);transition:opacity .25s,transform .25s,background .15s;z-index:60;box-shadow:0 6px 18px rgba(30,25,22,.22)}
.pg-totop.visible{opacity:1;transform:translateY(0) scale(1)}
.pg-totop:hover{background:var(--coral)}
.pg-totop svg{width:20px;height:20px}
@media(max-width:640px){.pg-totop{bottom:74px;right:16px;width:42px;height:42px}.pg-totop svg{width:18px;height:18px}}

/* モバイル用フローティング「目次」FABボタン */
.pg-fab{display:none;position:fixed;bottom:18px;right:16px;height:44px;padding:0 16px 0 14px;border:none;border-radius:24px;background:var(--coral);color:#FFFFFF;align-items:center;gap:8px;font-size:13px;font-weight:700;font-family:var(--f-jp);letter-spacing:.02em;cursor:pointer;opacity:0;transform:translateY(8px);transition:opacity .25s,transform .25s,background .15s;z-index:65;box-shadow:0 6px 18px rgba(232,98,72,.4)}
.pg-fab.visible{opacity:1;transform:translateY(0)}
.pg-fab:hover{background:var(--coral-h)}
.pg-fab svg{width:18px;height:18px;flex-shrink:0}
@media(max-width:1439px){.pg-fab{display:flex}}

/* モバイル：目次シート（ボトムシート） */
.pg-sheet{position:fixed;inset:0;z-index:300;visibility:hidden;pointer-events:none}
.pg-sheet.open{visibility:visible;pointer-events:auto}
.pg-sheet-bd{position:absolute;inset:0;background:rgba(15,10,8,.5);opacity:0;transition:opacity .25s}
.pg-sheet.open .pg-sheet-bd{opacity:1}
.pg-sheet-panel{position:absolute;left:0;right:0;bottom:0;background:var(--surface);border-radius:18px 18px 0 0;max-height:75vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s var(--ease-out);box-shadow:0 -8px 30px rgba(15,10,8,.15)}
.pg-sheet.open .pg-sheet-panel{transform:translateY(0)}
.pg-sheet-panel::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:38px;height:4px;border-radius:2px;background:var(--cream-3,#E8E2D9)}
.pg-sheet-hd{padding:22px 18px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--cream-2)}
.pg-sheet-title{font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.01em;margin-top:2px}
.pg-sheet-close{width:36px;height:36px;border-radius:50%;border:none;background:var(--cream);color:var(--ink-2);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s}
.pg-sheet-close:hover{background:var(--coral-paler);color:var(--coral)}
.pg-sheet-close svg{width:18px;height:18px}
.pg-sheet-list{padding:8px 12px 28px;overflow-y:auto;flex:1}
.pg-sheet-list a{padding:12px 14px;font-size:14px;line-height:1.55;border-radius:8px;border-left:3px solid transparent}
.pg-sheet-list a.active{background:rgba(30,25,22,.07);color:var(--ink);border-left-color:#334155;font-weight:600}
body.pg-sheet-locked{overflow:hidden}

/* PCで pg-toc 表示時、フッターやコンテンツとの干渉を避けるための main 余白
   は使わない（fixed なので元のレイアウトに影響なし）。ただし極端な広い画面で
   読みやすさのため main の max-width に達していない場合は何もしない。 */

/* ═══════════════════════════════════════
   DARK MODE — WCAG AA Compliant Palette
   Contrast ratios measured against --surface (#1A1614)
═══════════════════════════════════════ */
[data-theme="dark"] {
  /* Brand — coral lightened for 4.5:1+ on dark bg */
  --coral: #F08070; --coral-h: #E86248; --coral-l: #F7A090;
  --coral-pale: #3D2520; --coral-paler: #2A1A17;
  /* Neutral backgrounds */
  --cream: #1A1614; --cream-2: #262220; --cream-3: #332D2A;
  /* Ink — 15.2:1 / 10.3:1 / 6.2:1 / 4.5:1 */
  --ink: #F2EDE8; --ink-2: #D4CBC2; --ink-3: #B0A49E; --ink-4: #8A7D76; --ink-5: #5A504A;
  /* Surfaces */
  --surface: #1A1614; --surface-2: #211D1B; --surface-3: #2A2420;
  /* Panel dark — FIXED, never inverted */
  --panel-dark: #181412; --panel-dark-2: #241E1B; --panel-dark-3: #2E2622;
  /* Backward compat: --dark stays fixed too */
  --dark: #181412; --dark-2: #241E1B; --dark-3: #2E2622;
  /* Semantic — all 4.5:1+ on dark bg */
  --success: #52C987; --warning: #F5C842; --info: #6CB4F8; --danger: #F87A7A;
  /* Article types */
  --type-compare: #F08070; --type-deep: #6CB4F8; --type-monthly: #52C987; --type-news: #A78BFA;
  /* Shadows — deeper for dark surfaces */
  --sh-xs: 0 1px 2px rgba(0,0,0,0.3);
  --sh-sm: 0 2px 8px rgba(0,0,0,0.4), 0 1px 3px rgba(0,0,0,0.2);
  --sh-md: 0 8px 24px rgba(0,0,0,0.5), 0 3px 6px rgba(0,0,0,0.3);
  --sh-lg: 0 16px 48px rgba(0,0,0,0.6), 0 6px 16px rgba(0,0,0,0.4);
  color-scheme: dark;
}

/* ── Base body ── */
[data-theme="dark"] body { background: var(--cream); color: var(--ink); }
[data-theme="dark"] img { opacity: .92; }

/* ── Header ── */
[data-theme="dark"] .site-hd { background: oklch(12% .01 60 / .94); }

/* ── Badges ── */
[data-theme="dark"] .badge-compare { background: rgba(240,128,106,.15); }
[data-theme="dark"] .badge-deep { background: rgba(108,180,248,.15); }
[data-theme="dark"] .badge-monthly { background: rgba(82,201,135,.15); }
[data-theme="dark"] .badge-news { background: rgba(167,139,250,.15); }
[data-theme="dark"] .badge-new { background: var(--coral); }

/* ── Mega menu dropdown ── */
[data-theme="dark"] .mega-drop-inner { background: var(--surface-2); border-color: var(--cream-3); box-shadow: 0 20px 48px rgba(0,0,0,.4); }
[data-theme="dark"] .mega-link { color: var(--ink-2); }
[data-theme="dark"] .mega-link:hover { color: var(--coral); background: var(--cream-2); }
[data-theme="dark"] .mega-col-h { color: var(--ink-4); border-color: var(--cream-2); }

/* ── Search card ── */
[data-theme="dark"] .hd-search-modal { background: rgba(0,0,0,.6); }
[data-theme="dark"] .hd-search-card { background: var(--surface-2); box-shadow: 0 24px 48px rgba(0,0,0,.4); }
[data-theme="dark"] .hd-search-card input { background: var(--cream); color: var(--ink); border-color: var(--cream-3); }
[data-theme="dark"] .hd-search-card .hd-search-hint kbd { background: var(--cream-2); border-color: var(--cream-3); color: var(--ink-3); }

/* ── Mobile overlay ── */
[data-theme="dark"] .mob-overlay { background: var(--surface); }
[data-theme="dark"] .mob-overlay a { color: var(--ink-2); border-color: var(--cream-2); }
[data-theme="dark"] .mob-acc summary { color: var(--ink); }
[data-theme="dark"] .mob-acc-links a { color: var(--ink-2); }
[data-theme="dark"] .mob-overlay-search input { background: var(--cream-2); color: var(--ink); border-color: var(--cream-3); }

/* ── Hero section ── */
[data-theme="dark"] .hero { background: var(--surface); }
[data-theme="dark"] .hero::before { background: radial-gradient(ellipse,oklch(25% .08 25/.25),transparent 60%); }
[data-theme="dark"] .hero::after { background: radial-gradient(ellipse,oklch(20% .04 80/.2),transparent 60%); }
[data-theme="dark"] .hero-card { background: var(--surface-2); border-color: var(--cream-2); box-shadow: var(--sh-lg); }

/* ── Stats bar ── */
[data-theme="dark"] .stats-bar { background: var(--surface-2); border-color: var(--cream-2); }

/* ── Search section ── */
[data-theme="dark"] .search-sec { background: var(--surface); }
[data-theme="dark"] .search-box { background: var(--cream-2); border-color: var(--cream-3); }
[data-theme="dark"] .search-box:focus-within { background: var(--surface-2); border-color: var(--coral); }
[data-theme="dark"] .search-kbd { background: var(--cream-2); border-color: var(--cream-3); }
[data-theme="dark"] .search-chip { background: var(--cream-2); border-color: var(--cream-3); color: var(--ink-3); }
[data-theme="dark"] .search-suggests { background: var(--surface-2); border-color: var(--cream-2); }

/* ── Persona cards ── */
[data-theme="dark"] .persona-card { background: var(--surface-2); }

/* ── Compare section ── */
[data-theme="dark"] .compare-sec { background: var(--surface); }
[data-theme="dark"] .cmp-card { background: var(--cream-2); }
[data-theme="dark"] .cmp-tool { background: var(--surface-2); border-color: var(--cream-2); }
[data-theme="dark"] .cmp-comment { background: var(--cream-2); }
[data-theme="dark"] .cmp-verdict-bar { background: var(--cream-2); color: var(--ink); }
[data-theme="dark"] .cmp-verdict { background: var(--cream-2); }

/* ── Mini compare cards ── */
[data-theme="dark"] .cmp-mini-card { background: var(--surface-2); border-color: var(--cream-2); }
[data-theme="dark"] .cmp-mini-procon { background: var(--cream-2); }
[data-theme="dark"] .cmp-mini-link { background: var(--surface-2); }
[data-theme="dark"] .cmp-deep-cta { background: var(--cream-2); border-color: var(--cream-3); }

/* ── Article cards ── */
[data-theme="dark"] .art-hero,
[data-theme="dark"] .art-sm { background: var(--surface-2); }
[data-theme="dark"] .np-feature { background: var(--surface-2); border-color: var(--cream-2); }
[data-theme="dark"] .np-shoulder-card { background: var(--surface-2); border-color: var(--cream-2); }
[data-theme="dark"] .np-card { background: var(--surface-2); border-color: var(--cream-2); }

/* ── A-SCORE section ── */
[data-theme="dark"] .ascore-sec { background: var(--surface); }
[data-theme="dark"] .total-score { background: var(--cream-2); }

/* ── Content strategy ── */
[data-theme="dark"] .layer-flag,
[data-theme="dark"] .layer-seo { background: var(--surface-2); }
[data-theme="dark"] .layer-col { background: var(--coral-paler); }

/* ── Reports section ── */
[data-theme="dark"] .reports-sec { background: var(--surface); }
[data-theme="dark"] .report-card { background: var(--cream-2); }

/* ── Social section ── */
[data-theme="dark"] .social-card { background: var(--surface-2); }

/* ── Team section ── */
[data-theme="dark"] .team-sec { background: var(--surface); }
[data-theme="dark"] .team-card { background: var(--cream-2); }
[data-theme="dark"] .team-card.chief { background: var(--coral-paler); }
[data-theme="dark"] .team-avatar-badge { background: var(--surface-2); color: var(--ink); }

/* ── Policy section ── */
[data-theme="dark"] .pol-card { background: var(--surface-2); }
[data-theme="dark"] .pol-icon { background: var(--coral-paler); }

/* ── Pillar section ── */
[data-theme="dark"] .pillar-sec { background: var(--surface); }
[data-theme="dark"] .pillar-card { background: var(--cream-2); }
[data-theme="dark"] .cluster-item { background: var(--surface-2); border-color: var(--cream-2); }

/* ── Plus teaser ── */
[data-theme="dark"] .plus-teaser-card { background: var(--surface-2); border-color: var(--coral); }
[data-theme="dark"] .plus-teaser-right-cta { background: var(--cream-2); color: var(--coral); }

/* ── Newsletter messages ── */
[data-theme="dark"] .nl-msg { background: var(--surface-2); box-shadow: 0 6px 18px rgba(0,0,0,.3); }
[data-theme="dark"] .nl-msg span:last-child { color: var(--ink); }
[data-theme="dark"] .nl-msg-error span:last-child { color: var(--danger); }
[data-theme="dark"] .nl-done-card,
[data-theme="dark"] .nl-done-card--on-orange { background: var(--surface-2); box-shadow: 0 12px 32px rgba(0,0,0,.3); }
[data-theme="dark"] .nl-done-actions a { background: var(--cream-2); color: var(--ink); }
[data-theme="dark"] .nl-done-actions a:hover { background: var(--cream-3); }

/* ── Categories ── */
[data-theme="dark"] .cat-card { background: var(--surface-2); }
[data-theme="dark"] .cat-pill { background: var(--cream-2); border-color: var(--cream-3); }
[data-theme="dark"] .cat-count { background: var(--cream-2); border-color: var(--cream-3); }

/* ── Quick Start ── */
[data-theme="dark"] .qs-card { background: var(--surface-2); border-color: var(--cream-2); }
[data-theme="dark"] .qs-icon { background: var(--coral-paler); }

/* ── Editor's Pick ── */
[data-theme="dark"] .epick { background: linear-gradient(135deg,var(--panel-dark),var(--panel-dark-2)); }

/* ── Featured tools ── */
[data-theme="dark"] .feat-card { background: var(--surface-2); border-color: var(--cream-2); }
[data-theme="dark"] .feat-axis-bar { background: var(--cream-2); }

/* ── A-SCORE Live ── */
[data-theme="dark"] .live-search { background: var(--surface-2); border-color: var(--cream-2); }
[data-theme="dark"] .live-search:focus-within { border-color: var(--coral); }
[data-theme="dark"] .live-chip { background: var(--surface-2); border-color: var(--cream-2); color: var(--ink-3); }
[data-theme="dark"] .live-chip:hover:not(:disabled) { background: var(--coral-paler); }
[data-theme="dark"] .live-chip.active { background: var(--coral); color: #fff; }
[data-theme="dark"] .live-error { background: rgba(248,122,122,.1); border-color: rgba(248,122,122,.3); color: var(--danger); }
[data-theme="dark"] .verdict-card { background: var(--surface-2); border-color: var(--cream-2); }

/* ── Subpage cards (compare.html, guide.html, etc.) ── */
[data-theme="dark"] .card { background: var(--surface-2); }

/* ── Generic inline-style fallback (last resort) ── */
[data-theme="dark"] [style*="background:#fff"],
[data-theme="dark"] [style*="background: #fff"],
[data-theme="dark"] [style*="background:#FFF"],
[data-theme="dark"] [style*="background:white"] { background: var(--surface-2) !important; }

/* ── Hero text contrast ── */
[data-theme="dark"] .hero-sub-v5 { color: var(--ink-2); }
[data-theme="dark"] .hero-card-tool-cat { color: var(--ink-3); }
[data-theme="dark"] .hero-card-price { color: var(--ink-3); }
[data-theme="dark"] .hero-chip-label { color: var(--ink-3); }
[data-theme="dark"] .hero-score-label { color: var(--ink); }
[data-theme="dark"] .hero-score-num { color: var(--ink); }
[data-theme="dark"] .hero-ey-v5 { color: var(--coral); }

/* ── Page TOC ── */
[data-theme="dark"] .pg-toc { background: rgba(26,22,20,.92); border-color: var(--cream-2); backdrop-filter: saturate(180%) blur(10px); }
[data-theme="dark"] .pg-toc-ey { color: var(--ink-3); }
[data-theme="dark"] .pg-toc-count { color: var(--ink-2); }
[data-theme="dark"] .pg-toc-head { border-color: var(--cream-2); }
[data-theme="dark"] .pg-toc-list a { color: var(--ink-2); }
[data-theme="dark"] .pg-toc-list a:hover { background: var(--cream-2); color: var(--ink); }
[data-theme="dark"] .pg-toc-list a.active { background: var(--cream-2); color: var(--ink); border-left-color: var(--coral); }
[data-theme="dark"] .pg-toc::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); }

/* ── Article TOC (mr-toc / 比較・ガイド記事) ── */
[data-theme="dark"] .mr-toc { background: rgba(26,22,20,.85); border-color: var(--cream-2); }
[data-theme="dark"] .mr-toc-title { color: var(--ink-3); border-color: var(--cream-2); }
[data-theme="dark"] .mr-toc-list a { color: var(--ink-2); }
[data-theme="dark"] .mr-toc-list a:hover { background: var(--cream-2); color: var(--ink); }
[data-theme="dark"] .mr-toc-list a.active { background: var(--cream-2); color: var(--ink); border-left-color: var(--coral); }
[data-theme="dark"] .mr-toc::-webkit-scrollbar-thumb { background: rgba(255,255,255,.2); }
[data-theme="dark"] .mr-toc-mobile { background: var(--surface); border-color: var(--cream-2); }
[data-theme="dark"] .mr-toc-mobile summary { color: var(--ink-2); }

/* ── Dark mode toggle ── */
.theme-toggle {
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--cream-2); border: 1px solid var(--cream-3);
  cursor: pointer; transition: background .2s, transform .15s;
  flex-shrink: 0;
}
.theme-toggle:hover { transform: scale(1.08); }
.theme-toggle svg { width: 18px; height: 18px; stroke: var(--ink-3); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
[data-theme="dark"] .theme-toggle svg { stroke: var(--coral-l); }
@media(max-width:768px){
  .theme-toggle{width:28px;height:28px}
  .theme-toggle svg{width:14px;height:14px}
}

/* ═══════════════════════════════════════
   OS PREFERENCE FALLBACK
   Mirrors [data-theme="dark"] for users who
   haven't explicitly toggled. Complete sync.
═══════════════════════════════════════ */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --coral: #F08070; --coral-h: #E86248; --coral-l: #F7A090;
    --coral-pale: #3D2520; --coral-paler: #2A1A17;
    --cream: #1A1614; --cream-2: #262220; --cream-3: #332D2A;
    --ink: #F2EDE8; --ink-2: #D4CBC2; --ink-3: #B0A49E; --ink-4: #8A7D76; --ink-5: #5A504A;
    --surface: #1A1614; --surface-2: #211D1B; --surface-3: #2A2420;
    --panel-dark: #181412; --panel-dark-2: #241E1B; --panel-dark-3: #2E2622;
    --dark: #181412; --dark-2: #241E1B; --dark-3: #2E2622;
    --success: #52C987; --warning: #F5C842; --info: #6CB4F8; --danger: #F87A7A;
    --type-compare: #F08070; --type-deep: #6CB4F8; --type-monthly: #52C987; --type-news: #A78BFA;
    --sh-xs: 0 1px 2px rgba(0,0,0,0.3);
    --sh-sm: 0 2px 8px rgba(0,0,0,0.4), 0 1px 3px rgba(0,0,0,0.2);
    --sh-md: 0 8px 24px rgba(0,0,0,0.5), 0 3px 6px rgba(0,0,0,0.3);
    --sh-lg: 0 16px 48px rgba(0,0,0,0.6), 0 6px 16px rgba(0,0,0,0.4);
    color-scheme: dark;
  }
}

