/* =============================================================
   HCS Home — Sitewide layout + components
   Consumes tokens from hcs-tokens.css. Implements the locked
   Website Principles (D-014 + D-017 through D-020).
   No box shadows beyond --shadow-* tokens; no gradients except
   photography protection; no glassmorphism on nav; native scroll.
   ============================================================= */

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

html, body { overflow-x: hidden; }

/* Container widths */
.container {
  width: min(100% - 32px, 1200px);
  margin-inline: auto;
}
.container--narrow { width: min(100% - 32px, 880px); }
.container--wide   { width: min(100% - 32px, 1360px); }

@media (min-width: 768px) {
  .container, .container--narrow, .container--wide {
    width: min(100% - 64px, 1200px);
  }
  .container--narrow { width: min(100% - 64px, 880px); }
  .container--wide   { width: min(100% - 64px, 1360px); }
}

/* Sections */
.section {
  padding-block: 64px;
}
.section--sunken { background: var(--bg-sunken); }
.section--raised { background: var(--bg-raised); }
.section--forest {
  background: var(--hcs-forest-900);
  color: var(--hcs-off-white);
}
.section--forest h1,
.section--forest h2,
.section--forest h3,
.section--forest h4 { color: var(--hcs-off-white); }
.section--forest p { color: var(--hcs-forest-200); }
.section--forest .eyebrow { color: var(--hcs-marigold-400); }

@media (min-width: 768px) {
  .section { padding-block: 96px; }
}

/* =============================================================
   TOP NAV — solid cream. No glassmorphism. Always legible.
   (Website Principles §4; supersedes prior glass nav.)
   ============================================================= */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--bg-page);
  backdrop-filter: none;          /* kill legacy glassmorphism from components-nav.css */
  -webkit-backdrop-filter: none;
  box-shadow: none;               /* no drop shadow on nav */
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-base) var(--ease-out);
}
/* Neutralise legacy --over-video / --over-darkhero variants */
.site-nav.site-nav--over-video,
.site-nav.site-nav--over-darkhero,
.site-nav.site-nav--over-video.scrolled,
.site-nav.site-nav--over-darkhero.scrolled {
  background: var(--bg-page);
  color: var(--fg-1);
  box-shadow: none;
  backdrop-filter: none;
}
.site-nav.site-nav--over-video .nav-logo__name,
.site-nav.site-nav--over-darkhero .nav-logo__name,
.site-nav.site-nav--over-video .nav-links a,
.site-nav.site-nav--over-darkhero .nav-links a {
  color: var(--fg-1);
}
.site-nav.is-scrolled {
  border-bottom-color: var(--border-subtle);
}
.nav-inner {
  width: min(100% - 32px, 1360px);
  margin-inline: auto;
  padding-block: 14px;
  display: flex;
  align-items: center;
  gap: 24px;
}
@media (min-width: 768px) {
  .nav-inner { width: min(100% - 64px, 1360px); gap: 32px; }
}

.nav-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--fg-1);
  flex-shrink: 0;
}
.nav-logo img { height: 40px; width: auto; display: block; }
.nav-logo__name {
  font-family: var(--font-sans);
  font-weight: var(--fw-bold);
  font-size: 20px;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  white-space: nowrap;
}
@media (min-width: 1024px) {
  .nav-logo img { height: 48px; }
  .nav-logo__name { font-size: 22px; }
}

.nav-links {
  display: none;
  align-items: center;
  gap: 4px;
  flex: 1;
  justify-content: center;
}
.nav-links a {
  font-family: var(--font-ui);
  font-weight: var(--fw-medium);
  font-size: 14px;
  letter-spacing: 0.01em;
  color: var(--fg-2);
  text-decoration: none;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  transition: background-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.nav-links a:hover { background: var(--bg-inset); color: var(--fg-1); }
.nav-links a.active { color: var(--brand); }

.nav-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
  flex-shrink: 0;
}

/* Hamburger — mobile only */
.nav-hamburger {
  width: 44px;
  height: 44px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  cursor: pointer;
  color: var(--fg-1);
}
.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
}
.nav-hamburger:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.nav-wa-btn { display: none !important; }

@media (min-width: 1024px) {
  .nav-links { display: flex; }
  .nav-hamburger { display: none; }
  .nav-wa-btn { display: inline-flex !important; }
}

