/*
Theme Name: MRVA Journal
Theme URI: https://mrva.com/
Author: Morteza Riahi
Description: A responsive LTR WordPress blog theme inspired by MRVA.com, with rich article typography, archives, sidebar tools, managed text ads, and light/dark mode.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: mrva-journal
*/

:root {
  --bg: #fafaf7;
  --surface: #ffffff;
  --surface-soft: #ebf5f0;
  --surface-tint: #ebf5f0;
  --text: #1a2b24;
  --muted: #6b8072;
  --line: #d8e8e0;
  --brand: #2a7a5a;
  --brand-strong: #2a7a5a;
  --accent: #c9943a;
  --ink: #1a2b24;
  --code-bg: #101a17;
  --code-text: #dcfff4;
  --shadow: 0 4px 30px rgba(42, 122, 90, 0.10);
  --shadow-lift: 0 8px 32px rgba(42, 122, 90, 0.16);
  --radius: 14px;
  --content: 760px;
  color-scheme: light;
}

html[data-theme="dark"] {
  --bg: #101714;
  --surface: #17231e;
  --surface-soft: #20322a;
  --surface-tint: #1d2f27;
  --text: #f4faf7;
  --muted: #a6b9ad;
  --line: #2b4037;
  --brand: #3b9a72;
  --brand-strong: #9ae4c5;
  --accent: #e4b45a;
  --code-bg: #0b1210;
  --code-text: #e7fff5;
  --shadow: 0 16px 42px rgba(0, 0, 0, 0.26);
  color-scheme: dark;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  direction: ltr;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-tint) 56%, transparent), transparent 260px),
    var(--bg);
  color: var(--text);
  font-family: Inter, "Segoe UI", Arial, sans-serif;
  font-size: 15px;
  line-height: 1.7;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

a {
  color: var(--brand-strong);
  text-decoration: none;
  transition: color 0.18s ease, background-color 0.18s ease, border-color 0.18s ease;
}

a:hover,
a:focus-visible {
  color: var(--accent);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.wrap {
  width: min(1160px, calc(100% - 32px));
  margin-inline: auto;
}

.skip-link {
  position: absolute;
  top: -48px;
  left: 16px;
  z-index: 1000;
  background: var(--brand);
  color: #fff;
  padding: 8px 12px;
  border-radius: var(--radius);
}

.skip-link:focus {
  top: 16px;
}

.top-strip {
  border-bottom: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  background: var(--ink);
  color: var(--muted);
  font-size: 13px;
}

.top-strip a,
.top-strip__inner {
  color: #d8e5e1;
}

.top-strip__inner {
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.top-strip__inner > span:last-child {
  direction: ltr;
  white-space: nowrap;
  color: #cbd9d5;
  font-size: 12px;
}

.ticker {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.ticker__label {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #8fe5c9;
  font-weight: 700;
  white-space: nowrap;
}

.ticker__label::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: var(--accent);
  box-shadow: 5px 0 0 var(--brand);
}

.ticker__links {
  display: flex;
  gap: 14px;
  overflow: hidden;
  white-space: nowrap;
}

.ticker__links a {
  position: relative;
  color: #d8e5e1;
}

.ticker__links a + a {
  padding-left: 14px;
}

.ticker__links a + a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 1px;
  height: 14px;
  background: rgba(255, 255, 255, 0.18);
  transform: translateY(-50%);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
}

.site-header__inner {
  min-height: 88px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 22px;
}

.site-branding {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.site-logo,
.custom-logo-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 7px 10px;
  border: 1px solid color-mix(in srgb, var(--line) 75%, transparent);
  border-radius: var(--radius);
  background: #fff;
}

.site-logo--mark {
  gap: 8px;
  min-width: 178px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 12%, #fff), #fff);
  color: var(--text);
}

.site-logo__symbol {
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--brand), var(--brand-strong));
  color: #fff;
  direction: ltr;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.site-logo__symbol--photo {
  position: relative;
  overflow: hidden;
  border: 2px solid var(--surface);
  border-radius: 50%;
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    linear-gradient(135deg, var(--brand), var(--accent)) border-box;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--brand) 12%, transparent),
    0 8px 18px rgba(26, 43, 36, 0.14);
}

.site-logo__symbol--photo::after {
  content: "";
  position: absolute;
  inset: auto 3px 3px;
  height: 34%;
  border-radius: 999px;
  background: linear-gradient(0deg, rgba(42, 122, 90, 0.34), transparent);
  pointer-events: none;
}

.site-logo__symbol--photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.site-logo__text {
  color: var(--brand-strong);
  background: linear-gradient(135deg, var(--ink) 10%, var(--brand-strong) 54%, var(--accent) 115%);
  -webkit-background-clip: text;
  background-clip: text;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.55);
  -webkit-text-fill-color: transparent;
  white-space: nowrap;
}

.site-logo__text span {
  color: var(--accent);
}

html[data-theme="dark"] .site-logo--mark {
  background: #f8fbfa;
}

html[data-theme="dark"] .site-logo__text {
  background: linear-gradient(135deg, #f8fbfa 6%, #8ed6b5 58%, #e0c46b 116%);
  -webkit-background-clip: text;
  background-clip: text;
  text-shadow: none;
  -webkit-text-fill-color: transparent;
}

.site-logo img,
.custom-logo {
  width: 150px;
  height: auto;
}

.site-title {
  margin: 0;
  font-size: 15px;
  line-height: 1.4;
  font-weight: 800;
}

.site-description {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 12px;
}

.main-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  flex-wrap: wrap;
}

.main-navigation li {
  position: relative;
}

.main-navigation a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 6px 11px;
  border-radius: var(--radius);
  color: var(--text);
  font-size: 14px;
  font-weight: 700;
}

.main-navigation .menu-item-has-children > a {
  padding-right: 28px;
}

.main-navigation .menu-item-has-children > a::before {
  content: "";
  position: absolute;
  right: 11px;
  top: 50%;
  width: 6px;
  height: 6px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-62%) rotate(45deg);
  opacity: 0.62;
}

.main-navigation .sub-menu {
  position: absolute;
  left: 0;
  top: calc(100% + 10px);
  z-index: 60;
  width: 246px;
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  box-shadow: var(--shadow-lift);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
  backdrop-filter: blur(14px);
}

.main-navigation li:hover > .sub-menu,
.main-navigation li:focus-within > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.main-navigation .sub-menu::before {
  content: "";
  position: absolute;
  left: 18px;
  top: -6px;
  width: 12px;
  height: 12px;
  border-left: 1px solid var(--line);
  border-top: 1px solid var(--line);
  background: var(--surface);
  transform: rotate(45deg);
}

.main-navigation .sub-menu li {
  width: 100%;
}

.main-navigation .sub-menu a {
  width: 100%;
  justify-content: flex-start;
  min-height: 36px;
  padding: 7px 10px;
  border-radius: 10px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.main-navigation .sub-menu a:hover,
.main-navigation .sub-menu .current-menu-item > a {
  background: var(--surface-soft);
  color: var(--brand-strong);
}

.main-navigation .sub-menu a::after {
  content: none;
}

.main-navigation a:hover,
.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a,
.main-navigation .current-menu-ancestor > a,
.main-navigation .current_page_ancestor > a,
.main-navigation a.is-active {
  background: var(--surface-soft);
  color: var(--brand-strong);
}

.main-navigation .current-menu-item > a::after,
.main-navigation .current_page_item > a::after,
.main-navigation .current-menu-ancestor > a::after,
.main-navigation .current_page_ancestor > a::after,
.main-navigation a.is-active::after {
  content: "";
  position: absolute;
  right: 11px;
  left: 11px;
  bottom: 4px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--brand), var(--accent));
}

.header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.icon-button {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
  padding: 0;
  line-height: 1;
}

.icon-button span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  height: 1em;
  line-height: 1;
  transform: translateY(-1px);
}

.icon-button:hover {
  border-color: var(--brand);
  color: var(--brand-strong);
}

.mobile-menu-toggle {
  display: none;
}

.hero {
  padding: 34px 0 18px;
}

.hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
  gap: 24px;
  align-items: stretch;
}

.hero-card {
  min-height: 300px;
  padding: clamp(22px, 4vw, 44px);
  border-radius: var(--radius);
  background: linear-gradient(135deg, var(--surface), var(--surface-soft));
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border: 1px solid var(--line);
}

