/* ============================================================
   Design hub — premium light redesign (loaded last, overrides
   the legacy design-* layers in theme.css).
   Aesthetic: warm editorial light, large Cormorant headings,
   generous whitespace, big imagery, restrained gold accents.
   ============================================================ */

body.design-hub-page {
  --design-page-max: 1200px;
  --d-bg: #f5efe6;
  --d-bg-warm: #efe7da;
  --d-ink: #1d1a15;
  --d-ink-soft: #4a443b;
  --d-muted: #837a6c;
  --d-line: rgba(29, 26, 21, .12);
  --d-line-soft: rgba(29, 26, 21, .07);
  --d-gold: #ab7f4e;
  --d-gold-soft: rgba(171, 127, 78, .16);
  --d-surface: #fffdf9;
  --d-shadow: 0 24px 60px -28px rgba(40, 30, 18, .32);

  background:
    radial-gradient(1100px 640px at 50% -12%, rgba(171, 127, 78, .10), transparent 62%),
    radial-gradient(900px 600px at 100% 8%, rgba(120, 110, 92, .07), transparent 60%),
    var(--d-bg) !important;
  color: var(--d-ink);
}

body.design-hub-page ::selection {
  background: rgba(171, 127, 78, .22);
}

/* ---------- Section rhythm & container ---------- */
body.design-hub-page .design-section,
body.design-hub-page .design-final {
  width: min(var(--design-page-max), calc(100% - 48px));
  margin-left: auto !important;
  margin-right: auto !important;
  padding: clamp(64px, 9vw, 132px) 0;
}

body.design-hub-page .design-section--muted {
  width: 100%;
  padding: clamp(64px, 9vw, 132px) max(24px, calc((100% - var(--design-page-max)) / 2));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .5), rgba(255, 253, 249, .2)),
    var(--d-bg-warm);
  border-top: 1px solid var(--d-line-soft);
  border-bottom: 1px solid var(--d-line-soft);
}

/* ---------- Eyebrow ---------- */
body.design-hub-page .design-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 18px;
  color: var(--d-gold);
  font-family: var(--font-sans);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .32em;
  text-transform: uppercase;
}

body.design-hub-page .design-eyebrow::before {
  content: "";
  width: 30px;
  height: 1px;
  background: currentColor;
  opacity: .7;
}

/* ---------- Section heads ---------- */
body.design-hub-page .design-section__head {
  max-width: 760px;
  margin: 0 auto clamp(40px, 5vw, 64px);
  text-align: center;
}

body.design-hub-page .design-section__head .design-eyebrow {
  justify-content: center;
}

body.design-hub-page .design-section__head--left {
  margin: 0;
  text-align: left;
}

body.design-hub-page .design-section__head--left .design-eyebrow {
  justify-content: flex-start;
}

body.design-hub-page .design-section__head h2,
body.design-hub-page .design-final h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.3rem, 4.6vw, 3.9rem);
  line-height: 1.04;
  letter-spacing: .003em;
  color: var(--d-ink);
}

body.design-hub-page .design-section__head p {
  margin: 22px auto 0;
  max-width: 560px;
  color: var(--d-muted);
  font-size: 1.06rem;
  line-height: 1.6;
}

body.design-hub-page .design-section__head--left p {
  margin-left: 0;
  margin-right: 0;
}

body.design-hub-page .design-section__head .design-btn {
  margin-top: 30px;
}

/* ---------- Direction nav ---------- */
body.design-hub-page .design-context {
  position: sticky;
  top: 82px;
  z-index: 72;
  width: fit-content;
  max-width: calc(100% - 32px);
  margin: 10px auto -18px;
  padding: 5px;
  border: 1px solid var(--d-line-soft);
  border-radius: 999px;
  background: rgba(255, 253, 249, .78);
  box-shadow: 0 16px 40px -30px rgba(40, 30, 18, .42);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

body.design-hub-page .design-context__inner {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 7px;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

body.design-hub-page .design-context__parent {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 30px;
  padding: 0 11px;
  border: 0;
  border-radius: 999px;
  background: var(--d-ink);
  color: var(--d-ink);
  text-decoration: none;
}

body.design-hub-page .design-context__parent span {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
  color: var(--d-muted);
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}

body.design-hub-page .design-context__parent strong {
  color: var(--d-surface);
  font-family: var(--font-sans);
  font-size: .74rem;
  font-weight: 800;
}

body.design-hub-page .design-context__links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: auto;
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
}

body.design-hub-page .design-context__links::-webkit-scrollbar {
  display: none;
}

body.design-hub-page .design-context__links a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 11px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
  color: var(--d-ink-soft);
  font-size: .74rem;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}

