/* =============================================================
   에디토리얼 리디자인 (방향 A) — 셀프호스트 서브셋 폰트 + 토큰
   ============================================================= */
@font-face { font-family: "Song Myung"; font-style: normal; font-weight: 400; font-display: swap; src: url("/assets/fonts/song-myung-400.woff2") format("woff2"); }
@font-face { font-family: "Gowun Batang"; font-style: normal; font-weight: 400; font-display: swap; src: url("/assets/fonts/gowun-batang-400.woff2") format("woff2"); }
@font-face { font-family: "Gowun Batang"; font-style: normal; font-weight: 700; font-display: swap; src: url("/assets/fonts/gowun-batang-700.woff2") format("woff2"); }
@font-face { font-family: "IBM Plex Sans KR"; font-style: normal; font-weight: 400; font-display: swap; src: url("/assets/fonts/ibm-plex-sans-kr-400.woff2") format("woff2"); }
@font-face { font-family: "IBM Plex Sans KR"; font-style: normal; font-weight: 600; font-display: swap; src: url("/assets/fonts/ibm-plex-sans-kr-600.woff2") format("woff2"); }
@font-face { font-family: "IBM Plex Sans KR"; font-style: normal; font-weight: 700; font-display: swap; src: url("/assets/fonts/ibm-plex-sans-kr-700.woff2") format("woff2"); }
@font-face { font-family: "IBM Plex Mono"; font-style: normal; font-weight: 400; font-display: swap; src: url("/assets/fonts/ibm-plex-mono-400.woff2") format("woff2"); }
@font-face { font-family: "IBM Plex Mono"; font-style: normal; font-weight: 500; font-display: swap; src: url("/assets/fonts/ibm-plex-mono-500.woff2") format("woff2"); }

:root {
  /* 에디토리얼 팔레트 — 변수명 유지, 값만 교체해 기존 var() 참조가 자동 재스킨 */
  --ink: #1d1812;
  --muted: #73695b;
  --subtle: #8a7f6d;
  --line: #ddd1bf;
  --paper: #f3ece1;
  --surface: #eae1d0;
  --surface-strong: #e2d8c4;
  --blue: #cf3b22;        /* 액션/포인트 → 주칠 버밀리언 */
  --green: #15655a;       /* 보조/출처 → 단청 청록 */
  --red: #b3402c;
  --gold: #9c7a2e;
  --navy: #1d1812;        /* 다크 섹션 → 잉크 */
  --shadow: 0 14px 34px rgba(29, 24, 18, 0.1);
  --radius: 0;            /* 전역 샤프; 알약은 --radius-pill */

  /* 신규 토큰 */
  --serif: "Song Myung", "Nanum Myeongjo", serif;
  --serif-body: "Gowun Batang", serif;
  --sans: "IBM Plex Sans KR", system-ui, -apple-system, "Apple SD Gothic Neo", "Noto Sans KR", "Segoe UI", sans-serif;
  --mono: "IBM Plex Mono", "IBM Plex Sans KR", monospace;
  --band: #eae1d0;
  --card: #fffdf8;
  --faint: #a39a89;
  --accent: #cf3b22;
  --accent-2: #15655a;
  --ink-kicker: #e8a08f;  /* 다크 섹션 위 살구빛 키커 */
  --text-strong: #2c261d;
  --text-lead: #4a4338;
  --radius-pill: 999px;
  --shadow-card: 0 10px 26px rgba(29, 24, 18, 0.06);
  --shadow-hover: 0 18px 44px rgba(29, 24, 18, 0.12);
  --shadow-soft: 0 10px 26px rgba(29, 24, 18, 0.06);  /* 1759행 dangling var() 수정 */
}

* {
  box-sizing: border-box;
}

html {
  color: var(--ink);
  font-family: var(--sans);
  letter-spacing: 0;
  background: var(--paper);
}

/* 에디토리얼 타이포: 제목은 명조 디스플레이(Song Myung, 400) */
h1, h2, h3, h4 {
  font-family: var(--serif);
  font-weight: 400;
  word-break: keep-all;
}

/* 콘텐츠 산문만 본문 명조(Gowun Batang) — UI 전반은 sans 유지 */
.guide-lead,
.guide-body p,
.detail-content article p,
.district-intro p,
blockquote {
  font-family: var(--serif-body);
}

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

:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

body {
  margin: 0;
  min-width: 320px;
  background: var(--paper);
}

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

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

button,
input,
select {
  font: inherit;
}

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

.skip-link {
  position: absolute;
  left: 16px;
  top: -80px;
  z-index: 100;
  padding: 10px 14px;
  border-radius: var(--radius);
  background: var(--ink);
  color: white;
}

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

.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;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(243, 236, 225, 0.9);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
}

.header-inner {
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  min-width: max-content;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius);
  background: var(--navy);
  color: white;
  font-weight: 800;
}

.brand strong,
.brand small {
  display: block;
  line-height: 1.05;
}

.brand strong {
  font-family: var(--serif);
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: 0.02em;
}

.brand small {
  margin-top: 5px;
  color: var(--faint);
  font-family: var(--mono);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.22em;
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  overflow-x: auto;
  scrollbar-width: none;
}

.main-nav a {
  padding: 10px 12px;
  border-radius: var(--radius);
  color: var(--muted);
  font-size: 0.94rem;
  font-weight: 700;
  white-space: nowrap;
}

.main-nav a {
  position: relative;
}

.main-nav a[aria-current="page"],
.main-nav a:hover {
  background: transparent;
  color: var(--ink);
  box-shadow: inset 0 -2px 0 var(--accent);
}

.command-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: max-content;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  padding: 9px 14px;
  background: var(--card);
  color: var(--muted);
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(29, 24, 18, 0.06);
}

.command-trigger:hover,
.command-trigger:focus-visible {
  border-color: rgba(207, 59, 34, 0.45);
  outline: 0;
  box-shadow: 0 0 0 4px rgba(207, 59, 34, 0.12);
}

.command-trigger kbd,
.command-palette kbd {
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 2px 5px;
  background: var(--surface);
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.command-palette[hidden] {
  display: none;
}

.is-command-open {
  overflow: hidden;
}

.command-palette {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: start center;
  padding: 80px 16px 24px;
}

.command-palette__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(29, 24, 18, 0.52);
  backdrop-filter: blur(8px);
  cursor: pointer;
}

.command-palette__panel {
  position: relative;
  width: min(760px, 100%);
  max-height: min(760px, calc(100vh - 108px));
  overflow: hidden;
  border: 1px solid rgba(221, 209, 191, 0.9);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 28px 80px rgba(29, 24, 18, 0.24);
}

.command-palette__search {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
}

.command-palette__search > span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius);
  background: var(--surface-strong);
  color: var(--green);
  font-weight: 900;
}

.command-palette__search input {
  min-width: 0;
  border: 0;
  outline: 0;
  color: var(--ink);
  font-size: 1.05rem;
  font-weight: 800;
}

.command-palette__search button {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 8px 10px;
  background: var(--surface);
  color: var(--muted);
  font-weight: 800;
  cursor: pointer;
}

.command-palette__meta {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 18px 10px;
}

.command-palette__meta h2 {
  margin: 0;
  font-size: 1.25rem;
  line-height: 1.25;
}

.command-palette__meta p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.6;
}

.command-palette__meta > p {
  max-width: 310px;
  text-align: right;
}

.command-palette__chips {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 8px 18px 12px;
  scrollbar-width: none;
}

.command-palette__chips button {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 11px;
  background: var(--card);
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 800;
  white-space: nowrap;
  cursor: pointer;
}

.command-palette__chips button[aria-pressed="true"],
.command-palette__chips button:hover {
  border-color: rgba(207, 59, 34, 0.35);
  background: rgba(207, 59, 34, 0.08);
  color: var(--blue);
}

.command-palette__status {
  margin: 0;
  padding: 0 18px 10px;
  color: var(--subtle);
  font-size: 0.86rem;
  font-weight: 700;
}

.command-palette__results {
  max-height: min(500px, calc(100vh - 330px));
  overflow-y: auto;
  padding: 8px 10px 12px;
}

.command-palette__item {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 12px;
  padding: 11px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  color: var(--ink);
}

.command-palette__item + .command-palette__item {
  margin-top: 4px;
}

.command-palette__item.is-active,
.command-palette__item:hover,
.command-palette__item:focus-visible {
  border-color: rgba(207, 59, 34, 0.25);
  outline: 0;
  background: linear-gradient(90deg, rgba(207, 59, 34, 0.08), rgba(21, 101, 90, 0.06));
}

.command-palette__item-icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius);
  background: var(--navy);
  color: white;
  font-size: 0.84rem;
  font-weight: 900;
}

.command-palette__item strong,
.command-palette__item small,
.command-palette__item em {
  display: block;
  min-width: 0;
}

.command-palette__item strong {
  overflow: hidden;
  font-size: 0.98rem;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.command-palette__item small {
  margin-top: 3px;
  color: var(--green);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 900;
}

.command-palette__item em {
  display: -webkit-box;
  overflow: hidden;
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.87rem;
  font-style: normal;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.command-palette__empty {
  padding: 28px 18px 30px;
  text-align: center;
}

.command-palette__empty strong {
  display: block;
  margin-bottom: 8px;
  font-size: 1.05rem;
}

.command-palette__empty p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.section-navigator[hidden] {
  display: none;
}

.section-navigator {
  position: fixed;
  top: 86px;
  right: 16px;
  z-index: 64;
  width: min(300px, calc(100vw - 32px));
  pointer-events: none;
}

.section-navigator details {
  display: grid;
  justify-items: end;
  pointer-events: auto;
}

.section-navigator summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  max-width: 100%;
  border: 1px solid rgba(221, 209, 191, 0.92);
  border-radius: var(--radius);
  padding: 9px 10px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 32px rgba(29, 24, 18, 0.13);
  backdrop-filter: blur(14px);
  cursor: pointer;
  list-style: none;
}

.section-navigator summary::-webkit-details-marker {
  display: none;
}

.section-navigator summary:hover,
.section-navigator summary:focus-visible,
.section-navigator details[open] summary {
  border-color: rgba(207, 59, 34, 0.42);
  outline: 0;
  box-shadow: 0 0 0 4px rgba(207, 59, 34, 0.12), 0 12px 32px rgba(29, 24, 18, 0.13);
}

.section-navigator summary span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  border-radius: var(--radius);
  padding-inline: 8px;
  background: var(--navy);
  color: white;
  font-size: 0.76rem;
  font-weight: 900;
}

.section-navigator summary strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 0.84rem;
  line-height: 1.3;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.section-navigator__panel {
  width: 100%;
  max-height: min(520px, calc(100vh - 150px));
  overflow-y: auto;
  margin-top: 8px;
  border: 1px solid rgba(221, 209, 191, 0.94);
  border-radius: var(--radius);
  padding: 12px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 24px 70px rgba(29, 24, 18, 0.2);
  backdrop-filter: blur(18px);
}

.section-navigator__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 9px;
  border-bottom: 1px solid var(--line);
}

.section-navigator__head strong,
.section-navigator__head small {
  display: block;
}

.section-navigator__head strong {
  font-size: 0.92rem;
  line-height: 1.35;
}

.section-navigator__head small {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
  line-height: 1.4;
  text-align: right;
}

.section-navigator__list {
  display: grid;
  gap: 5px;
  padding-top: 9px;
}

.section-navigator__link {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  padding: 7px;
}

.section-navigator__link:hover,
.section-navigator__link:focus-visible,
.section-navigator__link.is-active {
  border-color: rgba(207, 59, 34, 0.26);
  outline: 0;
  background: rgba(207, 59, 34, 0.07);
}

.section-navigator__link span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 28px;
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--green);
  font-size: 0.7rem;
  font-weight: 900;
}

.section-navigator__link strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 0.82rem;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.section-navigator__link--sub {
  margin-left: 18px;
}

.section-navigator__link.is-active span {
  background: var(--blue);
  color: white;
}

body.has-page-action-bar {
  padding-bottom: 94px;
}

.page-action-bar[hidden] {
  display: none;
}

.page-action-bar {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 70;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  pointer-events: none;
}

.page-action-bar__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  width: min(1180px, 100%);
  margin-inline: auto;
  border: 1px solid rgba(221, 209, 191, 0.9);
  border-radius: var(--radius);
  padding: 12px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 48px rgba(29, 24, 18, 0.16);
  backdrop-filter: blur(16px);
  pointer-events: auto;
}

.page-action-bar__summary {
  min-width: 0;
}

.page-action-bar__summary span,
.page-action-bar__summary strong,
.page-action-bar__summary small {
  display: block;
  min-width: 0;
}

.page-action-bar__summary span {
  color: var(--green);
  font-size: 0.74rem;
  font-weight: 900;
}

.page-action-bar__summary strong {
  overflow: hidden;
  margin-top: 3px;
  font-size: 0.98rem;
  line-height: 1.3;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-action-bar__summary small {
  overflow: hidden;
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-action-bar__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.page-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  padding: 9px 14px;
  background: var(--card);
  color: var(--ink);
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
  cursor: pointer;
  white-space: nowrap;
}

.page-action-button:hover,
.page-action-button:focus-visible {
  border-color: rgba(207, 59, 34, 0.45);
  outline: 0;
  box-shadow: 0 0 0 4px rgba(207, 59, 34, 0.12);
}

.page-action-button.is-saved {
  border-color: rgba(21, 101, 90, 0.35);
  background: rgba(21, 101, 90, 0.1);
  color: var(--green);
}

.page-next-actions {
  position: relative;
}

.page-next-actions summary {
  list-style: none;
}

.page-next-actions summary::-webkit-details-marker {
  display: none;
}

.page-next-actions[open] summary {
  border-color: rgba(207, 59, 34, 0.45);
  background: rgba(207, 59, 34, 0.08);
  color: var(--blue);
}

.page-next-actions__panel {
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px);
  z-index: 2;
  width: min(440px, calc(100vw - 32px));
  border: 1px solid rgba(221, 209, 191, 0.94);
  border-radius: var(--radius);
  padding: 13px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 24px 70px rgba(29, 24, 18, 0.22);
  backdrop-filter: blur(18px);
}

.page-next-actions__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}

.page-next-actions__head strong,
.page-next-actions__head small {
  display: block;
}

.page-next-actions__head strong {
  font-size: 0.94rem;
  line-height: 1.35;
}

.page-next-actions__head small {
  max-width: 220px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1.45;
  text-align: right;
}

.page-next-actions__list {
  display: grid;
  gap: 8px;
  padding-top: 10px;
}

.page-next-action {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 3px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px;
  background: var(--card);
}

.page-next-action:hover,
.page-next-action:focus-visible {
  border-color: rgba(207, 59, 34, 0.38);
  outline: 0;
  background: linear-gradient(90deg, rgba(207, 59, 34, 0.08), rgba(21, 101, 90, 0.06));
  box-shadow: 0 0 0 4px rgba(207, 59, 34, 0.1);
}

.page-next-action span {
  grid-row: span 2;
  display: grid;
  place-items: center;
  min-height: 44px;
  border-radius: var(--radius);
  background: var(--surface-strong);
  color: var(--green);
  font-size: 0.74rem;
  font-weight: 900;
}

.page-next-action strong,
.page-next-action small {
  display: block;
  min-width: 0;
}

.page-next-action strong {
  overflow: hidden;
  color: var(--ink);
  font-size: 0.9rem;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-next-action small {
  display: -webkit-box;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.site-toast-region[hidden] {
  display: none;
}

.site-toast-region {
  position: fixed;
  right: 16px;
  bottom: 18px;
  z-index: 90;
  width: min(520px, calc(100vw - 32px));
}

.has-page-action-bar .site-toast-region {
  bottom: 104px;
}

.site-toast {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius);
  padding: 13px;
  background: rgba(29, 24, 18, 0.96);
  color: white;
  box-shadow: 0 22px 58px rgba(29, 24, 18, 0.24);
  backdrop-filter: blur(16px);
}

.site-toast__copy {
  min-width: 0;
}

.site-toast__copy strong,
.site-toast__copy span {
  display: block;
  min-width: 0;
}

.site-toast__copy strong {
  overflow: hidden;
  font-size: 0.95rem;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-toast__copy span {
  overflow: hidden;
  margin-top: 3px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.82rem;
  line-height: 1.45;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-toast__actions {
  display: flex;
  align-items: center;
  gap: 7px;
}

.site-toast__actions a,
.site-toast__actions button {
  min-height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius);
  padding: 7px 10px;
  background: rgba(255, 255, 255, 0.1);
  color: white;
  font-size: 0.82rem;
  font-weight: 900;
  cursor: pointer;
  white-space: nowrap;
}

.site-toast__actions a:first-child {
  border-color: rgba(255, 255, 255, 0.84);
  background: var(--card);
  color: var(--navy);
}

.site-toast__actions a:hover,
.site-toast__actions a:focus-visible,
.site-toast__actions button:hover,
.site-toast__actions button:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.16);
}

.trust-dock {
  position: fixed;
  bottom: 18px;
  left: 16px;
  z-index: 88;
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-start;
  width: min(430px, calc(100vw - 32px));
  pointer-events: none;
}

.has-page-action-bar .trust-dock {
  bottom: 104px;
}

.trust-dock[open] {
  pointer-events: auto;
}

.trust-dock summary {
  display: inline-grid;
  grid-template-columns: 36px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  width: max-content;
  max-width: 100%;
  border: 1px solid rgba(221, 209, 191, 0.92);
  border-radius: var(--radius);
  padding: 9px 11px;
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
  box-shadow: 0 14px 38px rgba(29, 24, 18, 0.16);
  backdrop-filter: blur(14px);
  cursor: pointer;
  list-style: none;
  pointer-events: auto;
}

.trust-dock summary::-webkit-details-marker {
  display: none;
}

.trust-dock summary:hover,
.trust-dock summary:focus-visible {
  border-color: rgba(207, 59, 34, 0.42);
  outline: 0;
  box-shadow: 0 0 0 4px rgba(207, 59, 34, 0.12), 0 14px 38px rgba(29, 24, 18, 0.16);
}

.trust-dock__mark {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius);
  background: var(--navy);
  color: white;
  font-weight: 900;
}

.trust-dock summary strong,
.trust-dock summary small {
  display: block;
  min-width: 0;
}

.trust-dock summary strong {
  font-size: 0.9rem;
  line-height: 1.25;
}

.trust-dock summary small {
  overflow: hidden;
  margin-top: 2px;
  color: var(--green);
  font-size: 0.75rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.trust-dock__panel {
  width: 100%;
  max-height: calc(100vh - 160px);
  overflow: auto;
  margin-bottom: 8px;
  border: 1px solid rgba(221, 209, 191, 0.94);
  border-radius: var(--radius);
  padding: 16px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 24px 70px rgba(29, 24, 18, 0.22);
  backdrop-filter: blur(18px);
}

.trust-dock__head h2,
.trust-dock__head p,
.trust-dock__sources h3,
.trust-dock__sources ul,
.trust-dock__notice {
  margin: 0;
}

.trust-dock__head h2 {
  font-size: 1.05rem;
  line-height: 1.3;
}

.trust-dock__head p:last-child {
  margin-top: 7px;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.6;
}

.trust-dock__facts {
  display: grid;
  gap: 8px;
  margin: 14px 0;
}

.trust-dock__facts div {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 9px 10px;
  background: var(--surface);
}

.trust-dock__facts dt {
  color: var(--subtle);
  font-size: 0.76rem;
  font-weight: 900;
}

.trust-dock__facts dd {
  margin: 0;
  color: var(--ink);
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1.45;
}

.trust-dock__sources {
  border-top: 1px solid var(--line);
  padding-top: 13px;
}

.trust-dock__sources h3 {
  font-size: 0.88rem;
  line-height: 1.35;
}

.trust-dock__sources ul {
  display: grid;
  gap: 6px;
  padding: 10px 0 0;
  list-style: none;
}

.trust-dock__sources li {
  position: relative;
  padding-left: 14px;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.45;
}

.trust-dock__sources li::before {
  content: "";
  position: absolute;
  top: 0.62em;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
}

.trust-dock__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.trust-dock__stats span {
  display: block;
  border: 1px solid rgba(207, 59, 34, 0.16);
  border-radius: var(--radius);
  padding: 9px;
  background: rgba(207, 59, 34, 0.06);
}

.trust-dock__stats strong,
.trust-dock__stats small {
  display: block;
}

.trust-dock__stats strong {
  color: var(--blue);
  font-size: 0.92rem;
  line-height: 1.2;
}

.trust-dock__stats small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.trust-dock__notice {
  margin-top: 14px;
  border: 1px solid rgba(179, 64, 44, 0.18);
  border-radius: var(--radius);
  padding: 10px;
  background: rgba(179, 64, 44, 0.07);
  color: #b3402c;
  font-size: 0.83rem;
  font-weight: 800;
  line-height: 1.55;
}

.trust-dock__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.trust-dock__actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 7px 10px;
  background: var(--card);
  color: var(--ink);
  font-size: 0.82rem;
  font-weight: 900;
}

