/* ============================================================
   Rock Steady — component & page styles
   ============================================================ */

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.95rem 1.4rem;
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--text-sm);
  letter-spacing: 0.01em;
  line-height: 1;
  border: 1px solid transparent;
  transition: transform var(--t-fast), background var(--t-fast), color var(--t-fast),
    box-shadow var(--t-fast), border-color var(--t-fast);
  white-space: nowrap;
}
.btn-primary {
  background: var(--color-primary);
  color: var(--color-text-inverse);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.15) inset, var(--shadow-sm);
}
.btn-primary:hover { background: var(--color-primary-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-primary:active { background: var(--color-primary-active); transform: translateY(0); }

.btn-on-dark { background: var(--color-primary); color: var(--color-text-inverse); }
.btn-on-dark:hover { background: #b3593a; }

.btn-ghost {
  background: transparent;
  color: var(--color-text);
  border: 1px solid var(--color-border-strong);
}
.btn-ghost:hover { background: var(--color-surface); border-color: var(--color-text); }

.btn-sm { padding: 0.7rem 1.1rem; font-size: 0.85rem; }
.btn-lg { padding: 1.1rem 1.7rem; font-size: 1rem; }
.btn-block { width: 100%; justify-content: center; }

/* ---------- Header ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(244, 239, 231, 0.88);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-base), background var(--t-base);
}
.site-header.is-scrolled {
  border-bottom-color: var(--color-border);
  background: rgba(244, 239, 231, 0.94);
}
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 101;
  height: 3px;
  background: rgba(31, 28, 23, 0.08);
  pointer-events: none;
}
.scroll-progress span {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, var(--color-primary), #d1a173);
  transform: scaleX(0);
  transform-origin: left center;
  box-shadow: 0 0 18px rgba(160, 74, 42, 0.35);
}
.header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  padding-block: var(--space-4);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text);
}
.brand-logo {
  display: block;
  width: clamp(150px, 18vw, 232px);
  height: auto;
  object-fit: contain;
}
.brand-logo--footer {
  width: min(232px, 100%);
  filter: invert(1) brightness(1.8);
}
.brand-text { display: inline-flex; flex-direction: column; line-height: 1.05; }
.brand-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.15rem;
  letter-spacing: -0.01em;
}
.brand-sub {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-top: 2px;
}

.site-nav {
  display: flex;
  gap: var(--space-6);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-muted);
}
.site-nav a { position: relative; padding-block: 4px; }
.site-nav a:hover { color: var(--color-text); }
.site-nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--color-text);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--t-base);
}
.site-nav a:hover::after { transform: scaleX(1); }

.header-cta { display: inline-flex; }

.nav-toggle { display: none; color: var(--color-text); }

.mobile-nav {
  display: none;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-6) var(--space-6);
  border-top: 1px solid var(--color-border);
  background: var(--color-bg);
}
.mobile-nav a { padding: var(--space-3) 0; font-weight: 500; }
.mobile-nav a.btn { margin-top: var(--space-2); justify-content: center; }
.mobile-nav.is-open { display: flex; }

@media (max-width: 880px) {
  .site-nav, .header-cta { display: none; }
  .nav-toggle { display: inline-flex; padding: 8px; }
}

/* ---------- Renovation pathways ---------- */
.section--pathways {
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-surface) 100%);
  border-bottom: 1px solid var(--color-border);
}
.pathway-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--space-6);
}
.pathway-card {
  position: relative;
  grid-column: span 4;
  min-height: 520px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background: var(--color-deep);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-md);
  isolation: isolate;
}
.pathway-card--bath { grid-column: span 5; }
.pathway-card--kitchen { grid-column: span 4; }
.pathway-card--cabinet {
  grid-column: span 3;
  background:
    linear-gradient(160deg, rgba(160, 74, 42, 0.22), transparent 45%),
    var(--color-deep);
}
.pathway-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.78;
  transition: transform 900ms var(--ease-out), opacity var(--t-base);
}
.pathway-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(15, 12, 8, 0.02), rgba(15, 12, 8, 0.82)),
    radial-gradient(circle at 10% 88%, rgba(160, 74, 42, 0.24), transparent 42%);
  z-index: 1;
}
.pathway-card__body {
  position: relative;
  z-index: 2;
  padding: var(--space-8);
}
.pathway-card__body--solo {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.pathway-card__body span {
  display: block;
  color: #e7b291;
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: var(--space-3);
}
.pathway-card__body h3 {
  color: var(--color-text-inverse);
  font-size: var(--text-xl);
  font-weight: 500;
  line-height: 1.12;
  margin-bottom: var(--space-4);
}
.pathway-card__body p {
  color: rgba(251, 247, 240, 0.78);
  font-size: var(--text-sm);
  line-height: 1.62;
  margin-bottom: var(--space-5);
}
.pathway-card .link-arrow {
  color: var(--color-text-inverse);
  border-bottom-color: rgba(251, 247, 240, 0.58);
}
.pathway-card .link-arrow:hover {
  color: #e7b291;
  border-bottom-color: #e7b291;
}
.pathway-card:hover img {
  transform: scale(1.035);
  opacity: 0.9;
}
@media (max-width: 980px) {
  .pathway-card,
  .pathway-card--bath,
  .pathway-card--kitchen,
  .pathway-card--cabinet {
    grid-column: span 6;
  }
}
@media (max-width: 640px) {
  .pathway-card,
  .pathway-card--bath,
  .pathway-card--kitchen,
  .pathway-card--cabinet {
    grid-column: span 12;
    min-height: 430px;
  }
  .pathway-card__body { padding: var(--space-6); }
}

/* ---------- Hero ---------- */
.hero {
  position: relative;
  padding-block: clamp(4rem, 8vw, 7rem) clamp(3rem, 7vw, 6rem);
  overflow: hidden;
}
.hero-pattern {
  position: absolute; inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 18% 28%, rgba(160, 74, 42, 0.07) 0, transparent 30%),
    radial-gradient(circle at 82% 70%, rgba(31, 28, 23, 0.06) 0, transparent 35%);
  z-index: 0;
}
.hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  align-items: center;
  gap: clamp(2rem, 5vw, 5rem);
}
.hero-text { display: flex; flex-direction: column; }

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.eyebrow-dot {
  width: 8px; height: 8px; border-radius: 99px;
  background: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(160, 74, 42, 0.16);
}

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 1.5rem + 4vw, 5rem);
  font-weight: 400;
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--color-text);
  font-variation-settings: "SOFT" 30, "WONK" 0, "opsz" 144;
  max-width: 14ch;
}
.hero-title .line { display: block; }
.hero-title em {
  display: inline-block;
  margin-right: 0.08em;
  font-style: italic;
  color: var(--color-primary);
  font-variation-settings: "SOFT" 100, "WONK" 1;
}