body.design-hub-page .design-context__links a:hover,
body.design-hub-page .design-context__links a[aria-current="page"],
body.design-hub-page .design-context__links a[aria-current="true"],
body.design-hub-page .design-context__links a.is-active {
  color: var(--d-ink);
  border-color: transparent;
  background: var(--d-gold-soft);
  box-shadow: none;
}

/* ---------- Buttons ---------- */
body.design-hub-page .design-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 28px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-family: var(--font-sans);
  font-size: .92rem;
  font-weight: 600;
  letter-spacing: .01em;
  text-decoration: none;
  transition: transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease, box-shadow .25s ease;
}

body.design-hub-page .design-btn--primary {
  background: var(--d-ink);
  color: #f7f1e6;
  box-shadow: 0 16px 32px -18px rgba(29, 26, 21, .7);
}

body.design-hub-page .design-btn--primary:hover {
  transform: translateY(-2px);
  background: #2c2820;
  box-shadow: 0 22px 40px -18px rgba(29, 26, 21, .75);
}

body.design-hub-page .design-btn--light,
body.design-hub-page .design-btn--ghost {
  background: transparent;
  color: var(--d-ink);
  border-color: var(--d-line);
}

body.design-hub-page .design-btn--light:hover,
body.design-hub-page .design-btn--ghost:hover {
  transform: translateY(-2px);
  border-color: var(--d-gold);
  color: var(--d-gold);
  background: rgba(171, 127, 78, .06);
}

/* ---------- Card link (route) ---------- */
body.design-hub-page .design-card-link {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-top: auto;
  padding-top: 18px;
  color: var(--d-gold);
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .01em;
}

body.design-hub-page .design-card-link i {
  transition: transform .25s ease;
}

body.design-hub-page .design-route-card:hover .design-card-link i {
  transform: translateX(5px);
}

/* ---------- Card labels & chips ---------- */
body.design-hub-page .design-card-label {
  display: inline-flex;
  width: fit-content;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--d-gold);
  font-family: var(--font-sans);
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
}

/* ---------- Generic surface cards ---------- */
body.design-hub-page .design-route-card,
body.design-hub-page .design-feature-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--d-line-soft);
  border-radius: 20px;
  background: var(--d-surface);
  box-shadow: var(--d-shadow);
}

body.design-hub-page .design-route-card h3,
body.design-hub-page .design-feature-card h3 {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--d-ink);
  letter-spacing: 0;
}

body.design-hub-page .design-route-card p,
body.design-hub-page .design-feature-card p {
  color: var(--d-muted);
  line-height: 1.58;
}

/* ---------- Route grid (Выберите формат) ---------- */
body.design-hub-page .design-route-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  width: min(100%, var(--design-page-max));
  margin-left: auto;
  margin-right: auto;
}

body.design-hub-page .design-route-card {
  gap: 12px;
  min-height: 220px;
  padding: 32px 30px;
}

body.design-hub-page .design-route-card h3 {
  font-size: 1.5rem;
  line-height: 1.12;
  margin: 6px 0 0;
}

body.design-hub-page .design-route-card p {
  font-size: .94rem;
  margin: 0;
}

body.design-hub-page .design-route-card--main {
  background:
    linear-gradient(135deg, rgba(171, 127, 78, .12), rgba(255, 253, 249, .4)),
    var(--d-surface);
  border-color: var(--d-gold-soft);
}

body.design-hub-page .design-route-card:hover {
  transform: translateY(-6px);
  border-color: var(--d-gold-soft);
  box-shadow: 0 32px 70px -30px rgba(40, 30, 18, .42);
}

body.design-hub-page .design-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: auto;
  padding-top: 8px;
}

/* ---------- Process (Практика) ---------- */
body.design-hub-page .design-process-grid {
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr);
  gap: clamp(36px, 5vw, 72px);
  align-items: center;
}

body.design-hub-page .design-feature-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