.trust-dock__actions a:first-child {
  border-color: rgba(29, 24, 18, 0.78);
  background: var(--navy);
  color: white;
}

.trust-dock__actions a:hover,
.trust-dock__actions a:focus-visible {
  border-color: rgba(207, 59, 34, 0.45);
  outline: 0;
  box-shadow: 0 0 0 4px rgba(207, 59, 34, 0.12);
}

.eyebrow,
.card-kicker {
  margin: 0 0 9px;
  font-family: var(--mono);
  color: var(--accent-2);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.page-hero h1 {
  margin: 0;
  font-size: clamp(2.2rem, 5vw, 4.8rem);
  line-height: 1.05;
  letter-spacing: 0;
}

.page-hero p {
  max-width: 720px;
  margin: 18px 0 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: clamp(1rem, 2vw, 1.2rem);
  line-height: 1.75;
}

.search-box {
  display: flex;
  width: 100%;
  min-width: 0;
  padding: 6px;
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow);
}

.search-box input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  padding: 13px 14px;
  background: transparent;
  color: var(--ink);
}

.search-box button,
.button {
  border: 0;
  border-radius: var(--radius-pill);
  padding: 0 22px;
  background: var(--ink);
  color: var(--paper);
  font-weight: 600;
  cursor: pointer;
}

.button {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
}

.button.secondary {
  border: 1px solid var(--ink);
  background: transparent;
  color: var(--ink);
}

.page-hero {
  background: var(--navy);
  color: white;
  padding: 76px 0 48px;
}

.page-hero--light {
  background: var(--surface);
  color: var(--ink);
}

.page-hero:not(.page-hero--light) .eyebrow {
  color: var(--ink-kicker);
}

.page-hero--light p {
  color: var(--muted);
}

.breadcrumbs {
  margin: 0 0 18px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.82rem;
  font-weight: 800;
}

.page-hero--light .breadcrumbs {
  color: var(--subtle);
}

.breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}

.breadcrumbs li {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.breadcrumbs li + li::before {
  content: "/";
  margin-right: 8px;
  color: currentColor;
  opacity: 0.58;
}

.breadcrumbs a {
  color: inherit;
}

.breadcrumbs a:hover {
  color: white;
}

.page-hero--light .breadcrumbs a:hover {
  color: var(--blue);
}

.breadcrumbs span {
  color: white;
  overflow-wrap: anywhere;
}

.page-hero--light .breadcrumbs span {
  color: var(--ink);
}

.page-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 24px;
  max-width: 680px;
}

.section {
  padding-block: 64px;
}

.section.compact {
  padding-block: 42px;
}

.section.band {
  background: var(--surface);
}

.section-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--ink);
}

.section-header h2 {
  margin: 0;
  font-size: clamp(1.55rem, 3vw, 2.35rem);
  line-height: 1.18;
}

.section-header p:not(.eyebrow) {
  margin: 10px 0 0;
  max-width: 680px;
  color: var(--muted);
  line-height: 1.7;
}

.text-link {
  color: var(--accent-2);
  font-weight: 700;
  white-space: nowrap;
}

.grid {
  display: grid;
  gap: 18px;
}

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

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

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

.media-card {
  display: grid;
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: var(--shadow-card);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

a.media-card:hover {
  transform: translateY(-3px);
  border-color: var(--ink);
  box-shadow: var(--shadow-hover);
}

.media-card__image {
  display: block;
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--surface-strong);
}

.media-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-card__fallback {
  display: grid;
  place-content: center;
  gap: 7px;
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: 18px;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(207, 59, 34, 0.13), transparent 42%),
    linear-gradient(315deg, rgba(179, 64, 44, 0.11), transparent 44%),
    linear-gradient(0deg, rgba(21, 101, 90, 0.12), rgba(255, 255, 255, 0)),
    #faf6ee;
  color: var(--navy);
  text-align: center;
  font-size: 1.15rem;
  font-weight: 900;
}

.media-card__fallback::before {
  content: "";
  position: absolute;
  inset: 12px;
  z-index: -1;
  border: 1px solid rgba(29, 24, 18, 0.08);
  border-radius: calc(var(--radius) - 2px);
  background:
    linear-gradient(90deg, rgba(29, 24, 18, 0.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(29, 24, 18, 0.05) 1px, transparent 1px);
  background-size: 22px 22px;
  opacity: 0.8;
}

.media-card__fallback span,
.media-card__fallback small {
  display: block;
  max-width: 100%;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.media-card__fallback strong {
  display: block;
  color: var(--navy);
  font-size: 1.85rem;
  line-height: 1.05;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.media-card__fallback small {
  color: var(--accent-2); /* 명도 대비 AA: 작은 vermillion(≈4.4:1)→jade(≈6:1) */
  font-size: 0.66rem;
}

.list-item__image .media-card__fallback,
.planner-candidate__image .media-card__fallback,
.media-room-card__image .media-card__fallback {
  gap: 5px;
  padding: 12px;
}

.list-item__image .media-card__fallback span,
.planner-candidate__image .media-card__fallback span,
.media-room-card__image .media-card__fallback span {
  font-size: 0.66rem;
}

.list-item__image .media-card__fallback strong,
.planner-candidate__image .media-card__fallback strong,
.media-room-card__image .media-card__fallback strong {
  font-size: 1.35rem;
}

.list-item__image .media-card__fallback small,
.planner-candidate__image .media-card__fallback small,
.media-room-card__image .media-card__fallback small {
  display: none;
}

.detail-image .media-card__fallback {
  min-height: 100%;
}

.detail-image .media-card__fallback strong {
  font-size: 2.6rem;
}

.media-card__badge,
.badge {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--ink);
  color: white;
  font-size: 0.75rem;
  font-weight: 800;
}

.media-card__badge {
  position: absolute;
  left: 12px;
  top: 12px;
}

.image-credit {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
  margin: 8px 0 0;
  color: var(--faint);
  font-family: var(--mono);
  font-size: 0.68rem;
  font-weight: 500;
  line-height: 1.35;
}

.image-credit span {
  color: var(--muted);
}

.image-credit a,
.image-credit strong {
  color: var(--accent-2);
  font-weight: 600;
}

.image-credit small {
  flex-basis: 100%;
  color: var(--subtle);
  font-size: 0.78rem;
  font-weight: 800;
}

.media-card__image .image-credit {
  position: absolute;
  right: 10px;
  bottom: 10px;
  z-index: 2; /* 다른 오버레이 credit과 동일하게 이미지 위 레이어 보장 */
  max-width: calc(100% - 20px);
  margin: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  padding: 5px 8px;
  box-shadow: 0 6px 18px rgba(29, 24, 18, 0.1);
}

.media-card__image .image-credit small {
  display: none;
}

.media-card__body {
  display: grid;
  align-content: start;
  min-height: 0;
  padding: 18px;
}

.media-card h3 {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.35;
}

.media-card p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.65;
}

.card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  align-items: center;
  margin-top: 16px;
}

.save-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  border: 1px solid var(--ink);
  border-radius: var(--radius-pill);
  background: var(--card);
  color: var(--ink);
  padding: 0 18px;
  font-weight: 600;
  cursor: pointer;
}

.save-button:hover,
.save-button.is-saved {
  border-color: #c7bba6;
  background: var(--surface-strong);
  color: var(--green);
}

.meta-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  padding: 0;
  margin: 14px 0 0;
  list-style: none;
}

.meta-list li {
  padding: 5px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  color: var(--muted);
  font-family: var(--mono);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.dashboard-strip {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 22px;
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}

.metric-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
}

.metric-card strong {
  display: block;
  font-size: 1.75rem;
  line-height: 1;
}

.metric-card span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-weight: 750;
}

.today-action-section {
  background:
    linear-gradient(180deg, #ffffff 0%, #faf6ee 100%);
}

.today-action-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.today-board-card {
  display: grid;
  align-content: start;
  min-height: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
  box-shadow: var(--shadow-soft);
}

.today-board-card__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}

.today-board-card__head span {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  border-radius: 999px;
  background: var(--surface-strong);
  color: var(--green);
  padding: 5px 9px;
  font-size: 0.75rem;
  font-weight: 900;
}

.today-board-card h2 {
  margin: 0 0 14px;
  font-size: 1.15rem;
  line-height: 1.35;
}

.today-board-list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.today-board-list a {
  display: grid;
  gap: 4px;
  border-top: 1px solid var(--line);
  padding-top: 10px;
  color: inherit;
}

.today-board-list li:first-child a {
  border-top: 0;
  padding-top: 0;
}

.today-board-list strong {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.42;
}

.today-board-list small {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.45;
}

.today-decision-board {
  display: grid;
  grid-template-columns: minmax(280px, 0.54fr) minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
  margin-top: 18px;
}

.today-decision-lead,
.today-decision-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.today-decision-lead {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 22px;
}

.today-decision-lead h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  line-height: 1.22;
}

.today-decision-lead p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
}

.today-district-focus {
  display: grid;
  gap: 5px;
  margin-top: 4px;
  border-left: 3px solid var(--green);
  background: rgba(21, 101, 90, 0.06);
  padding: 12px 14px;
}

.today-district-focus span,
.today-district-focus small {
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 850;
}

.today-district-focus strong {
  color: var(--green);
  font-size: 1.18rem;
}

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

.today-decision-card {
  display: grid;
  gap: 9px;
  align-content: start;
  min-height: 244px;
  padding: 16px;
}

.today-decision-card > span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: var(--surface-strong);
  color: var(--blue);
  padding: 5px 9px;
  font-size: 0.74rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.today-decision-card h3 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 0;
  color: var(--navy);
  font-size: 1.02rem;
  line-height: 1.38;
}

.today-decision-card p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  margin: 0;
  color: var(--muted);
  line-height: 1.56;
}

.today-decision-card small {
  color: var(--subtle);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.45;
}

.today-decision-card .card-actions {
  align-self: end;
  margin-top: 4px;
}

.today-rhythm-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.today-rhythm-strip div {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 14px;
}

.today-rhythm-strip strong,
.today-rhythm-strip span,
.today-rhythm-strip small {
  display: block;
}

.today-rhythm-strip strong {
  color: var(--navy);
  font-size: 1.55rem;
  line-height: 1;
}

.today-rhythm-strip span {
  margin-top: 6px;
  color: var(--ink);
  font-weight: 900;
}

.today-rhythm-strip small {
  margin-top: 3px;
  color: var(--muted);
  font-weight: 750;
  line-height: 1.45;
}

.today-scenario-board {
  display: grid;
  grid-template-columns: minmax(280px, 0.42fr) minmax(0, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.today-scenario-lead,
.today-scenario-panel {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.today-scenario-lead {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 22px;
}

.today-scenario-lead h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  line-height: 1.22;
}

.today-scenario-lead p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
}

.today-scenario-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 2px;
}

.today-scenario-tab {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  cursor: pointer;
  padding: 8px 11px;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 900;
  line-height: 1.2;
}

.today-scenario-tab:hover,
.today-scenario-tab:focus-visible,
.today-scenario-tab.is-active {
  border-color: rgba(207, 59, 34, 0.32);
  background: rgba(207, 59, 34, 0.09);
  color: var(--blue);
  outline: none;
}

.today-scenario-panels {
  min-width: 0;
}

.today-scenario-panel {
  display: grid;
  gap: 15px;
  padding: 18px;
}

.today-scenario-panel[hidden] {
  display: none;
}

.today-scenario-panel__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
}

.today-scenario-panel__head span {
  display: inline-flex;
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(21, 101, 90, 0.09);
  color: var(--green);
  padding: 5px 9px;
  font-size: 0.74rem;
  font-weight: 900;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.today-scenario-panel__head h3 {
  margin: 8px 0 0;
  color: var(--navy);
  font-size: clamp(1.28rem, 2vw, 1.72rem);
  line-height: 1.25;
}

.today-scenario-panel__head p {
  margin: 7px 0 0;
  color: var(--muted);
  line-height: 1.65;
}

.today-scenario-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.today-scenario-metrics article {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  padding: 13px;
}

.today-scenario-metrics strong,
.today-scenario-metrics span,
.today-scenario-metrics small {
  display: block;
}

.today-scenario-metrics strong {
  color: var(--navy);
  font-size: 1.45rem;
  line-height: 1;
}

.today-scenario-metrics span {
  margin-top: 6px;
  color: var(--ink);
  font-weight: 900;
}

.today-scenario-metrics small {
  margin-top: 3px;
  color: var(--muted);
  font-weight: 750;
  line-height: 1.42;
}

.today-scenario-steps {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.today-scenario-steps li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 13px;
  align-items: start;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #faf6ee 100%);
  padding: 14px;
}

.today-scenario-steps > li > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--navy);
  color: white;
  font-size: 0.76rem;
  font-weight: 950;
}

.today-scenario-steps div {
  min-width: 0;
}

.today-scenario-steps small {
  color: var(--subtle);
  font-weight: 850;
  line-height: 1.4;
}

.today-scenario-steps h4 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 4px 0 0;
  color: var(--navy);
  font-size: 1rem;
  line-height: 1.38;
}

.today-scenario-steps p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 5px 0 0;
  color: var(--muted);
  line-height: 1.55;
}

.today-scenario-steps .text-link {
  justify-self: end;
  white-space: nowrap;
}

.today-scenario-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  align-items: center;
  justify-content: flex-end;
}

/* ============================================================= */
/* 홈 — 에디토리얼 정밀 레이아웃 (Stage B)                          */
/* ============================================================= */

/* 히어로 — 좌 카피 / 우 4:5 이미지 */
.home-hero {
  padding-block: 42px 8px;
}

.home-hero__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 48px;
  align-items: center;
}

.home-hero__copy {
  min-width: 0;
}

.home-hero__kicker {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 20px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--accent-2);
}

.home-hero__kicker span {
  width: 30px;
  height: 1px;
  background: var(--accent-2);
}

.home-hero__title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.7rem, 5.2vw, 4.9rem);
  line-height: 1.06;
  letter-spacing: -0.01em;
  color: var(--ink);
}

.home-hero__title span {
  color: var(--accent);
}

.home-hero__lead {
  margin: 26px 0 0;
  max-width: 31em;
  font-family: var(--serif-body);
  font-size: clamp(1.05rem, 1.5vw, 1.26rem);
  line-height: 1.85;
  color: var(--text-lead);
}

.home-hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 32px;
}

.home-pill {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 14px 22px;
  border-radius: var(--radius-pill);
  font-size: 15px;
  font-weight: 600;
  transition: transform 0.15s ease, background 0.2s ease, color 0.2s ease,
    border-color 0.2s ease;
}

.home-pill span {
  font-family: var(--mono);
}

.home-pill--solid {
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
}

.home-pill--solid:hover {
  transform: translateY(-1px);
}

.home-pill--outline {
  background: none;
  color: var(--ink);
  border: 1px solid var(--ink);
}

.home-pill--outline:hover {
  background: var(--ink);
  color: var(--paper);
}

.home-hero__media {
  margin: 0;
  min-width: 0;
}

.home-hero__frame {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border: 1px solid var(--line);
  background: repeating-linear-gradient(135deg, #e6dbc7 0 13px, #e0d4bd 13px 26px);
}

.home-hero__frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.home-hero__frame .image-credit {
  position: absolute;
  right: 10px;
  bottom: 10px;
  z-index: 2;
  margin: 0;
}

.home-hero__media figcaption {
  margin-top: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--faint);
}

/* 지표 스트립 */
.home-metric-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  margin-top: 40px;
  border: 1px solid var(--line);
  background: var(--card);
}

.home-metric {
  padding: 20px 22px;
  border-right: 1px solid var(--line);
}

.home-metric:last-child {
  border-right: 0;
}

.home-metric strong {
  display: block;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 30px;
  line-height: 1;
  color: var(--ink);
}

.home-metric span {
  display: block;
  margin-top: 9px;
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
}

/* 섹션 헤더 키커 — 홈은 주칠(accent) 강조 */
.home-guides .section-header .eyebrow,
.home-collections .section-header .eyebrow,
.home-places .section-header .eyebrow {
  color: var(--accent);
}

.eyebrow--alt {
  color: var(--accent-2);
}

/* 테마 가이드 — 에디터의 선택 + 사이드 리스트 */
.home-guides__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
  margin-top: 28px;
}

.home-editor-pick {
  display: block;
  min-width: 0;
}

.home-editor-pick__image {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border: 1px solid var(--line);
  background: repeating-linear-gradient(135deg, #e6dbc7 0 13px, #e0d4bd 13px 26px);
}

.home-editor-pick__image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.home-editor-pick:hover .home-editor-pick__image img {
  transform: scale(1.02);
}

.home-editor-pick__flag {
  position: absolute;
  left: 14px;
  top: 14px;
  z-index: 2;
  padding: 6px 11px;
  background: var(--ink);
  color: #fff;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
}

.home-editor-pick__image .image-credit {
  position: absolute;
  right: 10px;
  bottom: 10px;
  z-index: 2;
  margin: 0;
}

.home-editor-pick__kicker {
  margin: 18px 0 0;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.1em;
  color: var(--accent-2);
}

.home-editor-pick__title {
  margin: 9px 0 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.5rem, 2.4vw, 2.05rem);
  line-height: 1.22;
  color: var(--ink);
}

.home-editor-pick__summary {
  margin: 12px 0 0;
  max-width: 36em;
  font-family: var(--serif-body);
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--text-lead);
}

.home-editor-pick__badge {
  margin: 14px 0 0;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.05em;
  color: var(--faint);
}

.home-guide-side {
  display: grid;
  gap: 18px;
  align-content: start;
}

.home-guide-row {
  display: grid;
  grid-template-columns: 108px 1fr;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}

.home-guide-row__thumb {
  aspect-ratio: 1;
  border: 1px solid var(--line);
  background: repeating-linear-gradient(135deg, #e6dbc7 0 10px, #e0d4bd 10px 20px);
}

.home-guide-row__text {
  display: block;
  min-width: 0;
}

.home-guide-row__kicker {
  display: block;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  color: var(--accent-2);
}

.home-guide-row__title {
  display: block;
  margin-top: 7px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.18rem;
  line-height: 1.32;
  color: var(--ink);
  transition: color 0.18s ease;
}

.home-guide-row:hover .home-guide-row__title {
  color: var(--accent);
}

.home-guide-row__badge {
  display: block;
  margin-top: 8px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--faint);
}

/* 추천 동선 카드 */
.home-collection-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin-top: 28px;
}

