/* ============================================================
   Site 001 · Swiss Editorial Grid (International Typographic Style)
   Layout archetype: Magazine single-column (magazine-1col)
   Self-contained — no remote assets, system/inline fonts only
   ============================================================ */
:root{
  /* role-based palette (light — dark flag is false, palette unchanged) */
  --bg:#F4F2EC;
  --surface:#FBFAF6;
  --surface-alt:#EAE7DD;
  --text:#16140F;
  --muted:#5C584E;
  --border:#1C1A14;
  --border-soft:#D6D2C6;
  --accent:#C21824;     /* signal red */
  --accent-2:#16140F;   /* ink-black fill */
  --success:#1F7A3D;
  --warning:#B26A00;
  --white:#FBFAF6;

  /* type */
  --font-body:"Pretendard","Apple SD Gothic Neo","Malgun Gothic",system-ui,sans-serif;
  --font-display:"Helvetica Neue",Helvetica,Arial,sans-serif;
  --font-mono:"IBM Plex Mono","SFMono-Regular",Consolas,"Courier New",monospace;

  /* 8pt scale */
  --s1:4px; --s2:8px; --s3:16px; --s4:24px; --s5:32px; --s6:48px; --s7:64px; --s8:96px;

  /* layout */
  --band:1120px;
  --column:760px;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  letter-spacing:-0.01em;
  -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;display:block;}
a{color:var(--text);text-decoration:none;}
a:hover{text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:3px;}

a:focus-visible,button:focus-visible,input:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}

.skip{position:absolute;left:-999px;top:0;background:var(--accent-2);color:var(--white);padding:10px 16px;z-index:50;}
.skip:focus{left:8px;top:8px;}

.kicker{
  font-family:var(--font-display);
  font-weight:700;
  font-size:12px;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--text);
}
.num{
  font-family:var(--font-mono);
  font-weight:700;
  color:var(--accent);
  font-size:13px;
  letter-spacing:0.04em;
}
.meta{
  font-family:var(--font-mono);
  font-size:13px;
  line-height:1.4;
  color:var(--muted);
}

/* ---------- 1. SLIM MASTHEAD ---------- */
.masthead{
  background:var(--surface);
  border-bottom:2px solid var(--border);
}
.masthead__inner{
  max-width:var(--band);
  margin:0 auto;
  padding:var(--s3) var(--s4);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--s4);
}
.wordmark{
  display:flex;
  align-items:baseline;
  gap:10px;
  font-family:var(--font-display);
  font-weight:900;
  font-size:24px;
  letter-spacing:-0.02em;
  color:var(--text);
}
.wordmark .mark{
  display:inline-block;
  width:14px;height:28px;
  background:var(--accent);
  transform:translateY(3px);
}
.wordmark small{
  font-family:var(--font-mono);
  font-weight:500;
  font-size:11px;
  letter-spacing:0.06em;
  color:var(--muted);
}
.search{
  display:flex;
  align-items:flex-end;
  gap:0;
}
.search input{
  font-family:var(--font-body);
  font-size:15px;
  color:var(--text);
  background:transparent;
  border:0;
  border-bottom:2px solid var(--border);
  height:44px;
  padding:0 8px;
  min-width:180px;
}
.search input::placeholder{color:var(--muted);}
.search input:focus{outline:none;border-bottom-color:var(--accent);}
.search button{
  font-family:var(--font-display);
  font-weight:700;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.06em;
  color:var(--white);
  background:var(--accent-2);
  border:0;
  height:44px;
  min-width:44px;
  padding:0 16px;
  cursor:pointer;
  transition:background .12s ease-out;
}
.search button:hover{background:var(--accent);}

/* nav */
.nav{
  max-width:var(--band);
  margin:0 auto;
  padding:0 var(--s4);
}
.nav__row{
  display:flex;
  align-items:stretch;
  flex-wrap:wrap;
}
.nav a{
  font-family:var(--font-display);
  font-weight:700;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:var(--text);
  padding:14px 20px;
  border-left:1px solid var(--border-soft);
  position:relative;
  min-height:44px;
  display:flex;
  align-items:center;
}
.nav a:first-child{border-left:0;padding-left:0;}
.nav a:hover{text-decoration:none;color:var(--accent);}
.nav a[aria-current="page"]::after,
.nav a.active::after{
  content:"";position:absolute;left:20px;right:20px;bottom:0;height:2px;background:var(--accent);
}
.nav a[aria-current="page"]:first-child::after,
.nav a.active:first-child::after{left:0;}
.nav__toggle{display:none;}