.hero-lede {
  margin-top: var(--space-6);
  max-width: 38rem;
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  line-height: 1.55;
}

.hero-ctas {
  margin-top: var(--space-8);
  display: flex; flex-wrap: wrap; gap: var(--space-3);
}

.hero-meta {
  margin-top: var(--space-10);
  display: flex; flex-wrap: wrap; align-items: center;
  gap: var(--space-4);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  text-transform: uppercase;
}
.hero-meta strong { color: var(--color-text); font-weight: 600; }
.hero-meta .dot {
  width: 4px; height: 4px; border-radius: 99px;
  background: var(--color-border-strong);
}
.hero-social-proof {
  margin-bottom: var(--space-5);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  width: fit-content;
  max-width: 32rem;
  padding: 0.58rem 0.78rem 0.58rem 0.68rem;
  border: 1px solid rgba(176, 91, 51, 0.22);
  border-radius: 999px;
  background: rgba(255, 252, 247, 0.66);
  color: var(--color-text-muted);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}
.hero-social-proof:hover {
  transform: translateY(-1px);
  border-color: rgba(176, 91, 51, 0.38);
  background: rgba(255, 252, 247, 0.9);
}
.hero-social-proof strong {
  flex: none;
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.2vw, 1.65rem);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--color-primary);
  font-weight: 500;
}
.hero-social-proof span {
  font-size: 0.82rem;
  line-height: 1.35;
  max-width: 26rem;
}

/* Hero editorial showcase */
.hero-visual {
  position: relative;
  height: clamp(440px, 40vw, 540px);
  min-height: 440px;
}
.hero-showcase {
  position: relative;
  height: 100%;
  isolation: isolate;
}
.hero-showcase::before {
  content: "";
  position: absolute;
  inset: 10% -6% 6% 8%;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(160, 74, 42, 0.14), transparent 62%);
  filter: blur(18px);
  z-index: -1;
}
.showcase-frame {
  position: absolute;
  inset: 0 0 0 4%;
  border-radius: clamp(22px, 3vw, 34px);
  overflow: hidden;
  box-shadow: 0 34px 90px rgba(50, 38, 25, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.72);
  background: var(--color-surface-2);
  transform: rotate(1.2deg);
}
.showcase-frame::before {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(251, 247, 240, 0.58);
  border-radius: clamp(16px, 2.5vw, 26px);
  pointer-events: none;
  z-index: 3;
}
.showcase-frame img,
.visual-card img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.hero-slideshow {
  position: absolute;
  inset: 0;
}
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: scale(1.035);
  transition: opacity 1100ms ease, transform 6200ms var(--ease-out);
}
.hero-slide.is-active {
  opacity: 1;
  transform: scale(1);
  z-index: 1;
}
.showcase-scrim {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(12, 10, 8, 0.08), transparent 34%),
    linear-gradient(0deg, rgba(12, 10, 8, 0.58), rgba(12, 10, 8, 0.02) 48%);
  z-index: 2;
}
.showcase-topline {
  position: absolute;
  top: var(--space-6);
  left: var(--space-6);
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(15, 12, 8, 0.5);
  color: #fbf7f0;
  backdrop-filter: blur(10px);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
}
.showcase-topline::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: #e7b291;
}
.showcase-caption {
  position: absolute;
  left: var(--space-8);
  right: var(--space-8);
  bottom: var(--space-8);
  z-index: 4;
  color: var(--color-text-inverse);
}
.showcase-caption span {
  display: block;
  margin-bottom: var(--space-2);
  color: rgba(251, 247, 240, 0.72);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 700;
}
.showcase-caption strong {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 2.5vw, 3rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.025em;
  max-width: 10ch;
}
.showcase-proof {
  position: absolute;
  right: var(--space-6);
  top: calc(var(--space-6) + 3.15rem);
  z-index: 5;
  width: min(260px, 44%);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  background: rgba(251, 247, 240, 0.88);
  border: 1px solid rgba(255, 255, 255, 0.8);
  box-shadow: 0 18px 50px rgba(50, 38, 25, 0.16);
  backdrop-filter: blur(16px);
}
.showcase-proof span {
  display: block;
  color: var(--color-primary);
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: var(--space-2);
}
.showcase-proof p {
  color: var(--color-text);
  font-size: var(--text-sm);
  line-height: 1.45;
  font-weight: 500;
}
.vc-label {
  position: absolute;
  top: var(--space-3); left: var(--space-3);
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(15, 12, 8, 0.55);
  color: #fbf7f0;
  backdrop-filter: blur(6px);
  z-index: 2;
}
.visual-card--a { top: 0; right: 0; width: 60%; height: 70%; transform: rotate(2deg); }
.visual-card--b { bottom: 4%; right: 28%; width: 50%; height: 55%; transform: rotate(-3deg); z-index: 2; }
.visual-card--c { bottom: 0; left: 0; width: 36%; height: 40%; transform: rotate(-2deg); z-index: 3; }

@media (max-width: 980px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { height: 520px; min-height: 420px; margin-top: var(--space-8); }
  .showcase-frame { inset: 0; transform: rotate(0.6deg); }
  .showcase-proof { top: auto; right: var(--space-6); bottom: var(--space-6); }
}
@media (max-width: 520px) {
  .hero-visual { height: 430px; min-height: 380px; }
  .hero-social-proof {
    align-items: flex-start;
    border-radius: var(--radius-lg);
    width: 100%;
  }
  .showcase-frame { inset: 0; border-radius: 22px; transform: none; }
  .showcase-frame::before { inset: 10px; border-radius: 16px; }
  .showcase-topline { top: var(--space-4); left: var(--space-4); }
  .showcase-caption { left: var(--space-5); right: var(--space-5); bottom: 8.8rem; }
  .showcase-caption strong { font-size: 2rem; }
  .showcase-proof {
    top: auto;
    left: var(--space-4);
    right: var(--space-4);
    bottom: var(--space-4);
    width: auto;
  }
}
@media (prefers-reduced-motion: reduce) {
  .hero-slide {
    transition: none;
    transform: none;
  }
}

