/* ============================================================
   DISPATCH — Kombiz.com design system
   Night-dispatch (dark) default · clean with zine accents
   Source of truth for the Kombiz aesthetic; reusable across
   the apex site and (later) the Ghost theme.
   ============================================================ */

:root {
  /* ---- palette: night dispatch ---- */
  --ink:        #0d0d0f;   /* ground */
  --ink-2:      #141417;   /* raised panel */
  --ink-3:      #1c1c20;   /* hairline fills */
  --paper:      #ece6d6;   /* primary text */
  --paper-dim:  #b7b1a3;   /* secondary text */
  --paper-faint:#6f6a5f;   /* meta / muted */
  --rule:       #34332e;   /* hairlines on dark */
  --accent:     #e8362b;   /* signal red */
  --accent-ink: #ffffff;   /* text on accent */

  /* ---- type ---- */
  --display: "Archivo", system-ui, sans-serif;
  --serif:   "Newsreader", Georgia, serif;
  --mono:    "JetBrains Mono", ui-monospace, monospace;

  /* ---- metrics ---- */
  --rule-w: 3px;
  --maxw: 1180px;
  --gutter: clamp(20px, 5vw, 72px);
  --grain-opacity: 0.05;
}

/* ---- light: paper dispatch (kept for reuse; site defaults dark) ---- */
[data-theme="light"] {
  --ink:        #ece5d4;
  --ink-2:      #f3eee0;
  --ink-3:      #e2dbc8;
  --paper:      #1a1916;
  --paper-dim:  #4d4a41;
  --paper-faint:#86806f;
  --rule:       #c6bda5;
  --accent-ink: #fff8f0;
}

/* ---- accent options ---- */
[data-accent="orange"] { --accent: #f0531f; }
[data-accent="blue"]   { --accent: #2f6bff; }
[data-accent="acid"]   { --accent: #b8e000; --accent-ink:#10110a; }

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* paper grain overlay */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9000;
  opacity: var(--grain-opacity);
  mix-blend-mode: var(--grain-blend, soft-light);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
[data-theme="light"] body::before,
[data-theme="light"]::before { --grain-blend: multiply; }

a { color: inherit; text-decoration: none; }

::selection { background: var(--accent); color: var(--accent-ink); }

.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gutter); }

/* mono label utility */
.label {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
}
.label--accent { color: var(--accent); }
.label--faint { color: var(--paper-faint); }

.sec { color: var(--accent); font-family: var(--mono); font-weight: 700; }

/* thick zine rule */
.rule { height: var(--rule-w); background: var(--paper); border: 0; margin: 0; }
.rule--thin { height: 1px; background: var(--rule); }
.rule--accent { background: var(--accent); }

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--ink) 88%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: var(--rule-w) solid var(--paper);
}
.topbar__in {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.brand {
  font-family: var(--display);
  font-weight: 900;
  font-size: 21px;
  letter-spacing: -0.01em;
  display: inline-flex; align-items: baseline; gap: 2px;
}
.brand .dot { color: var(--accent); }
.nav { display: flex; gap: 26px; align-items: center; }
.nav a {
  font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--paper-dim);
  padding: 4px 0; position: relative; transition: color .15s;
}
.nav a:hover { color: var(--paper); }
.nav a::after {
  content:""; position:absolute; left:0; right:100%; bottom:-2px;
  height:2px; background: var(--accent); transition: right .2s ease;
}
.nav a:hover::after { right: 0; }
.nav .nav__sub {
  background: var(--accent); color: var(--accent-ink);
  padding: 7px 13px; letter-spacing: 0.12em;
}
.nav .nav__sub::after { display:none; }
.nav .nav__sub:hover { color: var(--accent-ink); filter: brightness(1.08); }
.nav__toggle { display:none; }

/* ============================================================
   HERO  (layout variants via [data-layout])
   ============================================================ */
.hero { padding-top: clamp(48px, 8vw, 96px); padding-bottom: clamp(40px, 6vw, 72px); }
.hero__eyebrow { margin-bottom: 26px; display:flex; align-items:center; gap:14px; }
.hero__eyebrow .ln { flex: 0 0 42px; height: 2px; background: var(--accent); }

.hero h1 {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(48px, 8.5vw, 116px);
  line-height: 0.92;
  letter-spacing: -0.025em;
  margin: 0 0 28px;
  text-transform: uppercase;
  text-wrap: balance;
}
.hero__lede {
  font-size: clamp(19px, 2vw, 23px);
  line-height: 1.5;
  color: var(--paper-dim);
  max-width: 30em;
  margin: 0 0 36px;
}
.hero__lede b { color: var(--paper); font-weight: 600; }

