@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700;800&family=Zen+Kaku+Gothic+New:wght@400;500;700&family=Zen+Old+Mincho:wght@400;600;700;900&display=swap');
:root{
  --noir:#0e0e0f;--noir-2:#3a3b41;--blanc:#ffffff;--gris:#f2f2f4;--card:#ffffff;
  --rouge:#c8102e;--rouge-vif:#e10f20;--rouge-fonce:#8d0a1f;--anthra:#1c1d22;
  --line:#e4e4e7;--line-d:#2c2d34;--muted:#6c6d74;--footer:#121317;--ok:#1d6b4f;
  --mincho:'Zen Old Mincho','Shippori Mincho','Hiragino Mincho ProN','Yu Mincho',serif;
  --mincho2:'Shippori Mincho',serif;
  --gothic:'Zen Kaku Gothic New','Hiragino Kaku Gothic ProN','Yu Gothic',-apple-system,'Segoe UI',sans-serif;
  --mono:'SFMono-Regular',ui-monospace,'JetBrains Mono','Consolas',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--gothic);background:var(--blanc);color:var(--noir);line-height:1.78;-webkit-font-smoothing:antialiased}
a{color:var(--rouge-fonce)}
.wrap{max-width:1080px;margin:0 auto;padding:0 26px}
.narrow{max-width:760px}

