/* 梦想家 / 超好住 unified atelier design system
   Direction: editorial, quiet luxury, warm architectural minimalism. */

:root {
  --ds-bg: #f6f1e8;
  --ds-paper: #fffcf6;
  --ds-paper-2: #f1eae0;
  --ds-ink: #141414;
  --ds-ink-2: #272522;
  --ds-muted: #716b62;
  --ds-soft: #9b948a;
  --ds-line: rgba(20, 20, 20, .085);
  --ds-line-strong: rgba(20, 20, 20, .14);
  --ds-gold: #b69a72;
  --ds-gold-dark: #826846;
  --ds-gold-soft: rgba(182, 154, 114, .14);
  --ds-shadow: 0 30px 90px rgba(36, 30, 24, .10);
  --ds-shadow-soft: 0 16px 44px rgba(36, 30, 24, .07);
  --ds-radius-xl: 34px;
  --ds-radius-lg: 24px;
  --ds-radius-md: 16px;
  --ds-nav-h: 88px;

  --brand: var(--ds-gold);
  --brand-2: #d8c7ae;
  --brand-dark: var(--ds-gold-dark);
  --deep: var(--ds-ink);
  --deep-2: var(--ds-ink-2);
  --cream: var(--ds-bg);
  --primary: var(--ds-gold);
  --primary-dark: var(--ds-gold-dark);
  --primary-light: #d8c7ae;
  --primary-bg: var(--ds-gold-soft);
  --bg-page: var(--ds-bg);
  --bg-light: var(--ds-paper);
  --bg-white: var(--ds-paper);
  --bg-card: rgba(255, 252, 246, .78);
  --bg-accent: var(--ds-paper-2);
  --text-primary: var(--ds-ink);
  --text-dark: var(--ds-ink);
  --text-main: var(--ds-ink);
  --text-secondary: var(--ds-muted);
  --text-sec: var(--ds-muted);
  --text-muted: var(--ds-soft);
  --border: var(--ds-line);
}

