/* The Tokyo Local — vibrant edition. Warm Tokyo palette, color-blocked, editorial serif. Mobile-first. */
:root{
  --ink:#221f1d;
  --muted:#6b6560;
  --line:#efe7df;
  --bg:#ffffff;
  --band:#fff5ee;        /* warm peach band */
  --band2:#eafaf6;       /* fresh teal band */
  --card:#ffffff;
  --red:#e8472b;         /* primary — lantern/torii red, appetite */
  --red-dark:#c5371f;
  --yellow:#ffc233;      /* "deal" highlight */
  --yellow-ink:#5a4500;
  --teal:#0fa594;        /* secondary accent */
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,
    "Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --maxw:760px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  line-height:1.75;font-size:18px;border-top:5px solid var(--red);
}
a{color:var(--red-dark);text-decoration:underline;text-underline-offset:2px}
a:hover{color:var(--red)}
img{max-width:100%;height:auto;display:block}
.ph{background:linear-gradient(135deg,#ffe9e0,#ffd9cc);color:#c98a76;font-size:14px;
  font-family:var(--sans);display:flex;align-items:center;justify-content:center;text-align:center}

/* layout */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.site-header{border-bottom:1px solid var(--line);background:var(--card);position:sticky;top:0;z-index:50}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:13px 20px}
.brand{font-family:var(--serif);font-weight:800;font-size:24px;letter-spacing:.2px;text-decoration:none;color:var(--ink)}
.brand span{color:var(--red)}
.tagline{font-size:12px;color:var(--muted);margin:2px 0 0;letter-spacing:.3px}
.nav{flex-shrink:0}
.nav a{font-size:14px;margin-left:18px;color:var(--ink);text-decoration:none;font-weight:600}
.nav a:first-child{margin-left:0}
.nav a:hover{color:var(--red)}

/* ===== home hero: full-width photo band with overlay ===== */
.home-hero{position:relative;overflow:hidden;min-height:440px;display:flex;align-items:center}
.home-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.home-hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(34,31,29,.30),rgba(34,31,29,.62)),
             linear-gradient(90deg,rgba(232,71,43,.34),rgba(34,31,29,.05))}
.home-hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:56px 22px;color:#fff;text-align:center;width:100%}
.home-hero .kicker{display:inline-block;background:var(--yellow);color:var(--yellow-ink);
  font-weight:800;font-size:12px;letter-spacing:1.2px;text-transform:uppercase;padding:5px 12px;border-radius:999px;margin-bottom:16px}
