
/* ============================================================
   AI Manager Lab — Modern SaaS / Tech Media (ported from round3)
   ============================================================ */
:root{
  --bg:#FAFAF7;--bg-tint:#F4F4F0;--bg-card:#FFFFFF;--bg-dark:#0F1614;--bg-dark-2:#0A0E0D;
  --fg:#0F1614;--fg-sub:#4F5654;--fg-mute:#8A8F8D;--fg-on-dark:#F5F5F0;--fg-on-dark-sub:rgba(245,245,240,0.6);--fg-on-dark-mute:rgba(245,245,240,0.42);
  --border:#E5E5E0;--border-strong:#D4D4CE;--border-on-dark:rgba(245,245,240,0.12);--border-on-dark-strong:rgba(245,245,240,0.22);
  --accent:#2D5F4A;--accent-hover:#234A39;--accent-soft:#E8EFE9;--accent-bright:#5FAE8C;
  --moss:#2D5F4A;--moss-soft:#E8EFE9;--moss-grad:linear-gradient(135deg,#E8EFE9 0%,#F4FAF7 100%);
  --indigo:#3B4FE0;--indigo-soft:#EEF0FD;--indigo-grad:linear-gradient(135deg,#EEF0FD 0%,#F4F6FE 100%);
  --amber:#C9A876;--amber-soft:#FAF5EC;--amber-grad:linear-gradient(135deg,#FAF5EC 0%,#FDFAF3 100%);
  --rose:#B14A6E;--rose-soft:#FAEEF2;--rose-grad:linear-gradient(135deg,#FAEEF2 0%,#FDF6F9 100%);
  --grad-hero:linear-gradient(135deg,#2D5F4A 0%,#1F3F6B 50%,#0F1614 100%);
  --grad-divider:linear-gradient(90deg,rgba(45,95,74,0.25),rgba(45,95,74,0));
  --code-bg:#0F1614;--code-fg:#E8E8E0;
  --font-jp:"Noto Sans JP",system-ui,-apple-system,"Hiragino Sans",sans-serif;
  --font-en:"Inter",system-ui,-apple-system,sans-serif;
  --font-display:"Manrope","Inter",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;
  --maxw-content:720px;--maxw-wide:1200px;
  --r-card:12px;--r-pill:999px;--r-btn:6px;
  --ease:cubic-bezier(0.4,0,0.2,1);--ease-out:cubic-bezier(0.16,1,0.3,1);--t-fast:0.18s;--t:0.22s;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--font-jp);font-size:17px;line-height:1.85;letter-spacing:0.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"palt"}
@media (max-width:600px){html,body{font-size:16px}}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.2;letter-spacing:-0.015em;margin:0}
.jp-heading{font-family:var(--font-jp);letter-spacing:-0.005em}
p{margin:0 0 1.2em}
a{color:var(--accent);text-decoration:none;transition:color var(--t) var(--ease)}
a:hover{color:var(--accent-hover)}
button{font-family:inherit;cursor:pointer}
img,svg{display:block;max-width:100%}

.container{max-width:var(--maxw-wide);margin:0 auto;padding:0 32px}
.content{max-width:var(--maxw-content);margin:0 auto;padding:0 32px}
@media (max-width:600px){.container,.content{padding:0 20px}}

/* —— Header —— */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,250,247,0.78);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}
.site-header.on-dark{background:rgba(15,22,20,0.6);border-bottom-color:var(--border-on-dark)}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;height:68px;max-width:var(--maxw-wide);margin:0 auto;padding:0 32px}
@media (max-width:600px){.site-header-inner{padding:0 20px;height:60px}}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-0.01em;color:var(--fg);cursor:pointer;background:none;border:0;padding:0}
.on-dark .logo{color:var(--fg-on-dark)}
.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--accent);color:#fff;border-radius:6px;font-size:11px;font-weight:800;letter-spacing:0;line-height:1;position:relative;flex-shrink:0}
.logo-mark::after{content:"";position:absolute;right:5px;bottom:5px;width:4px;height:4px;border-radius:50%;background:var(--accent-bright)}
.nav{display:flex;align-items:center;gap:32px}
.nav a,.nav button{position:relative;background:none;border:0;padding:8px 0;font-family:var(--font-en);font-size:14px;font-weight:500;color:var(--fg-sub);letter-spacing:-0.005em;cursor:pointer;transition:color var(--t) var(--ease)}
.nav a::after,.nav button::after{content:"";position:absolute;left:0;bottom:4px;height:2px;width:100%;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t) var(--ease)}
.nav a:hover,.nav button:hover{color:var(--fg)}
.nav a:hover::after,.nav button:hover::after{transform:scaleX(1)}
.on-dark .nav a,.on-dark .nav button{color:var(--fg-on-dark-sub)}
.on-dark .nav a:hover,.on-dark .nav button:hover{color:var(--fg-on-dark)}
.on-dark .nav a::after,.on-dark .nav button::after{background:var(--accent-bright)}
/* Mobile nav: checkbox hack (no JS) */
.nav-toggle{display:none}
.nav-toggle-btn{display:none}
@media (max-width:600px){.nav{gap:22px}.nav a,.nav button{font-size:13px}}
@media (max-width:560px){
  .nav-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer}
  .on-dark .nav-toggle-btn{border-color:var(--border-on-dark)}
  .nav-toggle-btn span,.nav-toggle-btn span::before,.nav-toggle-btn span::after{content:"";display:block;width:18px;height:2px;background:var(--fg);position:relative;transition:transform .2s}
  .on-dark .nav-toggle-btn span,.on-dark .nav-toggle-btn span::before,.on-dark .nav-toggle-btn span::after{background:var(--fg-on-dark)}
  .nav-toggle-btn span::before{position:absolute;top:-6px}
  .nav-toggle-btn span::after{position:absolute;top:6px}
  .site-header-inner{flex-wrap:wrap;height:auto;padding-top:12px;padding-bottom:12px}
  .nav{order:3;width:100%;flex-direction:column;align-items:stretch;gap:0;max-height:0;overflow:hidden;transition:max-height .25s ease}
  .nav-toggle:checked ~ .nav{max-height:320px;margin-top:10px;border-top:1px solid var(--border)}
  .on-dark .nav-toggle:checked ~ .nav{border-top-color:var(--border-on-dark)}
  .nav a{width:100%;padding:12px 2px;border-bottom:1px solid var(--border)}
  .on-dark .nav a{border-bottom-color:var(--border-on-dark)}
  .nav a::after{display:none}
}