* {
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

html {
  background: var(--ds-bg) !important;
}

body {
  margin: 0 !important;
  color: var(--ds-ink) !important;
  background:
    radial-gradient(circle at 78% 12%, rgba(182, 154, 114, .09), transparent 30%),
    radial-gradient(circle at 10% 34%, rgba(20, 20, 20, .035), transparent 32%),
    linear-gradient(180deg, #fbf7ef 0%, #f4eee4 48%, #fbf7ef 100%) !important;
  font-family: "Inter", "SF Pro Display", "PingFang SC", "Microsoft YaHei", -apple-system, BlinkMacSystemFont, system-ui, sans-serif !important;
  line-height: 1.7 !important;
}

body::before,
body::after {
  opacity: .12 !important;
}

a {
  color: inherit;
  text-decoration: none !important;
}

img {
  max-width: 100%;
}

.container,
.footer-container,
.cases-container,
.social-container,
.promises-container,
.switcher-container {
  width: min(1180px, calc(100% - 56px)) !important;
  max-width: 1180px !important;
  margin-inline: auto !important;
}

/* Navigation: one exact component across desktop pages. */
.site-header,
.nav,
.header {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  min-height: var(--ds-nav-h) !important;
  height: var(--ds-nav-h) !important;
  padding: 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--ds-line) !important;
  background: rgba(246, 241, 232, .86) !important;
  box-shadow: none !important;
  backdrop-filter: blur(24px) saturate(120%) !important;
}

.site-header .nav,
nav.nav {
  position: relative !important;
  top: auto !important;
  display: flex !important;
  width: min(1180px, calc(100% - 56px)) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 34px !important;
  border-bottom: 0 !important;
  background: transparent !important;
  backdrop-filter: none !important;
}

.brand,
.nav-logo,
.header-logo {
  display: inline-flex !important;
  height: 48px !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 0 !important;
  color: var(--ds-ink) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: -.035em !important;
  white-space: nowrap !important;
}

.brand-mark {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  color: var(--ds-paper) !important;
  background: var(--ds-ink) !important;
  box-shadow: none !important;
  font-size: 13px !important;
  letter-spacing: -.04em !important;
}

.nav-links {
  display: flex !important;
  height: 56px !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 4px !important;
  border: 1px solid var(--ds-line) !important;
  border-radius: 999px !important;
  background: rgba(255, 252, 246, .58) !important;
  box-shadow: none !important;
}

.nav-link,
.nav-links a,
.nav-cta {
  display: inline-flex !important;
  height: 46px !important;
  min-height: 46px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 20px !important;
  border: 0 !important;
  border-radius: 999px !important;
  color: var(--ds-muted) !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  letter-spacing: -.018em !important;
  white-space: nowrap !important;
  transform: none !important;
}

.nav-link:hover,
.nav-links a:hover,
.nav-link.active,
.nav-links a.active {
  color: var(--ds-ink) !important;
  background: rgba(20, 20, 20, .055) !important;
  transform: none !important;
}

.nav-cta,
.nav-links .reserve {
  margin-left: 8px !important;
  min-width: 122px !important;
  color: var(--ds-paper) !important;
  background: var(--ds-ink) !important;
}

.nav-cta:hover,
.nav-links .reserve:hover,
.nav-cta.active {
  color: var(--ds-paper) !important;
  background: var(--ds-ink-2) !important;
}

.menu-btn,
.nav-menu-btn,
.mobile-menu-btn,
.header-btn,
.header-back {
  display: none;
  width: 44px !important;
  height: 44px !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid var(--ds-line) !important;
  border-radius: 999px !important;
  color: var(--ds-ink) !important;
  background: rgba(255, 252, 246, .70) !important;
  box-shadow: none !important;
}

/* Typography. */
h1,
h2,
h3,
.page-title,
.banner-title,
.section-title,
.product-detail-name,
.product-banner-name,
.product-name,
.contact-hero-title,
.hero-title,
.community-title,
.social-title,
.faq-title,
.cta-title {
  color: var(--ds-ink) !important;
  font-weight: 760 !important;
  letter-spacing: -.06em !important;
}

h1,
.page-title,
.banner-title,
.hero-title {
  line-height: .98 !important;
}

h2,
.section-title {
  line-height: 1.06 !important;
}

p,
.page-subtitle,
.banner-desc,
.banner-subtitle,
.section-subtitle,
.hero-lead,
.product-detail-slogan,
.product-banner-slogan,
.product-slogan,
.advantage-desc,
.system-desc,
.step-desc,
.promise-desc,
.footer-desc,
.footer-text {
  color: var(--ds-muted) !important;
  font-weight: 400 !important;
}

.eyebrow,
.section-tag,
.page-tag,
.banner-tag,
.product-detail-tag,
.product-banner-tag,
.product-tag,
.geo-local-trust__eyebrow {
  color: var(--ds-gold-dark) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

.highlight,
.hero-title span,
.price,
.product-detail-price-value,
.product-banner-price-value,
.price-value,
.count,
.data-value,
.stat-value,
.path-number {
  color: var(--ds-gold-dark) !important;
}

/* Hero and page headers. */
.hero,
.page-header,
.page-banner,
.product-banner,
.product-hero,
.page-hero,
.contact-page,
.contact-hero {
  border: 0 !important;
  border-bottom: 1px solid var(--ds-line) !important;
  background:
    radial-gradient(circle at 78% 18%, rgba(182, 154, 114, .10), transparent 30%),
    linear-gradient(180deg, #fbf7ef 0%, #f1e9de 100%) !important;
  box-shadow: none !important;
}

.hero {
  padding-top: 120px !important;
}

.hero-visual {
  background: rgba(255, 252, 246, .62) !important;
}

.hero-visual::before {
  opacity: .16 !important;
}

/* Cards and sections. */
.section,
.systems-section,
.brand-section,
.partners-section,
.faq-section,
.promises-section,
.modules-section,
.values-section,
.team-section,
.cases-section,
.social-section,
.story-section {
  background: transparent !important;
}

.visual-card,
.stats,
.trust-grid,
.path-card,
.product-card,
.package-card,
.product-detail,
.advantage-card,
.module-card,
.system-card,
.system-item,
.partner-card,
.promise-card,
.step-card,
.process-step,
.step,
.experience-card,
.center-card,
.case-info-card,
.case-grid-item,
.social-card,
.data-card,
.value-card,
.team-card,
.story-card,
.contact-option,
.method-card,
.info-item,
.faq-item,
.faq-question,
.geo-local-trust,
.geo-local-trust__card,
.geo-card,
.geo-copy,
.brand-table-wrapper,
.comparison-table-wrapper,
.contact-qrcode,
.qr-section,
.product-switcher,
.switcher {
  border: 1px solid var(--ds-line) !important;
  border-radius: var(--ds-radius-lg) !important;
  background: rgba(255, 252, 246, .70) !important;
  box-shadow: none !important;
}

.path-card:hover,
.product-card:hover,
.package-card:hover,
.advantage-card:hover,
.module-card:hover,
.system-card:hover,
.system-item:hover,
.partner-card:hover,
.promise-card:hover,
.step-card:hover,
.experience-card:hover,
.center-card:hover,
.team-card:hover,
.value-card:hover,
.data-card:hover,
.contact-option:hover,
.method-card:hover {
  transform: translateY(-6px) !important;
  border-color: var(--ds-line-strong) !important;
  box-shadow: var(--ds-shadow-soft) !important;
}

.products-section,
.feature-sticky,
.geo-facts,
.price-card,
.cta {
  color: var(--ds-paper) !important;
  border-color: rgba(255, 252, 246, .12) !important;
  background:
    radial-gradient(circle at 82% 12%, rgba(255, 252, 246, .10), transparent 26%),
    linear-gradient(145deg, #171716 0%, #2f2b26 100%) !important;
  box-shadow: none !important;
}

.products-section h1,
.products-section h2,
.products-section h3,
.feature-sticky h1,
.feature-sticky h2,
.feature-sticky h3,
.geo-facts h1,
.geo-facts h2,
.geo-facts h3,
.price-card h1,
.price-card h2,
.price-card h3,
.cta h1,
.cta h2,
.cta h3 {
  color: var(--ds-paper) !important;
}

.products-section p,
.feature-sticky p,
.geo-facts p,
.price-card p,
.cta p,
.products-section .section-subtitle,
.feature-sticky .section-subtitle {
  color: rgba(255, 252, 246, .68) !important;
}

.package-card,
.products-section .package-card {
  background: rgba(255, 252, 246, .055) !important;
  border-color: rgba(255, 252, 246, .13) !important;
}

/* Buttons and small tags. */
.btn,
.btn-primary,
.btn-secondary,
.geo-local-trust__link,
.product-banner-cta,
.contact-phone,
.method-card.phone-card,
.floating-btn.phone,
.float-phone {
  color: var(--ds-paper) !important;
  background: var(--ds-ink) !important;
  border: 1px solid var(--ds-ink) !important;
  box-shadow: none !important;
  font-weight: 650 !important;
}

.btn:hover,
.btn-primary:hover,
.btn-secondary:hover,
.geo-local-trust__link:hover,
.floating-btn:hover,
.float-phone:hover {
  transform: translateY(-3px) !important;
  box-shadow: var(--ds-shadow-soft) !important;
}

.btn.ghost,
.geo-local-trust__link--ghost,
.products-section .btn.ghost,
.cta .btn.ghost {
  color: var(--ds-ink) !important;
  background: rgba(255, 252, 246, .72) !important;
  border: 1px solid var(--ds-line) !important;
  box-shadow: none !important;
}

.product-banner-feature,
.feature-tag,
.system-tag,
.experience-tag,
.case-tag,
.center-badge,
.module-tag,
.modules-badge,
.upgrade-tag,
.meta-pill {
  color: var(--ds-gold-dark) !important;
  background: rgba(182, 154, 114, .105) !important;
  border: 1px solid rgba(182, 154, 114, .18) !important;
}

.fa,
.fas,
.far,
.fab,
.system-icon,
.advantage-icon,
.promise-icon,
.value-icon,
.data-icon,
.contact-option-icon,
.method-icon,
.info-icon,
.feature-icon {
  color: var(--ds-gold-dark) !important;
}

.feature-icon,
.system-icon,
.advantage-icon,
.promise-icon,
.value-icon,
.data-icon,
.method-icon,
.info-icon {
  background: rgba(182, 154, 114, .11) !important;
  border: 1px solid rgba(182, 154, 114, .18) !important;
}

/* Tables and FAQ. */
.comparison-table,
.brand-table {
  overflow: hidden !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  border: 1px solid var(--ds-line) !important;
  border-radius: var(--ds-radius-lg) !important;
  background: rgba(255, 252, 246, .78) !important;
  box-shadow: none !important;
}

.comparison-table th,
.comparison-table td,
.brand-table th,
.brand-table td,
.brand-row {
  border-color: var(--ds-line) !important;
}

.comparison-table th,
.brand-table th {
  color: var(--ds-ink) !important;
  background: rgba(20, 20, 20, .045) !important;
}

.plan-a,
.plan-b,
.highlight-cell,
.check {
  color: var(--ds-gold-dark) !important;
}

.faq-question,
summary {
  color: var(--ds-ink) !important;
  background: transparent !important;
}

.faq-answer,
.faq-answer-inner {
  color: var(--ds-muted) !important;
}

/* GEO block and footer. */
.geo-local-trust {
  margin-top: 72px !important;
  padding: 72px 24px !important;
  background: linear-gradient(180deg, rgba(255, 252, 246, .55), rgba(241, 234, 224, .72)) !important;
}

.geo-local-trust__inner {
  max-width: 1180px !important;
}

.geo-local-trust h2 {
  color: var(--ds-ink) !important;
}

.geo-footer-legal {
  color: rgba(255, 252, 246, .62) !important;
  border-color: rgba(255, 252, 246, .12) !important;
}

.footer,
footer {
  color: rgba(255, 252, 246, .64) !important;
  background: #141414 !important;
}

.footer a,
footer a {
  color: rgba(255, 252, 246, .78) !important;
}

.footer-title,
.footer strong,
.footer-brand,
.footer-logo {
  color: var(--ds-paper) !important;
}

/* Mobile navigation. */
.bottom-nav {
  height: 68px !important;
  border-top: 1px solid var(--ds-line) !important;
  background: rgba(246, 241, 232, .92) !important;
  box-shadow: none !important;
  backdrop-filter: blur(20px) !important;
}

.bottom-nav .nav-item {
  color: var(--ds-muted) !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 12px !important;
  font-weight: 600 !important;
}

.bottom-nav .nav-item.active {
  color: var(--ds-ink) !important;
}

.floating-buttons {
  background: transparent !important;
  box-shadow: none !important;
}

.wechat,
.wechat-card,
.wechat-icon {
  color: var(--ds-ink) !important;
  background: rgba(255, 252, 246, .74) !important;
  border-color: var(--ds-line) !important;
}

.lightbox {
  background: rgba(20, 20, 20, .88) !important;
}

.lightbox-content,
.lightbox-body,
.modal-content {
  border-radius: var(--ds-radius-lg) !important;
  background: var(--ds-paper) !important;
}

@media (max-width: 1080px) {
  .container,
  .footer-container,
  .cases-container,
  .social-container,
  .promises-container,
  .switcher-container {
    width: min(100% - 32px, 760px) !important;
  }

  .site-header,
  .nav,
  .header {
    min-height: 72px !important;
    height: 72px !important;
  }

  .site-header .nav,
  nav.nav {
    width: min(100% - 32px, 760px) !important;
  }

  .menu-btn,
  .nav-menu-btn,
  .mobile-menu-btn,
  .header-btn,
  .header-back {
    display: inline-flex !important;
  }

  .nav-links {
    position: absolute !important;
    top: 72px !important;
    right: 16px !important;
    left: 16px !important;
    display: none !important;
    height: auto !important;
    padding: 10px !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    border-radius: 24px !important;
    background: rgba(246, 241, 232, .96) !important;
    box-shadow: var(--ds-shadow-soft) !important;
  }

  .nav-links.active,
  .nav-links.open {
    display: grid !important;
  }

  .nav-link,
  .nav-links a,
  .nav-cta {
    width: 100% !important;
    justify-content: flex-start !important;
  }

  .nav-cta,
  .nav-links .reserve {
    margin-left: 0 !important;
    justify-content: center !important;
  }

  .page-header,
  .page-banner,
  .product-banner,
  .product-hero,
  .page-hero,
  .contact-page,
  .contact-hero {
    border-radius: 0 0 28px 28px !important;
  }

  .geo-local-trust {
    padding: 48px 18px !important;
  }
}

@media (max-width: 560px) {
  .container,
  .footer-container,
  .cases-container,
  .social-container,
  .promises-container,
  .switcher-container {
    width: min(100% - 28px, 520px) !important;
  }

  .brand,
  .nav-logo,
  .header-logo {
    max-width: calc(100vw - 104px) !important;
    overflow: hidden !important;
    font-size: 17px !important;
    text-overflow: ellipsis !important;
  }

  .brand-mark {
    width: 36px !important;
    height: 36px !important;
    flex: 0 0 auto !important;
  }
}

/* New editorial image-led system for the rebuilt home page. */
.site-page {
  background: #f5f1ea !important;
}

.dm-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  display: grid;
  grid-template-columns: minmax(150px, 1fr) auto minmax(150px, 1fr);
  height: 84px;
  align-items: center;
  gap: 40px;
  padding: 0 clamp(28px, 5vw, 72px);
  border-bottom: 1px solid rgba(18, 18, 18, .08);
  background: rgba(245, 241, 234, .86);
  backdrop-filter: blur(24px);
  transition: background .3s ease, box-shadow .3s ease, border-color .3s ease;
}

.dm-header.is-scrolled {
  border-bottom-color: rgba(18,18,18,.12);
  background: rgba(245,241,234,.94);
  box-shadow: 0 10px 36px rgba(18,18,18,.06);
}

.dm-brand {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  gap: 12px;
  color: #121212;
  font-size: 19px;
  font-weight: 650;
  letter-spacing: -.03em;
}

.dm-brand-mark {
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border-radius: 50%;
  color: #f8f4ec;
  background: #121212;
  font-size: 14px;
  font-weight: 600;
}

.dm-nav {
  display: flex;
  height: 52px;
  align-items: center;
  justify-self: center;
  gap: 2px;
}

.dm-nav a {
  display: inline-flex;
  height: 44px;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  color: #625d55;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -.01em;
}

.dm-nav a:hover,
.dm-nav a.active {
  color: #121212;
  background: rgba(18, 18, 18, .055);
}

.dm-nav .dm-nav-cta {
  min-width: 112px;
  margin-left: 10px;
  justify-self: end;
  color: #f8f4ec;
  background: #121212;
}

.dm-nav-product {
  position: static;
}

.dm-nav-product summary {
  display: inline-flex;
  height: 44px;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  color: #625d55;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -.01em;
  cursor: pointer;
  list-style: none;
}

.dm-nav-product summary::-webkit-details-marker {
  display: none;
}

.dm-nav-product summary:hover,
.dm-nav-product[open] summary,
.dm-nav-product.active summary {
  color: #121212;
  background: rgba(18,18,18,.055);
}

.dm-product-curtain {
  position: fixed;
  top: 84px;
  right: 0;
  left: 0;
  z-index: 999;
  padding: clamp(34px, 5vw, 64px) clamp(28px, 5vw, 72px) clamp(42px, 5vw, 68px);
  border-top: 1px solid rgba(18,18,18,.08);
  border-bottom: 1px solid rgba(18,18,18,.08);
  background: rgba(245,241,234,.98);
  box-shadow: 0 28px 60px rgba(18,18,18,.08);
  transform-origin: top center;
  animation: dmCurtainIn .24s ease both;
}

.dm-product-curtain-inner {
  display: grid;
  width: min(1180px, 100%);
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(18px, 3vw, 36px);
  margin: 0 auto;
}

.dm-nav .dm-curtain-card {
  display: grid;
  height: auto;
  padding: 0;
  border-radius: 0;
  color: #121212;
  background: transparent;
  text-align: center;
}

.dm-nav .dm-curtain-card:hover {
  background: transparent;
}

.dm-curtain-card img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  margin-bottom: 22px;
  transition: transform .7s ease, filter .7s ease;
}

.dm-curtain-card strong {
  color: #121212;
  font-size: clamp(22px, 2vw, 30px);
  font-weight: 650;
  line-height: 1.15;
  letter-spacing: -.04em;
}

.dm-curtain-card span {
  margin-top: 8px;
  color: rgba(18,18,18,.56);
  font-size: 14px;
  line-height: 1.6;
}

.dm-curtain-card:hover img {
  transform: scale(1.035);
  filter: brightness(.94);
}

@keyframes dmCurtainIn {
  from {
    opacity: 0;
    transform: translateY(-10px) scaleY(.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scaleY(1);
  }
}

@media (max-width: 980px) {
  .dm-nav-product summary {
    width: 100%;
    justify-content: flex-start;
  }

  .dm-product-curtain {
    position: static;
    padding: 12px 0 6px;
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  .dm-product-curtain-inner {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .dm-nav .dm-curtain-card {
    grid-template-columns: 86px 1fr;
    gap: 14px;
    align-items: center;
    text-align: left;
  }

  .dm-curtain-card img {
    aspect-ratio: 4 / 3;
    margin-bottom: 0;
  }

  .dm-curtain-card strong {
    font-size: 18px;
  }

  .dm-curtain-card span {
    grid-column: 2;
    margin-top: -8px;
  }
}

.dm-menu {
  display: none;
  width: 48px;
  height: 42px;
  border: 1px solid rgba(18, 18, 18, .12);
  border-radius: 999px;
  color: #121212;
  background: transparent;
}

@media (prefers-reduced-motion: no-preference) {
  .hb-hero-content,
  .hb-product-row article,
  .hb-story-item,
  .hb-grid-section,
  .hb-local,
  .hb-booking,
  .dm-page-hero,
  .dm-page-section,
  .dm-band,
  .dm-dark-band,
  .dm-cta,
  .old-exp-section {
    animation: dmReveal .72s ease both;
    animation-timeline: view();
    animation-range: entry 0% cover 24%;
  }

  .hb-hero-content {
    animation-timeline: auto;
  }

  .hb-hero img {
    animation: dmHeroBreath 10s ease-in-out infinite alternate;
  }
}

@keyframes dmReveal {
  from {
    opacity: 0;
    transform: translateY(26px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes dmHeroBreath {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(1.045);
  }
}

.dm-reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .72s ease, transform .72s ease;
}

.dm-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }

  .dm-reveal {
    opacity: 1;
    transform: none;
  }
}

.dm-hero {
  display: grid;
  min-height: calc(100vh - 84px);
  grid-template-columns: minmax(340px, .78fr) minmax(420px, 1fr);
  gap: clamp(32px, 5vw, 86px);
  align-items: center;
  padding: clamp(56px, 7vw, 112px) clamp(28px, 6vw, 96px);
}

.dm-hero-copy {
  max-width: 660px;
}

.dm-kicker {
  margin-bottom: 18px;
  color: #8d7358 !important;
  font-size: 12px;
  font-weight: 650;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.dm-hero h1,
.dm-section h2,
.dm-cta h2,
.dm-local h2 {
  margin: 0 0 24px;
  color: #121212 !important;
  font-size: clamp(48px, 6vw, 96px);
  font-weight: 520 !important;
  line-height: .98;
  letter-spacing: -.075em !important;
}

.dm-section h2,
.dm-local h2,
.dm-cta h2 {
  font-size: clamp(38px, 5vw, 72px);
}

.dm-lead {
  max-width: 640px;
  color: #625d55 !important;
  font-size: clamp(17px, 1.6vw, 22px);
  line-height: 1.85;
}

.dm-lead.small {
  font-size: 17px;
}

.dm-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 34px;
}

.dm-button {
  display: inline-flex;
  min-height: 50px;
  align-items: center;
  justify-content: center;
  padding: 0 24px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 560;
}

.dm-button.dark {
  color: #f8f4ec;
  background: #121212;
}

.dm-button.light {
  color: #121212;
  border: 1px solid rgba(18, 18, 18, .12);
  background: rgba(255, 252, 246, .62);
}

.dm-button:hover,
.dm-text-link:hover,
.dm-editor-card:hover,
.dm-product:hover,
.dm-experience-grid a:hover {
  transform: translateY(-4px);
}

.dm-hero-media {
  position: relative;
  min-height: min(720px, calc(100vh - 160px));
  margin: 0;
  overflow: hidden;
  border-radius: 2px;
  background: #ddd5ca;
}

.dm-hero-media img,
.dm-editor-card img,
.dm-product img,
.dm-experience-grid img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .8s ease, filter .8s ease;
}

.dm-editor-card:hover,
.dm-product:hover,
.dm-experience-grid a:hover,
.hb-card-grid a:hover,
.old-showrooms .is-gallery-card:hover,
.old-case.is-gallery-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 52px rgba(18,18,18,.10);
}

.dm-editor-card:hover img,
.dm-product:hover img,
.dm-experience-grid a:hover img,
.hb-card-grid a:hover img {
  transform: scale(1.03);
  filter: brightness(.96);
}

.old-showrooms .is-gallery-card:hover img,
.old-case.is-gallery-card:hover img {
  transform: scale(1.03);
  filter: none;
}

.dm-hero-media figcaption {
  position: absolute;
  right: 24px;
  bottom: 24px;
  left: 24px;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  padding-top: 120px;
  color: #fff;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.42));
}

.dm-hero-media span,
.dm-hero-media strong {
  position: relative;
  z-index: 1;
}

.dm-hero-media span {
  opacity: .72;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.dm-hero-media strong {
  font-size: 18px;
  font-weight: 520;
}

.dm-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid rgba(18, 18, 18, .10);
  border-bottom: 1px solid rgba(18, 18, 18, .10);
}

.dm-stats div {
  padding: 30px clamp(24px, 5vw, 72px);
  border-right: 1px solid rgba(18, 18, 18, .10);
}

.dm-stats div:last-child {
  border-right: 0;
}

.dm-stats strong {
  display: block;
  color: #121212;
  font-size: clamp(34px, 4vw, 58px);
  font-weight: 520;
  letter-spacing: -.06em;
}

.dm-stats span {
  color: #6d675f;
}

.dm-section,
.dm-local,
.dm-cta {
  width: min(1180px, calc(100% - 56px));
  margin: 0 auto;
  padding: clamp(84px, 10vw, 140px) 0;
}

.dm-section-head {
  display: grid;
  grid-template-columns: minmax(260px, .75fr) minmax(340px, 1fr);
  gap: clamp(28px, 5vw, 78px);
  align-items: end;
  margin-bottom: 42px;
}

.dm-three,
.dm-product-grid,
.dm-experience-grid {
  display: grid;
  gap: 18px;
}

.dm-three {
  grid-template-columns: repeat(3, 1fr);
}

.dm-editor-card {
  display: grid;
  min-height: 560px;
  grid-template-rows: 1fr auto;
  overflow: hidden;
  border: 1px solid rgba(18,18,18,.09);
  background: #fffcf6;
  transition: transform .45s ease, box-shadow .45s ease, border-color .45s ease;
}

.dm-editor-card img {
  min-height: 340px;
}

.dm-editor-card div {
  padding: 28px;
}

.dm-editor-card span,
.dm-feature-list span,
.dm-flow span {
  color: #8d7358;
  font-size: 12px;
  font-weight: 650;
  letter-spacing: .14em;
}

.dm-editor-card h3,
.dm-product h3,
.dm-feature-list h3 {
  margin: 14px 0 10px;
  color: #121212 !important;
  font-size: 28px;
  font-weight: 520 !important;
  letter-spacing: -.045em !important;
}

.dm-editor-card p,
.dm-product p,
.dm-feature-list p,
.dm-local p,
.dm-cta p {
  color: #625d55 !important;
}

.dm-products {
  width: 100%;
  max-width: none;
  padding-right: clamp(28px, 6vw, 96px);
  padding-left: clamp(28px, 6vw, 96px);
  background: #151515;
}

.dm-products .dm-section-head,
.dm-products .dm-section-head h2 {
  color: #f8f4ec !important;
}

.dm-products .dm-section-head {
  width: min(1180px, 100%);
  margin-right: auto;
  margin-left: auto;
}

.dm-product-grid {
  width: min(1180px, 100%);
  grid-template-columns: repeat(2, 1fr);
  margin: 0 auto;
}

.dm-product {
  display: grid;
  min-height: 680px;
  grid-template-rows: 1fr auto;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: #f8f4ec;
  transition: transform .45s ease, box-shadow .45s ease, border-color .45s ease;
}

.dm-product.dark {
  background: #211f1c;
}

.dm-product img {
  min-height: 410px;
}

.dm-product-body {
  padding: 34px;
}

.dm-product.dark h3,
.dm-product.dark p {
  color: #f8f4ec !important;
}

.dm-price {
  margin: 0 0 16px;
  color: #8d7358 !important;
  font-size: 34px;
  font-weight: 520;
  letter-spacing: -.05em;
}

.dm-text-link {
  display: inline-flex;
  margin-top: 20px;
  color: #8d7358;
  font-weight: 560;
  transition: transform .24s ease;
}

.dm-split {
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: clamp(36px, 6vw, 96px);
}

.dm-feature-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  border: 1px solid rgba(18,18,18,.10);
  background: rgba(18,18,18,.10);
}

.dm-feature-list article {
  min-height: 250px;
  padding: 30px;
  background: #fffcf6;
}

.dm-flow-section {
  border-top: 1px solid rgba(18,18,18,.10);
  border-bottom: 1px solid rgba(18,18,18,.10);
}

.dm-flow {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  margin-bottom: 28px;
  background: rgba(18,18,18,.10);
}

.dm-flow div {
  min-height: 172px;
  padding: 24px;
  background: #f5f1ea;
}

.dm-flow strong {
  display: block;
  margin-top: 72px;
  color: #121212;
  font-size: 18px;
  font-weight: 520;
}

.dm-experience-grid {
  grid-template-columns: repeat(3, 1fr);
}

.dm-experience-grid a {
  position: relative;
  display: block;
  min-height: 520px;
  overflow: hidden;
  transition: transform .45s ease, box-shadow .45s ease;
}

.dm-experience-grid span {
  position: absolute;
  right: 24px;
  bottom: 24px;
  left: 24px;
  color: #fff;
  font-size: 24px;
  font-weight: 520;
  letter-spacing: -.035em;
}

.dm-local {
  display: grid;
  grid-template-columns: 1fr .72fr;
  gap: clamp(32px, 6vw, 88px);
  border-top: 1px solid rgba(18,18,18,.10);
}

.dm-local dl {
  display: grid;
  gap: 1px;
  margin: 0;
  background: rgba(18,18,18,.10);
}

.dm-local dl div {
  padding: 26px;
  background: #fffcf6;
}

.dm-local dt {
  color: #8b857c;
  font-size: 12px;
  letter-spacing: .12em;
}

.dm-local dd {
  margin: 8px 0 0;
  color: #121212;
  font-size: 20px;
  font-weight: 520;
}

.dm-cta {
  margin-bottom: 96px;
  padding: clamp(44px, 7vw, 78px);
  background: #121212;
}

.dm-cta h2,
.dm-cta p {
  color: #f8f4ec !important;
}

.dm-footer {
  display: flex;
  justify-content: space-between;
  gap: 32px;
  padding: 40px clamp(28px, 6vw, 96px);
  color: rgba(248,244,236,.66);
  background: #121212;
}

.dm-footer strong {
  display: block;
  color: #f8f4ec;
  font-weight: 520;
}

.dm-footer p {
  margin: 6px 0 0;
  color: rgba(248,244,236,.66) !important;
}

.dm-footer a {
  color: rgba(248,244,236,.78);
}

@media (max-width: 980px) {
  .dm-header {
    grid-template-columns: 1fr auto;
    height: 72px;
    padding: 0 18px;
  }
  .dm-menu {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    justify-self: end;
  }
  .dm-nav {
    position: absolute;
    top: 72px;
    right: 14px;
    left: 14px;
    display: none;
    height: auto;
    padding: 12px;
    border: 1px solid rgba(18,18,18,.10);
    background: rgba(245,241,234,.98);
    justify-self: stretch;
  }
  .dm-nav.open {
    display: grid;
  }
  .dm-nav a {
    justify-content: flex-start;
  }
  .dm-nav .dm-nav-cta {
    margin-left: 0;
    justify-content: center;
  }
  .dm-hero,
  .dm-section-head,
  .dm-split,
  .dm-local {
    grid-template-columns: 1fr;
  }
  .dm-hero {
    padding: 54px 18px;
  }
  .dm-hero-media {
    min-height: 520px;
  }
  .dm-stats,
  .dm-three,
  .dm-product-grid,
  .dm-feature-list,
  .dm-flow,
  .dm-experience-grid {
    grid-template-columns: 1fr;
  }
  .dm-section,
  .dm-local,
  .dm-cta {
    width: min(100% - 28px, 720px);
    padding-top: 76px;
    padding-bottom: 76px;
  }
  .dm-products {
    width: 100%;
    padding-right: 14px;
    padding-left: 14px;
  }
  .dm-footer {
    display: grid;
    padding: 32px 18px;
  }
}

/* Definitive heading system: keep peer titles visually aligned and one-line on desktop. */
@media (min-width: 981px) {
  .dm-page-copy {
    max-width: 760px !important;
  }

  .dm-page-copy h1,
  .dm-detail-copy h1,
  .dm-band-copy h2,
  .dm-page-heading h2,
  .dm-section h2,
  .dm-local h2,
  .dm-cta h2,
  .hb-section-title h2,
  .hb-local h2,
  .hb-booking h2 {
    max-width: none !important;
    font-size: clamp(30px, 2.65vw, 40px) !important;
    line-height: 1.18 !important;
    letter-spacing: -.03em !important;
    text-wrap: balance !important;
  }

  .dm-page-copy h1,
  .dm-detail-copy h1 {
    white-space: nowrap !important;
  }

  .dm-page-hero {
    grid-template-columns: minmax(520px, .95fr) minmax(420px, 1fr) !important;
  }

  .dm-page-hero.reverse {
    grid-template-columns: minmax(420px, 1fr) minmax(520px, .95fr) !important;
  }
}

@media (max-width: 980px) {
  .dm-page-copy h1,
  .dm-detail-copy h1,
  .dm-band-copy h2,
  .dm-page-heading h2,
  .dm-section h2,
  .dm-local h2,
  .dm-cta h2,
  .hb-section-title h2,
  .hb-local h2,
  .hb-booking h2 {
    font-size: clamp(28px, 8vw, 40px) !important;
    line-height: 1.18 !important;
    letter-spacing: -.03em !important;
  }
}

/* Last-mile visual corrections requested: smaller titles, consistent experience images, breathing room on split imagery. */
.hb-hero-content h1,
.dm-page-copy h1,
.dm-detail-copy h1 {
  font-size: clamp(32px, 4vw, 56px) !important;
  line-height: 1.12 !important;
  letter-spacing: -.04em !important;
}

.hb-section-title h2,
.hb-local h2,
.hb-booking h2,
.dm-page-heading h2,
.dm-band-copy h2,
.dm-section h2,
.dm-local h2,
.dm-cta h2,
.dm-page-section h2,
.old-exp-head h2,
.old-exp-cta h2 {
  font-size: clamp(28px, 3.2vw, 44px) !important;
  line-height: 1.16 !important;
  letter-spacing: -.035em !important;
}

.old-exp-hero h1 {
  font-size: clamp(34px, 4.2vw, 58px) !important;
}

.hb-story-item h3,
.dm-image-card h3,
.dm-info-card h3,
.dm-gallery-card h3,
.dm-feature-list h3,
.old-case-title h3,
.showroom-body h3,
.case-showcase-head h3 {
  font-size: clamp(22px, 2vw, 30px) !important;
  line-height: 1.2 !important;
}

.dm-band {
  width: min(1180px, calc(100% - 64px)) !important;
  min-height: auto !important;
  margin: 0 auto !important;
  overflow: hidden !important;
  border: 1px solid rgba(18,18,18,.10) !important;
  background: #f5f1ea !important;
}

.dm-band-media {
  min-height: 520px !important;
  padding: 18px !important;
  background: #f5f1ea !important;
}

.dm-band-media img {
  border-radius: 2px !important;
}

.dm-band-copy {
  padding: clamp(42px, 6vw, 82px) !important;
}

.hb-card-grid.three img {
  height: 380px !important;
  object-fit: cover !important;
}

@media (max-width: 980px) {
  .dm-band {
    width: min(100% - 28px, 720px) !important;
  }
  .dm-band-media {
    min-height: 360px !important;
  }
  .hb-card-grid.three img {
    height: 320px !important;
  }
}

/* Restored comfortable experience-center layout */
.old-experience {
  background: #f5f6f8 !important;
}

.old-exp-hero {
  padding: 98px 24px 118px;
  text-align: center;
  background: radial-gradient(circle at 50% 0%, rgba(214, 149, 80, .16), transparent 36%), #fffaf4;
}

.old-exp-hero span {
  display: inline-flex;
  padding: 10px 28px;
  border: 1px solid rgba(214, 149, 80, .22);
  border-radius: 999px;
  color: #d58b43;
  background: rgba(214, 149, 80, .10);
  font-weight: 700;
}

.old-exp-hero h1 {
  margin: 34px 0 16px;
  color: #8a6249 !important;
  font-size: clamp(42px, 5.2vw, 74px) !important;
  font-weight: 800 !important;
  line-height: 1.08 !important;
  letter-spacing: -.04em !important;
}

.old-exp-hero p {
  margin: 0;
  color: #62677d !important;
  font-size: 20px;
}

.old-exp-section {
  width: min(1420px, calc(100% - 64px));
  margin: 0 auto;
  padding: 92px 0;
}

.old-exp-head {
  margin-bottom: 64px;
  text-align: center;
}

.old-exp-head h2 {
  margin: 0 0 18px;
  color: #17192c !important;
  font-size: clamp(34px, 4vw, 56px) !important;
  font-weight: 800 !important;
  letter-spacing: -.04em !important;
}

.old-exp-head p {
  color: #62677d !important;
  font-size: 18px;
}

.old-showrooms {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.old-showrooms article {
  overflow: hidden;
  border: 1px solid rgba(23, 25, 44, .08);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 12px 36px rgba(23,25,44,.05);
}

.showroom-media {
  position: relative;
  height: 250px;
  overflow: hidden;
  background: #17171f;
}

.showroom-media img,
.old-case-mosaic img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.showroom-media > span {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 1;
  padding: 8px 16px;
  border-radius: 999px;
  color: #fff;
  background: #d58b43;
  font-weight: 700;
}

.showroom-media.placeholder {
  display: grid;
  place-items: center;
  color: #62677d;
  text-align: center;
}

.showroom-media.placeholder span {
  position: static;
  color: #62677d;
  background: transparent;
}

.showroom-media.placeholder::before {
  color: #9b7652;
  content: "●";
  font-size: 52px;
}

.showroom-body {
  padding: 34px;
}

.showroom-body h3 {
  margin: 0 0 18px;
  color: #17192c !important;
  font-size: 28px !important;
  font-weight: 800 !important;
}

.showroom-body p {
  color: #62677d !important;
}

.showroom-body strong {
  display: inline-flex;
  margin: 10px 0 20px;
  padding: 10px 18px;
  border-radius: 10px;
  color: #d58b43;
  background: rgba(214, 149, 80, .12);
}

.showroom-body div,
.old-case-desc div {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.showroom-body em,
.old-case-desc em {
  padding: 9px 16px;
  border-radius: 8px;
  color: #62677d;
  background: #f5f6f8;
  font-style: normal;
  font-weight: 600;
}

.old-case {
  margin-top: 92px;
}

.old-case:first-of-type {
  margin-top: 0;
}

.old-case-title {
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: 24px;
  align-items: center;
  padding-bottom: 28px;
  border-bottom: 1px solid rgba(23,25,44,.10);
}

.old-case-title h3 {
  margin: 0;
  color: #17192c !important;
  font-size: 36px !important;
  font-weight: 800 !important;
}

.old-case-title span {
  padding: 10px 24px;
  border-radius: 999px;
  color: #fff;
  background: #d58b43;
  font-weight: 800;
}

.old-case-title ul {
  display: flex;
  justify-content: flex-end;
  gap: 26px;
  padding: 0;
  margin: 0;
  color: #62677d;
  list-style: none;
  font-weight: 700;
}

.old-case-mosaic {
  display: grid;
  grid-template-columns: 1.25fr .82fr .82fr;
  grid-auto-rows: 250px;
  gap: 8px;
  margin-top: 34px;
  overflow: hidden;
  border-radius: 22px;
}

.old-case-mosaic .large {
  grid-row: span 2;
}

.old-case-desc {
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: stretch;
  margin-top: 28px;
  padding: 34px;
  border: 1px solid rgba(23,25,44,.08);
  border-radius: 18px;
  background: #fff;
}

.old-case-desc p {
  margin: 0;
  color: #62677d !important;
  font-size: 18px;
  line-height: 1.9;
  max-width: 1120px;
}

.old-case-desc p:first-child {
  color: #4f5364 !important;
}

.old-case-desc strong {
  color: #17192c;
  font-weight: 800;
}

.old-case-desc div {
  margin-top: 6px;
}

.old-exp-cta {
  margin-bottom: 80px;
  border-radius: 28px;
  text-align: center;
  background: #fff;
}

.old-exp-cta h2 {
  margin: 0 0 12px;
  color: #17192c !important;
  font-size: 42px !important;
}

.old-exp-cta a {
  display: inline-flex;
  height: 48px;
  align-items: center;
  margin-top: 20px;
  padding: 0 28px;
  border-radius: 999px;
  color: #fff;
  background: #17192c;
  font-weight: 700;
}

@media (max-width: 980px) {
  .old-exp-section {
    width: min(100% - 28px, 720px);
    padding: 68px 0;
  }
  .old-showrooms,
  .old-case-title,
  .old-case-mosaic,
  .old-case-desc {
    grid-template-columns: 1fr;
  }
  .old-case-title ul {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .old-case-mosaic {
    grid-auto-rows: 260px;
  }
  .old-case-mosaic .large {
    grid-row: span 1;
  }
}

/* Final title scale refinement: calmer, closer to product/lifestyle sites. */
.hb-hero-content h1 {
  font-size: clamp(34px, 4.4vw, 62px) !important;
  line-height: 1.08 !important;
}

.hb-section-title h2,
.hb-local h2,
.hb-booking h2,
.dm-page-copy h1,
.dm-detail-copy h1,
.dm-page-heading h2,
.dm-band-copy h2,
.dm-section h2,
.dm-local h2,
.dm-cta h2,
.dm-page-section h2 {
  font-size: clamp(30px, 3.6vw, 48px) !important;
  line-height: 1.12 !important;
  letter-spacing: -.045em !important;
}

.hb-story-item h3,
.dm-image-card h3,
.dm-info-card h3,
.dm-gallery-card h3,
.dm-feature-list h3 {
  font-size: clamp(24px, 2.4vw, 36px) !important;
  line-height: 1.16 !important;
  letter-spacing: -.035em !important;
}

.dm-page-copy .dm-lead,
.hb-section-title p,
.hb-story-item p,
.dm-lead {
  font-size: clamp(16px, 1.25vw, 19px) !important;
}

.case-showcase {
  display: grid;
  gap: 84px;
}

.case-showcase article {
  display: grid;
  gap: 24px;
}

.case-showcase-head {
  display: grid;
  grid-template-columns: 80px minmax(220px, .5fr) 1fr;
  gap: 24px;
  align-items: end;
  border-bottom: 1px solid rgba(18,18,18,.10);
  padding-bottom: 22px;
}

.case-showcase-head span {
  color: #8d7358;
  font-size: 12px;
  font-weight: 650;
  letter-spacing: .14em;
}

.case-showcase-head h3 {
  margin: 0;
  color: #111 !important;
  font-size: clamp(26px, 3vw, 40px) !important;
  font-weight: 520 !important;
  letter-spacing: -.045em !important;
}

.case-showcase-head p {
  margin: 0;
  color: #625d55 !important;
}

.case-gallery {
  display: grid;
  grid-template-columns: 1.35fr .82fr .82fr;
  gap: 14px;
}

.case-gallery img {
  width: 100%;
  height: 430px;
  object-fit: cover;
}

.case-gallery img:first-child {
  height: 560px;
}

@media (max-width: 980px) {
  .case-showcase {
    gap: 58px;
  }
  .case-showcase-head,
  .case-gallery {
    grid-template-columns: 1fr;
  }
  .case-gallery img,
  .case-gallery img:first-child {
    height: 420px;
  }
}

/* Habitat-inspired calm product homepage */
.habitat-home {
  background: #f6f3ed !important;
}

.hb-hero {
  position: relative;
  min-height: calc(100vh - 84px);
  display: grid;
  place-items: center;
  overflow: hidden;
  background: #111;
}

.hb-hero img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .78;
}

.hb-hero::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(180deg, rgba(0,0,0,.22), rgba(0,0,0,.38));
}

.hb-hero-content {
  position: relative;
  z-index: 1;
  width: min(760px, calc(100% - 48px));
  padding-top: 12vh;
  color: #fff;
  text-align: center;
}

.hb-hero-content p {
  margin: 0 0 12px;
  color: rgba(255,255,255,.86) !important;
  font-size: 18px;
}

.hb-hero-content h1 {
  margin: 0 0 16px;
  color: #fff !important;
  font-size: clamp(40px, 5.2vw, 76px) !important;
  font-weight: 520 !important;
  line-height: 1.05 !important;
  letter-spacing: -.055em !important;
}

.hb-hero-content span {
  display: block;
  margin-bottom: 30px;
  color: rgba(255,255,255,.88);
  font-size: 22px;
}

.hb-hero-content a,
.hb-booking a {
  display: inline-flex;
  height: 44px;
  align-items: center;
  justify-content: center;
  margin: 0 8px;
  padding: 0 18px;
  border-radius: 999px;
  color: #fff;
  font-size: 15px;
  font-weight: 500;
}

.hb-hero-content a:first-child {
  background: rgba(255,255,255,.18);
  backdrop-filter: blur(12px);
}

.hb-hero-content a:last-child,
.hb-booking a {
  background: #fff;
  color: #111;
}

.hb-product-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(18,18,18,.10);
}

.hb-product-row article {
  position: relative;
  min-height: 520px;
  overflow: hidden;
  background: #111;
}

.hb-product-row img,
.hb-card-grid img,
.hb-story-item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hb-product-row img {
  position: absolute;
  inset: 0;
  opacity: .78;
}

.hb-product-row article::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.62));
}