body.design-hub-page .design-feature-card {
  gap: 10px;
  min-height: 0;
  padding: 28px 26px;
}

body.design-hub-page .design-feature-card i {
  margin-bottom: 8px;
  font-size: 1.3rem;
  color: var(--d-gold);
}

body.design-hub-page .design-feature-card h3 {
  font-size: 1.2rem;
  margin: 0;
}

body.design-hub-page .design-feature-card p {
  font-size: .92rem;
  margin: 0;
}

/* ---------- FAQ ---------- */
body.design-hub-page .design-faq-list {
  max-width: 820px;
  margin: 0 auto;
  display: grid;
  gap: 12px;
}

body.design-hub-page .design-faq-list details {
  border: 1px solid var(--d-line-soft);
  border-radius: 16px;
  background: var(--d-surface);
  box-shadow: 0 14px 36px -28px rgba(40, 30, 18, .3);
  overflow: hidden;
}

body.design-hub-page .design-faq-list summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 26px;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--d-ink);
}

body.design-hub-page .design-faq-list summary::-webkit-details-marker {
  display: none;
}

body.design-hub-page .design-faq-list summary::after {
  content: "\002B";
  flex-shrink: 0;
  color: var(--d-gold);
  font-size: 1.3rem;
  font-weight: 400;
  transition: transform .25s ease;
}

body.design-hub-page .design-faq-list details[open] summary::after {
  transform: rotate(45deg);
}

body.design-hub-page .design-faq-list p {
  margin: 0;
  padding: 0 26px 24px;
  color: var(--d-muted);
  line-height: 1.6;
}

/* ---------- Final CTA (dark closing band) ---------- */
body.design-hub-page .design-final {
  display: block;
  text-align: center;
  margin-bottom: clamp(48px, 7vw, 96px);
  padding: clamp(56px, 7vw, 104px) clamp(24px, 5vw, 80px);
  border-radius: 30px;
  background:
    radial-gradient(700px 400px at 50% -10%, rgba(171, 127, 78, .22), transparent 62%),
    linear-gradient(150deg, #221c14, #14110c);
  color: #fdf7ec;
}

body.design-hub-page .design-final .design-eyebrow {
  justify-content: center;
  color: #e6c79c;
}

body.design-hub-page .design-final__copy {
  max-width: 720px;
  margin: 0 auto;
}

body.design-hub-page .design-final h2 {
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  color: #fdf7ec;
}

body.design-hub-page .design-final__copy p {
  margin: 20px auto 0;
  max-width: 520px;
  color: rgba(255, 248, 236, .76);
  font-size: 1.08rem;
  line-height: 1.6;
}

body.design-hub-page .design-final__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  margin-top: 38px;
}

body.design-hub-page .design-final__actions .design-btn--primary {
  background: #fdf7ec;
  color: #1d1a15;
}

body.design-hub-page .design-final__actions .design-btn--primary:hover {
  background: #fff;
}

body.design-hub-page .design-final__actions .design-btn--light {
  color: #fdf7ec;
  border-color: rgba(255, 248, 236, .38);
}

body.design-hub-page .design-final__actions .design-btn--light:hover {
  border-color: #fdf7ec;
  color: #fff;
  background: rgba(255, 255, 255, .08);
}

body.design-hub-page .design-contact-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px 28px;
  margin-top: 52px;
  padding-top: 32px;
  border-top: 1px solid rgba(255, 248, 236, .16);
  color: rgba(255, 248, 236, .68);
  font-size: .92rem;
}

body.design-hub-page .design-contact-strip a,
body.design-hub-page .design-contact-strip span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(255, 248, 236, .72);
  text-decoration: none;
}

body.design-hub-page .design-contact-strip a:hover {
  color: #e6c79c;
}

