/* Institutional workspace culture layout — editorial grid, glass overlays */

:root {
  --color-background: #f4f3ee;
  --color-text: #1e232a;
  --color-spruce: #2c423b;
  --color-brass: #c5a059;
  --color-muted: rgba(30, 35, 42, 0.66);
  --color-glass-border: rgba(44, 66, 59, 0.18);
  --color-glass-fill: rgba(244, 243, 238, 0.62);
  --font-primary-serif: 'Libre Baskerville', 'Times New Roman', serif;
  --font-secondary-sans: 'Source Sans 3', system-ui, sans-serif;
  --space-xxs: 0.375rem;
  --space-xs: 0.5rem;
  --space-sm: 0.75rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --shadow-soft: 0 0.5rem 1.5rem rgba(30, 35, 42, 0.08);
  --shadow-card: 0 0.25rem 2rem rgba(30, 35, 42, 0.12);
  --transition-fast: 0.25s ease;
  --max-read: 74rem;
  --banner-min-height: 18rem;
  --photo-max-height: clamp(14rem, 36vw, 22rem);
  --surface-fixed-plain-header-slot: clamp(4.25rem, 11vw, 6rem);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 100%;
  scroll-behavior: smooth;
  overflow-x: hidden;
  scroll-padding-top: calc(var(--surface-fixed-plain-header-slot) + var(--space-sm));
}



body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-secondary-sans);
  color: var(--color-text);
  background-color: var(--color-background);
  line-height: 1.62;
  overflow-x: hidden;
}

body.navigation-panel-open {
  overflow: hidden;
}

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

a {
  color: var(--color-spruce);
  text-decoration-thickness: 0.0625rem;
  text-underline-offset: 0.15em;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible {
  outline: 0.125rem solid var(--color-brass);
  outline-offset: 0.125rem;
}

h1,
h2,
h3 {
  font-family: var(--font-primary-serif);
  line-height: 1.28;
}

p {
  margin: 0 0 var(--space-md);
}

p:last-child {
  margin-bottom: 0;
}

.surface-grid-overlay-body {
  position: relative;
  padding-top: var(--surface-fixed-plain-header-slot);
  background-color: var(--color-background);
  background-image: linear-gradient(
      to right,
      rgba(44, 66, 59, 0.06) 0.0625rem,
      transparent 0.0625rem
    ),
    linear-gradient(
      to bottom,
      rgba(44, 66, 59, 0.055) 0.0625rem,
      transparent 0.0625rem
    );
  background-size: 4rem 100%, 100% 4rem;
}

.skip-link-internal {
  position: absolute;
  left: -999rem;
  top: auto;
  width: 0.0625rem;
  height: 0.0625rem;
  overflow: hidden;
}

.skip-link-internal:focus {
  position: fixed;
  left: var(--space-md);
  top: var(--space-md);
  width: auto;
  height: auto;
  padding: var(--space-sm) var(--space-md);
  background: var(--color-glass-fill);
  border: 0.0625rem solid var(--color-glass-border);
  backdrop-filter: blur(0.625rem);
  z-index: 60;
}

.layout-page-shell-inner {
  width: min(100% - 2rem, var(--max-read));
  margin-inline: auto;
}

.layout-band-wide {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.surface-glass-banner-panel {
  background: var(--color-glass-fill);
  backdrop-filter: blur(0.75rem);
  border: 0.0625rem solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: var(--space-lg);
}

.surface-dossier-paper-stack {
  background: linear-gradient(160deg, #faf9f4 0%, #f1efe7 62%, #e8e4d8 100%);
  border: 0.0625rem solid rgba(44, 66, 59, 0.12);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: var(--space-xl);
}

/* Header -------------------------------------------------------------- */

.surface-header-shell.surface-header-plain {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  box-sizing: border-box;
  z-index: 48;
  background-color: rgba(244, 243, 238, 0.98);
  backdrop-filter: blur(0.5rem);
  -webkit-backdrop-filter: blur(0.5rem);
  border-bottom: 0.0625rem solid rgba(44, 66, 59, 0.15);
  box-shadow: 0 0.125rem 0.75rem rgba(30, 35, 42, 0.08);
}

.surface-header-shell {
  width: 100%;
}

.surface-header-shell:not(.surface-header-plain) {
  position: relative;
  z-index: 30;
}

.surface-header-shell:not(.surface-header-plain) .layout-header-overlay-row {
  position: absolute;
  inset-inline: 0;
  top: var(--space-md);
  pointer-events: none;
}

.surface-header-plain .layout-header-overlay-row {
  position: relative;
  padding-block: var(--space-md);
}

.layout-header-overlay-row .layout-page-shell-inner {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 3fr) auto;
  align-items: center;
  gap: var(--space-md);
  pointer-events: auto;
}

.layout-header-plain .layout-page-shell-inner {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 3fr) auto;
  align-items: center;
  gap: var(--space-md);
}

.header-brand-plain-text {
  font-family: var(--font-primary-serif);
  font-weight: 600;
  font-size: clamp(0.8rem, 2vw, 1.2rem);
  letter-spacing: 0.025em;
  color: var(--color-spruce);
  text-wrap: balance;
}

.layout-inline-navigation-slot {
  display: none;
  justify-self: center;
}

@media (min-width: 1024px) {
  .layout-inline-navigation-slot {
    display: flex;
  }
}

.list-inline-navigation-items {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-sm);
}

