/*
Theme Name:   WAYR 2025
Theme URI:    https://wayr.today
Template:     twentytwentyfive
Version:      1.9.0
Description:  WAYR child theme for Twenty Twenty-Five. Warm paper cream, muted rust accent, IBM Plex, hairline rules, un-numbered feed.
Author:       WAYR
Text Domain:  wayr-2025
*/

/* ============ FONTS ============ */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Serif:ital,wght@0,400;0,600;1,400&display=swap');

/* ============ TOKENS ============ */
:root {
  --paper:        #f6f1e6;
  --paper-2:      #efe8d8;
  --paper-3:      #e6dec8;
  --rule:         #d9cfb4;
  --rule-strong:  #b8ac8d;

  --ink:          #1a1816;
  --ink-2:        #4a4640;
  --ink-3:        #7d766b;
  --ink-4:        #a8a195;

  --accent:       #9a4638;
  --accent-deep:  #74342a;
  --accent-soft:  #ecd9d1;

  --font-sans:  'IBM Plex Sans', system-ui, -apple-system, sans-serif;
  --font-mono:  'IBM Plex Mono', ui-monospace, Menlo, monospace;
  --font-serif: 'IBM Plex Serif', Georgia, serif;
}

/* ============ GLOBAL ============ */
body.wp-site-blocks,
body {
  background: var(--paper) !important;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 14.5px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

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

a { color: var(--ink); text-decoration: underline; text-decoration-color: var(--rule-strong); text-underline-offset: 2px; transition: color 100ms ease; }
a:hover { color: var(--accent); text-decoration-color: var(--accent); }

/* ============ HEADINGS ============ */
h1, .wp-block-post-title, .entry-title {
  font-family: var(--font-sans); font-weight: 600; font-size: 34px;
  line-height: 1.18; letter-spacing: -0.018em; color: var(--ink);
  text-wrap: balance;
}
h2 { font-family: var(--font-sans); font-weight: 600; font-size: 26px; letter-spacing: -0.015em; line-height: 1.25; }
h3 { font-family: var(--font-sans); font-weight: 600; font-size: 20px; line-height: 1.3; }
h4 { font-family: var(--font-sans); font-weight: 600; font-size: 17px; }

/* ============ CATEGORY NAV (header) ============ */
/* Assign a "WAYR Categories" menu in Appearance → Menus → Navigation */
.wayr-cat-nav .wp-block-navigation__container {
  gap: 4px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
}
.wayr-cat-nav .wp-block-navigation-item__content {
  font-family: var(--font-mono) !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  color: var(--ink-3) !important;
  padding: 4px 9px !important;
  border: 1px solid transparent !important;
  text-decoration: none !important;
  line-height: 1 !important;
  display: block !important;
  transition: color 100ms ease, border-color 100ms ease !important;
}
.wayr-cat-nav .wp-block-navigation-item__content:hover {
  color: var(--ink) !important;
  border-color: var(--rule-strong) !important;
}
.wayr-cat-nav .current-menu-item .wp-block-navigation-item__content {
  color: var(--paper) !important;
  background: var(--ink) !important;
  border-color: var(--ink) !important;
}

/* Constrain header row to same width as feed so WAYR aligns with story titles */
header.wp-block-template-part > .wp-block-group,
header.wp-block-template-part {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 28px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 18px;
}

.wp-block-site-title a, .wp-block-site-title {
  font-family: var(--font-sans) !important;
  font-weight: 700 !important;
  font-size: 18px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--ink) !important;
  text-decoration: none !important;
}
.wp-block-site-tagline {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--ink-3);
  font-size: 13px;
}
.wp-block-site-logo img {
  width: 28px; height: 28px;
}

/* Nav */
.wp-block-navigation .wp-block-navigation-item__content {
  font-family: var(--font-sans); font-size: 13px; font-weight: 500;
  color: var(--ink-2); text-decoration: none;
  padding-bottom: 3px; border-bottom: 2px solid transparent;
}
.wp-block-navigation .wp-block-navigation-item__content:hover,
.wp-block-navigation .current-menu-item .wp-block-navigation-item__content {
  color: var(--ink); border-bottom-color: var(--accent);
}

/* ============ FEED (post list) ============ */
.wp-block-query.alignwide,
.wp-block-query {
  max-width: 920px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-top: 0 !important;
}

/* Kill TT5's default big gap between post list items */
.wp-block-query .wp-block-post-template,
.wp-block-query ul.wp-block-post-template {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
}
.wp-block-query .wp-block-post-template > li,
.wp-block-query .wp-block-post {
  margin: 0 !important;
}

/* Feed row — HN-style: title + subline */
.wayr-feed-row { cursor: pointer; }
.wayr-feed-row .wp-block-post-title {
  font-size: 14.5px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  letter-spacing: -0.003em !important;
  margin: 0 !important;
}
.wayr-feed-row .wp-block-post-title a {
  color: var(--ink) !important;
  text-decoration: none !important;
}
.wayr-feed-row .wp-block-post-title a:hover { color: var(--accent) !important; }

/* Subline: source · category · date */
.wayr-feed-row .wp-block-post-terms,
.wayr-feed-row .wp-block-post-date {
  font-family: var(--font-mono) !important;
  font-size: 11px !important;
  color: var(--ink-4) !important;
  letter-spacing: 0.01em !important;
  text-transform: none !important;
  margin: 0 !important;
}
.wayr-feed-row .wp-block-post-terms a {
  color: var(--ink-4) !important;
  text-decoration: none !important;
}
.wp-block-query .wp-block-post > * { grid-column: 1; margin: 0; }
.wp-block-query .wp-block-post .wp-block-post-date,
.wp-block-query .wp-block-post time {
  grid-column: 2; grid-row: 1 / span 3;
  font-family: var(--font-mono) !important; font-size: 12px !important;
  color: var(--ink-3) !important; white-space: nowrap;
}

