/* ============================================================
   Kamsin Kaneko — Component CSS (reference)
   Maps the design's components to plain CSS using tokens.css.
   Adapt selectors/classnames to your theme; values are final.
   ============================================================ */

/* ---- Page shell ---- */
.kk { background: var(--kk-bg); color: var(--kk-ink); font-family: var(--kk-sans); }
.kk-wrap { max-width: var(--kk-maxw); margin: 0 auto; padding-left: var(--kk-gutter); padding-right: var(--kk-gutter); }

/* ---- Wordmark (header) ---- */
.kk-wordmark { font-family: var(--kk-serif); font-weight: 500; font-size: 22px; line-height: 1; letter-spacing: .01em; color: var(--kk-ink); }
.kk-wordmark__kicker { font-family: var(--kk-mono); font-size: 9px; line-height: 1; letter-spacing: .26em; text-transform: uppercase; color: var(--kk-accent); margin-top: 4px; }

/* ---- Header / nav ---- */
.kk-header { display: flex; align-items: center; justify-content: space-between; padding: 30px var(--kk-gutter); border-bottom: 1px solid rgba(35,40,43,.14); }
.kk-nav { display: flex; gap: 32px; font-family: var(--kk-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--kk-soft); }
.kk-nav a { color: inherit; text-decoration: none; }
.kk-nav a[aria-current], .kk-nav a.is-active { color: var(--kk-ink); }
.kk-nav a:hover { color: var(--kk-accent); }

/* ---- Eyebrow / section label ---- */
.kk-eyebrow { font-family: var(--kk-mono); font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--kk-accent); }
.kk-label   { font-family: var(--kk-mono); font-size: 11px; letter-spacing: .2em;  text-transform: uppercase; color: var(--kk-soft); }

/* ---- Headings ---- */
.kk-h1 { font-family: var(--kk-serif); font-weight: 400; font-size: 56px; line-height: 1.08; letter-spacing: -.01em; color: var(--kk-ink-display); margin: 0; }
.kk-h2 { font-family: var(--kk-serif); font-weight: 400; font-size: 39px; line-height: 1.42; letter-spacing: -.005em; color: var(--kk-ink); margin: 0; text-wrap: pretty; }
.kk-h3 { font-family: var(--kk-serif); font-weight: 400; font-size: 33px; line-height: 1.2; color: var(--kk-ink); margin: 0; }
.kk-h4 { font-family: var(--kk-serif); font-weight: 500; font-size: 23px; line-height: 1.3; color: var(--kk-ink); margin: 0; }

/* ---- Body ---- */
.kk-body { font-family: var(--kk-sans); font-size: 17px; line-height: 1.9; color: var(--kk-body); max-width: 60ch; }
.kk-note { font-family: var(--kk-serif); font-style: italic; font-size: 18px; line-height: 1.6; color: var(--kk-soft); } /* reflective note */

/* ---- Caption / meta ---- */
.kk-caption { font-family: var(--kk-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--kk-faint); }

/* ---- CTA link "→" ---- */
.kk-cta { font-family: var(--kk-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--kk-accent); text-decoration: none; border-bottom: 1px solid var(--kk-accent-line); padding-bottom: 3px; cursor: pointer; }
.kk-cta:hover { border-bottom-color: var(--kk-accent); }

/* ---- Hero (full-bleed photograph) ---- */
.kk-hero { position: relative; height: 76vh; min-height: 440px; overflow: hidden; background: var(--kk-img-dark-2); }
.kk-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.kk-hero::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 220px; background: var(--kk-scrim-top); }
.kk-hero::after  { content: ""; position: absolute; bottom: 0; left: 0; right: 0; height: 340px; background: var(--kk-scrim-bottom); }
.kk-hero__bar  { position: absolute; left: var(--kk-gutter); right: var(--kk-gutter); bottom: 48px; display: flex; align-items: flex-end; justify-content: space-between; gap: 48px; color: var(--kk-on-dark); }
.kk-hero__line { font-family: var(--kk-serif); font-style: italic; font-size: 31px; line-height: 1.36; max-width: 640px; }
/* Header inside hero uses --kk-on-dark for wordmark + nav. */

/* ---- Project teaser grid (2-up, alternating) ---- */
.kk-projects { display: grid; gap: 56px; }
.kk-project  { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.kk-project--reverse .kk-project__img { order: 2; }
.kk-project__img { height: 480px; overflow: hidden; background: var(--kk-img-dark); }
.kk-project__img img { width: 100%; height: 100%; object-fit: cover; }

/* ---- Essay row (index list) ---- */
.kk-essay { display: grid; grid-template-columns: 118px 1fr 150px 64px; gap: 28px; align-items: baseline; border-top: 1px solid var(--kk-rule-soft); padding: 28px 0; text-decoration: none; }
.kk-essay:last-child { border-bottom: 1px solid var(--kk-rule-soft); }

/* ---- Print card (3-up grid) ---- */
.kk-prints { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.kk-print__img { height: 300px; overflow: hidden; background: var(--kk-img-dark); }
.kk-print__img img { width: 100%; height: 100%; object-fit: cover; }
.kk-print__meta { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-top: 16px; border-top: 1px solid var(--kk-rule-soft); padding-top: 14px; }

/* ---- Panel band (print teaser / subscribe / detail rows) ---- */
.kk-panel { background: var(--kk-panel); }

/* ---- Footer (indigo dye) ---- */
.kk-footer { background: var(--kk-footer-bg); color: var(--kk-footer-text); padding: 72px var(--kk-gutter) 40px; }
.kk-footer__brand { font-family: var(--kk-serif); font-style: italic; font-size: 26px; color: var(--kk-footer-head); }
.kk-footer__tag   { font-family: var(--kk-serif); font-style: italic; font-size: 15px; color: var(--kk-footer-text); }
.kk-footer a { color: var(--kk-footer-body); text-decoration: none; }
.kk-footer a.is-substack { color: var(--kk-accent); }
.kk-footer__copy { border-top: 1px solid rgba(255,255,255,.1); padding-top: 22px; font-family: var(--kk-mono); font-size: 10.5px; letter-spacing: .1em; color: var(--kk-footer-faint); }

/* ---- Responsive note ----
   Collapse 2-up grids to 1 column and reduce --kk-gutter (e.g. 24px)
   below ~900px. Essay-row grid collapses to date+title stacked.
   The design itself was authored at desktop width (1280px frames). */