.hb-product-row div {
  position: absolute;
  right: 28px;
  bottom: 26px;
  left: 28px;
  z-index: 1;
  color: #fff;
}

.hb-product-row h2,
.hb-product-row p {
  margin: 0;
  color: #fff !important;
}

.hb-product-row h2 {
  font-size: 30px !important;
  font-weight: 520 !important;
}

.hb-product-row a,
.hb-story-item a,
.hb-card-grid a {
  display: inline-flex;
  margin-top: 16px;
  color: inherit;
  font-size: 15px;
}

.hb-story,
.hb-grid-section,
.hb-local,
.hb-booking {
  width: min(1180px, calc(100% - 56px));
  margin: 0 auto;
  padding: clamp(84px, 10vw, 132px) 0;
}

.hb-section-title {
  max-width: 720px;
  margin: 0 auto 54px;
  text-align: center;
}

.hb-section-title h2,
.hb-local h2,
.hb-booking h2 {
  margin: 0 0 14px;
  color: #111 !important;
  font-size: clamp(34px, 4.2vw, 58px) !important;
  font-weight: 520 !important;
  line-height: 1.08 !important;
  letter-spacing: -.055em !important;
}

.hb-section-title p,
.hb-local p,
.hb-booking p,
.hb-story-item p,
.hb-card-grid p {
  color: #625d55 !important;
  font-size: 17px;
}