.navigation-inline-link-chip {
  display: inline-flex;
  align-items: center;
  padding: var(--space-xs) var(--space-sm);
  border-radius: 999rem;
  background: rgba(244, 243, 238, 0.55);
  border: 0.0625rem solid transparent;
  text-decoration: none;
  font-size: 0.95rem;
  color: var(--color-text);
  transition:
    border-color var(--transition-fast),
    background var(--transition-fast);
}

.navigation-inline-link-chip:hover {
  border-color: var(--color-brass);
  background: rgba(197, 160, 89, 0.12);
}

.navigation-burger-trigger {
  justify-self: end;
  grid-column: 3;
  grid-row: 1;
  pointer-events: auto;
  cursor: pointer;
  border-radius: var(--radius-md);
  padding: var(--space-sm) var(--space-md);
  border: 0.0625rem solid rgba(44, 66, 59, 0.25);
  background: rgba(244, 243, 238, 0.65);
  backdrop-filter: blur(0.875rem);
  display: inline-flex;
  gap: var(--space-sm);
  align-items: center;
  font-family: var(--font-secondary-sans);
  font-size: 0.9375rem;
  color: var(--color-text);
}

@media (min-width: 1024px) {
  .navigation-burger-trigger {
    display: none;
  }
}

.burger-trigger-icon-shape {
  display: inline-grid;
  grid-template-rows: repeat(3, 0.125rem);
  gap: 0.25rem;
  width: 1.625rem;
}

.burger-trigger-icon-shape span {
  display: block;
  height: 0.125rem;
  border-radius: 999rem;
  background: linear-gradient(to right, var(--color-brass), var(--color-spruce));
}

/* Mobile / tablet drawer nav */
.surface-navigation-panel-sheet {
  position: fixed;
  inset: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 120;
}

.surface-navigation-panel-sheet.navigation-panel-visible {
  visibility: visible;
  pointer-events: auto;
}

.navigation-panel-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(30, 35, 42, 0.35);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.surface-navigation-panel-sheet.navigation-panel-visible .navigation-panel-backdrop {
  opacity: 1;
}

.navigation-panel-sheet-card {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: min(92vw, 22rem);
  background: rgba(244, 243, 238, 0.92);
  backdrop-filter: blur(1rem);
  border-left: 0.0625rem solid var(--color-glass-border);
  transform: translateX(100%);
  transition: transform var(--transition-fast);
  display: flex;
  flex-direction: column;
}

.surface-navigation-panel-sheet.navigation-panel-visible .navigation-panel-sheet-card {
  transform: translateX(0);
}

.sheet-card-heading-slot {
  padding: var(--space-lg);
  border-bottom: 0.0625rem solid rgba(44, 66, 59, 0.12);
  font-family: var(--font-primary-serif);
}

.list-navigation-drawer-links {
  list-style: none;
  margin: 0;
  padding: var(--space-lg);
  display: grid;
  gap: 1.5rem;
}