.eyebrow,
.post-category {
  color: var(--brand-strong);
  font-size: 13px;
  font-weight: 700;
}

.hero-card h1 {
  margin: 12px 0 14px;
  max-width: 760px;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.35;
}

.hero-card p {
  max-width: 720px;
  margin: 0;
  color: var(--muted);
  font-size: 17px;
}

.hero-aside {
  display: grid;
  gap: 12px;
}

.mini-feature {
  padding: 16px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--line);
}

.mini-feature h2 {
  margin: 0 0 8px;
  font-size: 17px;
}

.mini-feature p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.site-main {
  padding: 30px 0 56px;
}

.layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 30px;
  align-items: start;
  direction: ltr;
}

.layout > section {
  grid-column: 1;
  min-width: 0;
}

.post-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.post-card {
  min-width: 0;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--line);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.post-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--brand) 32%, var(--line));
  box-shadow: var(--shadow-lift);
}

.post-card__thumb {
  display: block;
  aspect-ratio: 16 / 9;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 20%, transparent), transparent 52%),
    linear-gradient(315deg, color-mix(in srgb, var(--accent) 22%, transparent), transparent 48%),
    var(--surface-soft);
  overflow: hidden;
}

.post-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.post-card__body {
  padding: 18px 20px 20px;
}

.post-card h2 {
  margin: 9px 0 10px;
  font-size: 20px;
  line-height: 1.68;
}

.post-card h2 a {
  color: var(--text);
}

.post-card h2 a:hover {
  color: var(--brand-strong);
}

.post-excerpt {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 14.5px;
}

.post-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  color: var(--muted);
  font-size: 12px;
}

.read-more {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 16px;
  font-weight: 700;
}

.sidebar {
  grid-column: 2;
  grid-row: 1;
  display: grid;
  gap: 18px;
  position: sticky;
  top: 118px;
}

.author-bio-card {
  position: relative;
  overflow: hidden;
  padding: 24px 22px 22px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-lift);
  text-align: center;
}

.author-bio-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 92px;
  background:
    radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--accent) 24%, transparent), transparent 34%),
    linear-gradient(135deg, var(--surface-soft), color-mix(in srgb, var(--accent) 14%, var(--surface)));
  pointer-events: none;
}

.author-bio-card__head {
  position: relative;
  z-index: 1;
  width: 126px;
  height: 126px;
  margin: 0 auto 16px;
}

.author-bio-card__head img {
  width: 126px;
  height: 126px;
  border: 4px solid var(--surface);
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  box-shadow: 0 14px 30px rgba(26, 43, 36, 0.18);
}

.author-bio-card__status {
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 17px;
  height: 17px;
  border: 2px solid var(--surface);
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 5px rgba(34, 197, 94, 0.14);
}

.author-bio-card__body {
  position: relative;
  z-index: 1;
}

.author-bio-card__eyebrow {
  margin: 0 0 7px;
  color: var(--brand-strong);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.author-bio-card h2 {
  margin: 0 0 10px;
  color: var(--text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 23px;
  line-height: 1.25;
}

.author-bio-card p:not(.author-bio-card__eyebrow) {
  margin: 0 0 12px;
  color: var(--muted);
  font-size: 13.5px;
  line-height: 1.75;
  text-align: center;
}

.author-bio-card__summary {
  display: -webkit-box;
  max-height: calc(13.5px * 1.75 * 3);
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
}

.author-bio-card__more {
  margin-top: 4px;
  text-align: center;
}

.author-bio-card__more[open] {
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.author-bio-card__more[open] + * {
  margin-top: 10px;
}

.author-bio-card__more summary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 6px 12px;
  border: 1px solid color-mix(in srgb, var(--brand) 36%, var(--line));
  border-radius: var(--radius);
  background: var(--surface-soft);
  color: var(--brand-strong);
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  list-style: none;
  transition: border-color 0.18s ease, color 0.18s ease, background-color 0.18s ease;
}

.author-bio-card__more summary::-webkit-details-marker {
  display: none;
}

.author-bio-card__more summary::after {
  content: "+";
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  margin-left: 8px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--brand) 13%, transparent);
  color: var(--brand-strong);
  font-size: 14px;
  line-height: 1;
}

.author-bio-card__more[open] summary::after {
  content: "-";
}

.author-bio-card__more summary:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.author-bio-card__more p {
  margin: 10px 0 0;
}

.designer-ad {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lift);
}

.designer-ad a {
  min-height: 232px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;
  position: relative;
  isolation: isolate;
  padding: 22px;
  border: 1px solid color-mix(in srgb, var(--brand) 28%, var(--line));
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 18% 16%, rgba(96, 139, 255, 0.36), transparent 28%),
    radial-gradient(circle at 84% 24%, rgba(69, 199, 163, 0.34), transparent 24%),
    linear-gradient(145deg, #101833, #0c1714 62%, #14261f);
  color: #fff;
}

.designer-ad a::before {
  content: "";
  position: absolute;
  inset: 14px;
  z-index: -1;
  border: 1px solid rgba(255, 255, 255, 0.11);
  border-radius: calc(var(--radius) - 2px);
}

.designer-ad a::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  bottom: 0;
  z-index: -1;
  height: 46%;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.46), transparent);
}

.designer-ad__badge {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 1;
  width: auto;
  height: 34px;
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(8, 14, 28, 0.62);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.2);
  direction: ltr;
  text-align: left;
}

.designer-ad__badge span {
  display: inline;
  color: #fff;
  font-family: Arial, sans-serif;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0;
}

.designer-ad__badge small {
  display: inline;
  margin-top: 0;
  color: #95f1d6;
  font-family: Arial, sans-serif;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
}

.designer-ad__orbit {
  position: absolute;
  top: 18px;
  right: 22px;
  z-index: 0;
  width: 82px;
  height: 82px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 50%;
  pointer-events: none;
}

.designer-ad__orbit span {
  position: absolute;
  border-radius: 50%;
}

.designer-ad__orbit span:first-child {
  width: 18px;
  height: 18px;
  top: 10px;
  right: 11px;
  background: linear-gradient(135deg, #6c8cff, #45c7a3);
}

.designer-ad__orbit span:last-child {
  width: 8px;
  height: 8px;
  left: 12px;
  bottom: 16px;
  background: var(--accent);
}

.designer-ad__kicker {
  color: #95f1d6;
  direction: ltr;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
}

.designer-ad strong {
  max-width: 230px;
  color: #fff;
  font-size: 21px;
  line-height: 1.55;
}

.designer-ad small {
  max-width: 250px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 13px;
  line-height: 1.8;
}

.designer-ad__cta {
  width: max-content;
  margin-top: 6px;
  padding: 6px 10px;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.11);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
}

.widget,
.comments-area,
.author-box,
.related-posts,
.text-ads {
  padding: 20px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
}

.widget::before,
.text-ads::before {
  content: "";
  position: absolute;
  inset-inline: 0;
  top: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--brand), var(--accent));
}

.sidebar .wp-block-group,
.sidebar .wp-block-group__inner-container {
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.sidebar .wp-block-group::before,
.sidebar .wp-block-group__inner-container::before {
  content: none;
}

.widget-title,
.widget h2,
.related-posts h2,
.comments-title,
.comment-reply-title {
  margin: 0 0 16px;
  font-size: 17px;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
}

.widget-title::before,
.widget h2::before,
.related-posts h2::before {
  content: "";
  width: 20px;
  height: 8px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, var(--brand) 0 58%, var(--accent) 58% 100%);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--surface-soft) 82%, transparent);
}

.widget ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

.widget li + li {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.thumb-list li + li {
  margin-top: 12px;
  padding-top: 12px;
}

.thumb-list a {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  color: var(--text);
}

.thumb-list img,
.thumb-list a > span:first-child:empty {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 22%, transparent), transparent 55%),
    var(--surface-soft);
}

.thumb-list strong {
  display: block;
  font-size: 13.5px;
  line-height: 1.65;
}

.thumb-list small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 11px;
}

.archive-header,
.single-header,
.page-header {
  margin-bottom: 22px;
}

.home-heading {
  padding: clamp(20px, 3vw, 30px);
  border: 1px solid color-mix(in srgb, var(--brand) 22%, var(--line));
  border-left: 5px solid var(--brand);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 12% 18%, color-mix(in srgb, var(--brand) 13%, transparent), transparent 28%),
    linear-gradient(135deg, color-mix(in srgb, var(--surface-tint) 58%, var(--surface)), var(--surface) 62%);
  box-shadow: var(--shadow-lift);
  position: relative;
  overflow: hidden;
}