/* HEADER (compact, 2 lignes : barre + nav) */
.s-top{background:var(--noir);color:#f2f2f4;border-bottom:3px solid var(--rouge);position:sticky;top:0;z-index:50}
.s-bar{max-width:1080px;margin:0 auto;display:flex;align-items:center;gap:12px;padding:8px 22px}
.s-mark{width:34px;height:34px;border-radius:50%;background:var(--rouge-vif);flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--mincho);font-weight:700;font-size:18px;text-decoration:none}
.s-logo{text-decoration:none;display:flex;align-items:baseline;gap:8px;line-height:1}
.s-logo .jp{font-family:var(--mincho);font-size:21px;font-weight:700;color:#fff;letter-spacing:.06em}
.s-logo .lat{font-family:var(--mincho2);font-size:10px;color:#cfcfd6;letter-spacing:.32em;text-transform:uppercase}
.s-util{margin-left:auto;display:flex;align-items:center;gap:4px;font-family:var(--mono);font-size:12px}
.s-util a{color:#cfcfd6;text-decoration:none;padding:4px 7px}
.s-util a:hover{color:#fff}
.s-util a.u-partner{color:#fff}
.s-search{background:#1b1c20;border:1px solid #34353c;color:#e8e8ec;padding:6px 11px;font-size:12.5px;width:120px;font-family:var(--gothic);margin-left:4px}
.s-burger{display:none;margin-left:auto;background:transparent;border:0;width:34px;height:34px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:0}
.s-burger span{display:block;height:2px;width:22px;background:#fff;transition:.2s}
.s-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.s-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.s-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.s-nav{background:#141519;border-top:1px solid var(--line-d)}
.s-nav .in{max-width:1080px;margin:0 auto;display:flex;flex-wrap:nowrap;overflow-x:auto;padding:0 22px;scrollbar-width:none}
.s-nav .in::-webkit-scrollbar{display:none}
.s-nav a{color:#cfcfd6;text-decoration:none;font-size:13px;padding:9px 12px;border-bottom:3px solid transparent;white-space:nowrap;flex:none}
.s-nav a span{display:block;font-family:var(--mincho2);font-size:8.5px;color:#7e7f87;letter-spacing:.12em;margin-bottom:1px}
.s-nav a:hover,.s-nav a.cur{color:#fff;border-bottom-color:var(--rouge)}
.s-nav .partner{margin-left:auto;color:#fff;background:var(--rouge)}
@media(max-width:720px){
  .s-bar{padding:7px 16px;gap:9px}
  .s-mark{width:30px;height:30px;font-size:16px}
  .s-logo .jp{font-size:18px}
  .s-logo .lat{display:none}
  .s-util{display:none}
  .s-burger{display:flex}
  .s-nav{display:none}
  .s-nav.open{display:block}
  .s-nav.open .in{flex-direction:column;overflow:visible;padding:6px 16px}
  .s-nav.open a{padding:11px 4px;border-bottom:1px solid var(--line-d);width:100%}
  .s-nav.open a span{display:inline;margin-right:8px;color:#9a9aa2}
  .s-nav.open .partner{margin-left:0;background:transparent;color:#ec8a93}
}

/* generic */
h1,h2,h3{font-family:var(--mincho)}
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--rouge);font-weight:600;display:flex;align-items:center;gap:10px;margin-bottom:12px}
.kicker:before{content:"";width:24px;height:3px;background:var(--rouge)}
.breadcrumb{font-family:var(--mono);font-size:12px;color:var(--muted);padding:18px 0 0}
.breadcrumb a{color:var(--muted);text-decoration:none}

/* HERO homepage */
.hero{display:grid;grid-template-columns:1.5fr 1fr;gap:30px;padding:32px 0 14px}
@media(max-width:820px){.hero{grid-template-columns:1fr}}
.feat .ph{height:300px;position:relative;overflow:hidden;border:1px solid var(--line);background:var(--anthra);display:block}
.feat .ph .sun{position:absolute;right:-45px;top:-45px;width:240px;height:240px;border-radius:50%;background:var(--rouge-vif)}
.feat .vlabel{position:absolute;top:0;left:0;background:var(--rouge);color:#fff;font-family:var(--mincho);font-size:14px;padding:12px 7px;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:.15em;z-index:3}
.feat .cat{font-family:var(--mincho2);font-size:12px;letter-spacing:.3em;color:var(--rouge);font-weight:600;margin-top:16px;display:block}
.feat h2{font-size:27px;font-weight:700;line-height:1.3;margin:8px 0 8px}
.feat h2 a{color:var(--noir);text-decoration:none}
.feat p{font-size:14.5px;color:var(--noir-2);margin-bottom:10px}
.feat .by{font-size:12px;color:var(--muted);font-family:var(--mono)}
.side{border-left:3px solid var(--rouge);padding-left:24px}
@media(max-width:820px){.side{border-left:none;padding-left:0}}
.side h3{font-size:16px;border-bottom:2px solid var(--noir);padding-bottom:9px;margin-bottom:4px;display:flex;gap:9px;align-items:baseline}
.side h3 .jp{font-size:11px;color:var(--rouge);font-family:var(--mincho2)}
.s-item{display:flex;gap:13px;padding:12px 0;border-bottom:1px solid var(--line)}
.s-item .num{font-family:var(--mincho);font-weight:700;font-size:12px;min-width:22px;height:22px;background:var(--rouge);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none}
.s-item h4{font-family:var(--mincho2);font-size:14px;line-height:1.4}
.s-item h4 a{color:var(--noir);text-decoration:none}
.s-item .d{font-size:11px;color:var(--muted);font-family:var(--mono)}

.secttitle{font-size:21px;font-weight:700;margin:30px 0 18px;display:flex;align-items:center;gap:14px}
.secttitle:before{content:"";width:11px;height:22px;background:var(--rouge);flex:none}
.secttitle .jp{font-size:13px;color:var(--rouge);letter-spacing:.3em;font-weight:400}
.secttitle:after{content:"";flex:1;height:2px;background:var(--noir)}
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:820px){.cardgrid{grid-template-columns:1fr}}
.post .ph{height:150px;background:var(--anthra);position:relative;overflow:hidden;border:1px solid var(--line);display:block}
.post .ph .dot{position:absolute;right:14px;top:14px;width:38px;height:38px;border-radius:50%;background:var(--rouge-vif);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--mincho);font-weight:700;font-size:20px;line-height:1}
.post .cat{font-family:var(--mincho2);font-size:10px;letter-spacing:.25em;color:var(--rouge);font-weight:600;margin-top:12px;display:block}
.post h4{font-size:18px;font-weight:700;line-height:1.35;margin:6px 0 8px}
.post h4 a{color:var(--noir);text-decoration:none}
.post p{font-size:13px;color:var(--noir-2)}

.lead-cta{background:var(--rouge);color:#fff;padding:34px 26px;text-align:center;margin:34px 0}
.lead-cta h2{color:#fff;font-size:26px;margin-bottom:8px}
.lead-cta p{color:#ffe1e5;max-width:560px;margin:0 auto 18px}
.lead-cta a{background:#fff;color:var(--rouge-fonce);text-decoration:none;padding:13px 28px;font-family:var(--mincho2);font-weight:700;display:inline-block}

/* ARTICLE / TUTO */
.art{padding:8px 0 40px}
.art .cat{font-family:var(--mincho2);font-size:12px;letter-spacing:.3em;color:var(--rouge);font-weight:600;text-transform:uppercase}
.art h1{font-size:34px;font-weight:700;line-height:1.25;margin:10px 0 12px}
.art .dek{font-size:18px;color:var(--noir-2);font-family:var(--mincho2);max-width:720px}
.art .meta{display:flex;align-items:center;gap:12px;margin:16px 0 0;padding-bottom:18px;border-bottom:2px solid var(--noir)}
.art .av{width:40px;height:40px;border-radius:50%;background:var(--anthra);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--mincho);font-size:16px;border:2px solid var(--rouge)}
.art .who{font-size:13px}.art .who span{color:var(--muted);font-family:var(--mono);font-size:11.5px}
.art .recovery{background:var(--gris);border-left:4px solid var(--rouge);padding:12px 16px;font-size:13px;color:var(--noir-2);margin:18px 0}
.art .body{max-width:720px;font-size:17px;color:#17171a;margin-top:22px}
.art .body h2{font-size:24px;font-weight:700;margin:30px 0 12px;display:flex;align-items:center;gap:11px}
.art .body h2:before{content:"";width:11px;height:23px;background:var(--rouge);flex:none}
.art .body p{margin-bottom:15px}
.art .body ul,.art .body ol{margin:0 0 15px 22px}
.art .body li{margin-bottom:7px}
.art .body strong{font-weight:600}
pre{background:var(--anthra);color:#e6e6ea;font-family:var(--mono);font-size:13px;padding:16px 18px;overflow:auto;line-height:1.55;margin:14px 0;border-left:3px solid var(--rouge)}
code{font-family:var(--mono);font-size:.92em;background:var(--gris);padding:1px 5px;border-radius:3px}
pre code{background:none;padding:0}
.callout{background:var(--anthra);color:#e8e8ec;padding:16px 18px;margin:18px 0;border-left:4px solid var(--rouge);font-size:15px}
.callout strong{color:#fff}
.related{border-top:1px solid var(--line);margin-top:30px;padding-top:18px;max-width:720px}
.related a{display:block;padding:7px 0;text-decoration:none;color:var(--noir);font-family:var(--mincho2);font-size:15px}
.related a:before{content:"› ";color:var(--rouge)}

/* hub list */
.hublist{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}
@media(max-width:760px){.hublist{grid-template-columns:1fr}}
.hubitem{border:1px solid var(--line);padding:16px 18px;background:var(--card)}
.hubitem:hover{border-color:var(--rouge)}
.hubitem .tag{font-family:var(--mono);font-size:10px;color:var(--rouge);letter-spacing:1px}
.hubitem h3{font-family:var(--mincho2);font-size:17px;margin:5px 0 5px}
.hubitem h3 a{color:var(--noir);text-decoration:none}
.hubitem p{font-size:13px;color:var(--noir-2)}

/* FOOTER */
.s-foot{background:var(--footer);color:#cfcfd6;padding:34px 0 24px;border-top:4px solid var(--rouge);margin-top:30px}
.s-foot .in{max-width:1080px;margin:0 auto;padding:0 26px}
.s-foot .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:26px}
@media(max-width:760px){.s-foot .cols{grid-template-columns:1fr 1fr}}
.s-foot h5{color:#fff;font-size:12px;margin-bottom:11px;font-family:var(--mincho2)}
.s-foot a,.s-foot .fi{display:block;color:#a3a4ab;text-decoration:none;font-size:13px;padding:3px 0}
.s-foot .flogo{font-family:var(--mincho);font-size:24px;color:#fff;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:8px}
.s-foot .flogo .disc{width:16px;height:16px;border-radius:50%;background:var(--rouge-vif)}
.s-foot .legal{border-top:1px solid var(--line-d);margin-top:22px;padding-top:14px;font-size:11.5px;color:#7e7f87;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

.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}
