.gg-hero-card {
  margin: 56px 0;
  background: var(--paper-1);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
  box-shadow: none;
}

.gg-hero-card .gg-container {
  padding: 32px 20px;
}

.gg-sub {
  max-width: 75ch;
  color: var(--ink-1);
  font-size: var(--type-body-size);
  line-height: var(--type-body-line);
}

.gg-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 12px;
}

.btn {
  display: inline-block;
  padding: .65rem 1rem;
  border: 1px solid var(--rule);
  border-radius: 4px;
  text-decoration: none;
  line-height: 1;
}

.btn-primary {
  background: var(--accent-forest);
  border-color: var(--accent-forest);
  color: #fff;
}

.btn-secondary {
  border-color: var(--rule);
  color: var(--ink-0);
  background: var(--paper-1);
}

.btn-tertiary {
  color: var(--accent-slate);
  text-decoration: underline;
  background: transparent;
}

@media (max-width: 768px) {
  .gg-hero-card {
    margin: 40px 0;
  }

  .gg-cta-row {
    flex-direction: column;
    align-items: flex-start;
  }
}

.gg-trust-band {
  border-top: 1px solid var(--rule);
  padding: 16px 0;
}

.gg-badges {
  list-style: none;
  display: flex;
  gap: .5rem;
  padding: 0;
  margin: .5rem 0;
}

.gg-badges li {
  border: 1px solid var(--rule);
  padding: .25rem .5rem;
  border-radius: 2px;
  background: var(--paper-1);
}

.gg-hash code {
  background: var(--paper-1);
  padding: .125rem .25rem;
  border: 1px solid var(--rule);
  border-radius: 2px;
}

/* Shared Reading Room rhythm for home + related archive pages. */
body.gg-reading-room .entry-content,
body.gg-reading-room .gg-container {
  max-width: var(--reading-room-max);
  margin-inline: auto;
}

body.gg-reading-room:not(.home) .entry-content > :where(section, .wp-block-group, .wp-block-columns, .wp-block-kadence-rowlayout):not(:first-child) {
  border-top: 1px solid var(--rule);
  margin-top: var(--reading-room-stack);
  padding-top: var(--reading-room-stack);
}

body.gg-reading-room :is(.gg-section-label, .gg-home-shelf__label) {
  border-bottom: 1px solid var(--rule);
  color: var(--ink-1);
  display: inline-block;
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  font-variant-caps: all-small-caps;
  letter-spacing: .09em;
  margin: 0 0 .35rem;
  padding-bottom: .15rem;
  text-transform: uppercase;
}

body.gg-reading-room :is(.gg-section-title, .gg-home-shelf__heading) {
  border-bottom: var(--catalog-rule-width) solid var(--rule);
  font-size: var(--type-section-size);
  line-height: var(--type-section-line);
  margin: 0 0 .8rem;
  padding-bottom: .4rem;
}

/* Keep plugin glass wrappers archival without editing plugin files. */
.gg-glass-panel,
.ggfc-modal {
  --gg-blur-amount: 0px;
  --gg-surface-glass: var(--paper-1);
  --gg-surface-glass-2: var(--paper-1);
  --gg-border-glass: var(--rule);
  --gg-border-glass-strong: var(--rule);
  --gg-shadow-depth: none;
}

/* Not color-only: status must pair with text. */
[data-status]::before {
  display: inline-block;
  content: '';
  width: .6rem;
  height: .6rem;
  border-radius: 50%;
  margin-right: .4rem;
  vertical-align: middle;
  background: currentColor;
}

[data-status] {
  color: var(--ink-1);
}

/*
 * Card base variant: index card (plain archival card).
 * Ledger style is applied by modifier class.
 */
.gg-library-child .lc-library-card {
  --card-paper: var(--paper-1);
  --card-ink: var(--ink-0);
  --card-muted: var(--ink-1);
  --card-rule: var(--rule);
  --card-line-step: 1.6rem;

  background: var(--card-paper);
  border: var(--catalog-rule-width) solid var(--card-rule);
  border-radius: var(--catalog-radius);
  box-shadow: none;
  color: var(--card-ink);
  font-size: var(--type-body-size);
  line-height: var(--card-line-step);
  margin: 0;
  max-width: none;
  overflow: visible;
  padding: var(--catalog-space-3) var(--catalog-space-4);
  width: 100%;
}

.gg-library-child .lc-library-card::before {
  display: none;
}

.gg-library-child .lc-library-card-header {
  border-bottom: var(--catalog-rule-width) solid var(--card-rule);
  margin: 0 0 var(--catalog-space-2);
  padding: 0 0 var(--catalog-space-1);
}

