/* ============================================================
   KBS ─ Korea Beauty Style（韓国コスメ レビューメディア）
   Editorial magazine ／ inorganic monotone × vermillion
   ------------------------------------------------------------
   STRUCTURE
     0. tokens (:root)        ── colors / type / layout / motion
     1. reset & base
     2. layout primitives     ── .container is the ONLY width source
     3. utilities & atoms     ── mono / kicker / cat / btn / ph …
     4. header & nav
     5. home (magazine)
     6. archive (list + aside)
     7. single (article)
     8. pages (about / contact)
     9. footer
    10. state (reveal / progress)
    11. responsive
   ------------------------------------------------------------
   WordPress note: every full-width block wraps its content in
   `.container`; the article reading column adds `.container--read`.
   Change a width once in :root and the whole site follows.
   Integration (thumbnails, admin-bar, Gutenberg): assets/css/wp.css
   ============================================================ */

/* ============================================================
   0. TOKENS
   ============================================================ */
:root{
  /* ── color : surfaces ── */
  --bg:        #F1F1EF;   /* page background (cool off-white) */
  --bg-sunk:   #E7E7E3;   /* sunken / placeholder fill        */
  --surface:   #FFFFFF;   /* cards, inputs                    */
  --dark:      #161618;   /* dark sections (footer, bands)    */
  --on-dark:   #F1F1EF;   /* text on dark                     */

  /* ── color : ink (text) ── */
  --ink:       #141416;   /* headings, primary text           */
  --ink-2:     #38383C;   /* body text                        */
  --ink-soft:  #76767C;   /* meta, captions, mono labels      */

  /* ── color : lines ── */
  --line:      #E0E0DC;   /* hairline dividers                */
  --line-2:    #D1D1CC;   /* stronger borders                 */

  /* ── color : accent (single vermillion) ── */
  --accent:    #E33B26;   /* the one accent                   */
  --accent-d:  #C02E1B;   /* hover / pressed                  */
  --accent-t:  #F6DDD7;   /* tint                             */

  /* ── typography : families ── */
  --font-serif:   'Zen Old Mincho', serif;            /* headings   */
  --font-sans:    'Zen Kaku Gothic New', sans-serif;  /* body       */
  --font-mono:    'IBM Plex Mono', monospace;         /* labels     */
  --font-display: 'Archivo', sans-serif;              /* big numerals */
  --font-black:   'Archivo Black', sans-serif;        /* outline wordmark */

  /* ── typography : scale (base 16px) ── */
  --fs-micro: 11px;
  --fs-label: 12px;
  --fs-sm:    13.5px;
  --fs-base:  16px;
  --fs-md:    18px;
  --fs-lg:    21px;
  --fs-xl:    26px;
  --fs-2xl:   33px;

  --lh-tight: 1.32;
  --lh-base:  1.8;
  --lh-read:  2.05;

  /* ── layout ── */
  --w-page:  1280px;   /* full content frame  */
  --w-read:   760px;   /* article reading column */
  --w-aside:  296px;   /* archive sidebar       */
  --gutter:    32px;   /* page side padding   */
  --radius:     2px;
  --space-hero-pad:  clamp(28px, 4vw, 44px);  /* hero inner bottom before border */
  --space-after-hero: clamp(34px, 4vw, 52px); /* after hero border → content     */
  --space-main-end:   clamp(60px, 7vw, 90px); /* main content end → footer       */

  /* ── breakpoints (match responsive section) ── */
  --bp-wide:   1080px;
  --bp-tablet:  900px;
  --bp-admin:   782px;
  --bp-narrow:  680px;

  /* ── motion ── */
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   1. RESET & BASE
   ============================================================ */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-sans); color:var(--ink); background:var(--bg);
  font-size:var(--fs-base); line-height:var(--lh-base); letter-spacing:.012em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  /* 和文折り返しのベース（禁則・単語途中改行禁止）。詳細は wp.css html[lang^="ja"] */
  word-break:normal; overflow-wrap:normal; line-break:strict;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul,ol{ list-style:none; }
::selection{ background:var(--accent); color:#fff; }

/* ============================================================
   2. LAYOUT PRIMITIVES  ── single source of truth for width
   ------------------------------------------------------------
   .container        full content frame (1280)
   .container--read  centered reading column (760)
   Every page-width block in the markup uses `.container`.
   Components below only handle their *inner* layout, never width.
   ============================================================ */
.container{
  width:100%;
  max-width:var(--w-page);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.container--read{ max-width:var(--w-read); }

/* ── Page vertical rhythm (shared across templates) ── */
.page-head + :is(.container, .container--read),
.masthead + .filterbar{
  padding-top:var(--space-after-hero);
}
#main > :is(.container--read, .container.container--read):last-child{
  padding-bottom:var(--space-main-end);
}
#main > .container.container--read.prose:last-child{
  padding-bottom:var(--space-main-end);
}
.page-head + .container.container--read.prose{
  padding-top:var(--space-after-hero);
}
#main > article.reading:last-child{
  padding-bottom:var(--space-main-end);
}
#main > .post-nav:last-child{
  padding-bottom:var(--space-main-end);
}
#main > .section:last-child{
  padding-bottom:var(--space-main-end);
}

/* section vertical rhythm */
.section{ padding-block:clamp(44px,5vw,68px); }
.section--tight{ padding-block:clamp(34px,4vw,52px); }