.home-heading::after {
  content: "";
  position: absolute;
  inset-block: auto 0;
  inset-inline: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--brand), var(--accent), transparent 72%);
  pointer-events: none;
}

.home-heading h1 {
  max-width: 860px;
  position: relative;
  z-index: 1;
  display: inline;
  margin: 0;
  font-size: clamp(25px, 3vw, 38px);
  line-height: 1.55;
  font-weight: 900;
  background:
    linear-gradient(transparent 62%, color-mix(in srgb, var(--accent) 24%, transparent) 0),
    linear-gradient(90deg, var(--text), color-mix(in srgb, var(--brand-strong) 80%, var(--text)));
  -webkit-background-clip: text, text;
  background-clip: text, text;
  color: transparent;
}

.home-heading p {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 15px;
}

.front-page-content {
  margin-bottom: 22px;
}

.section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 0 12px;
}

.section-heading h2 {
  margin: 0;
  font-size: 20px;
  line-height: 1.5;
}

.section-heading h2::before {
  content: "";
  display: inline-block;
  width: 22px;
  height: 7px;
  margin-right: 9px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, var(--brand) 0 55%, var(--accent) 55% 100%);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--surface-soft) 80%, transparent);
  vertical-align: middle;
}

.featured-section {
  margin-bottom: 22px;
}

.featured-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.featured-tile {
  min-width: 0;
  display: grid;
  grid-template-columns: 108px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 128px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 88%, var(--surface-tint));
  color: var(--text);
  box-shadow: 0 8px 20px rgba(21, 44, 38, 0.05);
}

.featured-tile:hover {
  border-color: color-mix(in srgb, var(--brand) 36%, var(--line));
  color: var(--brand-strong);
}

.featured-tile__media {
  width: 108px;
  height: 92px;
  border-radius: var(--radius);
  overflow: hidden;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 22%, transparent), transparent 55%),
    var(--surface-soft);
}

.featured-tile__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.featured-tile strong {
  display: block;
  font-size: 15px;
  line-height: 1.75;
}

.featured-tile small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 11px;
}

.breadcrumb {
  margin: 0 0 10px;
  color: var(--muted);
  font-size: 13px;
}

.breadcrumb a {
  color: var(--muted);
}

.single-header h1,
.page-header h1,
.archive-header h1 {
  max-width: 920px;
  margin: 0 0 10px;
  font-size: clamp(22px, 2.5vw, 30px);
  line-height: 1.45;
}

.entry-shell {
  max-width: var(--content);
}

.entry-featured {
  margin-bottom: 22px;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.entry-content {
  padding: clamp(20px, 4vw, 34px);
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  overflow-wrap: break-word;
  word-break: normal;
}

.entry-content > *:first-child {
  margin-top: 0;
}

.entry-content > *:last-child {
  margin-bottom: 0;
}

.entry-content p {
  margin: 0 0 1.25em;
}

.entry-content h2,
.entry-content h3,
.entry-content h4 {
  scroll-margin-top: 110px;
  line-height: 1.55;
}

.entry-content h2 {
  margin: 2.2em 0 0.75em;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
  font-size: 28px;
}

.entry-content h3 {
  margin: 1.9em 0 0.65em;
  font-size: 23px;
}

.entry-content h4 {
  margin: 1.6em 0 0.55em;
  color: var(--brand-strong);
  font-size: 18px;
}

.entry-content a {
  border-bottom: 1px solid color-mix(in srgb, var(--brand) 45%, transparent);
  font-weight: 700;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.entry-content ul,
.entry-content ol {
  margin: 1.2em 0;
  padding: 0 0 0 1.35em;
}

.entry-content li {
  margin: 0.55em 0;
  padding-left: 0.15em;
}

.entry-content ul li::marker {
  color: var(--brand);
}

.entry-content ol li::marker {
  color: var(--brand-strong);
  font-weight: 700;
}

.entry-content blockquote {
  margin: 1.7em 0;
  padding: 18px 22px;
  border-left: 4px solid var(--brand);
  border-radius: var(--radius);
  background: var(--surface-soft);
  color: var(--text);
  font-size: 18px;
}

.entry-content mark {
  padding: 0.08em 0.28em;
  border-radius: 5px;
  background: color-mix(in srgb, var(--accent) 34%, transparent);
  color: inherit;
}

.entry-content code,
.entry-content kbd {
  max-width: 100%;
  border-radius: 6px;
  background: var(--surface-soft);
  color: var(--brand-strong);
  padding: 0.1em 0.38em;
  font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  font-size: 0.9em;
  direction: ltr;
  unicode-bidi: isolate;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.entry-content pre {
  margin: 1.7em 0;
  padding: 18px;
  overflow-x: auto;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  border-radius: var(--radius);
  background: var(--code-bg);
  color: var(--code-text);
  direction: ltr;
  text-align: left;
}

.entry-content pre code {
  padding: 0;
  background: transparent;
  color: inherit;
  white-space: inherit;
}

.entry-content table {
  width: 100%;
  margin: 1.6em 0;
  border-collapse: collapse;
  border-radius: var(--radius);
  font-size: 14px;
}

.entry-content > table {
  display: block;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  white-space: nowrap;
}

.entry-content .wp-block-table {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.entry-content .wp-block-table table {
  min-width: 640px;
}

.entry-content th,
.entry-content td {
  border: 1px solid var(--line);
  padding: 11px 12px;
  text-align: left;
  vertical-align: top;
}

.entry-content th {
  background: var(--surface-soft);
  color: var(--text);
}

.entry-content img,
.wp-caption {
  border-radius: var(--radius);
}

.entry-content .wp-caption-text {
  margin-top: 8px;
  color: var(--muted);
  font-size: 13px;
  text-align: center;
}

.share-box {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin: 20px 0 24px;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 78%, var(--brand));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--brand) 12%, transparent), transparent 38%),
    linear-gradient(135deg, color-mix(in srgb, var(--surface) 96%, var(--brand)), var(--surface));
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}

.share-box:has(.share-box__intro) {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  align-items: center;
  gap: 18px;
}

.share-box::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, var(--brand), var(--accent));
}

.share-box__intro {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.share-box__mark {
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  border: 1px solid color-mix(in srgb, var(--brand) 22%, var(--line));
  border-radius: 14px;
  background: color-mix(in srgb, var(--brand) 9%, var(--surface));
  color: var(--brand-strong);
}

.share-box__mark .ico {
  width: 20px;
  height: 20px;
}

.share-box__intro strong {
  display: block;
  color: var(--ink);
  font-size: 15px;
  line-height: 1.3;
}

.share-box__intro small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
}

.share-box > span:not([class]) {
  color: var(--ink);
  font-size: 15px;
  font-weight: 800;
  margin-inline-end: 4px;
}

.share-box__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.share-box a,
.tag-links a,
.cat-links a,
.text-ad-link {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 5px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-soft);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}

.share-box a {
  gap: 7px;
  min-height: 38px;
  padding: 7px 12px;
  border-color: color-mix(in srgb, var(--line) 86%, var(--brand));
  background: color-mix(in srgb, var(--surface-soft) 84%, #fff);
  box-shadow: 0 8px 20px rgba(26, 43, 36, 0.06);
}

.share-box a .ico {
  width: 15px;
  height: 15px;
}

.share-box a:hover,
.tag-links a:hover,
.cat-links a:hover,
.text-ad-link:hover {
  border-color: var(--brand);
  color: var(--brand-strong);
}

.share-box a:hover {
  background: color-mix(in srgb, var(--brand) 8%, var(--surface));
}

.post-nav {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 22px 0;
}

.post-nav a {
  display: block;
  padding: 14px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--line);
}

.related-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.related-card {
  min-width: 0;
}

.related-card h3 {
  margin: 8px 0 0;
  font-size: 15px;
  line-height: 1.6;
}

.pagination,
.nav-links {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.page-numbers,
.post-page-numbers {
  min-width: 38px;
  min-height: 38px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  padding: 5px 10px;
}

.page-numbers.current,
.post-page-numbers.current {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
}

.search-form {
  display: flex;
  gap: 8px;
}

.search-field,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="number"],
textarea {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  padding: 9px 12px;
  font: inherit;
}