/* ---------- Local nav ---------- */
body.design-hub-page .design-local-nav {
  width: min(var(--design-page-max), calc(100% - 48px));
  margin: -28px auto 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px;
  border: 1px solid var(--d-line-soft);
  border-radius: 999px;
  background: rgba(255, 253, 249, .82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 18px 44px -30px rgba(40, 30, 18, .4);
}

body.design-hub-page .design-local-nav a {
  padding: 9px 18px;
  border-radius: 999px;
  color: var(--d-ink-soft);
  font-size: .86rem;
  font-weight: 500;
  text-decoration: none;
  transition: background .2s ease, color .2s ease;
}

body.design-hub-page .design-local-nav a:hover {
  background: rgba(171, 127, 78, .1);
  color: var(--d-gold);
}

/* ---------- Hero ---------- */
body.design-hub-page .design-hero {
  position: relative;
  min-height: clamp(560px, 82vh, 760px);
  display: flex;
  align-items: flex-end;
  padding: 130px 0 70px;
  overflow: hidden;
}

body.design-hub-page .design-hero__media {
  position: absolute;
  left: 0;
  right: 0;
  top: -100px;
  height: calc(100% + 240px);
  transform: translate3d(0, var(--parallax-y, 0px), 0);
  will-change: transform;
}

body.design-hub-page .design-hero__media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.design-hub-page .design-hero__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(20, 16, 11, .28) 0%, rgba(20, 16, 11, .12) 38%, rgba(20, 16, 11, .82) 100%),
    linear-gradient(90deg, rgba(20, 16, 11, .5), transparent 60%);
}

body.design-hub-page .design-hero__inner {
  position: relative;
  z-index: 2;
  width: min(var(--design-page-max), calc(100% - 48px));
  margin: 0 auto;
}

body.design-hub-page .design-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 26px;
  color: rgba(255, 248, 236, .6);
  font-size: .82rem;
}

body.design-hub-page .design-breadcrumb a {
  color: rgba(255, 248, 236, .82);
  text-decoration: none;
}

body.design-hub-page .design-breadcrumb a:hover {
  color: #fff;
}

body.design-hub-page .design-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: clamp(32px, 5vw, 72px);
  align-items: end;
}

body.design-hub-page .design-hero__copy .design-eyebrow {
  color: #e6c79c;
}

body.design-hub-page .design-hero h1 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.8rem, 6vw, 5.6rem);
  line-height: .98;
  letter-spacing: .004em;
  text-align: left;
  color: #fdf7ec;
}

body.design-hub-page .design-lead {
  margin: 24px 0 0;
  max-width: 480px;
  color: rgba(255, 248, 236, .82);
  font-size: 1.12rem;
  line-height: 1.55;
}

body.design-hub-page .design-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 34px;
}

body.design-hub-page .design-hero__actions .design-btn--primary {
  background: #fdf7ec;
  color: #1d1a15;
}

body.design-hub-page .design-hero__actions .design-btn--primary:hover {
  background: #fff;
}

body.design-hub-page .design-hero__actions .design-btn--light {
  color: #fdf7ec;
  border-color: rgba(255, 248, 236, .4);
}

body.design-hub-page .design-hero__actions .design-btn--light:hover {
  border-color: #fdf7ec;
  color: #fff;
  background: rgba(255, 255, 255, .08);
}

body.design-hub-page .design-hero__panel {
  padding: 26px 28px;
  border: 1px solid rgba(255, 248, 236, .18);
  border-radius: 18px;
  background: rgba(28, 22, 15, .42);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

body.design-hub-page .design-hero__panel span {
  display: block;
  margin-bottom: 16px;
  color: #e6c79c;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .26em;
  text-transform: uppercase;
}

body.design-hub-page .design-hero__panel ul {
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

body.design-hub-page .design-hero__panel li {
  display: flex;
  align-items: center;
  gap: 12px;
  color: rgba(255, 248, 236, .9);
  font-size: .98rem;
}

body.design-hub-page .design-hero__panel li i {
  width: 20px;
  color: #e6c79c;
  text-align: center;
}

/* ---------- Parallax gallery (Работы учеников) ---------- */
body.design-hub-page .design-gallery {
  position: relative;
  width: 100%;
  min-height: clamp(580px, 88vh, 860px);
  display: grid;
  place-items: center;
  overflow: hidden;
  isolation: isolate;
  background: #14110c;
}

body.design-hub-page .design-gallery__track {
  position: absolute;
  inset: -16% 0;
  left: 0;
  right: 0;
  z-index: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  width: min(1400px, 100%);
  margin: 0 auto;
  padding: 0 20px;
}

body.design-hub-page .design-gallery__col {
  display: grid;
  gap: 20px;
  align-content: start;
  transform: translate3d(0, var(--parallax-y, 0px), 0);
  will-change: transform;
}

body.design-hub-page .design-gallery__col--b {
  margin-top: 9%;
}

body.design-hub-page .design-gallery__col--c {
  margin-top: 3%;
}

body.design-hub-page .design-gallery__col img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 14px;
  box-shadow: 0 30px 60px -30px rgba(0, 0, 0, .7);
}

body.design-hub-page .design-gallery__veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(130% 92% at 50% 50%, rgba(18, 14, 9, .5) 0%, rgba(18, 14, 9, .84) 70%, rgba(18, 14, 9, .95) 100%);
}