/* heading + rule — shared by every section header */
.rule-head{
  display:flex; align-items:baseline; justify-content:space-between; gap:20px;
  padding-bottom:clamp(14px,2vw,18px);
  border-bottom:1px solid var(--ink);
  margin-bottom:clamp(24px,3vw,38px);
}
.rule-head h2{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-xl); letter-spacing:.01em; }
.rule-head .mono{ letter-spacing:.16em; }

/* ============================================================
   3. UTILITIES & ATOMS
   ============================================================ */
.mono{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.13em; text-transform:uppercase; color:var(--ink-soft); }
.mono--accent{ color:var(--accent); }

.kicker{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.22em; text-transform:uppercase; color:var(--accent); display:inline-flex; align-items:center; gap:9px; }
.kicker::before{ content:""; width:18px; height:1px; background:var(--accent); display:inline-block; }

.cat{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); display:inline-flex; align-items:center; gap:6px; }
.cat::before{ content:""; width:6px; height:6px; background:var(--accent); border-radius:50%; }

.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.6em; font-family:var(--font-mono); font-size:var(--fs-label); letter-spacing:.07em; text-transform:uppercase; padding:14px 28px; border:1px solid var(--ink); color:var(--ink); border-radius:var(--radius); transition:.3s var(--ease); }
.btn:hover{ background:var(--ink); color:var(--bg); }
.btn--accent{ border-color:var(--accent); color:var(--accent); }
.btn--accent:hover{ background:var(--accent); color:#fff; }

.arrow{ font-family:var(--font-mono); font-size:var(--fs-label); letter-spacing:.05em; color:var(--accent); display:inline-flex; gap:.5em; align-items:center; }
.arrow::after{ content:"→"; transition:.3s var(--ease); }
.arrow:hover::after{ transform:translateX(5px); }

/* placeholder image */
.ph{ position:relative; overflow:hidden; background:var(--bg-sunk); display:grid; place-items:center;
  background-image:repeating-linear-gradient(135deg, transparent, transparent 16px, rgba(20,20,22,.025) 16px, rgba(20,20,22,.025) 17px); }
.ph__label{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); border:1px solid var(--line-2); background:rgba(255,255,255,.7); padding:5px 10px; }
.ph--16x10{ aspect-ratio:16/10; } .ph--16x9{ aspect-ratio:16/9; }
.ph--4x3{ aspect-ratio:4/3; } .ph--1x1{ aspect-ratio:1/1; }
.ph--3x4{ aspect-ratio:3/4; } .ph--wide{ aspect-ratio:21/8; }
.ph--zoom{ transition:transform .6s var(--ease); }
a:hover > .ph--zoom, .ed:hover .ph--zoom, .post-row:hover .ph--zoom, .rcard:hover .ph--zoom{ transform:scale(1.03); }

/* rating dots */
.rating{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--ink-2); }
.rating__dots{ display:inline-flex; gap:3px; }
.rating__dots i{ width:7px; height:7px; border-radius:50%; border:1px solid var(--accent); display:inline-block; }
.rating__dots i.on{ background:var(--accent); }

/* byline */
.byline{ display:inline-flex; align-items:center; gap:10px; }
.byline__ava{ width:28px; height:28px; border-radius:50%; background:var(--ink); color:var(--bg); display:grid; place-items:center; font-family:var(--font-serif); font-size:12px; }
.byline__txt{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.04em; color:var(--ink-soft); }
.byline__txt b{ color:var(--ink-2); font-weight:500; }

/* affiliate disclosure (article top) */
.aff-note{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:.01em; line-height:1.75; color:var(--ink-soft); border:1px solid var(--line-2); border-left:2px solid var(--accent); padding:13px 16px; }

/* ============================================================
   4. HEADER & NAV
   ============================================================ */