.search-submit,
input[type="submit"],
button {
  min-height: 42px;
  border: 1px solid var(--brand);
  border-radius: var(--radius);
  background: var(--brand);
  color: #fff;
  padding: 8px 14px;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.contact-form {
  position: relative;
  display: grid;
  gap: 18px;
  margin-top: 22px;
  padding: 24px;
  border: 1px solid color-mix(in srgb, var(--line) 86%, var(--brand));
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--brand) 12%, transparent), transparent 34%),
    linear-gradient(135deg, color-mix(in srgb, var(--surface) 96%, var(--brand)), var(--surface));
  box-shadow: var(--shadow-soft);
}

.contact-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.contact-form__field {
  display: grid;
  gap: 7px;
  margin: 0;
}

.contact-form__field label {
  color: var(--ink);
  font-size: 14px;
  font-weight: 800;
}

.contact-form__field--trap {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.contact-form textarea {
  min-height: 170px;
  resize: vertical;
}

.contact-form__footer {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
}

.contact-form__captcha {
  max-width: 260px;
}

.contact-form__submit {
  min-width: 152px;
  box-shadow: 0 12px 28px color-mix(in srgb, var(--brand) 24%, transparent);
}

.contact-form__notice {
  border-radius: var(--radius);
  padding: 12px 14px;
  font-weight: 700;
}

.contact-form__notice ul {
  margin: 0;
  padding-left: 18px;
}

.contact-form__notice--success {
  border: 1px solid color-mix(in srgb, var(--brand) 34%, var(--line));
  background: color-mix(in srgb, var(--brand) 11%, var(--surface));
  color: var(--brand-strong);
}

.contact-form__notice--error {
  border: 1px solid color-mix(in srgb, #b84a4a 34%, var(--line));
  background: color-mix(in srgb, #b84a4a 10%, var(--surface));
  color: #8f2d2d;
}

.site-footer {
  border-top: 1px solid var(--line);
  background: var(--surface);
}

.footer-widgets {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  padding: 34px 0 24px;
}

.text-ads {
  margin-bottom: 22px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 10%, transparent), transparent 45%),
    var(--surface);
}

.text-ads__links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.site-info {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 0;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 13px;
}

.site-info ul,
.legal-links ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.site-info a,
.legal-links a {
  color: var(--muted);
}

.site-info a:hover,
.legal-links a:hover {
  color: var(--brand-strong);
}

.legal-links {
  padding: 16px 0 0;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 13px;
}

.designer-credit a {
  font-weight: 800;
}

.consent-flag {
  position: fixed;
  left: 50%;
  bottom: 18px;
  z-index: 100;
  width: min(720px, calc(100% - 28px));
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 14px 14px 14px 16px;
  border: 1px solid color-mix(in srgb, var(--brand) 28%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  box-shadow: 0 18px 48px rgba(26, 43, 36, 0.18);
  transform: translateX(-50%);
  backdrop-filter: blur(16px);
}

.consent-flag[hidden] {
  display: none;
}

.consent-flag__text {
  display: grid;
  gap: 2px;
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1.55;
}

.consent-flag__text strong {
  color: var(--text);
  font-size: 13px;
}

.consent-flag__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.consent-flag__actions a,
.consent-flag__actions button {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 11px;
  border-radius: 10px;
  font-size: 12.5px;
  font-weight: 800;
}

.consent-flag__actions a {
  border: 1px solid var(--line);
  background: var(--surface-soft);
  color: var(--brand-strong);
}

.consent-flag__actions button {
  border-color: var(--brand);
  background: var(--brand);
  color: #fff;
}

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 980px) {
  .site-header__inner {
    display: flex;
    min-height: 74px;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px 12px;
  }

  .layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .layout > section,
  .sidebar {
    grid-column: auto;
    grid-row: auto;
  }

  .sidebar {
    position: static;
  }

  .main-navigation {
    display: none;
    width: 100%;
  }

  .main-navigation.is-open {
    display: block;
  }

  .main-navigation ul {
    align-items: stretch;
    justify-content: flex-start;
  }

  .main-navigation li,
  .main-navigation a {
    width: 100%;
  }

  .main-navigation .menu-item-has-children > a {
    padding-right: 11px;
  }

  .main-navigation .menu-item-has-children > a::before {
    content: none;
  }

  .main-navigation .sub-menu {
    position: static;
    width: 100%;
    margin: 4px 0 8px;
    padding: 8px 10px 8px 18px;
    border-radius: 12px;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    background: color-mix(in srgb, var(--surface-soft) 72%, transparent);
  }

  .main-navigation .sub-menu::before {
    content: none;
  }

  .mobile-menu-toggle {
    display: inline-grid;
  }

  .site-header__inner {
    gap: 12px;
  }

  .site-branding {
    flex: 1 1 auto;
    min-width: 0;
    padding-right: 0;
  }

  .header-actions {
    flex: 0 0 auto;
    order: 2;
  }

  .site-branding {
    order: 1;
  }

  .main-navigation {
    order: 3;
    flex: 1 0 100%;
    min-width: 0;
  }

  .post-grid,
  .related-grid,
  .footer-widgets {
    grid-template-columns: 1fr;
  }

  .featured-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* =========================================================================
   MRVA Journal — Redesign Layer v1.1
   Senior UI/UX redesign: brand identity, motion, signature elements.
   Color tokens preserved. Layers added below cascade over base.
   ========================================================================= */

:root {
  --font-serif: "Fraunces", Georgia, "Times New Roman", serif;
  --font-sans: "Inter", "Segoe UI", Arial, sans-serif;
  --ease-spring: cubic-bezier(.16, 1, .3, 1);
  --ease-out: cubic-bezier(.2, .8, .2, 1);
  --motion-fast: .22s;
  --motion-base: .42s;
  --motion-slow: .72s;
  --ring-brand: 0 0 0 3px color-mix(in srgb, var(--brand) 26%, transparent);
}

body {
  font-family: var(--font-sans);
}

h1, h2, h3, h4,
.entry-content h2,
.entry-content h3,
.hero-card h1,
.home-heading h1,
.single-header h1,
.page-header h1,
.archive-header h1,
.author-bio-card h2 {
  font-family: var(--font-serif);
  font-feature-settings: "ss01", "ss02", "case";
  letter-spacing: -0.005em;
}

/* ---------- Reading Progress Bar -------------------------------------- */
.reading-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 200;
  height: 3px;
  pointer-events: none;
  background: transparent;
}

.reading-progress__bar {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--brand), var(--accent) 55%, var(--brand-strong));
  box-shadow: 0 0 18px color-mix(in srgb, var(--accent) 60%, transparent);
  transform-origin: left center;
  transition: width .12s linear;
  border-radius: 0 999px 999px 0;
}

/* ---------- Cursor Glow ----------------------------------------------- */
.cursor-glow {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  width: 260px;
  height: 260px;
  margin: -130px 0 0 -130px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--brand) 8%, transparent), transparent 70%);
  filter: blur(60px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .6s var(--ease-out);
  transform: translate3d(0, 0, 0);
  will-change: transform, opacity;
  mix-blend-mode: multiply;
}

html[data-theme="dark"] .cursor-glow {
  background: radial-gradient(circle, color-mix(in srgb, var(--brand-strong) 12%, transparent), transparent 70%);
  mix-blend-mode: screen;
}

body.is-pointer-fine .cursor-glow {
  opacity: .35;
}

@media (prefers-reduced-motion: reduce) {
  .cursor-glow { display: none; }
}

/* ---------- AI Live Pulse in Top Strip --------------------------------- */
.ticker__label {
  position: relative;
  padding-left: 18px;
}

.ticker__label::before {
  content: none;
}

.ticker__pulse {
  position: absolute;
  left: 0;
  top: 50%;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #2ee59d;
  box-shadow: 0 0 0 0 rgba(46, 229, 157, 0.6);
  transform: translateY(-50%);
  animation: mrvaPulse 1.8s var(--ease-out) infinite;
}

@keyframes mrvaPulse {
  0%   { box-shadow: 0 0 0 0 rgba(46, 229, 157, 0.55); }
  70%  { box-shadow: 0 0 0 10px rgba(46, 229, 157, 0); }
  100% { box-shadow: 0 0 0 0 rgba(46, 229, 157, 0); }
}

/* ---------- Logo: Monogram + Wordmark --------------------------------- */
.site-logo,
.custom-logo-link {
  border: 0;
  background: transparent;
  padding: 4px 0;
}