.home-collection-card {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 188px;
  padding: 22px;
  background: var(--card);
  border: 1px solid var(--line);
  border-top: 4px solid var(--accent-2);
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.home-collection-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
}

.home-collection-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
}

.home-collection-card__meta span:first-child {
  color: var(--accent-2);
}

.home-collection-card__meta span:last-child {
  color: var(--faint);
}

.home-collection-card h3 {
  margin: 2px 0 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.42rem;
  line-height: 1.25;
  color: var(--ink);
}

.home-collection-card p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--muted);
}

.home-collection-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 4px 0 0;
  padding: 0;
  list-style: none;
}

.home-collection-card__chips li {
  padding: 4px 9px;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  font-size: 11.5px;
  font-weight: 600;
  color: var(--muted);
}

/* 장소 그리드 (MediaCard 재사용) */
.home-place-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 22px;
  margin-top: 28px;
}

/* 자치구 + 생활 서비스 스트립 */
.home-strip__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
}

.home-strip__panel {
  border: 1px solid var(--line);
  background: var(--card);
  padding: 26px;
}

.home-strip__panel h3 {
  margin: 0 0 18px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.2;
  color: var(--ink);
}

.home-strip__panel .eyebrow {
  margin-bottom: 6px;
  color: var(--accent);
}

.home-strip__panel .eyebrow.eyebrow--alt {
  color: var(--accent-2);
}

.home-district-tiles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
}

.home-district-tile {
  display: block;
  padding: 13px;
  border: 1px solid var(--line);
  background: var(--paper);
  transition: border-color 0.18s ease, background 0.18s ease;
}

.home-district-tile:hover {
  border-color: var(--accent);
  background: var(--card);
}

.home-district-tile strong {
  display: block;
  font-size: 14px;
  color: var(--ink);
}

.home-district-tile span {
  display: block;
  margin-top: 5px;
  font-size: 11.5px;
  line-height: 1.5;
  color: var(--muted);
}

.home-service-list {
  display: grid;
  gap: 0;
}

.home-service-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 4px;
  border-top: 1px solid var(--line);
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  transition: color 0.18s ease;
}

.home-service-row:hover {
  color: var(--accent);
}

.home-service-row__cat {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--accent-2);
  white-space: nowrap;
}

.home-strip__more {
  margin: 16px 0 0;
}

/* 서울 운영판 — 다크 4카드 */
.home-command-section {
  padding-block: 56px;
  background: var(--ink);
  color: var(--paper);
}

.home-command-head {
  margin-bottom: 24px;
}

.home-command-head .eyebrow {
  color: var(--ink-kicker);
}

.home-command-head h2 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  line-height: 1.18;
  color: var(--paper);
}

.home-command-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.home-command-card {
  display: grid;
  align-content: start;
  gap: 9px;
  min-height: 170px;
  padding: 24px;
  background: var(--ink);
  border-top: 3px solid var(--accent);
  transition: background 0.2s ease;
}

.home-command-card.is-accent-2 {
  border-top-color: var(--accent-2);
}

.home-command-card.is-gold {
  border-top-color: var(--gold);
}

.home-command-card.is-apricot {
  border-top-color: var(--ink-kicker);
}

.home-command-card:hover {
  background: #251f17;
}

.home-command-card__eyebrow {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  color: rgba(243, 236, 225, 0.55);
}

.home-command-card h3 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.35rem;
  color: var(--paper);
}

.home-command-card p {
  margin: 0;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(243, 236, 225, 0.7);
}

.home-command-card__go {
  margin-top: auto;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-kicker);
}

/* 신뢰 band — 좌 카피 / 우 2×2 통계 */
.home-trust__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 48px;
  align-items: center;
}

.home-trust__copy h2 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.7rem, 2.8vw, 2.5rem);
  line-height: 1.18;
  color: var(--ink);
}

.home-trust__copy p:not(.eyebrow) {
  margin: 18px 0 0;
  max-width: 30em;
  font-family: var(--serif-body);
  font-size: 1.06rem;
  line-height: 1.85;
  color: var(--text-lead);
}

.home-trust-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}

.home-trust-stat {
  background: var(--card);
  padding: 24px;
}

.home-trust-stat strong {
  display: block;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 34px;
  line-height: 1;
  color: var(--accent);
}

.home-trust-stat span {
  display: block;
  margin-top: 10px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
}

.home-trust-stat small {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: var(--faint);
}

/* 줄무늬 placeholder (이미지 없는 가이드 썸네일) */
.home-stripe-placeholder {
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(135deg, #e6dbc7 0 12px, #e0d4bd 12px 24px);
}

.panel {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 22px;
}

.panel h3 {
  margin: 0;
}

.quick-list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 18px 0 0;
  list-style: none;
}

.quick-list a,
.link-chip,
.filter-chip {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  background: var(--card);
  padding: 10px 14px;
  color: var(--ink);
  font-weight: 600;
}

.quick-list a:hover,
.link-chip:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.rank-list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 18px 0 0;
  list-style: none;
}

.rank-list li {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.rank-list span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--surface);
  color: var(--muted);
  font-weight: 850;
}

.rank-list a {
  min-width: 0;
  color: var(--ink);
  font-weight: 850;
}

.rank-list small {
  color: var(--muted);
  font-weight: 800;
}

.compare-command-board {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 14px;
  align-items: stretch;
}

.compare-command-lead {
  display: grid;
  gap: 12px;
  min-width: 0;
  border: 1px solid #ddd1bf;
  border-radius: var(--radius);
  background: linear-gradient(135deg, #faf6ee 0%, #f1ece1 100%);
  padding: 20px;
}

.compare-command-lead > span,
.compare-scenario-card span,
.compare-insight-strip span,
.compare-playbook span {
  color: var(--subtle);
  font-size: 0.76rem;
  font-weight: 900;
}

.compare-command-lead h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.32rem, 3vw, 1.85rem);
  line-height: 1.25;
}

.compare-command-lead p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
}

.compare-command-actions,
.compare-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.compare-command-actions {
  align-self: end;
}

.compare-scenario-grid,
.compare-insight-strip,
.compare-playbook {
  display: grid;
  gap: 10px;
}

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

.compare-playbook {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 14px;
}

.compare-scenario-card,
.compare-insight-strip article,
.compare-playbook a {
  display: grid;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 15px;
  color: var(--ink);
}

.compare-scenario-card:hover,
.compare-playbook a:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.compare-scenario-card strong,
.compare-insight-strip strong,
.compare-playbook strong {
  color: var(--navy);
  font-size: 1.02rem;
  line-height: 1.35;
}

.compare-scenario-card p,
.compare-playbook p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.compare-scenario-card small,
.compare-insight-strip small {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 850;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.compare-insight-strip {
  margin-top: 12px;
}

.compare-insight-strip article {
  background: var(--surface);
}

.compare-toolbar {
  justify-content: space-between;
  margin: 12px 0;
}

.compare-toolbar p {
  margin: 0;
  color: var(--muted);
  font-weight: 850;
}

.compare-toolbar .copy-feedback {
  flex-basis: 100%;
}

.compare-select-cell {
  width: 54px;
}

.compare-select-cell input {
  width: 18px;
  height: 18px;
  accent-color: var(--blue);
}

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

.district-tile {
  display: grid;
  gap: 8px;
  min-height: 124px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
}

.district-tile strong {
  font-size: 1.05rem;
}

.district-tile span {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.55;
}

.district-action-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.district-hub-board {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 12px;
  align-items: stretch;
}

.district-hub-lead {
  display: grid;
  gap: 12px;
  min-width: 0;
  border: 1px solid #ddd1bf;
  border-radius: var(--radius);
  background: linear-gradient(135deg, #faf6ee 0%, #f1ece1 100%);
  padding: 18px;
}

.district-hub-lead > span,
.district-hub-signals span,
.district-path-matrix span {
  color: var(--subtle);
  font-size: 0.76rem;
  font-weight: 900;
}

.district-hub-lead strong {
  color: var(--navy);
  font-size: clamp(1.8rem, 4vw, 2.45rem);
  letter-spacing: 0;
}

.district-hub-lead p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
}

.district-hub-lead__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-self: end;
}

.district-hub-flow {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.district-hub-flow li {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
}

.district-hub-flow li > span {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: var(--navy);
  color: white;
  font-size: 0.82rem;
  font-weight: 900;
}

.district-hub-flow div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.district-hub-flow small {
  color: var(--green);
  font-size: 0.75rem;
  font-weight: 900;
}

.district-hub-flow a {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  color: var(--navy);
  font-weight: 900;
  line-height: 1.35;
}

.district-hub-flow p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.5;
}

.district-hub-signals,
.district-path-matrix {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.district-hub-signals div,
.district-path-matrix a {
  display: grid;
  gap: 7px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 14px;
  color: var(--ink);
}

.district-hub-signals strong,
.district-path-matrix strong {
  color: var(--navy);
  font-size: 1.02rem;
  line-height: 1.35;
}

.district-hub-signals small,
.district-path-matrix small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.district-path-matrix a:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.district-path-matrix p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.district-action-card {
  display: grid;
  gap: 9px;
  min-width: 0;
  min-height: 180px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.04);
}

.district-action-card span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: var(--surface-strong);
  color: var(--green);
  padding: 4px 8px;
  font-size: 0.74rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.district-action-card h2 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 0;
  color: var(--navy);
  font-size: 1.06rem;
  line-height: 1.38;
}

.district-action-card p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
}

.district-action-card .button {
  align-self: end;
  justify-content: center;
  min-height: 38px;
  margin-top: 4px;
  padding-inline: 12px;
}

.district-copy-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

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

.district-explore-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
  color: var(--ink);
}

.district-explore-card:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.district-explore-card span {
  width: max-content;
  border-radius: 999px;
  background: var(--surface-strong);
  color: var(--muted);
  padding: 4px 8px;
  font-size: 0.74rem;
  font-weight: 900;
}

.district-explore-card strong {
  color: var(--navy);
  font-size: 1.02rem;
  line-height: 1.35;
}

.district-explore-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  overflow-wrap: anywhere;
}

.district-explore-card small {
  color: var(--blue);
  font-weight: 900;
}

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

.district-service-card {
  display: grid;
  gap: 9px;
  min-width: 0;
  min-height: 174px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
  color: var(--ink);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.04);
}

.district-service-card:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.district-service-card span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(207, 59, 34, 0.1);
  color: var(--blue);
  padding: 4px 8px;
  font-size: 0.74rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.district-service-card strong {
  color: var(--navy);
  font-size: 1.02rem;
  line-height: 1.35;
}

.district-service-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
  overflow-wrap: anywhere;
}

.district-service-card small {
  color: var(--green);
  font-weight: 900;
}

.filters {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 26px 0;
}

.filters label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 800;
}

.filters select,
.filters input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px 13px;
  color: var(--ink);
}

.visit-command-board {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.45fr);
  gap: 16px;
  align-items: stretch;
  margin: 26px 0 16px;
}

.visit-command-lead {
  display: grid;
  gap: 13px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(207, 59, 34, 0.08), rgba(21, 101, 90, 0.06) 52%, rgba(156, 122, 46, 0.08)),
    white;
  padding: 22px;
  box-shadow: 0 14px 34px rgba(29, 24, 18, 0.05);
}

.visit-command-lead h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.35rem, 2.4vw, 1.85rem);
  line-height: 1.25;
}

.visit-command-lead p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
}

.visit-command-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
}

.visit-command-actions .button {
  justify-content: center;
}

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

.visit-scenario-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  min-height: 224px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 17px;
  color: var(--ink);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.04);
}

.visit-scenario-card:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.visit-scenario-card span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(207, 59, 34, 0.09);
  color: var(--blue);
  padding: 5px 9px;
  font-size: 0.76rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.visit-scenario-card strong {
  color: var(--navy);
  font-size: 1.06rem;
  line-height: 1.35;
}

.visit-scenario-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
  overflow-wrap: anywhere;
}

.visit-scenario-card small {
  align-self: end;
  color: var(--green);
  font-weight: 900;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.visit-signal-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0 0 12px;
}

.visit-signal-strip div {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid rgba(221, 209, 191, 0.86);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 14px;
}

.visit-signal-strip strong {
  color: var(--navy);
  font-size: 1.45rem;
  line-height: 1;
}

.visit-signal-strip span {
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 900;
}

.visit-signal-strip small {
  color: var(--muted);
  font-weight: 750;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.visit-flow-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0 4px;
}

.visit-flow-list article {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 14px;
}

.visit-flow-list span {
  grid-row: span 2;
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--navy);
  color: white;
  font-size: 0.82rem;
  font-weight: 900;
}

.visit-flow-list strong {
  color: var(--ink);
  line-height: 1.35;
}

.visit-flow-list p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.visit-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  margin: -8px 0 18px;
}

.visit-toolbar output {
  color: var(--muted);
  font-size: 0.92rem;
  font-weight: 850;
  line-height: 1.5;
}

.visit-toolbar span {
  color: var(--green);
  font-size: 0.86rem;
  font-weight: 850;
  line-height: 1.5;
}

.collection-choice-board,
.collection-detail-board {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.52fr);
  gap: 16px;
  align-items: stretch;
  margin: 26px 0 16px;
}

.collection-choice-lead,
.collection-detail-lead {
  display: grid;
  gap: 13px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(21, 101, 90, 0.08), rgba(207, 59, 34, 0.06) 52%, rgba(156, 122, 46, 0.08)),
    white;
  padding: 22px;
  box-shadow: 0 14px 34px rgba(29, 24, 18, 0.05);
}

.collection-choice-lead h2,
.collection-detail-lead h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.35rem, 2.4vw, 1.85rem);
  line-height: 1.25;
}

.collection-choice-lead p:not(.eyebrow),
.collection-detail-lead p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
}

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

.collection-scenario-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  min-height: 238px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 17px;
  color: var(--ink);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.04);
}

.collection-scenario-card:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.collection-scenario-card span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(21, 101, 90, 0.1);
  color: var(--green);
  padding: 5px 9px;
  font-size: 0.76rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.collection-scenario-card strong {
  color: var(--navy);
  font-size: 1.04rem;
  line-height: 1.35;
}

.collection-scenario-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
  overflow-wrap: anywhere;
}

.collection-scenario-card small {
  align-self: end;
  color: var(--blue);
  font-weight: 900;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.collection-signal-strip,
.collection-detail-signals {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0 0 12px;
}

.collection-detail-signals {
  margin: 0;
}

.collection-signal-strip div,
.collection-detail-signals div {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid rgba(221, 209, 191, 0.86);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 14px;
}

.collection-signal-strip strong,
.collection-detail-signals strong {
  color: var(--navy);
  font-size: 1.35rem;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.collection-signal-strip span,
.collection-detail-signals span {
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 900;
}

.collection-signal-strip small,
.collection-detail-signals small {
  color: var(--muted);
  font-weight: 750;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.collection-route-flow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0 4px;
}

.collection-route-flow article {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 14px;
}

.collection-route-flow span {
  grid-row: span 2;
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--green);
  color: white;
  font-size: 0.82rem;
  font-weight: 900;
}

.collection-route-flow strong {
  color: var(--ink);
  line-height: 1.35;
}

.collection-route-flow p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.collection-toolbar,
.collection-copy-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.collection-toolbar {
  margin: -8px 0 18px;
}

.collection-toolbar output,
.collection-copy-tools span {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 850;
  line-height: 1.5;
}

.collection-copy-tools span {
  color: var(--green);
}

.collection-detail-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.collection-step-brief {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 12px;
}

.collection-step-brief span {
  border: 1px solid rgba(207, 59, 34, 0.14);
  border-radius: 999px;
  background: rgba(207, 59, 34, 0.06);
  padding: 5px 8px;
  color: var(--blue);
  font-size: 0.76rem;
  font-weight: 900;
}

.collection-checklist {
  display: grid;
  gap: 10px;
  margin-top: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 16px;
}

.collection-checklist h3 {
  margin: 0;
}

.collection-checklist output {
  color: var(--green);
  font-size: 0.86rem;
  font-weight: 900;
}

.collection-checklist label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  min-width: 0;
  border-top: 1px solid rgba(221, 209, 191, 0.9);
  padding-top: 10px;
  color: var(--ink);
}

.collection-checklist input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--green);
}

.collection-checklist strong,
.collection-checklist small {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.collection-checklist small {
  margin-top: 3px;
  color: var(--muted);
  line-height: 1.45;
}

.collection-copy-tools {
  margin-top: 12px;
}

.service-command-board {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.58fr);
  gap: 16px;
  align-items: stretch;
  margin: 26px 0 16px;
}

.service-command-lead {
  display: grid;
  gap: 13px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(207, 59, 34, 0.08), rgba(21, 101, 90, 0.06) 52%, rgba(190, 57, 57, 0.08)),
    white;
  padding: 22px;
  box-shadow: 0 14px 34px rgba(29, 24, 18, 0.05);
}

.service-command-lead h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.35rem, 2.4vw, 1.85rem);
  line-height: 1.25;
}

.service-command-lead p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
}

.service-command-actions,
.service-guide-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

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

.service-scenario-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  min-height: 238px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 17px;
  color: var(--ink);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.04);
}

.service-scenario-card:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.service-scenario-card span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(207, 59, 34, 0.1);
  color: var(--blue);
  padding: 5px 9px;
  font-size: 0.76rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.service-scenario-card strong {
  color: var(--navy);
  font-size: 1.02rem;
  line-height: 1.35;
}

.service-scenario-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.56;
  overflow-wrap: anywhere;
}

.service-scenario-card small {
  align-self: end;
  color: var(--green);
  font-weight: 900;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.service-signal-strip,
.service-category-rail,
.service-flow-list {
  display: grid;
  gap: 10px;
}

.service-signal-strip {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 0 0 12px;
}

.service-signal-strip div {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid rgba(221, 209, 191, 0.86);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 14px;
}

.service-signal-strip strong {
  color: var(--navy);
  font-size: 1.35rem;
  line-height: 1.1;
}

.service-signal-strip span {
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 900;
}

.service-signal-strip small {
  color: var(--muted);
  font-weight: 750;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.service-category-rail {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin: 12px 0;
}

.service-category-rail article {
  display: grid;
  gap: 7px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 14px;
}

.service-category-rail span {
  color: var(--red);
  font-size: 0.84rem;
  font-weight: 900;
}

.service-category-rail strong {
  color: var(--navy);
  line-height: 1.35;
}

.service-category-rail p,
.service-category-rail small {
  margin: 0;
  color: var(--muted);
  line-height: 1.52;
  overflow-wrap: anywhere;
}

.service-category-rail small {
  color: var(--blue);
  font-weight: 850;
}

.service-flow-list {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 12px 0;
}

.service-flow-list article {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 14px;
}

.service-flow-list span {
  grid-row: span 2;
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--blue);
  color: white;
  font-size: 0.82rem;
  font-weight: 900;
}

.service-flow-list strong {
  color: var(--ink);
  line-height: 1.35;
}

.service-flow-list p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.service-readiness-panel {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
  gap: 16px;
  align-items: start;
  margin: 16px 0 22px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(21, 101, 90, 0.07), rgba(255, 255, 255, 0.92) 50%, rgba(207, 59, 34, 0.06)),
    white;
  padding: 20px;
  box-shadow: 0 14px 34px rgba(29, 24, 18, 0.04);
}

.service-readiness-panel h2 {
  margin: 0;
  color: var(--navy);
  font-size: 1.3rem;
}

.service-readiness-panel p:not(.eyebrow) {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.62;
}

.service-checklist {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.service-checklist output {
  color: var(--green);
  font-size: 0.86rem;
  font-weight: 900;
}

.service-checklist label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  min-width: 0;
  border: 1px solid rgba(221, 209, 191, 0.88);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  padding: 10px;
  color: var(--ink);
}