/* ---------- main wrapper ---------- */
main{display:block;}

/* ---------- 2. LEAD STORY (full-width band) ---------- */
.lead{
  max-width:var(--band);
  margin:0 auto;
  padding:var(--s6) var(--s4) var(--s5);
}
.lead__num{
  display:flex;align-items:center;gap:12px;
  border-bottom:2px solid var(--border);
  padding-bottom:12px;margin-bottom:var(--s4);
}
.lead__num .kicker{color:var(--text);}
.site-h1{
  font-family:var(--font-body);
  font-weight:800;
  font-size:39px;
  line-height:1.15;
  letter-spacing:-0.02em;
  margin:0 0 var(--s4);
  max-width:18ch;
}
.lead__grid{
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:var(--s5);
  align-items:start;
}
.figure{
  position:relative;
  border:1px solid var(--border-soft);
  background:var(--surface);
}
.figure svg{width:100%;height:auto;display:block;}
.figure__num{
  position:absolute;top:0;left:0;
  background:var(--accent);
  color:var(--white);
  font-family:var(--font-mono);
  font-weight:700;
  font-size:13px;
  padding:4px 9px;
  letter-spacing:0.04em;
}
.lead__body h2{
  font-family:var(--font-body);
  font-weight:800;
  font-size:26px;
  line-height:1.2;
  letter-spacing:-0.01em;
  margin:0 0 var(--s3);
}
.lead__body h2 a:hover{color:var(--accent);}
.deck{
  font-size:17px;
  line-height:1.6;
  color:var(--text);
  margin:0 0 var(--s4);
  max-width:42ch;
}
.byline{
  border-top:1px solid var(--border-soft);
  padding-top:var(--s3);
  display:flex;
  flex-wrap:wrap;
  gap:6px 16px;
  align-items:center;
}
.lead__cta{margin-top:var(--s4);display:flex;gap:12px;flex-wrap:wrap;}

/* buttons */
.btn{
  font-family:var(--font-body);
  font-weight:600;
  font-size:15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 20px;
  border-radius:0;
  cursor:pointer;
  border:1.5px solid var(--border);
  transition:background .12s ease-out,color .12s ease-out;
}
.btn--primary{background:var(--accent-2);color:var(--white);border-color:var(--accent-2);}
.btn--primary:hover{background:var(--accent);border-color:var(--accent);text-decoration:none;}
.btn--secondary{background:transparent;color:var(--text);}
.btn--secondary:hover{background:var(--accent-2);color:var(--white);text-decoration:none;}

/* ---------- 3. ARTICLE COLUMN (single 760px) ---------- */
.column{
  max-width:var(--column);
  margin:0 auto;
  padding:0 var(--s4) var(--s6);
}
.section-rule{
  display:flex;align-items:center;gap:12px;
  border-top:2px solid var(--border);
  padding-top:12px;
  margin:var(--s6) 0 var(--s4);
}
.section-rule h2{
  font-family:var(--font-body);
  font-weight:700;
  font-size:24px;
  line-height:1.2;
  letter-spacing:-0.01em;
  margin:0;
}

.article-list{list-style:none;margin:0;padding:0;}
.article{
  display:grid;
  grid-template-columns:0.42fr 0.58fr;
  gap:var(--s4);
  align-items:start;
  padding:var(--s5) 0;
  border-top:2px solid var(--border);
}
.article:first-child{border-top:0;padding-top:var(--s2);}
.article--right .article__fig{order:2;}
.article--right .article__txt{order:1;}
.article__txt .kicker{display:inline-block;margin-bottom:10px;}
.article__txt h3{
  font-family:var(--font-body);
  font-weight:600;
  font-size:20px;
  line-height:1.3;
  letter-spacing:-0.01em;
  margin:0 0 10px;
}
.article__txt h3 a:hover{color:var(--accent);}
.excerpt{
  font-size:15px;
  line-height:1.65;
  color:var(--text);
  margin:0 0 14px;
}
.article__meta{
  display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center;
}
.chip{
  font-family:var(--font-display);
  font-weight:700;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.06em;
  color:var(--text);
  border:1px solid var(--border);
  padding:3px 8px;
  border-radius:0;
  line-height:1;
}
.chip--open{border-color:var(--success);}
.chip--soon{border-color:var(--warning);}
.chip--new{background:var(--accent);color:var(--white);border-color:var(--accent);}