/* Mobile slide-over menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: none;
  flex-direction: column;
  padding: 80px 20px 32px;
  background: var(--bg-page);
  overflow-y: auto;
}
.mobile-menu.is-open { display: flex; }
.mobile-menu-close {
  position: absolute;
  top: 14px;
  right: 16px;
  width: 44px;
  height: 44px;
  font-size: 28px;
  line-height: 1;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--fg-1);
  cursor: pointer;
}
.mobile-menu-close:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.mobile-menu-links { display: flex; flex-direction: column; gap: 4px; }
.mobile-menu-links a {
  display: flex;
  align-items: center;
  min-height: 56px;
  padding: 0 16px;
  font-family: var(--font-ui);
  font-weight: var(--fw-medium);
  font-size: 18px;
  color: var(--fg-1);
  text-decoration: none;
  border-radius: var(--radius-md);
}
.mobile-menu-links a:hover { background: var(--bg-sunken); }
.mobile-menu-footer {
  margin-top: 24px;
  padding: 24px 16px;
  background: var(--bg-inverse);
  color: var(--hcs-off-white);
  border-radius: var(--radius-lg);
}
.mobile-menu-footer .btn { width: 100%; margin-top: 16px; }
.mobile-tagline {
  display: block;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: var(--fw-bold);
  font-size: 28px;
  color: var(--hcs-marigold-400);
}
.mobile-menu-meta {
  display: block;
  margin-top: 8px;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--hcs-cream-200);
  opacity: 0.8;
}

/* =============================================================
   FOOTER — dark stone, warm accents
   ============================================================= */
.site-footer {
  background: var(--hcs-stone-900);
  color: var(--hcs-cream-200);
  padding: 64px 0 32px;
}
.footer-inner {
  width: min(100% - 32px, 1360px);
  margin-inline: auto;
  display: grid;
  gap: 40px;
}
.footer-top { display: flex; flex-direction: column; gap: 12px; }
.footer-logo { height: 48px; width: auto; filter: brightness(0) invert(1); }
.footer-tagline {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: var(--fw-bold);
  font-size: 22px;
  color: var(--hcs-marigold-400);
}
.footer-divider {
  height: 1px;
  background: rgba(255,255,255,0.08);
  margin: 8px 0;
}
.footer-middle { display: grid; gap: 32px; }
.footer-brand-col p { color: var(--hcs-cream-200); opacity: 0.8; }
.footer-brand-name {
  font-family: var(--font-sans);
  font-weight: var(--fw-bold);
  font-size: 18px;
  color: var(--hcs-off-white);
  margin-bottom: 4px;
}
.footer-subbrand { font-size: 14px; opacity: 0.6; }
.footer-brand-copy { margin-top: 12px; font-size: 14px; max-width: 36ch; }
.footer-col-title {
  font-family: var(--font-ui);
  font-weight: var(--fw-semibold);
  font-size: 12px;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--hcs-marigold-400);
  margin-bottom: 12px;
}
.footer-nav-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.footer-nav-col a {
  display: block;
  padding: 4px 0;
  font-size: 14px;
  color: var(--hcs-cream-200);
  text-decoration: none;
  opacity: 0.8;
  transition: opacity var(--dur-fast) var(--ease-out);
}
.footer-nav-col a:hover { opacity: 1; color: var(--hcs-off-white); }
.footer-contact p {
  margin: 0 0 4px;
  font-size: 14px;
  color: var(--hcs-cream-200);
  opacity: 0.8;
}
.footer-contact a {
  color: inherit;
  text-decoration: underline;
  text-decoration-color: rgba(255,255,255,0.2);
  text-underline-offset: 3px;
}
.footer-contact a:hover { color: var(--hcs-off-white); text-decoration-color: currentColor; }
.footer-social { display: flex; gap: 10px; margin-top: 16px; }
.footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.04);
  text-decoration: none;
  transition: background-color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.footer-social a:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.3); }
.footer-visit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
  padding: 12px 20px;
  font-family: var(--font-ui);
  font-weight: var(--fw-semibold);
  font-size: 14px;
  color: var(--hcs-off-white);
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.4);
  border-radius: var(--radius-md);
  transition: background-color var(--dur-fast) var(--ease-out);
}
.footer-visit-btn:hover { background: rgba(255,255,255,0.08); color: var(--hcs-off-white); }
.footer-bottom {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: grid;
  gap: 6px;
}
.footer-copyright {
  font-size: 12px;
  color: var(--hcs-stone-500);
  margin: 0;
}