.wp-block-query .wp-block-post-title {
  font-size: 15px !important;
  font-weight: 500 !important;
  line-height: 1.35 !important;
  letter-spacing: -0.005em !important;
  margin: 0 !important;
  text-wrap: balance;
}
.wp-block-query .wp-block-post-title a {
  color: var(--ink); text-decoration: none;
}
.wp-block-query .wp-block-post-title a:hover {
  color: var(--accent);
}

/* Category / source row under headline */
.wp-block-query .wp-block-post-terms,
.wp-block-query .taxonomy-category,
.wp-block-query .taxonomy-post_tag {
  font-family: var(--font-mono) !important;
  font-size: 10.5px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--ink-3) !important;
  margin-top: 4px !important;
}
.wp-block-query .wp-block-post-terms a {
  color: var(--ink-3);
  text-decoration: none;
}
.wp-block-query .wp-block-post-terms a:hover { color: var(--accent); }

/* Kill featured images in the feed — text-only per brand */
.wp-block-query .wp-block-post-featured-image { display: none !important; }

/* Pagination */
.wp-block-query-pagination {
  font-family: var(--font-mono); font-size: 12.5px;
  padding-top: 24px; border-top: 1px solid var(--rule); margin-top: 24px;
}
.wp-block-query-pagination a { text-decoration: none; color: var(--ink-3); padding: 0 6px; }
.wp-block-query-pagination a:hover { color: var(--accent); }
.wp-block-query-pagination .current { color: var(--ink); font-weight: 600; text-decoration: underline; text-decoration-color: var(--accent); text-underline-offset: 4px; }

/* Kill any extra top borders/margins that create double/triple rules */
main.wp-block-group { margin-top: 0 !important; border-top: 0 !important; }
.wp-site-blocks > main { border-top: 0 !important; margin-top: 0 !important; }

/* Header already has its own bottom border — don't double up via main margin */
main.wp-block-group {
  margin-top: 0 !important;
}

/* ============ SINGLE POST ============ */
.single main.wp-block-group,
.single .wp-block-post-content {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.single .wp-block-post-content {
  font-family: var(--font-sans); font-size: 16px; line-height: 1.65;
}
.single .wp-block-post-content p { margin: 0 0 20px; text-wrap: pretty; }
.single .wp-block-post-content strong { font-weight: 600; }
.single .wp-block-post-content h3 { margin: 32px 0 12px; }

.single .wp-block-post-title {
  max-width: 760px; margin: 0 auto 20px;
  font-size: 34px;
}

/* AI-disclosure pattern — wrap an <em> on the first paragraph */
.single .wp-block-post-content em:first-child {
  display: block; padding-left: 12px; border-left: 2px solid var(--accent);
  font-family: var(--font-serif); font-size: 14px; color: var(--ink-3);
  margin-bottom: 32px;
}

/* ============ FOOTER ============ */
.wp-block-template-part[data-type="wp_template_part"][data-slug="footer"],
footer.wp-block-template-part {
  border-top: 1px solid var(--rule);
  padding-top: 32px !important;
  margin-top: 80px !important;
}

/* ============ CODE / QUOTES ============ */
code, kbd, samp {
  font-family: var(--font-mono); font-size: 0.92em;
  background: var(--paper-2); padding: 1px 5px; border: 1px solid var(--rule);
}

/* Reset TT5's default blockquote styling completely.
   TT5 uses CSS custom props + right/left borders + has-background bg.
   We override with max-specificity selectors and !important on every property. */
html body blockquote,
html body .wp-block-quote,
html body .wp-block-quote.is-style-plain,
html body .wp-block-quote.is-style-large,
html body .wp-block-quote.has-background,
html body .wp-block-quote[style] {
  --wp--preset--color--contrast: transparent !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: 0 none !important;
  border-top: 0 none !important;
  border-right: 0 none !important;
  border-bottom: 0 none !important;
  border-left: 2px solid var(--accent) !important;
  border-radius: 0 !important;
  padding: 4px 0 4px 16px !important;
  margin: 0 0 28px !important;
  font-family: var(--font-serif) !important;
  font-style: italic !important;
  color: var(--ink-3) !important;
  box-shadow: none !important;
  outline: 0 !important;
}
html body blockquote::before,
html body blockquote::after,
html body .wp-block-quote::before,
html body .wp-block-quote::after {
  content: none !important;
  display: none !important;
  background: transparent !important;
  border: 0 !important;
}
html body blockquote *,
html body .wp-block-quote * {
  background: transparent !important;
  background-color: transparent !important;
  border: 0 none !important;
  box-shadow: none !important;
}
html body blockquote p,
html body .wp-block-quote p {
  color: var(--ink-3) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  padding: 0 !important;
  font-family: var(--font-serif) !important;
  font-style: italic !important;
}
html body blockquote cite,
html body .wp-block-quote cite { display: none !important; }

/* ============ BUTTONS ============ */
.wp-block-button__link {
  background: var(--ink) !important;
  color: var(--paper) !important;
  border-radius: 0 !important;
  font-family: var(--font-sans) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  padding: 12px 20px !important;
  transition: background 100ms ease;
}
.wp-block-button__link:hover { background: var(--accent) !important; }

/* ============ NO ROUNDED CORNERS, NO SHADOWS ============ */
.wp-block-group, .wp-block-cover, .wp-block-image img {
  border-radius: 0 !important;
  box-shadow: none !important;
}