.hb-story-item {
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: clamp(36px, 6vw, 88px);
  align-items: center;
  margin-top: 84px;
}

.hb-story-item:first-of-type {
  margin-top: 0;
}

.hb-story-item.reverse img {
  order: 2;
}

.hb-story-item.reverse div {
  order: 1;
}

.hb-story-item img {
  height: min(620px, 58vw);
}

.hb-story-item h3 {
  margin: 0 0 18px;
  color: #111 !important;
  font-size: clamp(30px, 3.4vw, 48px) !important;
  font-weight: 520 !important;
  line-height: 1.12 !important;
  letter-spacing: -.055em !important;
}

.hb-card-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

.hb-card-grid.three {
  grid-template-columns: repeat(3, 1fr);
}

.hb-card-grid a {
  display: block;
  margin: 0;
  overflow: hidden;
  color: #111;
  background: #fffcf6;
}

.hb-card-grid img {
  height: 420px;
}

.hb-card-placeholder {
  display: grid;
  height: 420px;
  place-items: center;
  align-content: center;
  gap: 8px;
  color: rgba(248,244,236,.72);
  background:
    radial-gradient(circle at 50% 38%, rgba(255,255,255,.08), transparent 28%),
    #151515;
}

.hb-card-placeholder span {
  color: #f8f4ec;
  font-size: 18px;
  font-weight: 520;
  letter-spacing: .08em;
}