/* ---------- Trust bar ---------- */
.trustbar {
  border-block: 1px solid var(--color-border);
  background: var(--color-surface);
}
.trustbar-inner {
  display: flex; flex-wrap: wrap; justify-content: space-between;
  align-items: center; gap: var(--space-6);
  padding-block: var(--space-6);
}
.trust-item {
  display: inline-flex; align-items: center; gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.trust-item svg { color: var(--color-primary); flex: none; }
.trust-item strong { color: var(--color-text); font-weight: 600; }
@media (max-width: 880px) {
  .trustbar-inner { justify-content: flex-start; }
}

/* ---------- Generic section ---------- */
.section {
  padding-block: clamp(4rem, 8vw, 7rem);
}
.section-head { max-width: 56rem; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-head--split {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12);
  max-width: none; align-items: end;
}
.section-head--split .section-lede { max-width: 36rem; margin-left: auto; }
@media (max-width: 880px) {
  .section-head--split { grid-template-columns: 1fr; gap: var(--space-6); }
  .section-head--split .section-lede { margin-left: 0; }
}

.kicker {
  display: inline-block;
  font-size: 0.74rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 600;
  margin-bottom: var(--space-4);
}
.kicker--light { color: #d6a98c; }

.section-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--text-2xl);
  line-height: 1.05;
  letter-spacing: -0.02em;
}
.section-title em {
  font-style: italic;
  color: var(--color-primary);
}
.section-title--light { color: var(--color-text-inverse); }

.section-lede {
  margin-top: var(--space-5);
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 38rem;
}

/* ---------- Services ---------- */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 0;
  border-top: 1px solid var(--color-border);
  border-left: 1px solid var(--color-border);
}
.service {
  padding: var(--space-10) var(--space-8);
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
  transition: background var(--t-base);
  position: relative;
}
.service:hover { background: var(--color-surface-2); }
.service-no {
  font-family: var(--font-display);
  font-size: 0.95rem;
  color: var(--color-primary);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-6);
}
.service-title {
  font-size: var(--text-xl);
  font-weight: 500;
  margin-bottom: var(--space-3);
}
.service p { color: var(--color-text-muted); margin-bottom: var(--space-5); }
.service-list {
  display: flex; flex-direction: column; gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.service-list li {
  padding-left: 1.1rem;
  position: relative;
}
.service-list li::before {
  content: "";
  position: absolute; left: 0; top: 0.65em;
  width: 6px; height: 1px; background: var(--color-primary);
}

/* ---------- Cabinet sales ---------- */
.section--cabinets {
  background: var(--color-surface);
  border-block: 1px solid var(--color-border);
}
.cabinets-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: center;
}
.cabinets-copy .section-title { max-width: 13ch; }
.cabinet-points {
  margin-block: var(--space-8);
  display: grid;
  gap: var(--space-4);
}
.cabinet-points div {
  padding: var(--space-5);
  border: 1px solid rgba(185, 172, 147, 0.58);
  border-radius: var(--radius-md);
  background: rgba(251, 247, 240, 0.72);
  box-shadow: var(--shadow-sm);
}
.cabinet-points strong {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-base);
  margin-bottom: var(--space-1);
}
.cabinet-points strong::before {
  content: "";
  width: 6px;
  height: 6px;
  flex: 0 0 6px;
  border-radius: 999px;
  background: var(--color-primary);
}
.cabinet-points span {
  display: block;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
}
.cabinets-visual {
  position: relative;
  min-height: 520px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid rgba(255, 255, 255, 0.7);
}
.cabinets-visual img {
  width: 100%;
  height: 100%;
  min-height: 520px;
  object-fit: cover;
  display: block;
}
.cabinets-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(15, 12, 8, 0.48));
}
.cabinet-note {
  position: absolute;
  left: var(--space-6);
  right: var(--space-6);
  bottom: var(--space-6);
  z-index: 2;
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  background: rgba(251, 247, 240, 0.9);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255, 255, 255, 0.8);
}
.cabinet-note span {
  display: block;
  color: var(--color-primary);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: var(--space-2);
}
.cabinet-note p {
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.45;
}
@media (max-width: 880px) {
  .cabinets-grid { grid-template-columns: 1fr; }
  .cabinets-visual, .cabinets-visual img { min-height: 380px; }
}

/* ---------- Process ---------- */
.section--process { background: var(--color-surface); border-block: 1px solid var(--color-border); }
.process-list {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-8);
  counter-reset: step;
}
.process-step {
  border-top: 2px solid var(--color-text);
  padding-top: var(--space-5);
}
.step-no {
  font-family: var(--font-display);
  font-size: 0.85rem;
  letter-spacing: 0.06em;
  color: var(--color-primary);
  margin-bottom: var(--space-3);
}
.process-step h3 {
  font-size: var(--text-lg);
  font-weight: 500;
  margin-bottom: var(--space-3);
}
.process-step p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* ---------- Proof / Schluter ---------- */
.section--proof {
  background: var(--color-deep);
  color: var(--color-text-inverse);
  position: relative;
  overflow: hidden;
}
.section--proof::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 80% 20%, rgba(160, 74, 42, 0.22) 0, transparent 40%),
    radial-gradient(circle at 10% 90%, rgba(74, 89, 73, 0.18) 0, transparent 50%);
  pointer-events: none;
}
.proof-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.proof-content .section-title { color: var(--color-text-inverse); max-width: 18ch; }
.proof-lede {
  margin-top: var(--space-5);
  font-size: var(--text-lg);
  color: rgba(251, 247, 240, 0.78);
  max-width: 38rem;
}
.proof-lede em { color: #e7b291; font-style: italic; }
.proof-points {
  list-style: none;
  margin-top: var(--space-8);
  display: flex; flex-direction: column; gap: var(--space-4);
}
.proof-points li {
  display: grid; grid-template-columns: 18px 1fr; gap: var(--space-4);
  align-items: start;
  font-size: var(--text-base);
  color: rgba(251, 247, 240, 0.85);
}
.proof-points .bullet {
  margin-top: 0.6em;
  width: 18px; height: 1px; background: var(--color-primary);
}
.proof-content .btn { margin-top: var(--space-8); }

.proof-visual { position: relative; }
.quote-card {
  background: var(--color-deep-2);
  border: 1px solid var(--color-deep-3);
  padding: var(--space-10) var(--space-8);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
}
.quote-card::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(160, 74, 42, 0.18) 0, transparent 50%);
  pointer-events: none;
}
.quote-mark { color: var(--color-primary); opacity: 0.6; margin-bottom: var(--space-4); }
.quote-text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  line-height: 1.3;
  color: var(--color-text-inverse);
  font-weight: 400;
}
.quote-attr {
  margin-top: var(--space-5);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(251, 247, 240, 0.55);
}