/* ---------- 4. MORE LIST + PAGER ---------- */
.morelist{
  border-top:2px solid var(--border);
  border-bottom:2px solid var(--border);
}
.morelist table{width:100%;border-collapse:collapse;}
.morelist caption{
  text-align:left;
  font-family:var(--font-display);
  font-weight:700;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  padding:14px 0;
  color:var(--text);
}
.morelist th,.morelist td{
  text-align:left;
  padding:13px 10px;
  border-top:1px solid var(--border-soft);
  font-size:15px;
}
.morelist thead th{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:0.04em;
  border-top:0;
}
.morelist td.col-num,.morelist th.col-num{width:48px;}
.morelist td.col-num{font-family:var(--font-mono);color:var(--accent);font-weight:700;font-size:13px;}
.morelist td.col-date,.morelist th.col-date,
.morelist td.col-hit,.morelist th.col-hit{font-family:var(--font-mono);font-size:13px;color:var(--muted);white-space:nowrap;}
.morelist td.col-title a{font-weight:600;}
.morelist td.col-title a:hover{color:var(--accent);}
.morelist tbody tr:hover{background:var(--surface-alt);}

.pager{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:6px;
  margin:var(--s5) 0 0;
  flex-wrap:wrap;
}
.pager a,.pager span{
  font-family:var(--font-mono);
  font-size:14px;
  min-width:44px;
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border-soft);
  color:var(--text);
}
.pager a:hover{border-color:var(--border);text-decoration:none;}
.pager [aria-current="page"]{background:var(--accent-2);color:var(--white);border-color:var(--accent-2);}

/* ---------- FOOTER ---------- */
footer{
  background:var(--surface);
  border-top:2px solid var(--border);
  margin-top:var(--s7);
}
.footer__inner{
  max-width:var(--band);
  margin:0 auto;
  padding:var(--s5) var(--s4) var(--s6);
}
.footer__links{
  display:flex;flex-wrap:wrap;gap:8px 0;margin:0 0 var(--s4);padding:0;list-style:none;
}
.footer__links li a{
  font-family:var(--font-display);
  font-weight:700;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.06em;
  padding:0 16px;
  border-left:1px solid var(--border-soft);
  min-height:44px;
  display:inline-flex;
  align-items:center;
}
.footer__links li:first-child a{border-left:0;padding-left:0;}
.footer__label{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--muted);
  border-top:1px solid var(--border-soft);
  padding-top:var(--s3);
  margin:0;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width:1024px){
  .lead__grid{grid-template-columns:1fr;gap:var(--s4);}
  .lead__body{max-width:var(--column);}
}
@media (max-width:768px){
  .site-h1{font-size:31px;}
  .nav__row{display:none;}
  .nav__row.open{display:block;}
  .nav a{border-left:0;border-top:1px solid var(--border-soft);padding:14px 0;}
  .nav a:first-child{border-top:0;}
  .nav a[aria-current="page"]::after,.nav a.active::after{left:0;right:auto;width:48px;}
  .nav__toggle{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--font-display);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:0.08em;
    background:transparent;border:0;border-top:1px solid var(--border-soft);
    width:100%;min-height:44px;padding:12px 0;cursor:pointer;color:var(--text);
  }
  .nav{padding-bottom:8px;}
  .article{grid-template-columns:1fr;gap:var(--s3);}
  .article--right .article__fig{order:0;}
  .article--right .article__txt{order:0;}
  .morelist td.col-hit,.morelist th.col-hit{display:none;}
}
@media (max-width:480px){
  .masthead__inner{flex-direction:column;align-items:stretch;gap:var(--s3);}
  .search{width:100%;}
  .search input{min-width:0;flex:1;}
  .site-h1{font-size:27px;}
  .lead{padding:var(--s5) var(--s3) var(--s4);}
  .column{padding:0 var(--s3) var(--s5);}
  .article__txt h3{font-size:18px;}
  .morelist td.col-date,.morelist th.col-date{display:none;}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important;animation:none !important;}
}