.site-logo--mark {
  position: relative;
  min-width: 0;
  gap: 12px;
  padding: 4px 6px 4px 4px;
  background: transparent;
  isolation: isolate;
  transition: transform var(--motion-base) var(--ease-spring);
}

.site-logo--mark::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 18% 50%, color-mix(in srgb, var(--brand) 14%, transparent), transparent 55%),
    radial-gradient(circle at 88% 50%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 60%);
  opacity: 0;
  transition: opacity var(--motion-base) var(--ease-out);
}

.site-logo--mark:hover::before,
.site-logo--mark:focus-visible::before {
  opacity: 1;
}

.site-logo__symbol--mono {
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  background: none;
  border-radius: 0;
  overflow: visible;
  flex: 0 0 44px;
}

.mr-monogram {
  width: 44px;
  height: 44px;
  overflow: visible;
}

.mr-monogram__halo {
  transform-origin: 32px 32px;
  animation: mrvaHaloBreath 4s ease-in-out infinite;
}

@keyframes mrvaHaloBreath {
  0%, 100% { opacity: .55; transform: scale(.9); }
  50%      { opacity: 1;   transform: scale(1.08); }
}

.mr-monogram__orbit {
  transform-origin: 32px 32px;
  animation: mrvaOrbitSpin 18s linear infinite;
  opacity: .8;
}

@keyframes mrvaOrbitSpin {
  to { transform: rotate(360deg); }
}

.mr-monogram__satellite {
  transform-origin: 32px 32px;
  animation: mrvaSatellite 6s linear infinite;
  filter: drop-shadow(0 0 4px color-mix(in srgb, var(--accent) 70%, transparent));
}

@keyframes mrvaSatellite {
  to { transform: rotate(360deg); }
}

.mr-monogram__path {
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  animation: mrvaDraw 1.4s var(--ease-out) forwards;
}

.mr-monogram__path--r {
  animation-delay: .18s;
}

@keyframes mrvaDraw {
  to { stroke-dashoffset: 0; }
}

.site-logo--mark:hover .mr-monogram__orbit {
  animation-duration: 6s;
}

.site-logo--mark:hover .mr-monogram__halo {
  opacity: 1;
}

.site-logo__text {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  background: none;
  -webkit-background-clip: initial;
  background-clip: initial;
  -webkit-text-fill-color: initial;
  color: var(--text);
  text-shadow: none;
  white-space: nowrap;
  line-height: 1;
  gap: 6px;
  min-height: 44px;
  font-family: var(--font-serif);
}

.site-logo__name {
  display: inline-flex;
  align-items: baseline;
  gap: 9px;
  line-height: 1;
}

.site-logo__word {
  display: inline-block;
  font-family: var(--font-serif);
  font-size: 21px;
  font-weight: 800;
  letter-spacing: -0.018em;
  line-height: 1;
}

.site-logo__word--first {
  color: var(--text);
}

.site-logo__word--last {
  position: relative;
  background: linear-gradient(120deg, var(--brand-strong) 10%, var(--accent) 55%, var(--brand-strong) 95%);
  background-size: 220% 100%;
  background-position: 0% 50%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  animation: mrvaShimmer 6s linear infinite;
}

@keyframes mrvaShimmer {
  to { background-position: 220% 50%; }
}

.site-logo__divider {
  position: relative;
  display: inline-block;
  width: 1.5px;
  height: 18px;
  align-self: center;
  background: linear-gradient(to bottom, transparent 6%, color-mix(in srgb, var(--brand) 80%, transparent) 35%, var(--accent) 65%, transparent 94%);
  border-radius: 999px;
  opacity: .85;
}

.site-logo__divider::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
  transform: translate(-50%, -50%);
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 70%, transparent);
  animation: mrvaDividerGlow 2.6s ease-in-out infinite;
}

@keyframes mrvaDividerGlow {
  0%, 100% { transform: translate(-50%, -50%) scale(.85); opacity: .55; }
  50%      { transform: translate(-50%, -50%) scale(1.15); opacity: 1; }
}

.site-logo__tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 0;
  padding: 0;
  color: color-mix(in srgb, var(--brand-strong) 80%, var(--muted));
  font-family: var(--font-sans);
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  line-height: 1;
  opacity: 1;
}

.site-logo__cap {
  display: inline-block;
  flex: 0 0 auto;
  width: 18px;
  height: 1.5px;
  border-radius: 999px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--brand) 75%, transparent), var(--accent));
  opacity: .9;
  position: relative;
}

.site-logo__cap::after {
  content: "";
  position: absolute;
  right: -1px;
  top: 50%;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
  transform: translateY(-50%);
  box-shadow: 0 0 6px color-mix(in srgb, var(--accent) 70%, transparent);
}

html[data-theme="dark"] .site-logo__cap {
  background: linear-gradient(90deg, color-mix(in srgb, #9ae4c5 70%, transparent), #e4b45a);
}

.site-logo__rotator {
  position: relative;
  display: inline-block;
  min-width: 168px;
  height: 12px;
  vertical-align: middle;
  overflow: hidden;
}

.site-logo__tag-set {
  position: absolute;
  inset: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(8px);
  animation: mrvaTagSwap 16s cubic-bezier(.16, 1, .3, 1) infinite both;
}

.site-logo__tag-set > span {
  color: inherit;
}

.site-logo__tag-set:nth-child(1) { animation-delay: 0s; }
.site-logo__tag-set:nth-child(2) { animation-delay: 4s; }
.site-logo__tag-set:nth-child(3) { animation-delay: 8s; }
.site-logo__tag-set:nth-child(4) { animation-delay: 12s; }

@keyframes mrvaTagSwap {
  0%   { opacity: 0; transform: translateY(8px); }
  3%   { opacity: 1; transform: translateY(0); }
  22%  { opacity: 1; transform: translateY(0); }
  25%  { opacity: 0; transform: translateY(-8px); }
  100% { opacity: 0; transform: translateY(-8px); }
}

.site-logo--mark:hover .site-logo__tag-set {
  animation-play-state: paused;
}

.site-logo__tag i {
  display: inline-block;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--accent);
  opacity: .85;
  flex: 0 0 auto;
}

.site-logo__tag span {
  color: inherit;
}

@media (prefers-reduced-motion: reduce) {
  .site-logo__tag-set { animation: none; opacity: 1; transform: none; }
  .site-logo__tag-set:not(:first-child) { display: none; }
}

html[data-theme="dark"] .site-logo--mark,
html[data-theme="dark"] .custom-logo-link {
  background: transparent;
  border-color: transparent;
}

html[data-theme="dark"] .site-logo__word--first { color: var(--text); }
html[data-theme="dark"] .site-logo__word--last  {
  background: linear-gradient(120deg, #9ae4c5 10%, #e4b45a 65%, #9ae4c5 95%);
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

html[data-theme="dark"] .site-logo__tag,
html[data-theme="dark"] .site-logo__tag-set,
html[data-theme="dark"] .site-logo__tag-set > span {
  color: #d6f0e1;
  opacity: 1;
  text-shadow: 0 0 12px color-mix(in srgb, #9ae4c5 35%, transparent);
}

html[data-theme="dark"] .site-logo__tag i {
  background: #e4b45a;
  opacity: 1;
  box-shadow: 0 0 8px color-mix(in srgb, #e4b45a 80%, transparent);
}

html[data-theme="dark"] .site-logo__divider {
  background: linear-gradient(to bottom, transparent 6%, color-mix(in srgb, #9ae4c5 80%, transparent) 35%, #e4b45a 65%, transparent 94%);
  opacity: 1;
}

@media (max-width: 620px) {
  .site-logo__word { font-size: 16px; }
  .site-logo__symbol--mono,
  .mr-monogram { width: 36px; height: 36px; flex-basis: 36px; }
  .site-logo__text { gap: 4px; min-height: 36px; }
  .site-logo__name { gap: 7px; }
  .site-logo__divider { height: 14px; }
  .site-logo__tag {
    font-size: 8.5px;
    letter-spacing: 0.22em;
    gap: 6px;
  }
  .site-logo__rotator {
    min-width: 132px;
    height: 10px;
  }
  .site-logo__tag-set { gap: 6px; }
  .site-logo__cap { width: 12px; }
}

@media (max-width: 400px) {
  .site-logo__rotator { min-width: 108px; }
  .site-logo__tag { font-size: 8px; letter-spacing: 0.18em; }
}

/* ---------- Author Bio Card — Pro Frame ------------------------------- */
.author-bio-card {
  padding: 30px 22px 24px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface-soft) 30%, var(--surface)), var(--surface) 65%);
  border-color: color-mix(in srgb, var(--brand) 14%, var(--line));
  isolation: isolate;
  transition: transform var(--motion-base) var(--ease-spring), box-shadow var(--motion-base) var(--ease-out);
}

.author-bio-card::before { content: none; }

.author-bio-card__aurora {
  position: absolute;
  inset: -40% -20% auto -20%;
  height: 220px;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(45% 60% at 20% 30%, color-mix(in srgb, var(--brand) 30%, transparent), transparent 70%),
    radial-gradient(45% 60% at 80% 35%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 70%);
  filter: blur(28px);
  opacity: .8;
  animation: mrvaAurora 14s ease-in-out infinite;
}

@keyframes mrvaAurora {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50%      { transform: translate3d(-4%, 3%, 0) scale(1.08); }
}

.author-bio-card__grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(color-mix(in srgb, var(--brand) 8%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--brand) 8%, transparent) 1px, transparent 1px);
  background-size: 26px 26px;
  mask-image: radial-gradient(circle at 50% 30%, #000 0%, transparent 60%);
  -webkit-mask-image: radial-gradient(circle at 50% 30%, #000 0%, transparent 60%);
  opacity: .55;
}

.author-bio-card__head {
  position: relative;
  z-index: 2;
  width: 140px;
  height: 140px;
  margin: 0 auto 18px;
}

.author-bio-card__avatar {
  position: absolute;
  inset: 14px;
  display: block;
  border-radius: 50%;
  overflow: hidden;
  background: var(--surface);
  box-shadow:
    0 18px 36px rgba(26, 43, 36, 0.22),
    inset 0 0 0 4px var(--surface);
  z-index: 2;
}

.author-bio-card__avatar img {
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: 0;
  object-fit: cover;
  object-position: center 18%;
  box-shadow: none;
  transition: transform .8s var(--ease-out);
}

.author-bio-card:hover .author-bio-card__avatar img {
  transform: scale(1.06);
}

.author-bio-card__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    conic-gradient(from 0deg, var(--brand) 0deg, var(--accent) 90deg, var(--brand-strong) 180deg, var(--accent) 270deg, var(--brand) 360deg);
  padding: 2px;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: mrvaRingSpin 9s linear infinite;
  z-index: 1;
}

@keyframes mrvaRingSpin {
  to { transform: rotate(360deg); }
}

.author-bio-card__ring--dashed {
  inset: -10px;
  background: none;
  border: 1.4px dashed color-mix(in srgb, var(--brand) 55%, transparent);
  padding: 0;
  -webkit-mask: none;
          mask: none;
  animation-duration: 28s;
  animation-direction: reverse;
  opacity: .55;
}

.author-bio-card__halo {
  position: absolute;
  inset: -18px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 28%, transparent), transparent 65%);
  filter: blur(14px);
  z-index: 0;
  animation: mrvaHaloPulse 3.8s ease-in-out infinite;
}

@keyframes mrvaHaloPulse {
  0%, 100% { opacity: .55; transform: scale(.94); }
  50%      { opacity: 1;   transform: scale(1.06); }
}

.author-bio-card__particle {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand);
  z-index: 3;
  box-shadow: 0 0 8px color-mix(in srgb, var(--brand) 50%, transparent);
}