@media (max-width: 880px) {
  .proof-grid { grid-template-columns: 1fr; }
}

/* ---------- Portfolio ---------- */
.album-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--space-6);
  margin-bottom: var(--space-12);
}
.album-card {
  position: relative;
  min-height: 460px;
  grid-column: span 6;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--color-deep);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-md);
  isolation: isolate;
}
.album-card--large { grid-column: span 6; }
.album-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.82;
  transition: transform 900ms var(--ease-out), opacity var(--t-base);
}
.album-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(15, 12, 8, 0.02), rgba(15, 12, 8, 0.78)),
    radial-gradient(circle at 12% 90%, rgba(160, 74, 42, 0.28), transparent 44%);
  z-index: 1;
}
.album-card:hover img {
  transform: scale(1.045);
  opacity: 0.9;
}
.album-card__body {
  position: absolute;
  left: var(--space-6);
  right: var(--space-6);
  bottom: var(--space-6);
  z-index: 2;
}
.album-card__body span {
  display: block;
  color: rgba(251, 247, 240, 0.7);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: var(--space-3);
}
.album-card__body h3 {
  color: var(--color-text-inverse);
  font-size: var(--text-xl);
  font-weight: 500;
  margin-bottom: var(--space-3);
}
.album-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.album-card__meta small {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0.35rem 0.65rem;
  border: 1px solid rgba(251, 247, 240, 0.28);
  border-radius: 999px;
  background: rgba(15, 12, 8, 0.24);
  color: rgba(251, 247, 240, 0.82);
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
}
.album-card__body p {
  color: rgba(251, 247, 240, 0.78);
  max-width: 30rem;
  margin-bottom: var(--space-5);
}
.album-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  background: rgba(251, 247, 240, 0.92);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 800;
  transition: transform var(--t-fast), background var(--t-fast);
}
.album-button:hover {
  transform: translateY(-1px);
  background: #fff;
}
.album-system {
  display: grid;
  grid-template-columns: minmax(220px, 0.62fr) minmax(0, 1.38fr);
  gap: var(--space-8);
  align-items: start;
  margin-bottom: var(--space-12);
  padding: var(--space-8);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}
.album-system h3 {
  margin-top: var(--space-3);
  font-size: var(--text-xl);
  font-weight: 500;
  max-width: 13ch;
}
.album-system ol {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  list-style: none;
}
.album-system li {
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-strong);
}
.album-system strong {
  display: block;
  margin-bottom: var(--space-2);
  font-size: var(--text-base);
}
.album-system span {
  display: block;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--space-6);
}
.case {
  grid-column: span 4;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
}

.case--earth, .case--lux { grid-column: span 6; }
.case--green, .case--boho { grid-column: span 6; }
.case--showers { grid-column: span 8; }
.case--cta { grid-column: span 4; background: var(--color-deep); color: var(--color-text-inverse); border-color: var(--color-deep-3); }

.case-image { aspect-ratio: 4 / 3; overflow: hidden; background: var(--color-surface-2); }
.case-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.case-body { padding: var(--space-6) var(--space-6) var(--space-8); }
.case-body--cta {
  height: 100%;
  display: flex; flex-direction: column; justify-content: center; align-items: flex-start;
  padding: var(--space-10) var(--space-8);
  gap: var(--space-4);
}
.case-body--cta p { color: rgba(251, 247, 240, 0.75); }
.case-body--cta .case-title { color: var(--color-text-inverse); }
.case-tag {
  display: inline-block;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-3);
  font-weight: 600;
}
.case-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  line-height: 1.15;
  margin-bottom: var(--space-3);
}
.case-body p { color: var(--color-text-muted); font-size: var(--text-base); }

@media (max-width: 980px) {
  .album-card, .album-card--large { grid-column: span 6; }
  .album-system { grid-template-columns: 1fr; }
  .album-system ol { grid-template-columns: repeat(2, 1fr); }
  .case, .case--earth, .case--green, .case--lux, .case--boho, .case--showers, .case--cta { grid-column: span 6; }
}
@media (max-width: 640px) {
  .album-card, .album-card--large { grid-column: span 12; min-height: 380px; }
  .album-card__body { left: var(--space-5); right: var(--space-5); bottom: var(--space-5); }
  .album-system { padding: var(--space-6); }
  .album-system ol { grid-template-columns: 1fr; }
  .case, .case--earth, .case--green, .case--lux, .case--boho, .case--showers, .case--cta { grid-column: span 12; }
}