/* headline highlight treatments via [data-headline] */
.hl { white-space: nowrap; }
[data-headline="block"]  .hl { background: var(--accent); color: var(--accent-ink); padding: 0 .14em; box-decoration-break: clone; }
[data-headline="underline"] .hl { box-shadow: inset 0 -0.16em 0 var(--accent); }
[data-headline="marker"] .hl {
  background: linear-gradient(104deg, transparent .5%, var(--accent) 0, var(--accent) 99%, transparent 0);
  color: var(--accent-ink); padding: 0 .12em;
  -webkit-box-decoration-break: clone; box-decoration-break: clone;
  border-radius: 2px 6px 4px 7px;
}
[data-headline="outline"] .hl {
  color: transparent; -webkit-text-stroke: 2px var(--accent);
  paint-order: stroke fill;
}
[data-headline="inverse"] .hl { background: var(--paper); color: var(--ink); padding: 0 .12em; box-decoration-break: clone; }

/* subscribe inline */
.sub {
  display: flex; gap: 0; max-width: 460px;
  border: 2px solid var(--paper);
}
.sub input {
  flex: 1; min-width: 0; border: 0; background: transparent;
  color: var(--paper); font-family: var(--mono); font-size: 14px;
  padding: 14px 16px; outline: none;
}
.sub input::placeholder { color: var(--paper-faint); }
.sub button {
  border: 0; background: var(--accent); color: var(--accent-ink);
  font-family: var(--mono); font-weight: 700; font-size: 13px;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0 22px; cursor: pointer; transition: filter .15s;
}
.sub button:hover { filter: brightness(1.1); }
.sub__note { margin-top: 12px; }
.sub__note span { color: var(--accent); }

.hero__art { display: none; }
.hero__art img { display:block; width: 100%; height: auto; }

/* --- centered --- */
[data-layout="centered"] .hero__in { text-align: center; max-width: 920px; margin: 0 auto; }
[data-layout="centered"] .hero__eyebrow { justify-content: center; }
[data-layout="centered"] .hero__lede { margin-left: auto; margin-right: auto; }
[data-layout="centered"] .sub { margin: 0 auto; }
[data-layout="centered"] .hero__art { display:block; max-width: 260px; margin: 0 auto 28px; }
[data-layout="centered"] .hero__art img { filter: none; }

/* --- editorial poster (site default — mascot left, text right) --- */
[data-layout="editorial"] .hero__in {
  display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(36px, 5vw, 80px);
  align-items: center;
}
[data-layout="editorial"] .hero__art-col {
  align-self: stretch;
  display: flex; align-items: center; justify-content: center;
}
[data-layout="editorial"] .hero__art {
  display: block; margin: 0; max-width: 520px; width: 100%;
}
[data-layout="editorial"] .hero__art img {
  width: 100%; height: auto; display: block;
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
}
[data-layout="editorial"] .hero h1 { font-size: clamp(40px, 5.6vw, 78px); }
[data-layout="editorial"] .hero__body .hero__lede { max-width: 36ch; }

/* --- poster --- */
[data-layout="poster"] .hero__in {
  display: grid; grid-template-columns: 1fr 0.82fr; gap: clamp(24px,4vw,56px);
  align-items: center;
}
[data-layout="poster"] .hero h1 { font-size: clamp(46px, 7vw, 104px); }
[data-layout="poster"] .hero__art {
  display: flex; align-self: stretch; align-items: flex-end; justify-content: center;
}
[data-layout="poster"] .hero__art img { max-height: 460px; width: auto; }

@media (max-width: 860px) {
  [data-layout="editorial"] .hero__in,
  [data-layout="poster"] .hero__in { grid-template-columns: 1fr; }
  [data-layout="editorial"] .hero__art-col { order: -1; max-width: 380px; margin: 0 auto 24px; }
  [data-layout="poster"] .hero__art { order: -1; max-width: 280px; margin: 0 0 20px; }
  [data-layout="poster"] .hero__art img { max-height: 320px; }
}

/* ============================================================
   FEED  — numbered writing
   ============================================================ */
.feed { padding-block: clamp(20px, 4vw, 48px) clamp(60px,8vw,110px); }
.feed__head {
  display:flex; align-items: baseline; justify-content: space-between;
  padding: 18px 0; margin-bottom: 6px;
}
.feed__head h2 {
  font-family: var(--mono); font-weight: 700; font-size: 14px;
  letter-spacing: 0.18em; text-transform: uppercase; margin: 0;
}
.feed__head h2 .sec { margin-right: 8px; }
.feed__empty { font-family: var(--serif); font-size: 19px; color: var(--paper-dim); padding: 38px 0 8px; }
.feed__empty a { color: var(--accent); box-shadow: inset 0 -0.12em 0 var(--accent); }