/* —— Hero —— */
.hero{position:relative;background:var(--grad-hero);color:var(--fg-on-dark);overflow:hidden;isolation:isolate;margin-top:-68px;padding-top:68px}
@media (max-width:600px){.hero{margin-top:-60px;padding-top:60px}}
.hero-inner{max-width:var(--maxw-wide);margin:0 auto;padding:120px 32px 140px;display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:48px;align-items:center;position:relative;z-index:2}
@media (max-width:900px){.hero-inner{grid-template-columns:1fr;padding:96px 32px 100px}}
@media (max-width:600px){.hero-inner{padding:72px 20px 88px}}
.hero .eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-en);font-size:12px;font-weight:600;color:var(--accent-bright);letter-spacing:0.22em;text-transform:uppercase;margin-bottom:36px}
.hero .eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent-bright);box-shadow:0 0 0 4px rgba(95,174,140,0.18)}
.hero h1{font-family:var(--font-jp);font-weight:700;font-size:clamp(40px,7vw,72px);line-height:1.18;letter-spacing:-0.025em;color:var(--fg-on-dark);margin-bottom:32px;text-wrap:pretty;max-width:900px}
.hero h1 .grad-word{background:linear-gradient(120deg,#5FAE8C 0%,#7DA8E0 50%,#C9A876 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.hero .lead{font-size:18px;line-height:1.85;color:var(--fg-on-dark-sub);max-width:560px;margin:0 0 44px}
@media (max-width:600px){.hero .lead{font-size:16px;margin-bottom:32px}}
.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-en);font-size:14px;font-weight:600;letter-spacing:-0.005em;padding:13px 22px;border-radius:var(--r-btn);border:1px solid transparent;cursor:pointer;transition:background-color var(--t) var(--ease),color var(--t) var(--ease),border-color var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease);background:none}
.btn .arrow{display:inline-block;transition:transform var(--t) var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:#fff;color:var(--bg-dark);border-color:#fff}
.btn-primary:hover{background:var(--fg-on-dark);box-shadow:0 8px 28px rgba(95,174,140,0.2);color:var(--bg-dark)}
.btn-ghost-light{background:transparent;color:var(--fg-on-dark);border-color:rgba(245,245,240,0.3)}
.btn-ghost-light:hover{background:rgba(245,245,240,0.08);border-color:rgba(245,245,240,0.5);color:var(--fg-on-dark)}
.btn-primary-dark{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary-dark:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 8px 24px rgba(45,95,74,0.22);color:#fff}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--border-strong)}
.btn-ghost:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.hero-graphic{position:relative;width:100%;aspect-ratio:1/1;max-width:480px;justify-self:end;align-self:center}
@media (max-width:900px){.hero-graphic{display:none}}
.hero-graphic svg{width:100%;height:100%;overflow:visible}
.hero-graphic .ring{fill:none;stroke:rgba(245,245,240,0.18);stroke-width:1}
.hero-graphic .ring-thick{stroke:rgba(95,174,140,0.5);stroke-width:1.5}
.hero-graphic .dot{fill:rgba(245,245,240,0.5)}
.hero-graphic .dot-accent{fill:var(--accent-bright)}
.hero-graphic .line{stroke:rgba(245,245,240,0.12);stroke-width:1;fill:none}
.hero-graphic .arc{fill:none;stroke-linecap:round}
.hero-tickers{position:relative;z-index:2;max-width:var(--maxw-wide);margin:-64px auto 0;padding:28px 32px 56px;display:flex;align-items:center;gap:36px;flex-wrap:wrap;border-top:1px solid var(--border-on-dark)}
@media (max-width:600px){.hero-tickers{padding:24px 20px 56px;gap:18px}}
.hero-tickers .label{font-family:var(--font-en);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-on-dark-mute)}
.hero-tickers .items{display:flex;gap:28px;flex-wrap:wrap;font-family:var(--font-en);font-size:13px;color:var(--fg-on-dark-sub)}
.hero-tickers .items span{display:inline-flex;align-items:center}
.hero-tickers .items b{color:var(--fg-on-dark);font-weight:600;margin-right:6px;font-variant-numeric:tabular-nums}

/* —— Sections —— */
.section{padding:120px 0 0}
@media (max-width:600px){.section{padding:72px 0 0}}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:48px;gap:24px}
.section-head .lhs{display:flex;flex-direction:column;gap:14px}
.section-head .eyebrow{font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px}
.section-head .eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}
.section-head h2{font-family:var(--font-display);font-size:clamp(28px,3.6vw,40px);font-weight:700;letter-spacing:-0.02em;line-height:1.15;color:var(--fg)}
.section-head h2.jp{font-family:var(--font-jp);letter-spacing:-0.005em;line-height:1.3}
.section-head .see-all{font-family:var(--font-en);font-size:14px;font-weight:500;color:var(--fg-sub);background:none;border:0;padding:8px 0;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:color var(--t) var(--ease)}
.section-head .see-all .arrow{transition:transform var(--t) var(--ease)}
.section-head .see-all:hover{color:var(--accent)}
.section-head .see-all:hover .arrow{transform:translateX(3px)}