/* ============ gnuboard dynamic supplements (Swiss Editorial) ============ */

/* thumbnail images inside figure/thumb wrappers */
.figure img{width:100%;height:100%;object-fit:cover;display:block;}
.article__fig img{width:100%;height:auto;object-fit:cover;display:block;}
.wz-thumb img{width:100%;height:100%;object-fit:cover;display:block;}

/* pager current page (Gnuboard outputs <strong> or .now) */
.pager strong,.pager .now{
  font-family:var(--font-mono);font-size:14px;
  min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent-2);color:var(--white);border:1px solid var(--accent-2);font-weight:700;
}

/* board list heading */
.board-h1{font-family:var(--font-body);font-weight:800;font-size:32px;line-height:1.15;letter-spacing:-0.02em;margin:0;color:var(--text);}
.board-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;border-bottom:2px solid var(--border);padding-bottom:12px;margin-bottom:var(--s4);}
.board-total{font-family:var(--font-mono);font-size:13px;color:var(--muted);}

/* board list search + write actions */
.board-actions{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:24px;padding-top:16px;border-top:1px solid var(--border-soft);}
.board-actions .board-search{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.board-actions select,.board-actions input[type=text]{height:44px;padding:0 12px;font-family:var(--font-body);font-size:14px;background:var(--surface);color:var(--text);border:1px solid var(--border-soft);}

/* board detail (view) — site 001 palette */
.hm-board-view{background:var(--surface);border:1px solid var(--border-soft);padding:var(--s5);margin:var(--s5) auto var(--s4);max-width:var(--column);}
.hm-view-head{border-bottom:2px solid var(--border);padding-bottom:var(--s3);margin-bottom:var(--s4);}
.hm-view-head .hm-board-kicker{font-family:var(--font-mono);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin:0 0 8px;}
.hm-view-head h1{font-family:var(--font-body);font-weight:800;font-size:26px;line-height:1.2;letter-spacing:-0.01em;color:var(--text);margin:0;}
.hm-view-meta{display:flex;gap:14px;margin-top:12px;font-family:var(--font-mono);font-size:13px;color:var(--muted);flex-wrap:wrap;}
.hm-view-content{font-size:16px;line-height:1.8;color:var(--text);padding:8px 0 var(--s5);border-bottom:1px solid var(--border-soft);}
.hm-view-content img{max-width:100%;height:auto;}
.hm-view-content p{margin:0 0 16px;}
.hm-view-files{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0;}
.hm-view-files a{font-family:var(--font-mono);font-size:13px;border:1px solid var(--border-soft);padding:6px 12px;color:var(--text);background:var(--surface);}
.hm-view-neighbor{display:flex;flex-direction:column;gap:8px;margin:var(--s4) 0;}
.hm-view-neighbor a{display:flex;gap:12px;padding:10px 12px;border:1px solid var(--border-soft);background:var(--surface-alt);}
.hm-view-neighbor span{font-family:var(--font-mono);font-size:12px;color:var(--muted);flex:0 0 auto;}
.hm-view-neighbor strong{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hm-view-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:var(--s4);}
.hm-view-actions a{min-height:40px;display:inline-flex;align-items:center;padding:0 16px;border:1.5px solid var(--border);font-family:var(--font-display);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:0.06em;color:var(--text);background:var(--surface);}
.hm-view-actions a.is-primary{background:var(--accent-2);color:var(--white);border-color:var(--accent-2);}
.hm-view-actions a.is-primary:hover{background:var(--accent);border-color:var(--accent);text-decoration:none;}
.hm-view-vote{display:flex;gap:10px;margin:16px 0;}
.hm-view-vote a{padding:8px 16px;border:1px solid var(--border-soft);color:var(--text);font-family:var(--font-mono);font-size:13px;}
.hm-view-vote a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none;}

/* shell wrapper for board pages */
.shell{max-width:var(--band);margin:0 auto;padding:0 var(--s4);}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;}