/* ---------- Social Proof ---------- */
.section--social-proof {
  background:
    radial-gradient(circle at 12% 18%, rgba(176, 91, 51, 0.12), transparent 32%),
    linear-gradient(135deg, var(--color-surface), var(--color-bg));
  border-block: 1px solid var(--color-border);
}
.social-proof-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(320px, 1.12fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.social-proof-copy .section-title {
  max-width: 13ch;
}
.social-proof-copy .section-lede {
  max-width: 44rem;
}
.social-proof-total {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-8);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border-strong);
  max-width: 34rem;
}
.social-proof-total strong {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 6.25rem);
  line-height: 0.92;
  letter-spacing: -0.06em;
  color: var(--color-primary);
  font-weight: 500;
}
.social-proof-total span {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.45;
  max-width: 15rem;
}
.social-proof-panel {
  display: grid;
  gap: var(--space-4);
}
.social-stat {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) auto;
  grid-template-areas:
    "platform count"
    "meta count"
    "link count";
  align-items: center;
  gap: var(--space-1) var(--space-6);
  padding: clamp(1.25rem, 3vw, 1.75rem);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  background: rgba(255, 252, 247, 0.72);
  color: var(--color-text);
  box-shadow: var(--shadow-sm);
  transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base), background var(--t-base);
}
.social-stat:hover {
  transform: translateY(-3px);
  border-color: rgba(176, 91, 51, 0.42);
  background: rgba(255, 252, 247, 0.95);
  box-shadow: var(--shadow-md);
}
.social-stat__platform {
  grid-area: platform;
  color: var(--color-primary);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 800;
}
.social-stat strong {
  grid-area: count;
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 6vw, 5.25rem);
  line-height: 0.9;
  letter-spacing: -0.055em;
  font-weight: 500;
  color: var(--color-text);
}
.social-stat__meta {
  grid-area: meta;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.social-stat__link {
  grid-area: link;
  margin-top: var(--space-3);
  color: var(--color-text);
  font-size: var(--text-base);
}
.social-stat__link::after {
  content: "→";
  margin-left: 0.4rem;
  color: var(--color-primary);
}
@media (max-width: 900px) {
  .social-proof-grid { grid-template-columns: 1fr; }
  .social-proof-copy .section-title { max-width: 16ch; }
}
@media (max-width: 560px) {
  .social-proof-total {
    align-items: flex-start;
    flex-direction: column;
  }
  .social-stat {
    grid-template-columns: 1fr;
    grid-template-areas:
      "platform"
      "count"
      "meta"
      "link";
  }
}

.album-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
}
.album-modal[hidden] { display: none; }
.album-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 12, 8, 0.72);
  backdrop-filter: blur(10px);
}
.album-modal__dialog {
  position: absolute;
  inset: clamp(1rem, 4vw, 3rem);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  overflow: hidden;
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: 0 34px 100px rgba(0, 0, 0, 0.38);
}
.album-modal__close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  z-index: 3;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: rgba(251, 247, 240, 0.92);
  color: var(--color-text);
  font-size: 1.7rem;
  line-height: 1;
}
.album-modal__media {
  background: var(--color-deep);
  min-height: 70vh;
}
.album-modal__media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.album-modal__content {
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  overflow-y: auto;
}
.album-modal__content span {
  color: var(--color-primary);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: var(--space-4);
}
.album-modal__content h3 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-3);
}
.album-modal__content p {
  color: var(--color-text-muted);
  margin-bottom: var(--space-5);
}
.album-modal__chapters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.album-modal__chapters:empty { display: none; }
.album-modal__chapters button {
  min-height: 36px;
  padding: 0.45rem 0.7rem;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-2);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.album-modal__chapters button.is-active {
  background: var(--color-deep);
  border-color: var(--color-deep);
  color: var(--color-text-inverse);
}
.album-modal__chapters button:hover {
  border-color: var(--color-text-muted);
  color: var(--color-text);
}
.album-modal__chapters button.is-active:hover {
  color: var(--color-text-inverse);
}
.album-modal__scope {
  display: grid;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  list-style: none;
}
.album-modal__scope li {
  position: relative;
  padding-left: var(--space-5);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.45;
}
.album-modal__scope li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 7px;
  height: 1px;
  background: var(--color-primary);
}
.album-modal__thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}
.album-modal__thumbs button {
  overflow: hidden;
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  border: 2px solid transparent;
  background: var(--color-surface-2);
  opacity: 0.62;
  transition: opacity var(--t-fast), border-color var(--t-fast);
}
.album-modal__thumbs button.is-active {
  opacity: 1;
  border-color: var(--color-primary);
}
.album-modal__thumbs button:hover { opacity: 1; }
.album-modal__thumbs img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.album-modal__controls {
  display: flex;
  gap: var(--space-3);
}
.album-modal__controls button {
  flex: 1;
  padding: 0.85rem 1rem;
  border-radius: 999px;
  background: var(--color-deep);
  color: var(--color-text-inverse);
  font-weight: 800;
  font-size: var(--text-sm);
}
@media (max-width: 760px) {
  .album-modal__dialog {
    grid-template-columns: 1fr;
    inset: var(--space-3);
  }
  .album-modal__media { min-height: 38vh; max-height: 42vh; }
  .album-modal__media img { object-fit: cover; }
  .album-modal__content { padding: var(--space-5); }
}

/* Finished tile gallery */
.gallery-proof {
  margin-top: var(--space-12);
  display: grid;
  grid-template-columns: minmax(240px, 0.75fr) minmax(0, 1.25fr);
  gap: var(--space-8);
  align-items: stretch;
}
.gallery-proof__intro {
  background: var(--color-deep);
  color: var(--color-text-inverse);
  border: 1px solid var(--color-deep-3);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 360px;
}
.gallery-proof__intro .kicker { color: #e7b291; }
.gallery-proof__intro h3 {
  color: var(--color-text-inverse);
  font-size: var(--text-xl);
  font-weight: 500;
  line-height: 1.15;
  margin-top: var(--space-4);
}
.gallery-proof__intro p {
  color: rgba(251, 247, 240, 0.72);
  margin-top: var(--space-4);
}
.gallery-proof__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 180px;
  gap: var(--space-4);
}
.gallery-tile {
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}
.gallery-tile--large {
  grid-column: span 2;
  grid-row: span 2;
}
.gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 980px) {
  .gallery-proof { grid-template-columns: 1fr; }
  .gallery-proof__intro { min-height: auto; }
}
@media (max-width: 640px) {
  .gallery-proof__grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 160px;
  }
  .gallery-tile--large {
    grid-column: span 2;
    grid-row: span 2;
  }
}