.drawer-navigation-link-row {
  text-decoration: none;
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  border: 0.0625rem solid rgba(44, 66, 59, 0.12);
  background: rgba(255, 255, 255, 0.4);
}

.drawer-navigation-link-row:hover {
  border-color: var(--color-brass);
}

.surface-footer-mini-rail {
  border-top: 0.0625rem solid rgba(44, 66, 59, 0.12);
  padding-block: var(--space-xl);
  margin-top: var(--space-2xl);
  background: linear-gradient(160deg, #fbfaf7, #eae6da);
}

.list-footer-mini-links-row {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs) var(--space-md);
  font-size: 0.9rem;
}

.text-footer-micro-note {
  font-size: 0.85rem;
  color: var(--color-muted);
  margin-top: var(--space-md);
}

/* Hero & banner ------------------------------------------------------- */

.surface-hero-banner-fullviewport {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  overflow: clip;
}

/* Hero backdrop: photographic layer behind typography */
.banner-hero-photo-readability-root {
  position: relative;
  min-height: clamp(26rem, 52vh, 38rem);
  padding-bottom: var(--space-2xl);
}

.banner-hero-cover-photo-holder {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.banner-hero-cover-photo-img-layer {
  width: 100%;
  height: 100%;
  min-height: 18rem;
  object-fit: cover;
  object-position: center;
  display: block;
}

.surface-hero-banner-fullviewport > .banner-hero-readable-scrim-sheet {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    162deg,
    rgba(244, 243, 238, 0.93) 0%,
    rgba(244, 243, 238, 0.78) 38%,
    rgba(244, 243, 238, 0.52) 68%,
    rgba(244, 243, 238, 0.28) 100%
  );
}

.surface-hero-banner-fullviewport > .surface-ambient-gradient-sheen {
  z-index: 1;
}

.surface-hero-banner-fullviewport > .banner-copy-cluster-upper-region {
  position: relative;
  z-index: 3;
}

.banner-stack-vertical-text-before-photo {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  min-height: var(--banner-min-height);
}

.banner-stack-vertical-text-before-photo .banner-photo-slot-below-copy {
  order: 3;
}

.banner-copy-cluster-upper-region {
  order: 1;
  padding: var(--space-2xl) var(--space-md) 0;
}

@media (min-width: 48rem) {
  .banner-copy-cluster-upper-region {
    padding: clamp(7rem, 12vw, 10rem) var(--space-lg) var(--space-sm);
    max-width: min(92%, 44rem);
    margin-inline: auto;
  }
}

.surface-ambient-gradient-sheen {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      circle at 20% -10%,
      rgba(197, 160, 89, 0.18),
      transparent 54%
    ),
    radial-gradient(
      circle at 88% 20%,
      rgba(44, 66, 59, 0.16),
      transparent 52%
    );
  opacity: 0.75;
  z-index: 0;
}

.banner-inner-stack-layered {
  position: relative;
  z-index: 1;
}

.heading-hero-primary-span {
  font-size: clamp(2rem, 1.65rem + 2.2vw, 3.125rem);
  margin: 0 0 var(--space-md);
  color: var(--color-text);
}

.text-hero-leading-sentence {
  font-size: 1.05rem;
  max-width: 36rem;
  color: var(--color-muted);
}

.hero-action-row-soft {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}

.button-primary-soft-spruce {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-lg);
  border-radius: 999rem;
  background: linear-gradient(
    136deg,
    var(--color-spruce),
    #1f2f2a 70%
  );
  color: var(--color-background);
  text-decoration: none;
  border: none;
  cursor: pointer;
  box-shadow: 0 0.25rem 0.875rem rgba(44, 66, 59, 0.22);
}

.button-primary-soft-spruce:hover {
  filter: brightness(1.06);
}

.button-ghost-muted-outline {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: var(--space-sm) var(--space-lg);
  border-radius: 999rem;
  border: 0.0625rem solid rgba(44, 66, 59, 0.28);
  text-decoration: none;
  background: transparent;
}

.banner-photo-slot-below-copy {
  width: 100%;
}