.gg-library-child .lc-library-card-title {
  color: var(--card-ink);
  font-family: var(--gg-font-header);
  font-size: var(--type-item-size);
  font-weight: 600;
  letter-spacing: .01em;
  line-height: var(--type-item-line);
  margin: 0;
  overflow-wrap: anywhere;
  text-transform: none;
}

.gg-library-child .lc-library-card-row {
  display: grid;
  gap: var(--catalog-space-2);
  grid-template-columns: minmax(88px, 118px) 1fr;
  margin: 0;
  min-height: var(--card-line-step);
  padding: 0;
}

.gg-library-child .lc-library-card-label {
  color: var(--card-muted);
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  letter-spacing: .06em;
  line-height: var(--card-line-step);
  text-transform: uppercase;
}

.gg-library-child .lc-library-card-value {
  color: var(--card-ink);
  font-size: var(--type-body-size);
  line-height: var(--card-line-step);
  overflow-wrap: anywhere;
}

.gg-library-child .lc-library-card-hash-container {
  border-top: var(--catalog-rule-width) dashed var(--card-rule);
  margin-top: var(--catalog-space-1);
  padding-top: var(--catalog-space-1);
}

.gg-library-child .lc-library-card-hash-label {
  color: var(--card-muted);
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  letter-spacing: .05em;
  line-height: var(--card-line-step);
  margin: 0;
}

.gg-library-child .lc-library-card-hash-value {
  background: transparent;
  border: var(--catalog-rule-width) solid var(--card-rule);
  border-radius: var(--catalog-radius);
  color: var(--card-ink);
  display: inline-block;
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  line-height: var(--type-meta-line);
  max-inline-size: 100%;
  overflow-wrap: anywhere;
  padding: 0 var(--catalog-space-1);
}

.gg-library-child .lc-copy-hash-btn {
  background: transparent;
  border: var(--catalog-rule-width) solid var(--card-rule);
  border-radius: var(--catalog-radius);
  color: var(--card-ink);
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  line-height: var(--type-meta-line);
}

.gg-library-child .lc-library-card-footer {
  margin-top: var(--catalog-space-2);
  text-align: left;
}

.gg-library-child .lc-library-card-link {
  color: var(--accent-slate);
  text-decoration: underline;
  text-underline-offset: var(--catalog-link-offset);
}

.gg-library-child .lc-library-card-link:visited {
  color: var(--accent-brick);
}

.gg-library-child .lc-library-card-link:hover {
  color: var(--accent-forest);
}

.gg-library-child .lc-library-card :is(a, button):focus-visible,
.gg-library-child .lc-copy-hash-btn:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

.gg-library-child .lc-card-deco-line {
  background: var(--card-rule);
  height: var(--catalog-rule-width);
  margin: var(--catalog-space-2) 0 0;
}

.gg-library-child .lc-library-card.lc-card--ledger,
.gg-library-child .lc-library-card[data-card-variant="ledger"] {
  --ledger-paper: #F5E7B6;
  --ledger-rule: rgba(67, 92, 133, 0.34);
  --ledger-margin-rule: rgba(179, 93, 93, 0.56);
  --ledger-margin-x: 2.05rem;
  --ledger-line-offset: .42rem;
  --card-ink: #272117;
  --card-muted: #5E553F;
  --card-rule: #A08D58;
  --card-line-step: 1.7rem;

  background-color: var(--ledger-paper);
  background-image:
    linear-gradient(
      to right,
      transparent var(--ledger-margin-x),
      var(--ledger-margin-rule) var(--ledger-margin-x),
      var(--ledger-margin-rule) calc(var(--ledger-margin-x) + 0.07rem),
      transparent calc(var(--ledger-margin-x) + 0.07rem)
    ),
    repeating-linear-gradient(
      to bottom,
      transparent 0,
      transparent calc(var(--card-line-step) - 1px),
      var(--ledger-rule) calc(var(--card-line-step) - 1px),
      var(--ledger-rule) var(--card-line-step)
    );
  background-position: 0 var(--ledger-line-offset), 0 var(--ledger-line-offset);
  padding-left: 2.65rem;
  padding-top: calc(var(--catalog-space-3) + var(--ledger-line-offset));
}

/* Keep ledger text aligned with ruled-slip baselines for readability. */
.gg-library-child .lc-library-card.lc-card--ledger :is(.lc-library-card-label, .lc-library-card-value),
.gg-library-child .lc-library-card[data-card-variant="ledger"] :is(.lc-library-card-label, .lc-library-card-value) {
  line-height: var(--card-line-step);
}