@media (min-width: 768px) {
  .footer-top { flex-direction: row; align-items: center; justify-content: space-between; }
  .footer-middle { grid-template-columns: 1.3fr 1fr 1.2fr; align-items: start; gap: 40px; }
  .footer-bottom { grid-template-columns: 1fr 1fr; column-gap: 32px; }
}

/* =============================================================
   HERO — reusable protection gradient pattern
   "No solid black overlay on photography" — linear-gradient mask only.
   ============================================================= */
.hero-photo-mask {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(20, 30, 18, 0.55) 0%,
    transparent 50%,
    rgba(20, 30, 18, 0.35) 100%
  );
  pointer-events: none;
}

/* =============================================================
   FORMS — shared primitives
   ============================================================= */
.form-field { margin-bottom: 16px; }
.form-field__label {
  display: block;
  margin-bottom: 6px;
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-2);
}
.form-field__control {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-1);
  background: var(--bg-raised);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.form-field__control:focus { border-color: var(--border-focus); box-shadow: var(--focus-ring); }
.form-field__control::placeholder { color: var(--fg-4); }

/* =============================================================
   SECTION HEAD — eyebrow + h2 + aside tagline
   ============================================================= */
.section-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: 40px;
}
.section-head h2 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(32px, 4vw, 48px);
  letter-spacing: -0.03em;
  line-height: 1.02;
  max-width: 18ch;
  margin: 8px 0 0;
}
.section-head__aside { color: var(--fg-3); max-width: 48ch; font-size: 15px; }
@media (min-width: 900px) {
  .section-head {
    grid-template-columns: 1.2fr 1fr;
    gap: 40px;
    align-items: end;
    margin-bottom: 48px;
  }
}

/* Pull quotes — serif italic */
.pull-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: var(--fw-bold);
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.3;
  color: var(--highlight);
  max-width: 30ch;
  margin: 0;
}
.pull-quote__attr {
  display: block;
  margin-top: 16px;
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--fg-3);
  font-style: normal;
}

/* =============================================================
   HERO — homepage video hero
   ============================================================= */
.hero-video-section {
  position: relative;
  min-height: min(92vh, 820px);
  overflow: hidden;
  background: var(--hcs-stone-900);
  color: var(--hcs-off-white);
}
.hero-video,
.hero-video-section img.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.hero-video-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(20, 30, 18, 0.45) 0%,
    rgba(20, 30, 18, 0.15) 35%,
    rgba(20, 30, 18, 0.75) 100%
  );
  z-index: 1;
  pointer-events: none;
}
.hero-video-section > .container,
.hero-content {
  position: relative;
  z-index: 2;
  min-height: inherit;
}
.hero-content {
  width: min(100% - 32px, 1360px);
  margin-inline: auto;
  padding-block: 120px 64px;
  display: grid;
  gap: 40px;
  align-content: end;
}
.hero-copy { max-width: 640px; }
.hero-kicker {
  color: var(--hcs-cream-200);
  opacity: 0.85;
  text-shadow: 0 1px 6px rgba(0,0,0,0.45);
}
.hero-title {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: var(--fw-bold);
  font-size: clamp(56px, 10vw, 132px);
  line-height: 0.92;
  letter-spacing: -0.04em;
  color: var(--highlight);
  margin: 16px 0;
  text-shadow: 0 2px 16px rgba(0,0,0,0.35);
  word-break: break-word;
}
.hero-title em { font-style: inherit; }
.hero-subtitle {
  max-width: 56ch;
  font-size: 17px;
  line-height: 1.6;
  color: var(--hcs-cream-100);
  margin: 0 0 24px;
  text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.hero-scroll-hint {
  position: absolute;
  right: 32px;
  bottom: 32px;
  z-index: 2;
  display: none;
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
@media (min-width: 1024px) {
  .hero-content { padding-block: 160px 80px; }
  .hero-scroll-hint { display: block; }
}

/* Inner-page hero — "Statement Header" pattern
   Fills the visible viewport below the sticky nav so every inner page
   opens with the same full-screen rhythm. */
.page-hero {
  min-height: calc(100svh - var(--nav-height, 88px));
  padding-block: 56px;
  background: var(--bg-page);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.page-hero__eyebrow { margin-bottom: 16px; }
.page-hero__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(36px, 6vw, 88px);
  line-height: 0.96;
  letter-spacing: -0.035em;
  max-width: 22ch;
  color: var(--fg-1);
  margin: 0 0 24px;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.page-hero__title em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--accent);
}
.page-hero__intro {
  font-size: 18px;
  line-height: 1.6;
  color: var(--fg-2);
  max-width: 58ch;
  margin: 0;
}
.page-hero__actions { margin-top: 32px; display: flex; gap: 12px; flex-wrap: wrap; }
@media (min-width: 1024px) {
  .page-hero { padding-block: 80px; }
}

/* =============================================================
   STAT STRIP — home + inner pages
   ============================================================= */
.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 24px;
  padding-block: 32px;
}
.stat-item { text-align: left; }
.stat-item__number {
  display: block;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(40px, 5vw, 64px);
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--fg-1);
}
.stat-item__label {
  display: block;
  margin-top: 8px;
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--fg-3);
}