.banner-photo-frame-rounded {
  position: relative;
  border-radius: 0;
  overflow: hidden;
  border-block: 0.0625rem solid rgba(44, 66, 59, 0.12);
  background: #111827;
}

.banner-photo-framed-nonstretch {
  display: block;
  width: 100%;
  max-height: var(--photo-max-height);
  object-fit: cover;
  margin: 0 auto;
}

/* Sections ------------------------------------------------------------ */

.surface-main-reading-column {
  padding-block-start: clamp(1rem, 2vw + 0.5rem, 2rem);
  padding-block-end: clamp(2rem, 3vw + 2rem, 5rem);
}

.section-editorial-split-row {
  display: grid;
  gap: var(--space-xl);
  align-items: start;
}

@media (min-width: 60rem) {
  .section-editorial-split-row {
    grid-template-columns: minmax(0, 38%) minmax(0, 62%);
    column-gap: var(--space-2xl);
  }

  .section-editorial-reverse-on-wide {
    direction: rtl;
  }

  .section-editorial-reverse-on-wide > * {
    direction: ltr;
  }
}

.surface-section-marker-index {
  display: inline-flex;
  gap: var(--space-sm);
  align-items: center;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.section-marker-bullet-bar {
  width: 3rem;
  height: 0.0625rem;
  background: linear-gradient(to right, var(--color-brass), transparent);
}

.heading-secondary-section-span {
  font-size: clamp(1.6rem, 1.38rem + 0.95vw, 2.185rem);
  margin: var(--space-sm) 0 var(--space-md);
}

.badge-neutral-tag-pill {
  display: inline-flex;
  align-items: center;
  padding: var(--space-xxs) var(--space-sm);
  border-radius: 999rem;
  background: rgba(44, 66, 59, 0.08);
  font-size: 0.7625rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.grid-asymmetric-pillar-board {
  display: grid;
  gap: var(--space-md);
}

@media (min-width: 40rem) {
  .grid-asymmetric-pillar-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.surface-pillar-mini-card-frame {
  border-radius: var(--radius-lg);
  border: 0.0625rem solid rgba(44, 66, 59, 0.16);
  background: rgba(255, 255, 255, 0.5);
  padding: var(--space-lg);
}

.pillar-miniheading-serif {
  font-family: var(--font-primary-serif);
  font-size: 1.1rem;
  margin-bottom: var(--space-sm);
}

/* Matrix -------------------------------------------------------------- */

.surface-matrix-analytical-pane {
  border-radius: var(--radius-lg);
  border: 0.0625rem dashed rgba(44, 66, 59, 0.38);
  background: radial-gradient(circle at 50% -10%, rgba(197, 160, 89, 0.16), transparent 62%),
    rgba(244, 243, 238, 0.86);
  padding: var(--space-xl);
  box-shadow: var(--shadow-soft);
}

.matrix-shift-variant-async {
  border-image: linear-gradient(to right bottom, rgba(197, 160, 89, 0.8), transparent) 1;
}

.matrix-shift-variant-guard {
  border-image: linear-gradient(to left top, rgba(44, 66, 59, 0.8), transparent) 1;
}

.matrix-shift-variant-dense {
  box-shadow:
    var(--shadow-soft),
    inset 0 0 3rem rgba(44, 66, 59, 0.08);
}

.matrix-control-grid-layout {
  display: grid;
  gap: var(--space-lg);
}

@media (min-width: 48rem) {
  .matrix-control-grid-layout {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  }
}

.slider-label-row-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs);
  font-size: 0.9rem;
}

.slider-label-vertical-stack-cover {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-xs);
}

.matrix-fieldset-legend-line {
  width: 100%;
  justify-content: flex-start;
  margin-bottom: var(--space-sm);
}

.visually-contained-hidden-slot {
  position: absolute;
  width: 0.0625rem;
  height: 0.0625rem;
  padding: 0;
  margin: -0.0625rem;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

input[type='range'].matrix-range-input-field {
  width: 100%;
  accent-color: var(--color-spruce);
}

.surface-radio-leadership-matrix {
  display: grid;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}

.radio-row-matrix-option {
  display: flex;
  gap: var(--space-sm);
  align-items: flex-start;
}

.radio-row-matrix-option input {
  margin-top: 0.25rem;
}

.matrix-insight-readout-slot {
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.6);
  border: 0.0625rem solid rgba(44, 66, 59, 0.16);
  padding: var(--space-lg);
  display: grid;
  gap: var(--space-md);
}