/* featured (01) */
.post-feat {
  display: grid; grid-template-columns: auto 1fr; gap: clamp(20px,4vw,56px);
  padding: 34px 0; border-top: var(--rule-w) solid var(--paper);
  align-items: start;
}
.post-feat__no, .post__no {
  font-family: var(--display); font-weight: 900; line-height: 0.8;
  color: var(--paper-faint); font-variant-numeric: tabular-nums;
}
.post-feat__no { font-size: clamp(54px, 8vw, 104px); }
.post-feat__body { max-width: 46ch; }
.post-feat h3 {
  font-family: var(--display); font-weight: 800; text-transform: uppercase;
  font-size: clamp(30px, 4.4vw, 52px); line-height: 0.98; letter-spacing: -0.018em;
  margin: 12px 0 14px;
}
.post-feat p { color: var(--paper-dim); font-size: 19px; margin: 0 0 18px; max-width: 50ch; }

/* compact rows */
.post {
  display: grid;
  grid-template-columns: 64px 150px 1fr auto;
  gap: clamp(14px, 2.4vw, 34px);
  align-items: baseline;
  padding: 22px 0;
  border-top: 1px solid var(--rule);
  transition: background .15s, padding-left .15s;
}
.post:last-child { border-bottom: 1px solid var(--rule); }
.post:hover { background: var(--ink-2); padding-left: 10px; }
.post__no { font-size: 26px; }
.post:hover .post__no { color: var(--accent); }
.post__cat { align-self: baseline; }
.post h3 {
  font-family: var(--display); font-weight: 800; text-transform: uppercase;
  font-size: clamp(20px, 2.5vw, 28px); line-height: 1.02; letter-spacing: -0.01em;
  margin: 0; transition: color .15s;
}
.post:hover h3 { color: var(--paper); }
.post__meta { font-family: var(--mono); font-size: 11.5px; color: var(--paper-faint); letter-spacing: 0.08em; white-space: nowrap; text-align: right; }
.post__arrow { color: var(--accent); font-family: var(--mono); opacity: 0; transition: opacity .15s, transform .15s; }
.post:hover .post__arrow { opacity: 1; transform: translateX(3px); }

@media (max-width: 720px) {
  .post { grid-template-columns: 42px 1fr; grid-template-areas: "no cat" "no title" "no meta"; gap: 4px 16px; }
  .post__no { grid-area: no; }
  .post__cat { grid-area: cat; margin-bottom: 4px; }
  .post h3 { grid-area: title; margin-bottom: 8px; }
  .post__meta { grid-area: meta; text-align: left; }
  .post__arrow { display: none; }
  .post-feat { grid-template-columns: 1fr; }
  .post-feat__no { font-size: 56px; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot { border-top: var(--rule-w) solid var(--paper); padding-block: 48px 64px; }
.foot__grid { display: grid; grid-template-columns: auto 1fr auto; gap: clamp(24px,5vw,64px); align-items: start; }
.foot__mascot {
  width: 150px; flex: none;
  position: relative; /* taped sticker look */
}
.foot__mascot img { width: 100%; height: auto; display: block; }
.foot__tape {
  position:absolute; top:-12px; left:50%; transform: translateX(-50%) rotate(-3deg);
  width: 84px; height: 22px; background: color-mix(in srgb, var(--accent) 22%, transparent);
  border: 1px dashed color-mix(in srgb, var(--accent) 55%, transparent);
}
.foot__tag {
  font-family: var(--display); font-weight: 900; text-transform: uppercase;
  font-size: clamp(22px,3vw,30px); line-height: 1; letter-spacing: -0.01em; margin: 0 0 12px;
}
.foot__tag .sec { font-size: .8em; }
.foot__copy { font-family: var(--mono); font-size: 12px; color: var(--paper-faint); letter-spacing: 0.06em; }
.foot__links { display:flex; flex-direction: column; gap: 10px; text-align: right; }
.foot__links a { font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--paper-dim); display:inline-flex; gap:8px; justify-content: flex-end; align-items:center; }
.foot__links a:hover { color: var(--accent); }
.foot__codeline { font-family: var(--mono); font-size: 12px; color: var(--paper-faint); letter-spacing: 0.14em; margin-top: 26px; }
.foot__codeline b { color: var(--accent); font-weight: 700; }

@media (max-width: 720px) {
  .foot__grid { grid-template-columns: 1fr; }
  .foot__links { text-align: left; }
  .foot__links a { justify-content: flex-start; }
  .nav { display:none; }
}