.util{ background:var(--dark); color:var(--on-dark); }
.util .container{ padding-block:8px; display:flex; justify-content:space-between; gap:16px; }
.util span{ font-family:var(--font-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:color-mix(in srgb,var(--on-dark) 66%, transparent); }
.util .ac{ color:var(--accent); }

.site-head{ position:sticky; top:0; z-index:100; background:color-mix(in srgb,var(--bg) 86%, transparent); backdrop-filter:blur(12px) saturate(1.1); border-bottom:1px solid var(--ink); }
.site-head .container{ height:64px; display:flex; align-items:center; gap:26px; }
.brand{ display:flex; align-items:center; margin-right:auto; }
.brand__logo{ display:block; width:auto; height:28px; }
.brand__logo--footer{ height:27px; }
/* outline / ghost wordmark — nameplate & legacy fallback */
.brand__mark{ font-family:var(--font-black); font-weight:400; font-size:21px; letter-spacing:.03em; line-height:1; color:transparent; -webkit-text-stroke:1.2px var(--ink); }
.brand__mark .wm-b{ -webkit-text-stroke-color:var(--accent); }
.brand__sub{ font-family:var(--font-mono); font-size:9.5px; letter-spacing:.16em; color:var(--ink-soft); text-transform:uppercase; }
.mainnav{ display:flex; gap:24px; }
.mainnav a{ font-family:var(--font-mono); font-size:var(--fs-label); letter-spacing:.08em; text-transform:uppercase; color:var(--ink-2); position:relative; padding:4px 0; }
.mainnav a::after{ content:""; position:absolute; left:0; bottom:-1px; width:0; height:1.5px; background:var(--accent); transition:.3s var(--ease); }
.mainnav a:hover::after, .mainnav a.is-current::after{ width:100%; }
.mainnav a.is-current{ color:var(--accent); }
.head-tools{ display:flex; align-items:center; gap:4px; }
.iconbtn{ width:36px; height:36px; display:grid; place-items:center; color:var(--ink-2); transition:.25s; }
.iconbtn:hover{ color:var(--accent); }
.menu-btn{ display:none; }

.search{ border-bottom:1px solid var(--line); background:var(--surface); max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.search.open{ max-height:120px; }
.search .container{ display:flex; align-items:center; gap:14px; height:76px; }
.search input{ flex:1; font-family:var(--font-serif); font-size:21px; background:none; border:none; color:var(--ink); }
.search input::placeholder{ color:var(--line-2); }
.search input:focus{ outline:none; }

/* ============================================================
   5. HOME (magazine)
   ============================================================ */
/* Zone dividers: one 1px line between major home blocks */
.cover-masthead,
.home-section,
.note-band{
  border-bottom:1px solid var(--ink);
}

/* nameplate */
.cover-masthead{ padding-block:clamp(30px,4vw,48px) var(--space-hero-pad); }
.cover-masthead .container{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:24px; }
.cover-masthead__side{ font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; color:var(--ink-soft); line-height:1.7; }
.cover-masthead__side.r{ text-align:right; }
.cover-masthead__side .ac{ color:var(--accent); }
.cover-masthead__stack{ display:flex; flex-direction:column; gap:6px; }
.cover-masthead__line{ display:block; }
.cover-masthead__tagline{ font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; color:var(--ink-soft); line-height:1.7; margin-inline-start:auto; }
.nameplate{ text-align:center; }
.nameplate h1{ font-family:var(--font-black); font-weight:400; font-size:clamp(48px,9vw,116px); line-height:.92; letter-spacing:.02em; display:inline-block; color:transparent; -webkit-text-stroke:clamp(1.8px,.3vw,3.2px) var(--ink); }
.nameplate h1 .wm-b{ -webkit-text-stroke-color:var(--accent); }
.nameplate p{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.34em; text-transform:uppercase; color:var(--ink-2); margin-top:14px; }

/* contents: lead story + TOC */
.contents .container{
  display:grid; grid-template-columns:1.62fr 1fr; gap:clamp(32px,4vw,60px);
  padding-block:clamp(34px,4vw,52px) clamp(40px,5vw,64px);
}
.contents .container > *{ min-width:0; }
.lead__body{ min-width:0; }
.lead__media{ position:relative; display:block; overflow:visible; }
.lead__media .ph{ aspect-ratio:16/9.6; }
.lead__no{
  position:absolute; left:clamp(10px,1.4vw,18px); top:clamp(28px,4vw,48px);
  font-family:var(--font-display); font-weight:800;
  font-size:clamp(56px,7.5vw,100px); line-height:.82;
  color:var(--ink); letter-spacing:-.03em;
  z-index:2; mix-blend-mode:multiply; pointer-events:none;
}
.lead__tag{ position:absolute; left:16px; bottom:16px; background:var(--accent); color:#fff; font-family:var(--font-mono); font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; padding:6px 12px; z-index:2; }
.lead__body{ padding-top:24px; }
.lead__kick{ display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.lead h2{ font-family:var(--font-serif); font-weight:700; font-size:clamp(26px,3.1vw,40px); line-height:1.34; letter-spacing:.006em; }
.lead h2 a:hover{ color:var(--accent-d); }
.lead__excerpt{ color:var(--ink-2); margin:16px 0 22px; font-size:var(--fs-sm); line-height:1.95; }
.lead__foot{ display:flex; align-items:center; gap:18px; }

.toc{ border-left:1px solid var(--line-2); padding-left:clamp(20px,2.4vw,34px); }
.toc__h{
  display:flex; align-items:baseline; justify-content:space-between;
  padding-bottom:14px; margin-bottom:6px;
  border-bottom:1px solid var(--ink);
}
.toc__h :is(h2,.t){ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-md); line-height:1.35; }
.toc__item{ display:grid; grid-template-columns:auto 1fr; gap:16px; padding:15px 0; border-bottom:1px solid var(--line); align-items:start; min-width:0; }
.toc__item > div{ min-width:0; }
.toc__item .idx{ font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--accent); padding-top:3px; }
.toc__item .meta{ display:flex; gap:10px; align-items:center; margin-bottom:5px; }
.toc__item .date{ font-family:var(--font-mono); font-size:10px; color:var(--ink-soft); }
.toc__item h3{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-sm); line-height:1.5; transition:.25s var(--ease); }
.toc__item:hover h3{ color:var(--accent-d); }

/* editorial 12-col grid */
.ed-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(28px,3vw,44px) clamp(24px,2.6vw,40px); }
.ed{ grid-column:span 4; }
.ed--feat{ grid-column:span 8; display:grid; grid-template-columns:1.15fr 1fr; gap:28px; align-items:center; }
.ed--feat > div{ min-width:0; }
.ed--side{ grid-column:span 4; align-self:stretch; display:flex; }
.ed--wide{ grid-column:span 12; display:grid; grid-template-columns:auto 1.1fr 1fr; gap:30px; align-items:center; padding:26px 0; border-top:1px solid var(--ink); border-bottom:1px solid var(--line); }
.ed__media{ position:relative; display:block; overflow:hidden; }
.ed__num{ font-family:var(--font-display); font-weight:800; font-size:clamp(40px,5vw,72px); line-height:.85; color:var(--ink); letter-spacing:-.03em; }
.ed__meta{ display:flex; align-items:center; gap:12px; margin:14px 0 9px; }
.ed__date{ font-family:var(--font-mono); font-size:10px; letter-spacing:.05em; color:var(--ink-soft); }
.ed h3{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-lg); line-height:1.5; letter-spacing:.005em; transition:.25s var(--ease); }
.ed:hover h3, .ed--feat:hover h3, .ed--wide:hover h3{ color:var(--accent-d); }
.ed--feat h3{ font-size:var(--fs-2xl); line-height:1.32; }
.ed__excerpt{ color:var(--ink-2); font-size:var(--fs-sm); line-height:1.9; margin-top:10px; }
.ed__foot{ display:flex; align-items:center; gap:16px; margin-top:14px; flex-wrap:wrap; }
.ed--side .ed__inner{ border:1px solid var(--ink); padding:24px; display:flex; flex-direction:column; width:100%; }
.ed--side .ed__num{ color:var(--accent); }
.ed--side h3{ font-size:var(--fs-md); margin-top:auto; }

