:root {
  color-scheme: light;
  --color-background: #f6f6f4;
  --color-background-strong: #e9e9e4;
  --color-surface: #ffffff;
  --color-surface-muted: #f4f4f1;
  --color-surface-warm: #f7f5f1;
  --color-card: #ffffff;
  --color-text: #222222;
  --color-heading: #090909;
  --color-muted: #6b6b66;
  --color-primary: #111111;
  --color-primary-hover: #343434;
  --color-primary-contrast: #ffffff;
  --color-primary-soft: #eeeeea;
  --color-accent: #5f5a52;
  --color-accent-dark: #2f2f2b;
  --color-accent-soft: #f0eee9;
  --color-border: #deded8;
  --color-border-strong: #bebeb6;
  --color-success: #16775f;
  --color-danger: #a13636;
  --color-info: #315f94;
  --color-info-soft: #e7eef7;
  --font-family-base: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-family-heading: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --shadow-card: 0 18px 42px rgba(17, 17, 17, 0.07);
  --shadow-raised: 0 24px 64px rgba(17, 17, 17, 0.12);
  --radius-card: 22px;
  --radius-inner: 16px;
  --radius-control: 14px;
  --container-max-width: 1120px;
  --header-height-offset: 5.25rem;
}
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-family-base);
  background:
    radial-gradient(circle at top left, rgba(17, 17, 17, 0.045), transparent 32rem),
    linear-gradient(180deg, #ffffff 0%, var(--color-background) 48%, #efefec 100%);
  color: var(--color-text);
  line-height: 1.62;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(rgba(17, 17, 17, 0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(17, 17, 17, 0.018) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.28), transparent 68%);
}

a {
  color: var(--color-primary);
  font-weight: 700;
  text-decoration: none;
  transition: color 150ms ease, background-color 150ms ease, border-color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

a:hover { color: var(--color-primary-hover); }

a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 3px solid rgba(17, 17, 17, 0.28);
  outline-offset: 3px;
}

button, input, textarea, select { font: inherit; }

button, .button-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 2.75rem;
  width: max-content;
  max-width: 100%;
  background: var(--color-primary);
  color: var(--color-primary-contrast);
  border: 1px solid var(--color-primary);
  border-radius: 999px;
  padding: 0.72rem 1.15rem;
  font-weight: 800;
  cursor: pointer;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(17, 17, 17, 0.13);
  transition: transform 140ms ease, box-shadow 140ms ease, background-color 140ms ease, border-color 140ms ease;
}

button:hover, .button-link:hover {
  transform: translateY(-1px);
  color: var(--color-primary-contrast);
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  box-shadow: 0 14px 30px rgba(17, 17, 17, 0.18);
}

.button-link-secondary, .button-link-ghost {
  background: transparent;
  color: var(--color-primary);
  box-shadow: none;
}

.button-link-secondary { border-color: rgba(17, 17, 17, 0.22); }
.button-link-ghost { border-color: transparent; }
.button-link-secondary:hover, .button-link-ghost:hover {
  color: var(--color-primary-hover);
  background: var(--color-primary-soft);
  border-color: var(--color-primary-soft);
  box-shadow: none;
}

.container { width: min(var(--container-max-width), calc(100% - 2rem)); margin: 0 auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid rgba(222, 222, 216, 0.88);
  backdrop-filter: blur(18px);
  box-shadow: 0 10px 30px rgba(17, 17, 17, 0.06);
}

.nav-shell {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-5);
  min-height: 5rem;
  padding: 0.7rem 0;
}