/* —— Cards —— */
.card-hero{display:grid;grid-template-columns:1fr;gap:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;cursor:pointer;text-align:left;padding:0;font-family:inherit;color:inherit;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease)}
.card-hero:hover{border-color:var(--border-strong);box-shadow:0 12px 32px rgba(15,22,20,0.06);transform:translateY(-2px)}
.card-hero .visual{aspect-ratio:16/8;position:relative;overflow:hidden}
.card-hero .body{padding:36px 40px 40px}
.card-hero h3{font-family:var(--font-jp);font-size:clamp(22px,2.4vw,30px);line-height:1.4;font-weight:700;letter-spacing:-0.005em;margin:16px 0 16px;text-wrap:pretty;transition:color var(--t) var(--ease)}
.card-hero:hover h3{color:var(--accent)}
.card-hero .excerpt{font-size:15px;line-height:1.85;color:var(--fg-sub);margin:0 0 24px;max-width:640px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-hero .read-link{font-family:var(--font-en);font-size:14px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.card-hero .read-link .arrow{transition:transform var(--t) var(--ease)}
.card-hero:hover .read-link .arrow{transform:translateX(4px)}
@media (max-width:600px){.card-hero .body{padding:28px 24px 32px}}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
@media (max-width:960px){.card-grid{grid-template-columns:repeat(2,1fr);gap:28px}}
@media (max-width:600px){.card-grid{grid-template-columns:1fr;gap:32px}}
.card-std{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;cursor:pointer;text-align:left;font-family:inherit;color:inherit;padding:0;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease)}
.card-std:hover{border-color:var(--border-strong);box-shadow:0 8px 24px rgba(15,22,20,0.06);transform:translateY(-2px)}
.card-std .visual{aspect-ratio:16/10;position:relative;overflow:hidden}
.card-std .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-std .meta{display:flex;align-items:center;gap:10px;font-family:var(--font-en);font-size:12px;color:var(--fg-mute);flex-wrap:wrap}
.card-std .meta .dot{color:var(--border-strong)}
.card-std h3{font-family:var(--font-jp);font-size:18px;line-height:1.55;font-weight:700;letter-spacing:-0.005em;text-wrap:pretty;transition:color var(--t) var(--ease);margin:0}
.card-std:hover h3{color:var(--accent)}
.card-std .excerpt{font-size:13.5px;color:var(--fg-sub);line-height:1.75;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-mini{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-left-width:4px;border-radius:var(--r-card);padding:22px 24px;cursor:pointer;text-align:left;font-family:inherit;color:inherit;gap:8px;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease),transform var(--t) var(--ease)}
.card-mini:hover{box-shadow:0 6px 18px rgba(15,22,20,0.06);transform:translateY(-1px)}
.card-mini h3{font-family:var(--font-jp);font-size:16px;line-height:1.55;font-weight:700;letter-spacing:-0.005em;transition:color var(--t) var(--ease)}
.card-mini:hover h3{color:var(--accent)}
.card-mini .meta{display:flex;align-items:center;gap:10px;font-family:var(--font-en);font-size:11.5px;color:var(--fg-mute)}
.visual{background:var(--moss-grad);position:relative;overflow:hidden}
.visual .grid-pattern{position:absolute;inset:0;background-image:linear-gradient(rgba(15,22,20,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(15,22,20,0.04) 1px,transparent 1px);background-size:28px 28px;background-position:-1px -1px;pointer-events:none}
.visual img{width:100%;height:100%;object-fit:cover;display:block}
.visual .glyph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:clamp(40px,7vw,88px);color:var(--accent);letter-spacing:-0.04em;opacity:0.88}
.visual .num{position:absolute;top:18px;left:22px;font-family:var(--font-en);font-weight:700;font-size:12px;color:var(--accent);letter-spacing:0.04em}
.visual .label{position:absolute;bottom:18px;right:22px;font-family:var(--font-mono);font-size:10px;color:var(--accent);opacity:0.55;letter-spacing:0.06em}
.visual.cat-moss{background:var(--moss-grad)}
.visual.cat-moss .glyph,.visual.cat-moss .num,.visual.cat-moss .label{color:var(--moss)}
.visual.cat-indigo{background:var(--indigo-grad)}
.visual.cat-indigo .glyph,.visual.cat-indigo .num,.visual.cat-indigo .label{color:var(--indigo)}
.visual.cat-amber{background:var(--amber-grad)}
.visual.cat-amber .glyph,.visual.cat-amber .num,.visual.cat-amber .label{color:#8B6A3A}
.visual.cat-rose{background:var(--rose-grad)}
.visual.cat-rose .glyph,.visual.cat-rose .num,.visual.cat-rose .label{color:var(--rose)}
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-pill);line-height:1.4}
.tag.cat-moss{background:var(--moss-soft);color:var(--moss)}
.tag.cat-indigo{background:var(--indigo-soft);color:var(--indigo)}
.tag.cat-amber{background:var(--amber-soft);color:#8B6A3A}
.tag.cat-rose{background:var(--rose-soft);color:var(--rose)}
.card-mini.cat-moss{border-left-color:var(--moss)}
.card-mini.cat-indigo{border-left-color:var(--indigo)}
.card-mini.cat-amber{border-left-color:var(--amber)}
.card-mini.cat-rose{border-left-color:var(--rose)}

/* —— Dark stats band —— */
.dark-band{margin-top:120px;padding:96px 0;background:var(--bg-dark);color:var(--fg-on-dark);position:relative;overflow:hidden;isolation:isolate}
.dark-band::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(95,174,140,0.15) 0%,transparent 55%),radial-gradient(ellipse at 20% 80%,rgba(59,79,224,0.12) 0%,transparent 50%);pointer-events:none;z-index:0}
.dark-band > .container{position:relative;z-index:1}
@media (max-width:600px){.dark-band{padding:64px 0;margin-top:72px}}
.dark-band-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:64px;align-items:center}
@media (max-width:900px){.dark-band-grid{grid-template-columns:1fr;gap:48px}}
.dark-band .eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:24px}
.dark-band .eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent-bright)}
.dark-band h2{font-family:var(--font-jp);font-size:clamp(28px,3.6vw,44px);line-height:1.3;letter-spacing:-0.005em;font-weight:700;color:var(--fg-on-dark);margin-bottom:24px;text-wrap:pretty}
.dark-band p{color:var(--fg-on-dark-sub);font-size:16px;line-height:1.85;max-width:520px;margin:0 0 36px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--border-on-dark);border-bottom:1px solid var(--border-on-dark)}
.stat{padding:28px 24px;border-right:1px solid var(--border-on-dark);display:flex;flex-direction:column;gap:6px}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--font-display);font-size:clamp(40px,6vw,64px);line-height:1;font-weight:700;letter-spacing:-0.03em;color:var(--fg-on-dark);font-variant-numeric:tabular-nums}
.stat .lbl{font-family:var(--font-en);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-on-dark-mute);margin-top:8px}
.stat .sub{font-family:var(--font-en);font-size:12px;color:var(--fg-on-dark-sub)}