/* editor's note (dark band) */
.note-band{ background:var(--dark); color:var(--on-dark); }
.note-band .container{ display:grid; grid-template-columns:auto 1fr; gap:clamp(30px,5vw,72px); align-items:center; padding-block:clamp(56px,7vw,90px); }
.note-band__label{ writing-mode:vertical-rl; font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.3em; text-transform:uppercase; color:var(--accent); }
.note-band blockquote{ font-family:var(--font-serif); font-weight:500; font-size:clamp(22px,2.8vw,34px); line-height:1.75; letter-spacing:.01em; }
.note-band .reveal{ min-width:0; }
.note-band blockquote .ac{ color:var(--accent); }
.note-band__by{ display:flex; align-items:center; gap:12px; margin-top:26px; }
.note-band__by .byline__ava{ background:var(--accent); color:#fff; }
.note-band__by .byline__txt{ color:color-mix(in srgb,var(--on-dark) 60%,transparent); }
.note-band__by .byline__txt b{ color:var(--on-dark); }

/* category index */
.cat-index__grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.cat-index__cell{ border-bottom:1px solid var(--line); border-right:1px solid var(--line); padding:26px 24px; transition:.3s var(--ease); position:relative; }
.cat-index__cell:nth-child(4n){ border-right:none; }
.cat-index__cell:hover{ background:var(--dark); color:var(--on-dark); }
.cat-index__cell .no{ font-family:var(--font-mono); font-size:10px; letter-spacing:.1em; color:var(--ink-soft); }
.cat-index__cell:hover .no{ color:var(--accent); }
.cat-index__cell h3{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-lg); margin:30px 0 6px; }
.cat-index__cell .n{ font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--ink-soft); }
.cat-index__cell:hover .n{ color:color-mix(in srgb,var(--on-dark) 60%,transparent); }

/* ============================================================
   6. ARCHIVE (list + aside)
   ============================================================ */
.masthead{ padding-block:clamp(40px,5vw,72px) var(--space-hero-pad); border-bottom:1px solid var(--ink); }
.masthead h1{ font-family:var(--font-serif); font-weight:700; line-height:1.2; font-size:clamp(28px,4vw,46px); margin-top:14px; }
.masthead__lead{ font-size:var(--fs-sm); color:var(--ink-2); margin-top:14px; line-height:1.95; }

.layout{ display:grid; grid-template-columns:minmax(0,1fr) var(--w-aside); gap:clamp(36px,5vw,64px); padding-block:clamp(40px,5vw,60px) var(--space-main-end); align-items:start; }
.sec-head{ display:flex; align-items:baseline; justify-content:space-between; gap:20px; padding-bottom:16px; border-bottom:1px solid var(--ink); margin-bottom:4px; }
.sec-head h2{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-xl); }

.post-row{ display:grid; grid-template-columns:30px minmax(140px,196px) minmax(0,1fr); gap:clamp(18px,2.5vw,26px); align-items:start; padding:26px 0; border-bottom:1px solid var(--line); }
.post-row > div{ min-width:0; }
.post-row__no{ font-family:var(--font-mono); font-size:var(--fs-label); color:var(--ink-soft); padding-top:3px; }
.post-row__media{ position:relative; overflow:hidden; }
.post-row__meta{ display:flex; align-items:center; gap:12px; margin-bottom:11px; }
.post-row__date{ font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--ink-soft); }
.post-row h3{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-lg); line-height:1.5; transition:.25s var(--ease); }
.post-row:hover h3{ color:var(--accent-d); }
.post-row__excerpt{ color:var(--ink-2); margin-top:9px; font-size:var(--fs-sm); line-height:1.9; min-width:0; }
.post-row__foot{ display:flex; align-items:center; gap:16px; margin-top:14px; flex-wrap:wrap; }
.list-more{ text-align:center; padding-top:42px; }