.brand-lockup { display: grid; gap: 0.1rem; min-width: min(36rem, 54vw); }
.brand {
  color: var(--color-primary);
  font-size: clamp(1.45rem, 2.4vw, 1.72rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.055em;
  text-decoration: none;
}
.brand:hover { color: var(--color-primary-hover); }
.tagline { margin: 0; color: var(--color-muted); font-size: 0.92rem; max-width: 42rem; }

.nav-toggle {
  display: none;
  min-height: 2.6rem;
  padding: 0.58rem 0.86rem;
  background: var(--color-surface);
  color: var(--color-primary);
  border-color: var(--color-border);
  box-shadow: none;
}
.nav-toggle:hover { color: var(--color-primary-hover); background: var(--color-primary-soft); box-shadow: none; }
.nav-toggle-icon { display: grid; gap: 0.22rem; width: 1.1rem; }
.nav-toggle-icon span { display: block; height: 2px; border-radius: 999px; background: currentColor; }

.site-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
}
.site-nav a:not(.button-link), .user-chip {
  border-radius: 999px;
  color: var(--color-text);
  font-weight: 800;
  padding: 0.55rem 0.8rem;
  text-decoration: none;
}
.site-nav a:not(.button-link):hover, .user-chip:hover { background: var(--color-primary-soft); color: var(--color-primary); }
.site-nav a[aria-current="page"] { background: #111111; color: #ffffff; }
.user-chip { background: var(--color-primary-soft); color: var(--color-primary); }
#logout-form { margin: 0; }
#nav-logout-button { min-height: 2.35rem; padding: 0.5rem 0.85rem; background: transparent; color: var(--color-primary); border-color: transparent; box-shadow: none; }
#nav-logout-button:hover { background: var(--color-primary-soft); color: var(--color-primary-hover); }

.page-shell { position: relative; padding: clamp(1.2rem, 2.5vw, 2rem) 0 2.75rem; }
.site-footer { border-top: 1px solid var(--color-border); background: rgba(255,255,255,0.76); }
.footer-shell { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; padding: 1.25rem 0; color: var(--color-muted); font-size: 0.95rem; }
.footer-shell p { margin: 0; }
.footer-links { display: flex; flex-wrap: wrap; gap: 0.85rem; }
.hero, .panel {
  margin: 0 0 1.35rem;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: clamp(1.15rem, 2.4vw, 2rem);
  box-shadow: var(--shadow-card);
}
.hero { overflow: hidden; }
.hero-split { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(280px, 0.8fr); gap: clamp(1rem, 2.2vw, 1.6rem); align-items: stretch; }
.hero-copy { display: grid; align-content: center; gap: 1rem; }
.hero h1 { max-width: 760px; font-size: clamp(2.15rem, 5vw, 4.25rem); line-height: 1.02; letter-spacing: -0.065em; margin-bottom: 0; }
.hero-lede { max-width: 680px; font-size: 1.15rem; color: var(--color-muted); margin-bottom: 0; }
.hero-card { display: grid; gap: 0.9rem; align-content: center; background: linear-gradient(145deg, #111111, #363636); color: #fff; border-radius: 20px; padding: 1.35rem; box-shadow: inset 0 1px 0 rgba(255,255,255,0.15); }
.hero-card p { color: rgba(255,255,255,0.82); margin: 0; }
.hero-card code { background: rgba(255,255,255,0.14); color: #fff; }
.narrow-panel { max-width: 740px; }
.page-intro { background: rgba(255, 253, 248, 0.98); }
.panel-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.hero-actions, .row-actions, .tag-row, .chip-row { display: flex; flex-wrap: wrap; gap: 0.7rem; align-items: center; }
.eyebrow { display: inline-block; margin: 0 0 0.5rem; color: var(--color-accent); font-weight: 900; text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.78rem; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { color: var(--color-heading); font-family: var(--font-family-heading); line-height: 1.17; letter-spacing: -0.025em; }
h2, h3 { margin-bottom: 0.35rem; }
p:last-child { margin-bottom: 0; }
.muted { color: var(--color-muted); }
.content-body { white-space: pre-wrap; }
.status-list, .stack { margin: 0; padding-left: 0; list-style: none; }
.stack { display: grid; gap: 1rem; }
.card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: 18px;
  padding: 1rem;
  box-shadow: 0 1px 0 rgba(255,255,255,0.8), 0 10px 24px rgba(17,17,17,0.045);
}
.card:hover { border-color: var(--color-border-strong); }
.question-card, .answer-card, .tag-card, .member-card { display: grid; gap: 0.8rem; }
.question-card { grid-template-columns: minmax(0, 1fr); }
.question-card h2, .question-card h3, .answer-card h3, .member-card h2 { margin-bottom: 0.2rem; }
.question-card h2 a, .question-card h3 a, .member-card h2 a, .tag-card h2 a { color: var(--color-heading); }
.question-card h2 a:hover, .question-card h3 a:hover, .member-card h2 a:hover, .tag-card h2 a:hover { color: var(--color-primary); }
.tag-pill, .accepted-badge, .status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border-radius: 999px;
  padding: 0.36rem 0.72rem;
  text-decoration: none;
  font-weight: 800;
  font-size: 0.92rem;
}
.tag-pill { background: var(--color-accent-soft); color: var(--color-accent-dark); border: 1px solid rgba(17,17,17,0.1); }
.tag-pill:hover { background: #e5e3dc; color: #111111; transform: translateY(-1px); }
.accepted-badge { background: #dff3ea; color: var(--color-success); width: max-content; }
.accepted-card { border-color: #87c8b2; box-shadow: 0 0 0 3px rgba(34, 116, 95, 0.08); }
.search-form { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: 0.7rem; align-items: center; margin-top: 0.9rem; }
.form-grid label { display: grid; gap: 0.4rem; font-weight: 800; }
input, textarea, select {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-control);
  padding: 0.88rem 0.95rem;
  background: #fff;
  color: var(--color-text);
  outline: none;
  box-shadow: inset 0 1px 0 rgba(23,33,27,0.02);
}
textarea { resize: vertical; }
input::placeholder, textarea::placeholder { color: #8a9288; }
input:focus, textarea:focus, select:focus { border-color: var(--color-primary); box-shadow: 0 0 0 4px rgba(17, 17, 17, 0.11); }
.error-box { border: 1px solid #efb4b4; background: #fff1f1; color: var(--color-danger); border-radius: 14px; padding: 0.9rem 1rem; margin-bottom: 1rem; }
.error-box ul { margin: 0; padding-left: 1rem; }
.empty-state { padding: 1rem; border: 1px dashed var(--color-border-strong); border-radius: 16px; background: var(--color-surface-muted); }
.empty-state strong { color: var(--color-heading); }
.empty-state p { margin-bottom: 0; }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1rem; }
.stats-grid .card { display: grid; gap: 0.4rem; }
.stats-grid span { font-size: 1.5rem; font-weight: 900; }
.mini-meta, .stats-strip { margin: 0; display: grid; gap: 0.75rem; }
.mini-meta div, .stats-strip div { display: grid; gap: 0.1rem; }
.mini-meta dt, .stats-strip dt { color: var(--color-muted); font-size: 0.78rem; font-weight: 900; letter-spacing: 0.07em; text-transform: uppercase; }
.mini-meta dd, .stats-strip dd { margin: 0; font-weight: 850; }
.member-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1rem; }
.member-card { align-content: start; }
.avatar-mark { display: inline-grid; place-items: center; width: 3rem; height: 3rem; border-radius: 1rem; background: var(--color-primary-soft); color: var(--color-primary); font-weight: 900; font-size: 1.2rem; }
.avatar-mark-large { width: 4.5rem; height: 4.5rem; border-radius: 1.4rem; font-size: 1.8rem; }
.member-profile-hero { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 1.2rem; align-items: center; }
.profile-stats { grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); }
code { background: #efefea; border-radius: 7px; padding: 0.15rem 0.36rem; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.admin-dashboard-root { gap: 1.25rem; }
.admin-hero-panel { margin-bottom: 0; background: linear-gradient(145deg, rgba(255,253,248,0.98), rgba(246,239,226,0.94)); }
.admin-layout { display: grid; grid-template-columns: minmax(240px, 0.25fr) minmax(0, 1fr); gap: 1.25rem; align-items: start; }
.admin-main { min-width: 0; }
.admin-mobile-shell { display: none; align-items: center; justify-content: space-between; gap: 0.75rem; }
.admin-sidebar-backdrop { display: none; }
.admin-sidebar { position: sticky; top: calc(var(--header-height-offset) + 1rem); display: grid; gap: 1rem; margin-bottom: 0; align-self: start; background: linear-gradient(180deg, #173b2f, #224f41 58%, #2f6653); color: rgba(255,255,255,0.88); border-color: rgba(255,255,255,0.12); box-shadow: 0 24px 60px rgba(23, 33, 27, 0.18); }
.admin-sidebar .eyebrow, .admin-sidebar strong { color: #fff; }
.admin-sidebar-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 0.75rem; }
.admin-sidebar-close { display: none; min-height: 2.25rem; width: 2.25rem; padding: 0; border-radius: 999px; background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.2); color: #fff; box-shadow: none; font-size: 1.25rem; }
.admin-sidebar-nav { display: grid; gap: 0.45rem; }
.admin-sidebar-nav a { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; border: 1px solid transparent; border-radius: 14px; color: rgba(255,255,255,0.84); font-weight: 850; padding: 0.78rem 0.9rem; text-decoration: none; }
.admin-sidebar-nav a:hover { background: rgba(255,255,255,0.1); color: #fff; border-color: rgba(255,255,255,0.14); }
.admin-sidebar-nav a.is-active { background: #fff; color: var(--color-primary); border-color: #fff; box-shadow: 0 14px 32px rgba(0,0,0,0.12); }
.admin-current-indicator { border-radius: 999px; padding: 0.2rem 0.5rem; background: var(--color-accent-soft); color: var(--color-accent-dark); font-size: 0.72rem; font-weight: 900; letter-spacing: 0.04em; text-transform: uppercase; }
.admin-sidebar-note { margin: 0; font-size: 0.92rem; color: rgba(255,255,255,0.74); }
.admin-dashboard-shell { gap: 1.25rem; }
.admin-overview-grid, .admin-form-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.admin-stats-grid { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.admin-system-grid { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.admin-job-status-grid { grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); }
.admin-record-card { gap: 0.85rem; border-left: 4px solid rgba(47, 102, 83, 0.22); }
.admin-filter-form { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0.7rem; align-items: end; padding: 1rem; border: 1px solid var(--color-border); border-radius: 16px; background: rgba(249, 246, 239, 0.95); box-shadow: 0 12px 28px rgba(47,58,43,0.06); }
.admin-filter-sticky { position: sticky; top: calc(var(--header-height-offset) + 0.65rem); z-index: 20; backdrop-filter: blur(14px); }
.admin-filter-form label { font-weight: 800; }
.admin-filter-form input, .admin-filter-form select { background: #fff; }
.admin-filter-form button, .admin-filter-form .button-link { align-self: end; }
.card-heading-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 0.75rem; }
.meta-list { margin: 0; display: grid; gap: 0.75rem; }
.meta-list > div { display: grid; gap: 0.2rem; }
.meta-list dt { font-size: 0.85rem; color: var(--color-muted); font-weight: 800; text-transform: uppercase; letter-spacing: 0.04em; }
.meta-list dd { margin: 0; }
.compact-meta-list { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.notice-box, .notice-inline { border-radius: 14px; border: 1px solid var(--color-border); padding: 0.9rem 1rem; }
.notice-box p, .notice-inline p { margin-bottom: 0; }
.notice-box-success { background: #ecfdf5; border-color: #86efac; color: #166534; }
.notice-box-info { background: var(--color-info-soft); border-color: #93c5fd; color: #1e3a8a; }
.notice-inline-danger { background: #fef2f2; border-color: #fecaca; color: var(--color-danger); }
.notice-inline-muted { background: #f8fafc; }
.status-badge { text-transform: capitalize; }
.status-badge-success { background: #dcfce7; color: #166534; }
.status-badge-danger { background: #fee2e2; color: #991b1b; }
.status-badge-info { background: var(--color-info-soft); color: var(--color-info); }
.status-badge-muted { background: #e5e7eb; color: #374151; }
.admin-action-form { background: #ffffff; border: 1px solid var(--color-border); border-radius: 14px; padding: 1rem; }
.admin-action-form label { font-weight: 700; }
.admin-action-form textarea { min-height: 5.25rem; }
.admin-note-list { display: grid; gap: 0.75rem; padding-left: 1.1rem; }
.admin-runtime-note { margin-bottom: 0; }
.admin-health-card code { font-size: 0.92em; }
.admin-health-card .meta-list dd { overflow-wrap: anywhere; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; }
}
@media (max-width: 980px) {
  .admin-layout { grid-template-columns: 1fr; }
  .admin-mobile-shell { display: flex; position: sticky; top: calc(var(--header-height-offset) + 0.35rem); z-index: 35; padding: 0.7rem; border: 1px solid var(--color-border); border-radius: 18px; background: rgba(255,253,248,0.94); box-shadow: var(--shadow-card); backdrop-filter: blur(14px); }
  .admin-sidebar-toggle { min-height: 2.5rem; padding: 0.58rem 0.9rem; }
  .admin-sidebar-close { display: inline-flex; align-items: center; justify-content: center; }
  .js .admin-sidebar { position: fixed; inset: 0 auto 0 0; z-index: 70; width: min(84vw, 20rem); max-height: 100vh; overflow-y: auto; border-radius: 0 22px 22px 0; transform: translateX(-106%); opacity: 0.98; transition: transform 190ms ease; }
  .js .admin-sidebar[data-open="true"] { transform: translateX(0); }
  .js .admin-sidebar-backdrop[data-open="true"] { display: block; position: fixed; inset: 0; z-index: 65; background: rgba(16,25,19,0.38); backdrop-filter: blur(2px); }
  .admin-filter-sticky { top: calc(var(--header-height-offset) + 4.9rem); }
}
@media (max-width: 820px) {
  .hero-split, .member-profile-hero { grid-template-columns: 1fr; }
  .search-form, .admin-filter-form { grid-template-columns: 1fr; }
  .search-form button, .search-form .button-link, .admin-filter-form button, .admin-filter-form .button-link { width: 100%; }
}
@media (max-width: 720px) {
  .container { width: min(var(--container-max-width), calc(100% - 1rem)); }
  .nav-shell { min-height: 4.25rem; align-items: center; gap: 0.75rem; }
  .brand-lockup { min-width: 0; }
  .tagline { display: none; }
  .js .nav-toggle { display: inline-flex; }
  .site-nav { width: 100%; justify-content: flex-start; gap: 0.5rem; }
  .js .site-nav {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% - 0.35rem);
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    max-height: 26rem;
    overflow: hidden;
    padding: 0.55rem;
    background: rgba(255, 253, 248, 0.98);
    border: 1px solid var(--color-border);
    border-radius: 0 0 20px 20px;
    box-shadow: var(--shadow-raised);
    transform-origin: top;
    opacity: 1;
    transform: scaleY(1);
    transition: max-height 180ms ease, opacity 180ms ease, transform 180ms ease, padding 180ms ease, border-color 180ms ease;
  }
  .js .site-nav[data-open="false"] {
    max-height: 0;
    opacity: 0;
    transform: scaleY(0.98);
    padding-top: 0;
    padding-bottom: 0;
    border-color: transparent;
    pointer-events: none;
  }
  .site-nav a:not(.button-link), .site-nav .button-link, .site-nav button { width: 100%; justify-content: flex-start; }
  #logout-form { width: 100%; }
  .panel-header { flex-direction: column; align-items: flex-start; }
  .hero, .panel { border-radius: 18px; }
}
@media (max-width: 480px) {
  .hero h1 { font-size: clamp(2rem, 14vw, 3rem); }
  .hero-actions .button-link, .row-actions button, .row-actions .button-link { width: 100%; }
  .member-profile-hero { justify-items: start; }
}

/* Phase 2 public editorial and media-card polish */
.hero-editorial {
  position: relative;
  isolation: isolate;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(246, 239, 226, 0.94)),
    radial-gradient(circle at 78% 18%, rgba(153, 108, 54, 0.18), transparent 18rem);
}

.hero-editorial::after,
.visual-panel::after,
.media-card::before,
.empty-state-illustrated::before {
  content: "";
  position: absolute;
  pointer-events: none;
}

.hero-editorial::after {
  right: clamp(1rem, 4vw, 3rem);
  bottom: -2rem;
  width: 15rem;
  height: 15rem;
  border: 1px solid rgba(17, 17, 17, 0.11);
  border-radius: 42% 58% 50% 50%;
  background: radial-gradient(circle at 38% 34%, rgba(17, 17, 17, 0.12), transparent 0.6rem), radial-gradient(circle at 64% 54%, rgba(95, 90, 82, 0.11), transparent 3.6rem);
  opacity: 0.55;
  z-index: -1;
}

.visual-panel {
  position: relative;
  overflow: hidden;
}

.visual-panel::after {
  inset: auto -2.5rem -3rem auto;
  width: 12rem;
  height: 12rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.24), transparent 68%);
}

.visual-kicker,
.card-kicker,
.privacy-note {
  margin: 0;
  color: var(--color-accent);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.hero-card .visual-kicker { color: rgba(255, 255, 255, 0.76); }

.media-strip,
.auth-layout,
.question-detail-hero {
  display: grid;
  gap: 1rem;
}

.media-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 1.35rem;
}

.media-card {
  position: relative;
  min-height: 15rem;
  display: grid;
  align-content: end;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 1.15rem;
  background: var(--color-surface);
  box-shadow: var(--shadow-card);
}

.media-card::before {
  inset: 0;
  background:
    linear-gradient(180deg, transparent 0%, rgba(16, 25, 19, 0.03) 42%, rgba(16, 25, 19, 0.07) 100%),
    radial-gradient(circle at 72% 20%, rgba(255, 255, 255, 0.42), transparent 6rem),
    linear-gradient(135deg, rgba(17, 17, 17, 0.07), rgba(95, 90, 82, 0.08));
}

.media-card > * { position: relative; }
.media-card-pasture { background: linear-gradient(135deg, #f6f6f3, #ffffff); }
.media-card-tack { background: linear-gradient(135deg, #ffffff, #eeeeea); }
.media-card-arena { background: linear-gradient(135deg, #f3f4f6, #ffffff); }
.media-icon {
  position: absolute;
  top: 0.9rem;
  right: 1rem;
  color: rgba(17, 17, 17, 0.16);
  font-size: 4rem;
  font-weight: 900;
  line-height: 1;
}

.search-form-featured {
  padding: 0.45rem;
  border: 1px solid rgba(17, 17, 17, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82), 0 10px 28px rgba(17, 17, 17, 0.06);
}
.search-form-featured input { border-color: transparent; background: transparent; box-shadow: none; }
.search-form-featured input:focus { background: #fff; }

.search-scope-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.85rem;
}
.search-scope-row span,
.compact-stats div,
.prompt-panel {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-muted);
  padding: 0.42rem 0.75rem;
  color: var(--color-muted);
  font-size: 0.9rem;
  font-weight: 800;
}
.search-scope-row span:first-child { color: var(--color-primary); background: var(--color-primary-soft); }

.question-card-media {
  grid-template-columns: minmax(0, 1fr) minmax(13rem, 0.32fr);
  align-items: start;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.96), rgba(255,253,248,0.94)),
    radial-gradient(circle at 94% 10%, rgba(17, 17, 17, 0.07), transparent 8rem);
}
.question-card-aside { display: grid; gap: 0.8rem; align-content: start; }
.compact-stats { grid-template-columns: repeat(auto-fit, minmax(6.5rem, 1fr)); }
.compact-stats div { border-radius: 14px; }
.compact-stats dd { font-size: 1.2rem; color: var(--color-heading); }

.question-detail-hero {
  grid-template-columns: minmax(0, 1fr) minmax(16rem, 0.34fr);
  align-items: stretch;
}
.detail-context-card {
  display: grid;
  gap: 1rem;
  align-content: start;
  border: 1px solid rgba(17, 17, 17, 0.1);
  border-radius: 20px;
  padding: 1rem;
  background: linear-gradient(145deg, var(--color-surface-muted), #ffffff);
}
.answer-media-card { border-left: 5px solid rgba(17, 17, 17, 0.18); }
.answer-compose-panel { margin-inline: auto; }

.prompt-panel {
  display: grid;
  gap: 0.5rem;
  border-radius: 18px;
  margin: 1rem 0;
  color: var(--color-text);
}
.feature-list { margin: 0; padding-left: 1.15rem; color: var(--color-muted); }
.feature-list li + li { margin-top: 0.45rem; }

.tag-directory-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}
.tag-media-card { min-height: 13rem; align-content: space-between; background: linear-gradient(145deg, #fffdf8, var(--color-surface-warm)); }
.tag-cloud .tag-pill { font-size: 1rem; padding: 0.48rem 0.86rem; }

.member-directory-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.member-media-card {
  position: relative;
  overflow: hidden;
  background: linear-gradient(145deg, #ffffff, var(--color-surface-muted));
}
.member-media-card::after {
  content: "";
  position: absolute;
  right: -2rem;
  top: -2rem;
  width: 7rem;
  height: 7rem;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.06);
}
.member-media-card > * { position: relative; }
.member-profile-editorial { background: linear-gradient(135deg, var(--color-surface), var(--color-primary-soft)); }
.privacy-note {
  width: max-content;
  max-width: 100%;
  border: 1px solid rgba(17, 17, 17, 0.12);
  border-radius: 999px;
  padding: 0.42rem 0.75rem;
  background: rgba(255, 255, 255, 0.62);
  color: var(--color-primary);
}

.auth-layout {
  grid-template-columns: minmax(0, 0.95fr) minmax(18rem, 0.55fr);
  align-items: stretch;
}
.auth-panel,
.auth-side-card { margin-bottom: 0; }
.auth-side-card {
  align-content: center;
  background: linear-gradient(145deg, #111111, #333333 56%, #5f5a52);
  color: #fff;
}
.auth-side-card h2 { color: #fff; }
.auth-side-card .feature-list,
.auth-side-card .privacy-note { color: rgba(255, 255, 255, 0.82); }
.auth-side-card .visual-kicker { color: rgba(255, 255, 255, 0.72); }
.auth-side-card .privacy-note { border-color: rgba(255,255,255,0.22); background: rgba(255,255,255,0.12); }

.empty-state-illustrated {
  position: relative;
  overflow: hidden;
  padding-right: 5rem;
}
.empty-state-illustrated::before {
  right: 1rem;
  top: 50%;
  width: 3rem;
  height: 3rem;
  border-radius: 40% 60% 55% 45%;
  transform: translateY(-50%);
  background: linear-gradient(135deg, rgba(47, 102, 83, 0.14), rgba(153, 108, 54, 0.18));
}

@media (max-width: 900px) {
  .media-strip,
  .auth-layout,
  .question-detail-hero,
  .question-card-media { grid-template-columns: 1fr; }
  .question-card-aside { grid-template-columns: minmax(0, 1fr); }
}

@media (max-width: 820px) {
  .search-form-featured { border-radius: 18px; }
}
.auth-side-card { display: grid; gap: 1rem; }

/* Phase 2 public premium-neutral refinement: token-first, restrained color, intentional shell */
:root {
  --color-background: #f6f6f3;
  --color-background-strong: #ececea;
  --color-surface: #ffffff;
  --color-surface-muted: #f8f8f6;
  --color-surface-warm: #f5f4f0;
  --color-card: #ffffff;
  --color-text: #242424;
  --color-heading: #0b0b0c;
  --color-muted: #6d6d6a;
  --color-primary: #2d5d4d;
  --color-primary-hover: #173d33;
  --color-primary-contrast: #ffffff;
  --color-primary-soft: #e7f0ec;
  --color-accent: #7a6242;
  --color-accent-dark: #4d3e2a;
  --color-accent-soft: #f0ebe2;
  --color-border: #e2e2dd;
  --color-border-strong: #c9c9c2;
  --color-info-soft: #edf3f8;
  --shadow-card: 0 1px 2px rgba(15, 23, 42, 0.04), 0 18px 48px rgba(15, 23, 42, 0.06);
  --shadow-raised: 0 24px 70px rgba(15, 23, 42, 0.12);
}

body {
  background:
    radial-gradient(circle at 16% -8%, rgba(45, 93, 77, 0.08), transparent 28rem),
    linear-gradient(180deg, #ffffff 0%, var(--color-background) 52%, #efefec 100%);
  color: var(--color-text);
}

body::before {
  background-image: linear-gradient(rgba(17, 24, 39, 0.024) 1px, transparent 1px), linear-gradient(90deg, rgba(17, 24, 39, 0.018) 1px, transparent 1px);
  opacity: 0.8;
}

.site-header {
  background: rgba(255, 255, 255, 0.9);
  border-bottom-color: rgba(226, 226, 221, 0.9);
}

.brand { color: var(--color-heading); }
.brand:hover { color: var(--color-primary); }

.site-nav a:not(.button-link).is-active,
.site-nav a:not(.button-link)[aria-current="page"] {
  background: #111111;
  color: #ffffff;
}

.site-nav a:not(.button-link).is-active:hover,
.site-nav a:not(.button-link)[aria-current="page"]:hover {
  background: #000000;
  color: #ffffff;
}

.hero,
.panel,
.media-card,
.card {
  background: rgba(255, 255, 255, 0.96);
  border-color: var(--color-border);
}

.hero-editorial,
.admin-hero-panel,
.member-profile-editorial,
.question-card-media,
.member-media-card,
.tag-media-card,
.detail-context-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,248,246,0.96));
}

.hero-editorial::after,
.visual-panel::after,
.media-card::before,
.member-media-card::after,
.empty-state-illustrated::before {
  opacity: 0.42;
}

.hero-card,
.auth-side-card {
  background: linear-gradient(145deg, #111111, #27332f 58%, #2d5d4d);
}

.media-card-pasture,
.media-card-tack,
.media-card-arena {
  background: linear-gradient(145deg, #ffffff, #f3f3ef);
}

.media-card::before {
  background:
    linear-gradient(180deg, transparent 0%, rgba(17, 24, 39, 0.03) 48%, rgba(17, 24, 39, 0.065) 100%),
    radial-gradient(circle at 78% 22%, rgba(45, 93, 77, 0.12), transparent 7rem);
}

button,
.button-link {
  letter-spacing: -0.01em;
}

.button-link-secondary,
.button-link-ghost,
#nav-logout-button {
  color: var(--color-heading);
}

.button-link-secondary:hover,
.button-link-ghost:hover,
#nav-logout-button:hover {
  color: var(--color-heading);
  background: var(--color-surface-muted);
}

.tag-pill {
  background: var(--color-surface-muted);
  color: var(--color-heading);
  border-color: var(--color-border);
}

.tag-pill:hover {
  background: #111111;
  color: #ffffff;
  border-color: #111111;
}

.search-form-featured {
  border-color: var(--color-border);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 12px 34px rgba(15, 23, 42, 0.055);
}

input,
textarea,
select {
  border-color: var(--color-border-strong);
  background: #ffffff;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--color-heading);
  box-shadow: 0 0 0 4px rgba(17, 17, 17, 0.08);
}

.empty-state,
.prompt-panel,
.search-scope-row span,
.compact-stats div {
  background: var(--color-surface-muted);
}

.site-footer {
  border-top: 1px solid var(--color-border);
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(14px);
}

.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.25rem;
  align-items: center;
  padding: 1.4rem 0;
}

.footer-brand {
  display: grid;
  gap: 0.35rem;
}

.footer-brand p {
  margin: 0;
  max-width: 44rem;
  color: var(--color-muted);
}

.footer-brand-link {
  width: max-content;
  font-size: 1.2rem;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.5rem;
}

.footer-links a {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.48rem 0.75rem;
  color: var(--color-heading);
  font-weight: 800;
}

.footer-links a:hover {
  border-color: #111111;
  background: #111111;
  color: #ffffff;
}

@media (max-width: 720px) {
  .footer-grid {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .footer-links {
    justify-content: flex-start;
  }
}

/* Phase 3 public Q&A UX modernization */
.home-hero-premium .hero-lede { font-size: clamp(1.08rem, 2vw, 1.28rem); }
.search-form-hero { max-width: 760px; }
.search-form-hero input { font-size: 1.05rem; }
.trust-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin: 0 0 1.35rem;
}
.trust-strip div {
  display: grid;
  gap: 0.25rem;
  padding: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow-card);
}
.trust-strip strong { color: var(--color-heading); }
.trust-strip span { color: var(--color-muted); font-size: 0.95rem; }
.topic-lane-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.topic-lane-card { min-height: 13rem; align-content: space-between; }
.featured-questions-panel { background: linear-gradient(180deg, #ffffff, var(--color-surface-muted)); }
.latest-questions-panel { background: rgba(255, 255, 255, 0.92); }
.question-card-premium { border-left: 4px solid rgba(45, 93, 77, 0.28); }
.topic-badge { text-transform: none; }
.calm-stats div { background: #ffffff; }
.ask-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.48fr);
  gap: 1.25rem;
  align-items: start;
}
.ask-guide-panel { margin: 0; border-radius: var(--radius-card); align-content: start; }
.field-help { color: var(--color-muted); font-weight: 700; }
.auth-link-note { margin-top: 1rem; }
.checklist-list li::marker { color: var(--color-primary); }
@media (max-width: 980px) {
  .topic-lane-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ask-layout { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .trust-strip, .topic-lane-grid { grid-template-columns: 1fr; }
}