.gg-library-child .lc-library-card.lc-card--index,
.gg-library-child .lc-library-card[data-card-variant="index"] {
  background-image: none;
}

/* Archival list + table system for catalog/index pages. */
.gg-reading-room .gg-record-list {
  border-top: var(--catalog-rule-width) solid var(--rule);
  list-style: none;
  margin: 0;
  padding: 0;
}

.gg-reading-room .gg-record-list > li {
  border-bottom: var(--catalog-rule-width) solid var(--rule);
  display: grid;
  gap: var(--catalog-space-1);
  padding: var(--catalog-space-2) 0;
}

.gg-reading-room .gg-record-meta {
  color: var(--ink-1);
  display: block;
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  letter-spacing: .04em;
  line-height: var(--type-meta-line);
  margin-top: var(--catalog-space-1);
  overflow-wrap: anywhere;
}

.gg-reading-room .gg-record-table {
  background: var(--paper-1);
  border: var(--catalog-rule-width) solid var(--rule);
  border-collapse: collapse;
  color: var(--ink-0);
  inline-size: 100%;
  table-layout: fixed;
}

.gg-reading-room .gg-record-table caption {
  color: var(--ink-1);
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  letter-spacing: .06em;
  line-height: var(--type-meta-line);
  margin-bottom: .35rem;
  text-align: left;
  text-transform: uppercase;
}

.gg-reading-room .gg-record-table :is(th, td) {
  border-bottom: var(--catalog-rule-width) solid var(--rule);
  overflow-wrap: anywhere;
  padding: var(--catalog-space-2) var(--catalog-space-3);
  vertical-align: top;
}

.gg-reading-room .gg-record-table thead th {
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  letter-spacing: .06em;
  line-height: var(--type-meta-line);
  text-align: left;
  text-transform: uppercase;
}

.gg-reading-room .gg-record-table tbody tr:last-child :is(th, td) {
  border-bottom: 0;
}

.gg-reading-room .gg-record-table tbody tr:focus-within {
  background: var(--catalog-hover-bg);
  outline: var(--catalog-rule-strong) solid var(--focus-ring);
  outline-offset: -2px;
}

.gg-reading-room .gg-record-table :is(code, .hash, [data-record-hash]) {
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  line-height: var(--type-meta-line);
}

.gg-reading-room .gg-empty-state {
  background: var(--paper-1);
  border: var(--catalog-rule-width) dashed var(--rule);
  color: var(--ink-1);
  line-height: var(--type-body-line);
  margin: var(--catalog-space-2) 0;
  max-inline-size: 72ch;
  padding: var(--catalog-space-3) var(--catalog-space-4);
}

.gg-reading-room .gg-empty-state :is(p, ul, ol) {
  margin: 0;
}

.gg-reading-room .gg-empty-state strong {
  color: var(--ink-0);
}

.gg-reading-room .gg-record-list > li:focus-within {
  background: var(--catalog-hover-bg);
  outline: var(--catalog-rule-strong) solid var(--focus-ring);
  outline-offset: 2px;
}

.gg-reading-room :is(.lc-library-card-link, .gg-record-list a, .gg-record-table a, .ggfc-modal a, .ggfc-modal-link) {
  color: var(--accent-slate);
  text-decoration: underline;
  text-underline-offset: var(--catalog-link-offset);
}

.gg-reading-room :is(.lc-library-card-link, .gg-record-list a, .gg-record-table a, .ggfc-modal a, .ggfc-modal-link):visited {
  color: var(--accent-brick);
}

.gg-reading-room :is(.lc-library-card-link, .gg-record-list a, .gg-record-table a, .ggfc-modal a, .ggfc-modal-link):hover {
  color: var(--accent-forest);
}

.gg-reading-room :is(.lc-library-card-link, .gg-record-list a, .gg-record-table a, .ggfc-modal a, .ggfc-modal-link):focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

/* Home-only draft module treatment */
.home {
  background: var(--paper-0);
}

.home .gg-home-shelf {
  margin: 1.8rem 0;
  padding-bottom: .25rem;
  padding-top: .75rem;
  border-top: 1px solid var(--rule);
}

.home .gg-home-shelf__label {
  margin: 0 0 .35rem;
}

.home .gg-home-shelf__heading {
  margin: 0 0 .8rem;
  font-size: var(--type-section-size);
  line-height: var(--type-section-line);
}