/* —— Series pills —— */
.series-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:900px){.series-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.series-grid{grid-template-columns:1fr}}
.series-pill{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-card);padding:28px 26px;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:8px;font-family:inherit;color:inherit;overflow:hidden;isolation:isolate;transition:border-color var(--t) var(--ease),transform var(--t) var(--ease),box-shadow var(--t) var(--ease)}
.series-pill::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity var(--t) var(--ease);z-index:-1}
.series-pill.cat-moss::before{background:var(--moss-grad)}
.series-pill.cat-indigo::before{background:var(--indigo-grad)}
.series-pill.cat-amber::before{background:var(--amber-grad)}
.series-pill.cat-rose::before{background:var(--rose-grad)}
.series-pill:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(15,22,20,0.06)}
.series-pill:hover::before{opacity:1}
.series-pill.cat-moss:hover{border-color:var(--moss)}
.series-pill.cat-indigo:hover{border-color:var(--indigo)}
.series-pill.cat-amber:hover{border-color:var(--amber)}
.series-pill.cat-rose:hover{border-color:var(--rose)}
.series-pill .glyph{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}
.series-pill.cat-moss .glyph{background:var(--moss);color:#fff}
.series-pill.cat-indigo .glyph{background:var(--indigo);color:#fff}
.series-pill.cat-amber .glyph{background:var(--amber);color:#fff}
.series-pill.cat-rose .glyph{background:var(--rose);color:#fff}
.series-pill .label{font-family:var(--font-en);font-size:10.5px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-mute)}
.series-pill .ttl{font-family:var(--font-jp);font-size:17px;font-weight:700;color:var(--fg);letter-spacing:-0.005em}
.series-pill .count{font-family:var(--font-en);font-size:12px;color:var(--fg-sub);margin-top:auto;padding-top:12px}
.series-pill.cat-moss .count{color:var(--moss)}
.series-pill.cat-indigo .count{color:var(--indigo)}
.series-pill.cat-amber .count{color:#8B6A3A}
.series-pill.cat-rose .count{color:var(--rose)}

/* —— Article page —— */
.article-wrap{display:grid;grid-template-columns:220px minmax(0,var(--maxw-content)) 220px;gap:56px;max-width:var(--maxw-wide);margin:0 auto;padding:72px 32px 0;align-items:start}
@media (max-width:1100px){.article-wrap{grid-template-columns:minmax(0,var(--maxw-content));padding:56px 32px 0;justify-content:center}.toc-side,.article-side{display:none}}
@media (max-width:600px){.article-wrap{padding:48px 20px 0}}
.toc-side,.article-side{position:sticky;top:96px;font-family:var(--font-en);font-size:13px}
.toc-side .label,.article-side .label{font-size:10.5px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:18px}
.toc-side ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.toc-side a{color:var(--fg-sub);font-size:13px;line-height:1.55;display:block;padding:4px 0 4px 14px;border-left:2px solid var(--border);transition:color var(--t) var(--ease),border-left-color var(--t) var(--ease)}
.toc-side a:hover{color:var(--accent);text-decoration:none}
.toc-side a.active{color:var(--accent);border-left-color:var(--accent);border-left-width:3px;padding-left:13px;font-weight:600}
.breadcrumb{font-family:var(--font-en);font-size:12.5px;letter-spacing:0.02em;color:var(--fg-mute);margin-bottom:32px}
.breadcrumb a{color:var(--fg-mute);cursor:pointer}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{margin:0 10px;color:var(--border-strong)}
.breadcrumb .current{color:var(--fg-sub)}
.article h1{font-family:var(--font-jp);font-size:clamp(32px,5vw,52px);line-height:1.3;letter-spacing:-0.015em;margin-bottom:24px;text-wrap:pretty;font-weight:700}
@media (max-width:600px){.article h1{font-size:32px;line-height:1.4}}
.article .meta{font-family:var(--font-en);font-size:13px;color:var(--fg-mute);display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:40px}
.article .meta .dot{color:var(--border-strong)}
.article .meta .updated{color:var(--fg-sub);font-size:12px;padding:3px 10px;border:1px solid var(--border);border-radius:var(--r-pill);letter-spacing:0.02em}
.article-eyecatch{margin:0 0 56px;border:1px solid var(--border);border-radius:var(--r-card);overflow:hidden;aspect-ratio:16/9}
.article-eyecatch img{width:100%;height:100%;object-fit:cover;display:block}
.toc-mobile{display:none;border:1px solid var(--border);border-radius:var(--r-card);padding:18px 22px;margin-bottom:48px;background:var(--bg-card)}
@media (max-width:1100px){.toc-mobile{display:block}}
.toc-mobile summary{list-style:none;cursor:pointer;font-size:12px;font-family:var(--font-en);letter-spacing:0.18em;text-transform:uppercase;color:var(--fg);font-weight:600;display:flex;justify-content:space-between;align-items:center}
.toc-mobile summary::-webkit-details-marker{display:none}
.toc-mobile summary::after{content:"+";font-size:18px;color:var(--fg-mute)}
.toc-mobile[open] summary::after{content:"\2212"}
.toc-mobile ol{list-style:decimal;padding-left:24px;margin:18px 0 4px;display:flex;flex-direction:column;gap:8px}
.toc-mobile a{color:var(--fg-sub);font-size:14px}
.toc-mobile a:hover{color:var(--accent)}
.article-body{font-size:17px;line-height:1.95;color:var(--fg)}
.article-body p{margin:0 0 32px;text-wrap:pretty}
.article-body img{margin:32px auto;border-radius:var(--r-card);border:1px solid var(--border)}
.article-body > p:first-of-type{font-size:18.5px;line-height:1.9;color:var(--fg)}
@media (max-width:600px){.article-body > p:first-of-type{font-size:17px}}
.article-body h2{font-family:var(--font-jp);font-size:clamp(26px,3.2vw,40px);font-weight:700;line-height:1.35;letter-spacing:-0.005em;margin:72px 0 28px;padding-top:44px;border-top:1px solid var(--border);position:relative;scroll-margin-top:96px;text-wrap:balance;line-break:strict}
.article-body h2::before{content:"";display:block;width:46px;height:4px;background:linear-gradient(90deg,var(--accent),var(--accent-bright));margin-bottom:20px;border-radius:2px}
.article-body h3{font-family:var(--font-jp);font-size:22px;font-weight:700;line-height:1.5;letter-spacing:-0.005em;margin:48px 0 18px;padding-left:16px;border-left:4px solid var(--accent);scroll-margin-top:96px;text-wrap:balance;line-break:strict}
.article-body h4{font-family:var(--font-jp);font-size:19px;font-weight:700;margin:36px 0 14px}
@media (max-width:600px){.article-body h2{margin-top:56px;padding-top:36px;font-size:25px}.article-body h3{margin-top:36px;font-size:19px;padding-left:14px}}
.article-body ul,.article-body ol{margin:0 0 32px;padding-left:24px}
.article-body li{margin-bottom:10px}
.article-body li::marker{color:var(--accent)}
.article-body strong{font-weight:700;color:var(--accent)}
.article-body a{color:var(--accent);border-bottom:1px solid transparent;transition:border-bottom-color var(--t) var(--ease),color var(--t) var(--ease)}
.article-body a:hover{border-bottom-color:var(--accent);color:var(--accent-hover)}
.article-body code:not(pre code){background:var(--accent-soft);color:var(--accent);font-family:var(--font-mono);font-size:13.5px;padding:2px 7px;border-radius:4px}
.article-body pre{background:var(--code-bg);color:var(--code-fg);font-family:var(--font-mono);font-size:13.5px;line-height:1.75;padding:22px 24px;border-radius:var(--r-card);overflow-x:auto;margin:36px 0}
.article-body pre code{background:transparent;color:inherit;padding:0}
.article-body blockquote{border-left:3px solid var(--amber);background:linear-gradient(90deg,rgba(201,168,118,0.06),transparent 60%);padding:8px 0 8px 24px;margin:40px 0;font-style:italic;font-size:19px;line-height:1.75;color:var(--fg)}
.article-body blockquote p{margin-bottom:8px}
.article-body blockquote p:last-of-type{margin-bottom:0}
.article-body table{width:100%;border-collapse:collapse;margin:36px 0;font-size:14.5px;line-height:1.7}
.article-body table th,.article-body table td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:top}
.article-body table th{font-family:var(--font-en);font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--fg-sub);border-bottom:1px solid var(--border-strong);padding-bottom:10px}
.article-body table tr:last-child td{border-bottom:0}
.article-body figure{margin:40px 0}
.article-body figure img{width:100%;height:auto;border-radius:var(--r-card);border:1px solid var(--border)}
.article-body figcaption{font-family:var(--font-en);font-size:13px;color:var(--fg-mute);margin-top:14px;text-align:center}
.article-body hr{border:none;height:1px;background:var(--border);margin:48px 0}
.article-body .featured-image,.article-body .swell-block-button{max-width:100%}
.article-body .c-balloon__icon img{width:auto !important;max-width:80px;border:0}
/* 記事内CTA：柱4ガジェット記事への予告（rose系）。本文HTMLに <div class="cta-gadget"> を置くと描画される。 */
.article-body .cta-gadget{margin:56px 0 0;padding:26px 30px;border:1px solid var(--border);border-left:3px solid var(--rose);border-radius:var(--r-card);background:var(--rose-grad)}
.article-body .cta-gadget__eyebrow{display:inline-block;font-family:var(--font-en);font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--rose);margin-bottom:10px}
.article-body .cta-gadget__title{font-family:var(--font-jp);font-size:19px;font-weight:700;color:var(--fg);margin:0 0 8px;line-height:1.4}
.article-body .cta-gadget p{margin:0;color:var(--fg-sub);font-size:15px;line-height:1.8}
/* 強調ボックス：本文で「ここは読んでほしい」要点を囲む。HTMLに <div class="callout"><div class="callout__label">ポイント</div><p>…</p></div>。--warn を足すと注意（rose）配色。 */
.article-body .callout{margin:40px 0;padding:22px 26px 24px;border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:var(--r-card);background:var(--accent-soft)}
.article-body .callout > *:last-child{margin-bottom:0}
.article-body .callout__label{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-en);font-size:11.5px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.article-body .callout__label::before{content:"\2713";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--accent);color:#fff;border-radius:50%;font-size:12px;line-height:1}
.article-body .callout p{margin:0 0 12px;color:var(--fg);font-size:16px;line-height:1.85}
.article-body .callout--warn{border-left-color:var(--rose);background:var(--rose-soft)}
.article-body .callout--warn .callout__label{color:var(--rose)}
.article-body .callout--warn .callout__label::before{content:"!";background:var(--rose)}
/* チェックリスト：<ul class="checklist"> で緑チェック付き箇条書きに。 */
.article-body ul.checklist{list-style:none;padding-left:0;margin:32px 0}
.article-body ul.checklist li{position:relative;padding-left:36px;margin-bottom:14px;line-height:1.8}
.article-body ul.checklist li::before{content:"\2713";position:absolute;left:0;top:1px;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:50%;font-size:13px;font-weight:700;line-height:1}
.article-body .callout ul.checklist,.article-body .callout--warn ul.checklist{margin:4px 0 0}
.article-footer{max-width:var(--maxw-content);margin:0 auto;padding:0 32px}
@media (max-width:600px){.article-footer{padding:0 20px}}
.author-card{margin-top:96px;padding:36px;border:1px solid var(--border);border-radius:var(--r-card);background:linear-gradient(135deg,var(--bg-card) 0%,var(--accent-soft) 200%);display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:flex-start}
@media (max-width:600px){.author-card{padding:28px;gap:20px;grid-template-columns:1fr}}
.author-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#1F3F6B);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:20px;letter-spacing:-0.02em;position:relative;flex-shrink:0}
.author-avatar::after{content:"";position:absolute;right:-2px;bottom:-2px;width:14px;height:14px;border-radius:50%;background:var(--accent-bright);border:3px solid var(--bg)}
.author-card .name-eyebrow{font-family:var(--font-en);font-size:10.5px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:6px}
.author-card .author-name{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-0.015em;margin-bottom:4px}
.author-card .author-handle{font-family:var(--font-en);font-size:13px;color:var(--accent);margin-bottom:12px}
.author-card .author-bio{font-size:14px;color:var(--fg-sub);line-height:1.85;margin:0 0 16px}
.author-card .author-link{font-family:var(--font-en);font-size:13px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.author-card .author-link .arrow{transition:transform var(--t) var(--ease)}
.author-card .author-link:hover .arrow{transform:translateX(4px)}
.related{margin-top:96px}
.related .related-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:28px}
.related .related-head h2{font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:-0.015em}
.related .related-meta{font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-mute)}
.related .related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:780px){.related .related-grid{grid-template-columns:1fr}}