.aside{ position:sticky; top:88px; display:grid; gap:34px; }
.widget__h{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.14em; text-transform:uppercase; color:var(--ink); padding-bottom:12px; border-bottom:1px solid var(--ink); margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.widget__h::before{ content:""; width:6px; height:6px; background:var(--accent); border-radius:50%; }
.profile-card__top{ display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.profile-card__ava{ width:52px; height:52px; border-radius:50%; background:var(--ink); color:var(--bg); display:grid; place-items:center; font-family:var(--font-serif); font-size:21px; }
.profile-card__name{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-md); }
.profile-card__role{ font-family:var(--font-mono); font-size:10px; letter-spacing:.04em; color:var(--ink-soft); margin-top:3px; }
.profile-card p{ font-size:var(--fs-sm); color:var(--ink-2); line-height:1.9; }
.profile-card .arrow{ margin-top:14px; font-size:var(--fs-micro); }
.cat-list li{ border-bottom:1px solid var(--line); }
.cat-list a{ display:flex; align-items:center; justify-content:space-between; padding:11px 0; font-size:var(--fs-sm); color:var(--ink-2); transition:.25s var(--ease); }
.cat-list a:hover{ color:var(--accent); padding-left:6px; }
.cat-list .n{ font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--ink-soft); }
.tagcloud{ display:flex; flex-wrap:wrap; gap:8px; }
.tagcloud a{ font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--ink-2); border:1px solid var(--line-2); padding:6px 11px; transition:.25s var(--ease); }
.tagcloud a:hover{ border-color:var(--accent); color:var(--accent); }
.follow{ display:flex; gap:8px; }
.follow a{ flex:1; height:42px; display:grid; place-items:center; border:1px solid var(--line-2); color:var(--ink-2); transition:.25s var(--ease); }
.follow a:hover{ background:var(--ink); color:var(--bg); border-color:var(--ink); }
.note{ background:var(--bg-sunk); border:1px solid var(--line); padding:18px 20px; }
.note .mono{ display:block; margin-bottom:8px; }
.note p{ font-size:var(--fs-label); color:var(--ink-2); line-height:1.8; }

.filterbar{ display:flex; flex-wrap:wrap; gap:8px; padding-bottom:clamp(28px,3vw,40px); }
.filterbar a{ font-family:var(--font-mono); font-size:11px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-2); border:1px solid var(--line-2); padding:9px 16px; transition:.25s var(--ease); }
.filterbar a:hover{ border-color:var(--ink); }
.filterbar a.is-current{ background:var(--accent); border-color:var(--accent); color:#fff; }
.pagination{ display:flex; align-items:center; justify-content:center; gap:8px; padding-top:48px; }
.pagination a,
.pagination span,
.pagination .page-numbers{
  font-family:var(--font-mono); font-size:var(--fs-sm); min-width:40px; height:40px;
  display:grid; place-items:center; border:1px solid var(--line-2); color:var(--ink-2);
  transition:.25s var(--ease); padding:0 8px;
}
.pagination a:hover,
.pagination a.page-numbers:hover{ border-color:var(--ink); color:var(--ink); }
.pagination .is-current,
.pagination .current,
.pagination .page-numbers.current,
.pagination span.current{
  background:var(--ink); border-color:var(--ink); color:var(--bg);
}
.pagination .dots,
.pagination span.dots{ border:none; }

/* ============================================================
   7. SINGLE (article)  ── one consistent reading column
   ============================================================ */
.reading{ padding-top:clamp(34px,4vw,52px); }
.article-head{ text-align:center; }
.article-head__meta{ display:flex; align-items:center; justify-content:center; gap:14px; margin-bottom:20px; }
.article-head h1{ font-family:var(--font-serif); font-weight:700; font-size:clamp(28px,4vw,44px); line-height:1.42; letter-spacing:.01em; }
.article-head__sub{ color:var(--ink-2); margin-top:18px; font-size:var(--fs-md); line-height:1.95; }
.article-head__byline{ display:flex; justify-content:center; gap:14px; margin-top:clamp(28px,3vw,36px); padding-top:clamp(20px,2.5vw,26px); padding-bottom:clamp(6px,1vw,10px); border-top:1px solid var(--line); }
.article-hero{ margin-top:clamp(36px,5vw,56px); }
.article-body{ padding-top:clamp(36px,4vw,52px); }
.article-body > *{ margin-bottom:24px; }
.article-body > *:last-child{ margin-bottom:0; }
.article-body p{ font-size:var(--fs-md); line-height:var(--lh-read); color:var(--ink-2); }

/* ── headings (editorial section rhythm) ── */
.article-body h2{
  position:relative;
  font-family:var(--font-serif); font-weight:700;
  font-size:clamp(22px,3.2vw,var(--fs-xl));
  line-height:1.48; letter-spacing:.01em;
  margin:clamp(48px,6vw,68px) 0 22px;
  padding:20px 0 18px 22px;
  border-top:2px solid var(--ink);
  border-bottom:1px solid var(--line);
  color:var(--ink);
}
.article-body h2::before{
  content:"";
  position:absolute; left:0; top:24px; bottom:22px;
  width:4px; background:var(--accent);
}
.article-body h2 .mono{
  display:block; margin-bottom:8px;
  font-family:var(--font-mono); font-size:var(--fs-micro);
  letter-spacing:.12em; text-transform:uppercase; color:var(--accent);
  font-weight:400;
}
.article-body > h2:first-child{ margin-top:0; }

.article-body h3{
  font-family:var(--font-serif); font-weight:700;
  font-size:var(--fs-lg); line-height:1.55;
  margin:36px 0 14px; padding-left:16px;
  border-left:3px solid var(--accent);
  color:var(--ink);
}
.article-body h4{
  font-family:var(--font-mono); font-weight:500;
  font-size:var(--fs-label); letter-spacing:.08em;
  text-transform:uppercase; color:var(--ink);
  margin:28px 0 10px;
  display:flex; align-items:center; gap:10px;
}
.article-body h4::before{
  content:""; width:8px; height:8px;
  background:var(--accent); border-radius:50%; flex:none;
}

.article-body figure{ margin:36px 0; }
.article-body figcaption{ font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--ink-soft); margin-top:10px; text-align:center; }
.article-body blockquote{
  position:relative;
  border-left:2px solid var(--accent);
  padding:8px 0 8px clamp(20px,3vw,28px);
  margin:32px 0;
  font-family:var(--font-serif); font-size:var(--fs-lg);
  line-height:1.85; color:var(--ink-2);
  background:linear-gradient(90deg, color-mix(in srgb,var(--accent-t) 55%,transparent), transparent 72%);
}
.article-body hr{
  border:none; height:1px; background:var(--line);
  margin:clamp(36px,5vw,52px) 0;
  position:relative;
}
.article-body hr::after{
  content:""; position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%);
  width:7px; height:7px; background:var(--accent); border-radius:50%;
}
.article-body a.inline{
  color:var(--accent);
  border-bottom:none;
  text-decoration:underline;
  text-decoration-color:color-mix(in srgb,var(--accent) 35%,transparent);
  text-underline-offset:3px;
}