.home .gg-home-shelf__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.home .gg-hero-card,
.home .gg-trust-band {
  background: var(--paper-1);
  border: 1px solid var(--rule);
  border-radius: var(--radius);
}

.home .gg-trust-band {
  padding: 16px;
}

.home :is(.library-card, .ggrr-card) {
  background: var(--paper-1);
  border: 1px solid var(--rule);
  border-radius: 2px;
  box-shadow: none;
}

@media (max-width: 1024px) {
  .home .gg-home-shelf__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .home .gg-home-shelf__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 640px) {
  .gg-library-child .lc-library-card-row {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .gg-library-child .lc-library-card.lc-card--ledger,
  .gg-library-child .lc-library-card[data-card-variant="ledger"] {
    --ledger-margin-x: 1.2rem;
    padding-left: 1.65rem;
  }
}

/* Calendar archival skin from child theme only */
.gg-fullcalendar {
  background: var(--paper-1);
  border: 1px solid var(--rule);
  border-radius: 2px;
  color: var(--ink-0);
  padding: 1rem;
}

.gg-fullcalendar .fc {
  --fc-border-color: var(--rule);
  --fc-button-bg-color: var(--paper-1);
  --fc-button-border-color: var(--rule);
  --fc-button-text-color: var(--ink-0);
  --fc-button-hover-bg-color: #EEE7D7;
  --fc-button-active-bg-color: #E4DCC8;
  --fc-today-bg-color: rgba(48, 75, 93, 0.08);
  --fc-event-bg-color: var(--paper-1);
  --fc-event-border-color: var(--rule);
  --fc-list-event-hover-bg-color: #EEE7D7;
  color: var(--ink-0);
}

.gg-fullcalendar .fc-header-toolbar {
  margin-bottom: 1rem !important;
  padding: .75rem;
  border: 1px solid var(--rule);
  border-radius: 2px;
  background: var(--paper-1);
  gap: .45rem .65rem;
}

.gg-fullcalendar .fc .fc-toolbar-title {
  font-family: var(--gg-font-header);
  font-size: var(--type-section-size);
  line-height: var(--type-section-line);
}

.gg-fullcalendar .fc .fc-toolbar-chunk {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}

.gg-fullcalendar .fc .fc-button {
  border-radius: 2px;
  font-size: var(--type-meta-size);
  line-height: var(--type-meta-line);
  text-transform: none;
  font-family: var(--gg-font-header);
  transition: background-color var(--motion-fast) ease, color var(--motion-fast) ease;
}

.gg-fullcalendar .fc .fc-button:focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
  box-shadow: none !important;
}

.gg-fullcalendar .fc :is(.fc-col-header-cell-cushion, .fc-daygrid-day-number) {
  color: var(--ink-0);
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  letter-spacing: .05em;
  line-height: var(--type-meta-line);
  text-decoration: none;
  text-transform: uppercase;
}

.gg-fullcalendar .fc-daygrid-day-top {
  padding: .2rem .25rem;
}

.gg-fullcalendar .fc-event {
  background: var(--paper-1) !important;
  border: 1px solid var(--rule) !important;
  border-left-width: 3px !important;
  border-radius: 0 !important;
  color: var(--ink-0) !important;
  box-shadow: none !important;
  line-height: var(--type-item-line);
  padding: .15rem .25rem !important;
  transition: background-color var(--motion-fast) ease, color var(--motion-fast) ease;
}

.gg-fullcalendar .fc-event:hover {
  background: #EEE7D7 !important;
  text-decoration: underline;
}

.gg-fullcalendar .fc-event:focus-visible,
.gg-fullcalendar .fc-event.fc-event-selected {
  outline: 3px solid var(--focus-ring) !important;
  outline-offset: 1px;
}