.home-hero h1{font-family:var(--serif);font-weight:800;font-size:34px;line-height:1.18;margin:0 0 10px;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.home-hero .anti{font-family:var(--serif);font-style:italic;font-weight:700;font-size:21px;margin:0 auto 16px;max-width:30em;color:#fff;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.home-hero .anti span{color:var(--yellow);font-style:normal}
.home-hero p{font-size:16px;margin:0 auto;max-width:36em;color:#f0e9e4}

/* section header (Hololive-style: big head + subtitle + colored bar) */
.sec-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;padding:44px 0 8px;border-bottom:3px solid var(--red);margin-bottom:26px}
.sec-head h2{font-family:var(--serif);font-weight:800;font-size:30px;margin:0;line-height:1}
.sec-head span{color:var(--muted);font-size:14px;font-weight:600}

/* article cards */
.cards{display:grid;gap:26px;padding:0 0 16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 2px 0 rgba(232,71,43,.10);transition:box-shadow .15s ease,transform .15s ease}
.card:hover{box-shadow:0 14px 34px rgba(232,71,43,.16);transform:translateY(-3px)}
.card a{display:block;text-decoration:none;color:inherit}
.card .thumb{aspect-ratio:16/10;width:100%;object-fit:cover;display:block}
.card .body{padding:18px 22px 24px}
.card h2{font-family:var(--serif);font-weight:700;font-size:22px;line-height:1.28;margin:10px 0 9px}
.card p{color:var(--muted);font-size:15px;margin:0}
.more-line{color:var(--muted);font-size:14px;text-align:center;padding:10px 0 52px}

/* colored category pill */
.eyebrow{display:inline-block;background:var(--red);color:#fff;font-size:11px;font-weight:800;
  letter-spacing:1px;text-transform:uppercase;padding:4px 11px;border-radius:999px;margin:0}

/* article page */
article{background:var(--card);border:1px solid var(--line);border-radius:16px;margin:28px 0;padding:0 0 8px;overflow:hidden}
.post-hero{aspect-ratio:16/9;width:100%;object-fit:cover;display:block}
article > *:not(.post-hero):not(.support):not(.comments):not(.post-head){padding-left:32px;padding-right:32px}
.post-head{padding:24px 32px 22px;border-bottom:1px solid var(--line);margin-bottom:8px}
.post-head .eyebrow{margin-bottom:12px}
.post-head h1{font-family:var(--serif);font-weight:800;font-size:33px;line-height:1.2;margin:12px 0 12px}
.post-head .lede{color:var(--ink);font-size:18px;margin:0}
article h2{font-family:var(--serif);font-weight:700;font-size:26px;margin:36px 0 8px;line-height:1.26}
article h3{font-size:18px;margin:24px 0 6px}
article p{margin:14px 0}
article ul,article ol{margin:14px 0;padding-left:24px}
article li{margin:6px 0}
article li::marker{color:var(--red)}
article hr{border:0;border-top:1px solid var(--line);margin:32px 0}
.what-it-is{background:var(--band2);border-left:4px solid var(--teal);border-radius:0 8px 8px 0;padding:2px 16px;margin:14px 0;font-size:16px}

/* in-article figures */
figure.fig{margin:24px 0}
figure.fig .ph{aspect-ratio:16/9;border-radius:12px}
figure.fig img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:12px;display:block}
figure.fig figcaption{font-size:13px;color:var(--muted);margin-top:8px;text-align:center;font-style:italic}

/* callouts */
.note{background:var(--band);border:1px solid #f3ddcf;border-radius:12px;padding:14px 18px;margin:20px 0;font-size:15px;color:#7a5c48}
.rule{background:#fff1ed;border:1px solid #f6cabd;border-left:5px solid var(--red);border-radius:0 12px 12px 0;padding:16px 20px;margin:24px 0}
.rule strong{color:var(--red-dark)}

/* price tag — the "deal" pop */
.price{display:inline-block;background:var(--yellow);border-radius:6px;padding:0 8px;font-weight:800;color:var(--yellow-ink);white-space:nowrap}

/* affiliate / tools box */
.tools{background:var(--band2);border:1px solid #cfeee7;border-radius:14px;padding:6px 24px;margin:28px 0}
.tools h2{margin-top:18px}
.affiliate-slot,.ad-slot{margin:22px 0;text-align:center}
.ad-slot{min-height:90px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--line);border-radius:10px;color:#c3b6ac;font-size:13px}

/* buy me a coffee + comments */
.support{text-align:center;padding:32px;border-top:1px solid var(--line);background:var(--band);margin-top:8px}
.bmc{display:inline-block;background:var(--red);color:#fff;font-weight:800;text-decoration:none;border-radius:999px;padding:13px 26px;margin:10px 0;box-shadow:0 6px 18px rgba(232,71,43,.30)}
.bmc:hover{background:var(--red-dark);color:#fff}
.comments{padding:32px;border-top:1px solid var(--line)}
.comments h2{font-family:var(--serif);margin-top:0;font-size:22px}

/* footer — dark color block */
.site-footer{background:#221f1d;color:#cdc4bd;margin-top:48px}
.site-footer .wrap{padding:34px 20px;font-size:13px}
.site-footer a{color:#f0b8ac}
.site-footer .brand-sm{font-family:var(--serif);font-weight:800;color:#fff;font-size:16px}
.footer-nav{display:flex;flex-wrap:wrap;gap:8px 20px;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.15)}
.footer-nav a{color:#f0e9e4;text-decoration:none;font-weight:600;font-size:14px}
.footer-nav a:hover{color:var(--yellow)}

/* static info pages (about / contact / privacy / disclaimer) */
.page{background:var(--card);border:1px solid var(--line);border-radius:16px;margin:28px 0;padding:0 0 24px;overflow:hidden}
.page>*{padding-left:32px;padding-right:32px}
.page .page-head{padding:26px 32px 18px;border-bottom:1px solid var(--line);margin-bottom:8px}
.page h1{font-family:var(--serif);font-weight:800;font-size:32px;margin:0;line-height:1.2}
.page .updated{color:var(--muted);font-size:13px;margin:8px 0 0}
.page h2{font-family:var(--serif);font-weight:700;font-size:22px;margin:30px 0 6px}
.page p{margin:12px 0}
.page ul{margin:12px 0;padding-left:22px}
.page li{margin:6px 0}
.page li::marker{color:var(--red)}

@media(min-width:640px){
  .cards{grid-template-columns:1fr 1fr}
  .home-hero{min-height:480px}
  .home-hero h1{font-size:46px}
  .sec-head h2{font-size:36px}
  .post-head h1{font-size:42px}
}