.hb-card-placeholder small {
  color: rgba(248,244,236,.48);
  font-size: 13px;
  letter-spacing: .12em;
}

.hb-card-grid h3,
.hb-card-grid p {
  margin-right: 28px;
  margin-left: 28px;
}

.hb-card-grid h3 {
  margin-top: 24px;
  margin-bottom: 6px;
  color: #111 !important;
  font-size: 26px !important;
  font-weight: 520 !important;
}

.hb-card-grid p {
  margin-bottom: 28px;
}

.hb-local {
  display: grid;
  grid-template-columns: 1fr .72fr;
  gap: clamp(36px, 6vw, 88px);
  border-top: 1px solid rgba(18,18,18,.10);
}

.hb-local dl {
  margin: 0;
}

.hb-local dl div {
  padding: 24px 0;
  border-bottom: 1px solid rgba(18,18,18,.10);
}

.hb-local dt {
  color: #8d7358;
  font-size: 12px;
  letter-spacing: .14em;
}

.hb-local dd {
  margin: 8px 0 0;
  color: #111;
  font-size: 20px;
}

.hb-booking {
  margin-bottom: 90px;
  text-align: center;
  border-top: 1px solid rgba(18,18,18,.10);
}

.hb-booking a {
  margin-top: 24px;
  background: #111;
  color: #fff;
}