body.design-hub-page .design-gallery__copy {
  position: relative;
  z-index: 2;
  max-width: 620px;
  padding: 0 24px;
  text-align: center;
}

body.design-hub-page .design-gallery__copy .design-eyebrow {
  justify-content: center;
  color: #e6c79c;
}

body.design-hub-page .design-gallery__copy h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  line-height: 1.02;
  color: #fdf7ec;
}

body.design-hub-page .design-gallery__copy p {
  margin: 22px auto 0;
  max-width: 440px;
  color: rgba(255, 248, 236, .78);
  font-size: 1.06rem;
  line-height: 1.55;
}

body.design-hub-page .design-gallery__copy .design-btn {
  margin-top: 30px;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  body.design-hub-page .design-process-grid {
    grid-template-columns: 1fr;
    align-items: start;
  }
  body.design-hub-page .design-hero__grid {
    grid-template-columns: 1fr;
    align-items: start;
  }
  body.design-hub-page .design-hero__panel {
    max-width: 420px;
  }
}

@media (max-width: 720px) {
  body.design-hub-page .design-context {
    top: 74px;
    max-width: calc(100% - 20px);
    margin-top: 8px;
    padding: 5px;
  }
  body.design-hub-page .design-context__links {
    justify-content: flex-start;
  }
  body.design-hub-page .design-context__links a {
    min-height: 30px;
    padding: 0 10px;
  }
  body.design-hub-page .design-section,
  body.design-hub-page .design-final {
    width: min(var(--design-page-max), calc(100% - 32px));
    padding: clamp(48px, 11vw, 80px) 0;
  }
  body.design-hub-page .design-section--muted {
    padding-left: 16px;
    padding-right: 16px;
  }
  body.design-hub-page .design-section__head {
    margin-bottom: clamp(28px, 7vw, 40px);
  }
  body.design-hub-page .design-local-nav {
    width: min(var(--design-page-max), calc(100% - 32px));
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
  }
  body.design-hub-page .design-local-nav::-webkit-scrollbar {
    display: none;
  }
  /* Single column for the offer cards (clear CTAs) */
  body.design-hub-page .design-route-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  body.design-hub-page .design-route-card {
    min-height: 0;
    padding: 26px 22px;
  }
  body.design-hub-page .design-route-card h3 {
    font-size: 1.32rem;
  }
  /* Keep feature cards 2-up so the page stays short */
  body.design-hub-page .design-feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }
  body.design-hub-page .design-feature-card {
    padding: 22px 18px;
  }
  body.design-hub-page .design-feature-card h3 {
    font-size: 1.05rem;
  }
  body.design-hub-page .design-feature-card p {
    font-size: .86rem;
  }

  /* Gallery: 2 columns on mobile, shorter scene */
  body.design-hub-page .design-gallery {
    min-height: clamp(460px, 78vh, 620px);
  }
  body.design-hub-page .design-gallery__track {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    inset: -20% 0;
  }
  body.design-hub-page .design-gallery__col--c {
    display: none;
  }
  body.design-hub-page .design-gallery__col--b {
    margin-top: 16%;
  }
  body.design-hub-page .design-gallery__col img {
    aspect-ratio: 3 / 4;
    border-radius: 10px;
  }
}

@media (max-width: 420px) {
  body.design-hub-page .design-feature-card p {
    display: none;
  }
}

/* ============================================================
   Compact rhythm tuning.
   Keeps the design overview premium, but less oversized and airy.
   ============================================================ */
body.design-hub-page .design-section,
body.design-hub-page .design-final {
  padding-top: clamp(48px, 6.5vw, 88px);
  padding-bottom: clamp(48px, 6.5vw, 88px);
}

body.design-hub-page .design-section--muted {
  padding-top: clamp(48px, 6.5vw, 88px);
  padding-bottom: clamp(48px, 6.5vw, 88px);
}