/* ---------- Trade / who it's for ---------- */
.section--trade { background: var(--color-surface); border-block: 1px solid var(--color-border); }
.trade-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
}
.trade-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex; flex-direction: column; gap: var(--space-3);
  transition: border-color var(--t-base), transform var(--t-base);
}
.trade-card:hover { border-color: var(--color-text); transform: translateY(-3px); }
.trade-icon {
  width: 52px; height: 52px;
  border-radius: 999px;
  background: var(--color-primary-soft);
  color: var(--color-primary);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--space-3);
}
.trade-card h3 { font-size: var(--text-xl); font-weight: 500; }
.trade-card p { color: var(--color-text-muted); }

.link-arrow {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-text);
  margin-top: var(--space-3);
  border-bottom: 1px solid var(--color-text);
  padding-bottom: 4px;
  align-self: flex-start;
}
.link-arrow:hover { color: var(--color-primary); border-bottom-color: var(--color-primary); }
.link-arrow svg { transition: transform var(--t-base); }
.link-arrow:hover svg { transform: translateX(3px); }

/* ---------- Consult / form ---------- */
.section--consult { background: var(--color-bg); }
.consult-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(2.5rem, 6vw, 6rem);
  align-items: start;
}
.consult-copy .section-title { max-width: 14ch; }
.consult-bullets {
  margin-top: var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-3);
  font-size: var(--text-base);
  color: var(--color-text-muted);
}
.consult-bullets li { display: inline-flex; align-items: center; gap: var(--space-3); }
.consult-bullets svg { color: var(--color-primary); flex: none; }

.consult-form {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2.5rem);
  display: flex; flex-direction: column; gap: var(--space-4);
  box-shadow: var(--shadow-md);
}
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.field { display: flex; flex-direction: column; gap: 6px; }
.field label {
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  font-weight: 600;
}
.field .opt { font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--color-text-faint); }

.field input, .field select, .field textarea {
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  padding: 0.85rem 0.95rem;
  font-size: var(--text-base);
  color: var(--color-text);
  transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
  width: 100%;
  font-family: inherit;
}
.field textarea { resize: vertical; min-height: 110px; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(160, 74, 42, 0.12);
}
.field input.invalid, .field select.invalid, .field textarea.invalid {
  border-color: #b3382c;
  background: #faecea;
}
.form-fine {
  font-size: 0.78rem;
  color: var(--color-text-faint);
  margin-top: var(--space-1);
  max-width: none;
}
.form-success {
  background: #e6f0e3;
  color: #2c4a1f;
  border: 1px solid #b5cdac;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}

.jobtread-form-wrap {
  gap: var(--space-6);
}
.jobtread-form-head {
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.jobtread-form-head span {
  display: block;
  color: var(--color-primary);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 800;
  margin-bottom: var(--space-2);
}
.jobtread-form-head p {
  color: var(--color-text-muted);
  max-width: 42rem;
  font-size: var(--text-sm);
  line-height: 1.55;
}
.jobtread-form {
  display: grid;
  gap: var(--space-4);
}
.jobtread-brand {
  display: none;
}
.jobtread-form label {
  display: grid;
  gap: var(--space-2);
  cursor: pointer;
}
.jobtread-form label > span,
.jobtread-checks legend {
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 800;
  line-height: 1.3;
}
.jobtread-form em,
.jobtread-checks em {
  color: var(--color-primary);
  font-style: normal;
  margin-left: 0.15rem;
}
.jobtread-form small {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: 1.45;
}
.jobtread-form input[type="text"],
.jobtread-form input[type="email"],
.jobtread-form input[type="tel"],
.jobtread-form input[type="file"],
.jobtread-form textarea {
  width: 100%;
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  padding: 0.85rem 0.95rem;
  font-size: var(--text-base);
  color: var(--color-text);
  transition: border-color var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
  font-family: inherit;
}
.jobtread-form input[type="file"] {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.jobtread-form textarea {
  resize: vertical;
  min-height: 104px;
}
.jobtread-form input:focus,
.jobtread-form textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(160, 74, 42, 0.12);
  background: var(--color-surface-2);
}
.jobtread-field-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}
.jobtread-checks {
  display: grid;
  gap: var(--space-3);
  border: 0;
  padding: 0;
  margin: 0;
}
.jobtread-checks legend {
  margin-bottom: var(--space-1);
}
.jobtread-checks label {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  transition: border-color var(--t-fast), background var(--t-fast);
}
.jobtread-checks label:hover {
  border-color: rgba(160, 74, 42, 0.45);
  background: var(--color-surface-2);
}
.jobtread-checks input {
  width: 18px;
  height: 18px;
  accent-color: var(--color-primary);
  flex: 0 0 auto;
}
.jobtread-checks label span {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-weight: 600;
}

@media (max-width: 880px) {
  .consult-grid { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .jobtread-field-row { grid-template-columns: 1fr; }
}

/* ---------- FAQ ---------- */
.section--faq { background: var(--color-surface); border-top: 1px solid var(--color-border); }
.faq-wrap { max-width: 920px; margin-inline: auto; }
.faq-list { display: flex; flex-direction: column; }
.faq-item {
  border-top: 1px solid var(--color-border);
  padding-block: var(--space-5);
}
.faq-item:last-of-type { border-bottom: 1px solid var(--color-border); }
.faq-item summary {
  list-style: none;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4);
  cursor: pointer;
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--color-text);
  padding-block: var(--space-2);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item .chev {
  position: relative;
  width: 16px; height: 16px;
  flex: none;
}
.faq-item .chev::before, .faq-item .chev::after {
  content: ""; position: absolute; background: var(--color-text);
  transition: transform var(--t-base);
}
.faq-item .chev::before { left: 0; right: 0; top: 50%; height: 1.5px; transform: translateY(-50%); }
.faq-item .chev::after  { top: 0; bottom: 0; left: 50%; width: 1.5px; transform: translateX(-50%); }
.faq-item[open] .chev::after { transform: translateX(-50%) scaleY(0); }

.faq-body {
  padding-top: var(--space-3);
  color: var(--color-text-muted);
  max-width: 64ch;
}

/* ---------- Closing CTA ---------- */
.section--cta {
  padding-block: clamp(3rem, 6vw, 5rem);
  background: var(--color-deep);
  color: var(--color-text-inverse);
  position: relative;
  overflow: hidden;
}
.section--cta::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 50%, rgba(160, 74, 42, 0.25) 0, transparent 50%);
  pointer-events: none;
}
.cta-band {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) auto;
  align-items: center;
  gap: var(--space-10);
}
.cta-band .section-title { max-width: 22ch; }
@media (max-width: 880px) { .cta-band { grid-template-columns: 1fr; } }