/* =============================================================
   GEO ENTITY BLOCK — plain HTML text, accented left border
   ============================================================= */
.geo-block {
  padding: 32px;
  border-left: 4px solid var(--highlight);
  background: var(--bg-raised);
  border-radius: var(--radius-lg);
  max-width: 960px;
  margin-inline: auto;
}
.geo-block p {
  margin: 0;
  font-size: 17px;
  line-height: 1.6;
  color: var(--fg-2);
}

/* =============================================================
   JOURNEY — Stage Zero + 5 stages
   ============================================================= */
.journey-zero {
  display: grid;
  gap: 16px;
  padding: 32px;
  background: var(--brand-subtle);
  border-radius: var(--radius-lg);
  margin-bottom: 32px;
}
.journey-zero__label {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--brand);
}
.journey-zero__name {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 28px;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--fg-1);
}
.journey-zero__desc {
  margin: 0;
  color: var(--fg-2);
  max-width: 62ch;
}
.journey-list { display: grid; gap: 20px; }
.journey-stage {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 20px;
  padding: 24px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
}
.journey-stage__num {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 40px;
  line-height: 1;
  color: var(--accent);
  letter-spacing: -0.02em;
}
.journey-stage__name {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 22px;
  letter-spacing: -0.015em;
  margin: 0 0 6px;
  color: var(--fg-1);
}
.journey-stage__desc { margin: 0; color: var(--fg-2); }
@media (min-width: 768px) {
  .journey-list { grid-template-columns: 1fr 1fr; }
}

/* =============================================================
   VALUE CARDS — About H-O-A-R, architects offer, etc.
   ============================================================= */
.value-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 20px;
}
.value-card {
  padding: 28px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  display: grid;
  gap: 12px;
  align-content: start;
}
.value-card__letter {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 44px;
  line-height: 1;
  color: var(--accent);
}
.value-card__name {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 22px;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--fg-1);
}
.value-card__desc { margin: 0; color: var(--fg-2); }

/* =============================================================
   PARTNER BU SPLIT — two equal BUs
   ============================================================= */
.bu-split {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}
.bu-card {
  padding: 32px;
  border-radius: var(--radius-lg);
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  display: grid;
  gap: 12px;
  align-content: start;
}
.bu-card--dark {
  background: var(--hcs-forest-900);
  color: var(--hcs-off-white);
  border-color: transparent;
}
.bu-card--dark .bu-card__eyebrow { color: var(--hcs-marigold-400); }
.bu-card--dark .bu-card__heading { color: var(--hcs-off-white); }
.bu-card--dark .bu-card__body { color: var(--hcs-cream-200); }
.bu-card--dark .bu-card__link { color: var(--hcs-marigold-400); }
.bu-card__eyebrow { color: var(--accent); }
.bu-card__heading {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 26px;
  letter-spacing: -0.02em;
  margin: 4px 0 0;
}
.bu-card__body { margin: 8px 0; color: var(--fg-2); }
.bu-card__link {
  display: inline-flex;
  gap: 8px;
  margin-top: 8px;
  font-family: var(--font-ui);
  font-weight: var(--fw-semibold);
  font-size: 14px;
  color: var(--brand);
  text-decoration: none;
}
.bu-card__link:hover { text-decoration: underline; }
@media (min-width: 768px) { .bu-split { grid-template-columns: 1fr 1fr; } }

/* =============================================================
   FEATURE LIST — bullet-free text lines (architect offer, etc.)
   ============================================================= */
.feature-list { display: grid; gap: 16px; margin: 0; padding: 0; list-style: none; }
.feature-list__item {
  padding-left: 20px;
  border-left: 2px solid var(--highlight);
  color: var(--fg-2);
  font-size: 16px;
  line-height: 1.6;
}

/* =============================================================
   FAQ — native <details>, editorial
   ============================================================= */