/* ── custom bullet list (.bullets) ── */
.article-body ul.bullets{
  margin:0 0 28px; padding:0; list-style:none;
}
.article-body ul.bullets li{
  position:relative; padding-left:22px; margin-bottom:12px;
  font-size:var(--fs-base); line-height:var(--lh-read); color:var(--ink-2);
}
.article-body ul.bullets li::before{
  content:""; position:absolute; left:0; top:.78em;
  width:6px; height:6px; background:var(--accent); border-radius:50%;
}
.article-body ul.bullets li:last-child{ margin-bottom:0; }

.article-tags{ margin-top:clamp(36px,4vw,52px); padding-top:28px; border-top:1px solid var(--line); }
.article-tags .mono{ display:block; margin-bottom:14px; color:var(--accent); }
.tagcloud a.is-current{ background:var(--accent); border-color:var(--accent); color:#fff; }

.review-box{ background:var(--surface); border:1px solid var(--ink); padding:clamp(22px,3vw,30px); margin:14px 0 38px; }
.review-box__h{ display:flex; align-items:center; gap:10px; padding-bottom:16px; border-bottom:1px solid var(--line); margin-bottom:20px; }
.review-box__h .mono{ color:var(--accent); }
.review-box__grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px 28px; }
.spec{ display:flex; flex-direction:column; gap:3px; padding:6px 0; border-bottom:1px dotted var(--line-2); }
.spec dt{ font-family:var(--font-mono); font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
.spec dd{ font-size:var(--fs-sm); }
.spec dd b{ color:var(--accent); font-weight:700; }
.review-box__score{ display:flex; align-items:baseline; gap:10px; margin-top:18px; }
.review-box__score .big{ font-family:var(--font-display); font-weight:800; font-size:42px; line-height:1; color:var(--accent); }
.review-box__score .of{ font-family:var(--font-mono); font-size:var(--fs-label); color:var(--ink-soft); }

.proscons{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:14px 0 38px; }
.pc{ border:1px solid var(--line-2); padding:20px 22px; }
.pc h4{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.08em; text-transform:uppercase; margin-bottom:14px; }
.pc--good h4{ color:var(--accent); } .pc--bad h4{ color:var(--ink-2); }
.pc li{ font-size:var(--fs-sm); line-height:1.8; padding-left:18px; position:relative; margin-bottom:8px; color:var(--ink-2); }
.pc--good li::before{ content:"+"; position:absolute; left:0; color:var(--accent); font-family:var(--font-mono); }
.pc--bad li::before{ content:"−"; position:absolute; left:0; color:var(--ink-soft); font-family:var(--font-mono); }

.author-box{ margin-top:clamp(40px,5vw,56px); }
.author-box__in{ display:flex; gap:20px; align-items:flex-start; border-top:2px solid var(--ink); border-bottom:1px solid var(--line); padding:24px 0; }
.author-box__ava{ width:60px; height:60px; border-radius:50%; background:var(--ink); color:var(--bg); display:grid; place-items:center; font-family:var(--font-serif); font-size:25px; flex:none; }
.author-box__name{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-md); }
.author-box__role{ font-family:var(--font-mono); font-size:10px; color:var(--ink-soft); margin:3px 0 10px; }
.author-box p{ font-size:var(--fs-sm); color:var(--ink-2); line-height:1.9; }