body.design-hub-page .design-section__head {
  margin-bottom: clamp(28px, 4vw, 44px);
}

body.design-hub-page .design-section__head h2,
body.design-hub-page .design-final h2,
body.design-hub-page .design-gallery__copy h2 {
  font-size: clamp(1.75rem, 3vw, 2.65rem) !important;
  line-height: 1.08 !important;
}

body.design-hub-page .design-hero {
  min-height: clamp(500px, 72vh, 680px);
  padding-top: 110px;
  padding-bottom: 56px;
}

body.design-hub-page .design-hero h1 {
  font-size: clamp(2.35rem, 5vw, 4.35rem) !important;
  line-height: 1 !important;
}

body.design-hub-page .design-section__head p,
body.design-hub-page .design-lead,
body.design-hub-page .design-gallery__copy p {
  font-size: .98rem;
}

body.design-hub-page .design-route-card,
body.design-hub-page .design-feature-card {
  padding: 24px;
}

body.design-hub-page .design-route-card {
  min-height: 190px;
}

body.design-hub-page .design-final {
  margin-bottom: clamp(32px, 5vw, 64px);
  padding: clamp(38px, 5vw, 68px);
}

/* ============================================================
   Hub — restrained scroll parallax (2026-06). The hero/gallery already
   drift; per user this page stays the calmest of the four, so we only add
   soft gold washes + a couple floating chips behind courses / process /
   contact. No photo panels — keeps the "generous whitespace, restrained
   gold" character. Driven by app.js (--parallax-y / --parallax-rotate);
   it bails under prefers-reduced-motion.
   ============================================================ */
body.design-hub-page .design-hub-bg,
body.design-hub-page .design-hub-note {
  transform:
    translate3d(0, var(--parallax-y, 0px), 0)
    rotate(var(--parallax-rotate, 0deg));
  will-change: transform;
}
body.design-hub-page #courses,
body.design-hub-page #process,
body.design-hub-page #contact {
  position: relative;
  overflow: hidden;
}
body.design-hub-page #courses > :not(.design-hub-bg):not(.design-hub-note),
body.design-hub-page #process > :not(.design-hub-bg):not(.design-hub-note),
body.design-hub-page #contact > :not(.design-hub-bg):not(.design-hub-note) {
  position: relative;
  z-index: 1;
}
body.design-hub-page .design-hub-bg {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  border-radius: 999px;
  background:
    radial-gradient(ellipse at 42% 44%, rgba(171, 127, 78, .14), transparent 62%),
    radial-gradient(ellipse at 70% 58%, rgba(131, 122, 108, .08), transparent 66%);
  filter: blur(22px);
}
body.design-hub-page .design-hub-note {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 14px;
  border: 1px solid rgba(171, 127, 78, .22);
  border-radius: 999px;
  background: rgba(255, 253, 249, .72);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  color: var(--d-gold);
  box-shadow: 0 16px 38px -26px rgba(40, 30, 18, .4);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .13em;
  text-transform: uppercase;
  pointer-events: none;
}
body.design-hub-page .design-hub-bg--courses {
  right: -12%;
  top: -10%;
  width: clamp(440px, 50vw, 820px);
  height: clamp(250px, 30vw, 480px);
}
body.design-hub-page .design-hub-note--courses {
  left: 4%;
  top: 6%;
}
body.design-hub-page .design-hub-bg--process {
  left: -14%;
  bottom: -12%;
  width: clamp(440px, 52vw, 860px);
  height: clamp(250px, 30vw, 480px);
}
body.design-hub-page .design-hub-note--process {
  right: 5%;
  top: 7%;
}
body.design-hub-page .design-hub-bg--contact {
  left: 50%;
  top: -16%;
  translate: -50% 0;
  width: clamp(480px, 56vw, 940px);
  height: clamp(260px, 32vw, 520px);
}
body.design-hub-page .design-hub-note--contact {
  left: 6%;
  bottom: 12%;
}
@media (max-width: 900px) {
  /* Drop decorative parallax on phones: lighter scroll + the wide washes were
     overflowing the viewport (horizontal scroll). Content/hero drift stays. */
  body.design-hub-page .design-hub-bg,
  body.design-hub-page .design-hub-note {
    display: none;
  }
}