/* Correct over-scaled older editorial sections. */
.dm-page-copy h1,
.dm-detail-copy h1,
.dm-page-heading h2,
.dm-band-copy h2,
.dm-section h2,
.dm-local h2,
.dm-cta h2 {
  font-size: clamp(34px, 4.2vw, 58px) !important;
  line-height: 1.08 !important;
  letter-spacing: -.055em !important;
}

@media (max-width: 980px) {
  .hb-product-row,
  .hb-story-item,
  .hb-card-grid,
  .hb-card-grid.three,
  .hb-local {
    grid-template-columns: 1fr;
  }
  .hb-story-item.reverse img,
  .hb-story-item.reverse div {
    order: initial;
  }
  .hb-product-row article {
    min-height: 460px;
  }
  .hb-story,
  .hb-grid-section,
  .hb-local,
  .hb-booking {
    width: min(100% - 28px, 720px);
    padding-top: 74px;
    padding-bottom: 74px;
  }
  .hb-story-item {
    gap: 28px;
    margin-top: 58px;
  }
  .hb-story-item img,
  .hb-card-grid img {
    height: 420px;
  }
}

/* Editorial subpage system */
.dm-page-main {
  background: #f5f1ea;
}

.dm-page-hero {
  display: grid;
  grid-template-columns: minmax(340px, .8fr) minmax(420px, 1fr);
  gap: clamp(36px, 6vw, 96px);
  align-items: center;
  padding: clamp(56px, 8vw, 124px) clamp(28px, 6vw, 96px);
  border-bottom: 1px solid rgba(18,18,18,.09);
}

.dm-page-hero.reverse {
  grid-template-columns: minmax(420px, 1fr) minmax(340px, .8fr);
}

.dm-page-hero.reverse .dm-page-copy {
  order: 2;
}

.dm-page-hero.reverse .dm-page-media {
  order: 1;
}

.dm-page-copy h1 {
  margin: 0 0 26px;
  color: #121212 !important;
  font-size: clamp(48px, 6vw, 96px);
  font-weight: 520 !important;
  line-height: .98;
  letter-spacing: -.075em !important;
}

.dm-page-copy p {
  max-width: 650px;
}

.dm-page-media {
  position: relative;
  min-height: min(660px, calc(100vh - 180px));
  overflow: hidden;
  background: #ddd5ca;
}

.dm-page-media img,
.dm-image-card img,
.dm-band-media img,
.dm-gallery-card img,
.dm-detail-hero img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dm-page-media-caption {
  position: absolute;
  right: 22px;
  bottom: 22px;
  left: 22px;
  color: #fff;
  font-size: 14px;
  text-shadow: 0 1px 18px rgba(0,0,0,.35);
}

.dm-page-section {
  width: min(1180px, calc(100% - 56px));
  margin: 0 auto;
  padding: clamp(82px, 10vw, 140px) 0;
}

.dm-page-section.tight {
  padding-top: clamp(54px, 7vw, 92px);
}

.dm-page-heading {
  display: grid;
  grid-template-columns: minmax(280px, .76fr) minmax(360px, 1fr);
  gap: clamp(30px, 6vw, 86px);
  align-items: end;
  margin-bottom: 42px;
}

.dm-page-heading h2 {
  margin: 0;
  color: #121212 !important;
  font-size: clamp(38px, 5vw, 72px);
  font-weight: 520 !important;
  line-height: 1.03;
  letter-spacing: -.07em !important;
}

.dm-page-heading p {
  max-width: 620px;
}

.dm-grid-2,
.dm-grid-3,
.dm-grid-4 {
  display: grid;
  gap: 18px;
}

.dm-grid-2 { grid-template-columns: repeat(2, 1fr); }
.dm-grid-3 { grid-template-columns: repeat(3, 1fr); }
.dm-grid-4 { grid-template-columns: repeat(4, 1fr); }

.dm-image-card,
.dm-info-card,
.dm-gallery-card {
  overflow: hidden;
  border: 1px solid rgba(18,18,18,.09);
  background: #fffcf6;
}

.dm-image-card {
  display: grid;
  grid-template-rows: minmax(300px, 1fr) auto;
  min-height: 560px;
}

.dm-image-card-body,
.dm-info-card,
.dm-gallery-body {
  padding: 30px;
}

.dm-image-card h3,
.dm-info-card h3,
.dm-gallery-card h3,
.dm-band-copy h2,
.dm-detail-copy h1 {
  color: #121212 !important;
  font-weight: 520 !important;
  letter-spacing: -.05em !important;
}

.dm-image-card h3,
.dm-info-card h3,
.dm-gallery-card h3 {
  margin: 12px 0 10px;
  font-size: 28px;
}

.dm-info-card {
  min-height: 260px;
}

.dm-info-card .num {
  color: #8d7358;
  font-size: 12px;
  font-weight: 650;
  letter-spacing: .14em;
}

.dm-dark-band {
  width: 100%;
  max-width: none;
  padding: clamp(82px, 10vw, 132px) clamp(28px, 6vw, 96px);
  color: #f8f4ec;
  background: #151515;
}

.dm-dark-band .dm-page-heading {
  width: min(1180px, 100%);
  margin-right: auto;
  margin-left: auto;
}

.dm-dark-band h2,
.dm-dark-band h3 {
  color: #f8f4ec !important;
}

.dm-dark-band p {
  color: rgba(248,244,236,.68) !important;
}

.dm-dark-band .dm-info-card,
.dm-dark-band .dm-image-card {
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.055);
}

.dm-dark-band .dm-grid-2,
.dm-dark-band .dm-grid-3,
.dm-dark-band .dm-grid-4 {
  width: min(1180px, 100%);
  margin: 0 auto;
}

.dm-band {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 660px;
  border-top: 1px solid rgba(18,18,18,.09);
  border-bottom: 1px solid rgba(18,18,18,.09);
}

.dm-band-media {
  overflow: hidden;
  min-height: 520px;
}

.dm-band-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(44px, 7vw, 96px);
}

.dm-flow-large {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: rgba(18,18,18,.10);
}

.dm-flow-large article {
  min-height: 220px;
  padding: 24px;
  background: #f5f1ea;
}

.dm-flow-large span {
  color: #8d7358;
  font-size: 12px;
  font-weight: 650;
  letter-spacing: .14em;
}

.dm-flow-large h3 {
  margin-top: 86px;
  font-size: 20px;
}

.dm-table {
  width: 100%;
  overflow: hidden;
  border: 1px solid rgba(18,18,18,.09);
  background: #fffcf6;
}

.dm-table-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border-bottom: 1px solid rgba(18,18,18,.09);
}

.dm-table-row:last-child {
  border-bottom: 0;
}

.dm-table-row > div {
  padding: 22px 24px;
  border-right: 1px solid rgba(18,18,18,.09);
}

.dm-table-row > div:last-child {
  border-right: 0;
}

.dm-table-head {
  color: #121212;
  font-weight: 650;
  background: rgba(18,18,18,.04);
}

.dm-fact-list {
  display: grid;
  gap: 1px;
  border: 1px solid rgba(18,18,18,.10);
  background: rgba(18,18,18,.10);
}

.dm-fact-list article {
  display: grid;
  grid-template-columns: minmax(180px, .42fr) 1fr;
  gap: 24px;
  padding: 26px 28px;
  background: #fffcf6;
}

.dm-fact-list h3,
.dm-faq h3 {
  margin: 0;
  color: #121212 !important;
  font-size: clamp(20px, 1.8vw, 26px) !important;
  font-weight: 520 !important;
  line-height: 1.25 !important;
  letter-spacing: -.025em !important;
}

.dm-fact-list p,
.dm-faq p {
  margin: 0;
  color: rgba(18,18,18,.64) !important;
  line-height: 1.78;
}

.dm-faq {
  display: grid;
  gap: 1px;
  border: 1px solid rgba(18,18,18,.10);
  background: rgba(18,18,18,.10);
}

.dm-faq article {
  padding: 28px;
  background: #fffcf6;
}

.dm-faq h3 {
  margin-bottom: 10px;
}

.dm-material-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  border: 1px solid rgba(18,18,18,.10);
  background: rgba(18,18,18,.10);
}

.dm-material-grid div {
  padding: 24px;
  background: #fffcf6;
}

.dm-material-grid span {
  display: block;
  margin-bottom: 8px;
  color: #8d7358;
  font-size: 12px;
  font-weight: 650;
  letter-spacing: .14em;
}

.dm-material-grid strong {
  color: #121212;
  font-weight: 520;
}

.dm-contact-layout {
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: 18px;
}

.dm-contact-layout.refined {
  grid-template-columns: minmax(0, .95fr) minmax(420px, .72fr);
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(18,18,18,.09);
  background: #fffcf6;
}

.dm-contact-intro {
  min-height: 520px;
  padding: clamp(42px, 6vw, 78px);
  border-right: 1px solid rgba(18,18,18,.09);
}

.dm-contact-intro h2 {
  max-width: 760px;
  margin: 34px 0 28px;
  color: #121212 !important;
  font-size: clamp(42px, 5vw, 76px);
  font-weight: 520;
  line-height: 1.08;
  letter-spacing: -.055em;
}

.dm-contact-intro > p:not(.dm-kicker) {
  max-width: 720px;
  color: #5f5a52 !important;
  font-size: clamp(17px, 1.45vw, 22px);
  line-height: 1.95;
}

.dm-contact-points {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 44px;
}

.dm-contact-points span {
  padding: 11px 16px;
  color: #8d7358;
  background: rgba(18,18,18,.045);
  font-size: 14px;
  font-weight: 650;
}

.dm-contact-actions {
  display: grid;
  grid-template-rows: .9fr 1.1fr;
  min-height: 520px;
}

.dm-contact-call {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(34px, 4vw, 56px);
  color: #f8f4ec !important;
  background: #121212;
}