.author-bio-card__particle--a { top: 4px;  left: 8px;  background: var(--accent); animation: mrvaFloat 5s ease-in-out infinite; }
.author-bio-card__particle--b { top: 24px; right: 2px; animation: mrvaFloat 6.5s ease-in-out infinite -1s; width: 5px; height: 5px; }
.author-bio-card__particle--c { bottom: 12px; left: 0; animation: mrvaFloat 7s ease-in-out infinite -2s; width: 4px; height: 4px; background: var(--accent); }
.author-bio-card__particle--d { bottom: 6px; right: 14px; animation: mrvaFloat 8s ease-in-out infinite -.5s; width: 5px; height: 5px; }

@keyframes mrvaFloat {
  0%, 100% { transform: translate(0, 0); opacity: .9; }
  50%      { transform: translate(-3px, -5px); opacity: 1; }
}

.author-bio-card__badge {
  position: absolute;
  bottom: 4px;
  right: 6px;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px 4px 6px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--ink), color-mix(in srgb, var(--brand) 65%, var(--ink)));
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.06em;
  box-shadow: 0 6px 14px rgba(26, 43, 36, 0.32);
}

.author-bio-card__badge svg {
  width: 12px;
  height: 12px;
}

.author-bio-card__status {
  position: absolute;
  bottom: 8px;
  left: 10px;
  z-index: 4;
  width: 14px;
  height: 14px;
  border: 2px solid var(--surface);
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.45);
  animation: mrvaPulseDot 2.4s ease-out infinite;
  right: auto;
  top: auto;
}

@keyframes mrvaPulseDot {
  0%   { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.5); }
  70%  { box-shadow: 0 0 0 9px rgba(34, 197, 94, 0); }
  100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0); }
}

.author-bio-card__body {
  position: relative;
  z-index: 2;
}

.author-bio-card__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin: 0 0 8px;
  padding: 4px 10px;
  border: 1px solid color-mix(in srgb, var(--brand) 28%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand) 6%, var(--surface));
  font-size: 10px;
  letter-spacing: 0.16em;
}

.author-bio-card__pulse {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--brand) 50%, transparent);
  animation: mrvaPulseDot 1.6s ease-out infinite;
}

.author-bio-card__name {
  margin: 0 0 4px;
  font-size: 26px;
  letter-spacing: -0.018em;
}

.author-bio-card__role {
  margin: 0 0 14px;
  color: var(--brand-strong);
  font-family: var(--font-sans);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.author-bio-card__chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
  margin: 0 0 14px;
  padding: 0;
  list-style: none;
}

.author-bio-card__chips {
  gap: 5px;
  flex-wrap: nowrap;
  justify-content: center;
  margin-left: -4px;
  margin-right: -4px;
}

.author-bio-card__chips li {
  padding: 3px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  transition: transform var(--motion-fast) var(--ease-spring), color var(--motion-fast) ease, border-color var(--motion-fast) ease;
}

.author-bio-card__chips li:hover {
  transform: translateY(-2px);
  color: var(--brand-strong);
  border-color: color-mix(in srgb, var(--brand) 50%, var(--line));
}

@media (prefers-reduced-motion: reduce) {
  .author-bio-card__aurora,
  .author-bio-card__ring,
  .author-bio-card__ring--dashed,
  .author-bio-card__halo,
  .author-bio-card__particle,
  .author-bio-card__status,
  .author-bio-card__pulse,
  .mr-monogram__halo,
  .mr-monogram__orbit,
  .mr-monogram__satellite,
  .site-logo__word--last {
    animation: none !important;
  }
}

/* ---------- Post Card: Spotlight + Reveal + Reading Time --------------- */
.post-card {
  position: relative;
  isolation: isolate;
}

.post-card__sheen {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  border-radius: inherit;
  background: radial-gradient(420px circle at var(--spot-x, 50%) var(--spot-y, 50%), color-mix(in srgb, var(--brand) 14%, transparent), transparent 55%);
  opacity: 0;
  transition: opacity var(--motion-base) var(--ease-out);
}

.post-card:hover .post-card__sheen { opacity: 1; }

.post-card__thumb {
  position: relative;
}

.post-card__thumb img {
  transition: transform .9s var(--ease-out);
}

.post-card:hover .post-card__thumb img { transform: scale(1.05); }

.post-card__reading {
  position: absolute;
  left: 12px;
  bottom: 12px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  padding: 4px 9px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 78%, transparent);
  color: #fff;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  backdrop-filter: blur(6px);
}

.post-card__body { position: relative; z-index: 2; }

.post-card__link {
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size: 0 1.5px;
  background-position: 0 100%;
  transition: background-size var(--motion-base) var(--ease-out), color var(--motion-fast) ease;
}

.post-card:hover .post-card__link {
  background-size: 100% 1.5px;
}

.read-more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  position: relative;
}

.read-more__arrow {
  width: 14px;
  height: 11px;
  transition: transform var(--motion-base) var(--ease-spring);
}