.faq-list { display: grid; gap: 4px; }
.faq-item {
  border-top: 1px solid var(--border-subtle);
  padding: 8px 0;
}
.faq-item[open] { padding-bottom: 16px; }
.faq-item > summary {
  list-style: none;
  cursor: pointer;
  padding: 16px 40px 16px 0;
  position: relative;
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--fg-1);
}
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item > summary::after {
  content: "+";
  position: absolute;
  top: 14px;
  right: 4px;
  font-family: var(--font-display);
  font-weight: var(--fw-regular);
  font-size: 24px;
  line-height: 1;
  color: var(--fg-3);
  transition: transform var(--dur-base) var(--ease-out);
}
.faq-item[open] > summary::after { content: "−"; }
.faq-item__answer {
  padding: 0 40px 8px 0;
  max-width: 72ch;
  color: var(--fg-2);
  line-height: 1.65;
}

/* =============================================================
   FOREST BAND — CTA in forest-900
   ============================================================= */
.forest-band {
  background: var(--hcs-forest-900);
  color: var(--hcs-off-white);
  border-radius: var(--radius-2xl);
  padding: 56px 32px;
  display: grid;
  gap: 32px;
}
.forest-band h2,
.forest-band h3 { color: var(--hcs-off-white); font-family: var(--font-display); font-weight: var(--fw-bold); }
.forest-band p { color: var(--hcs-forest-200); max-width: 52ch; }
.forest-band .eyebrow { color: var(--hcs-marigold-400); }
.forest-band__info { display: grid; gap: 14px; }
.forest-band__info-row {
  padding: 16px 20px;
  background: rgba(255,255,255,0.06);
  border-radius: var(--radius-md);
}
.forest-band__info-row .k {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--hcs-marigold-400);
  display: block;
  margin-bottom: 4px;
}
.forest-band__info-row .v {
  font-size: 15px;
  line-height: 1.5;
  color: var(--hcs-off-white);
  display: block;
  word-break: normal;
  overflow-wrap: normal;
}
@media (min-width: 900px) {
  .forest-band { grid-template-columns: 1.3fr 1fr; padding: 64px; align-items: center; }
}

/* =============================================================
   QUOTES / testimonials
   ============================================================= */
.quotes-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}
.quote-card {
  padding: 32px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
}
.quote-card__mark {
  font-family: var(--font-serif);
  font-weight: var(--fw-bold);
  font-size: 64px;
  line-height: 0.6;
  color: var(--peach);
}
.quote-card__text {
  font-family: var(--font-sans);
  font-style: italic;
  font-size: 17px;
  line-height: 1.5;
  color: var(--fg-1);
  margin: 12px 0 20px;
}
.quote-card__who { display: flex; align-items: center; gap: 12px; }
.quote-card__avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--peach-soft);
  color: var(--hcs-terracotta-800);
  font-family: var(--font-ui);
  font-weight: var(--fw-semibold);
  font-size: 14px;
  display: grid; place-items: center;
}
.quote-card__name {
  font-family: var(--font-ui);
  font-weight: var(--fw-semibold);
  font-size: 14px;
  color: var(--fg-1);
}
.quote-card__role { font-size: 12px; color: var(--fg-3); }
@media (min-width: 768px) { .quotes-grid { grid-template-columns: 1fr 1fr; } }

/* =============================================================
   FLOORS — showroom page
   ============================================================= */
.floor {
  display: grid;
  gap: 32px;
  padding-block: 48px 0;
  grid-template-columns: 1fr;
}
.floor__media {
  aspect-ratio: 4/3;
  background: var(--bg-sunken);
  border-radius: var(--radius-xl);
  overflow: hidden;
  position: relative;
}
.floor__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.floor__content { display: grid; gap: 12px; align-content: start; }
.floor__eyebrow { color: var(--accent); }
.floor__title {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: clamp(28px, 3vw, 38px);
  letter-spacing: -0.025em;
  margin: 4px 0;
  color: var(--fg-1);
}
.floor__highlights {
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}
.floor__highlights li {
  padding-left: 20px;
  position: relative;
  color: var(--fg-2);
}
.floor__highlights li::before {
  content: "·";
  position: absolute;
  left: 4px;
  top: 0;
  color: var(--highlight);
  font-weight: var(--fw-bold);
  font-size: 20px;
  line-height: 1.4;
}
@media (min-width: 900px) {
  .floor { grid-template-columns: 1.1fr 1fr; align-items: center; padding-block: 64px; }
  .floor--reverse > .floor__media { order: 2; }
}