.gg-fullcalendar .fc-event-title {
  font-size: clamp(.85rem, 1.2vw, .95rem);
  line-height: var(--type-item-line);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.gg-fullcalendar .fc-event-time {
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  line-height: var(--type-meta-line);
}

.gg-fullcalendar .fc-daygrid-event .fc-event-title {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.gg-fullcalendar .fc-timegrid-event .fc-event-main {
  padding: .2rem .3rem;
}

.gg-fullcalendar :is(.fc-col-header-cell-cushion, .fc-daygrid-day-number, .fc-more-link):focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

.gg-fullcalendar .fc :is(
  .fc-prev-button,
  .fc-next-button,
  .fc-today-button,
  .fc-dayGridMonth-button,
  .fc-timeGridWeek-button,
  .fc-timeGridDay-button,
  .fc-listWeek-button,
  .fc-event,
  .fc-more-link
):focus-visible {
  outline: 3px solid var(--focus-ring) !important;
  outline-offset: 2px;
  box-shadow: none !important;
}

.gg-fullcalendar .fc-popover,
.gg-fullcalendar .fc-theme-standard .fc-popover-header {
  background: var(--paper-1);
  border-color: var(--rule);
}

.gg-fullcalendar .ggfc-event-source-label,
.gg-fullcalendar .ggfc-event-jurisdiction-label {
  line-height: var(--type-item-line);
  opacity: 1;
}

/* Calendar event details: archival card panel */
.gg-reading-room .ggfc-modal-overlay {
  background: rgba(30, 27, 23, 0.64);
  padding: var(--catalog-space-5);
}

.gg-reading-room .ggfc-modal {
  background: var(--paper-1);
  border: var(--catalog-rule-width) solid var(--rule);
  border-radius: var(--catalog-radius);
  box-shadow: none;
  color: var(--ink-0);
  max-height: 90vh;
  overflow-y: auto;
  padding: var(--catalog-space-5);
  width: min(42rem, 100%);
}

.gg-reading-room .ggfc-modal-title {
  border-bottom: var(--catalog-rule-width) solid var(--rule);
  color: var(--ink-0);
  font-family: var(--gg-font-header);
  font-size: var(--type-item-size);
  line-height: var(--type-item-line);
  margin: 0 0 var(--catalog-space-3);
  padding: 0 var(--catalog-space-4) var(--catalog-space-2) 0;
}

.gg-reading-room .ggfc-modal-source {
  color: var(--ink-1);
  font-family: var(--gg-font-mono);
  font-size: var(--type-meta-size);
  letter-spacing: .06em;
  margin: 0 0 var(--catalog-space-2);
  text-transform: uppercase;
}

.gg-reading-room .ggfc-modal-meta {
  background: transparent;
  border: var(--catalog-rule-width) solid var(--rule);
  border-radius: var(--catalog-radius);
  color: var(--ink-0);
  line-height: var(--type-body-line);
  padding: var(--catalog-space-2) var(--catalog-space-3);
}

.gg-reading-room .ggfc-modal-description {
  color: var(--ink-0);
  font-size: var(--type-body-size);
  line-height: var(--type-body-line);
  margin: var(--catalog-space-3) 0;
}

.gg-reading-room .ggfc-modal-hash-container {
  border-top: var(--catalog-rule-width) dashed var(--rule);
  color: var(--ink-1);
  margin-top: var(--catalog-space-3);
  padding-top: var(--catalog-space-3);
}

.gg-reading-room .ggfc-hash-value {
  background: transparent;
  border: var(--catalog-rule-width) solid var(--rule);
  border-radius: var(--catalog-radius);
  color: var(--ink-0);
}

.gg-reading-room .ggfc-copy-hash {
  background: var(--paper-1);
  border: var(--catalog-rule-width) solid var(--rule);
  border-radius: var(--catalog-radius);
  color: var(--ink-0);
  font-family: var(--gg-font-mono);
}

.gg-reading-room .ggfc-modal-actions {
  border-top: var(--catalog-rule-width) solid var(--rule);
  margin-top: var(--catalog-space-3);
  padding-top: var(--catalog-space-2);
}

.gg-reading-room .ggfc-modal-link {
  background: transparent;
  border: var(--catalog-rule-width) solid var(--rule);
  border-radius: var(--catalog-radius);
  display: inline-block;
  font-family: var(--gg-font-header);
  font-size: var(--type-meta-size);
  font-weight: 600;
  line-height: var(--type-meta-line);
  padding: var(--catalog-space-1) var(--catalog-space-3);
}

.gg-reading-room .ggfc-modal-close {
  background: var(--paper-1);
  border: var(--catalog-rule-width) solid var(--rule);
  border-radius: var(--catalog-radius);
  color: var(--ink-0);
  inline-size: 2rem;
  block-size: 2rem;
}

.gg-reading-room .ggfc-modal-close:hover {
  background: var(--catalog-hover-bg);
}

.gg-reading-room .ggfc-modal :is(button, a):focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 2px;
}

@media (max-width: 768px) {
  .gg-fullcalendar .fc-header-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .gg-fullcalendar .fc .fc-toolbar-title {
    font-size: var(--type-item-size);
  }

  .gg-fullcalendar .fc-toolbar-chunk {
    inline-size: 100%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .gg-fullcalendar * {
    animation: none !important;
    transition: none !important;
  }
}