.service-checklist input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--green);
}

.service-checklist strong,
.service-checklist small {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.service-checklist small {
  margin-top: 3px;
  color: var(--muted);
  line-height: 1.45;
}

.service-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  margin: -8px 0 18px;
}

.service-toolbar output,
.service-toolbar span,
.service-guide-actions span {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 850;
  line-height: 1.5;
}

.service-toolbar span,
.service-guide-actions span {
  color: var(--green);
}

.service-guide-card {
  display: grid;
  gap: 12px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 20px;
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.04);
}

.service-guide-card h2 {
  margin: 0;
  color: var(--navy);
  line-height: 1.32;
}

.service-guide-card p:not(.card-kicker) {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
}

.service-guide-actions {
  margin-top: 4px;
}

.search-command-panel {
  display: grid;
  gap: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(207, 59, 34, 0.07), rgba(21, 101, 90, 0.06)),
    white;
  padding: 22px;
  box-shadow: var(--shadow);
}

.search-command-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.45fr);
  gap: 18px;
  align-items: start;
}

.search-command-head h2 {
  margin: 0;
  font-size: 1.45rem;
}

.search-command-head p:not(.eyebrow) {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.65;
}

.search-result-tools {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(207, 59, 34, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  padding: 14px;
}

.search-result-tools output {
  display: block;
  min-height: 46px;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 750;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.search-result-tools .button {
  width: 100%;
}

.search-command-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.search-command-metrics article {
  display: grid;
  gap: 4px;
  border: 1px solid rgba(221, 209, 191, 0.82);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.8);
  padding: 13px;
}

.search-command-metrics span,
.search-command-metrics small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.search-command-metrics strong {
  font-size: 1.5rem;
  line-height: 1;
}

.search-type-chips,
.search-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.search-type-chips button,
.search-suggestions a {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--card);
  color: var(--ink);
  font-size: 0.86rem;
  font-weight: 850;
}

.search-type-chips button {
  display: inline-flex;
  gap: 7px;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  cursor: pointer;
}

.search-type-chips button[aria-pressed="true"] {
  border-color: rgba(207, 59, 34, 0.42);
  background: var(--blue);
  color: white;
}

.search-type-chips small {
  color: inherit;
  font-size: 0.72rem;
  opacity: 0.78;
}

.search-suggestions {
  padding-top: 2px;
}

.search-suggestions a {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  color: var(--muted);
}

.search-suggestions a:hover {
  border-color: rgba(21, 101, 90, 0.45);
  color: var(--green);
}

.search-query-insight {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: flex-start;
  border-top: 1px solid rgba(221, 209, 191, 0.9);
  padding-top: 12px;
}

.search-query-insight[hidden] {
  display: none !important;
}

.search-query-insight > span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
}

.search-query-insight div {
  display: flex;
  flex: 1 1 240px;
  flex-wrap: wrap;
  gap: 7px;
}

.search-query-insight p {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
  margin: 0;
  border: 1px solid rgba(207, 59, 34, 0.16);
  border-radius: 999px;
  background: rgba(207, 59, 34, 0.06);
  padding: 6px 9px;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 850;
}

.search-query-insight strong {
  color: var(--blue);
}

.search-query-insight p span {
  color: var(--muted);
}

.search-active-filters,
.search-recent-panel {
  display: grid;
  gap: 10px;
  border-top: 1px solid rgba(221, 209, 191, 0.9);
  padding-top: 12px;
}

.search-active-filters[hidden],
.search-recent-panel[hidden] {
  display: none !important;
}

.search-active-filters {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
}

.search-active-filters > span,
.search-recent-head span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
}

.search-active-filters > div,
.search-recent-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  min-width: 0;
}

.search-active-filters button,
.search-recent-panel button {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--card);
  color: var(--ink);
  font-size: 0.8rem;
  font-weight: 850;
  cursor: pointer;
}

.search-active-filters [data-search-remove] {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  min-height: 34px;
  padding: 6px 10px;
}

.search-active-filters [data-search-remove] span {
  color: var(--blue);
  font-size: 0.92rem;
  line-height: 1;
}

.search-active-filters [data-search-reset],
.search-recent-head button {
  min-height: 34px;
  padding: 6px 10px;
  color: var(--muted);
}

.search-active-filters button:hover,
.search-active-filters button:focus-visible,
.search-recent-panel button:hover,
.search-recent-panel button:focus-visible {
  border-color: rgba(207, 59, 34, 0.35);
  outline: 0;
  background: #f0e9db;
  color: var(--blue);
}

.search-recent-head {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
}

.search-recent-list button {
  display: inline-grid;
  gap: 2px;
  min-height: 42px;
  padding: 8px 11px;
  text-align: left;
}

.search-recent-list strong {
  overflow: hidden;
  font-size: 0.82rem;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.search-recent-list span {
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.25;
}

.search-empty-state {
  gap: 10px;
}

.search-empty-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 4px;
}

.search-intelligence-panel {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(260px, 0.52fr);
  gap: 14px;
  align-items: stretch;
  border: 1px solid rgba(207, 59, 34, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
  padding: 15px;
}

.search-intelligence-panel[hidden] {
  display: none;
}

.search-intelligence-head {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.search-intelligence-head span,
.search-intelligence-metrics span,
.search-intelligence-metrics small,
.search-intelligence-actions small {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 850;
  line-height: 1.35;
}

.search-intelligence-head > span {
  color: var(--blue);
}

.search-intelligence-head strong {
  color: var(--navy);
  font-size: 1.08rem;
  line-height: 1.35;
}

.search-intelligence-head p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.62;
}

.search-intelligence-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  grid-column: 1 / -1;
}

.search-intelligence-metrics article {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid rgba(221, 209, 191, 0.9);
  border-radius: 8px;
  background: #faf6ee;
  padding: 10px;
}

.search-intelligence-metrics strong {
  color: var(--ink);
  font-size: 1.22rem;
  line-height: 1;
}

.search-intelligence-metrics small {
  overflow-wrap: anywhere;
}

.search-intelligence-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}

.search-intelligence-actions a {
  display: grid;
  gap: 4px;
  min-height: 54px;
  min-width: 0;
  border: 1px solid rgba(207, 59, 34, 0.18);
  border-radius: 8px;
  background: var(--card);
  color: var(--blue);
  padding: 10px 11px;
  font-size: 0.86rem;
  font-weight: 900;
  line-height: 1.25;
  text-decoration: none;
}

.search-intelligence-actions a.is-primary {
  border-color: rgba(207, 59, 34, 0.28);
  background: var(--blue);
  color: white;
}

.search-intelligence-actions a.is-primary small {
  color: rgba(255, 255, 255, 0.76);
}

.search-intelligence-actions a.is-local {
  border-color: rgba(21, 101, 90, 0.24);
  color: var(--green);
}

.search-intelligence-actions a.is-type {
  border-color: rgba(156, 122, 46, 0.28);
  color: #9c7a2e;
}

.search-intelligence-actions a:hover,
.search-intelligence-actions a:focus-visible {
  outline: 0;
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(29, 24, 18, 0.08);
}

.search-result-score {
  color: var(--blue);
}

.search-result-proof {
  display: grid;
  grid-template-columns: minmax(108px, 0.18fr) minmax(0, 1fr);
  gap: 10px;
  align-items: stretch;
  margin-top: 4px;
}

.search-result-readiness {
  display: grid;
  gap: 2px;
  align-content: center;
  border: 1px solid rgba(207, 59, 34, 0.16);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(207, 59, 34, 0.08), rgba(21, 101, 90, 0.07));
  padding: 9px 10px;
}

.search-result-readiness span,
.search-result-readiness small {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 850;
  line-height: 1.25;
}

.search-result-readiness strong {
  color: var(--navy);
  font-size: 1.08rem;
  line-height: 1;
}

.search-result-badges,
.search-result-routes {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  min-width: 0;
}

.search-result-badges {
  align-content: center;
}

.search-result-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  max-width: 100%;
  border: 1px solid rgba(115, 105, 91, 0.22);
  border-radius: 999px;
  background: #faf6ee;
  color: var(--muted);
  padding: 5px 9px;
  font-size: 0.76rem;
  font-weight: 850;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.search-result-badges span[data-state="good"] {
  border-color: rgba(21, 101, 90, 0.24);
  background: rgba(21, 101, 90, 0.08);
  color: var(--green);
}

.search-result-badges span[data-state="source"] {
  border-color: rgba(207, 59, 34, 0.24);
  background: rgba(207, 59, 34, 0.08);
  color: var(--blue);
}

.search-result-badges span[data-state="action"] {
  border-color: rgba(156, 122, 46, 0.28);
  background: rgba(156, 122, 46, 0.1);
  color: #9c7a2e;
}

.search-result-badges span[data-state="watch"] {
  border-color: rgba(208, 87, 61, 0.24);
  background: rgba(208, 87, 61, 0.08);
  color: var(--red);
}

.search-result-routes {
  margin-top: -2px;
}

.search-result-routes a {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  border: 1px solid rgba(207, 59, 34, 0.18);
  border-radius: 999px;
  background: var(--card);
  color: var(--blue);
  padding: 6px 10px;
  font-size: 0.78rem;
  font-weight: 850;
  line-height: 1.25;
  text-decoration: none;
}

.search-result-routes a:hover,
.search-result-routes a:focus-visible {
  outline: 0;
  border-color: rgba(207, 59, 34, 0.4);
  background: #f0e9db;
}

.search-result mark {
  border-radius: 4px;
  background: rgba(156, 122, 46, 0.16);
  color: var(--ink);
  padding: 0 2px;
}

.search-result-hint {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
  border-left: 3px solid rgba(21, 101, 90, 0.45);
  background: rgba(21, 101, 90, 0.06);
  padding: 9px 11px;
  color: var(--ink) !important;
  font-size: 0.9rem;
  font-weight: 750;
}

.search-result-hint span {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
}

.list-stack {
  display: grid;
  gap: 14px;
}

.table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
}

.compare-table {
  width: 100%;
  min-width: 1040px;
  border-collapse: collapse;
}

.compare-table th,
.compare-table td {
  border-bottom: 1px solid var(--line);
  padding: 13px 14px;
  text-align: left;
  vertical-align: top;
}

.compare-table th {
  background: var(--surface);
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 850;
}

.compare-table tr:last-child td {
  border-bottom: 0;
}

.compare-table td small {
  display: block;
  margin-top: 4px;
  color: var(--subtle);
  font-weight: 750;
}

.score-cell {
  display: grid;
  gap: 7px;
  min-width: 110px;
}

.score-cell strong {
  font-size: 1rem;
}

.score-cell span {
  display: block;
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--blue), var(--green));
}

.status-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.status-chips span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 7px;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 800;
}

.list-item {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr);
  gap: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
}

.list-item__image {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface-strong);
}

.list-item__image img,
.detail-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.list-item__body {
  min-width: 0;
  padding: 6px 4px;
}

.list-item h2,
.list-item h3 {
  margin: 0;
  font-size: 1.2rem;
}

.list-item p {
  margin: 9px 0 0;
  color: var(--muted);
  line-height: 1.65;
}

.detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(260px, 0.7fr);
  gap: 28px;
  align-items: start;
}

.detail-image {
  overflow: hidden;
  aspect-ratio: 16 / 8;
  border-radius: var(--radius);
  background: var(--surface-strong);
}

.detail-content {
  padding-block: 42px;
}

.detail-content h1 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1.08;
}

.detail-content p {
  color: var(--muted);
  line-height: 1.8;
}

.fact-list {
  display: grid;
  gap: 12px;
  margin: 0;
}

.fact-list div {
  display: grid;
  gap: 4px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}

.fact-list dt {
  color: var(--subtle);
  font-size: 0.8rem;
  font-weight: 800;
}

.fact-list dd {
  margin: 0;
  color: var(--ink);
  line-height: 1.55;
}

.source-disclosure {
  display: grid;
  gap: 14px;
  margin-top: 24px;
  border-top: 1px solid var(--line);
  padding-top: 20px;
}

.source-disclosure h3 {
  margin: 0;
  font-size: 1rem;
}

.source-disclosure dl,
.source-disclosure ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
}

.source-disclosure dl div {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.source-disclosure dt {
  color: var(--subtle);
  font-size: 0.78rem;
  font-weight: 900;
}

.source-disclosure dd {
  margin: 0;
  color: var(--ink);
  font-size: 0.9rem;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.source-disclosure li {
  margin-left: 18px;
  color: var(--muted);
  line-height: 1.55;
}

.district-media-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

.district-media-panel {
  position: sticky;
  top: 92px;
}

.mini-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0 18px;
}

.mini-metrics div {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
}

.mini-metrics strong {
  color: var(--navy);
  font-size: 1.25rem;
}

.mini-metrics span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.link-groups {
  display: grid;
  gap: 22px;
}

.link-group h2,
.link-group h3 {
  margin: 0 0 12px;
}

.link-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.notice {
  border-left: 4px solid var(--gold);
  background: #fff8ea;
  padding: 14px 16px;
  color: #9c7a2e;
  line-height: 1.6;
}

.notice.compact-notice {
  margin: 14px 0 0;
  padding: 11px 13px;
  font-size: 0.92rem;
}

.collection-companion {
  display: grid;
  gap: 10px;
  margin: 18px 0 4px;
}

.collection-companion .card-kicker {
  margin: 0;
}

.collection-companion .button {
  justify-self: start;
}

.collection-intro {
  margin-top: 6px;
}

.saved-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  margin-bottom: 24px;
}

.saved-toolbar h2 {
  margin: 0;
  font-size: clamp(1.55rem, 3vw, 2.25rem);
}

.saved-command-board {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.9fr);
  gap: 16px;
  align-items: stretch;
  border: 1px solid rgba(29, 24, 18, 0.16);
  border-radius: var(--radius);
  background: linear-gradient(135deg, #faf6ee 0%, #ffffff 58%, #f1ece1 100%);
  padding: 18px;
  margin-bottom: 18px;
}

.saved-command-lead h2,
.saved-command-lead p,
.saved-command-next p {
  margin: 0;
}

.saved-command-lead {
  display: grid;
  gap: 12px;
  align-content: start;
}

.saved-command-lead h2 {
  font-size: 1.38rem;
}

.saved-command-lead > p:not(.eyebrow),
.saved-command-next p {
  color: var(--muted);
  line-height: 1.65;
}

.saved-command-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.saved-command-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.saved-command-metrics article,
.saved-command-next,
.saved-type-pill {
  border: 1px solid rgba(29, 24, 18, 0.09);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
  padding: 13px;
}

.saved-command-metrics span,
.saved-command-metrics small,
.saved-command-next span,
.saved-type-pill span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.saved-command-metrics strong {
  display: block;
  margin: 5px 0 3px;
  font-size: 1.55rem;
}

.saved-command-next {
  grid-column: 1 / -1;
  display: grid;
  gap: 7px;
}

.saved-command-next strong {
  font-size: 1.08rem;
}

.saved-type-rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}

.saved-type-pill {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.saved-type-pill strong {
  font-size: 1.2rem;
}

.planner-topline {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(150px, 0.75fr) minmax(130px, 0.6fr) repeat(2, minmax(118px, 0.55fr));
  gap: 12px;
  margin-bottom: 18px;
}

.planner-topline label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 800;
}

.planner-topline input,
.planner-step input,
.planner-step select,
.planner-step textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  color: var(--ink);
}

.planner-topline input {
  min-height: 48px;
  padding: 12px 13px;
}

.planner-stat {
  display: grid;
  align-content: center;
  min-height: 72px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px 14px;
}

.planner-stat strong {
  font-size: 1.2rem;
}

.planner-stat span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.planner-command-board,
.my-command-board {
  display: grid;
  grid-template-columns: minmax(260px, 0.95fr) minmax(0, 1.2fr) minmax(230px, 0.75fr);
  gap: 14px;
  margin-bottom: 20px;
}

.planner-command-lead,
.planner-command-next,
.my-command-lead,
.my-command-next {
  display: grid;
  gap: 12px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.planner-command-lead,
.my-command-lead {
  background:
    linear-gradient(145deg, rgba(207, 59, 34, 0.08), rgba(21, 101, 90, 0.08)),
    white;
}

.planner-command-lead h2,
.planner-command-next strong,
.my-command-lead h2,
.my-command-next strong {
  margin: 0;
  color: var(--navy);
  font-size: 1.2rem;
  line-height: 1.35;
}

.planner-command-lead p,
.planner-command-next p,
.my-command-lead p,
.my-command-next p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.planner-command-actions,
.my-command-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.planner-command-metrics,
.my-command-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.planner-command-metrics article,
.my-command-grid article {
  display: grid;
  gap: 6px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 14px;
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.04);
}

.planner-command-metrics span,
.planner-command-metrics small,
.my-command-grid span,
.my-command-grid small,
.my-command-next span {
  color: var(--subtle);
  font-size: 0.76rem;
  font-weight: 900;
}

.planner-command-metrics strong,
.my-command-grid strong {
  color: var(--navy);
  font-size: 1.45rem;
  line-height: 1;
}

.planner-command-next span,
.my-command-next span {
  width: max-content;
  border-radius: 999px;
  background: rgba(207, 59, 34, 0.1);
  color: var(--blue);
  padding: 5px 8px;
}

.planner-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(340px, 0.85fr);
  gap: 18px;
  align-items: start;
}

.planner-panel {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
}

.planner-panel--board {
  position: sticky;
  top: 92px;
  max-height: calc(100vh - 112px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

.planner-panel__head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  margin-bottom: 16px;
}

.planner-panel__head h2 {
  margin: 0;
  font-size: 1.35rem;
}

.planner-panel__head > span {
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 850;
  white-space: nowrap;
}

.planner-filters {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 16px 0;
}

.planner-candidates,
.planner-timeline {
  display: grid;
  gap: 12px;
}

.planner-candidate {
  display: grid;
  grid-template-columns: 142px minmax(0, 1fr);
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 10px;
}

.planner-candidate__image {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface-strong);
}

.planner-candidate__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.planner-candidate__body {
  min-width: 0;
  padding: 3px 0;
}

.planner-candidate h3,
.planner-step h3 {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.35;
}

.planner-step__title-row {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  justify-content: space-between;
}

.planner-completion {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 0.72rem;
  font-weight: 900;
  white-space: nowrap;
}

.planner-completion.is-complete {
  background: rgba(21, 101, 90, 0.13);
  color: #15655a;
}

.planner-completion.is-progress {
  background: rgba(207, 59, 34, 0.1);
  color: var(--blue);
}

.planner-completion.is-low {
  background: rgba(207, 59, 34, 0.1);
  color: var(--red);
}

.planner-candidate p,
.planner-step p {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.58;
}

.planner-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.planner-summary div {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 12px;
}

.planner-summary span,
.planner-summary strong {
  display: block;
}

.planner-summary span {
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 800;
}

.planner-summary strong {
  margin-top: 3px;
  font-size: 1.05rem;
}

.planner-diagnostics {
  display: grid;
  gap: 10px;
  margin: 14px 0;
}

.planner-diagnostic {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
}

.planner-diagnostic.is-good {
  border-color: rgba(21, 101, 90, 0.22);
  background: #f1ece1;
}

.planner-diagnostic.is-warning {
  border-color: rgba(207, 59, 34, 0.24);
  background: #fff8f6;
}