/* =============================================================
   STAIRCASE split — between-floors section
   ============================================================= */
.staircase-split {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: center;
}
.staircase-split__copy { display: grid; gap: 16px; align-content: start; }
.staircase-split__media {
  aspect-ratio: 3/4;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--bg-inset);
}
.staircase-split__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.staircase-concepts {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 12px;
}
.staircase-concept {
  display: grid;
  gap: 4px;
  padding: 16px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}
.staircase-concept__num {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 22px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--accent);
}
.staircase-concept__label {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: var(--fw-semibold);
  color: var(--fg-1);
  line-height: 1.3;
}
@media (min-width: 900px) {
  .staircase-split { grid-template-columns: 1fr 1fr; gap: 56px; }
  .staircase-split__media { aspect-ratio: 4/5; }
}

/* =============================================================
   CATEGORY / VERTICAL CARDS — For Your Home
   ============================================================= */
.cat-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.cat-card {
  padding: 28px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  display: grid;
  gap: 14px;
  align-content: start;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.cat-card:hover {
  border-color: var(--border-default);
  box-shadow: var(--shadow-md);
  color: inherit;
  text-decoration: none;
}
.cat-card__num {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}
.cat-card__title {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 22px;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--fg-1);
}
.cat-card__desc { margin: 0; color: var(--fg-2); }
.cat-card__brands {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}
.cat-card__brand {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-medium);
  padding: 4px 10px;
  background: var(--bg-sunken);
  border-radius: var(--radius-pill);
  color: var(--fg-2);
}
@media (min-width: 768px) { .cat-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px) { .cat-grid { grid-template-columns: 1fr 1fr 1fr; } }

/* =============================================================
   BRANDS — logos + links to official sites
   ============================================================= */
.brand-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  padding: 16px 0;
}
@media (min-width: 640px) { .brand-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 960px) { .brand-grid { grid-template-columns: repeat(5, 1fr); } }

.brand-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px 18px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: inherit;
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
  min-height: 104px;
}
.brand-link:hover {
  border-color: var(--border-default);
  box-shadow: var(--shadow-md);
  color: inherit;
  text-decoration: none;
}
.brand-link__logo {
  max-width: 100%;
  max-height: 56px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: saturate(0.92);
  transition: filter var(--dur-fast) var(--ease-out);
}
.brand-link:hover .brand-link__logo { filter: saturate(1); }
/* Text fallback — only shown when no logo asset is found */
.brand-link__name {
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-wide);
  color: var(--fg-2);
}
.brand-link:hover .brand-link__name { color: var(--brand); }

/* Chip variant — smaller, inline, for cat-card brand rows */
.brand-link--chip {
  padding: 10px 16px;
  min-height: 44px;
  background: var(--bg-sunken);
  border-color: transparent;
  border-radius: var(--radius-pill);
}
.brand-link--chip .brand-link__logo { max-height: 22px; }
.brand-link--chip .brand-link__name {
  font-size: 12px;
  letter-spacing: 0.08em;
}
.brand-link--chip:hover {
  background: var(--bg-inset);
  border-color: transparent;
  box-shadow: none;
}

/* cat-card__brands lays out chips in a flex row */
.cat-card__brands {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.cat-card__note {
  margin: 0;
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
}

/* Legacy — still used on brand-strip markup, kept for compat */
.brand-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 32px;
  justify-content: center;
  padding: 32px 0;
}
.brand-strip__item {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 20px;
  letter-spacing: -0.01em;
  color: var(--fg-2);
}

/* =============================================================
   BEHTAR NOTES — editorial index
   ============================================================= */
.notes-hero {
  min-height: calc(100svh - var(--nav-height, 88px));
  padding: 56px 0;
  background: var(--bg-page);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (min-width: 1024px) { .notes-hero { padding: 80px 0; } }
.notes-hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: end;
}
@media (min-width: 900px) {
  .notes-hero__grid { grid-template-columns: minmax(0, 1.5fr) minmax(260px, 1fr); gap: 64px; }
}
.notes-hero__copy { display: grid; gap: 16px; }
.notes-hero__eyebrow { margin: 0; }
.notes-hero__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(56px, 11vw, 148px);
  line-height: 0.92;
  letter-spacing: -0.04em;
  color: var(--fg-1);
  margin: 0;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.notes-hero__title em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--accent);
}
.notes-hero__intro {
  font-size: 19px;
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 54ch;
  margin: 0;
}
.notes-hero__meta {
  display: grid;
  gap: 16px;
  padding: 24px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  border-left: 4px solid var(--highlight);
}
.notes-hero__meta-row { display: grid; gap: 2px; }
.notes-hero__meta-num {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 36px;
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--fg-1);
}
.notes-hero__meta-label {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--fg-3);
}
.notes-topics {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 32px 0 0;
  padding: 0;
  list-style: none;
}
.notes-topics__item {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.04em;
  padding: 6px 12px;
  background: var(--bg-sunken);
  border-radius: var(--radius-pill);
  color: var(--fg-2);
}