@media (max-width: 560px) {
  .brand-logo {
    width: 148px;
  }
}

/* ---------- Lead retention prompts ---------- */
.lead-modal[hidden],
.mobile-lead-cta {
  display: none;
}
.lead-modal {
  position: fixed;
  inset: 0;
  z-index: 140;
  display: grid;
  place-items: center;
  padding: var(--space-6);
}
.lead-modal__backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 65% 35%, rgba(160, 74, 42, 0.18), transparent 36%),
    rgba(21, 19, 15, 0.58);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.lead-modal__dialog {
  position: relative;
  width: min(100%, 560px);
  padding: clamp(1.6rem, 4vw, 2.6rem);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(145deg, rgba(251, 247, 240, 0.98), rgba(239, 230, 216, 0.98));
  box-shadow: 0 28px 80px rgba(21, 19, 15, 0.28);
  color: var(--color-text);
  transform: translateY(18px) scale(0.98);
  opacity: 0;
  transition:
    opacity 320ms var(--ease-out),
    transform 420ms var(--ease-out);
}
.lead-modal.is-open .lead-modal__dialog {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.lead-modal__close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  background: rgba(31, 28, 23, 0.06);
  font-size: 1.35rem;
  line-height: 1;
  transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.lead-modal__close:hover {
  background: rgba(31, 28, 23, 0.11);
  color: var(--color-text);
  transform: rotate(4deg);
}
.lead-modal__kicker {
  display: inline-flex;
  margin-bottom: var(--space-4);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 700;
}
.lead-modal h2 {
  max-width: 12ch;
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 6vw, 4.3rem);
  line-height: 0.96;
  letter-spacing: -0.04em;
  font-weight: 500;
}
.lead-modal p {
  margin-top: var(--space-5);
  max-width: 34rem;
  color: var(--color-text-muted);
  font-size: var(--text-base);
  line-height: 1.65;
}
.lead-modal__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-6);
}
.lead-modal__phone {
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 700;
  text-decoration: underline;
  text-decoration-color: rgba(160, 74, 42, 0.32);
  text-underline-offset: 0.24em;
}

.mobile-lead-cta {
  position: fixed;
  left: var(--space-4);
  right: var(--space-4);
  bottom: var(--space-4);
  z-index: 95;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 22px;
  background: rgba(21, 19, 15, 0.94);
  color: var(--color-text-inverse);
  box-shadow: 0 18px 44px rgba(21, 19, 15, 0.28);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  opacity: 0;
  transform: translateY(calc(100% + var(--space-6)));
  transition:
    opacity 360ms var(--ease-out),
    transform 420ms var(--ease-out);
}
.mobile-lead-cta span {
  display: grid;
  gap: 0.1rem;
  font-size: 0.82rem;
  line-height: 1.25;
  color: rgba(251, 247, 240, 0.72);
}
.mobile-lead-cta strong {
  color: var(--color-text-inverse);
  font-size: 0.92rem;
}
.mobile-lead-cta svg {
  flex: none;
  color: var(--color-primary);
}
@media (max-width: 760px) {
  .mobile-lead-cta {
    display: flex;
  }
  .mobile-lead-cta.is-visible {
    opacity: 1;
    transform: translateY(0);
  }
  body.has-mobile-lead-cta {
    padding-bottom: 96px;
  }
}
@media (min-width: 761px) {
  .mobile-lead-cta {
    display: none !important;
  }
}

/* ---------- Journal / Articles ---------- */
.journal-hero {
  padding-block: clamp(5rem, 10vw, 8rem) clamp(3rem, 6vw, 5rem);
  background:
    radial-gradient(circle at 18% 24%, rgba(176, 91, 51, 0.12), transparent 32%),
    var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}