.planner-diagnostic strong {
  display: block;
  color: var(--navy);
  font-size: 0.92rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.planner-diagnostic p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.planner-route-guide {
  display: grid;
  gap: 12px;
  margin: 14px 0;
}

.planner-day-summary {
  display: grid;
  gap: 10px;
  margin: 14px 0;
}

.planner-route-empty,
.planner-route-head,
.planner-route-day,
.planner-route-checklist article,
.planner-day-summary article,
.planner-day-summary__head,
.planner-day-summary li {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
}

.planner-route-empty {
  background: var(--surface);
}

.planner-route-empty strong,
.planner-route-head strong,
.planner-route-day__head strong,
.planner-route-checklist strong,
.planner-day-summary strong {
  display: block;
  color: var(--navy);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.planner-route-empty p,
.planner-route-head span,
.planner-route-checklist p,
.planner-day-summary p,
.planner-day-summary span {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.planner-route-days,
.planner-route-checklist,
.planner-day-summary ol {
  display: grid;
  gap: 10px;
}

.planner-day-summary ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

.planner-day-summary__head,
.planner-day-summary li {
  background: #faf6ee;
}

.planner-route-day {
  display: grid;
  gap: 10px;
}

.planner-route-day__head {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
}

.planner-route-day__head span {
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 0.72rem;
  font-weight: 900;
  white-space: nowrap;
}

.planner-route-day__head span.is-good {
  background: rgba(21, 101, 90, 0.12);
  color: #15655a;
}

.planner-route-day__head span.is-warning {
  background: rgba(207, 59, 34, 0.12);
  color: var(--red);
}

.route-sequence {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.route-sequence li {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--ink);
  padding: 5px 8px;
  font-size: 0.78rem;
  font-weight: 800;
}

.planner-route-checklist article {
  background: #faf6ee;
}

.planner-route-checklist p {
  font-size: 0.84rem;
}

.planner-step {
  display: grid;
  grid-template-columns: 136px minmax(0, 1fr);
  gap: 13px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
}

.planner-step.is-attention {
  border-color: rgba(207, 59, 34, 0.45);
  box-shadow: 0 0 0 3px rgba(207, 59, 34, 0.08);
}

.planner-step__time {
  display: grid;
  align-content: start;
  gap: 8px;
}

.planner-step input,
.planner-step select {
  min-height: 40px;
  padding: 9px 10px;
}

.planner-step textarea {
  min-height: 70px;
  margin-top: 10px;
  padding: 10px;
  resize: vertical;
}

.planner-step__quick-links,
.planner-step__suggestions div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.planner-step__quick-links {
  margin-top: 10px;
}

.planner-step__quick-links a,
.planner-step__suggestions button {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  color: var(--ink);
  padding: 6px 10px;
  font-size: 0.8rem;
  font-weight: 850;
  text-decoration: none;
}

.planner-step__quick-links a:hover,
.planner-step__suggestions button:hover {
  border-color: rgba(207, 59, 34, 0.28);
  background: #f0e9db;
  color: var(--blue);
}

.planner-step__prep-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.planner-step__prep-grid label {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.planner-step__prep-grid span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
}

.planner-step__prep-grid textarea {
  min-height: 66px;
  margin-top: 0;
}

.planner-step__suggestions {
  display: grid;
  gap: 7px;
  margin-top: 10px;
}

.planner-step__suggestions > span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
}

.planner-step__suggestions button {
  cursor: pointer;
}

.planner-step__checks {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.planner-step__checks label {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  padding: 6px 10px;
  color: var(--ink);
  font-size: 0.82rem;
  font-weight: 850;
  cursor: pointer;
}

.planner-step__checks input {
  width: 15px;
  height: 15px;
  min-height: 0;
  padding: 0;
  accent-color: var(--green);
}

.planner-step__checks label:has(input:checked) {
  border-color: rgba(21, 101, 90, 0.32);
  background: #f1ece1;
  color: #15655a;
}

.planner-step__body {
  min-width: 0;
}

.planner-step__actions,
.planner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.planner-step__actions .save-button {
  min-height: 36px;
  padding-inline: 12px;
}

.save-button:disabled,
.button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.planner-actions {
  margin-top: 16px;
}

.planner-saved-plans {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.planner-saved-plans article,
.planner-saved-plans__head {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 12px;
}

.planner-saved-plans__head,
.planner-saved-plans__list article {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.planner-saved-plans strong,
.planner-saved-plans span,
.planner-saved-plans p {
  overflow-wrap: anywhere;
}

.planner-saved-plans strong {
  display: block;
  color: var(--navy);
  line-height: 1.35;
}

.planner-saved-plans span,
.planner-saved-plans p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.55;
}

.planner-saved-plans__list {
  display: grid;
  gap: 8px;
}

.planner-saved-plans__list article.is-current {
  border-color: rgba(21, 101, 90, 0.28);
  background: #f1ece1;
}

.planner-saved-plans__list article > div:last-child {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.planner-saved-plans .save-button {
  min-height: 32px;
  padding: 6px 9px;
}

.planner-share-tools {
  display: grid;
  gap: 10px;
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #faf6ee;
  padding: 12px;
}

.planner-share-tools strong {
  display: block;
  color: var(--navy);
  line-height: 1.35;
}

.planner-share-tools p,
.planner-share-tools span {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.55;
}

.planner-share-tools__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.planner-calendar-tools {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(21, 101, 90, 0.18);
  border-radius: 10px;
  background: #f1ece1;
  padding: 11px;
}

.planner-calendar-tools__head {
  display: grid;
  gap: 2px;
}

.planner-calendar-list {
  display: grid;
  gap: 8px;
}

.planner-calendar-list article {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(29, 24, 18, 0.08);
  border-radius: 8px;
  background: #ffffff;
  padding: 9px;
}

.planner-calendar-list__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.planner-calendar-list__actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border: 1px solid rgba(207, 59, 34, 0.18);
  border-radius: 999px;
  background: #ffffff;
  padding: 5px 9px;
  color: var(--blue);
  font-size: 0.78rem;
  font-weight: 900;
}

.planner-import-tools {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(207, 59, 34, 0.14);
  border-radius: 10px;
  background: #ffffff;
  padding: 11px;
}

.planner-import-tools__file {
  display: grid;
  gap: 6px;
}

.planner-import-tools input[type="file"] {
  width: 100%;
  min-width: 0;
  border: 1px dashed rgba(207, 59, 34, 0.28);
  border-radius: 8px;
  background: #faf6ee;
  padding: 9px;
  color: var(--navy);
  font-size: 0.86rem;
}

.planner-share-tools label {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.planner-share-tools textarea {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 10px;
  resize: vertical;
  color: var(--navy);
  font: inherit;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.planner-share-preview {
  min-width: 0;
  border: 1px solid rgba(207, 59, 34, 0.16);
  border-radius: 8px;
  background: #ffffff;
  padding: 10px;
}

.planner-share-preview .meta-list {
  margin-top: 8px;
}

.my-seoul-shell {
  display: grid;
  grid-template-columns: minmax(280px, 0.72fr) minmax(0, 1.28fr);
  gap: 20px;
  align-items: start;
}

.my-settings {
  position: sticky;
  top: 92px;
}

.my-settings h3 {
  margin: 24px 0 12px;
  font-size: 1rem;
}

.preference-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.preference-grid--districts {
  max-height: 360px;
  overflow: auto;
  padding-right: 4px;
}

.preference-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--card);
  padding: 8px 11px;
  color: var(--ink);
  font-size: 0.9rem;
  font-weight: 800;
  cursor: pointer;
}

.preference-pill:has(input:checked) {
  border-color: rgba(207, 59, 34, 0.35);
  background: #f0e9db;
  color: var(--blue);
}

.preference-pill input {
  width: 16px;
  height: 16px;
  accent-color: var(--blue);
}

.my-dashboard {
  min-width: 0;
}

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

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

.my-plan-panel {
  display: grid;
  gap: 14px;
}

.my-plan-toolbar {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  min-width: 0;
  border: 1px solid rgba(207, 59, 34, 0.14);
  border-radius: var(--radius);
  background: #faf6ee;
  padding: 14px;
}

.my-plan-toolbar div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.my-plan-toolbar strong {
  color: var(--navy);
  font-size: 0.98rem;
}

.my-plan-toolbar span {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

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

.my-plan-card {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 14px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
  box-shadow: 0 12px 28px rgba(29, 24, 18, 0.06);
}

.my-plan-card__step {
  display: grid;
  align-content: start;
  justify-items: center;
  gap: 8px;
  min-width: 0;
}

.my-plan-card__step strong {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: var(--navy);
  color: white;
  font-size: 1rem;
}

.my-plan-card__step span {
  color: var(--blue);
  font-size: 0.76rem;
  font-weight: 900;
  line-height: 1.3;
  text-align: center;
}

.my-plan-card__body {
  display: grid;
  gap: 9px;
  min-width: 0;
}

.my-plan-card h3 {
  margin: 0;
  color: var(--navy);
  font-size: 1.08rem;
  line-height: 1.38;
  overflow-wrap: anywhere;
}

.my-plan-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
  overflow-wrap: anywhere;
}

.my-action-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  min-height: 188px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.my-action-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
}

.my-action-card__meta span,
.my-action-card__meta small {
  border-radius: 999px;
  padding: 5px 8px;
  font-size: 0.75rem;
  font-weight: 900;
}

.my-action-card__meta span {
  background: rgba(207, 59, 34, 0.1);
  color: var(--blue);
}

.my-action-card__meta small {
  background: var(--surface);
  color: var(--muted);
}

.my-action-card h3 {
  margin: 0;
  color: var(--navy);
  font-size: 1.08rem;
  line-height: 1.38;
  overflow-wrap: anywhere;
}

.my-action-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.62;
  overflow-wrap: anywhere;
}

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

.my-recent-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.06);
}

.my-recent-card__head {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.my-recent-card__head span,
.my-recent-card__head small {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
}

.my-recent-card__head small {
  color: var(--subtle);
}

.my-recent-card h3 {
  margin: 0;
  overflow-wrap: anywhere;
  font-size: 1rem;
  line-height: 1.35;
}

.my-recent-card p {
  display: -webkit-box;
  overflow: hidden;
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.my-section {
  padding-block: 34px 0;
}

.my-section.bandless {
  background: transparent;
}

.calendar-metrics {
  margin: 18px 0 26px;
}

.calendar-plan-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 12px;
  align-items: center;
  margin: 0 0 20px;
  border: 1px solid rgba(21, 101, 90, 0.18);
  border-radius: var(--radius);
  background: #f1ece1;
  padding: 14px;
}

.calendar-plan-bar div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.calendar-plan-bar strong {
  color: var(--navy);
  font-size: 0.98rem;
}

.calendar-plan-bar span,
.calendar-plan-bar p {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.calendar-planner-board {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.95fr);
  gap: 14px;
  align-items: stretch;
  margin: 0 0 22px;
  border: 1px solid rgba(29, 24, 18, 0.14);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #ffffff 0%, #faf6ee 100%);
  box-shadow: var(--shadow-soft);
  padding: 16px;
}

.calendar-planner-board__lead {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.calendar-planner-board__lead h2 {
  margin: 0;
  color: var(--navy);
  font-size: 1.28rem;
  line-height: 1.32;
}

.calendar-planner-board__lead p:not(.eyebrow),
.calendar-overlay-next p,
.calendar-overlay-day p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
  overflow-wrap: anywhere;
}

.calendar-planner-board__actions,
.calendar-overlay-item__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.calendar-overlay-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.calendar-overlay-metrics article,
.calendar-overlay-next,
.calendar-overlay-day {
  min-width: 0;
  border: 1px solid rgba(29, 24, 18, 0.08);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
}

.calendar-overlay-metrics span,
.calendar-overlay-metrics small,
.calendar-overlay-next span,
.calendar-overlay-day__head span,
.calendar-overlay-day__head small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.calendar-overlay-metrics strong {
  display: block;
  margin-top: 4px;
  color: var(--navy);
  font-size: 1.38rem;
  line-height: 1.1;
}

.calendar-overlay-next {
  display: grid;
  gap: 6px;
  align-content: start;
}

.calendar-overlay-next > strong {
  color: var(--navy);
  font-size: 1rem;
  line-height: 1.38;
  overflow-wrap: anywhere;
}

.calendar-overlay-list {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.calendar-overlay-day {
  display: grid;
  gap: 12px;
}

.calendar-overlay-day__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.calendar-overlay-day__head strong {
  display: block;
  margin-top: 3px;
  color: var(--navy);
  font-size: 0.98rem;
  line-height: 1.35;
}

.calendar-overlay-day ol {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.calendar-overlay-day li {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  border-top: 1px solid var(--line);
  padding-top: 9px;
}

.calendar-overlay-day time {
  color: var(--blue);
  font-size: 0.85rem;
  font-weight: 900;
}

.calendar-overlay-day li strong {
  color: var(--navy);
  line-height: 1.38;
  overflow-wrap: anywhere;
}

.calendar-overlay-item__actions {
  justify-content: flex-end;
}

.calendar-overlay-item__actions a {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #faf6ee;
  color: var(--navy);
  font-size: 0.78rem;
  font-weight: 850;
  padding: 5px 9px;
}

.calendar-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
  gap: 20px;
  align-items: start;
}

.calendar-subhead {
  margin-bottom: 14px;
}

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

.calendar-day {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 15px;
}

.calendar-day__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.calendar-day__head h3 {
  margin: 0;
  font-size: 1.12rem;
}

.calendar-day__head strong {
  display: grid;
  place-items: center;
  min-width: 38px;
  height: 38px;
  border-radius: 999px;
  background: var(--navy);
  color: white;
}

.calendar-items {
  display: grid;
  gap: 8px;
  padding: 0;
  margin: 14px 0 0;
  list-style: none;
}

.calendar-items a {
  display: grid;
  gap: 3px;
  border-top: 1px solid var(--line);
  padding-top: 8px;
}

.calendar-items span {
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 850;
}

.calendar-items strong {
  font-size: 0.94rem;
  line-height: 1.45;
}

.calendar-agenda {
  position: sticky;
  top: 92px;
  max-height: calc(100vh - 112px);
  overflow: auto;
}

.calendar-agenda-list {
  display: grid;
  gap: 12px;
}

.calendar-agenda-row {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 12px;
  min-width: 0;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 12px;
}

.calendar-agenda-row.is-in-plan {
  border-color: rgba(21, 101, 90, 0.42);
  box-shadow: inset 4px 0 0 rgba(21, 101, 90, 0.68);
}

.calendar-agenda-row > * {
  min-width: 0;
}

.calendar-agenda-row time {
  color: var(--blue);
  font-size: 0.88rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.calendar-agenda-row h3 {
  margin: 0;
  font-size: 1rem;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.calendar-agenda-row p:not(.card-kicker) {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.briefing-metrics {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.briefing-action-rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.briefing-action-card {
  display: grid;
  gap: 10px;
  align-content: start;
  min-width: 0;
  min-height: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.05);
}

.briefing-action-card span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: var(--surface-strong);
  color: var(--green);
  padding: 5px 9px;
  font-size: 0.75rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.briefing-action-card h2 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 0;
  color: var(--navy);
  font-size: 1.08rem;
  line-height: 1.4;
}

.briefing-action-card p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.briefing-action-card small {
  color: var(--subtle);
  font-weight: 850;
  line-height: 1.45;
}

.briefing-action-card .button {
  align-self: end;
  justify-content: center;
  min-height: 38px;
  margin-top: 4px;
  padding-inline: 12px;
}

.briefing-command-board {
  display: grid;
  grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.1fr);
  gap: 16px;
  margin-top: 18px;
}

.briefing-priority-panel,
.briefing-timeline-panel,
.briefing-matrix-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.05);
}

.briefing-priority-panel {
  display: grid;
  align-content: start;
  gap: 13px;
  padding: 22px;
}

.briefing-priority-panel h2,
.briefing-timeline-panel h2 {
  margin: 0;
  color: var(--navy);
  line-height: 1.24;
}

.briefing-priority-panel h2 {
  font-size: clamp(1.45rem, 2.4vw, 2.08rem);
}

.briefing-priority-panel p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.68;
}

.briefing-signal-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.briefing-signal-strip div {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 13px;
}

.briefing-signal-strip strong,
.briefing-signal-strip span,
.briefing-signal-strip small {
  display: block;
}

.briefing-signal-strip strong {
  color: var(--blue);
  font-size: 1.55rem;
  line-height: 1;
}

.briefing-signal-strip span {
  margin-top: 6px;
  color: var(--ink);
  font-weight: 900;
}

.briefing-signal-strip small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 780;
  line-height: 1.45;
}

.briefing-timeline-panel {
  display: grid;
  gap: 14px;
  padding: 20px;
}

.section-mini-head {
  display: grid;
  gap: 5px;
}

.section-mini-head h2 {
  font-size: 1.25rem;
}

.briefing-timeline {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.briefing-timeline li {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.briefing-timeline li:first-child {
  border-top: 0;
  padding-top: 0;
}

.briefing-timeline > li > span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(21, 101, 90, 0.1);
  color: var(--green);
  padding: 6px 9px;
  font-size: 0.78rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.briefing-timeline div {
  min-width: 0;
}

.briefing-timeline h3 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 0;
  font-size: 1rem;
  line-height: 1.38;
}

.briefing-timeline p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin: 5px 0 0;
  color: var(--muted);
  line-height: 1.55;
}

.briefing-timeline small {
  display: block;
  margin-top: 5px;
  color: var(--subtle);
  font-size: 0.78rem;
  font-weight: 850;
  line-height: 1.45;
}

.briefing-matrix {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.briefing-matrix-card {
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 16px;
}

.briefing-matrix-card > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}

.briefing-matrix-card span {
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 900;
}

.briefing-matrix-card strong {
  color: var(--navy);
  font-size: 1.65rem;
  line-height: 1;
}

.briefing-matrix-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.55;
}

.briefing-matrix-card ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.briefing-matrix-card li {
  min-width: 0;
  border-top: 1px solid var(--line);
  padding-top: 8px;
}

.briefing-matrix-card a {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  color: var(--ink);
  font-weight: 850;
  line-height: 1.4;
}

.briefing-matrix-card small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 780;
  line-height: 1.4;
}

.briefing-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

.briefing-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.briefing-item {
  display: grid;
  grid-template-columns: 44px 150px minmax(0, 1fr) minmax(130px, max-content);
  gap: 16px;
  align-items: start;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.05);
}

.briefing-item__rank {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius);
  background: var(--navy);
  color: white;
  font-weight: 900;
}

.briefing-item__media {
  display: block;
  min-width: 0;
  height: 118px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: inherit;
}

.briefing-item__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.briefing-item__media .media-card__fallback {
  height: 100%;
}

.briefing-item__body {
  min-width: 0;
}

.briefing-item h2 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.briefing-item p:not(.card-kicker) {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.65;
  overflow-wrap: anywhere;
}

.briefing-item__actions {
  display: grid;
  gap: 8px;
  justify-items: stretch;
}

.briefing-item__actions .button,
.briefing-item__actions .save-button {
  width: 100%;
  min-height: 38px;
  justify-content: center;
  padding-inline: 12px;
}

.briefing-side {
  display: grid;
  gap: 16px;
  position: sticky;
  top: 92px;
}

.tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tag-cloud span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
  font-size: 0.9rem;
  font-weight: 800;
}

.tag-cloud small {
  color: var(--green);
  font-weight: 900;
}

.status-list {
  display: grid;
  gap: 10px;
}

.status-list div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}

.status-list div:last-child {
  border-bottom: 0;
}

.status-list span {
  color: var(--muted);
  font-weight: 700;
}

.status-list strong {
  font-size: 1.4rem;
  color: var(--navy);
}

.briefing-pulse-list {
  display: grid;
  gap: 12px;
}

.briefing-pulse-list a {
  display: grid;
  gap: 8px;
  color: inherit;
}

.briefing-pulse-list span {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}

.briefing-pulse-list strong {
  color: var(--ink);
  font-size: 0.95rem;
}

.briefing-pulse-list small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  white-space: nowrap;
}

.briefing-pulse-list em {
  display: block;
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--surface-strong);
}