.read-more:hover .read-more__arrow {
  transform: translateX(4px);
}

/* Stagger reveal */
[data-reveal] {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .7s var(--ease-out), transform .7s var(--ease-spring);
  will-change: opacity, transform;
}

[data-reveal].is-visible {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* ---------- Entry Content: Pro Link Underline -------------------------- */
.entry-content a {
  position: relative;
  border-bottom: 0;
  background-image: linear-gradient(currentColor, currentColor);
  background-repeat: no-repeat;
  background-size: 100% 1.5px;
  background-position: 0 calc(100% - 1px);
  transition: background-size var(--motion-base) var(--ease-out), color var(--motion-fast) ease;
}

.entry-content a:hover {
  background-size: 0 1.5px;
  background-position: 100% calc(100% - 1px);
  color: var(--accent);
}

/* ---------- Hero Card subtle pattern ----------------------------------- */
.hero-card {
  position: relative;
  overflow: hidden;
}

.hero-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(color-mix(in srgb, var(--brand) 12%, transparent) 1px, transparent 1px);
  background-size: 22px 22px;
  mask-image: radial-gradient(circle at 80% 0%, #000, transparent 70%);
  -webkit-mask-image: radial-gradient(circle at 80% 0%, #000, transparent 70%);
  opacity: .55;
}

/* ---------- Section heading lift ------------------------------------- */
.section-heading h2 {
  font-family: var(--font-serif);
  letter-spacing: -0.012em;
}

/* ---------- Back to Top FAB ------------------------------------------ */
.back-to-top {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 90;
  width: 48px;
  height: 48px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand), color-mix(in srgb, var(--brand-strong) 60%, var(--accent)));
  color: #fff;
  cursor: pointer;
  display: grid;
  place-items: center;
  box-shadow: 0 12px 28px rgba(26, 43, 36, 0.28);
  opacity: 0;
  transform: translateY(20px) scale(.85);
  transition: opacity var(--motion-base) var(--ease-out), transform var(--motion-base) var(--ease-spring);
}

.back-to-top.is-visible {
  opacity: 1;
  transform: none;
}

.back-to-top[hidden] { display: none; }

.back-to-top:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px rgba(26, 43, 36, 0.32);
}

.back-to-top__ring {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
  pointer-events: none;
}

.back-to-top__track {
  fill: none;
  stroke: rgba(255, 255, 255, 0.18);
  stroke-width: 3;
}

.back-to-top__progress {
  fill: none;
  stroke: var(--accent);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  transition: stroke-dashoffset .15s linear;
}

.back-to-top__icon svg {
  width: 14px;
  height: 14px;
}

@media (max-width: 620px) {
  .back-to-top { right: 14px; bottom: 14px; }
}

/* ---------- Header polish --------------------------------------------- */
.site-header {
  background: color-mix(in srgb, var(--surface) 86%, transparent);
}

.icon-button {
  position: relative;
  width: 36px;
  height: 36px;
  transition: border-color var(--motion-fast) ease, color var(--motion-fast) ease, transform var(--motion-fast) var(--ease-spring), background-color var(--motion-fast) ease;
}

.icon-button:hover {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--brand) 8%, var(--surface));
}

.icon-button .ico {
  width: 17px;
  height: 17px;
  margin: 0;
  transform: none;
}

.icon-button .ico svg {
  width: 100%;
  height: 100%;
  display: block;
}

.icon-button--contact {
  color: var(--text);
}

.icon-button--contact:hover {
  color: var(--brand-strong);
  border-color: var(--brand);
}

.icon-button__dot {
  position: absolute;
  top: 7px;
  right: 7px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow:
    0 0 0 2px var(--surface),
    0 0 8px color-mix(in srgb, var(--accent) 60%, transparent);
  animation: mrvaPulseDot 2.6s ease-out infinite;
}

html[data-theme="dark"] .icon-button__dot {
  box-shadow: 0 0 0 2px var(--surface), 0 0 10px color-mix(in srgb, #e4b45a 70%, transparent);
}

/* Header tighten so primary nav doesn't wrap */
.site-header__inner {
  gap: 14px;
}

.header-actions {
  gap: 6px;
}

.main-navigation ul {
  gap: 0;
  flex-wrap: nowrap;
}

.main-navigation a {
  padding: 6px 9px;
  font-size: 13.5px;
}

.main-navigation .menu-item-has-children > a {
  padding-right: 22px;
}

.main-navigation .menu-item-has-children > a::before {
  right: 8px;
}

@media (max-width: 1100px) {
  .main-navigation a { padding: 6px 7px; font-size: 13px; }
}

@media (max-width: 980px) {
  .icon-button { width: 38px; height: 38px; }
  .main-navigation ul { flex-wrap: wrap; }
  .main-navigation a { padding: 6px 11px; font-size: 14px; }
}

.main-navigation a {
  transition: color var(--motion-fast) ease, background-color var(--motion-fast) ease, transform var(--motion-fast) var(--ease-spring);
}

.main-navigation a:hover {
  transform: translateY(-1px);
}

/* ---------- Focus ring -------------------------------------------- */
a:focus-visible,
button:focus-visible,
.icon-button:focus-visible,
.main-navigation a:focus-visible,
.post-card:focus-within {
  outline: none;
  box-shadow: var(--ring-brand);
  border-radius: 12px;
}

/* ---------- Designer (sidebar) micro-tilt ---------------------------- */
[data-tilt] {
  transform-style: preserve-3d;
  transform: perspective(900px) rotateX(0) rotateY(0);
  transition: transform var(--motion-base) var(--ease-out);
}

@media (prefers-reduced-motion: reduce) {
  [data-tilt] { transform: none !important; transition: none; }
}

/* ---------- Front-page heading: editorial ---------------------------- */
.home-heading h1 {
  font-family: var(--font-serif);
  letter-spacing: -0.02em;
}

/* ---------- Featured: Magazine Layout -------------------------------- */
.featured-section {
  margin-bottom: 32px;
}

.featured-heading {
  align-items: baseline;
}

.featured-heading h2 {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-serif);
  font-size: 22px;
  letter-spacing: -0.012em;
}

.featured-heading h2::before { content: none; }

.featured-heading__icon {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--brand), var(--accent));
  color: #fff;
  box-shadow: 0 6px 14px color-mix(in srgb, var(--brand) 22%, transparent);
}

.featured-heading__icon svg {
  width: 13px;
  height: 13px;
}

.featured-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border: 1px solid color-mix(in srgb, var(--brand) 22%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand) 5%, var(--surface));
  color: var(--brand-strong);
  font-family: var(--font-sans);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.featured-kicker::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 50%, transparent);
  animation: mrvaPulseDot 2.4s ease-out infinite;
}

.featured-magazine {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr);
  grid-template-rows: repeat(3, 1fr);
  gap: 14px;
  min-height: 420px;
}

/* === Lead card === */
.feat-lead {
  grid-column: 1;
  grid-row: 1 / span 3;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--ink);
  color: #fff;
  isolation: isolate;
  display: block;
  transition: transform var(--motion-base) var(--ease-spring), box-shadow var(--motion-base) var(--ease-out);
  box-shadow: var(--shadow);
}

.feat-lead:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lift);
  color: #fff;
}

.feat-lead__media {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  background: linear-gradient(135deg, color-mix(in srgb, var(--brand) 40%, var(--ink)), var(--ink));
}

.feat-lead__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s var(--ease-out);
}

.feat-lead:hover .feat-lead__media img {
  transform: scale(1.06);
}

.feat-lead__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, transparent 30%, rgba(8, 16, 13, 0.45) 60%, rgba(8, 16, 13, 0.92) 100%),
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 18%, transparent), transparent 55%);
  pointer-events: none;
}

.feat-lead__badge {
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px 5px 9px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 70%, var(--brand-strong)));
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 10.5px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.3);
}

.feat-lead__badge svg {
  width: 11px;
  height: 11px;
}

.feat-lead__body {
  position: absolute;
  inset: auto 0 0 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px 24px 24px;
}

.feat-lead__cat {
  align-self: flex-start;
  padding: 3px 9px;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  color: #f4faf7;
  font-family: var(--font-sans);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.feat-lead__title {
  color: #fff;
  font-family: var(--font-serif);
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: -0.018em;
}

.feat-lead__meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(244, 250, 247, 0.75);
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
}