.journal-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(280px, 0.72fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
}
.journal-title {
  margin-top: var(--space-5);
  max-width: 12ch;
  font-family: var(--font-display);
  font-size: clamp(3.25rem, 8vw, 7rem);
  line-height: 0.96;
  letter-spacing: -0.04em;
  font-weight: 400;
}
.journal-plan-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.86fr);
  gap: var(--space-6);
}
.journal-plan-card {
  padding: clamp(1.5rem, 4vw, 2.5rem);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
}
.journal-plan-card h2 {
  margin-top: var(--space-3);
  margin-bottom: var(--space-5);
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  line-height: 1;
  letter-spacing: -0.035em;
  font-weight: 500;
}
.journal-plan-card p {
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.journal-plan-card--dark {
  background: var(--color-deep);
  color: var(--color-text-inverse);
  border-color: var(--color-deep-3);
}
.journal-plan-card--dark p {
  color: rgba(251, 247, 240, 0.72);
}
.journal-topic-list {
  display: grid;
  gap: var(--space-3);
}
.journal-topic-list li {
  padding-block: var(--space-3);
  border-top: 1px solid var(--color-border-strong);
  color: var(--color-text-muted);
}
.article-header {
  padding-block: clamp(4rem, 8vw, 7rem);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
}
.article-header-inner { max-width: 860px; }
.article-back {
  display: inline-flex;
  margin-bottom: var(--space-8);
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: 700;
}
.article-header h1 {
  margin-top: var(--space-4);
  max-width: 12ch;
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 6.5rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
  font-weight: 400;
}
.article-dek {
  margin-top: var(--space-6);
  max-width: 42rem;
  font-size: var(--text-lg);
  line-height: 1.55;
  color: var(--color-text-muted);
}
.article-meta {
  margin-top: var(--space-6);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(260px, 0.28fr);
  gap: clamp(2rem, 6vw, 5rem);
  padding-block: clamp(4rem, 8vw, 7rem);
  align-items: start;
}
.article-body { max-width: 760px; }
.article-body p,
.article-body li {
  color: var(--color-text-muted);
  font-size: var(--text-lg);
  line-height: 1.7;
}
.article-body p + p { margin-top: var(--space-5); }
.article-body h2 {
  margin-top: var(--space-12);
  margin-bottom: var(--space-4);
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
  letter-spacing: -0.025em;
  font-weight: 500;
}
.article-cta {
  position: sticky;
  top: 110px;
  padding: var(--space-6);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}
.article-cta h2 {
  margin-top: var(--space-3);
  margin-bottom: var(--space-4);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: 1.05;
  font-weight: 500;
}
.article-cta p {
  margin-bottom: var(--space-5);
  color: var(--color-text-muted);
}
@media (max-width: 900px) {
  .journal-hero-grid,
  .journal-plan-grid,
  .article-layout {
    grid-template-columns: 1fr;
  }
  .article-cta { position: static; }
}

/* ---------- Footer ---------- */
.site-footer {
  background: #15130f;
  color: rgba(251, 247, 240, 0.72);
  padding-block: var(--space-16) var(--space-8);
  font-size: var(--text-sm);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: clamp(2rem, 4vw, 4rem);
  padding-bottom: var(--space-10);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.brand--footer { color: var(--color-text-inverse); }
.brand--footer .brand-name { color: var(--color-text-inverse); }
.brand--footer .brand-sub { color: rgba(251, 247, 240, 0.55); }
.footer-tagline { margin-top: var(--space-4); max-width: 28ch; line-height: 1.55; }

.footer-col h4 {
  font-family: var(--font-body);
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(251, 247, 240, 0.55);
  margin-bottom: var(--space-4);
  font-weight: 600;
}
.footer-col ul { display: flex; flex-direction: column; gap: var(--space-2); }
.footer-col a { color: rgba(251, 247, 240, 0.88); }
.footer-col a:hover { color: var(--color-primary); }
.muted { color: rgba(251, 247, 240, 0.4); }
.contact-list .muted { font-style: italic; }

.social { display: flex; gap: var(--space-3); margin-top: var(--space-5); }
.social-icon {
  width: 38px; height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(251, 247, 240, 0.8);
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.social-icon:hover { background: var(--color-primary); border-color: var(--color-primary); color: var(--color-text-inverse); }

.footer-bottom {
  display: flex; justify-content: space-between; gap: var(--space-4);
  padding-top: var(--space-6);
  font-size: 0.78rem;
  color: rgba(251, 247, 240, 0.45);
  flex-wrap: wrap;
}
.footer-fine { font-size: 0.78rem; }

@media (max-width: 880px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; }
}

/* ---------- Scroll reveal ---------- */
.reveal {
  --reveal-x: 0px;
  --reveal-y: 34px;
  --reveal-scale: 1;
  --reveal-rotate: 0deg;
  --reveal-blur: 8px;
  --reveal-delay: 0ms;
  opacity: 0;
  transform:
    translate3d(var(--reveal-x), var(--reveal-y), 0)
    rotate(var(--reveal-rotate))
    scale(var(--reveal-scale));
  filter: blur(var(--reveal-blur));
  transition:
    opacity 620ms var(--ease-out) var(--reveal-delay),
    transform 820ms var(--ease-out) var(--reveal-delay),
    filter 760ms var(--ease-out) var(--reveal-delay);
  will-change: opacity, transform, filter;
}
.reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
  filter: blur(0);
}
.reveal[data-reveal="fade-up"] {
  --reveal-y: 32px;
}
.reveal[data-reveal="soft-rise"] {
  --reveal-y: 24px;
  --reveal-scale: 0.985;
}
.reveal[data-reveal="problem"] {
  --reveal-y: 36px;
  --reveal-x: -10px;
  --reveal-rotate: -0.7deg;
  --reveal-scale: 0.985;
}
.reveal[data-reveal="problem"].is-visible {
  animation: problem-settle 780ms var(--ease-out) var(--reveal-delay) both;
}
.reveal[data-reveal="ladder"] {
  --reveal-y: 46px;
  --reveal-scale: 0.96;
  transform-origin: top center;
}
.reveal[data-reveal="album"] {
  --reveal-y: 38px;
  --reveal-scale: 0.975;
}
.reveal[data-reveal="alternate-left"] {
  --reveal-x: -44px;
  --reveal-y: 22px;
}
.reveal[data-reveal="alternate-right"] {
  --reveal-x: 44px;
  --reveal-y: 22px;
}
.reveal[data-reveal="flip-left"] {
  --reveal-y: 26px;
  --reveal-blur: 6px;
  transform:
    perspective(900px)
    translate3d(var(--reveal-x), var(--reveal-y), 0)
    rotateY(-14deg)
    scale(0.985);
  transform-origin: left center;
}
.reveal[data-reveal="flip-right"] {
  --reveal-y: 26px;
  --reveal-blur: 6px;
  transform:
    perspective(900px)
    translate3d(var(--reveal-x), var(--reveal-y), 0)
    rotateY(14deg)
    scale(0.985);
  transform-origin: right center;
}
.reveal[data-reveal="flip-left"].is-visible,
.reveal[data-reveal="flip-right"].is-visible {
  transform: perspective(900px) translate3d(0, 0, 0) rotateY(0deg) scale(1);
}
.reveal[data-reveal="cta"] {
  --reveal-y: 22px;
  --reveal-scale: 0.98;
  --reveal-blur: 5px;
}

@keyframes problem-settle {
  0% {
    opacity: 0;
    transform: translate3d(-18px, 36px, 0) rotate(-0.9deg) scale(0.985);
    filter: blur(8px);
  }
  46% {
    opacity: 1;
    transform: translate3d(9px, -4px, 0) rotate(0.35deg) scale(1.004);
    filter: blur(0);
  }
  67% {
    transform: translate3d(-4px, 2px, 0) rotate(-0.18deg) scale(1);
  }
  84% {
    transform: translate3d(2px, 0, 0) rotate(0.08deg) scale(1);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
    filter: blur(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .scroll-progress span {
    box-shadow: none;
  }
  .reveal,
  .reveal[data-reveal],
  .reveal.is-visible,
  .reveal[data-reveal].is-visible {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    animation: none !important;
    transition: none !important;
  }
}