.briefing-pulse-list em::before {
  display: block;
  width: var(--pulse, 20%);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--blue), var(--green));
  content: "";
}

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

.briefing-radar-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  min-height: 150px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
}

.briefing-radar-card strong {
  font-size: 1.08rem;
}

.briefing-radar-card span,
.briefing-radar-card small {
  color: var(--muted);
  line-height: 1.55;
  overflow-wrap: anywhere;
}

.briefing-radar-card small {
  color: var(--subtle);
}

.channel-metrics {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.channel-insight-grid {
  margin-bottom: 18px;
}

.channel-insight-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  padding: 18px;
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.channel-insight-card span {
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 900;
}

.channel-insight-card strong {
  color: var(--navy);
  font-size: clamp(1.45rem, 2.4vw, 2.05rem);
  line-height: 1.08;
  overflow-wrap: anywhere;
}

.channel-insight-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.channel-live-rail {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
}

.channel-live-rail a {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 13px;
}

.channel-live-rail a > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--ink);
  color: white;
  font-weight: 900;
}

.channel-live-rail small {
  color: var(--green);
  font-weight: 850;
  line-height: 1.45;
}

.channel-live-rail strong {
  display: block;
  margin-top: 5px;
  color: var(--navy);
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.updates-radar-head {
  margin-top: 28px;
}

.updates-radar-cards {
  margin: 0 0 18px;
}

.updates-signal-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  padding: 18px;
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.updates-signal-card span {
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 900;
}

.updates-signal-card strong {
  color: var(--navy);
  font-size: clamp(1.35rem, 2.2vw, 1.9rem);
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.updates-signal-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.updates-queue-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin: 18px 0;
}

.updates-queue-grid--media {
  margin-bottom: 26px;
}

.updates-queue-list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.updates-queue-list a {
  display: grid;
  gap: 5px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 12px;
}

.updates-queue-list span {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
}

.updates-queue-list strong {
  color: var(--navy);
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.updates-matrix {
  margin: 30px 0 24px;
}

.updates-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
  min-width: min(100%, 320px);
}

.updates-filter-chips a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper);
  color: var(--navy);
  font-size: 0.88rem;
  font-weight: 850;
}

.updates-matrix-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.updates-matrix-card {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.05);
}

.updates-matrix-card__head,
.updates-matrix-card__actions,
.updates-matrix-stat span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-width: 0;
}

.updates-matrix-card__head > div {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.updates-matrix-card__head span,
.updates-matrix-stat small {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 850;
}

.updates-matrix-card__head strong {
  color: var(--navy);
  font-size: 1.28rem;
}

.updates-matrix-card__head a,
.updates-matrix-card__actions a {
  color: var(--green);
  font-size: 0.84rem;
  font-weight: 900;
}

.updates-matrix-bars {
  display: grid;
  gap: 9px;
}

.updates-matrix-stat {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.updates-matrix-stat strong {
  color: var(--navy);
}

.updates-matrix-bar {
  position: relative;
  display: block;
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: #e2d8c4;
}

.updates-matrix-bar::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--value);
  min-width: 8px;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--green), var(--blue));
  content: "";
}

.channel-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

.channel-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.channel-card {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.05);
}

.channel-card__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.channel-card h2 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.channel-status {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 6px 10px;
  background: var(--surface);
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
}

.channel-status.is-ready {
  background: rgba(21, 101, 90, 0.12);
  color: var(--green);
}

.channel-status.needs-check {
  background: rgba(179, 64, 44, 0.12);
  color: var(--red);
}

.channel-progress {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--surface);
}

.channel-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--green), var(--blue));
}

.channel-latest {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 12px;
}

.channel-latest span {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
}

.channel-latest strong {
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.channel-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.channel-side {
  display: grid;
  gap: 16px;
  position: sticky;
  top: 92px;
}

.channel-detail-main {
  display: grid;
  gap: 10px;
}

.channel-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  gap: 18px;
  align-items: stretch;
}

.channel-detail-visual {
  min-height: 100%;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}

.channel-detail-visual img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
}

.channel-detail-visual .update-embed {
  display: block;
  width: 100%;
  min-height: 420px;
  height: 100%;
  border: 0;
  background: #1d1812;
}

.channel-detail-brief {
  display: grid;
  align-content: center;
  gap: 14px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  padding: 22px;
  box-shadow: 0 16px 36px rgba(29, 24, 18, 0.07);
}

.channel-detail-brief h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.45rem, 2.6vw, 2.1rem);
  line-height: 1.22;
}

.channel-detail-brief p {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}

.update-path-section {
  padding-top: 10px;
}

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

.update-path-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  min-height: 154px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.update-path-card span,
.update-neighbor-nav span {
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 900;
}

.update-path-card strong,
.update-neighbor-nav strong {
  color: var(--navy);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.update-path-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

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

.update-neighbor-nav > a,
.update-neighbor-nav > span {
  display: grid;
  gap: 6px;
  min-width: 0;
  min-height: 96px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}

.update-neighbor-nav small {
  color: var(--muted);
  font-weight: 750;
}

.update-copy-tools {
  display: grid;
  gap: 10px;
  padding-top: 6px;
}

.update-copy-tools h3 {
  margin: 0;
  color: var(--navy);
  font-size: 1rem;
}

.update-copy-tools .save-button {
  width: 100%;
}

.channel-subscribe-grid,
.channel-update-grid {
  display: grid;
  gap: 14px;
}

.channel-subscribe-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.channel-subscribe-card,
.channel-update-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.channel-subscribe-card {
  display: grid;
  gap: 9px;
  padding: 16px;
}

.channel-subscribe-card span,
.channel-update-card span {
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 900;
}

.channel-subscribe-card strong,
.channel-update-card strong {
  color: var(--navy);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

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

.channel-update-card {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  overflow: hidden;
}

.channel-update-card__image {
  min-height: 154px;
  background: var(--surface);
}

.channel-update-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.channel-update-card > div:last-child {
  display: grid;
  gap: 8px;
  padding: 14px;
}

.channel-update-card p {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  line-height: 1.55;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.channel-detail-side {
  position: sticky;
  top: 92px;
}

.subscription-metrics {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.subscription-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 24px;
  align-items: start;
}

.subscription-preset-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin: 0 0 22px;
}

.subscription-preset-grid .save-button {
  width: 100%;
  min-width: 0;
  padding-inline: 10px;
}

.subscription-source-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.subscription-card {
  display: grid;
  gap: 14px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  padding: 18px;
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.05);
}

.subscription-card__toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 900;
}

.subscription-card__toggle input {
  width: 22px;
  height: 22px;
  accent-color: var(--green);
}

.subscription-card__toggle span {
  margin-left: auto;
  border-radius: 999px;
  background: rgba(21, 101, 90, 0.1);
  color: var(--green);
  padding: 5px 9px;
  font-size: 0.76rem;
}

.subscription-card h2 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.4;
  overflow-wrap: anywhere;
}

.subscription-output-panel {
  display: grid;
  gap: 16px;
  position: sticky;
  top: 92px;
}

.subscription-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 16px 0 0;
}

.subscription-summary div {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
  padding: 10px;
}

.subscription-summary dt {
  color: var(--subtle);
  font-size: 0.74rem;
  font-weight: 900;
}

.subscription-summary dd {
  margin: 4px 0 0;
  color: var(--navy);
  font-size: 1.08rem;
  font-weight: 900;
}

.subscription-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(108px, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.subscription-actions .button {
  justify-content: center;
  width: 100%;
}

.copy-feedback {
  min-height: 22px;
  margin: 12px 0 0;
  color: var(--green);
  font-size: 0.86rem;
  font-weight: 850;
}

.subscription-output {
  width: 100%;
  min-height: 180px;
  resize: vertical;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
  color: var(--ink);
  padding: 12px;
  font-size: 0.82rem;
  line-height: 1.55;
  white-space: pre;
  overflow: auto;
}

.subscription-feed-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.subscription-feed-strip a {
  display: grid;
  gap: 7px;
  min-width: 0;
  min-height: 112px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
  box-shadow: 0 10px 28px rgba(29, 24, 18, 0.05);
}

.subscription-feed-strip a:hover {
  border-color: #c7bba6;
  background: var(--surface);
}

.subscription-feed-strip strong {
  color: var(--navy);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.subscription-feed-strip span {
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.55;
  font-weight: 750;
}

.coverage-list {
  display: grid;
  gap: 8px;
}

.coverage-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}

.coverage-list a:last-child {
  border-bottom: 0;
}

.coverage-list span {
  color: var(--muted);
  font-weight: 800;
}

.coverage-list strong {
  color: var(--navy);
  font-size: 1.1rem;
}

.status-metrics {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.status-trust-board {
  display: grid;
  grid-template-columns: minmax(240px, 340px) minmax(0, 1fr);
  gap: 18px;
  margin-bottom: 22px;
}

.status-trust-score,
.status-trust-panel,
.status-lineage-card,
.status-cadence-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.status-trust-score {
  display: grid;
  gap: 12px;
  padding: 20px;
  align-content: start;
  background:
    linear-gradient(145deg, rgba(21, 101, 90, 0.08), rgba(207, 59, 34, 0.08)),
    white;
}

.status-trust-score strong {
  color: var(--navy);
  font-size: clamp(2.8rem, 8vw, 4.8rem);
  line-height: 0.95;
  letter-spacing: 0;
}

.status-trust-score h2,
.status-trust-panel h2,
.status-lineage-card h2,
.status-cadence-card h2 {
  margin: 0;
  color: var(--ink);
  font-size: 1.08rem;
  line-height: 1.35;
}

.status-trust-score p,
.status-lineage-card p,
.status-cadence-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.status-trust-panel {
  display: grid;
  gap: 16px;
  padding: 20px;
}

.status-trust-panel__head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
}

.status-trust-panel__head > div {
  min-width: 0;
}

.status-trust-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.status-trust-list div {
  min-width: 0;
  padding: 13px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
}

.status-trust-list span {
  display: block;
  color: var(--subtle);
  font-size: 0.75rem;
  font-weight: 900;
}

.status-trust-list strong {
  display: block;
  margin-top: 6px;
  color: var(--navy);
  font-size: 1.25rem;
  line-height: 1.1;
}

.status-lineage-grid,
.status-cadence-grid {
  display: grid;
  gap: 14px;
}

.status-lineage-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.status-lineage-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  padding: 16px;
  align-items: start;
}

.status-lineage-card > span {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--navy);
  color: white;
  font-weight: 900;
}

.status-lineage-card.is-watch > span {
  background: #9c7a2e;
}

.status-lineage-card.is-attention > span {
  background: #b3402c;
}

.status-cadence-board {
  margin-top: 34px;
}

.status-cadence-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.status-cadence-card {
  display: grid;
  gap: 12px;
  padding: 18px;
}

.status-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

.status-signal-grid,
.data-set-grid,
.district-status-grid {
  display: grid;
  gap: 16px;
}

.status-signal-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.data-set-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.district-status-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.visual-status-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

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

.status-signal,
.data-set-card,
.district-status-card,
.visual-status-card,
.status-issue {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.status-signal,
.data-set-card,
.district-status-card,
.visual-status-card {
  padding: 18px;
}

.status-signal {
  display: grid;
  gap: 10px;
  align-content: start;
}

.status-signal > span {
  width: max-content;
  border-radius: 999px;
  padding: 5px 9px;
  background: var(--surface);
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
}

.status-signal.is-ready > span,
.status-signal.is-good > span,
.status-pill.is-ready,
.status-pill.is-good {
  background: rgba(21, 101, 90, 0.12);
  color: #15655a;
}

.status-signal.is-watch > span,
.status-pill.is-watch {
  background: #fff1d2;
  color: #9c7a2e;
}

.status-signal.is-attention > span,
.status-signal.is-thin > span,
.status-pill.is-attention,
.status-pill.is-thin {
  background: rgba(207, 59, 34, 0.12);
  color: #b3402c;
}

.status-signal strong {
  color: var(--navy);
  font-size: 2rem;
  line-height: 1;
}

.status-signal h2,
.data-set-card h2,
.district-status-card h2,
.visual-status-card h2,
.status-issue h2 {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.35;
}

.status-signal p,
.data-set-card p,
.visual-status-card p,
.status-issue p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.visual-status-card {
  display: grid;
  gap: 14px;
}

.visual-status-card__head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}

.visual-status-card__head > div {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.visual-status-card__head strong {
  color: var(--navy);
  font-size: 1.8rem;
  line-height: 1;
}

.visual-status-card .mini-facts {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.visual-missing-panel {
  display: grid;
  gap: 12px;
}

.visual-missing-panel p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.visual-missing-list {
  display: grid;
  gap: 10px;
}

.visual-missing-list a {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
}

.visual-missing-list span,
.visual-missing-list small {
  color: var(--subtle);
  font-size: 0.76rem;
  font-weight: 900;
}

.visual-missing-list strong {
  color: var(--ink);
  line-height: 1.35;
}

.source-mix {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}

.source-mix div {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}

.source-mix div:last-child {
  border-bottom: 0;
}

.source-mix span {
  color: var(--muted);
  font-weight: 800;
}

.source-mix strong {
  color: var(--navy);
}

.data-set-card {
  display: grid;
  gap: 12px;
}

.data-set-card > div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  border-radius: 999px;
  padding: 5px 9px;
  background: var(--surface);
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 900;
}

.status-pill.is-muted {
  background: var(--surface);
  color: var(--subtle);
}

.district-status-card {
  display: grid;
  gap: 14px;
}

.district-status-card__head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}

.status-score {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--surface-strong);
}

.status-score span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--green), var(--blue));
}

.mini-facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.mini-facts div {
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
}

.mini-facts dt {
  color: var(--subtle);
  font-size: 0.74rem;
  font-weight: 900;
}

.mini-facts dd {
  margin: 4px 0 0;
  color: var(--ink);
  font-weight: 900;
}

.status-issue-list {
  display: grid;
  gap: 12px;
}

.status-issue {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 16px 18px;
}

.status-issue > * {
  min-width: 0;
}

.status-issue p {
  overflow-wrap: anywhere;
}

.topic-metrics {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.topic-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

.topic-list {
  display: grid;
  gap: 16px;
  margin-top: 18px;
}

.topic-card {
  display: grid;
  gap: 16px;
  min-width: 0;
  scroll-margin-top: 96px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.topic-card__head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
}

.topic-card h2 {
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.35;
}

.topic-card h3 {
  margin: 0 0 10px;
  font-size: 0.95rem;
}

.topic-card p:not(.card-kicker) {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.topic-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.topic-strip div {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 12px;
}

.topic-strip strong,
.topic-strip span {
  display: block;
}

.topic-strip strong {
  color: var(--navy);
  font-size: 1.1rem;
  overflow-wrap: anywhere;
}

.topic-strip span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 800;
}

.topic-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.topic-tags a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--card);
  padding: 7px 10px;
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 800;
}

.topic-tags small {
  color: var(--green);
  font-weight: 900;
}

.topic-columns {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: 16px;
}

.topic-update-list,
.topic-link-list {
  display: grid;
  gap: 10px;
}

.topic-update-list a,
.topic-link-list a {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 12px;
}

.topic-update-list span,
.topic-link-list span {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
}

.topic-update-list strong,
.topic-link-list strong {
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.topic-side {
  display: grid;
  gap: 16px;
  position: sticky;
  top: 92px;
}

.topic-detail-main {
  display: grid;
  gap: 10px;
}

.topic-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  gap: 18px;
  align-items: stretch;
}

.topic-detail-visual {
  min-height: 100%;
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--surface);
}

.topic-detail-visual img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
}

.topic-detail-brief {
  display: grid;
  align-content: center;
  gap: 14px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  padding: 22px;
  box-shadow: 0 16px 36px rgba(29, 24, 18, 0.07);
}

.topic-detail-brief h2 {
  margin: 0;
  color: var(--navy);
  font-size: clamp(1.45rem, 2.6vw, 2.1rem);
  line-height: 1.22;
}

.topic-detail-brief p:not(.card-kicker) {
  margin: 0;
  color: var(--muted);
  line-height: 1.7;
}

.topic-district-grid,
.topic-action-grid,
.topic-update-grid {
  display: grid;
  gap: 14px;
}

.topic-district-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.topic-district-grid a,
.topic-action-card,
.topic-update-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 10px 26px rgba(29, 24, 18, 0.05);
}

.topic-district-grid a {
  display: grid;
  gap: 5px;
  padding: 16px;
}

.topic-district-grid strong,
.topic-action-card strong,
.topic-update-card strong {
  color: var(--navy);
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.topic-district-grid span,
.topic-action-card span,
.topic-update-card span {
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 900;
}

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

.topic-update-card {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  overflow: hidden;
}

.topic-update-card__image {
  min-height: 154px;
  background: var(--surface);
}

.topic-update-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.topic-update-card > div:last-child,
.topic-action-card {
  display: grid;
  gap: 8px;
  padding: 14px;
}

.topic-update-card p,
.topic-action-card p {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  line-height: 1.55;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

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

.topic-action-card small {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.45;
}

.topic-detail-side {
  position: sticky;
  top: 92px;
}

.coverage-list > span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}

.coverage-list > span:last-child {
  border-bottom: 0;
}

.report-scoreboard {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}

.report-score {
  display: grid;
  align-content: center;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--navy);
  color: white;
  padding: 28px;
  box-shadow: var(--shadow);
}

.report-score span {
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.82rem;
  font-weight: 900;
}

.report-score strong {
  margin-top: 8px;
  font-size: clamp(3rem, 7vw, 5.4rem);
  line-height: 0.95;
}

.report-score p {
  margin: 14px 0 0;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.7;
}

.report-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.report-signal-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  min-height: 160px;
  border: 1px solid var(--line);
  border-top: 4px solid var(--green);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.report-signal-card.is-watch {
  border-top-color: var(--gold);
}

.report-signal-card.is-attention {
  border-top-color: var(--red);
}

.report-signal-card span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
}

.report-signal-card strong {
  color: var(--navy);
  font-size: 2rem;
  line-height: 1;
}

.report-signal-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
}

.report-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

.report-topic-list {
  display: grid;
  gap: 14px;
}