.dm-contact-call span,
.dm-contact-wechat span {
  color: #9b8267;
  font-size: 13px;
  font-weight: 650;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.dm-contact-call strong {
  margin: 24px 0 16px;
  color: rgba(248,244,236,.92);
  font-size: clamp(38px, 4vw, 58px);
  font-weight: 430;
  letter-spacing: -.065em;
}

.dm-contact-call em {
  color: rgba(248,244,236,.64);
  font-style: normal;
  font-size: 16px;
}

.dm-contact-wechat {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: clamp(24px, 3vw, 44px);
  align-items: center;
  padding: clamp(34px, 4vw, 56px);
  border-top: 1px solid rgba(18,18,18,.09);
  background: #fffaf1;
}

.dm-contact-wechat strong {
  display: block;
  margin: 18px 0 12px;
  color: #121212;
  font-size: clamp(28px, 3vw, 44px);
  font-weight: 560;
  letter-spacing: -.04em;
}

.dm-contact-wechat p {
  max-width: 360px;
  color: #69645d !important;
  font-size: 16px;
  line-height: 1.75;
}

.dm-contact-panel {
  padding: clamp(32px, 5vw, 58px);
  background: #fffcf6;
  border: 1px solid rgba(18,18,18,.09);
}

.dm-contact-panel.dark {
  color: #f8f4ec;
  background: #151515;
}

.dm-contact-panel.dark p,
.dm-contact-panel.dark a {
  color: rgba(248,244,236,.72) !important;
}

.dm-contact-phone {
  display: block;
  margin: 28px 0;
  color: #f8f4ec !important;
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 520;
  letter-spacing: -.06em;
}

.dm-qr {
  width: 188px;
  padding: 14px;
  background: #fff;
  border: 1px solid rgba(18,18,18,.08);
}

.dm-detail-hero {
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  gap: clamp(36px, 6vw, 92px);
  align-items: center;
  padding: clamp(60px, 8vw, 120px) clamp(28px, 6vw, 96px);
}

.dm-detail-copy h1 {
  margin: 0 0 20px;
  font-size: clamp(50px, 6vw, 96px);
}

.dm-detail-price {
  margin: 28px 0;
  color: #8d7358 !important;
  font-size: clamp(42px, 5vw, 76px);
  font-weight: 520;
  letter-spacing: -.06em;
}

.dm-detail-hero figure {
  min-height: min(680px, calc(100vh - 180px));
  margin: 0;
  overflow: hidden;
}

@media (max-width: 980px) {
  .dm-page-hero,
  .dm-page-hero.reverse,
  .dm-page-heading,
  .dm-grid-2,
  .dm-grid-3,
  .dm-grid-4,
  .dm-band,
  .dm-contact-layout,
  .dm-detail-hero {
    grid-template-columns: 1fr;
  }
  .dm-page-hero.reverse .dm-page-copy,
  .dm-page-hero.reverse .dm-page-media {
    order: initial;
  }
  .dm-page-hero,
  .dm-detail-hero {
    padding: 54px 18px;
  }
  .dm-page-media,
  .dm-detail-hero figure {
    min-height: 520px;
  }
  .dm-page-section {
    width: min(100% - 28px, 720px);
    padding-top: 76px;
    padding-bottom: 76px;
  }
  .dm-dark-band {
    padding-right: 14px;
    padding-left: 14px;
  }
  .dm-flow-large,
  .dm-table-row,
  .dm-fact-list article,
  .dm-material-grid {
    grid-template-columns: 1fr;
  }
  .dm-table-row > div {
    border-right: 0;
    border-bottom: 1px solid rgba(18,18,18,.09);
  }
  .dm-table-row > div:last-child {
    border-bottom: 0;
  }
  .dm-contact-layout.refined {
    grid-template-columns: 1fr;
  }
  .dm-contact-intro {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(18,18,18,.09);
  }
  .dm-contact-intro h2 {
    margin-top: 24px;
  }
  .dm-contact-actions {
    min-height: auto;
  }
  .dm-contact-wechat {
    grid-template-columns: 1fr;
  }
  .dm-qr {
    width: min(220px, 100%);
  }
}

@media (max-width: 560px) {
  .dm-contact-intro,
  .dm-contact-call,
  .dm-contact-wechat {
    padding: 30px 24px;
  }
  .dm-contact-call strong {
    font-size: clamp(32px, 10vw, 44px);
  }
  .dm-contact-points span {
    width: 100%;
  }
}

/* Final editorial type scale. This block intentionally sits last. */
:root {
  --dm-title-page: clamp(34px, 3.2vw, 46px);
  --dm-title-section: clamp(28px, 2.55vw, 38px);
  --dm-title-card: clamp(22px, 1.8vw, 28px);
}

.dm-page-copy h1,
.dm-detail-copy h1 {
  font-size: var(--dm-title-page) !important;
  line-height: 1.16 !important;
  letter-spacing: -.045em !important;
}

.dm-page-heading h2,
.dm-band-copy h2,
.dm-section h2,
.dm-local h2,
.dm-cta h2,
.hb-section-title h2,
.hb-local h2,
.hb-booking h2,
.hb-story-item h3 {
  font-size: var(--dm-title-section) !important;
  line-height: 1.18 !important;
  letter-spacing: -.04em !important;
}

.dm-image-card h3,
.dm-info-card h3,
.dm-gallery-card h3,
.hb-card-grid h3,
.hb-product-row h2 {
  font-size: var(--dm-title-card) !important;
  line-height: 1.22 !important;
  letter-spacing: -.025em !important;
}

@media (min-width: 981px) {
  .dm-page-copy h1,
  .dm-detail-copy h1,
  .dm-page-heading h2,
  .hb-section-title h2,
  .hb-local h2,
  .hb-booking h2 {
    white-space: nowrap !important;
  }

  .dm-page-heading {
    grid-template-columns: minmax(360px, .9fr) minmax(360px, 1fr) !important;
  }
}

@media (max-width: 980px) {
  :root {
    --dm-title-page: clamp(30px, 8vw, 38px);
    --dm-title-section: clamp(26px, 7vw, 34px);
    --dm-title-card: clamp(21px, 5.6vw, 26px);
  }
}

/* Experience page alignment with the current premium system. */
.old-experience {
  background: #f5f1ea !important;
}

.old-exp-hero {
  padding: clamp(72px, 8vw, 112px) clamp(28px, 6vw, 96px) clamp(78px, 8vw, 118px) !important;
  background: #f5f1ea !important;
}

.old-exp-hero span {
  border-color: rgba(18,18,18,.12) !important;
  color: #8d7358 !important;
  background: rgba(18,18,18,.035) !important;
  font-size: 12px !important;
  font-weight: 650 !important;
  letter-spacing: .14em !important;
}

.old-exp-hero h1 {
  color: #121212 !important;
  font-size: var(--dm-title-page) !important;
  font-weight: 520 !important;
  line-height: 1.16 !important;
  letter-spacing: -.045em !important;
}

.old-exp-hero p,
.old-exp-head p,
.showroom-body p,
.old-case-title ul,
.old-case-desc p,
.old-exp-cta p {
  color: rgba(18,18,18,.62) !important;
  font-size: clamp(16px, 1.25vw, 19px) !important;
  line-height: 1.75 !important;
  font-weight: 400 !important;
}

.old-exp-section {
  width: min(1180px, calc(100% - 56px)) !important;
  padding: clamp(82px, 10vw, 140px) 0 !important;
}

.old-exp-head {
  margin-bottom: 42px !important;
}

.old-exp-head h2,
.old-exp-cta h2 {
  color: #121212 !important;
  font-size: var(--dm-title-section) !important;
  font-weight: 520 !important;
  line-height: 1.18 !important;
  letter-spacing: -.04em !important;
}

.old-showrooms {
  gap: 18px !important;
}

.old-showrooms article,
.old-case-desc,
.old-exp-cta {
  border-color: rgba(18,18,18,.09) !important;
  border-radius: 0 !important;
  background: #fffcf6 !important;
  box-shadow: none !important;
}

.showroom-body h3,
.old-case-title h3 {
  color: #121212 !important;
  font-size: var(--dm-title-card) !important;
  font-weight: 520 !important;
  line-height: 1.22 !important;
  letter-spacing: -.025em !important;
}

.showroom-body strong,
.old-case-title span {
  color: #8d7358 !important;
  background: rgba(18,18,18,.045) !important;
  font-weight: 650 !important;
}

.showroom-body em,
.old-case-desc em {
  color: rgba(18,18,18,.62) !important;
  background: rgba(18,18,18,.045) !important;
  font-weight: 500 !important;
}

.old-case-title {
  border-bottom-color: rgba(18,18,18,.10) !important;
}

.old-exp-cta a {
  background: #121212 !important;
  font-weight: 650 !important;
}

.is-gallery-card {
  cursor: zoom-in;
}

.is-gallery-card:focus-visible {
  outline: 2px solid #121212;
  outline-offset: 6px;
}

.is-gallery-card img {
  transition: transform .7s ease, filter .7s ease;
}

.is-gallery-card:hover img {
  transform: scale(1.025);
  filter: none;
}

.is-gallery-card .showroom-media::after,
.is-gallery-card .old-case-mosaic::after {
  position: absolute;
  right: 18px;
  bottom: 18px;
  z-index: 2;
  padding: 8px 13px;
  color: #f8f4ec;
  background: rgba(18,18,18,.58);
  content: "查看大图";
  font-size: 12px;
  letter-spacing: .1em;
  pointer-events: none;
}

.is-gallery-card .showroom-media,
.is-gallery-card .old-case-mosaic {
  position: relative;
}

/* Mobile one-page landing. */
.mobile-onepage {
  color: #121212;
  background: #f5f0e8;
  font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", sans-serif;
}

.mobile-onepage * {
  box-sizing: border-box;
}

.m1-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 58px;
  padding: 0 18px;
  background: rgba(245,240,232,.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(18,18,18,.08);
}

.m1-brand {
  color: #121212;
  font-size: 18px;
  font-weight: 700;
}

.m1-phone {
  padding: 9px 14px;
  border-radius: 999px;
  color: #f8f4ec;
  background: #121212;
  font-size: 13px;
  font-weight: 650;
}

.m1-hero,
.m1-section,
.m1-booking,
.m1-footer {
  width: min(100% - 32px, 520px);
  margin: 0 auto;
}

.m1-hero {
  padding: 42px 0 26px;
}

.m1-kicker {
  margin: 0 0 14px;
  color: #8d7358;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.m1-hero h1,
.m1-section h2,
.m1-booking h2 {
  margin: 0;
  color: #121212;
  font-weight: 560;
  letter-spacing: -.055em;
}

.m1-hero h1 {
  font-size: clamp(38px, 11vw, 58px);
  line-height: 1.05;
}

.m1-hero > p:not(.m1-kicker),
.m1-section > p:not(.m1-kicker),
.m1-booking > p {
  margin: 20px 0 0;
  color: #5f5a52;
  font-size: 16px;
  line-height: 1.9;
}

.m1-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 26px;
}

.m1-actions a,
.m1-booking a {
  display: flex;
  min-height: 48px;
  justify-content: center;
  align-items: center;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 700;
}

.m1-actions a:first-child,
.m1-booking a {
  color: #f8f4ec;
  background: #121212;
}

.m1-actions a:last-child {
  color: #121212;
  background: #fffaf1;
  border: 1px solid rgba(18,18,18,.1);
}

.m1-hero-card {
  margin-top: 30px;
  overflow: hidden;
  background: #fffaf1;
  border: 1px solid rgba(18,18,18,.08);
}

.m1-hero-card img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.m1-hero-card dl {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin: 0;
  border-top: 1px solid rgba(18,18,18,.08);
}

.m1-hero-card div {
  padding: 16px 12px;
  border-right: 1px solid rgba(18,18,18,.08);
}

.m1-hero-card div:last-child {
  border-right: 0;
}

.m1-hero-card dt {
  color: #8d7358;
  font-size: 12px;
  font-weight: 700;
}

.m1-hero-card dd {
  margin: 8px 0 0;
  font-size: 17px;
  font-weight: 700;
}

.m1-anchor {
  position: sticky;
  top: 58px;
  z-index: 18;
  display: flex;
  gap: 8px;
  width: 100%;
  overflow-x: auto;
  padding: 10px 16px;
  background: rgba(245,240,232,.92);
  border-top: 1px solid rgba(18,18,18,.06);
  border-bottom: 1px solid rgba(18,18,18,.08);
  scrollbar-width: none;
}

.m1-anchor a {
  flex: 0 0 auto;
  padding: 9px 14px;
  border-radius: 999px;
  color: #5f5a52;
  background: #fffaf1;
  font-size: 13px;
  font-weight: 650;
}

.m1-section {
  padding: 54px 0 0;
}

.m1-section h2,
.m1-booking h2 {
  font-size: clamp(30px, 8vw, 42px);
  line-height: 1.12;
}

.m1-grid,
.m1-proof-list,
.m1-faq {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.m1-grid article,
.m1-proof-list article,
.m1-faq details,
.m1-company dl,
.m1-product-list article,
.m1-case,
.m1-showrooms article {
  background: #fffaf1;
  border: 1px solid rgba(18,18,18,.08);
}

.m1-grid article,
.m1-proof-list article {
  padding: 22px;
}

.m1-grid span {
  color: #9b8267;
  font-size: 12px;
  font-weight: 800;
}

.m1-grid h3,
.m1-proof-list h3 {
  margin: 12px 0 8px;
  color: #121212;
  font-size: 20px;
  font-weight: 650;
}

.m1-grid p,
.m1-proof-list p {
  margin: 0;
  color: #69645d;
  font-size: 15px;
  line-height: 1.75;
}

.m1-product-list {
  display: grid;
  gap: 16px;
  margin-top: 26px;
}

.m1-product-list img,
.m1-case img,
.m1-showrooms img {
  display: block;
  width: 100%;
  aspect-ratio: 1.28 / 1;
  object-fit: cover;
}

.m1-product-list div,
.m1-case div {
  padding: 22px;
}

.m1-product-list strong,
.m1-case strong,
.m1-showrooms strong {
  display: block;
  color: #121212;
  font-size: 22px;
  font-weight: 650;
  letter-spacing: -.03em;
}

.m1-product-list p,
.m1-case p {
  margin: 12px 0 0;
  color: #5f5a52;
  font-size: 15px;
  line-height: 1.8;
}

.m1-product-list em {
  display: block;
  margin-top: 14px;
  color: #8d7358;
  font-size: 13px;
  font-style: normal;
  font-weight: 650;
}

.m1-steps {
  padding: 0;
  margin: 26px 0 0;
  list-style: none;
  counter-reset: step;
}

.m1-steps li {
  position: relative;
  padding: 18px 0 18px 54px;
  border-bottom: 1px solid rgba(18,18,18,.10);
  counter-increment: step;
}

.m1-steps li::before {
  position: absolute;
  left: 0;
  top: 18px;
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  color: #f8f4ec;
  background: #121212;
  border-radius: 50%;
  content: counter(step);
  font-size: 13px;
  font-weight: 800;
}

.m1-steps strong {
  display: block;
  font-size: 19px;
}

.m1-steps span {
  display: block;
  margin-top: 7px;
  color: #69645d;
  font-size: 15px;
  line-height: 1.7;
}

.m1-case,
.m1-showrooms {
  margin-top: 18px;
}

.m1-showrooms {
  display: grid;
  gap: 14px;
}

.m1-showrooms article {
  overflow: hidden;
}

.m1-showrooms strong,
.m1-showrooms span {
  padding-right: 22px;
  padding-left: 22px;
}

.m1-showrooms strong {
  padding-top: 20px;
}

.m1-showrooms span {
  display: block;
  padding-top: 8px;
  padding-bottom: 22px;
  color: #8d7358;
  font-size: 14px;
  font-weight: 650;
}

.m1-placeholder {
  display: grid;
  width: 100%;
  aspect-ratio: 1.28 / 1;
  place-items: center;
  color: #9b8267;
  background: #181820;
  font-weight: 700;
}

.m1-faq summary {
  padding: 20px 22px;
  color: #121212;
  cursor: pointer;
  font-size: 17px;
  font-weight: 650;
}

.m1-faq p {
  margin: 0;
  padding: 0 22px 22px;
  color: #69645d;
  font-size: 15px;
  line-height: 1.8;
}

.m1-company dl {
  margin: 24px 0 0;
}

.m1-company dl div {
  padding: 18px 22px;
  border-bottom: 1px solid rgba(18,18,18,.08);
}

.m1-company dl div:last-child {
  border-bottom: 0;
}

.m1-company dt {
  color: #8d7358;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
}

.m1-company dd {
  margin: 8px 0 0;
  color: #121212;
  font-size: 16px;
  line-height: 1.7;
}

.m1-booking {
  margin-top: 58px;
  padding: 34px 24px;
  color: #f8f4ec;
  background: #121212;
}

.m1-booking .m1-kicker,
.m1-booking p {
  color: rgba(248,244,236,.68) !important;
}

.m1-booking h2 {
  color: #f8f4ec;
}

.m1-booking a {
  margin-top: 24px;
  color: #121212;
  background: #f8f4ec;
}

.m1-booking img {
  display: block;
  width: 170px;
  margin: 26px auto 12px;
  padding: 10px;
  background: #fff;
}

.m1-booking span {
  display: block;
  color: rgba(248,244,236,.62);
  text-align: center;
  font-size: 13px;
}

.m1-footer {
  padding: 34px 0 50px;
  color: #69645d;
  font-size: 13px;
  line-height: 1.8;
}

.m1-footer strong {
  display: block;
  margin-bottom: 10px;
  color: #121212;
  font-size: 16px;
}

.m1-footer p {
  margin: 4px 0;
}

.m1-footer a {
  color: #8d7358;
}

.is-unavailable {
  cursor: default;
}

body.has-lightbox {
  overflow: hidden;
}

.dm-lightbox {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 72px 84px;
  background: rgba(10,10,10,.92);
}

.dm-lightbox.open {
  display: flex;
}

.dm-lightbox figure {
  display: grid;
  gap: 18px;
  width: min(1180px, 100%);
  max-height: 100%;
  margin: 0;
}

.dm-lightbox img {
  display: block;
  width: 100%;
  max-height: calc(100vh - 170px);
  object-fit: contain;
  background: #111;
}

.dm-lightbox figcaption {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: rgba(248,244,236,.78);
  font-size: 14px;
  letter-spacing: .08em;
}

.dm-lightbox-close,
.dm-lightbox-nav {
  position: fixed;
  z-index: 3;
  border: 1px solid rgba(248,244,236,.22);
  color: #f8f4ec;
  background: rgba(255,255,255,.06);
  cursor: pointer;
}

.dm-lightbox-close {
  top: 24px;
  right: 28px;
  height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  font-size: 13px;
  letter-spacing: .12em;
}

.dm-lightbox-nav {
  top: 50%;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  font-size: 36px;
  line-height: 1;
  transform: translateY(-50%);
}

.dm-lightbox-nav.prev {
  left: 24px;
}

.dm-lightbox-nav.next {
  right: 24px;
}

.dm-lightbox-close:hover,
.dm-lightbox-nav:hover {
  background: rgba(255,255,255,.14);
}

@media (min-width: 981px) {
  .dm-band-copy h2,
  .hb-story-item h3,
  .old-exp-hero h1,
  .old-exp-head h2,
  .old-exp-cta h2 {
    white-space: nowrap !important;
  }
}

@media (max-width: 980px) {
  .old-exp-section {
    width: min(100% - 28px, 720px) !important;
    padding: 76px 0 !important;
  }

  .old-exp-hero {
    padding-right: 18px !important;
    padding-left: 18px !important;
  }

  .dm-lightbox {
    padding: 64px 14px 34px;
  }

  .dm-lightbox img {
    max-height: calc(100vh - 150px);
  }

  .dm-lightbox-nav {
    top: auto;
    bottom: 18px;
    width: 46px;
    height: 46px;
    font-size: 30px;
    transform: none;
  }

  .dm-lightbox-nav.prev {
    left: 18px;
  }

  .dm-lightbox-nav.next {
    right: 18px;
  }

  .dm-lightbox figcaption {
    padding: 0 58px;
    font-size: 12px;
  }
}