.feat-dot {
  display: inline-block;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--accent);
}

/* === Side cards === */
.feat-side {
  grid-column: 2;
  position: relative;
  display: grid;
  grid-template-columns: 32px 92px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text);
  overflow: hidden;
  transition: transform var(--motion-base) var(--ease-spring), border-color var(--motion-fast) ease, box-shadow var(--motion-base) var(--ease-out);
}

.feat-side::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(90deg, color-mix(in srgb, var(--brand) 8%, transparent), transparent 50%);
  opacity: 0;
  transition: opacity var(--motion-fast) ease;
}

.feat-side:hover {
  transform: translateX(2px);
  border-color: color-mix(in srgb, var(--brand) 38%, var(--line));
  box-shadow: 0 10px 26px rgba(26, 43, 36, 0.08);
}

.feat-side:hover::before { opacity: 1; }

.feat-side__index {
  position: relative;
  z-index: 1;
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 800;
  background: linear-gradient(140deg, var(--brand-strong) 20%, var(--accent) 90%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  text-align: center;
  letter-spacing: -0.02em;
  line-height: 1;
}

.feat-side__media {
  position: relative;
  z-index: 1;
  width: 92px;
  height: 76px;
  border-radius: 10px;
  overflow: hidden;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--brand) 25%, transparent), transparent 60%),
    var(--surface-soft);
}

.feat-side__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .7s var(--ease-out);
}

.feat-side:hover .feat-side__media img { transform: scale(1.06); }

.feat-side__body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.feat-side__cat {
  color: var(--brand-strong);
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.feat-side__title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-family: var(--font-serif);
  font-size: 14.5px;
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.005em;
  color: var(--text);
}

.feat-side:hover .feat-side__title { color: var(--brand-strong); }

.feat-side__meta {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 11px;
}

/* === Dark mode tweaks === */
html[data-theme="dark"] .feat-side {
  background: color-mix(in srgb, var(--surface) 80%, var(--ink));
}

html[data-theme="dark"] .feat-lead__badge {
  color: var(--ink);
}

/* === Responsive === */
@media (max-width: 980px) {
  .featured-magazine {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto;
    min-height: 0;
  }
  .feat-lead {
    grid-column: 1;
    grid-row: auto;
    aspect-ratio: 16 / 10;
  }
  .feat-side {
    grid-column: 1;
  }
}

@media (max-width: 620px) {
  .feat-lead { aspect-ratio: 4 / 3; }
  .feat-lead__body { padding: 16px 16px 18px; }
  .feat-lead__title { font-size: 19px; }
  .feat-side {
    grid-template-columns: 26px 76px minmax(0, 1fr);
    gap: 10px;
    padding: 10px;
  }
  .feat-side__index { font-size: 18px; }
  .feat-side__media { width: 76px; height: 64px; }
  .feat-side__title { font-size: 13.5px; }
}

/* ---------- Inline icons (.ico) -------------------------------------- */
.ico {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1em;
  height: 1em;
  margin-right: 6px;
  flex: 0 0 auto;
  color: currentColor;
  vertical-align: -.12em;
}

.ico svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ---------- Category chip (post-card + archives) --------------------- */
.post-category {
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 4px 11px 4px 9px;
  border: 1px solid color-mix(in srgb, var(--brand) 28%, var(--line));
  border-radius: 999px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--brand) 10%, var(--surface)), var(--surface) 75%);
  color: var(--brand-strong);
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.4;
  transition: transform var(--motion-fast) var(--ease-spring), border-color var(--motion-fast) ease, color var(--motion-fast) ease;
}

.post-category .ico {
  width: 12px;
  height: 12px;
  margin-right: 6px;
  color: var(--accent);
}

.post-category:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  color: var(--accent);
}

.post-category:hover .ico { color: var(--brand-strong); }

/* ---------- Post meta with icons ------------------------------------- */
.post-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 14px;
  font-size: 12px;
  color: var(--muted);
}

.post-meta__item {
  display: inline-flex;
  align-items: center;
  gap: 0;
}

.post-meta__item .ico {
  width: 13px;
  height: 13px;
  margin-right: 5px;
  color: var(--brand);
  opacity: .85;
}

/* ---------- Breadcrumb with icons ------------------------------------ */
.breadcrumb {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 6px;
  margin: 0 0 12px;
  padding: 4px 10px 4px 8px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 80%, var(--surface-soft));
  color: var(--muted);
  font-size: 12px;
  width: max-content;
  max-width: 100%;
}

.breadcrumb__item {
  display: inline-flex;
  align-items: center;
  gap: 0;
  color: var(--muted);
  font-weight: 600;
  line-height: 1.2;
}

.breadcrumb__item--home .ico {
  width: 13px;
  height: 13px;
  margin-right: 5px;
  color: var(--brand-strong);
}

.breadcrumb__item--current {
  color: var(--text);
  font-weight: 700;
}

.breadcrumb__sep {
  display: inline-flex;
  align-items: center;
  width: 12px;
  height: 12px;
  color: color-mix(in srgb, var(--muted) 60%, transparent);
  opacity: .6;
}

.breadcrumb__sep .ico {
  width: 12px;
  height: 12px;
  margin: 0;
}

/* ---------- Widget title accent -------------------------------------- */
.widget-title,
.widget h2,
.related-posts h2 {
  position: relative;
  padding-left: 0;
}

/* ---------- Section heading dot -------------------------------------- */
.section-heading h2 {
  display: inline-flex;
  align-items: center;
  gap: 9px;
}

/* ---------- Animations override for non-motion users ----------------- */
@media (prefers-reduced-motion: reduce) {
  .reading-progress__bar { transition: none; }
  .ticker__pulse,
  .mr-monogram__halo,
  .mr-monogram__orbit,
  .mr-monogram__satellite {
    animation: none !important;
  }
}

@media (max-width: 620px) {
  .wrap {
    width: 100%;
    padding-inline: 12px;
  }

  .site-info,
  .post-nav {
    flex-direction: column;
    display: flex;
    align-items: stretch;
  }

  .ticker__links {
    display: none;
  }

  .top-strip__inner {
    min-height: 34px;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }

  .ticker {
    min-width: auto;
  }

  .ticker__label {
    font-size: 12px;
  }

  .top-strip__inner > span:last-child {
    font-size: 12px;
  }

  .site-main {
    padding-top: 18px;
  }

  .site-header__inner {
    padding-block: 8px;
  }

  .site-logo img,
  .custom-logo {
    width: 112px;
  }

  .site-logo--mark {
    min-width: auto;
    padding: 6px 8px;
  }

  .site-logo__symbol {
    width: 30px;
    height: 30px;
    font-size: 13px;
  }

  .site-logo__text {
    font-size: 14px;
  }

  .consent-flag {
    grid-template-columns: 1fr;
    bottom: 12px;
  }

  .consent-flag__actions {
    justify-content: space-between;
  }

  .consent-flag__actions a,
  .consent-flag__actions button {
    flex: 1;
  }

  .site-title,
  .site-description {
    display: none;
  }

  .post-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .featured-strip {
    grid-template-columns: 1fr;
  }

  .featured-tile {
    grid-template-columns: 92px minmax(0, 1fr);
    min-height: 112px;
  }

  .featured-tile__media {
    width: 92px;
    height: 84px;
  }

  .post-card__body {
    padding: 16px;
  }

  .post-card h2 {
    font-size: 18px;
  }

  .entry-content {
    padding: 18px;
  }

  .share-box {
    gap: 10px;
    padding: 14px 12px;
  }

  .share-box:has(.share-box__intro) {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .share-box > span:not([class]) {
    flex: 1 0 100%;
  }

  .share-box > a {
    flex: 1 1 calc(50% - 8px);
  }

  .share-box__links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
  }

  .share-box a {
    justify-content: center;
    padding-inline: 8px;
  }

  .contact-form {
    padding: 18px;
  }

  .contact-form__grid,
  .contact-form__footer {
    grid-template-columns: 1fr;
    display: grid;
  }

  .contact-form__captcha,
  .contact-form__submit {
    max-width: none;
    width: 100%;
  }

  .home-heading {
    padding: 17px 15px 20px;
  }

  .home-heading::after {
    height: 3px;
  }

  .home-heading h1 {
    font-size: 23px;
  }

  .single-header h1,
  .page-header h1,
  .archive-header h1 {
    font-size: 21px;
  }
}