.post-nav{ padding-block:clamp(34px,4vw,46px); display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.post-nav a{ border:1px solid var(--line-2); padding:18px 20px; transition:.3s var(--ease); }
.post-nav a:hover{ border-color:var(--accent); }
.post-nav .mono{ display:block; margin-bottom:8px; }
.post-nav .t{ font-family:var(--font-serif); font-size:var(--fs-sm); line-height:1.5; }
.post-nav a.next{ text-align:right; }

.related{ border-top:1px solid var(--ink); padding-block:clamp(48px,6vw,72px) var(--space-main-end); }
.related__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:26px; }
.rcard__media{ overflow:hidden; }
.rcard h3{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-md); line-height:1.5; margin-top:14px; transition:.25s var(--ease); }
.rcard:hover h3{ color:var(--accent-d); }
.rcard__meta{ display:flex; gap:12px; align-items:center; margin-top:10px; }

/* ============================================================
   8. PAGES (about / contact)
   ============================================================ */
.page-head{ padding-block:clamp(44px,6vw,80px) var(--space-hero-pad); border-bottom:1px solid var(--ink); text-align:center; }
.page-head h1{ font-family:var(--font-serif); font-weight:700; font-size:clamp(30px,4.4vw,52px); line-height:1.3; margin-top:16px; }
.page-head p{ color:var(--ink-2); margin-top:16px; font-size:var(--fs-sm); }
.prose{ padding-block:0; }
.container--read > .prose:not(:first-child){ margin-top:clamp(40px,5vw,60px); }
.prose p{ font-size:var(--fs-base); line-height:var(--lh-read); margin-bottom:22px; }
.prose h2{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-xl); margin:40px 0 14px; }
.prose .mono{ display:block; margin-bottom:6px; }
.prose .legal-date{ font-family:var(--font-mono); font-size:var(--fs-micro); color:var(--ink-soft); margin-bottom:28px; }
.prose ul.bullets{ margin:0 0 22px; padding:0; list-style:none; }
.prose ul.bullets li{ position:relative; padding-left:22px; margin-bottom:10px; font-size:var(--fs-base); line-height:var(--lh-read); }
.prose ul.bullets li::before{ content:""; position:absolute; left:0; top:13px; width:6px; height:6px; background:var(--accent); border-radius:50%; }
.qa{ border-top:1px solid var(--ink); }
.qa__item{ border-bottom:1px solid var(--line); padding:22px 0; }
.qa__q{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-md); display:flex; gap:12px; }
.qa__q::before{ content:"Q"; font-family:var(--font-mono); color:var(--accent); }
.qa__a{ font-size:var(--fs-sm); color:var(--ink-2); line-height:1.95; margin-top:10px; padding-left:24px; }
.profile-hero{ display:grid; grid-template-columns:200px minmax(0,1fr); gap:36px; align-items:start; padding-top:clamp(38px,5vw,56px); }
.page-head + .container--read > .profile-hero:first-child{ padding-top:0; }
.profile-hero > div{ min-width:0; }
.profile-hero__ava{ width:200px; aspect-ratio:1; flex:none; }
.profile-hero h2{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-2xl); }
.profile-hero .profile-card__role{ font-size:var(--fs-label); margin:6px 0 14px; color:var(--ink-soft); }
.profile-hero__bio{ color:var(--ink-2); font-size:var(--fs-base); line-height:var(--lh-read); text-wrap:pretty; }
.profile-hero__bio p{ margin:0 0 1em; line-height:inherit; }
.profile-hero__bio p:last-child{ margin-bottom:0; }
.profile-hero__bio h3{ font-family:var(--font-serif); font-weight:700; font-size:var(--fs-lg); margin:1.4em 0 .6em; color:var(--ink); }
.stat-row{ display:flex; flex-wrap:wrap; gap:28px 36px; margin-top:28px; }
.stat-row .num{ font-family:var(--font-display); font-weight:800; font-size:30px; line-height:1; }
.stat-row .lbl{ font-family:var(--font-mono); font-size:11px; letter-spacing:.04em; color:var(--ink-soft); margin-top:6px; }

.form{ max-width:560px; padding-block:clamp(40px,5vw,56px); display:grid; gap:20px; }
.field{ display:grid; gap:8px; }
.field label{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-2); }
.field input, .field textarea{ font-family:var(--font-sans); font-size:var(--fs-base); color:var(--ink); background:var(--surface); border:1px solid var(--line-2); padding:13px 15px; }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--accent); }
.field textarea{ min-height:150px; resize:vertical; }

/* ============================================================
   9. FOOTER
   ============================================================ */