.report-topic-card {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 16px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.report-topic-card__rank {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: var(--navy);
  color: white;
  font-weight: 900;
}

.report-topic-card h2,
.report-district-card h2,
.report-calendar-day h2,
.report-action-card h2,
.report-media-card h2 {
  margin: 0;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.report-topic-card p:not(.card-kicker),
.report-district-card p:not(.card-kicker),
.report-action-card p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.65;
  overflow-wrap: anywhere;
}

.report-side {
  display: grid;
  gap: 16px;
  position: sticky;
  top: 92px;
}

.report-narrative {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 14px 0 0;
  list-style: none;
}

.report-narrative li {
  border-left: 3px solid var(--green);
  padding-left: 12px;
  color: var(--muted);
  line-height: 1.65;
}

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

.report-district-card {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.report-district-card > a:first-child {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  color: inherit;
}

.report-district-card__image {
  min-height: 210px;
  background: var(--surface-strong);
}

.report-district-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.report-district-card__body {
  display: grid;
  align-content: start;
  min-width: 0;
  padding: 18px;
}

.report-latest-link {
  display: grid;
  gap: 6px;
  min-width: 0;
  border-top: 1px solid var(--line);
  background: var(--surface);
  padding: 13px 16px;
}

.report-latest-link span {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
}

.report-latest-link strong {
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.report-two-column {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.88fr);
  gap: 24px;
  align-items: start;
}

.report-calendar-list,
.report-action-list {
  display: grid;
  gap: 14px;
}

.report-calendar-day {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 16px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.report-calendar-items {
  display: grid;
  gap: 8px;
}

.report-calendar-items a {
  display: grid;
  gap: 4px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  background: var(--surface);
  padding: 10px 12px;
}

.report-calendar-items span {
  color: var(--green);
  font-size: 0.76rem;
  font-weight: 900;
}

.report-calendar-items strong {
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.report-action-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.report-action-card > span {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: rgba(207, 59, 34, 0.1);
  color: var(--blue);
  padding: 5px 9px;
  font-size: 0.76rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

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

.report-media-card {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.report-media-card > a {
  display: grid;
  color: inherit;
}

.report-media-card__image {
  aspect-ratio: 16 / 9;
  background: var(--surface-strong);
}

.report-media-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.report-media-card__body {
  display: grid;
  align-content: start;
  min-width: 0;
  padding: 16px;
}

.media-room-metrics {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.media-room-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.65fr);
  gap: 18px;
  align-items: stretch;
}

.media-room-lead {
  position: relative;
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 16px 38px rgba(29, 24, 18, 0.08);
}

.media-room-lead > a {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  min-height: 100%;
  color: inherit;
}

.media-room-lead__image {
  min-height: 360px;
  background: var(--surface);
}

.media-room-lead__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-room-lead__body {
  display: grid;
  align-content: center;
  gap: 14px;
  min-width: 0;
  padding: 28px;
}

.media-room-lead h2 {
  margin: 0;
  font-size: clamp(1.6rem, 2vw, 2.25rem);
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.media-room-lead p:not(.card-kicker) {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.media-room-lead .save-button {
  position: absolute;
  right: 18px;
  top: 18px;
  background: rgba(255, 255, 255, 0.94);
}

.media-room-support {
  display: grid;
  gap: 12px;
}

.media-room-support article {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
}

.media-room-support a {
  display: grid;
  gap: 8px;
  color: inherit;
}

.media-room-support span {
  color: var(--green);
  font-size: 0.78rem;
  font-weight: 900;
}

.media-room-support strong {
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.media-room-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
  align-items: start;
}

.media-room-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
}

.media-room-card {
  position: relative;
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--paper);
  box-shadow: 0 12px 30px rgba(29, 24, 18, 0.06);
}

.media-room-card > a {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  min-height: 100%;
  color: inherit;
}

.media-room-card__image {
  min-height: 190px;
  background: var(--surface);
}

.media-room-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-room-card__body {
  display: grid;
  align-content: start;
  gap: 10px;
  min-width: 0;
  padding: 18px;
}

.media-room-card h2 {
  margin: 0;
  font-size: 1.08rem;
  line-height: 1.38;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.media-room-card p:not(.card-kicker) {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.media-room-card .save-button {
  position: absolute;
  right: 12px;
  top: 12px;
  background: rgba(255, 255, 255, 0.94);
}

.media-room-side {
  display: grid;
  gap: 16px;
  position: sticky;
  top: 92px;
}

.media-room-districts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.media-room-districts article {
  display: grid;
  grid-template-columns: minmax(0, 0.64fr) minmax(0, 1fr) minmax(96px, auto);
  gap: 14px;
  align-items: center;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 16px;
}

.media-room-districts h2 {
  margin: 0;
  font-size: 1.08rem;
}

.media-room-districts .text-link {
  justify-self: start;
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
}

.media-room-districts span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  justify-self: end;
  text-align: right;
  white-space: normal;
}

.timeline {
  display: grid;
  gap: 16px;
}

.timeline-step {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  padding: 18px;
}

.timeline-step__marker {
  display: grid;
  align-content: start;
  justify-items: start;
  gap: 8px;
}

.timeline-step__marker strong {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: var(--navy);
  color: white;
}

.timeline-step__marker span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
}

.timeline-step__body {
  min-width: 0;
}

.timeline-step__body h2 {
  margin: 0;
  font-size: 1.25rem;
}

.timeline-step__body p {
  margin: 10px 0 0;
}

.resource-link {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-top: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 13px 14px;
}

.resource-link span,
.resource-link strong,
.resource-link small {
  display: block;
  min-width: 0;
}

.resource-link small {
  margin-top: 4px;
  color: var(--muted);
}

.resource-link em {
  flex: 0 0 auto;
  color: var(--blue);
  font-style: normal;
  font-weight: 800;
  white-space: nowrap;
}

.empty-state {
  border: 1px dashed #c7bba6;
  border-radius: var(--radius);
  padding: 22px;
  background: var(--card);
}

.empty-state strong {
  display: block;
  margin-bottom: 6px;
}

.empty-state p {
  margin: 0;
  color: var(--muted);
}

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

.footer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
  padding-block: 42px 28px;
}

.footer-grid p,
.footer-bottom {
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.65;
}

.footer-bottom {
  display: flex;
  gap: 16px;
  align-items: center;
  padding-block: 18px 26px;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.footer-bottom span {
  margin-right: auto;
}

.footer-grid ul {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.footer-grid li a {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.92rem;
  font-weight: 600;
}

.footer-grid li a:hover,
.footer-grid li a[aria-current="page"] {
  color: #fff;
  text-decoration: underline;
}

[data-filter-item].is-hidden,
[data-briefing-item].is-hidden,
[data-channel-item].is-hidden,
[data-builder-card].is-hidden,
[data-topic-item].is-hidden,
[data-media-item].is-hidden,
[data-status-card].is-hidden,
.search-result.is-hidden {
  display: none;
}

.updated-line {
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.65;
}

@media (max-width: 920px) {
  .header-inner {
    align-items: stretch;
    flex-direction: column;
    padding-block: 12px;
  }

  .main-nav {
    width: 100%;
  }

  .command-trigger {
    justify-content: center;
    width: 100%;
  }

  .dashboard-strip,
  .detail-grid,
  .today-decision-board,
  .today-scenario-board,
  .compare-command-board,
  .visit-command-board,
  .collection-choice-board,
  .collection-detail-board,
  .service-command-board,
  .service-readiness-panel,
  .saved-command-board,
  .planner-command-board,
  .my-command-board,
  .planner-shell,
  .my-seoul-shell,
  .calendar-layout,
  .briefing-command-board,
  .briefing-layout,
  .channel-layout,
  .channel-detail-hero,
  .subscription-layout,
  .topic-layout,
  .topic-detail-hero,
  .district-hub-board,
  .district-media-layout,
  .status-trust-board,
  .status-layout,
  .visual-status-layout,
  .media-room-hero-grid,
  .media-room-layout,
  .updates-queue-grid,
  .report-scoreboard,
  .report-layout,
  .report-two-column {
    grid-template-columns: 1fr;
  }

  .grid.four,
  .grid.three,
  .home-command-grid,
  .today-action-grid,
  .today-decision-grid,
  .today-rhythm-strip,
  .today-scenario-panel__head,
  .today-scenario-metrics,
  .today-scenario-steps li,
  .compare-scenario-grid,
  .compare-insight-strip,
  .compare-playbook,
  .visit-scenario-grid,
  .visit-signal-strip,
  .visit-flow-list,
  .collection-scenario-grid,
  .collection-signal-strip,
  .collection-detail-signals,
  .collection-route-flow,
  .service-scenario-grid,
  .service-signal-strip,
  .service-category-rail,
  .service-flow-list,
  .district-grid,
  .district-hub-signals,
  .district-path-matrix,
  .district-action-board,
  .district-explore-grid,
  .district-service-grid,
  .filters,
  .search-command-head,
  .search-command-metrics,
  .search-active-filters,
  .footer-grid,
  .planner-topline,
  .planner-command-metrics,
  .my-command-grid,
  .briefing-metrics,
  .briefing-action-rail,
  .briefing-signal-strip,
  .briefing-matrix,
  .briefing-radar,
  .channel-metrics,
  .channel-subscribe-grid,
  .channel-update-grid,
  .subscription-metrics,
  .subscription-preset-grid,
  .subscription-source-grid,
  .subscription-feed-strip,
  .channel-list,
  .my-plan-grid,
  .my-action-grid,
  .status-metrics,
  .status-trust-list,
  .status-lineage-grid,
  .status-cadence-grid,
  .status-signal-grid,
  .visual-status-grid,
  .data-set-grid,
  .district-status-grid,
  .topic-metrics,
  .topic-strip,
  .topic-columns,
  .topic-district-grid,
  .topic-update-grid,
  .topic-action-grid,
  .media-room-metrics,
  .media-room-grid,
  .media-room-districts,
  .report-metrics,
  .report-signal-grid,
  .report-district-grid,
  .report-media-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .planner-panel--board {
    position: static;
    max-height: none;
    overflow: visible;
  }

  .my-settings {
    position: static;
  }

  .calendar-agenda {
    position: static;
    max-height: none;
  }

  .briefing-side {
    position: static;
  }

  .channel-side {
    position: static;
  }

  .channel-detail-side {
    position: static;
  }

  .subscription-output-panel {
    position: static;
  }

  .topic-side {
    position: static;
  }

  .topic-detail-side {
    position: static;
  }

  .district-media-panel {
    position: static;
  }

  .media-room-side {
    position: static;
  }

  .report-side {
    position: static;
  }

  .calendar-plan-bar {
    grid-template-columns: 1fr;
  }

  .calendar-plan-bar .button {
    width: 100%;
  }

  .calendar-planner-board,
  .calendar-overlay-list {
    grid-template-columns: 1fr;
  }

  .home-command-head {
    align-items: start;
    display: grid;
  }

  .command-palette__meta {
    display: grid;
  }

  .command-palette__meta > p {
    max-width: none;
    text-align: left;
  }
}

@media (max-width: 620px) {
  .container {
    width: min(100% - 24px, 1180px);
  }

  .page-hero h1 {
    font-size: 2.25rem;
  }

  .page-hero-actions,
  .search-box {
    display: grid;
  }

  .search-box button {
    min-height: 44px;
  }

  .command-palette {
    align-items: start;
    padding: 12px;
  }

  .command-palette__panel {
    max-height: calc(100vh - 24px);
  }

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

  .command-palette__search button {
    grid-column: 1 / -1;
  }

  .command-palette__meta {
    padding-inline: 14px;
  }

  .command-palette__chips {
    padding-inline: 14px;
  }

  .command-palette__status {
    padding-inline: 14px;
  }

  .command-palette__results {
    max-height: calc(100vh - 310px);
  }

  .command-palette__item {
    grid-template-columns: 38px minmax(0, 1fr);
    padding: 10px;
  }

  .command-palette__item-icon {
    width: 38px;
    height: 38px;
  }

  .section-navigator {
    top: 78px;
    right: 10px;
    left: 10px;
    width: auto;
  }

  .section-navigator details {
    justify-items: end;
  }

  .section-navigator summary {
    width: min(210px, 100%);
  }

  .section-navigator__panel {
    max-height: min(420px, calc(100vh - 220px));
  }

  .section-navigator__link--sub {
    margin-left: 10px;
  }

  .grid.four,
  .grid.three,
  .grid.two,
  .home-command-grid,
  .today-action-grid,
  .today-decision-board,
  .today-decision-grid,
  .today-rhythm-strip,
  .today-scenario-board,
  .today-scenario-panel__head,
  .today-scenario-metrics,
  .today-scenario-steps li,
  .compare-command-board,
  .compare-scenario-grid,
  .compare-insight-strip,
  .compare-playbook,
  .visit-command-board,
  .visit-scenario-grid,
  .visit-signal-strip,
  .visit-flow-list,
  .visit-flow-list article,
  .collection-choice-board,
  .collection-detail-board,
  .collection-scenario-grid,
  .collection-signal-strip,
  .collection-detail-signals,
  .collection-route-flow,
  .collection-route-flow article,
  .service-command-board,
  .service-scenario-grid,
  .service-signal-strip,
  .service-category-rail,
  .service-flow-list,
  .service-flow-list article,
  .service-readiness-panel,
  .district-grid,
  .district-hub-board,
  .district-hub-signals,
  .district-path-matrix,
  .district-action-board,
  .district-explore-grid,
  .district-service-grid,
  .filters,
  .search-command-head,
  .search-command-metrics,
  .search-intelligence-panel,
  .search-intelligence-metrics,
  .search-intelligence-actions,
  .footer-grid,
  .planner-topline,
  .planner-filters,
  .planner-command-board,
  .planner-command-metrics,
  .saved-command-board,
  .saved-command-metrics,
  .saved-type-rail,
  .planner-summary,
  .insight-strip,
  .my-command-board,
  .my-command-grid,
  .my-plan-grid,
  .my-action-grid,
  .my-recent-grid,
  .calendar-grid,
  .briefing-metrics,
  .briefing-action-rail,
  .briefing-command-board,
  .briefing-signal-strip,
  .briefing-timeline li,
  .briefing-matrix,
  .briefing-radar,
  .channel-metrics,
  .channel-subscribe-grid,
  .channel-update-grid,
  .channel-update-card,
  .subscription-metrics,
  .subscription-preset-grid,
  .subscription-source-grid,
  .subscription-feed-strip,
  .channel-list,
  .status-metrics,
  .status-trust-board,
  .status-trust-list,
  .status-lineage-grid,
  .status-cadence-grid,
  .status-signal-grid,
  .visual-status-grid,
  .data-set-grid,
  .district-status-grid,
  .topic-metrics,
  .topic-strip,
  .topic-columns,
  .topic-district-grid,
  .topic-update-grid,
  .topic-update-card,
  .topic-action-grid,
  .media-room-metrics,
  .media-room-grid,
  .media-room-districts,
  .report-metrics,
  .report-signal-grid,
  .report-topic-card,
  .report-district-grid,
  .report-district-card > a:first-child,
  .report-two-column,
  .report-calendar-day,
  .report-media-grid,
  .update-path-grid,
  .update-neighbor-nav,
  .media-room-lead > a,
  .media-room-card > a,
  .media-room-districts article {
    grid-template-columns: 1fr;
  }

  .calendar-plan-bar {
    grid-template-columns: 1fr;
  }

  .calendar-plan-bar .button {
    width: 100%;
  }

  .calendar-planner-board,
  .calendar-overlay-metrics,
  .calendar-overlay-list,
  .calendar-overlay-day li {
    grid-template-columns: 1fr;
  }

  .calendar-planner-board__actions .button,
  .calendar-planner-board__actions a,
  .calendar-overlay-item__actions a {
    justify-content: center;
    width: 100%;
  }

  .calendar-overlay-item__actions {
    justify-content: flex-start;
  }

  .section-header {
    display: grid;
  }

  .updates-filter-chips {
    justify-content: flex-start;
  }

  .search-command-panel {
    padding: 16px;
  }

  .search-result-tools {
    padding: 12px;
  }

  .visit-command-lead,
  .visit-scenario-card,
  .collection-choice-lead,
  .collection-detail-lead,
  .collection-scenario-card,
  .service-command-lead,
  .service-scenario-card,
  .service-guide-card,
  .service-readiness-panel {
    padding: 15px;
  }

  .visit-toolbar,
  .collection-toolbar,
  .collection-copy-tools,
  .collection-detail-actions,
  .service-toolbar,
  .service-command-actions,
  .service-guide-actions,
  .saved-command-actions,
  .planner-command-actions,
  .my-command-actions,
  .today-scenario-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .visit-toolbar .button,
  .collection-toolbar .button,
  .collection-copy-tools .button,
  .collection-detail-actions .button,
  .service-toolbar .button,
  .service-command-actions .button,
  .service-guide-actions .button,
  .saved-command-actions .button,
  .planner-command-actions .button,
  .my-command-actions .button,
  .today-scenario-actions .button,
  .today-scenario-actions .save-button {
    justify-content: center;
    width: 100%;
  }

  .search-type-chips button,
  .search-suggestions a {
    flex: 1 1 calc(50% - 8px);
  }

  .list-item {
    grid-template-columns: 1fr;
  }

  .search-result-proof {
    grid-template-columns: 1fr;
  }

  .search-result-readiness {
    grid-template-columns: auto auto minmax(0, 1fr);
    align-items: center;
  }

  .timeline-step,
  .resource-link,
  .planner-candidate,
  .planner-step,
  .planner-calendar-list article,
  .my-plan-card,
  .calendar-agenda-row,
  .briefing-item,
  .status-issue {
    grid-template-columns: 1fr;
  }

  .planner-calendar-list__actions {
    justify-content: flex-start;
  }

  .channel-card__head,
  .channel-actions,
  .subscription-actions,
  .status-trust-panel__head,
  .topic-card__head,
  .district-status-card__head,
  .visual-status-card__head {
    display: grid;
  }

  .status-trust-panel__head .button {
    justify-content: center;
    width: 100%;
  }

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

  .visual-status-card .mini-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .media-room-lead__image {
    min-height: 220px;
  }

  .channel-detail-visual .update-embed {
    min-height: 260px;
  }

  .media-room-card__image {
    min-height: 210px;
  }

  .briefing-item__media {
    height: 180px;
  }

  .media-room-districts span {
    white-space: normal;
  }

  .timeline-step {
    display: grid;
  }

  .resource-link {
    display: grid;
  }

  .footer-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .saved-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .my-plan-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .my-plan-toolbar .button {
    width: 100%;
  }

  body.has-page-action-bar {
    padding-bottom: 84px;
  }

  .page-action-bar {
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
  }

  .page-action-bar__inner {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 8px 10px;
  }

  /* 모바일: 장황한 요약을 숨기고 액션을 한 줄 가로 스크롤로 — 바 높이 264px→~56px */
  .page-action-bar__summary {
    display: none;
  }

  .page-action-bar__actions {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    width: 100%;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .page-action-bar__actions::-webkit-scrollbar {
    display: none;
  }

  .page-action-button {
    flex: 0 0 auto;
    min-height: 40px;
    padding-inline: 14px;
    white-space: nowrap;
  }

  .page-next-actions {
    flex: 0 0 auto;
    width: auto;
  }

  .page-next-actions__panel {
    right: -10px;
    width: calc(100vw - 20px);
    max-height: calc(100vh - 180px);
    overflow-y: auto;
  }

  .page-next-actions__head {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .page-next-actions__head small {
    max-width: none;
    text-align: left;
  }

  .page-next-action {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .site-toast-region {
    right: 10px;
    bottom: 12px;
    width: calc(100vw - 20px);
  }

  .has-page-action-bar .site-toast-region {
    bottom: 88px;
  }

  .site-toast {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .site-toast__copy span {
    white-space: normal;
  }

  .site-toast__actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .site-toast__actions a,
  .site-toast__actions button {
    justify-content: center;
    width: 100%;
    text-align: center;
  }

  .trust-dock {
    right: 10px;
    bottom: 12px;
    left: 10px;
    width: auto;
  }

  .has-page-action-bar .trust-dock {
    bottom: 88px;
  }

  /* 모바일: 닫힌 상태는 아이콘만(수동 큐레이션 라벨·통계 숨김) → 폭 355px→~54px */
  .trust-dock:not([open]) summary {
    width: max-content;
    grid-template-columns: auto;
    padding: 9px;
  }

  .trust-dock:not([open]) summary strong,
  .trust-dock:not([open]) summary small {
    display: none;
  }

  .trust-dock[open] summary {
    width: 100%;
  }

  .trust-dock__panel {
    max-height: calc(100vh - 200px);
    padding: 14px;
  }

  .trust-dock__facts div {
    grid-template-columns: 78px minmax(0, 1fr);
  }

  .trust-dock__stats {
    grid-template-columns: 1fr;
  }

  .trust-dock__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .footer-bottom span {
    margin-right: 0;
  }
}

@media print {
  .site-header,
  .site-footer,
  .page-action-bar,
  .site-toast-region,
  .trust-dock,
  .section-navigator,
  .page-hero-actions,
  .planner-panel--search,
  .planner-actions,
  .planner-step__actions,
  .skip-link {
    display: none !important;
  }

  .page-hero,
  .section {
    padding-block: 24px;
  }

  .planner-shell {
    display: block;
  }

  .planner-panel,
  .planner-step,
  .planner-summary div,
  .planner-stat {
    box-shadow: none;
    break-inside: avoid;
  }
}

/* 테마 가이드 (에디토리얼) */
.guide-lead {
  font-size: 1.12rem;
  line-height: 1.8;
  color: var(--ink);
  margin: 18px 0 8px;
}

.guide-body section.compact {
  margin-top: 22px;
}

.guide-body h2 {
  font-size: 1.2rem;
  margin-bottom: 10px;
}

.guide-body p {
  line-height: 1.85;
  color: var(--ink);
  margin: 0 0 12px;
}

.guide-faq details {
  border-top: 1px solid var(--line);
  padding: 14px 0;
}

.guide-faq summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  list-style: none;
  cursor: pointer;
  font-size: 1.02rem;
  font-weight: 700;
  color: var(--ink);
}

.guide-faq summary::-webkit-details-marker {
  display: none;
}

.guide-faq .faq-mark {
  font-family: var(--mono);
  color: var(--accent);
}

.guide-faq p {
  margin: 12px 0 0;
  font-size: 14px;
  line-height: 1.75;
  color: var(--muted);
}

.guide-source-list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.guide-source-list a {
  color: var(--blue);
  text-decoration: underline;
}
/* ============================================================= */
/* 장소 상세 — 에디토리얼 정밀 레이아웃 (Stage B)                   */
/* ============================================================= */
.place-detail__intro {
  padding-block: 28px 0;
}

.place-detail__intro .breadcrumbs {
  margin: 0 0 4px;
  color: var(--muted);
  font-weight: 600;
}

.place-detail__intro .breadcrumbs span {
  color: var(--ink);
}

.place-detail__intro .breadcrumbs a:hover {
  color: var(--accent);
}

.place-detail__meta {
  margin: 26px 0 0;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  color: var(--accent-2);
}

.place-detail__title {
  margin: 14px 0 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  line-height: 1.04;
  color: var(--ink);
}

.place-detail__lead {
  margin: 20px 0 0;
  max-width: 34em;
  font-family: var(--serif-body);
  font-size: clamp(1.1rem, 1.6vw, 1.32rem);
  line-height: 1.8;
  color: var(--text-lead);
}

.place-detail__cover-wrap {
  padding-block: 32px 0;
}

.place-detail__cover {
  position: relative;
  aspect-ratio: 21 / 9;
  border: 1px solid var(--line);
  background: repeating-linear-gradient(135deg, #e6dbc7 0 15px, #e0d4bd 15px 30px);
}

.place-detail__cover .image-credit {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 3;
  margin: 0;
}

.place-detail__main {
  padding-block: 48px 72px;
}

.place-detail__cols {
  display: flex;
  flex-wrap: wrap;
  gap: 48px;
  align-items: flex-start;
}

.place-detail__article {
  flex: 1 1 440px;
  min-width: 0;
}

.place-detail__article .guide-body p {
  font-size: 1.14rem;
  line-height: 1.95;
  color: var(--text-strong);
  margin: 0 0 22px;
}

.place-detail__quote {
  margin: 14px 0 36px;
  padding: 28px 32px;
  border-left: 3px solid var(--accent);
  background: var(--card);
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.5;
  color: var(--ink);
}

.place-detail__fallback-note {
  color: var(--muted);
  line-height: 1.8;
}

.place-detail__faq {
  margin-top: 36px;
}

.place-detail__faq-title {
  margin: 0 0 14px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.6rem;
  color: var(--ink);
}

.place-faq details {
  border-top: 1px solid var(--line);
  padding: 14px 0;
}

.place-faq summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  list-style: none;
  cursor: pointer;
  font-size: 1.02rem;
  font-weight: 700;
  color: var(--ink);
}

.place-faq summary::-webkit-details-marker {
  display: none;
}

.place-faq .faq-mark {
  font-family: var(--mono);
  color: var(--accent);
}

.place-faq p {
  margin: 12px 0 0;
  font-size: 14px;
  line-height: 1.75;
  color: var(--muted);
}

.place-detail__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 36px;
}

.place-detail__aside {
  position: sticky;
  top: 96px;
  flex: 1 1 300px;
  align-self: flex-start;
  display: grid;
  gap: 18px;
}

.place-side-card {
  border: 1px solid var(--line);
  background: var(--card);
  padding: 22px;
}

.place-side-card--band {
  background: var(--band);
}

.place-side-card__kicker {
  margin: 0 0 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--accent-2);
}

.place-side-card__kicker--muted {
  color: var(--muted);
}

.place-fact {
  display: grid;
  margin: 0;
}

.place-fact div {
  display: grid;
  grid-template-columns: 62px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--line);
}

.place-fact dt {
  margin: 0;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--faint);
}

.place-fact dd {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink);
}

.place-side-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin-top: 14px;
  padding: 12px;
  background: var(--ink);
  color: var(--paper);
  font-size: 14px;
  font-weight: 700;
  transition: background 0.2s ease;
}

.place-side-card__cta:hover {
  background: #2c261d;
}

.place-source-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.place-source-list li {
  position: relative;
  padding-left: 14px;
  font-size: 12.5px;
  line-height: 1.5;
  font-weight: 600;
}

.place-source-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent-2);
}

.place-source-list a {
  color: var(--muted);
}

.place-source-list a:hover {
  color: var(--accent);
}

.place-source-list__image {
  margin: 10px 0 0;
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--faint);
}