.matrix-diagnostic-chip-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.11em;
  color: var(--color-muted);
}

.matrix-insight-body-text {
  color: var(--color-text);
  font-size: 0.98rem;
}

.matrix-secondary-link-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.link-inline-brass-accent {
  text-decoration: underline;
}

/* Comparison table (frameworks) ------------------------------------ */

.surface-comparison-table-shell {
  width: 100%;
  overflow-x: auto;
  border-radius: var(--radius-lg);
}

.table-structure-comparison-sheet {
  width: 100%;
  border-collapse: collapse;
  min-width: 36rem;
  font-size: 0.935rem;
  background: rgba(255, 255, 255, 0.76);
}

.table-structure-comparison-sheet th,
.table-structure-comparison-sheet td {
  border: 0.0625rem solid rgba(44, 66, 59, 0.16);
  padding: var(--space-sm);
  vertical-align: top;
}

.table-structure-comparison-sheet thead th {
  background: rgba(44, 66, 59, 0.08);
  font-family: var(--font-primary-serif);
}

.surface-case-whitepaper-chip {
  display: grid;
  gap: var(--space-lg);
}

.microchart-bar-muted-row {
  display: grid;
  grid-template-columns: 6rem minmax(0, 1fr);
  gap: var(--space-sm);
  align-items: center;
  font-size: 0.86rem;
}

.microchart-neutral-bar-shell {
  position: relative;
  height: 0.5625rem;
  border-radius: 999rem;
  background: rgba(44, 66, 59, 0.09);
}

.microchart-neutral-bar-fill {
  position: absolute;
  inset: 0;
  width: var(--bar-value, 50%);
  background: linear-gradient(to right, var(--color-brass), var(--color-spruce));
  border-radius: inherit;
}

.microchart-neutral-bar-fill.microchart-sample-level-muted-one {
  width: 58%;
}

.microchart-neutral-bar-fill.microchart-sample-level-muted-two {
  width: 71%;
}

.microchart-neutral-bar-fill.microchart-sample-level-muted-three {
  width: 65%;
}

/* Audit form ---------------------------------------------------------- */

.surface-audit-linear-form-sheet {
  display: grid;
  gap: var(--space-xl);
}

.audit-flow-step-grid {
  display: grid;
  gap: var(--space-md);
}

@media (min-width: 52rem) {
  .audit-flow-step-grid.two-column-on-wide-audit-grid {
    grid-template-columns: minmax(0, 37%) minmax(0, 63%);
    align-items: start;
    column-gap: var(--space-2xl);
  }
}

.label-audit-soft-cap {
  display: grid;
  gap: var(--space-xs);
  font-size: 0.9365rem;
}

.input-audit-text-field-like,
textarea.audit-notes-field-area {
  width: 100%;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  border: 0.0625rem solid rgba(44, 66, 59, 0.24);
  background: rgba(255, 255, 255, 0.7);
  font-family: var(--font-secondary-sans);
}

textarea.audit-notes-field-area {
  min-height: 8rem;
  resize: vertical;
}

.surface-audit-readout-pane {
  border-radius: var(--radius-lg);
  border: 0.0625rem solid rgba(44, 66, 59, 0.16);
  background: rgba(244, 243, 238, 0.75);
  padding: var(--space-lg);
  display: grid;
  gap: var(--space-md);
}

.readout-muted-disclaimer-micro {
  font-size: 0.84rem;
  color: var(--color-muted);
}

/* Contact ------------------------------------------------------------- */

.grid-contact-information-columns {
  display: grid;
  gap: var(--space-xl);
}

@media (min-width: 56rem) {
  .grid-contact-information-columns.two-card-wide-pair-grid {
    grid-template-columns: minmax(0, 51%) minmax(0, 49%);
    align-items: start;
    column-gap: var(--space-2xl);
  }
}