/* Featured piece — image-led magazine treatment */
.note-featured { margin: 0; }
.note-featured__link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.note-featured__link:hover { color: inherit; text-decoration: none; }
.note-featured__visual {
  position: relative;
  display: block;
  margin: 0 0 32px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--hcs-forest-900);
}
.note-featured__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}
.note-featured__link:hover .note-featured__image { transform: scale(1.02); }
.note-featured__badge {
  position: absolute;
  top: 20px;
  left: 20px;
  padding: 6px 14px;
  background: var(--highlight);
  color: var(--hcs-stone-900);
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  border-radius: var(--radius-pill);
  z-index: 1;
  margin: 0;
}
.note-featured__body { display: grid; gap: 18px; max-width: 68ch; }
.note-featured__eyebrow {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}
.note-featured__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.04;
  letter-spacing: -0.025em;
  color: var(--fg-1);
  margin: 0;
  transition: color var(--dur-fast) var(--ease-out);
}
.note-featured__link:hover .note-featured__title { color: var(--brand); }
.note-featured__dek {
  font-family: var(--font-serif);
  font-size: 21px;
  font-style: italic;
  line-height: 1.45;
  color: var(--fg-2);
  margin: 0;
  max-width: 56ch;
}
.note-featured__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: var(--fw-semibold);
  color: var(--brand);
  margin-top: 4px;
}
.note-featured__link:hover .note-featured__cta { text-decoration: underline; }

/* Forest-green placeholder for notes without images */
.note-placeholder {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--hcs-forest-700) 0%, var(--hcs-forest-900) 100%);
  display: grid;
  place-content: center;
  gap: 18px;
  justify-items: center;
  text-align: center;
  color: var(--hcs-cream-200);
  padding: 32px;
}
.note-placeholder__rule {
  width: 48px;
  height: 1px;
  background: var(--highlight);
  opacity: 0.7;
}
.note-placeholder__kicker {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--highlight);
}
.note-placeholder__topic {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(28px, 3.5vw, 42px);
  line-height: 1.1;
  color: var(--hcs-cream-200);
  max-width: 20ch;
}
.note-placeholder--tile .note-placeholder__topic { font-size: clamp(22px, 2.2vw, 28px); }
.note-placeholder--tile { gap: 12px; padding: 24px; }

.note-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--fg-3);
}
.note-meta__dot { color: var(--fg-4); }
.note-meta__author { font-weight: var(--fw-semibold); color: var(--fg-2); }

/* Earlier notes — image-led grid */
.notes-list-heading {
  font-family: var(--font-ui);
  font-weight: var(--fw-semibold);
  font-size: 12px;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--fg-3);
  margin: 0 0 48px;
  display: flex;
  align-items: center;
  gap: 20px;
}
.notes-list-heading > span { flex: 0 0 auto; }
.notes-list-heading::after {
  content: "";
  flex: 1 1 auto;
  height: 1px;
  background: var(--border-subtle);
}
.notes-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px 32px;
}
@media (min-width: 720px)  { .notes-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px) { .notes-grid { grid-template-columns: repeat(3, 1fr); } }
.note-tile {
  display: grid;
  gap: 18px;
  text-decoration: none;
  color: inherit;
  align-content: start;
}
.note-tile:hover { color: inherit; text-decoration: none; }
.note-tile__visual {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--hcs-forest-900);
}
.note-tile__visual img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}
.note-tile:hover .note-tile__visual img { transform: scale(1.03); }
.note-tile__body { display: grid; gap: 10px; }
.note-tile__topic {
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}
.note-tile__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 24px;
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 0;
  transition: color var(--dur-fast) var(--ease-out);
}
.note-tile:hover .note-tile__title { color: var(--brand); }
.note-tile__dek {
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.5;
  color: var(--fg-2);
  margin: 0;
}
.note-tile .note-meta--compact {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--fg-3);
  margin-top: 2px;
}