.place-detail__related {
  margin-top: 8px;
  padding-top: 32px;
  border-top: 2px solid var(--ink);
}

.place-detail__related > h2 {
  margin: 0 0 24px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.7rem;
  color: var(--ink);
}

.place-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 22px;
}
/* ============================================================= */
/* 가이드 상세 — 에디토리얼 (다크 히어로 + 번호 단계) (Stage B)      */
/* ============================================================= */
.guide-detail__hero {
  background: var(--ink);
  color: var(--paper);
}

.guide-detail__hero-inner {
  width: min(900px, calc(100% - 48px));
  margin-inline: auto;
  padding: 34px 0 56px;
  text-align: center;
}

.guide-detail__hero .breadcrumbs {
  margin: 0 0 6px;
}

.guide-detail__hero .breadcrumbs ol {
  justify-content: center;
}

.guide-detail__kicker {
  margin: 30px 0 0;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  color: var(--ink-kicker);
}

.guide-detail__title {
  margin: 18px 0 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.1rem, 4.4vw, 3.7rem);
  line-height: 1.12;
  color: var(--paper);
}

.guide-detail__summary {
  margin: 22px auto 0;
  max-width: 32em;
  font-family: var(--serif-body);
  font-size: 1.18rem;
  line-height: 1.85;
  color: rgba(243, 236, 225, 0.82);
}

.guide-detail__meta {
  margin: 24px 0 0;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  color: rgba(243, 236, 225, 0.55);
}

.guide-detail__cover-wrap {
  width: min(900px, calc(100% - 48px));
  margin-inline: auto;
  padding-bottom: 40px;
}

.guide-detail__cover {
  position: relative;
  z-index: 1;
  margin-top: -32px;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--line);
  background: repeating-linear-gradient(135deg, #e6dbc7 0 15px, #e0d4bd 15px 30px);
}

.guide-detail__cover .image-credit {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 3;
  margin: 0;
}

.guide-detail__article {
  width: min(720px, calc(100% - 48px));
  margin-inline: auto;
  padding: 28px 0 80px;
}

.guide-detail__article .guide-lead {
  margin: 0 0 26px;
  font-size: 1.18rem;
  line-height: 1.98;
  color: var(--text-strong);
}

.guide-detail__article .guide-body p {
  margin: 0 0 18px;
  font-size: 1.14rem;
  line-height: 1.95;
  color: var(--text-strong);
}

/* 코스에 담긴 장소 — 번호 단계 */
.guide-detail__steps-title {
  margin: 30px 0 16px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.6rem;
  color: var(--ink);
}

.guide-step {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  padding: 18px 0;
  border-top: 1px solid var(--line);
}

.guide-step__no {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-pill);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--mono);
  font-size: 13px;
}

.guide-step__body {
  min-width: 0;
}

.guide-step__body h3 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.25;
  color: var(--ink);
}

.guide-step__body p {
  margin: 8px 0 0;
  font-family: var(--serif-body);
  font-size: 1.04rem;
  line-height: 1.75;
  color: var(--text-lead);
}

.guide-step__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--accent-2);
  transition: color 0.18s ease;
}

.guide-step__link:hover {
  color: var(--accent);
}

/* 닫는 인용 */
.guide-detail__quote {
  margin: 30px 0 0;
  padding: 4px 0 4px 26px;
  border-left: 3px solid var(--accent);
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.45rem;
  line-height: 1.5;
  color: var(--ink);
}

/* FAQ / 출처 / 액션 */
.guide-detail__faq,
.guide-detail__sources {
  margin-top: 40px;
}

.guide-detail__faq-title,
.guide-detail__sources-title {
  margin: 0 0 14px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.6rem;
  color: var(--ink);
}

.guide-detail__sources-note {
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--muted);
}

.guide-detail__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 40px;
}

/* 관련 가이드 */
.guide-detail__related-title {
  margin: 0 0 24px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.55rem, 3vw, 2.35rem);
  line-height: 1.18;
  color: var(--ink);
}

.guide-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
/* ============================================================= */
/* 동선 상세 — 에디토리얼 (다크 히어로 + 메타 칩 + 번호 단계) (Stage B) */
/* (운영판 chrome: .collection-detail-board/.collection-checklist/    */
/*  .collection-copy-tools 는 Stage A 스킨 유지)                      */
/* ============================================================= */
.coll-hero {
  background: var(--ink);
  color: var(--paper);
}

.coll-hero__inner {
  width: min(900px, calc(100% - 48px));
  margin-inline: auto;
  padding: 34px 0 50px;
}

.coll-hero .breadcrumbs {
  margin: 0 0 6px;
}

.coll-hero__kicker {
  margin: 28px 0 0;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  color: var(--ink-kicker);
}

.coll-hero__title {
  margin: 16px 0 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.1rem, 4.4vw, 3.6rem);
  line-height: 1.1;
  color: var(--paper);
}

.coll-hero__summary {
  margin: 18px 0 0;
  max-width: 34em;
  font-family: var(--serif-body);
  font-size: 1.16rem;
  line-height: 1.8;
  color: rgba(243, 236, 225, 0.82);
}

.coll-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}

.coll-hero__chips span {
  padding: 7px 12px;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--radius-pill);
  font-family: var(--mono);
  font-size: 11.5px;
  color: var(--paper);
}

/* 단일 칼럼 본문 */
.coll-body {
  width: min(820px, calc(100% - 48px));
  margin-inline: auto;
  padding: 40px 0 80px;
}

/* 번호 단계 — 단계별 동선 */
.coll-steps__title {
  margin: 0 0 20px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.7rem;
  color: var(--ink);
}

.coll-step {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  padding: 22px 0;
  border-top: 1px solid var(--line);
}

.coll-step__no {
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: var(--radius-pill);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--mono);
  font-size: 13px;
}

.coll-step__body {
  flex: 1 1 auto;
  min-width: 0;
}

.coll-step__label {
  display: inline-block;
  padding: 4px 9px;
  border-radius: var(--radius-pill);
  background: var(--surface-strong);
  color: var(--accent-2);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
}

.coll-step__body h3 {
  margin: 10px 0 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.25;
  color: var(--ink);
}

.coll-step__desc {
  margin: 8px 0 0;
  font-family: var(--serif-body);
  font-size: 1.04rem;
  line-height: 1.75;
  color: var(--text-strong);
}

.coll-step__tip {
  margin: 8px 0 0;
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted);
}

.coll-step .collection-step-brief {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}

.coll-step .collection-step-brief span {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--faint);
}

.coll-step__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--accent-2);
  transition: color 0.18s ease;
}

.coll-step__link:hover {
  color: var(--accent);
}

/* 본문 내 보조 블록 간격 + 액션 */
.coll-body > .section.compact,
.coll-body > .collection-detail-board,
.coll-body > .collection-checklist,
.coll-body > .collection-copy-tools,
.coll-body > .coll-actions,
.coll-body > .source-disclosure {
  margin-top: 36px;
}

.coll-toolkit__title {
  margin: 0 0 12px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.3rem;
  color: var(--ink);
}

.coll-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

/* 관련 동선 */
.coll-related__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
}
/* ============================================================= */
/* 목록 공통 에디토리얼 헤더 + 가이드 번호 행 + 자치구 타일 (Stage B) */
/* ============================================================= */
.list-hero {
  padding-block: 52px 30px;
}

.list-hero .breadcrumbs {
  margin: 0 0 16px;
  color: var(--muted);
  font-weight: 600;
}

.list-hero .breadcrumbs span {
  color: var(--ink);
}

.list-hero .breadcrumbs a:hover {
  color: var(--accent);
}

.list-hero__kicker {
  margin: 0 0 14px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--accent);
}

.list-hero__title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2.4rem, 4.6vw, 4.2rem);
  line-height: 1.05;
  max-width: 14em;
  color: var(--ink);
}

.list-hero__lead {
  margin: 20px 0 0;
  max-width: 36em;
  font-family: var(--serif-body);
  font-size: 1.08rem;
  line-height: 1.8;
  color: var(--text-lead);
}

.list-hero__link {
  margin: 16px 0 0;
}

.list-body {
  padding-block: 8px 76px;
}

/* 가이드 — 번호 행 리스트 */
.guide-row {
  display: flex;
  flex-wrap: wrap;
  gap: 18px 30px;
  align-items: center;
  padding: 30px 0;
  border-top: 1px solid var(--line);
}

.guide-row__no {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 3rem;
  line-height: 1;
  color: var(--accent);
}

.guide-row__text {
  flex: 1 1 320px;
  min-width: 0;
}

.guide-row__kicker {
  margin: 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--accent-2);
}

.guide-row__title {
  margin: 9px 0 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.5rem, 2.6vw, 2.1rem);
  line-height: 1.2;
  color: var(--ink);
  transition: color 0.18s ease;
}

.guide-row:hover .guide-row__title {
  color: var(--accent);
}

.guide-row__summary {
  margin: 12px 0 0;
  max-width: 42em;
  font-family: var(--serif-body);
  font-size: 1.04rem;
  line-height: 1.75;
  color: var(--text-lead);
}

.guide-row__thumb {
  position: relative;
  flex: 1 1 200px;
  max-width: 320px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid var(--line);
  background: repeating-linear-gradient(135deg, #e6dbc7 0 12px, #e0d4bd 12px 24px);
}

.guide-row__thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.guide-row:hover .guide-row__thumb img {
  transform: scale(1.03);
}

.guide-row__thumb .image-credit {
  position: absolute;
  right: 8px;
  bottom: 8px;
  z-index: 2;
  margin: 0;
}

/* 자치구 — 타일 그리드 */
.dlist {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}

.dlist-tile {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 120px;
  padding: 22px;
  border: 1px solid var(--line);
  background: var(--card);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.dlist-tile:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: var(--shadow-card);
}

.dlist-tile strong {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.4rem;
  color: var(--ink);
}

.dlist-tile span {
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted);
}
/* 목록 다크 히어로 변형 (장소 목록) + 필터 카드 래퍼 */
.list-hero--dark {
  background: var(--ink);
  color: var(--paper);
}

.list-hero--dark .breadcrumbs {
  color: rgba(243, 236, 225, 0.72);
}

.list-hero--dark .breadcrumbs span {
  color: var(--paper);
}

.list-hero--dark .breadcrumbs a:hover {
  color: var(--ink-kicker);
}

.list-hero--dark .list-hero__kicker {
  color: var(--ink-kicker);
}

.list-hero--dark .list-hero__title {
  color: var(--paper);
}

.list-hero--dark .list-hero__lead {
  color: rgba(243, 236, 225, 0.82);
}

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

/* 행사 목록 — 대표 카드 그리드 + 이번 주 행 리스트 (목업 §8) */
.evt-feature {
  margin-top: 34px;
}

.evt-feature .home-place-grid {
  margin-top: 16px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.evt-feature__kicker {
  margin: 0;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--accent-2);
}

.evt-feature-card {
  display: flex;
  flex-direction: column;
  background: var(--card);
  border: 1px solid var(--line);
  text-decoration: none;
  color: inherit;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.evt-feature-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
  border-color: var(--accent);
}

.evt-feature-card__media {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  background: repeating-linear-gradient(135deg, #e6dbc7 0 12px, #e0d4bd 12px 24px);
}

.evt-feature-card__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.evt-feature-card:hover .evt-feature-card__media img {
  transform: scale(1.03);
}

.evt-feature-card__cat {
  position: absolute;
  left: 12px;
  top: 12px;
  z-index: 3;
  padding: 5px 9px;
  background: rgba(255, 253, 248, 0.92);
  border: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  color: var(--accent-2);
}

.evt-feature-card__media .image-credit {
  position: absolute;
  right: 8px;
  bottom: 8px;
  z-index: 3;
  margin: 0;
}

.evt-feature-card__body {
  display: grid;
  align-content: start;
  gap: 7px;
  padding: 18px;
}

.evt-feature-card__district {
  margin: 0;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--faint);
}

.evt-feature-card__body h3 {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.32rem;
  line-height: 1.25;
  color: var(--ink);
}

.evt-feature-card__dek {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--muted);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.evt-feature-card__price {
  margin: 3px 0 0;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--accent-2);
}

.evt-list {
  margin-top: 44px;
}

.evt-list__head {
  margin: 0;
  padding-bottom: 18px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.7rem;
  line-height: 1.2;
  color: var(--ink);
  border-bottom: 2px solid var(--ink);
}

.evt-row {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  text-decoration: none;
  color: inherit;
  transition: background 0.18s ease;
}

.evt-row:hover {
  background: var(--band);
}

.evt-row__date {
  font-family: var(--mono);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--accent);
}

.evt-row__main {
  min-width: 0;
}

.evt-row__title {
  display: block;
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.18rem;
  line-height: 1.3;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color 0.18s ease;
}

.evt-row:hover .evt-row__title {
  color: var(--accent);
}

.evt-row__meta {
  display: block;
  margin-top: 5px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--muted);
}

.evt-row__price {
  max-width: 220px;
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  text-align: right;
}

.evt-source-note {
  margin: 18px 0 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.02em;
  color: var(--faint);
}

/* 검색 — 에디토리얼 히어로 (목업 §10): 운영판 chrome·런타임은 보존, 히어로만 재스킨 */
.search-hero {
  padding-block: 52px 4px;
}

.search-hero__inner {
  width: min(900px, calc(100% - 48px));
  margin-inline: auto;
}

.search-hero .breadcrumbs {
  margin: 0 0 16px;
  color: var(--muted);
  font-weight: 600;
}

.search-hero .breadcrumbs span {
  color: var(--ink);
}

.search-hero .breadcrumbs a:hover {
  color: var(--accent);
}

.search-hero__kicker {
  margin: 0 0 16px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--accent);
}

.search-hero__title {
  margin: 0 0 26px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(2rem, 3.6vw, 3.2rem);
  line-height: 1.1;
  color: var(--ink);
}

.search-hero .search-box {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 6px 6px 22px;
  border: 2px solid var(--ink);
  border-radius: 0;
  background: var(--card);
  box-shadow: none;
}

.search-hero .search-box::before {
  content: "⌕";
  font-size: 22px;
  line-height: 1;
  color: var(--muted);
}

.search-hero .search-box input {
  padding: 14px 0;
  font-family: var(--serif);
  font-size: 1.4rem;
  color: var(--ink);
}

.search-hero .search-box button {
  flex: none;
  padding: 12px 18px;
  border-radius: 0;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  transition: background 0.2s ease;
}

.search-hero .search-box button:hover {
  background: var(--accent);
}