/* —— About page —— */
.about-page{max-width:var(--maxw-content);margin:0 auto;padding:96px 32px 0}
@media (max-width:600px){.about-page{padding:64px 20px 0}}
.about-page .eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}
.about-page .eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}
.about-page h1{font-family:var(--font-jp);font-size:clamp(28px,4vw,44px);line-height:1.35;letter-spacing:-0.005em;margin-bottom:56px;font-weight:700;text-wrap:pretty}
.about-intro{display:grid;grid-template-columns:120px 1fr;gap:32px;align-items:flex-start;padding:36px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:56px}
@media (max-width:600px){.about-intro{grid-template-columns:1fr;gap:20px}}
.about-avatar{width:120px;height:120px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#5FAE8C 0%,var(--accent) 55%,#1F3F6B 100%);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:44px;color:#fff;letter-spacing:-0.02em;position:relative}
.about-avatar::after{content:"";position:absolute;inset:-8px;border:1px solid var(--border);border-radius:50%}
.about-avatar .pulse{position:absolute;right:4px;bottom:4px;width:18px;height:18px;border-radius:50%;background:var(--accent-bright);border:3px solid var(--bg)}
.about-intro .pen{font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:8px}
.about-intro h2{font-family:var(--font-display);font-size:24px;font-weight:700;margin-bottom:12px;letter-spacing:-0.015em}
.about-intro p{font-size:15px;color:var(--fg-sub);line-height:1.85;margin:0}
.about-block{margin-bottom:56px}
.about-block h3{font-family:var(--font-en);font-size:11.5px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg);margin-bottom:28px;display:flex;align-items:center;gap:14px}
.about-block h3::before{content:"";display:inline-block;width:24px;height:3px;background:var(--accent);border-radius:2px}
.about-block > p{font-size:15.5px;color:var(--fg-sub);line-height:1.95;margin:0 0 18px}
.about-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.about-list li{display:grid;grid-template-columns:130px 1fr;gap:20px;padding:16px 0;border-bottom:1px solid var(--border);font-size:15px;line-height:1.8;color:var(--fg)}
.about-list li:first-child{padding-top:0}
.about-list li:last-child{border-bottom:0}
.about-list li .k{font-family:var(--font-en);font-size:12px;font-weight:600;color:var(--fg-mute);letter-spacing:0.04em;white-space:nowrap;padding-top:3px}
@media (max-width:600px){.about-list li{grid-template-columns:1fr;gap:4px}}
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (max-width:600px){.contact-grid{grid-template-columns:1fr}}
.contact-card{border:1px solid var(--border);border-radius:var(--r-card);padding:20px 22px;background:var(--bg-card);display:flex;align-items:center;justify-content:space-between;font-size:14px;cursor:pointer;transition:border-color var(--t) var(--ease),background-color var(--t) var(--ease),transform var(--t) var(--ease)}
.contact-card:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}
.contact-card .k{font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-mute);display:block;margin-bottom:4px}
.contact-card .v{font-family:var(--font-en);color:var(--fg);font-weight:600;font-size:14px}
.contact-card .arrow{color:var(--accent);font-family:var(--font-en);font-size:16px;transition:transform var(--t) var(--ease)}
.contact-card:hover .arrow{transform:translate(4px,-4px)}