/* Empty state */
.notes-empty {
  padding: 48px;
  background: var(--bg-raised);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  border-left: 4px solid var(--highlight);
  max-width: 68ch;
}
.notes-empty h2 {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 28px;
  letter-spacing: -0.02em;
  margin: 8px 0 12px;
  color: var(--fg-1);
}
.notes-empty p { color: var(--fg-2); line-height: 1.6; margin: 0; }
.notes-empty a { color: var(--brand); }

/* Legacy — earlier flat list, kept for compat */
.notes-index { display: grid; gap: 24px; }
.note-card {
  padding: 28px 0;
  border-top: 1px solid var(--border-subtle);
  display: grid;
  gap: 8px;
  text-decoration: none;
  color: inherit;
}
.note-card:first-child { border-top: 0; padding-top: 8px; }
.note-card__meta {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--fg-3);
}
.note-card__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(26px, 3vw, 36px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 0;
}
.note-card__dek { font-size: 17px; color: var(--fg-2); margin: 4px 0 0; max-width: 64ch; }
.note-card:hover .note-card__title { color: var(--brand); }

/* Two-column layout: body + sticky TOC */
.note-layout { display: grid; grid-template-columns: 1fr; gap: 48px; }
@media (min-width: 1024px) {
  .note-layout {
    grid-template-columns: minmax(0, 1fr) 240px;
    gap: 64px;
    align-items: start;
  }
}
.note-toc {
  padding: 20px 24px;
  background: var(--bg-sunken);
  border-radius: var(--radius-lg);
}
@media (min-width: 1024px) {
  .note-toc { position: sticky; top: 100px; }
}
.note-toc__label {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--fg-3);
  margin: 0 0 12px;
}
.note-toc__list {
  margin: 0;
  padding-left: 0;
  list-style: decimal inside;
  display: grid;
  gap: 8px;
}
.note-toc__list li { font-size: 14px; line-height: 1.4; }
.note-toc__list a {
  color: var(--fg-2);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.note-toc__list a:hover { color: var(--brand); border-bottom-color: currentColor; }

/* Article body — 66–72ch measure, serif */
.note-article { padding-block: 64px; }
.note-article__meta {
  font-family: var(--font-ui);
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 12px;
}
.note-article__title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.03em;
  color: var(--fg-1);
  max-width: 22ch;
  margin: 0 0 16px;
}
.note-article__dek {
  font-family: var(--font-serif);
  font-size: 22px;
  font-style: italic;
  color: var(--fg-2);
  line-height: 1.45;
  max-width: 48ch;
  margin: 0 0 32px;
}
.note-article__body {
  font-family: var(--font-serif);
  font-size: 19px;
  line-height: 1.7;
  color: var(--fg-2);
  max-width: 68ch;
}
.note-article__body h2 {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 32px;
  color: var(--fg-1);
  margin: 48px 0 16px;
  letter-spacing: -0.02em;
}
.note-article__body h3 {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: 24px;
  color: var(--fg-1);
  margin: 32px 0 12px;
}
.note-article__body p { margin: 0 0 20px; color: var(--fg-2); }
.note-article__body a { color: var(--brand); }
.note-figure {
  margin: 28px 0;
  display: block;
}
.note-figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
}
.note-figure figcaption {
  margin-top: 10px;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--fg-4);
  line-height: 1.5;
}

/* =============================================================
   FLASH NOTICE — for contact form success/error
   ============================================================= */
.flash {
  padding: 16px 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
  background: var(--bg-sunken);
  margin-bottom: 24px;
  font-size: 15px;
}
.flash--success {
  border-color: color-mix(in oklab, var(--status-success) 30%, transparent);
  background: var(--status-success-subtle);
  color: var(--brand-subtle-fg);
}
.flash--error {
  border-color: color-mix(in oklab, var(--status-danger) 30%, transparent);
  background: var(--status-danger-subtle);
  color: var(--status-danger);
}

/* =============================================================
   MAP EMBED
   ============================================================= */
.map-wrap {
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-sunken);
  margin-top: 24px;
}
.map-wrap iframe { width: 100%; height: 100%; border: 0; display: block; }

/* =============================================================
   UTILITIES
   ============================================================= */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.text-center { text-align: center; }
.text-muted { color: var(--fg-3); }
.mt-0 { margin-top: 0; }
.mt-4 { margin-top: 16px; }
.mt-6 { margin-top: 24px; }
.mt-8 { margin-top: 40px; }