.site-foot{ background:var(--dark); color:var(--on-dark); padding-block:clamp(52px,6vw,76px) 26px; }
.site-foot__top{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px; }
.site-foot__brand .brand__logo--footer{ height:27px; }
.site-foot__brand .brand__mark .wm-b{ -webkit-text-stroke-color:var(--accent); }
.site-foot__brand p{ font-size:var(--fs-sm); color:color-mix(in srgb,var(--on-dark) 60%,transparent); margin-top:16px; line-height:1.9; }
.fcol h4{ font-family:var(--font-mono); font-size:var(--fs-micro); letter-spacing:.12em; text-transform:uppercase; color:color-mix(in srgb,var(--on-dark) 52%,transparent); margin-bottom:16px; }
.fcol a{ display:block; font-size:var(--fs-sm); color:color-mix(in srgb,var(--on-dark) 82%,transparent); padding:6px 0; transition:.25s var(--ease); }
.fcol a:hover{ color:var(--accent); padding-left:4px; }
.site-foot__sns{ display:flex; gap:10px; margin-top:20px; }
.site-foot__sns a{ width:38px; height:38px; border:1px solid color-mix(in srgb,var(--on-dark) 22%,transparent); display:grid; place-items:center; color:color-mix(in srgb,var(--on-dark) 75%,transparent); transition:.25s var(--ease); }
.site-foot__sns a:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }
.site-foot__note{ margin-top:clamp(36px,4vw,52px); padding-top:16px; border-top:1px solid color-mix(in srgb,var(--on-dark) 16%,transparent); }
.site-foot__note small{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.02em; line-height:1.85; color:color-mix(in srgb,var(--on-dark) 48%,transparent); }
.site-foot__bottom{ margin-top:18px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.site-foot__bottom small{ font-family:var(--font-mono); font-size:var(--fs-micro); color:color-mix(in srgb,var(--on-dark) 48%,transparent); }

/* ============================================================
   10. STATE (reveal / progress)
   ============================================================ */
.reveal{ opacity:1; transform:none; }
.js .reveal{ opacity:0; transform:translateY(20px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.js .reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .js .reveal{ opacity:1; transform:none; transition:none; } }
.progress{ position:fixed; top:0; left:0; height:2px; width:0; background:var(--accent); z-index:200; transition:width .1s linear; }

/* ============================================================
   11. RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .contents .container{ grid-template-columns:1fr; gap:40px; }
  .toc{ border-left:none; padding-left:0; }
  .ed--feat{ grid-column:span 12; }
  .ed--side{ grid-column:span 6; }
  .ed{ grid-column:span 6; }
  .ed--wide{ grid-template-columns:auto 1fr; }
  .ed--wide .ed__excerpt{ display:none; }
  .cat-index__grid{ grid-template-columns:repeat(2,1fr); }
  .cat-index__cell:nth-child(4n){ border-right:1px solid var(--line); }
  .cat-index__cell:nth-child(2n){ border-right:none; }
  .layout{ grid-template-columns:1fr; }
  .aside{ position:static; grid-template-columns:repeat(2,1fr); gap:34px 40px; }
  .related__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px){
  .post-row{ grid-template-columns:24px minmax(112px,160px) minmax(0,1fr); gap:18px; padding:22px 0; }
  .profile-hero{ grid-template-columns:minmax(140px,180px) minmax(0,1fr); gap:28px; }
  .profile-hero__ava{ width:min(180px,40vw); }
}
@media (max-width:680px){
  :root{ --gutter:20px; --w-aside:100%; }
  .site-head .container{ height:56px; gap:14px; }
  .brand__logo{ height:24px; }
  .brand__sub{ display:none; }
  .mainnav{ position:fixed; inset:56px 0 auto; flex-direction:column; gap:0; background:var(--surface); border-bottom:1px solid var(--ink); padding:6px var(--gutter) 16px; transform:translateY(-130%); transition:transform .4s var(--ease); z-index:90; }
  .mainnav.open{ transform:translateY(0); }
  .mainnav a{ padding:14px 0; border-bottom:1px solid var(--line); font-size:var(--fs-sm); }
  .menu-btn{ display:grid; }
  .search .container{ height:64px; }
  .search input{ font-size:18px; }
  .cover-masthead .container{ grid-template-columns:1fr; gap:14px; text-align:center; }
  .cover-masthead__side, .cover-masthead__side.r{ text-align:center; }
  .cover-masthead__stack{ align-items:center; }
  .cover-masthead__tagline{ margin-inline:auto; }
  .contents .container{ padding-block:clamp(28px,5vw,40px) clamp(32px,5vw,48px); gap:32px; }
  .lead__no{ font-size:clamp(40px,11vw,64px); top:clamp(14px,3vw,24px); left:clamp(8px,2vw,14px); }
  .lead__tag{ left:12px; bottom:12px; font-size:10px; padding:5px 10px; }
  .lead h2{ font-size:clamp(22px,5.5vw,28px); }
  .ed, .ed--feat, .ed--side{ grid-column:span 12; }
  .ed--feat{ grid-template-columns:1fr; gap:18px; }
  .ed--wide{ grid-template-columns:1fr; gap:14px; }
  .ed--wide .ed__num{ display:none; }
  .note-band .container{ grid-template-columns:1fr; gap:20px; }
  .note-band__label{ writing-mode:horizontal-tb; }
  .cat-index__grid{ grid-template-columns:1fr; }
  .cat-index__cell, .cat-index__cell:nth-child(2n){ border-right:none; }
  .post-row{ grid-template-columns:1fr; gap:14px; }
  .post-row__no{ display:none; }
  .post-row__media .ph{ aspect-ratio:16/9; }
  .aside{ grid-template-columns:1fr; }
  .proscons, .review-box__grid, .related__grid, .post-nav{ grid-template-columns:1fr; }
  .profile-hero{ grid-template-columns:1fr; text-align:center; justify-items:center; }
  .profile-hero__ava{ width:150px; }
  .stat-row{ justify-content:center; }
  .site-foot__top{ grid-template-columns:1fr 1fr; gap:28px; }
  .site-foot__brand{ grid-column:1/-1; }
}