/* —— Categories / Series page —— */
.category-page{max-width:var(--maxw-wide);margin:0 auto;padding:96px 32px 0}
@media (max-width:600px){.category-page{padding:64px 20px 0}}
.category-page .eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}
.category-page .eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}
.category-page h1{font-family:var(--font-jp);font-size:clamp(32px,4.5vw,52px);line-height:1.25;letter-spacing:-0.015em;margin-bottom:16px;font-weight:700;text-wrap:pretty}
.category-page .lead{font-size:17px;color:var(--fg-sub);max-width:620px;line-height:1.85;margin-bottom:64px}
.cat-card{position:relative;border:1px solid var(--border);border-radius:var(--r-card);padding:40px;margin-bottom:20px;cursor:pointer;overflow:hidden;isolation:isolate;transition:border-color var(--t) var(--ease),transform var(--t) var(--ease),box-shadow var(--t) var(--ease)}
.cat-card::before{content:"";position:absolute;inset:0;z-index:-1}
.cat-card.cat-moss::before{background:var(--moss-grad)}
.cat-card.cat-indigo::before{background:var(--indigo-grad)}
.cat-card.cat-amber::before{background:var(--amber-grad)}
.cat-card.cat-rose::before{background:var(--rose-grad)}
.cat-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(15,22,20,0.06)}
.cat-card.cat-moss:hover{border-color:var(--moss)}
.cat-card.cat-indigo:hover{border-color:var(--indigo)}
.cat-card.cat-amber:hover{border-color:var(--amber)}
.cat-card.cat-rose:hover{border-color:var(--rose)}
.cat-card .inner{display:grid;grid-template-columns:1fr;gap:32px}
@media (min-width:800px){.cat-card .inner{grid-template-columns:320px 1fr;gap:56px}}
.cat-card .head{display:flex;flex-direction:column;gap:14px}
.cat-card .glyph{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;margin-bottom:8px}
.cat-card.cat-moss .glyph{background:var(--moss)}
.cat-card.cat-indigo .glyph{background:var(--indigo)}
.cat-card.cat-amber .glyph{background:var(--amber)}
.cat-card.cat-rose .glyph{background:var(--rose)}
.cat-card .label-row{display:flex;align-items:center;gap:12px;font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-sub)}
.cat-card .label-row .count{color:#fff;padding:3px 10px;border-radius:var(--r-pill);font-size:11px;font-weight:600;letter-spacing:0.06em}
.cat-card.cat-moss .label-row .count{background:var(--moss)}
.cat-card.cat-indigo .label-row .count{background:var(--indigo)}
.cat-card.cat-amber .label-row .count{background:var(--amber)}
.cat-card.cat-rose .label-row .count{background:var(--rose)}
.cat-card h2{font-family:var(--font-jp);font-size:24px;font-weight:700;letter-spacing:-0.005em;line-height:1.4}
.cat-card .cat-desc{font-size:14px;color:var(--fg-sub);line-height:1.85;margin:0}
.cat-card .cat-articles{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
@media (min-width:800px){.cat-card .cat-articles{border-left:1px solid var(--border);padding-left:32px}}
.cat-card .cat-articles .articles-label{font-family:var(--font-en);font-size:10.5px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:14px}
.cat-card .cat-articles li{padding:14px 0;border-bottom:1px solid rgba(15,22,20,0.06);display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:baseline;font-size:14.5px;line-height:1.5;transition:color var(--t) var(--ease)}
.cat-card .cat-articles li:last-of-type{border-bottom:0}
.cat-card .cat-articles .num{font-family:var(--font-en);font-size:11px;font-weight:600;color:var(--fg-mute);letter-spacing:0.04em}
.cat-card .cat-articles .ttl{color:var(--fg);font-weight:500;transition:color var(--t) var(--ease)}
.cat-card .cat-articles .date{font-family:var(--font-en);font-size:11px;color:var(--fg-mute)}
.cat-card .cat-articles li:hover .ttl{color:var(--accent)}
.cat-card .cat-articles .empty{color:var(--fg-mute);font-size:13px;padding:14px 0}
.cat-card .see-all-link{margin-top:14px;font-family:var(--font-en);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.cat-card.cat-moss .see-all-link{color:var(--moss)}
.cat-card.cat-indigo .see-all-link{color:var(--indigo)}
.cat-card.cat-amber .see-all-link{color:#8B6A3A}
.cat-card.cat-rose .see-all-link{color:var(--rose)}
/* Category archive (single-series) grid uses card-grid */
.category-page .card-grid{margin-top:8px}

/* —— Newsletter block —— */
.newsletter{margin-top:72px;border:1px solid var(--border);border-radius:var(--r-card);background:linear-gradient(135deg,var(--accent-soft) 0%,#F4FAF7 100%);padding:40px 44px;position:relative;overflow:hidden;isolation:isolate}
@media (max-width:600px){.newsletter{padding:28px 22px;margin-top:56px}}
.newsletter .eyebrow{font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}
.newsletter .eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}
.newsletter h2{font-family:var(--font-jp);font-size:clamp(20px,2.6vw,26px);font-weight:700;letter-spacing:-0.005em;line-height:1.4;color:var(--fg);margin-bottom:10px;text-wrap:pretty}
.newsletter p{font-size:14.5px;color:var(--fg-sub);line-height:1.8;margin:0 0 24px;max-width:520px}
.newsletter form{display:flex;gap:10px;flex-wrap:wrap;max-width:520px}
.newsletter input[type=email]{flex:1;min-width:220px;padding:12px 16px;border:1px solid var(--border-strong);border-radius:var(--r-btn);font-family:var(--font-jp);font-size:14px;background:var(--bg-card);color:var(--fg)}
.newsletter input[type=email]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,95,74,0.12)}
.newsletter button{padding:12px 22px;border-radius:var(--r-btn);border:1px solid var(--accent);background:var(--accent);color:#fff;font-family:var(--font-en);font-weight:600;font-size:14px;cursor:pointer;transition:background-color var(--t) var(--ease)}
.newsletter button:hover{background:var(--accent-hover)}
.newsletter .privacy-note{font-family:var(--font-en);font-size:11.5px;color:var(--fg-mute);margin:14px 0 0;line-height:1.6}
.newsletter .privacy-note a{color:var(--fg-sub);border-bottom:1px solid var(--border-strong)}
.newsletter .nl-msg{margin:16px 0 0;font-size:14px;font-weight:600}
.newsletter .nl-msg.ok{color:var(--accent)}
.newsletter .nl-msg.err{color:var(--rose)}

/* —— Archive (page>=2) —— */
.archive-head{max-width:var(--maxw-wide);margin:0 auto;padding:96px 32px 0}
@media (max-width:600px){.archive-head{padding:64px 20px 0}}
.archive-head .eyebrow{font-family:var(--font-en);font-size:11px;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px;margin-bottom:20px}
.archive-head .eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}
.archive-head h1{font-family:var(--font-jp);font-size:clamp(28px,4vw,44px);line-height:1.3;letter-spacing:-0.015em;font-weight:700;margin-bottom:14px}
.archive-head .lead{font-size:15.5px;color:var(--fg-sub);line-height:1.85;max-width:560px}
.archive-grid-wrap{max-width:var(--maxw-wide);margin:0 auto;padding:48px 32px 0}
@media (max-width:600px){.archive-grid-wrap{padding:36px 20px 0}}

/* —— Pagination —— */
.pagination{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;max-width:var(--maxw-wide);margin:64px auto 0;padding:0 32px}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:44px;padding:10px 14px;border-radius:var(--r-btn);border:1px solid var(--border);background:var(--bg-card);font-family:var(--font-en);font-size:14px;font-weight:500;color:var(--fg-sub);transition:border-color var(--t) var(--ease),color var(--t) var(--ease),background-color var(--t) var(--ease)}
.pagination a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.pagination .current{background:var(--accent);border-color:var(--accent);color:#fff}

/* —— 404 —— */
.notfound{max-width:var(--maxw-content);margin:0 auto;padding:120px 32px;text-align:center}
.notfound h2{font-family:var(--font-display);font-size:96px;font-weight:800;letter-spacing:-0.04em;color:var(--fg);line-height:1}
.notfound p{color:var(--fg-sub);margin:8px 0}

/* —— Footer —— */
.site-footer{margin-top:140px;background:var(--bg-dark);color:var(--fg-on-dark);padding:80px 0 40px;position:relative}
.site-footer-inner{max-width:var(--maxw-wide);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
@media (max-width:800px){.site-footer-inner{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:600px){.site-footer-inner{grid-template-columns:1fr;padding:0 20px}}
.site-footer .brand .logo{color:var(--fg-on-dark)}
.site-footer .brand p{margin:18px 0 0;font-size:13.5px;color:var(--fg-on-dark-sub);line-height:1.85;max-width:320px}
.site-footer .col-label{font-family:var(--font-en);font-size:10.5px;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-on-dark-mute);margin-bottom:16px}
.site-footer .col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.site-footer .col a{color:var(--fg-on-dark-sub);font-family:var(--font-en);font-size:14px;transition:color var(--t) var(--ease)}
.site-footer .col a:hover{color:var(--fg-on-dark)}
.site-footer .bottom{max-width:var(--maxw-wide);margin:64px auto 0;padding:24px 32px 0;border-top:1px solid var(--border-on-dark);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-en);font-size:12px;color:var(--fg-on-dark-mute);flex-wrap:wrap;gap:12px}
.site-footer .bottom a{color:var(--fg-on-dark-sub)}
.site-footer .bottom a:hover{color:var(--fg-on-dark)}
@media (max-width:600px){.site-footer .bottom{padding:24px 20px 0}}

/* —— Legacy WP-content compatibility (kept from engine) —— */
.post-content figure,.post-content .wp-block-image,.post-content .wp-block-embed,.post-content table{max-width:100%;overflow:auto}
.post-content figure img,.post-content figure video{width:100%;height:auto}

.aff-banner{margin:40px 0;padding:24px 26px;border:1px solid var(--border);border-radius:var(--r-card);background:var(--bg-card);position:relative;}
.aff-banner-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding-bottom:12px;margin-bottom:16px;border-bottom:1px solid var(--border);}
.aff-banner-label{font-family:var(--font-en);font-size:10.5px;font-weight:700;letter-spacing:.2em;color:var(--fg-mute);text-transform:uppercase;}
.aff-banner-ad{font-family:var(--font-en);font-size:10px;font-weight:600;letter-spacing:.12em;color:var(--fg-mute);text-transform:uppercase;border:1px solid var(--border-strong);border-radius:var(--r-pill);padding:2px 9px;}
.aff-banner-product{display:flex;gap:18px;align-items:center;}
.aff-product-img{width:88px;height:88px;flex-shrink:0;border-radius:var(--r-btn);background:var(--accent-soft);border:1px solid var(--border);overflow:hidden;position:relative;}
.aff-product-img--photo img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.aff-product-img--ph::after{content:"";position:absolute;inset:0;display:block;background-image:linear-gradient(rgba(15,22,20,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(15,22,20,0.05) 1px,transparent 1px);background-size:14px 14px;}
.aff-product-meta{flex:1;min-width:0;}
.aff-product-name{font-family:var(--font-jp);font-weight:700;font-size:16px;line-height:1.5;margin-bottom:4px;color:var(--fg);letter-spacing:-.005em;}
.aff-product-spec{font-family:var(--font-en);font-size:12px;color:var(--fg-mute);margin-bottom:6px;letter-spacing:.02em;}
.aff-product-price{font-family:var(--font-en);font-weight:600;font-size:13px;color:var(--fg-sub);}
.aff-banner-cta{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;}
.aff-amazon,.aff-rakuten{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--r-btn);border:1px solid var(--accent);background:var(--accent);color:#fff;text-decoration:none;font-family:var(--font-en);font-weight:600;font-size:13.5px;letter-spacing:-.005em;transition:background-color var(--t,.22s) ease,border-color var(--t,.22s) ease;}
.aff-rakuten{background:transparent;color:var(--accent);}
.aff-amazon:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff;text-decoration:none;}
.aff-rakuten:hover{background:var(--accent-soft);color:var(--accent);text-decoration:none;}
.aff-cta-brand{font-size:10px;font-weight:700;letter-spacing:.14em;opacity:.7;}
.aff-cta-label{font-size:13.5px;}
.aff-banner-note{margin-top:16px;margin-bottom:0;font-family:var(--font-en);font-size:11px;color:var(--fg-mute);letter-spacing:.02em;line-height:1.6;}
/* specificity overrides: .article-body a {color:var(--accent)} を勝たせない */
.article-body a.aff-amazon{color:#fff;border-bottom:0;}
.article-body a.aff-amazon:hover{color:#fff;border-bottom:0;}
.article-body a.aff-rakuten{color:var(--accent);border-bottom:0;}

/* ─── 本文中インラインstyleの旧CTAを落ち着いたカードに置換 ─── */
.content-cta-card{margin:32px 0;padding:22px 24px;border:1px solid var(--border);border-radius:var(--r-card);background:var(--bg-tint);text-align:left;}
.content-cta-card-label{margin:0 0 14px;font-family:var(--font-en);font-size:11px;color:var(--fg-mute);font-weight:700;letter-spacing:.16em;text-transform:uppercase;}
.content-cta-row{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 0;}
.content-cta{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border-radius:var(--r-btn);border:1px solid var(--accent);background:var(--accent);color:#fff !important;text-decoration:none !important;font-family:var(--font-en);font-weight:600;letter-spacing:-.005em;font-size:13.5px;line-height:1.3;transition:background-color .22s ease;}
.content-cta:hover{background:var(--accent-hover);color:#fff !important;text-decoration:none !important;}
.content-cta-rakuten{background:transparent;color:var(--accent) !important;}
.content-cta-rakuten:hover{background:var(--accent-soft);color:var(--accent) !important;}

@media (max-width: 600px){
  .aff-banner{padding:20px;}
  .aff-banner-product{gap:14px;}
  .aff-product-img{width:64px;height:64px;}
  .aff-banner-cta{gap:8px;}
  .aff-amazon,.aff-rakuten{flex:1;justify-content:center;padding:10px 12px;}
}