.surface-contact-form-card-sheet {
  border-radius: var(--radius-lg);
  border: 0.0625rem solid rgba(44, 66, 59, 0.16);
  background: rgba(255, 255, 255, 0.7);
  padding: var(--space-xl);
  box-shadow: var(--shadow-soft);
}

.form-contact-stacked-rows {
  display: grid;
  gap: var(--space-md);
}

.label-contact-soft-cap {
  display: grid;
  gap: var(--space-xs);
  font-size: 0.9325rem;
}

.input-contact-text-field-like {
  width: 100%;
  padding: var(--space-sm);
  border-radius: var(--radius-md);
  border: 0.0625rem solid rgba(44, 66, 59, 0.24);
  background: rgba(255, 255, 255, 0.9);
}

.textarea-contact-message-field-area {
  min-height: 9rem;
  resize: vertical;
}

.row-consent-checkbox-align {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  font-size: 0.9rem;
}

.surface-map-shell-iframe-wrap {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 0.0625rem solid rgba(44, 66, 59, 0.16);
  min-height: 16rem;
  background: #e9e8e1;
}

.map-embedded-frame-fill {
  display: block;
  width: 100%;
  min-height: 16rem;
  border: none;
}

/* Products ------------------------------------------------------------ */

.grid-product-card-row-three {
  display: grid;
  gap: var(--space-lg);
}

@media (min-width: 52rem) {
  .grid-product-card-row-three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
    column-gap: var(--space-lg);
  }
}

.surface-product-plain-card-sheet {
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--space-md);
  border-radius: var(--radius-lg);
  border: 0.0625rem solid rgba(44, 66, 59, 0.16);
  background: rgba(255, 255, 255, 0.7);
  padding: var(--space-lg);
  height: 100%;
}

.price-tag-monospace-muted {
  font-family: ui-monospace, monospace;
  color: var(--color-spruce);
  font-weight: 600;
}

/* Consent banner ------------------------------------------------------- */

.surface-consent-overlay-root {
  position: fixed;
  inset-inline: 0;
  bottom: 0;
  padding: var(--space-md);
  z-index: 55;
}

.consent-overlay-hidden {
  display: none !important;
}

.surface-consent-glass-sheet {
  max-width: 44rem;
  margin-inline: auto;
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background: rgba(244, 243, 238, 0.78);
  border: 0.0625rem solid var(--color-glass-border);
  backdrop-filter: blur(0.8125rem);
  box-shadow: var(--shadow-card);
}

.consent-sheet-row-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

/* Legal typography ----------------------------------------------------- */

.surface-legal-reading-stack {
  max-width: 45rem;
  margin-inline: auto;
}

.heading-legal-top-h1-span {
  font-size: clamp(1.875rem, 1.62rem + 0.74vw, 2.275rem);
  margin-bottom: var(--space-sm);
}

.text-legal-updated-micro {
  font-size: 0.9rem;
  color: var(--color-muted);
  margin-bottom: var(--space-xl);
}

.list-plain-ordered-legal-steps {
  margin: var(--space-md) 0;
  padding-left: 1.2rem;
}

/* Thanks / Error ------------------------------------------------------- */

.surface-thanks-centered-panel {
  min-height: clamp(18rem, 35vh, 30rem);
  display: grid;
  place-items: center;
  text-align: center;
  padding-inline: var(--space-md);
}

.thanks-message-max-width-soft {
  max-width: 32rem;
  margin-inline: auto;
}

/* Helpers -------------------------------------------------------------- */

.stack-vertical-gap-soft {
  display: grid;
  gap: var(--space-md);
}

.text-muted-explanatory-soft {
  color: var(--color-muted);
  font-size: 0.95rem;
}

.display-inline-link-row-soft {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

@media (max-width: 47.9375rem) {
  .layout-header-overlay-row .layout-page-shell-inner,
  .surface-header-plain .layout-page-shell-inner {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-auto-rows: auto;
    row-gap: var(--space-sm);
  }

  .header-brand-plain-text {
    grid-column: 1;
  }

  .navigation-inline-link-chip {
    font-size: 0.894rem;
    padding-inline: var(--space-xs);
  }
}
