:root {
  --orange: #e05e0e;
  --orange-deep: #c84f07;
  --orange-soft: #f39a49;
  --orange-fog: rgba(255, 208, 171, 0.34);
  --cream: #fff2df;
  --cream-strong: #ffe6c2;
  --cream-soft: rgba(255, 247, 233, 0.82);
  --brown: #724404;
  --brown-soft: rgba(114, 68, 4, 0.8);
  --white-line: rgba(255, 255, 255, 0.42);
  --card-shadow: 0 20px 40px rgba(131, 52, 7, 0.16);
  --radius-xl: 38px;
  --radius-lg: 28px;
  --radius-md: 20px;
  --content-width: min(1160px, calc(100vw - 40px));
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: #fff;
  font-family: "M PLUS Rounded 1c", sans-serif;
  background:
    radial-gradient(circle at 10% 12%, rgba(255, 209, 168, 0.38), transparent 16%),
    radial-gradient(circle at 88% 24%, rgba(255, 242, 223, 0.18), transparent 18%),
    radial-gradient(circle at 78% 74%, rgba(255, 191, 122, 0.22), transparent 16%),
    linear-gradient(180deg, #ea6f1c 0%, #e05e0e 38%, #d7550a 100%);
}

.site-header {
  position: absolute;
  inset: 0 0 auto;
  z-index: 50;
}

body.is-loaded .site-header {
  animation: headerFadeIn 900ms ease both;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, 0.13) 0 68px, transparent 69px),
    radial-gradient(circle at 84% 10%, rgba(255, 255, 255, 0.1) 0 96px, transparent 97px),
    radial-gradient(circle at 72% 82%, rgba(255, 255, 255, 0.08) 0 84px, transparent 85px);
  pointer-events: none;
}

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

.text-link {
  color: var(--brown);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.keep-inline {
  white-space: nowrap;
}

button,
input,
select,
textarea {
  font: inherit;
}

.page-shell {
  position: relative;
  overflow: clip;
}

.page-shell::before,
.page-shell::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  height: 220px;
  pointer-events: none;
  z-index: 0;
}

.page-shell::before {
  top: 660px;
  background:
    radial-gradient(circle at 16% 10%, rgba(255, 255, 255, 0.22) 0 80px, transparent 81px),
    radial-gradient(circle at 76% 20%, rgba(255, 255, 255, 0.18) 0 110px, transparent 111px);
}

.page-shell::after {
  bottom: 180px;
  background:
    radial-gradient(circle at 20% 60%, rgba(255, 193, 131, 0.22) 0 120px, transparent 121px),
    radial-gradient(circle at 86% 50%, rgba(255, 255, 255, 0.12) 0 86px, transparent 87px);
}

.ambient {
  position: absolute;
  border-radius: 42% 58% 48% 52% / 38% 34% 66% 62%;
  filter: none;
  opacity: 0.34;
  pointer-events: none;
  overflow: visible;
}

.ambient::before {
  content: "";
  position: absolute;
  inset: 8% 12% 14% 10%;
  border-radius: 48% 52% 44% 56% / 42% 38% 62% 58%;
  background: rgba(255, 232, 205, 0.34);
}

.ambient-left {
  width: 340px;
  height: 280px;
  top: 178px;
  left: -86px;
  background: linear-gradient(180deg, rgba(255, 225, 191, 0.3), rgba(255, 205, 150, 0.18));
  animation: ambientFloatLeft 16s ease-in-out infinite;
}

.ambient-right {
  width: 300px;
  height: 244px;
  top: 566px;
  right: -72px;
  background: linear-gradient(180deg, rgba(255, 213, 168, 0.24), rgba(255, 186, 120, 0.16));
  animation: ambientFloatRight 20s ease-in-out infinite;
}

.topbar,
.nav-wrap,
.section,
.site-footer {
  width: var(--content-width);
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.topbar {
  display: none;
}

.nav-wrap {
  position: static;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 26px 10px 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  backdrop-filter: none;
}

.brand {
  display: flex;
  align-items: center;
  gap: 14px;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.82);
  background: transparent;
  color: #fff;
  font-size: 1.22rem;
  font-weight: 800;
}

.brand-copy {
  display: flex;
  flex-direction: column;
}

.brand-copy strong {
  font-size: 1.15rem;
  letter-spacing: 0.04em;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-weight: 600;
}

.brand-copy small {
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: lowercase;
}

.site-nav {
  display: flex;
  align-items: center;
  gap: 20px;
}

.site-nav a {
  font-size: 1rem;
  font-weight: 500;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  transition: opacity 300ms ease, transform 300ms ease, text-shadow 300ms ease;
}

.site-nav a:hover {
  transform: translateY(-2px);
  text-shadow: 0 6px 16px rgba(255, 255, 255, 0.18);
}

.nav-cta {
  color: #fff;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.menu-toggle {
  display: none;
  width: 48px;
  height: 48px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 6px;
  cursor: pointer;
}

.menu-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  background: #fff;
  transition: transform 180ms ease, opacity 180ms ease;
}

.section {
  padding: 92px 0;
}

.hero {
  display: block;
  min-height: 100vh;
  padding-top: 120px;
  padding-bottom: 72px;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 78%, rgba(247, 222, 182, 0.92), rgba(247, 222, 182, 0.08) 26%, transparent 44%),
    linear-gradient(180deg, rgba(48, 49, 53, 0.92) 0%, rgba(96, 84, 77, 0.7) 28%, rgba(233, 198, 146, 0.88) 82%, rgba(104, 78, 43, 0.88) 100%);
  border-radius: 0 0 36px 36px;
}

.hero::after {
  content: "PLAY";
  position: absolute;
  left: 50%;
  top: 48%;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  width: 86px;
  height: 86px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.8);
  color: rgba(255, 255, 255, 0.92);
  font-family: "Cormorant Garamond", serif;
  font-size: 1rem;
  letter-spacing: 0.08em;
  backdrop-filter: blur(2px);
  z-index: 1;
}

.hero-copy {
  position: relative;
  max-width: 680px;
  margin: min(56vh, 520px) auto 0;
  padding: 0 12px;
  border-radius: 0;
  background: transparent;
  color: #fff;
  box-shadow: none;
  text-align: center;
}

.hero-copy::after {
  display: none;
}

.hero-panel {
  display: none;
}

.eyebrow,
.mini-label {
  margin: 0 0 12px;
  font-size: 0.86rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.84);
}

.hero h1,
.section-heading h2,
.spotlight h2,
.contact h2,
.legal-wrap h1 {
  margin: 0;
  font-size: clamp(2.6rem, 5vw, 5.2rem);
  line-height: 1.08;
  letter-spacing: -0.04em;
  font-weight: 800;
}

.hero h1 {
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.5;
  text-shadow: 0 12px 22px rgba(0, 0, 0, 0.2);
}

.lead,
.section-heading p,
.spotlight p,
.contact-copy p,
.legal-wrap .lead {
  line-height: 1.95;
  font-size: 1rem;
}

.hero-copy .lead,
.hero-copy h1 {
  color: #fff;
}

.hero-actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 28px;
  flex-wrap: wrap;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 24px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 800;
  cursor: pointer;
  transition: transform 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.button:hover {
  transform: translateY(-2px);
}

.button-primary {
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.44);
  box-shadow: none;
  backdrop-filter: blur(8px) brightness(1.1);
}

.button-primary:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.button-secondary {
  border-color: rgba(255, 255, 255, 0.34);
  color: #fff;
  background: transparent;
  backdrop-filter: none;
}

.hero-badges {
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.hero-badges li {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(255, 255, 255, 0.88);
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(8px);
}

.hero-badges li::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9);
  flex-shrink: 0;
}

.panel-card,
.service-card,
.policy-card,
.plan-card,
.spotlight-card,
.contact-form,
.metrics article,
.faq-list details,
.audience-card,
.flow-list article,
.legal-table div,
.legal-stack .policy-card {
  border-radius: var(--radius-xl);
  box-shadow: var(--card-shadow);
}

.panel-card,
.metrics article,
.audience-card,
.service-card,
.plan-card,
.flow-list article {
  background:
    radial-gradient(circle at top right, rgba(255, 210, 159, 0.42), transparent 34%),
    linear-gradient(180deg, rgba(255, 247, 233, 0.94), rgba(255, 229, 194, 0.92));
  color: var(--brown);
}

.panel-card {
  padding: 28px;
}

.status-card {
  min-height: 320px;
}

.panel-grid {
  display: grid;
  gap: 18px;
  margin-top: 40px;
}

.panel-grid div {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding-bottom: 16px;
  border-bottom: 2px solid rgba(224, 94, 14, 0.12);
}

.panel-grid div:last-child {
  border-bottom: 0;
}

.panel-value {
  font-size: 2.6rem;
  color: var(--orange);
  line-height: 1;
  font-weight: 800;
}

.concierge-card {
  color: #fff;
  background:
    radial-gradient(circle at 88% 12%, rgba(255, 203, 151, 0.26), transparent 22%),
    linear-gradient(180deg, #ec701d 0%, #d95809 100%);
}

.card-heading {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}

.concierge-card .mini-label,
.concierge-card .card-heading span {
  color: rgba(255, 255, 255, 0.78);
}

.concierge-card ul {
  margin: 20px 0 0;
  padding-left: 18px;
  display: grid;
  gap: 14px;
}

.metrics {
  display: none;
}

.metrics article {
  padding: 24px;
}

.metrics strong {
  display: block;
  margin-bottom: 8px;
  font-size: 1.46rem;
  color: var(--orange);
  font-weight: 800;
}

.metrics p,
.service-card p,
.audience-card p,
.policy-card li,
.plan-card li,
.flow-list p,
.faq-list p,
.site-footer p {
  line-height: 1.85;
}

.section-heading {
  max-width: 860px;
  text-align: center;
  margin: 0 auto;
}

.section-heading h2 {
  font-size: clamp(2.3rem, 4vw, 4.2rem);
  margin-bottom: 14px;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-weight: 600;
}

.section-heading h2::after {
  content: "";
  display: block;
  width: 92px;
  height: 4px;
  margin: 18px auto 0;
  border-radius: 999px;
  background: currentColor;
}

.audience-grid,
.service-grid,
.policy-grid,
.plan-grid {
  display: grid;
  gap: 18px;
  margin-top: 32px;
}

.audience-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.audience-card,
.service-card,
.plan-card {
  padding: 28px;
}

.audience-card span,
.service-index,
.plan-name {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  padding: 7px 14px;
  border-radius: 999px;
  background: rgba(224, 94, 14, 0.12);
  color: var(--orange);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.audience-card {
  background: rgba(255, 183, 112, 0.16);
  border: 0;
  box-shadow: none;
  color: #fff;
}

.audience-card h3,
.audience-card p {
  color: #fff;
}

.audience-card h3,
.service-card h3,
.spotlight-card h3,
.policy-card h3,
.flow-list h3 {
  margin: 0 0 12px;
  font-size: 1.34rem;
  line-height: 1.45;
}

.service-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.service-card {
  min-height: 230px;
  border-radius: 42% 58% 44% 56% / 36% 34% 66% 64%;
}

.spotlight {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: 22px;
  align-items: stretch;
}

.spotlight-copy {
  padding: 26px 0;
}

.spotlight-copy .eyebrow,
.spotlight-copy h2,
.spotlight-copy p,
.spotlight-copy strong,
.spotlight-copy .case-list article p {
  color: #fff;
}

.spotlight-copy h2::after {
  content: "";
  display: block;
  width: 88px;
  height: 4px;
  border-radius: 999px;
  margin-top: 18px;
  background: rgba(255, 255, 255, 0.8);
}

.case-list {
  display: grid;
  gap: 18px;
  margin-top: 30px;
}

.case-list article {
  padding: 22px 24px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(10px);
}

.case-list strong {
  display: block;
  margin-bottom: 8px;
}

.spotlight-card {
  padding: 34px;
  min-height: 520px;
  background:
    radial-gradient(circle at 70% 30%, rgba(255, 233, 204, 0.18), transparent 16%),
    linear-gradient(180deg, rgba(130, 81, 31, 0.46), rgba(88, 56, 22, 0.42)),
    linear-gradient(135deg, #d8b181 0%, #b7834a 38%, #8f6037 100%);
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border-radius: 46% 54% 38% 62% / 32% 36% 64% 68%;
}

.policy,
.compliance,
.faq,
.contact {
  box-shadow: 0 0 0 100vmax var(--cream);
  clip-path: inset(0 -100vmax);
  color: var(--brown);
}

.policy::before,
.compliance::before,
.faq::before,
.contact::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -74px;
  width: 108vw;
  height: 126px;
  background: url("./assets/decor/cream-section-wave.svg") center top / 100% 100% no-repeat;
  transform: translate3d(-50%, 0, 0) scaleX(1);
  transform-origin: center top;
  will-change: transform;
  animation: sectionWaveFloat 8.5s cubic-bezier(0.42, 0, 0.22, 1) infinite;
  pointer-events: none;
}

.policy .eyebrow,
.compliance .eyebrow,
.faq .eyebrow,
.contact .eyebrow,
.policy h2,
.compliance h2,
.faq h2,
.contact h2,
.policy .section-heading p,
.compliance .section-heading p,
.faq .section-heading p,
.contact .contact-copy p {
  color: var(--brown);
}

.policy-card,
.contact-form,
.faq-list details,
.legal-stack .policy-card,
.legal-table div {
  background:
    radial-gradient(circle at top right, rgba(255, 214, 168, 0.32), transparent 30%),
    rgba(255, 250, 243, 0.96);
  color: var(--brown);
  border: 1px solid rgba(224, 94, 14, 0.12);
}

.policy-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.policy-card {
  padding: 30px;
}

.policy-card ul,
.plan-card ul {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 12px;
}

.plan-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.plan-card strong {
  display: block;
  font-size: 2.6rem;
  color: var(--brown);
  margin: 0 0 8px;
}

.plan-card span {
  display: block;
  margin-bottom: 24px;
  color: var(--brown-soft);
}

.featured {
  background:
    radial-gradient(circle at top right, rgba(255, 191, 122, 0.42), transparent 32%),
    linear-gradient(180deg, #fff9f0 0%, #ffd8ad 100%);
  outline: 2px solid rgba(224, 94, 14, 0.14);
}

.flow .section-heading,
.flow .section-heading h2,
.flow .section-heading p {
  color: #fff;
}

.flow-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.flow-list article {
  position: relative;
  padding: 28px;
}

.flow-list span {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: 20px;
  border-radius: 50%;
  background: var(--orange);
  color: #fff;
  font-weight: 800;
}

.faq-list {
  display: grid;
  gap: 14px;
  margin-top: 26px;
}

.faq-list details {
  padding: 0 24px;
}

.faq-list summary {
  list-style: none;
  cursor: pointer;
  font-weight: 800;
  padding: 22px 0;
  position: relative;
}

.faq-list summary::-webkit-details-marker {
  display: none;
}

.faq-list summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 17px;
  font-size: 1.5rem;
  color: var(--orange);
}

.faq-list details[open] summary::after {
  content: "-";
}

.faq-list p {
  margin: 0 0 22px;
  color: var(--brown-soft);
}

.contact {
  display: grid;
  grid-template-columns: 0.94fr 1.06fr;
  gap: 22px;
}

.contact-form {
  display: grid;
  gap: 16px;
  padding: 30px;
}

.contact-form label {
  display: grid;
  gap: 8px;
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--brown);
}

.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  border: 1px solid rgba(224, 94, 14, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.85);
  padding: 15px 16px;
  color: var(--brown);
}

.contact-form textarea {
  resize: vertical;
  min-height: 150px;
}

.submit-button {
  width: 100%;
  background: linear-gradient(180deg, var(--orange-soft), var(--orange));
  color: #fff;
}

.form-note {
  margin: 0;
  font-size: 0.88rem;
  color: var(--brown-soft);
}

.site-footer {
  padding: 36px 0 56px;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
  color: rgba(255, 255, 255, 0.86);
}

.footer-links {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.footer-links .text-link {
  color: #fff;
}

.result-dialog {
  width: min(560px, calc(100vw - 24px));
  border: 0;
  border-radius: 32px;
  padding: 0;
  background: rgba(255, 248, 238, 0.98);
  box-shadow: 0 30px 70px rgba(113, 59, 6, 0.22);
}

.result-dialog::backdrop {
  background: rgba(81, 36, 2, 0.36);
  backdrop-filter: blur(4px);
}

.dialog-inner {
  padding: 28px;
  color: var(--brown);
}

.dialog-inner h2 {
  margin: 0 0 18px;
  font-size: 2rem;
}

#result-output {
  padding: 18px;
  border-radius: 22px;
  background: rgba(224, 94, 14, 0.08);
  white-space: pre-wrap;
  line-height: 1.8;
  font-family: "M PLUS Rounded 1c", sans-serif;
  margin-bottom: 18px;
}

.legal-page {
  min-height: 100vh;
  color: var(--brown);
  background:
    radial-gradient(circle at 12% 16%, rgba(255, 214, 168, 0.4), transparent 18%),
    linear-gradient(180deg, #fff7ea 0%, #ffe8c8 100%);
}

.legal-wrap {
  max-width: 860px;
}

.legal-wrap .eyebrow,
.legal-wrap h1,
.legal-wrap .lead {
  color: var(--brown);
}

.legal-wrap h1 {
  margin: 10px 0 16px;
  font-size: clamp(2.4rem, 5vw, 4.4rem);
}

.legal-table,
.legal-stack {
  display: grid;
  gap: 16px;
  margin-top: 28px;
}

.legal-table div {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 16px;
  padding: 24px;
}

.legal-table strong {
  color: var(--orange);
}

.reveal {
  opacity: 0;
  filter: blur(10px);
  transform: translateY(50px);
  transition:
    opacity 900ms ease,
    filter 900ms ease,
    transform 900ms cubic-bezier(0.2, 0.8, 0.2, 1);
  transition-delay: var(--reveal-delay, 0ms);
}

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

/* ----------------------------------------------------------------
Osolo-like brand page rewrite
----------------------------------------------------------------- */
.brand-copy-script {
  gap: 0;
}

.brand-copy-script strong {
  font-size: 3.3rem;
  line-height: 0.8;
}

.brand-copy-script small {
  margin-top: 2px;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
}

.hero {
  min-height: 100vh;
  padding-top: 0;
  padding-bottom: 0;
}

.hero-copy {
  min-height: 100vh;
  margin: 0;
  max-width: none;
  display: grid;
  place-items: center;
  padding: 0;
}

.play-ring {
  width: 86px;
  height: 86px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.8);
  background: transparent;
  color: rgba(255, 255, 255, 0.92);
  font-family: "Cormorant Garamond", serif;
  font-size: 1rem;
  letter-spacing: 0.08em;
  cursor: pointer;
}

.play-ring span {
  position: relative;
  display: inline-block;
  padding-top: 16px;
}

.play-ring span::before {
  content: "";
  position: absolute;
  top: -2px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid rgba(255, 255, 255, 0.9);
}

.hero::after {
  display: none;
}

.promo,
.concept-block,
.showcase,
.products,
.support-stage {
  position: relative;
  color: #fff;
}

.promo::before,
.concept-block::before,
.products::before,
.support-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 190, 124, 0.22) 0 130px, transparent 131px),
    radial-gradient(circle at 82% 16%, rgba(255, 190, 124, 0.18) 0 150px, transparent 151px);
  pointer-events: none;
}

.promo {
  isolation: isolate;
  z-index: 2;
  margin-top: -92px;
  padding-top: 118px;
  padding-bottom: 34px;
  background-color: #d8802c;
  background-image: url("./assets/decor/promo-wave-top.svg");
  background-position: center top;
  background-size: 100% 154px;
  background-repeat: no-repeat;
}

.promo::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 180px;
  background:
    radial-gradient(55% 120px at 18% 0, rgba(232, 128, 36, 0.95) 0 60%, transparent 61%),
    radial-gradient(60% 140px at 50% 16px, rgba(232, 128, 36, 0.95) 0 58%, transparent 59%),
    radial-gradient(48% 120px at 84% 0, rgba(232, 128, 36, 0.95) 0 58%, transparent 59%);
  pointer-events: none;
}

.promo-announcement {
  position: relative;
  z-index: 2;
  text-align: center;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0.03em;
  margin-bottom: 24px;
}

.promo-blob {
  position: relative;
  z-index: 2;
  width: min(760px, 86vw);
  min-height: 320px;
  margin: 0 auto;
  padding: 36px 40px;
  border-radius: 42% 58% 48% 52% / 40% 34% 66% 60%;
  background:
    radial-gradient(circle at 28% 32%, rgba(255, 255, 255, 0.28) 0 24px, transparent 25px),
    radial-gradient(circle at 68% 24%, rgba(255, 221, 170, 0.3) 0 94px, transparent 95px),
    linear-gradient(180deg, #f8dca7 0%, #efc47e 100%);
  box-shadow: 0 30px 50px rgba(165, 79, 8, 0.18);
  color: var(--brown);
}

.promo-blob::before,
.promo-blob::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  background: rgba(255, 229, 194, 0.44);
}

.promo-blob::before {
  width: 150px;
  height: 150px;
  right: 54px;
  top: 28px;
}

.promo-blob::after {
  width: 120px;
  height: 120px;
  left: 44px;
  bottom: 22px;
}

.promo-blob-copy {
  position: relative;
  z-index: 1;
  max-width: 320px;
}

.promo-blob-copy p,
.promo-blob-copy small {
  margin: 0;
}

.promo-blob-copy p {
  font-size: 1.08rem;
  font-weight: 700;
}

.promo-blob-copy h2 {
  margin: 12px 0;
  font-size: clamp(2.2rem, 4vw, 3.6rem);
  line-height: 1.12;
  color: var(--brown);
}

.promo-product {
  position: absolute;
  right: 44px;
  top: 44px;
  width: min(280px, 34vw);
  aspect-ratio: 0.9;
  border-radius: 45% 55% 44% 56% / 44% 38% 62% 56%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.5) 0 16px, transparent 17px),
    linear-gradient(180deg, rgba(255, 234, 194, 0.9), rgba(241, 198, 124, 0.96));
}

.promo-tag {
  position: absolute;
  right: 6px;
  top: 24px;
  padding: 12px 14px;
  border-radius: 50%;
  background: rgba(224, 94, 14, 0.18);
  font-size: 0.85rem;
  color: #fff;
}

.promo-bottle {
  position: absolute;
  bottom: 36px;
  width: 82px;
  border-radius: 24px 24px 28px 28px;
  background: linear-gradient(180deg, #efbe7d 0%, #d98d46 100%);
  box-shadow: inset 0 -12px 20px rgba(154, 79, 17, 0.22);
}

.promo-bottle::before {
  content: "";
  position: absolute;
  top: -34px;
  left: 50%;
  transform: translateX(-50%);
  width: 28px;
  height: 42px;
  border-radius: 12px 12px 8px 8px;
  background: linear-gradient(180deg, #f7dfb5, #efc77b);
}

.promo-bottle::after {
  content: "";
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  width: 42px;
  height: 12px;
  border-radius: 999px;
  background: rgba(255, 244, 222, 0.88);
}

.promo-bottle-left {
  left: calc(50% - 70px);
  height: 170px;
}

.promo-bottle-right {
  left: calc(50% + 10px);
  height: 158px;
  background: linear-gradient(180deg, #f8da7b 0%, #e8b44f 100%);
}

.promo-heading {
  position: relative;
  z-index: 2;
  margin-top: 78px;
}

.promo-heading .eyebrow,
.products .eyebrow,
.flow .eyebrow,
.faq .eyebrow,
.contact .eyebrow {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  text-transform: none;
  letter-spacing: 0;
  color: #fff;
}

.promo-heading h2,
.products h2 {
  max-width: 760px;
  margin: 0 auto;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-style: normal;
  font-size: clamp(1.2rem, 2vw, 1.7rem);
  line-height: 2;
  font-weight: 700;
}

.promo-heading h2::after,
.products .section-heading h2::after {
  width: 72px;
  background: rgba(255, 255, 255, 0.82);
}

.promo-heading p {
  color: rgba(255, 255, 255, 0.9);
}

.concept-block {
  padding-top: 28px;
  padding-bottom: 56px;
}

.concept-copy {
  position: relative;
  z-index: 1;
  max-width: 620px;
  margin: 0 auto;
  text-align: center;
}

.concept-copy p {
  margin: 0 0 12px;
  font-size: 1.05rem;
  line-height: 1.9;
}

.concept-copy h2 {
  margin: 36px 0 0;
  font-size: clamp(2.1rem, 4vw, 3.4rem);
  line-height: 1.4;
  color: #fff;
}

.showcase {
  padding-top: 0;
  padding-bottom: 0;
}

.showcase-visual {
  width: 100%;
  min-height: 370px;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  overflow: hidden;
}

.showcase-left,
.showcase-right {
  position: relative;
  min-height: 370px;
}

.showcase-left {
  background:
    linear-gradient(180deg, rgba(57, 39, 23, 0.18), rgba(57, 39, 23, 0.18)),
    linear-gradient(135deg, #efd8b7 0%, #b98757 58%, #9d6637 100%);
}

.showcase-left::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 58%, rgba(38, 24, 14, 0.28) 0 120px, transparent 121px),
    radial-gradient(circle at 48% 54%, rgba(251, 241, 224, 0.78) 0 140px, transparent 141px),
    linear-gradient(180deg, transparent 0 58%, rgba(58, 40, 22, 0.32) 58% 100%);
  mix-blend-mode: multiply;
}

.showcase-right {
  background:
    linear-gradient(180deg, rgba(98, 60, 28, 0.18), rgba(98, 60, 28, 0.18)),
    linear-gradient(180deg, #c99a67 0%, #ae7744 56%, #8b5c36 100%);
}

.showcase-right::before {
  content: "";
  position: absolute;
  left: -180px;
  top: 0;
  bottom: 0;
  width: 320px;
  background: rgba(255, 244, 228, 0.96);
  border-radius: 0 0 220px 0;
  transform: skewX(-24deg);
}

.showcase-logo {
  position: absolute;
  left: -100px;
  top: 18px;
  z-index: 2;
  color: #fff;
}

.showcase-logo span {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(6rem, 10vw, 10rem);
  font-style: italic;
  line-height: 0.82;
}

.showcase-logo small {
  display: block;
  margin-left: 180px;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
}

.showcase-bottles {
  position: absolute;
  right: 46px;
  top: 40px;
  display: flex;
  gap: 30px;
  z-index: 3;
}

.showcase-bottle {
  width: 150px;
  height: 210px;
  border-radius: 34px 34px 52px 52px;
  background: linear-gradient(180deg, #e8a355 0%, #cd7c35 100%);
  box-shadow: inset 0 -18px 26px rgba(141, 70, 16, 0.24);
}

.showcase-bottle::before {
  content: "";
  position: absolute;
  top: -18px;
  width: 56px;
  height: 20px;
  border-radius: 999px;
  background: rgba(255, 245, 223, 0.88);
}

.showcase-bottle::after {
  content: "";
  position: absolute;
  top: 34px;
  left: 20px;
  right: 20px;
  height: 50px;
  border-radius: 20px;
  border: 1px solid rgba(114, 68, 4, 0.18);
  opacity: 0.45;
}

.showcase-bottle-left {
  position: relative;
}

.showcase-bottle-right {
  position: relative;
  background: linear-gradient(180deg, #f0be58 0%, #dca040 100%);
}

.products {
  padding-top: 58px;
  padding-bottom: 64px;
}

.products .section-heading p {
  color: rgba(255, 255, 255, 0.9);
  max-width: 760px;
  margin: 0 auto;
}

.product-blob {
  position: relative;
  z-index: 1;
  width: min(450px, 72vw);
  min-height: 260px;
  margin: 36px auto 0;
  border-radius: 46% 54% 0 0 / 38% 38% 0 0;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(86, 57, 26, 0.18), rgba(86, 57, 26, 0.18)),
    linear-gradient(180deg, #c79763 0%, #9a6438 70%, #7d4f2b 100%);
}

.product-bottle {
  position: absolute;
  bottom: 0;
  width: 100px;
  height: 150px;
  border-radius: 26px 26px 36px 36px;
  box-shadow: inset 0 -14px 20px rgba(141, 70, 16, 0.2);
}

.product-bottle::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  width: 46px;
  height: 14px;
  border-radius: 999px;
  background: rgba(255, 245, 223, 0.88);
}

.product-bottle-left {
  left: calc(50% - 76px);
  background: linear-gradient(180deg, #e8a355 0%, #cd7c35 100%);
}

.product-bottle-right {
  left: calc(50% + 6px);
  background: linear-gradient(180deg, #f0be58 0%, #dca040 100%);
}

.product-badge {
  position: absolute;
  right: 34px;
  top: 42px;
  display: grid;
  place-items: center;
  width: 86px;
  height: 86px;
  border-radius: 50%;
  background: rgba(84, 45, 26, 0.74);
  color: #fff;
  text-align: center;
  font-size: 0.86rem;
  line-height: 1.45;
  animation: badgeFloat 7s ease-in-out infinite;
}

.support-stage {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 36px;
  align-items: center;
  padding-top: 34px;
  padding-bottom: 86px;
}

.support-copy {
  position: relative;
  z-index: 1;
}

.support-copy p {
  margin: 0 0 14px;
  font-size: 1rem;
  line-height: 1.9;
}

.support-copy h3 {
  margin: 26px 0 28px;
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  line-height: 1.4;
}

.support-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 174px;
  min-height: 56px;
  padding: 0 26px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.56);
  color: #fff;
  background: transparent;
  font-weight: 700;
  transition: transform 220ms ease, background 220ms ease, box-shadow 260ms ease;
}

.support-link::after {
  content: "→";
  margin-left: 14px;
  font-size: 1.2rem;
  transition: transform 220ms ease;
}

.support-link:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(111, 47, 4, 0.18);
}

.support-link:hover::after {
  transform: translateX(5px);
}

.support-visual {
  position: relative;
  z-index: 1;
  min-height: 430px;
}

.support-photo {
  position: absolute;
  right: 0;
  width: min(420px, 100%);
  height: 420px;
  border-radius: 48% 52% 44% 56% / 42% 42% 58% 58%;
  background:
    linear-gradient(180deg, rgba(69, 45, 24, 0.14), rgba(69, 45, 24, 0.14)),
    linear-gradient(135deg, #d2b18b 0%, #a77449 60%, #8a5d34 100%);
  overflow: hidden;
  animation: frameDrift 15s ease-in-out infinite;
}

.support-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 28% 50%, rgba(73, 44, 22, 0.22) 0 100px, transparent 101px),
    radial-gradient(circle at 64% 48%, rgba(255, 242, 224, 0.74) 0 120px, transparent 121px),
    linear-gradient(180deg, transparent 0 72%, rgba(92, 61, 30, 0.24) 72% 100%);
  mix-blend-mode: multiply;
}

.support-sticker {
  position: absolute;
  right: 34px;
  bottom: 18px;
  padding: 22px 28px;
  border-radius: 46% 54% 50% 50% / 44% 40% 60% 56%;
  background: rgba(224, 136, 34, 0.94);
  color: #fff;
  font-size: 1.1rem;
  line-height: 1.7;
  box-shadow: 0 18px 34px rgba(157, 73, 10, 0.2);
  animation: badgeFloat 8s ease-in-out infinite reverse;
}

@media (max-width: 980px) {
  .hero,
  .spotlight,
  .contact,
  .metrics,
  .plan-grid,
  .flow-list {
    grid-template-columns: 1fr;
  }

  .audience-grid,
  .service-grid,
  .policy-grid {
    grid-template-columns: 1fr;
  }

  .site-nav {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 12px);
    display: none;
    padding: 20px;
    border-radius: 30px;
    background: rgba(231, 95, 17, 0.96);
    box-shadow: 0 18px 40px rgba(117, 47, 5, 0.2);
    flex-direction: column;
    align-items: stretch;
  }

  .site-nav.is-open {
    display: flex;
  }

  .menu-toggle {
    display: inline-flex;
  }
}

@media (max-width: 720px) {
  :root {
    --content-width: min(100vw - 24px, 1160px);
  }

  .topbar {
    justify-content: flex-start;
  }

  .topbar span {
    font-size: 0.7rem;
  }

  .nav-wrap {
    padding: 18px 0 0;
  }

  .brand-copy small {
    display: block;
  }

  .section {
    padding: 72px 0;
  }

  .hero {
    min-height: 92vh;
    padding-top: 98px;
    padding-bottom: 52px;
  }

  .hero-copy {
    margin-top: min(56vh, 420px);
  }

  .hero h1,
  .section-heading h2,
  .spotlight h2,
  .contact h2,
  .legal-wrap h1 {
    font-size: clamp(2.1rem, 10vw, 3.4rem);
    line-height: 1.22;
  }

  .hero::after {
    width: 72px;
    height: 72px;
    top: 44%;
  }

  .panel-card,
  .audience-card,
  .service-card,
  .policy-card,
  .plan-card,
  .contact-form,
  .spotlight-card,
  .flow-list article {
    padding: 22px;
  }

  .policy::before,
  .compliance::before,
  .faq::before,
  .contact::before {
    top: -50px;
    width: 118vw;
    height: 88px;
  }

  .site-footer {
    padding-bottom: 44px;
  }

  .legal-table div {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
  .promo-blob {
    width: min(620px, 90vw);
    padding: 28px 28px 240px;
  }

  .promo-product {
    right: 50%;
    top: auto;
    bottom: 24px;
    transform: translateX(50%);
    width: min(250px, 52vw);
  }

  .showcase-visual,
  .support-stage {
    grid-template-columns: 1fr;
  }

  .showcase-right::before {
    display: none;
  }

  .showcase-logo {
    left: 18px;
    top: 12px;
  }

  .showcase-logo span {
    font-size: clamp(4.2rem, 18vw, 7rem);
  }

  .showcase-logo small {
    margin-left: 100px;
  }

  .showcase-bottles {
    right: 24px;
    top: 110px;
  }

  .support-visual {
    min-height: 460px;
  }

  .support-photo {
    right: 50%;
    transform: translateX(50%);
  }
}

@media (max-width: 720px) {
  .brand-copy-script strong {
    font-size: 2.7rem;
  }

  .site-nav a {
    font-size: 1.3rem;
  }

  .hero {
    min-height: 88vh;
  }

  .play-ring {
    width: 72px;
    height: 72px;
  }

  .promo {
    padding-top: 34px;
    padding-bottom: 22px;
  }

  .promo-announcement {
    font-size: 0.95rem;
  }

  .promo-blob {
    min-height: 0;
    padding: 24px 22px 210px;
  }

  .promo-blob-copy h2 {
    font-size: 2rem;
  }

  .promo-product {
    width: 220px;
  }

  .promo-heading {
    margin-top: 54px;
  }

  .promo-heading .eyebrow,
  .products .eyebrow,
  .flow .eyebrow,
  .faq .eyebrow,
  .contact .eyebrow {
    font-size: 2.4rem;
  }

  .promo-heading h2,
  .products h2 {
    font-size: 1rem;
    line-height: 1.9;
  }

  .concept-copy p {
    font-size: 0.95rem;
  }

  .concept-copy h2 {
    font-size: 2rem;
    line-height: 1.6;
  }

  .showcase-visual,
  .showcase-left,
  .showcase-right {
    min-height: 260px;
  }

  .showcase-bottles {
    gap: 16px;
    top: 96px;
    right: 18px;
  }

  .showcase-bottle {
    width: 96px;
    height: 138px;
  }

  .product-blob {
    min-height: 220px;
  }

  .product-bottle {
    width: 82px;
    height: 126px;
  }

  .support-copy h3 {
    font-size: 2rem;
    line-height: 1.6;
  }

  .support-visual {
    min-height: 340px;
  }

  .support-photo {
    width: min(320px, 88vw);
    height: 320px;
  }

  .support-sticker {
    right: 12px;
    bottom: 8px;
    padding: 18px 22px;
    font-size: 0.96rem;
  }
}

/* ----------------------------------------------------------------
Screenshot alignment pass
----------------------------------------------------------------- */
body {
  background: linear-gradient(180deg, #da7a2d 0%, #d47126 100%);
}

body::before,
.ambient,
.page-shell::before,
.page-shell::after {
  display: none;
}

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 80;
}

.nav-wrap {
  width: min(1308px, calc(100vw - 64px));
  padding: 30px 0 0;
  align-items: flex-start;
}

.brand-copy-script {
  gap: 0;
}

.brand-copy-script strong {
  font-family: "Parisienne", cursive;
  font-size: clamp(3.6rem, 4.6vw, 4.9rem);
  line-height: 0.72;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0;
}

.brand-copy-script small {
  margin-top: 4px;
  margin-left: 24px;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
}

.site-nav {
  gap: 22px;
  padding-top: 12px;
}

.site-nav a {
  font-size: 1.55rem;
  letter-spacing: 0;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.12);
  transition: opacity 300ms ease, transform 300ms ease, text-shadow 300ms ease;
}

.site-nav a:hover {
  transform: translateY(-2px);
  text-shadow: 0 6px 16px rgba(255, 255, 255, 0.18);
}

.nav-cta {
  padding: 0;
}

.hero {
  position: relative;
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  min-height: 100vh;
  padding: 0;
  overflow: hidden;
}

.hero::before {
  border-radius: 0;
  background: linear-gradient(180deg, rgba(26, 22, 20, 0.22) 0%, rgba(26, 22, 20, 0.08) 24%, rgba(255, 245, 228, 0.08) 100%);
}

.hero-film {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background: #d7dfdf;
}

body.is-loaded .hero-film {
  animation: heroReveal 1400ms ease both;
}

.hero-illustration {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
  filter: saturate(0.78) contrast(1.02) brightness(0.92);
  transform: scale(1.03);
  animation: heroDrift 22s ease-in-out infinite alternate;
}

.hero-film::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 68%, rgba(250, 230, 199, 0.34) 0, rgba(250, 230, 199, 0.12) 18%, transparent 34%),
    radial-gradient(circle at 80% 18%, rgba(255, 255, 255, 0.08) 0 160px, transparent 161px),
    linear-gradient(90deg, rgba(24, 20, 17, 0.24) 0%, rgba(24, 20, 17, 0.12) 36%, transparent 66%),
    linear-gradient(180deg, rgba(24, 20, 17, 0.14) 0%, transparent 40%, rgba(24, 20, 17, 0.08) 100%);
  animation: shimmerShift 18s ease-in-out infinite alternate;
}

.hero-film::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8, 7, 8, 0.16) 0%, rgba(8, 7, 8, 0) 30%, rgba(8, 7, 8, 0.2) 100%),
    linear-gradient(0deg, rgba(255, 244, 226, 0.12) 0%, rgba(255, 244, 226, 0) 22%);
}

.hero-haze {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 66% 76%, rgba(255, 233, 205, 0.16) 0 210px, transparent 211px),
    radial-gradient(circle at 24% 14%, rgba(255, 255, 255, 0.06) 0 160px, transparent 161px);
  animation: hazeFloat 20s ease-in-out infinite alternate;
}

.hero-silhouette {
  display: none;
}

.hero-silhouette-left {
  left: -20px;
  width: 250px;
  height: 210px;
  clip-path: polygon(0 100%, 10% 58%, 18% 72%, 24% 38%, 32% 70%, 40% 28%, 48% 74%, 56% 44%, 65% 82%, 72% 48%, 82% 84%, 90% 62%, 100% 100%);
}

.hero-silhouette-right {
  right: -30px;
  width: 300px;
  height: 160px;
  clip-path: polygon(0 100%, 8% 56%, 18% 80%, 28% 38%, 38% 82%, 46% 46%, 56% 88%, 66% 52%, 76% 78%, 86% 34%, 94% 76%, 100% 100%);
}

.hero-figures {
  display: none;
}

.hero-figure {
  position: absolute;
  bottom: 0;
  background: linear-gradient(180deg, rgba(38, 32, 28, 0.98), rgba(18, 16, 15, 0.98));
}

.hero-figure::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(38, 32, 28, 0.98), rgba(18, 16, 15, 0.98));
  border-radius: 50%;
}

.hero-figure-tall {
  right: 16px;
  width: 52px;
  height: 126px;
  border-radius: 34px 34px 10px 10px;
}

.hero-figure-tall::before {
  top: -26px;
  width: 40px;
  height: 40px;
}

.hero-figure-small {
  left: 32px;
  width: 42px;
  height: 94px;
  border-radius: 28px 28px 10px 10px;
}

.hero-figure-small::before {
  top: -18px;
  width: 28px;
  height: 28px;
}

.hero-copy {
  position: relative;
  z-index: 2;
}

.play-ring {
  display: grid;
  place-items: center;
  width: 88px;
  height: 88px;
  background: rgba(255, 255, 255, 0.04);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.18) inset,
    0 16px 40px rgba(13, 11, 10, 0.16);
  backdrop-filter: blur(2px);
}

.play-ring span {
  padding-top: 20px;
  line-height: 1;
}

.hero-status {
  position: absolute;
  right: min(52px, 4vw);
  bottom: 22px;
  margin: 0;
  z-index: 2;
  color: rgba(255, 255, 255, 0.86);
  font-size: 1rem;
  letter-spacing: 0.02em;
}

.promo,
.concept-block,
.products,
.support-stage {
  width: 100%;
  overflow: hidden;
}

.promo {
  padding-top: 72px;
  padding-bottom: 94px;
  background: linear-gradient(180deg, #dc7c2f 0%, #d7752a 100%);
  box-shadow: inset 0 18px 0 rgba(58, 65, 48, 0.34);
}

.promo::before {
  background:
    radial-gradient(circle at 18% 14%, rgba(255, 194, 136, 0.18) 0 142px, transparent 143px),
    radial-gradient(circle at 80% 74%, rgba(255, 194, 136, 0.14) 0 154px, transparent 155px),
    radial-gradient(circle at 86% 18%, rgba(255, 228, 198, 0.08) 0 120px, transparent 121px);
}

.promo::after {
  left: -4%;
  right: -4%;
  bottom: -58px;
  height: 140px;
  background: #d26f25;
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}

.promo-announcement {
  font-size: clamp(1.12rem, 1.8vw, 1.34rem);
  letter-spacing: 0.01em;
  margin-bottom: 30px;
}

.promo-blob {
  width: min(820px, 84vw);
  min-height: 360px;
  padding: 38px 48px;
  border-radius: 44% 56% 48% 52% / 40% 34% 66% 60%;
  background:
    radial-gradient(circle at 27% 26%, rgba(255, 255, 255, 0.22) 0 26px, transparent 27px),
    radial-gradient(circle at 74% 18%, rgba(255, 221, 169, 0.38) 0 110px, transparent 111px),
    radial-gradient(circle at 24% 74%, rgba(255, 229, 197, 0.3) 0 76px, transparent 77px),
    linear-gradient(180deg, #f6d7a4 0%, #eebf74 100%);
  box-shadow: 0 28px 54px rgba(150, 74, 10, 0.18);
  animation: blobBreathe 12s ease-in-out infinite;
}

.promo-blob::before {
  width: 168px;
  height: 168px;
  right: 40px;
  top: 24px;
  animation: softFloat 9s ease-in-out infinite;
}

.promo-blob::after {
  width: 136px;
  height: 136px;
  left: 54px;
  bottom: 24px;
  animation: softFloat 11s ease-in-out infinite reverse;
}

.promo-blob-copy {
  padding-top: 12px;
}

.promo-blob-copy p {
  font-size: 1.16rem;
}

.promo-blob-copy h2 {
  font-size: clamp(2.4rem, 4.2vw, 3.9rem);
  line-height: 1.14;
}

.promo-product {
  right: 66px;
  top: 34px;
  width: min(300px, 30vw);
  background:
    radial-gradient(circle at 34% 28%, rgba(255, 255, 255, 0.54) 0 18px, transparent 19px),
    radial-gradient(circle at 70% 74%, rgba(255, 225, 181, 0.26) 0 120px, transparent 121px),
    linear-gradient(180deg, rgba(255, 238, 206, 0.92), rgba(241, 193, 108, 0.96));
}

.promo-tag {
  top: 22px;
  right: 10px;
  width: 78px;
  height: 78px;
  padding: 0;
  display: grid;
  place-items: center;
  background: rgba(222, 137, 48, 0.54);
  font-size: 0.92rem;
}

.promo-bottle {
  bottom: 34px;
  width: 90px;
  border-radius: 24px 24px 32px 32px;
}

.promo-bottle-left {
  left: calc(50% - 78px);
  height: 184px;
}

.promo-bottle-right {
  left: calc(50% + 12px);
  height: 170px;
}

.promo-heading {
  margin-top: 92px;
}

.promo-heading .eyebrow,
.products .eyebrow,
.flow .eyebrow,
.faq .eyebrow,
.contact .eyebrow {
  font-size: clamp(3rem, 4.2vw, 4.4rem);
  font-weight: 500;
}

.promo-heading h2,
.products h2 {
  font-size: clamp(1.2rem, 1.6vw, 1.62rem);
  line-height: 1.9;
}

.concept-block {
  padding-top: 82px;
  padding-bottom: 88px;
  background: linear-gradient(180deg, #d26f25 0%, #d8752a 100%);
}

.concept-block::before {
  background:
    radial-gradient(circle at 16% 36%, rgba(255, 188, 128, 0.14) 0 136px, transparent 137px),
    radial-gradient(circle at 78% 8%, rgba(255, 192, 133, 0.12) 0 150px, transparent 151px);
}

.concept-copy {
  max-width: 560px;
}

.concept-copy p {
  margin-bottom: 10px;
  font-size: 1.06rem;
  line-height: 2;
}

.concept-copy h2 {
  margin-top: 46px;
  font-size: clamp(2.6rem, 4.2vw, 4rem);
  line-height: 1.5;
  letter-spacing: 0.03em;
}

.showcase {
  padding: 0;
}

.showcase-visual {
  min-height: 500px;
  grid-template-columns: 1.05fr 0.95fr;
}

.showcase-left,
.showcase-right {
  min-height: 500px;
  overflow: hidden;
}

.showcase-left {
  background:
    linear-gradient(180deg, rgba(72, 45, 24, 0.14), rgba(72, 45, 24, 0.14)),
    linear-gradient(180deg, #d8ba96 0%, #b98558 52%, #9d6a3d 100%);
}

.showcase-left::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(251, 241, 226, 0.18), transparent 44%),
    radial-gradient(circle at 26% 62%, rgba(75, 48, 26, 0.18) 0 160px, transparent 161px),
    linear-gradient(180deg, transparent 0 72%, rgba(85, 54, 29, 0.28) 72% 100%);
}

.showcase-left::after {
  display: none;
}

.showcase-portrait {
  position: absolute;
  bottom: -8px;
  border-radius: 140px 140px 18px 18px;
  box-shadow: 0 10px 34px rgba(74, 44, 23, 0.12);
}

.showcase-portrait::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -86px;
  transform: translateX(-50%);
  width: 82px;
  height: 104px;
  border-radius: 46% 46% 40% 40% / 52% 52% 48% 48%;
  background:
    linear-gradient(180deg, rgba(76, 44, 22, 0.92) 0 34%, rgba(216, 173, 129, 0.92) 35% 100%);
}

.showcase-portrait::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -96px;
  transform: translateX(-50%);
  width: 128px;
  height: 168px;
  border-radius: 48% 48% 44% 44% / 56% 56% 44% 44%;
  background: linear-gradient(180deg, rgba(76, 44, 22, 0.98), rgba(49, 31, 19, 0.98));
  z-index: -1;
}

.showcase-portrait-small {
  left: 42px;
  width: 178px;
  height: 246px;
  background: linear-gradient(180deg, #bf8b68 0%, #915739 100%);
}

.showcase-portrait-large {
  left: 164px;
  width: 250px;
  height: 338px;
  background: linear-gradient(180deg, #efe2cb 0%, #d6b18c 100%);
}

.showcase-copymark {
  position: absolute;
  right: 34px;
  bottom: 34px;
  margin: 0;
  color: rgba(255, 255, 255, 0.94);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  line-height: 1.45;
  text-shadow: 0 10px 18px rgba(66, 37, 18, 0.16);
}

.showcase-right {
  background:
    linear-gradient(180deg, rgba(96, 58, 28, 0.12), rgba(96, 58, 28, 0.12)),
    linear-gradient(180deg, #d0a06c 0%, #ba834d 62%, #9f683d 100%);
}

.showcase-right::before {
  left: -120px;
  top: -22px;
  bottom: auto;
  width: 260px;
  height: 360px;
  background: rgba(255, 244, 227, 0.96);
  border-radius: 0 0 220px 0;
  transform: none;
}

.showcase-counter {
  position: absolute;
  right: -28px;
  bottom: -18px;
  width: 450px;
  height: 170px;
  background:
    linear-gradient(180deg, rgba(127, 80, 39, 0.14), rgba(127, 80, 39, 0.34)),
    linear-gradient(180deg, #dba56b 0%, #bf8754 100%);
  transform: skewX(-24deg);
  transform-origin: bottom right;
  box-shadow: inset 0 14px 30px rgba(255, 245, 228, 0.08);
}

.showcase-logo {
  left: -18px;
  top: 10px;
}

.showcase-logo span {
  font-family: "Parisienne", cursive;
  font-style: normal;
  font-size: clamp(6.8rem, 9.6vw, 10rem);
  line-height: 0.76;
}

.showcase-logo small {
  margin-left: 208px;
  font-size: 1.06rem;
  letter-spacing: 0.1em;
}

.showcase-bottles {
  top: 36px;
  right: 44px;
  gap: 30px;
}

.showcase-bottle {
  width: 154px;
  height: 220px;
  border-radius: 32px 32px 54px 54px;
}

.products {
  padding-top: 76px;
  padding-bottom: 96px;
  background: linear-gradient(180deg, #d7772b 0%, #d6772b 100%);
}

.products::before {
  background:
    radial-gradient(circle at 82% 30%, rgba(255, 192, 134, 0.16) 0 148px, transparent 149px),
    radial-gradient(circle at 18% 82%, rgba(255, 192, 134, 0.12) 0 124px, transparent 125px);
}

.products .section-heading p {
  font-size: 1.02rem;
}

.product-blob {
  width: min(540px, 76vw);
  min-height: 308px;
  margin-top: 44px;
  border-radius: 48% 52% 0 0 / 32% 32% 0 0;
  box-shadow: 0 18px 42px rgba(125, 60, 12, 0.16);
}

.product-bottle {
  width: 108px;
  height: 164px;
  border-radius: 30px 30px 40px 40px;
}

.product-bottle-left {
  left: calc(50% - 82px);
}

.product-bottle-right {
  left: calc(50% + 6px);
}

.product-badge {
  width: 96px;
  height: 96px;
  font-size: 0.94rem;
  background: rgba(96, 57, 37, 0.72);
}

.support-stage {
  display: grid;
  grid-template-columns: 0.88fr 1.12fr;
  gap: 40px;
  align-items: center;
  padding-top: 58px;
  padding-inline: max(24px, calc((100vw - 1120px) / 2));
  padding-bottom: 118px;
  background: linear-gradient(180deg, #d6772b 0%, #d17024 100%);
}

.support-stage::before {
  background:
    radial-gradient(circle at 16% 84%, rgba(255, 192, 134, 0.12) 0 128px, transparent 129px),
    radial-gradient(circle at 84% 14%, rgba(255, 192, 134, 0.1) 0 144px, transparent 145px);
}

.support-copy {
  padding-left: 12px;
}

.support-copy p {
  font-size: 1.04rem;
  line-height: 1.95;
}

.support-copy h3 {
  margin-top: 30px;
  margin-bottom: 30px;
  font-size: clamp(2.7rem, 4vw, 4rem);
  line-height: 1.38;
  letter-spacing: 0.02em;
}

.support-link {
  min-width: 194px;
  min-height: 58px;
}

.support-visual {
  min-height: 500px;
}

.support-photo {
  width: min(470px, 100%);
  height: 470px;
  border-radius: 48% 52% 44% 56% / 42% 42% 58% 58%;
  background:
    linear-gradient(180deg, rgba(75, 46, 23, 0.12), rgba(75, 46, 23, 0.12)),
    linear-gradient(180deg, #dec09d 0%, #b47d4d 64%, #8b5c34 100%);
}

.support-photo::before {
  background:
    radial-gradient(circle at 30% 56%, rgba(75, 46, 23, 0.16) 0 120px, transparent 121px),
    radial-gradient(circle at 64% 32%, rgba(255, 241, 221, 0.38) 0 128px, transparent 129px),
    linear-gradient(180deg, transparent 0 72%, rgba(79, 49, 25, 0.22) 72% 100%);
}

.support-portrait {
  position: absolute;
  bottom: -4px;
  border-radius: 140px 140px 18px 18px;
}

.support-portrait::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -84px;
  transform: translateX(-50%);
  width: 84px;
  height: 102px;
  border-radius: 46% 46% 42% 42% / 52% 52% 48% 48%;
  background:
    linear-gradient(180deg, rgba(77, 45, 24, 0.96) 0 32%, rgba(222, 176, 131, 0.96) 33% 100%);
}

.support-portrait::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -96px;
  transform: translateX(-50%);
  width: 138px;
  height: 170px;
  border-radius: 48% 48% 44% 44% / 58% 58% 42% 42%;
  background: linear-gradient(180deg, rgba(77, 45, 24, 0.98), rgba(51, 31, 18, 0.98));
  z-index: -1;
}

.support-portrait-back {
  left: 64px;
  width: 166px;
  height: 254px;
  background: linear-gradient(180deg, #c09472 0%, #8c5635 100%);
}

.support-portrait-front {
  right: 54px;
  width: 216px;
  height: 344px;
  background: linear-gradient(180deg, #efe0c8 0%, #cba37c 100%);
}

.support-sticker {
  right: 14px;
  bottom: 12px;
  padding: 24px 30px;
  font-size: 1.16rem;
  line-height: 1.7;
}

@media (max-width: 980px) {
  .nav-wrap {
    width: min(100vw - 32px, 1308px);
    padding-top: 22px;
    align-items: center;
  }

  .site-nav {
    padding-top: 0;
  }

  .hero-figures {
    bottom: 78px;
  }

  .promo {
    padding-top: 58px;
    padding-bottom: 86px;
  }

  .promo-blob {
    width: min(680px, 90vw);
    padding: 28px 28px 246px;
  }

  .promo-product {
    right: 50%;
    top: auto;
    bottom: 24px;
    transform: translateX(50%);
    width: min(280px, 56vw);
  }

  .concept-copy {
    max-width: 620px;
    padding: 0 18px;
  }

  .showcase-visual,
  .support-stage {
    grid-template-columns: 1fr;
  }

  .showcase-left,
  .showcase-right,
  .support-visual {
    min-height: 360px;
  }

  .showcase-right::before {
    width: 220px;
    height: 280px;
  }

  .showcase-logo {
    left: 18px;
  }

  .showcase-logo small {
    margin-left: 132px;
  }

  .showcase-bottles {
    top: 108px;
    right: 24px;
  }

  .showcase-counter {
    width: 360px;
    height: 140px;
  }

  .support-copy {
    padding-left: 0;
  }

  .support-photo {
    right: 50%;
    transform: translateX(50%);
  }
}

@media (max-width: 720px) {
  .site-header {
    position: absolute;
  }

  .nav-wrap {
    width: min(100vw - 24px, 1308px);
    padding-top: 18px;
  }

  .brand-copy-script strong {
    font-size: 3rem;
  }

  .brand-copy-script small {
    margin-left: 16px;
    font-size: 0.68rem;
  }

  .site-nav {
    padding: 18px;
  }

  .site-nav a {
    font-size: 1.24rem;
  }

  .hero {
    min-height: 92vh;
  }

  .hero-silhouette-left {
    width: 170px;
    height: 146px;
    bottom: 78px;
  }

  .hero-silhouette-right {
    width: 200px;
    height: 116px;
    bottom: 78px;
  }

  .hero-figures {
    width: 116px;
    height: 132px;
    bottom: 70px;
  }

  .hero-figure-tall {
    width: 42px;
    height: 98px;
  }

  .hero-figure-tall::before {
    width: 34px;
    height: 34px;
    top: -20px;
  }

  .hero-figure-small {
    width: 34px;
    height: 72px;
    left: 22px;
  }

  .hero-figure-small::before {
    width: 24px;
    height: 24px;
    top: -14px;
  }

  .play-ring {
    width: 72px;
    height: 72px;
  }

  .hero-status {
    right: 18px;
    bottom: 18px;
    font-size: 0.82rem;
  }

  .promo {
    padding-top: 42px;
    padding-bottom: 70px;
  }

  .promo-announcement {
    font-size: 0.98rem;
    margin-bottom: 20px;
  }

  .promo-blob {
    min-height: 0;
    padding: 24px 20px 212px;
  }

  .promo-blob-copy p,
  .promo-blob-copy small {
    font-size: 0.94rem;
  }

  .promo-blob-copy h2 {
    font-size: 2rem;
  }

  .promo-product {
    width: 220px;
  }

  .promo-tag {
    width: 64px;
    height: 64px;
    font-size: 0.78rem;
  }

  .promo-bottle {
    width: 76px;
  }

  .promo-heading {
    margin-top: 60px;
  }

  .promo-heading .eyebrow,
  .products .eyebrow,
  .flow .eyebrow,
  .faq .eyebrow,
  .contact .eyebrow {
    font-size: 2.4rem;
  }

  .promo-heading h2,
  .products h2 {
    font-size: 1rem;
    line-height: 1.9;
  }

  .concept-block {
    padding-top: 62px;
    padding-bottom: 64px;
  }

  .concept-copy p {
    font-size: 0.94rem;
  }

  .concept-copy h2 {
    font-size: 2rem;
    margin-top: 34px;
  }

  .showcase-visual {
    min-height: 0;
  }

  .showcase-left,
  .showcase-right {
    min-height: 280px;
  }

  .showcase-portrait-small {
    left: 20px;
    width: 118px;
    height: 166px;
  }

  .showcase-portrait-large {
    left: 98px;
    width: 156px;
    height: 220px;
  }

  .showcase-portrait::before {
    width: 54px;
    height: 70px;
    top: -56px;
  }

  .showcase-portrait::after {
    width: 86px;
    height: 108px;
    top: -62px;
  }

  .showcase-copymark {
    right: 16px;
    bottom: 16px;
    font-size: 1.28rem;
  }

  .showcase-logo span {
    font-size: 4.8rem;
  }

  .showcase-logo small {
    margin-left: 92px;
    font-size: 0.78rem;
  }

  .showcase-bottles {
    gap: 14px;
    top: 84px;
    right: 16px;
  }

  .showcase-bottle {
    width: 92px;
    height: 134px;
  }

  .showcase-counter {
    width: 240px;
    height: 104px;
    right: -18px;
  }

  .products {
    padding-top: 58px;
    padding-bottom: 70px;
  }

  .product-blob {
    min-height: 228px;
    width: min(360px, 82vw);
  }

  .product-bottle {
    width: 84px;
    height: 128px;
  }

  .product-badge {
    width: 74px;
    height: 74px;
    right: 16px;
    top: 26px;
    font-size: 0.72rem;
  }

  .support-stage {
    gap: 22px;
    padding-top: 44px;
    padding-inline: 18px;
    padding-bottom: 78px;
  }

  .support-copy h3 {
    font-size: 2rem;
    line-height: 1.5;
  }

  .support-visual {
    min-height: 352px;
  }

  .support-photo {
    width: min(324px, 88vw);
    height: 324px;
  }

  .support-portrait-back {
    left: 44px;
    width: 104px;
    height: 164px;
  }

  .support-portrait-front {
    right: 36px;
    width: 134px;
    height: 222px;
  }

  .support-portrait::before {
    width: 54px;
    height: 68px;
    top: -58px;
  }

  .support-portrait::after {
    width: 90px;
    height: 106px;
    top: -64px;
  }

  .support-sticker {
    right: 10px;
    bottom: 10px;
    padding: 16px 20px;
    font-size: 0.92rem;
  }
}

/* ----------------------------------------------------------------
Real asset replacement pass
----------------------------------------------------------------- */
.hero-illustration {
  object-position: 76% center;
  filter: saturate(0.9) contrast(1.02) brightness(0.76);
}

.promo-product,
.product-blob,
.support-photo {
  overflow: hidden;
}

.promo-product {
  display: flex;
  align-items: stretch;
  justify-content: stretch;
}

.promo-illustration,
.showcase-photo-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.promo-illustration {
  border-radius: inherit;
  object-position: center center;
}

.promo-tag {
  z-index: 2;
}

.showcase-left {
  background: #b78965;
}

.showcase-left::before {
  background:
    linear-gradient(180deg, rgba(28, 21, 19, 0.04) 0%, rgba(28, 21, 19, 0.18) 100%),
    linear-gradient(90deg, rgba(248, 237, 221, 0.08), transparent 44%);
  z-index: 1;
}

.showcase-photo-img {
  object-position: center 20%;
  filter: saturate(0.78) brightness(0.92);
}

.showcase-copymark {
  z-index: 2;
}

.showcase-right {
  background:
    linear-gradient(180deg, rgba(110, 69, 40, 0.1), rgba(110, 69, 40, 0.16)),
    linear-gradient(180deg, #d3a26e 0%, #bf8a55 62%, #a56e43 100%);
}

.showcase-illustration {
  position: absolute;
  right: 26px;
  top: 96px;
  z-index: 3;
  width: min(440px, 84%);
  border-radius: 42px;
  box-shadow: 0 24px 48px rgba(78, 44, 18, 0.18);
}

.showcase-bottles,
.showcase-bottle,
.showcase-portrait,
.product-bottle,
.support-portrait {
  display: none;
}

.product-blob {
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 50% 10%, rgba(255, 210, 169, 0.2) 0 90px, transparent 91px),
    linear-gradient(180deg, #c7925b 0%, #9c6238 72%, #87532f 100%);
}

.product-illustration {
  width: min(390px, 84%);
  height: auto;
  transform: translateY(18px);
  filter: drop-shadow(0 12px 24px rgba(74, 40, 17, 0.18));
}

.support-photo {
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 229, 195, 0.22) 0 120px, transparent 121px),
    linear-gradient(180deg, #e4c49f 0%, #b27747 64%, #8b5932 100%);
}

.support-photo::before {
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 242, 224, 0.18) 0 150px, transparent 151px),
    linear-gradient(180deg, rgba(71, 44, 23, 0.04) 0%, rgba(71, 44, 23, 0.18) 100%);
}

.support-illustration {
  position: relative;
  z-index: 2;
  width: min(440px, 92%);
  height: auto;
  transform: translateY(8px);
  filter: drop-shadow(0 18px 32px rgba(73, 39, 17, 0.16));
}

@media (max-width: 980px) {
  .hero-illustration {
    object-position: 70% center;
  }

  .showcase-illustration {
    top: 106px;
    right: 20px;
    width: min(360px, 74vw);
  }

  .product-illustration {
    width: min(320px, 80%);
  }

  .support-illustration {
    width: min(360px, 88%);
  }
}

@media (max-width: 720px) {
  .hero-illustration {
    object-position: 68% center;
  }

  .promo-product {
    width: min(240px, 60vw);
  }

  .showcase-photo-img {
    object-position: center 14%;
  }

  .showcase-illustration {
    top: 88px;
    right: 14px;
    width: 220px;
    border-radius: 28px;
  }

  .product-illustration {
    width: min(230px, 78%);
    transform: translateY(12px);
  }

  .support-illustration {
    width: min(250px, 84%);
  }
}

/* Premium illustration pass */
.promo-product {
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at 28% 24%, rgba(255, 255, 255, 0.62) 0 22px, transparent 23px),
    linear-gradient(180deg, rgba(255, 244, 228, 0.98), rgba(242, 215, 181, 0.98));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.56), 0 24px 44px rgba(116, 67, 32, 0.14);
}

.promo-tag {
  background: rgba(102, 62, 35, 0.78);
  box-shadow: 0 12px 22px rgba(84, 45, 26, 0.14);
}

.promo-illustration {
  position: relative;
  inset: auto;
  width: min(250px, 82%);
  height: auto;
  object-fit: contain;
  border-radius: 0;
  object-position: center;
  filter: sepia(0.34) saturate(0.68) hue-rotate(-16deg) brightness(0.98) contrast(0.95);
}

.showcase-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 52px 34px 44px;
  background:
    radial-gradient(circle at 74% 18%, rgba(255, 234, 214, 0.24) 0 84px, transparent 85px),
    linear-gradient(180deg, #d8ab7b 0%, #c18a59 58%, #9d683e 100%);
}

.showcase-right::before {
  width: min(280px, 72%);
  height: min(320px, 72%);
  top: auto;
  bottom: 30px;
  right: 24px;
  border-radius: 48% 52% 42% 58% / 42% 36% 64% 58%;
  background: rgba(253, 238, 218, 0.18);
}

.showcase-counter {
  width: min(360px, 94%);
  height: 182px;
  margin: 104px auto 0;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255, 250, 243, 0.24), rgba(255, 250, 243, 0.06)),
    linear-gradient(180deg, rgba(110, 69, 40, 0.18), rgba(110, 69, 40, 0.05));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}

.showcase-illustration {
  display: none;
}

.product-blob {
  min-height: 340px;
  background:
    radial-gradient(circle at 24% 18%, rgba(255, 243, 228, 0.18) 0 80px, transparent 81px),
    linear-gradient(180deg, #d6ab7c 0%, #bd8455 60%, #9d673e 100%);
}

.product-illustration {
  width: min(318px, 74%);
  transform: translateY(34px);
  filter:
    sepia(0.3)
    saturate(0.56)
    hue-rotate(-18deg)
    brightness(1.02)
    contrast(0.95)
    drop-shadow(0 18px 30px rgba(78, 44, 18, 0.12));
}

.support-photo {
  display: block;
  background: linear-gradient(180deg, #e6c7a3 0%, #c18a59 68%, #8b5932 100%);
  box-shadow: 0 28px 54px rgba(84, 45, 26, 0.16);
}

.support-photo::before {
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(31, 20, 13, 0.02), rgba(31, 20, 13, 0.22)),
    linear-gradient(90deg, rgba(255, 242, 224, 0.06), transparent 48%);
}

.support-photo-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 18%;
  filter: saturate(0.6) sepia(0.15) brightness(0.98);
}

.support-photo-room {
  object-position: center center;
  filter: saturate(0.78) sepia(0.08) brightness(0.9);
}

.support-sticker {
  z-index: 2;
  right: 22px;
  bottom: 20px;
  background: rgba(184, 111, 38, 0.92);
  box-shadow: 0 18px 34px rgba(116, 67, 32, 0.18);
}

@media (max-width: 980px) {
  .promo {
    margin-top: -74px;
    padding-top: 96px;
    background-size: 100% 128px;
  }

  .showcase-right {
    padding: 42px 24px 36px;
  }

  .showcase-counter {
    width: min(340px, 92%);
    height: 152px;
    margin-top: 88px;
  }

  .product-blob {
    min-height: 300px;
  }

  .product-illustration {
    width: min(280px, 76%);
    transform: translateY(26px);
  }
}

@media (max-width: 720px) {
  .promo {
    margin-top: -56px;
    padding-top: 76px;
    background-size: 100% 96px;
  }

  .promo-product {
    width: min(248px, 62vw);
    padding: 20px;
  }

  .promo-illustration {
    width: min(194px, 82%);
  }

  .showcase-right {
    padding: 34px 18px 28px;
  }

  .showcase-counter {
    height: 126px;
    margin-top: 78px;
    border-radius: 26px;
  }

  .product-blob {
    min-height: 270px;
  }

  .product-illustration {
    width: min(224px, 74%);
    transform: translateY(18px);
  }

  .support-photo {
    height: 360px;
  }
}

/* Promo wave background pass */
.hero::after {
  display: none !important;
  content: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: none !important;
}

.hero-boundary {
  position: absolute;
  left: 50%;
  bottom: -1px;
  width: 100vw;
  height: 164px;
  z-index: 1;
  pointer-events: none;
  transform: translateX(-50%);
  overflow: hidden;
}

body.is-loaded .hero-boundary {
  animation: boundaryRise 1100ms 140ms ease both;
}

.hero-boundary-svg {
  display: block;
  width: 100%;
  height: 100%;
}

.promo {
  position: relative;
  z-index: 4;
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: 0;
  padding-top: 72px;
  padding-bottom: 94px;
  background: linear-gradient(180deg, #dc7c2f 0%, #d7752a 100%);
  overflow: hidden;
  box-shadow: none;
}

.promo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 14%, rgba(255, 194, 136, 0.18) 0 142px, transparent 143px),
    radial-gradient(circle at 80% 74%, rgba(255, 194, 136, 0.14) 0 154px, transparent 155px),
    radial-gradient(circle at 86% 18%, rgba(255, 228, 198, 0.08) 0 120px, transparent 121px);
}

.promo::after {
  content: "";
  position: absolute;
  left: -4%;
  right: -4%;
  bottom: -58px;
  height: 140px;
  z-index: 0;
  pointer-events: none;
  transform: none;
  background: #d26f25;
  border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}

.promo-announcement,
.promo-blob,
.promo-heading {
  z-index: 2;
}

body.is-loaded .promo-announcement {
  animation: riseFade 900ms 220ms ease both;
}

body.is-loaded .promo-blob {
  animation:
    riseFade 1000ms 300ms ease both,
    blobBreathe 12s 1.3s ease-in-out infinite;
}

body.is-loaded .promo-heading {
  animation: riseFade 900ms 380ms ease both;
}

@media (max-width: 980px) {
  .hero-boundary {
    height: 132px;
  }

  .promo {
    margin-top: 0;
    padding-top: 60px;
    padding-bottom: 82px;
  }
}

@media (max-width: 720px) {
  .hero-boundary {
    height: 104px;
  }

  .promo {
    margin-top: 0;
    padding-top: 50px;
    padding-bottom: 72px;
  }
}

/* Final content and typography tuning */
.site-nav {
  gap: clamp(14px, 1.5vw, 22px);
}

.site-nav a {
  font-size: clamp(0.92rem, 1.06vw, 1.04rem);
  line-height: 1.2;
  letter-spacing: 0.01em;
}

.hero-copy,
.play-ring,
.hero-status,
.faq {
  display: none !important;
}

.promo-heading h1,
.promo-heading h2,
.section-heading h2,
.concept-copy h2,
.support-copy h3,
.contact-copy h2,
.plan-card strong {
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-weight: 600;
  letter-spacing: 0.01em;
  font-feature-settings: "palt" 1;
}

.promo-announcement {
  font-size: clamp(0.84rem, 0.94vw, 0.96rem);
  letter-spacing: 0.08em;
}

.promo-blob {
  width: min(700px, calc(100vw - 72px));
  min-height: 420px;
  padding: 38px 44px 44px;
}

.promo-blob-copy {
  max-width: 420px;
}

.promo-blob-copy p,
.promo-blob-copy small {
  font-size: clamp(0.84rem, 0.98vw, 0.98rem);
  line-height: 1.68;
  letter-spacing: 0.04em;
}

.promo-blob-copy h2 {
  margin: 12px 0 14px;
  font-size: clamp(2.16rem, 3.5vw, 3.34rem);
  line-height: 1.36;
  letter-spacing: 0.01em;
  text-wrap: balance;
}

.promo-product {
  width: min(280px, 29vw);
  right: 58px;
}

.promo-heading {
  max-width: 1040px;
  margin-top: 84px;
}

.promo-heading h1,
.promo-heading h2,
.section-heading h2,
.concept-copy h2,
.support-copy h3,
.plan-card strong,
.contact-copy h2 {
  text-wrap: balance;
}

.promo-heading h1,
.promo-heading h2 {
  max-width: 940px;
  margin-inline: auto;
  font-size: clamp(1.42rem, 1.86vw, 1.92rem);
  line-height: 1.68;
  font-weight: 600;
}

.promo-heading h1::after,
.promo-heading h2::after {
  content: "";
  display: block;
  width: 54px;
  height: 3px;
  margin: 20px auto 0;
  background: rgba(255, 247, 233, 0.76);
  border-radius: 999px;
}

.section-heading h2,
.products .section-heading h2,
.flow .section-heading h2,
.faq .section-heading h2,
.contact .section-heading h2,
.policy .section-heading h2,
.compliance .section-heading h2,
.plans .section-heading h2 {
  max-width: 920px;
  margin-inline: auto;
  font-size: clamp(1.34rem, 1.86vw, 2rem);
  line-height: 1.62;
}

.section-heading > p:last-child,
.products .section-heading p:last-child,
.flow .section-heading p:last-child,
.faq .section-heading p:last-child,
.contact .section-heading p:last-child,
.policy .section-heading p:last-child,
.compliance .section-heading p:last-child,
.plans .section-heading p:last-child,
.contact-copy > p:last-child {
  max-width: 760px;
  margin-inline: auto;
  font-size: 0.98rem;
  line-height: 1.82;
}

.concept-copy {
  max-width: 780px;
}

.concept-copy p {
  font-size: clamp(0.98rem, 1.04vw, 1.08rem);
  line-height: 1.82;
  text-wrap: pretty;
}

.concept-copy h2 {
  max-width: 720px;
  margin-inline: auto;
  font-size: clamp(1.98rem, 3vw, 2.86rem);
  line-height: 1.58;
}

.support-copy p,
.policy-card li,
.plan-card li,
.faq-list p,
.contact-copy p,
.form-note,
.flow-list p {
  line-height: 1.82;
}

.support-copy h3 {
  max-width: 640px;
  font-size: clamp(1.94rem, 2.9vw, 2.74rem);
  line-height: 1.58;
}

.plan-name {
  letter-spacing: 0.08em;
}

.plan-card strong {
  font-size: clamp(1.18rem, 1.48vw, 1.42rem);
  line-height: 1.68;
  margin-bottom: 10px;
}

.plan-card span {
  font-size: 0.98rem;
  line-height: 1.7;
}

.contact-copy h2 {
  max-width: 720px;
  font-size: clamp(1.38rem, 1.9vw, 2.02rem);
  line-height: 1.65;
}

.product-badge,
.support-sticker {
  font-family: "M PLUS Rounded 1c", sans-serif;
  letter-spacing: 0.04em;
}

.product-badge {
  width: auto;
  min-width: 126px;
  padding: 0 18px;
  border-radius: 999px;
  white-space: nowrap;
}

.support-sticker {
  width: auto;
  max-width: 320px;
  padding-inline: 24px;
  line-height: 1.55;
}

@media (max-width: 980px) {
  .site-nav a {
    font-size: 0.95rem;
  }

  .promo-blob {
    width: min(640px, calc(100vw - 48px));
    min-height: 390px;
    padding: 34px 36px 40px;
  }

  .promo-product {
    width: min(240px, 30vw);
    right: 40px;
  }

  .promo-heading h1,
  .promo-heading h2 {
    font-size: clamp(1.28rem, 2.24vw, 1.68rem);
    line-height: 1.68;
  }

  .plan-card strong {
    font-size: 1.12rem;
  }

  .support-sticker {
    max-width: 280px;
    padding-inline: 18px;
  }
}

@media (max-width: 720px) {
  .site-nav a {
    font-size: 1.04rem;
  }

  .promo-announcement {
    font-size: 0.8rem;
  }

  .promo-blob {
    width: min(92vw, 420px);
    min-height: 0;
    padding: 26px 22px 196px;
  }

  .promo-blob-copy {
    max-width: 100%;
  }

  .promo-blob-copy h2 {
    font-size: clamp(1.72rem, 6.8vw, 2.18rem);
    line-height: 1.42;
  }

  .promo-product {
    right: 24px;
    width: min(214px, 56vw);
  }

  .promo-heading {
    margin-top: 62px;
  }

  .promo-heading h1,
  .promo-heading h2,
  .section-heading h2,
  .products .section-heading h2,
  .flow .section-heading h2,
  .faq .section-heading h2,
  .contact .section-heading h2,
  .policy .section-heading h2,
  .compliance .section-heading h2,
  .plans .section-heading h2,
  .contact-copy h2 {
    font-size: 1.08rem;
    line-height: 1.72;
  }

  .concept-copy h2 {
    font-size: 1.7rem;
    line-height: 1.64;
  }

  .support-copy h3 {
    font-size: 1.74rem;
    line-height: 1.62;
  }

  .plan-card strong {
    font-size: 1.04rem;
    line-height: 1.65;
  }

  .plan-card span,
  .concept-copy p,
  .support-copy p,
  .faq-list p,
  .flow-list p,
  .contact-copy p {
    font-size: 0.94rem;
    text-wrap: pretty;
  }

  .product-badge,
  .support-sticker {
    font-size: 0.76rem;
  }
}

.booking-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: 0 auto 28px;
}

.growth-guides {
  color: var(--brown);
}

.guide-link-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 32px;
}

.guide-link-card {
  padding: 28px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(255, 214, 168, 0.32), transparent 30%),
    rgba(255, 250, 243, 0.96);
  color: var(--brown);
  border: 1px solid rgba(224, 94, 14, 0.12);
  box-shadow: var(--card-shadow);
}

.guide-link-card h3 {
  margin: 0 0 12px;
  font-size: 1.28rem;
  line-height: 1.48;
}

.guide-link-card p {
  line-height: 1.82;
}

.guide-page {
  color: var(--brown);
}

.guide-wrap {
  max-width: 980px;
}

.guide-stack {
  margin-top: 30px;
}

.guide-links {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 28px;
}

.booking-steps article {
  padding: 18px 20px;
  border-radius: 24px;
  background: rgba(255, 248, 236, 0.16);
  border: 1px solid rgba(255, 245, 232, 0.24);
  backdrop-filter: blur(10px);
}

.booking-steps strong,
.booking-steps span {
  display: block;
}

.booking-steps strong {
  margin-bottom: 8px;
  font-size: 1rem;
}

.booking-steps span {
  font-size: 0.92rem;
  line-height: 1.72;
  color: rgba(255, 248, 240, 0.86);
}

.booking-form {
  gap: 18px;
}

.booking-form-intro {
  margin: -4px 0 2px;
  font-size: 0.92rem;
  line-height: 1.78;
  color: rgba(114, 68, 4, 0.86);
}

.booking-contact-hint {
  display: block;
  margin-top: 2px;
  font-size: 0.84rem;
  line-height: 1.7;
  color: rgba(114, 68, 4, 0.72);
}

.booking-optional {
  padding: 18px 20px;
  border-radius: 22px;
  background: rgba(255, 248, 236, 0.14);
  border: 1px solid rgba(255, 245, 232, 0.24);
}

.booking-optional summary {
  cursor: pointer;
  font-weight: 800;
  color: var(--brown);
  list-style: none;
}

.booking-optional summary::-webkit-details-marker {
  display: none;
}

.booking-optional summary::after {
  content: "＋";
  float: right;
  color: rgba(114, 68, 4, 0.72);
}

.booking-optional[open] summary::after {
  content: "−";
}

.booking-optional-stack {
  display: grid;
  gap: 18px;
  margin-top: 16px;
}

.field-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.contact-form label {
  display: grid;
  gap: 10px;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  padding: 15px 16px;
  border-radius: 18px;
  border: 1px solid rgba(114, 68, 4, 0.16);
  background: rgba(255, 251, 245, 0.96);
  color: var(--brown);
  outline: none;
}

.contact-form textarea {
  resize: vertical;
  min-height: 164px;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  border-color: rgba(224, 94, 14, 0.5);
  box-shadow: 0 0 0 3px rgba(255, 220, 185, 0.4);
}

.checkbox-group {
  display: grid;
  gap: 12px;
}

.booking-check {
  padding: 18px 20px;
  border-radius: 22px;
  background: rgba(255, 248, 236, 0.14);
  border: 1px solid rgba(255, 245, 232, 0.24);
}

.booking-challenge {
  display: grid !important;
  gap: 10px;
}

.booking-challenge-copy {
  font-size: 0.9rem;
  line-height: 1.72;
  color: rgba(114, 68, 4, 0.78);
}

.booking-challenge-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px;
  gap: 12px;
  align-items: center;
}

.booking-challenge-prompt {
  margin: 0;
  padding: 15px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(224, 94, 14, 0.14);
  color: var(--brown);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-align: center;
}

.checkbox-label {
  display: flex !important;
  align-items: flex-start;
  gap: 12px;
  font-size: 0.94rem;
  line-height: 1.72;
}

.checkbox-label input {
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
}

.booking-feedback {
  margin-top: 22px;
  padding: 24px 26px;
  border-radius: 26px;
  background: rgba(255, 249, 241, 0.92);
  color: var(--brown);
  box-shadow: var(--card-shadow);
}

.booking-feedback h3 {
  margin: 0 0 10px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(1.24rem, 1.7vw, 1.56rem);
  line-height: 1.5;
}

.booking-feedback p {
  margin: 0;
  line-height: 1.8;
}

.booking-feedback-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin: 18px 0 0;
}

.booking-feedback-meta div {
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255, 241, 218, 0.96);
}

.booking-feedback-meta dt {
  margin-bottom: 8px;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(114, 68, 4, 0.74);
}

.booking-feedback-meta dd {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
}

.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.booking-trust-note {
  margin: 2px 0 0;
  font-size: 0.84rem;
  line-height: 1.8;
  color: rgba(255, 248, 240, 0.78);
}

.contact-direct-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.contact-direct-card {
  padding: 28px;
  border-radius: 30px;
  background: rgba(255, 248, 236, 0.16);
  border: 1px solid rgba(255, 245, 232, 0.24);
  box-shadow: var(--card-shadow);
  backdrop-filter: blur(10px);
}

.contact-direct-card h3 {
  margin: 10px 0 12px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(1.24rem, 1.9vw, 1.68rem);
  line-height: 1.5;
}

.contact-direct-card p {
  margin: 0;
  line-height: 1.82;
}

.contact-direct-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  margin-top: 20px;
  padding: 0 24px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.52);
  color: #fff;
  font-weight: 800;
  transition: transform 220ms ease, box-shadow 220ms ease, background 220ms ease;
}

.contact-direct-link:hover {
  transform: translateY(-3px);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 14px 30px rgba(111, 47, 4, 0.18);
}

.contact-direct-subcopy {
  margin-top: 12px !important;
  font-size: 0.88rem;
  color: rgba(255, 248, 240, 0.78);
}

.contact-direct-note {
  max-width: 760px;
  margin: 22px auto 0;
  font-size: 0.92rem;
  line-height: 1.82;
  text-align: center;
  color: rgba(255, 248, 240, 0.88);
}

.admin-body {
  min-height: 100vh;
  margin: 0;
  color: #fff;
  font-family: "M PLUS Rounded 1c", sans-serif;
  background:
    radial-gradient(circle at 10% 12%, rgba(255, 209, 168, 0.28), transparent 16%),
    radial-gradient(circle at 88% 24%, rgba(255, 242, 223, 0.14), transparent 18%),
    linear-gradient(180deg, #d86f29 0%, #cb631d 100%);
}

.admin-app {
  width: min(1320px, calc(100vw - 40px));
  margin: 0 auto;
  padding: 32px 0 72px;
}

.admin-header-card,
.admin-list-panel,
.admin-detail-panel {
  padding: 26px;
  border-radius: 30px;
  background: rgba(255, 247, 235, 0.12);
  border: 1px solid rgba(255, 245, 232, 0.18);
  backdrop-filter: blur(14px);
}

.admin-header-row,
.admin-toolbar,
.admin-grid,
.admin-stats,
.admin-auth-actions {
  display: grid;
  gap: 18px;
}

.admin-header-row {
  grid-template-columns: 1.35fr auto;
  align-items: end;
}

.admin-header-card h1 {
  margin: 8px 0 10px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(2rem, 3.2vw, 3rem);
  line-height: 1.22;
}

.admin-header-card p,
.admin-alert,
.admin-read-grid dd,
.admin-list-item small,
.admin-list-item p {
  line-height: 1.8;
}

.admin-auth-actions {
  grid-auto-flow: column;
  align-items: center;
  justify-content: end;
}

.admin-user-chip {
  padding: 12px 16px;
  border-radius: 999px;
  background: rgba(255, 243, 228, 0.16);
  font-size: 0.92rem;
}

.admin-alert {
  margin: 18px 0 0;
  color: rgba(255, 248, 240, 0.88);
}

.admin-stats {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-top: 22px;
}

.admin-stat-card {
  padding: 18px;
  border-radius: 24px;
  background: rgba(255, 248, 236, 0.16);
  text-align: center;
}

.admin-stat-card strong,
.admin-stat-card span {
  display: block;
}

.admin-stat-card strong {
  font-size: 1.7rem;
}

.admin-stat-card span {
  margin-top: 8px;
  font-size: 0.86rem;
  line-height: 1.6;
}

.admin-toolbar {
  grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  margin: 22px 0;
}

.admin-toolbar-actions {
  display: flex;
  align-items: end;
  justify-content: end;
}

.admin-toolbar label,
.admin-editor label {
  display: grid;
  gap: 8px;
}

.admin-toolbar input,
.admin-toolbar select,
.admin-editor input,
.admin-editor select,
.admin-editor textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(114, 68, 4, 0.16);
  background: rgba(255, 251, 245, 0.96);
  color: var(--brown);
}

.admin-grid {
  grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
}

.admin-panel-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.admin-panel-heading h2 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.4rem;
}

.admin-list {
  display: grid;
  gap: 12px;
}

.admin-list-item {
  width: 100%;
  padding: 18px;
  border: 1px solid rgba(255, 247, 235, 0.18);
  border-radius: 22px;
  background: rgba(255, 248, 236, 0.1);
  color: #fff;
  text-align: left;
  cursor: pointer;
}

.admin-list-item.is-selected {
  border-color: rgba(255, 234, 200, 0.68);
  background: rgba(255, 248, 236, 0.18);
}

.admin-list-top {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
}

.admin-list-item strong,
.admin-list-item p,
.admin-list-item small {
  display: block;
}

.admin-list-item p {
  margin: 0 0 6px;
  font-size: 1rem;
}

.admin-list-item small {
  color: rgba(255, 248, 240, 0.78);
}

.admin-status {
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  white-space: nowrap;
  background: rgba(255, 248, 236, 0.18);
}

.admin-status-new,
.admin-status-reply-pending,
.admin-status-scheduling {
  background: rgba(255, 228, 174, 0.2);
}

.admin-status-confirmed {
  background: rgba(182, 255, 214, 0.18);
}

.admin-status-completed {
  background: rgba(175, 227, 255, 0.18);
}

.admin-status-cancelled {
  background: rgba(255, 182, 182, 0.18);
}

.admin-empty-state,
.admin-empty-copy {
  color: rgba(255, 248, 240, 0.8);
  line-height: 1.8;
}

.admin-editor {
  display: grid;
  gap: 18px;
}

.admin-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.admin-quick-actions .button {
  min-width: 180px;
  justify-content: center;
}

.admin-read-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 0;
}

.admin-read-grid div {
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255, 248, 236, 0.1);
}

.admin-read-grid dt {
  margin-bottom: 8px;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 248, 240, 0.68);
}

.admin-read-grid dd {
  margin: 0;
  font-size: 0.98rem;
}

.admin-editor textarea {
  min-height: 180px;
  resize: vertical;
}

.admin-history {
  display: grid;
  gap: 14px;
  padding: 20px;
  border-radius: 24px;
  background: rgba(255, 248, 236, 0.1);
}

.admin-history h3 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.08rem;
}

.admin-history-list {
  display: grid;
  gap: 10px;
}

.admin-history-item {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 248, 236, 0.08);
}

.admin-history-item span,
.admin-history-item small {
  color: rgba(255, 248, 240, 0.78);
}

.admin-slot-panel {
  margin-top: 22px;
  padding: 26px;
  border-radius: 30px;
  background: rgba(255, 247, 235, 0.12);
  border: 1px solid rgba(255, 245, 232, 0.18);
  backdrop-filter: blur(14px);
}

.admin-slot-form {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(160px, 0.8fr) auto;
  gap: 14px;
  align-items: end;
  margin-bottom: 18px;
}

.admin-slot-form label {
  display: grid;
  gap: 8px;
}

.admin-slot-form input,
.admin-slot-form select {
  width: 100%;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(114, 68, 4, 0.16);
  background: rgba(255, 251, 245, 0.96);
  color: var(--brown);
}

.admin-availability-grid {
  display: grid;
  gap: 18px;
}

.admin-availability-grid .admin-slot-form {
  grid-template-columns: minmax(160px, 1fr) minmax(150px, 0.7fr) minmax(220px, 1.1fr) auto;
}

.admin-slot-list {
  display: grid;
  gap: 10px;
}

.admin-slot-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255, 248, 236, 0.1);
  border: 1px solid rgba(255, 247, 235, 0.14);
}

.admin-slot-item strong,
.admin-slot-item small {
  display: block;
}

.admin-slot-item small,
.admin-slot-item > span {
  margin-top: 4px;
  color: rgba(255, 248, 240, 0.74);
}

.admin-availability-item {
  align-items: start;
}

.admin-availability-slots {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.admin-availability-slot {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255, 248, 236, 0.12);
  color: rgba(255, 248, 240, 0.88);
  font-size: 0.82rem;
}

.admin-availability-slot .button {
  min-height: 28px;
  padding: 4px 9px;
  font-size: 0.72rem;
}

@media (max-width: 980px) {
  .booking-steps,
  .contact-direct-grid,
  .guide-link-grid,
  .admin-stats,
  .admin-grid,
  .admin-header-row,
  .admin-toolbar {
    grid-template-columns: 1fr;
  }

  .admin-slot-form,
  .admin-availability-grid .admin-slot-form,
  .admin-slot-item {
    grid-template-columns: 1fr;
  }

  .admin-auth-actions {
    grid-auto-flow: row;
    justify-content: stretch;
  }

  .admin-toolbar-actions {
    justify-content: stretch;
  }
}

@media (max-width: 720px) {
  .field-row,
  .booking-feedback-meta,
  .admin-read-grid {
    grid-template-columns: 1fr;
  }

  .booking-steps article,
  .booking-feedback,
  .admin-header-card,
  .admin-list-panel,
  .admin-detail-panel {
    padding: 20px;
  }

  .admin-app {
    width: min(100vw - 20px, 1320px);
    padding-top: 20px;
  }
}

/* Final responsive pass */
.contact {
  grid-template-columns: 1fr;
  gap: 20px;
}

.contact-copy,
.booking-steps,
.contact-direct-grid,
.contact-form,
.booking-feedback {
  width: 100%;
  max-width: 920px;
  margin-inline: auto;
}

.guide-wrap {
  width: min(980px, 100%);
}

@media (max-width: 1100px) {
  .section {
    padding: 82px 0;
  }

  .nav-wrap {
    gap: 18px;
    padding-top: 22px;
  }

  .showcase-visual,
  .support-stage {
    grid-template-columns: 1fr;
  }

  .plan-grid,
  .guide-link-grid,
  .flow-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .contact-copy,
  .booking-steps,
  .contact-form,
  .booking-feedback {
    max-width: 100%;
  }

  .showcase-visual {
    min-height: 0;
  }

  .showcase-left,
  .showcase-right {
    min-height: 300px;
  }

  .support-stage {
    gap: 28px;
  }

  .support-visual {
    min-height: 360px;
  }

  .support-photo {
    right: 50%;
    width: min(420px, 100%);
    transform: translateX(50%);
  }

  .admin-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  :root {
    --content-width: min(100vw - 28px, 1160px);
  }

  body {
    overflow-x: hidden;
  }

  .page-shell::before,
  .page-shell::after {
    opacity: 0.7;
  }

  .nav-wrap {
    position: relative;
    align-items: center;
    padding-top: 18px;
  }

  .menu-toggle {
    display: inline-flex;
    flex-shrink: 0;
  }

  .site-nav {
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 16px;
    border-radius: 24px;
    background: rgba(220, 113, 35, 0.97);
    box-shadow: 0 20px 40px rgba(117, 47, 5, 0.22);
    backdrop-filter: blur(12px);
  }

  .site-nav.is-open {
    display: flex;
  }

  .site-nav a,
  .nav-cta {
    display: block;
    padding: 8px 4px;
    font-size: 1rem;
  }

  .brand-copy-script strong {
    font-size: clamp(2.4rem, 10vw, 3rem);
  }

  .brand-copy-script small {
    font-size: 0.72rem;
  }

  .hero {
    min-height: 76svh;
  }

  .hero-illustration {
    object-position: 68% center;
  }

  .hero-boundary {
    height: 92px;
  }

  .promo {
    padding-top: 44px;
    padding-bottom: 64px;
  }

  .promo-blob {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: min(100%, 560px);
    min-height: 0;
    padding: 30px 24px 28px;
    border-radius: 42px;
  }

  .promo-blob::before {
    width: 112px;
    height: 112px;
    right: 18px;
    top: 18px;
  }

  .promo-blob::after {
    width: 82px;
    height: 82px;
    left: 16px;
    bottom: 16px;
  }

  .promo-blob-copy {
    max-width: 100%;
  }

  .promo-blob-copy h2 {
    font-size: clamp(1.88rem, 6.5vw, 2.5rem);
    line-height: 1.38;
  }

  .promo-product {
    position: relative;
    inset: auto;
    width: min(230px, 62vw);
    margin-inline: auto;
    transform: none;
  }

  .promo-tag {
    top: 14px;
    right: 10px;
    padding: 10px 12px;
    font-size: 0.74rem;
  }

  .promo-heading {
    margin-top: 52px;
  }

  .section-heading h2,
  .products .section-heading h2,
  .flow .section-heading h2,
  .contact .section-heading h2,
  .policy .section-heading h2,
  .compliance .section-heading h2,
  .plans .section-heading h2,
  .contact-copy h2,
  .promo-heading h1,
  .promo-heading h2 {
    font-size: clamp(1.26rem, 4.8vw, 1.74rem);
    line-height: 1.62;
  }

  .section-heading > p:last-child,
  .products .section-heading p:last-child,
  .flow .section-heading p:last-child,
  .contact .section-heading p:last-child,
  .policy .section-heading p:last-child,
  .compliance .section-heading p:last-child,
  .plans .section-heading p:last-child,
  .contact-copy > p:last-child,
  .concept-copy p,
  .support-copy p,
  .flow-list p,
  .guide-link-card p {
    font-size: 0.95rem;
    line-height: 1.8;
  }

  .concept-copy h2,
  .support-copy h3 {
    font-size: clamp(1.64rem, 6vw, 2.18rem);
    line-height: 1.58;
  }

  .policy-grid,
  .plan-grid,
  .guide-link-grid,
  .flow-list,
  .booking-steps,
  .contact-direct-grid,
  .field-row,
  .booking-feedback-meta {
    grid-template-columns: 1fr;
  }

  .guide-link-card,
  .policy-card,
  .plan-card,
  .flow-list article,
  .booking-steps article,
  .contact-direct-card,
  .booking-optional,
  .booking-check,
  .contact-form,
  .booking-feedback,
  .legal-table div,
  .legal-stack .policy-card {
    padding: 22px;
    border-radius: 24px;
  }

  .showcase-left,
  .showcase-right {
    min-height: 280px;
  }

  .showcase-logo {
    left: 16px;
    top: 14px;
  }

  .showcase-logo span {
    font-size: clamp(3.6rem, 17vw, 5.8rem);
  }

  .showcase-logo small {
    margin-left: 86px;
    font-size: 0.9rem;
  }

  .showcase-copymark {
    right: 18px;
    bottom: 20px;
    font-size: clamp(1.28rem, 5vw, 1.86rem);
  }

  .showcase-counter {
    margin-top: 90px;
    height: 150px;
  }

  .product-blob {
    width: min(100%, 420px);
    min-height: 250px;
    margin-top: 26px;
  }

  .product-illustration {
    width: min(250px, 78%);
    transform: translateY(16px);
  }

  .support-visual {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    min-height: 0;
  }

  .support-photo {
    position: relative;
    right: auto;
    width: min(360px, 100%);
    height: 320px;
    transform: none;
  }

  .support-sticker {
    position: relative;
    right: auto;
    bottom: auto;
    max-width: 100%;
    padding: 16px 20px;
    font-size: 0.9rem;
    text-align: center;
  }

  .contact-form textarea {
    min-height: 150px;
  }

  .button,
  .support-link,
  .submit-button {
    width: 100%;
    justify-content: center;
  }

  .site-footer {
    display: grid;
    gap: 10px;
    padding-top: 24px;
    padding-bottom: 36px;
  }

  .guide-links {
    flex-direction: column;
    gap: 12px;
  }

  .legal-wrap {
    max-width: 100%;
  }

  .legal-wrap h1 {
    font-size: clamp(1.96rem, 8vw, 2.8rem);
    line-height: 1.3;
  }

  .lead {
    font-size: 0.98rem;
    line-height: 1.82;
  }

  .admin-grid,
  .admin-header-row,
  .admin-toolbar {
    grid-template-columns: 1fr;
  }

  .admin-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-auth-actions {
    grid-auto-flow: row;
    justify-content: stretch;
  }

  .admin-toolbar-actions,
  .admin-quick-actions .button {
    width: 100%;
  }

  .admin-toolbar-actions {
    justify-content: stretch;
  }

  .admin-list-top {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-user-chip {
    word-break: break-word;
  }
}

@media (max-width: 560px) {
  :root {
    --content-width: min(100vw - 22px, 1160px);
  }

  .section {
    padding: 60px 0;
  }

  .nav-wrap {
    padding-top: 14px;
    gap: 12px;
  }

  .menu-toggle {
    width: 44px;
    height: 44px;
  }

  .site-nav {
    top: calc(100% + 8px);
    padding: 14px;
    border-radius: 20px;
  }

  .hero {
    min-height: 64svh;
  }

  .hero-boundary {
    height: 76px;
  }

  .promo {
    padding-top: 38px;
    padding-bottom: 56px;
  }

  .promo-announcement {
    margin-bottom: 18px;
  }

  .promo-blob {
    padding: 24px 18px 22px;
    gap: 16px;
  }

  .promo-product {
    width: min(198px, 66vw);
  }

  .promo-heading {
    margin-top: 44px;
  }

  .concept-copy h2,
  .support-copy h3 {
    font-size: clamp(1.44rem, 7vw, 1.88rem);
  }

  .guide-link-card h3,
  .policy-card h3,
  .flow-list h3,
  .plan-card strong {
    font-size: 1.08rem;
    line-height: 1.55;
  }

  .guide-link-card,
  .policy-card,
  .plan-card,
  .flow-list article,
  .booking-steps article,
  .contact-direct-card,
  .contact-form,
  .booking-feedback,
  .admin-header-card,
  .admin-list-panel,
  .admin-detail-panel {
    padding: 18px;
    border-radius: 20px;
  }

  .showcase-left,
  .showcase-right {
    min-height: 240px;
  }

  .showcase-counter {
    margin-top: 74px;
    height: 126px;
  }

  .support-photo {
    height: 280px;
  }

  .booking-challenge-row {
    grid-template-columns: 1fr;
  }

  .checkbox-label {
    gap: 10px;
    font-size: 0.9rem;
  }

  .form-note,
  .booking-trust-note,
  .contact-direct-note,
  .contact-direct-subcopy {
    font-size: 0.82rem;
  }

  .admin-app {
    width: min(100vw - 16px, 1320px);
    padding-top: 16px;
    padding-bottom: 44px;
  }

  .admin-stats,
  .admin-read-grid {
    grid-template-columns: 1fr;
  }

  .admin-panel-heading {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Products motion + organic blob pass */
.products {
  padding-top: 78px;
  padding-bottom: 112px;
  overflow: hidden;
  isolation: isolate;
}

.products::before,
.products::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.products::before {
  top: 58px;
  right: max(24px, calc((100vw - 1120px) / 2));
  width: 296px;
  height: 238px;
  border-radius: 44% 56% 46% 54% / 36% 40% 60% 64%;
  background: linear-gradient(180deg, rgba(255, 206, 157, 0.22), rgba(255, 195, 137, 0.12));
  animation: blobPoyoSide 11s ease-in-out infinite;
}

.products::after {
  left: max(28px, calc((100vw - 1120px) / 2));
  bottom: 26px;
  width: 220px;
  height: 172px;
  border-radius: 46% 54% 40% 60% / 38% 34% 66% 62%;
  background: linear-gradient(180deg, rgba(255, 197, 139, 0.14), rgba(255, 186, 120, 0.08));
  animation: blobPoyoSide 13s ease-in-out infinite reverse;
}

.product-stage {
  position: relative;
  z-index: 2;
  max-width: 900px;
  min-height: 430px;
  margin: 46px auto 0;
}

.product-decor {
  position: absolute;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255, 210, 167, 0.28), rgba(255, 197, 138, 0.1));
  animation: blobPoyoSide 10s ease-in-out infinite;
}

.product-decor-left {
  left: 54px;
  top: 70px;
  width: 286px;
  height: 230px;
  border-radius: 42% 58% 48% 52% / 36% 34% 66% 64%;
}

.product-decor-right {
  right: 64px;
  top: 8px;
  width: 230px;
  height: 188px;
  border-radius: 50% 50% 42% 58% / 38% 42% 58% 62%;
  animation-direction: reverse;
}

.product-blob {
  position: relative;
  z-index: 2;
  width: min(432px, 62vw);
  min-height: 354px;
  margin: 0 auto;
  padding: 26px 24px 0;
  border-radius: 40% 60% 48% 52% / 34% 36% 64% 66%;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 244, 227, 0.22), rgba(255, 244, 227, 0.06)),
    linear-gradient(180deg, #d8ae7d 0%, #c18653 56%, #9f6840 100%);
  box-shadow: 0 28px 50px rgba(109, 61, 24, 0.16);
  animation: blobPoyoMain 8.8s ease-in-out infinite;
}

.product-blob::before,
.product-blob::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.product-blob::before {
  top: 18px;
  right: 22px;
  width: 126px;
  height: 108px;
  border-radius: 44% 56% 46% 54% / 38% 42% 58% 62%;
  background: rgba(255, 238, 214, 0.18);
  animation: blobPoyoSide 12s ease-in-out infinite;
}

.product-blob::after {
  left: 18px;
  bottom: 16px;
  width: 150px;
  height: 118px;
  border-radius: 46% 54% 42% 58% / 36% 40% 60% 64%;
  background: rgba(255, 205, 160, 0.12);
  animation: blobPoyoSide 11s ease-in-out infinite reverse;
}

.product-illustration {
  position: relative;
  z-index: 2;
  display: block;
  width: min(350px, 82%);
  margin: 42px auto 0;
  transform: translateY(16px);
  filter:
    sepia(0.24)
    saturate(0.62)
    hue-rotate(-14deg)
    brightness(1.02)
    contrast(0.95)
    drop-shadow(0 18px 30px rgba(78, 44, 18, 0.12));
}

.product-badge {
  position: absolute;
  top: 22px;
  right: 110px;
  z-index: 3;
  width: auto;
  min-width: 142px;
  padding: 18px 24px;
  border-radius: 44% 56% 48% 52% / 42% 38% 62% 58%;
  white-space: nowrap;
  background: rgba(178, 103, 41, 0.92);
  box-shadow: 0 18px 34px rgba(116, 67, 32, 0.18);
  animation: blobPoyoBadge 7.4s ease-in-out infinite;
}

@media (max-width: 980px) {
  .products::before {
    top: 72px;
    right: 10px;
    width: 240px;
    height: 194px;
  }

  .products::after {
    left: 8px;
    width: 176px;
    height: 142px;
  }

  .product-stage {
    min-height: 390px;
  }

  .product-decor-left {
    left: 10px;
    top: 90px;
    width: 210px;
    height: 174px;
  }

  .product-decor-right {
    right: 18px;
    top: 22px;
    width: 188px;
    height: 150px;
  }

  .product-blob {
    width: min(382px, 74vw);
    min-height: 326px;
  }

  .product-badge {
    top: 18px;
    right: 48px;
  }
}

@media (max-width: 720px) {
  .products {
    padding-top: 64px;
    padding-bottom: 88px;
  }

  .product-stage {
    min-height: 338px;
    margin-top: 34px;
  }

  .product-decor-left {
    left: -8px;
    top: 98px;
    width: 150px;
    height: 124px;
  }

  .product-decor-right {
    right: 2px;
    top: 34px;
    width: 138px;
    height: 112px;
  }

  .product-blob {
    width: min(304px, 80vw);
    min-height: 282px;
    padding-top: 18px;
  }

  .product-illustration {
    width: min(246px, 86%);
    margin-top: 38px;
    transform: translateY(12px);
  }

  .product-badge {
    top: -2px;
    right: 14px;
    min-width: 116px;
    padding: 14px 18px;
    font-size: 0.82rem;
  }
}

@keyframes ambientFloatLeft {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(18px, -22px, 0) scale(1.04);
  }
}

@keyframes headerFadeIn {
  from {
    opacity: 0;
    transform: translateY(-18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes heroReveal {
  from {
    opacity: 0;
    transform: scale(1.04);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes boundaryRise {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(22px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

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

@keyframes ambientFloatRight {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(-24px, 18px, 0) scale(1.06);
  }
}

@keyframes sectionWaveFloat {
  0%,
  100% {
    transform: translate3d(-50%, 0, 0) scaleX(1) rotate(0deg);
  }
  50% {
    transform: translate3d(-46%, 6px, 0) scaleX(1.04) rotate(-0.6deg);
  }
}

@keyframes heroDrift {
  0% {
    transform: scale(1.03) translate3d(0, 0, 0);
  }
  100% {
    transform: scale(1.08) translate3d(-1.5%, -1.2%, 0);
  }
}

@keyframes shimmerShift {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.92;
  }
  100% {
    transform: translate3d(2%, -2%, 0) scale(1.04);
    opacity: 1;
  }
}

@keyframes hazeFloat {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-1.6%, 1.8%, 0);
  }
}

@keyframes blobBreathe {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(0, -8px, 0) scale(1.012);
  }
}

@keyframes softFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(8px, -10px, 0);
  }
}

@keyframes badgeFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -8px, 0);
  }
}

@keyframes blobPoyoMain {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  }
  50% {
    transform: translate3d(0, -12px, 0) scale(1.028) rotate(-0.9deg);
  }
}

@keyframes blobPoyoSide {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  }
  50% {
    transform: translate3d(10px, -8px, 0) scale(1.06) rotate(2deg);
  }
}

@keyframes blobPoyoBadge {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  }
  50% {
    transform: translate3d(0, -8px, 0) scale(1.035) rotate(-1deg);
  }
}

@keyframes frameDrift {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
  50% {
    transform: translate3d(-8px, 8px, 0) rotate(-0.8deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation: none !important;
    transition-duration: 0.01ms !important;
    transition-delay: 0ms !important;
  }

  .reveal {
    opacity: 1;
    filter: none;
    transform: none;
  }
}

/* Kanayama beauty salon refresh: keep the layout, calm down the old orange campaign tone. */
:root {
  --orange: #7f8a73;
  --orange-deep: #596353;
  --orange-soft: #b89c82;
  --orange-fog: rgba(183, 199, 174, 0.28);
  --cream: #f7f1ea;
  --cream-strong: #eadbc9;
  --cream-soft: rgba(250, 246, 239, 0.86);
  --brown: #31382f;
  --brown-soft: rgba(49, 56, 47, 0.78);
  --card-shadow: 0 22px 46px rgba(43, 50, 41, 0.17);
}

body {
  background:
    radial-gradient(circle at 12% 14%, rgba(211, 225, 199, 0.22), transparent 18%),
    radial-gradient(circle at 86% 28%, rgba(232, 216, 198, 0.22), transparent 20%),
    linear-gradient(180deg, #687461 0%, #7a6f61 42%, #4c433c 100%);
}

.hero-illustration {
  object-position: center 48%;
  filter: saturate(0.98) contrast(1.04) brightness(1.04);
}

.hero-film::before {
  background:
    linear-gradient(90deg, rgba(38, 45, 39, 0.28) 0%, rgba(64, 68, 55, 0.12) 42%, rgba(44, 40, 34, 0.02) 100%),
    linear-gradient(180deg, rgba(22, 24, 21, 0.04) 0%, transparent 44%, rgba(22, 24, 21, 0.04) 100%) !important;
}

.hero-film::after {
  background:
    linear-gradient(180deg, rgba(13, 15, 13, 0.04) 0%, rgba(13, 15, 13, 0) 34%, rgba(13, 15, 13, 0.08) 100%),
    linear-gradient(0deg, rgba(247, 241, 234, 0.04) 0%, rgba(247, 241, 234, 0) 24%) !important;
}

.hero-haze {
  background:
    radial-gradient(circle at 22% 18%, rgba(247, 241, 234, 0.08) 0 150px, transparent 151px),
    radial-gradient(circle at 68% 78%, rgba(194, 210, 185, 0.1) 0 180px, transparent 181px) !important;
}

.hero-boundary-svg path:first-child {
  fill: #6d7664;
}

.hero-boundary-svg path:nth-child(2) {
  stroke: #e2d4c5;
}

.promo,
.products,
.support-stage,
.site-footer {
  background: linear-gradient(180deg, #6d7664 0%, #7e735f 100%) !important;
}

.products::before,
.products::after {
  background:
    radial-gradient(circle at 18% 14%, rgba(226, 212, 197, 0.14) 0 150px, transparent 151px),
    radial-gradient(circle at 82% 72%, rgba(194, 210, 185, 0.12) 0 160px, transparent 161px) !important;
}

.promo::after {
  background: #6d7664 !important;
}

.promo-blob {
  background:
    radial-gradient(circle at 26% 28%, rgba(255, 255, 255, 0.34) 0 24px, transparent 25px),
    linear-gradient(180deg, #f3eadf 0%, #d9c8b5 100%) !important;
  box-shadow: 0 30px 52px rgba(44, 50, 41, 0.2);
}

.promo-product {
  overflow: hidden;
  background: #efe7dc !important;
  box-shadow: 0 18px 36px rgba(42, 49, 41, 0.18);
}

.product-blob {
  overflow: hidden;
  background: #efe7dc !important;
  box-shadow: 0 22px 44px rgba(42, 49, 41, 0.2);
}

.promo-illustration,
.product-illustration {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.promo-tag,
.product-badge,
.support-sticker {
  background: rgba(54, 63, 50, 0.78) !important;
  color: #fff !important;
}

.showcase-left {
  background:
    linear-gradient(180deg, rgba(42, 49, 41, 0.16), rgba(42, 49, 41, 0.16)),
    linear-gradient(135deg, #d9c8b5 0%, #8a7a66 58%, #596353 100%) !important;
}

.showcase-right {
  background:
    linear-gradient(180deg, rgba(42, 49, 41, 0.18), rgba(42, 49, 41, 0.18)),
    linear-gradient(180deg, #7f8a73 0%, #6a705e 56%, #4f5749 100%) !important;
}

.button-primary,
.submit-button {
  background: linear-gradient(180deg, #8c7a64 0%, #606b58 100%) !important;
  color: #fff;
}

/* Premium salon polish */
.site-header {
  pointer-events: none;
}

.topbar,
.nav-wrap,
.menu-toggle,
.site-nav,
.brand {
  pointer-events: auto;
}

.nav-wrap {
  width: min(1200px, calc(100vw - 48px));
  margin: 0 auto;
}

.site-nav {
  gap: clamp(16px, 2vw, 28px);
}

.site-nav a {
  font-size: 0.94rem;
  text-shadow: 0 2px 16px rgba(16, 18, 15, 0.18);
}

.nav-cta {
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 999px;
  padding: 10px 18px;
  background: rgba(38, 45, 39, 0.18);
  backdrop-filter: blur(10px);
}

.hero {
  min-height: clamp(680px, 92vh, 880px);
}

.hero-boundary {
  opacity: 0.96;
}

.promo {
  padding-top: clamp(72px, 9vw, 116px);
}

.promo-announcement {
  display: inline-flex;
  width: auto;
  max-width: calc(100vw - 40px);
  margin: 0 auto 24px;
  padding: 10px 18px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  background: rgba(41, 49, 39, 0.34);
  box-shadow: 0 18px 42px rgba(22, 24, 21, 0.13);
  backdrop-filter: blur(10px);
}

.promo-blob {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(260px, 0.72fr);
  align-items: center;
  gap: clamp(24px, 4vw, 56px);
  width: min(1040px, calc(100vw - 40px));
  min-height: 0;
  padding: clamp(34px, 5vw, 62px);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 30px;
}

.promo-blob::before,
.promo-blob::after {
  opacity: 0.34;
}

.promo-blob-copy {
  max-width: 540px;
}

.promo-blob-copy h2 {
  font-size: clamp(2.1rem, 5vw, 4.4rem);
  letter-spacing: 0;
}

.promo-product {
  position: relative;
  top: auto;
  right: auto;
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: 24px;
}

.promo-tag {
  right: 16px;
  top: 16px;
  border-radius: 999px;
}

.promo-heading {
  width: min(920px, calc(100vw - 40px));
}

.promo-heading h1 {
  font-size: clamp(1.5rem, 3vw, 2.62rem);
  line-height: 1.65;
}

.concept-block {
  background: linear-gradient(180deg, #f7f1ea 0%, #eee3d6 100%) !important;
  color: #2f382e;
}

.concept-copy {
  width: min(900px, calc(100vw - 40px));
  margin: 0 auto;
}

.concept-copy p {
  color: rgba(47, 56, 46, 0.8);
}

.concept-copy h2 {
  color: #2f382e;
}

.showcase-visual {
  width: min(1120px, calc(100vw - 40px));
  border-radius: 34px;
  overflow: hidden;
  box-shadow: 0 28px 70px rgba(22, 24, 21, 0.18);
}

.showcase-left::after {
  opacity: 0.42;
}

.products {
  padding-top: clamp(80px, 10vw, 124px);
}

.products .section-heading,
.support-copy,
.policy .section-heading,
.contact-copy {
  width: min(900px, calc(100vw - 40px));
  margin-left: auto;
  margin-right: auto;
}

.products .section-heading p:last-child,
.support-copy p,
.policy .section-heading p,
.contact-copy p {
  line-height: 2;
}

.product-stage,
.support-stage {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.product-blob {
  border-radius: 30px;
}

.support-stage {
  gap: clamp(36px, 6vw, 72px);
}

.support-photo {
  overflow: hidden;
  border-radius: 30px;
  box-shadow: 0 24px 64px rgba(22, 24, 21, 0.18);
}

.policy {
  background: linear-gradient(180deg, #efe6da 0%, #f7f1ea 100%) !important;
  color: #2f382e;
}

.policy-card {
  border: 1px solid rgba(62, 72, 58, 0.1);
  border-radius: 24px;
  box-shadow: 0 18px 44px rgba(37, 42, 34, 0.08);
}

.contact {
  background: linear-gradient(180deg, #5f6759 0%, #4a5146 100%) !important;
}

.contact-form {
  border: 1px solid rgba(255, 255, 255, 0.26);
  box-shadow: 0 30px 76px rgba(22, 24, 21, 0.2);
}

/* Sub pages */
.subpage-body {
  color: #2f382e;
  background: linear-gradient(180deg, #f7f1ea 0%, #e8ded2 100%);
}

.subpage-body .site-header {
  position: sticky;
  top: 0;
  background: rgba(72, 80, 68, 0.72);
  backdrop-filter: blur(18px);
}

.subpage-body .topbar {
  background: rgba(37, 44, 36, 0.28);
}

.subpage-main {
  padding: 140px 0 0;
}

.subpage-hero {
  width: min(1160px, calc(100vw - 40px));
  margin: 0 auto 56px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.74fr);
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
}

.subpage-hero-copy {
  display: grid;
  gap: 18px;
}

.subpage-kicker {
  margin: 0;
  color: #6c765f;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.subpage-hero h1 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(2rem, 3.8vw, 3.8rem);
  line-height: 1.2;
  letter-spacing: 0;
}

.subpage-lead {
  margin: 0;
  color: rgba(47, 56, 46, 0.76);
  font-size: clamp(1rem, 1.35vw, 1.18rem);
  line-height: 2;
}

.subpage-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
}

.subpage-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 12px 20px;
  border-radius: 999px;
  font-weight: 800;
}

.subpage-button-primary {
  background: #596353;
  color: #fff;
}

.subpage-button-secondary {
  border: 1px solid rgba(47, 56, 46, 0.18);
  color: #2f382e;
}

.subpage-hero-media {
  overflow: hidden;
  border-radius: 30px;
  box-shadow: 0 28px 70px rgba(37, 42, 34, 0.16);
  aspect-ratio: 4 / 5;
}

.subpage-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.subpage-section {
  width: min(1160px, calc(100vw - 40px));
  margin: 0 auto;
  padding: 72px 0;
}

.subpage-section + .subpage-section {
  border-top: 1px solid rgba(47, 56, 46, 0.1);
}

.subpage-heading {
  display: grid;
  gap: 10px;
  margin-bottom: 26px;
}

.subpage-heading h2 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  line-height: 1.35;
}

.subpage-heading p {
  max-width: 760px;
  margin: 0;
  color: rgba(47, 56, 46, 0.72);
  line-height: 2;
}

.subpage-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.subpage-grid-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.subpage-card,
.price-card,
.faq-item,
.flow-step {
  border: 1px solid rgba(47, 56, 46, 0.12);
  border-radius: 24px;
  background: rgba(255, 252, 247, 0.82);
  box-shadow: 0 16px 42px rgba(37, 42, 34, 0.07);
}

.subpage-card,
.price-card,
.faq-item {
  padding: clamp(22px, 3vw, 34px);
}

.subpage-card h3,
.price-card h3,
.faq-item h3,
.flow-step h3 {
  margin: 0 0 12px;
  font-size: 1.18rem;
  line-height: 1.5;
}

.subpage-card p,
.price-card p,
.faq-item p,
.flow-step p,
.subpage-card li,
.price-card li {
  color: rgba(47, 56, 46, 0.74);
  line-height: 1.9;
}

.subpage-card p,
.price-card p,
.faq-item p {
  margin: 0;
}

.price-card-featured {
  background: #596353;
  color: #fff;
}

.price-card-featured p,
.price-card-featured li {
  color: rgba(255, 255, 255, 0.82);
}

.price-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 18px;
  margin: 18px 0;
  padding: 16px 0;
  border-top: 1px solid rgba(47, 56, 46, 0.12);
  border-bottom: 1px solid rgba(47, 56, 46, 0.12);
}

.price-card-featured .price-row {
  border-color: rgba(255, 255, 255, 0.2);
}

.price-main {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 800;
}

.price-sub {
  font-size: 0.92rem;
  color: inherit;
  opacity: 0.72;
}

.flow-list {
  display: grid;
  gap: 16px;
}

.flow-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  padding: 24px;
}

.flow-number {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #596353;
  color: #fff;
  font-weight: 800;
}

.note-band {
  border-radius: 30px;
  padding: clamp(28px, 4vw, 44px);
  background: #596353;
  color: #fff;
}

.note-band p {
  color: rgba(255, 255, 255, 0.84);
}

@media (max-width: 860px) {
  .site-nav {
    gap: 0;
  }

  .promo-blob,
  .subpage-hero,
  .subpage-grid,
  .subpage-grid-two {
    grid-template-columns: 1fr;
  }

  .promo-product {
    max-width: 360px;
    margin: 0 auto;
  }

  .subpage-main {
    padding-top: 112px;
  }

  .subpage-hero-media {
    aspect-ratio: 16 / 11;
  }
}

/* ----------------------------------------------------------------
Boutique hotel mobile home
----------------------------------------------------------------- */
.home-body {
  --bt-ivory: #f7f1e8;
  --bt-paper: #fffcf6;
  --bt-stone: #ded4c7;
  --bt-ink: #292722;
  --bt-muted: rgba(41, 39, 34, 0.68);
  --bt-sage: #87917d;
  --bt-sage-soft: #e0e5dc;
  --bt-brass: #aa8653;
  --bt-rose: #b78b78;
  color: var(--bt-ink);
  font-family: "Hiragino Sans", "Yu Gothic", "YuGothic", sans-serif;
  background:
    linear-gradient(90deg, rgba(170, 134, 83, 0.08) 0 1px, transparent 1px) 7vw 0 / 1px 100% no-repeat,
    linear-gradient(180deg, #f8f1e8 0%, #fffaf4 42%, #eee8dd 100%);
}

.home-body::before,
.home-body .ambient,
.home-body .page-shell::before,
.home-body .page-shell::after {
  display: none;
}

.home-body .site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 90;
  pointer-events: none;
}

.home-body .topbar {
  display: none;
}

.home-body .nav-wrap {
  width: min(430px, calc(100vw - 32px));
  padding: 18px 0 0;
  align-items: flex-start;
  pointer-events: auto;
}

.home-body .brand-copy-script strong {
  font-family: "Parisienne", cursive;
  font-size: clamp(3rem, 14vw, 3.9rem);
  line-height: 0.72;
  color: var(--bt-ink);
  text-shadow: 0 12px 34px rgba(70, 54, 36, 0.13);
}

.home-body .brand-copy-script small {
  margin-top: 3px;
  margin-left: 22px;
  color: rgba(41, 39, 34, 0.62);
  font-size: 0.68rem;
  letter-spacing: 0.12em;
}

.home-body .menu-toggle {
  display: inline-flex;
  width: 42px;
  height: 42px;
  margin-top: 2px;
  border: 1px solid rgba(170, 134, 83, 0.35);
  background: rgba(255, 252, 246, 0.72);
  box-shadow: 0 16px 34px rgba(58, 49, 38, 0.09);
  backdrop-filter: blur(14px);
}

.home-body .menu-toggle span {
  background: var(--bt-ink);
}

.home-body .site-nav {
  position: absolute;
  top: 76px;
  left: 0;
  right: 0;
  display: none;
  gap: 0;
  padding: 14px 18px;
  border: 1px solid rgba(170, 134, 83, 0.28);
  border-radius: 20px;
  background: rgba(255, 252, 246, 0.94);
  box-shadow: 0 24px 58px rgba(55, 47, 36, 0.16);
  backdrop-filter: blur(18px);
}

.home-body .site-nav.is-open {
  display: grid;
}

.home-body .site-nav a,
.home-body .nav-cta {
  display: flex;
  justify-content: space-between;
  padding: 13px 0;
  border: 0;
  border-bottom: 1px solid rgba(170, 134, 83, 0.16);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: var(--bt-ink);
  font-size: 1.05rem;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  text-shadow: none;
}

.home-body .site-nav a:last-child {
  border-bottom: 0;
}

.boutique-main {
  position: relative;
  z-index: 1;
  overflow: hidden;
  background:
    radial-gradient(circle at 88% 8%, rgba(224, 229, 220, 0.82), transparent 20%),
    linear-gradient(90deg, transparent 0 calc(100% - 42px), rgba(170, 134, 83, 0.12) calc(100% - 42px) calc(100% - 41px), transparent calc(100% - 41px)),
    linear-gradient(180deg, var(--bt-ivory) 0%, #fffaf4 38%, #efe8dc 100%);
}

.boutique-main img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.boutique-hero,
.boutique-index,
.boutique-concept,
.boutique-treatment,
.boutique-access,
.boutique-guide-links,
.boutique-reserve {
  width: min(430px, 100vw);
  margin: 0 auto;
}

.boutique-hero {
  position: relative;
  min-height: 820px;
  padding: 94px 20px 54px;
}

.boutique-hero-location {
  margin: 0 0 30px auto;
  width: fit-content;
  color: rgba(41, 39, 34, 0.56);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.boutique-script-ghost {
  margin: 0;
  font-family: "Parisienne", cursive;
  font-size: clamp(8.9rem, 46vw, 12.4rem);
  line-height: 0.72;
  color: rgba(170, 134, 83, 0.14);
  pointer-events: none;
}

.boutique-hero > .boutique-script-ghost {
  position: absolute;
  top: 96px;
  left: -42px;
  z-index: 1;
}

.boutique-hero-photo {
  position: relative;
  z-index: 2;
  width: min(70vw, 286px);
  height: 394px;
  margin-left: auto;
  overflow: hidden;
  border-radius: 999px 999px 20px 20px;
  box-shadow: 0 34px 70px rgba(54, 43, 30, 0.15);
}

.boutique-hero-photo::after,
.boutique-concept-photo::after,
.boutique-treatment-photo::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid rgba(255, 252, 246, 0.58);
  border-radius: inherit;
  pointer-events: none;
}

.boutique-hero-copy {
  position: relative;
  z-index: 3;
  width: min(330px, 100%);
  margin-top: -80px;
}

.boutique-kicker {
  margin: 0 0 12px;
  color: var(--bt-brass);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.boutique-hero h1,
.boutique-concept h2,
.boutique-treatment h2,
.boutique-access h2,
.boutique-reserve h2 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-weight: 500;
  letter-spacing: 0;
}

.boutique-hero h1 {
  font-size: clamp(2.5rem, 11.6vw, 3.46rem);
  line-height: 1.12;
}

.boutique-hero-copy p:last-of-type,
.boutique-concept-copy p,
.boutique-treatment-copy p,
.boutique-access-copy p,
.boutique-reserve-copy p {
  color: var(--bt-muted);
  line-height: 2;
}

.boutique-hero-copy p:last-of-type {
  margin: 14px 0 0;
  max-width: 278px;
  font-size: 0.9rem;
  line-height: 1.82;
}

.boutique-hero-links {
  display: flex;
  gap: 22px;
  margin-top: 20px;
}

.boutique-hero-links a,
.boutique-inline-link,
.boutique-reserve-button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--bt-ink);
  font-weight: 800;
}

.boutique-hero-links a::after,
.boutique-inline-link::after {
  content: "";
  width: 36px;
  height: 1px;
  background: var(--bt-brass);
}

.boutique-index {
  padding: 4px 20px 104px;
}

.boutique-index a,
.boutique-menu-lines a,
.boutique-guide-links a {
  position: relative;
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: 8px 16px;
  padding: 26px 0;
  border-top: 1px solid rgba(170, 134, 83, 0.34);
  color: var(--bt-ink);
}

.boutique-index a::after,
.boutique-guide-links a::after {
  content: "";
  align-self: center;
  width: 34px;
  height: 1px;
  background: rgba(170, 134, 83, 0.62);
}

.boutique-index a:nth-child(2) {
  margin-left: 36px;
}

.boutique-index a:nth-child(3) {
  margin-left: 12px;
}

.boutique-index a:nth-child(4) {
  margin-left: 58px;
  border-bottom: 1px solid rgba(170, 134, 83, 0.34);
}

.boutique-index span,
.boutique-menu-lines span,
.boutique-guide-links span {
  color: var(--bt-brass);
  font-family: "Cormorant Garamond", serif;
  font-size: 1rem;
  font-style: italic;
}

.boutique-index strong,
.boutique-guide-links strong {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.92rem;
  font-style: italic;
  font-weight: 600;
  line-height: 1;
}

.boutique-index small,
.boutique-menu-lines small,
.boutique-guide-links small {
  grid-column: 2 / -1;
  color: rgba(41, 39, 34, 0.54);
  line-height: 1.65;
}

.boutique-concept {
  position: relative;
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 18px;
  padding: 0 20px 112px;
}

.boutique-section-label {
  grid-row: span 2;
  position: relative;
  padding-top: 8px;
}

.boutique-section-label span {
  writing-mode: vertical-rl;
  color: var(--bt-brass);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.04rem;
  font-style: italic;
}

.boutique-section-label::after {
  content: "";
  display: block;
  width: 1px;
  height: 160px;
  margin: 20px auto 0;
  background: rgba(170, 134, 83, 0.35);
}

.boutique-concept-copy h2 {
  font-size: clamp(2rem, 9.2vw, 2.72rem);
  line-height: 1.28;
}

.boutique-concept-copy p {
  margin: 20px 0 0;
  width: min(260px, 100%);
  font-size: 0.9rem;
}

.boutique-concept-photo {
  grid-column: 2;
  position: relative;
  width: min(72vw, 288px);
  height: 430px;
  margin: 36px -6px 0 auto;
  overflow: hidden;
  border-radius: 160px 160px 18px 18px;
  box-shadow: 0 32px 64px rgba(52, 43, 31, 0.15);
}

.boutique-concept-photo figcaption {
  position: absolute;
  right: -2px;
  bottom: 22px;
  padding: 8px 12px;
  background: rgba(255, 252, 246, 0.86);
  color: rgba(41, 39, 34, 0.55);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.86rem;
  font-style: italic;
}

.boutique-treatment {
  position: relative;
  padding: 88px 20px 74px;
  background:
    linear-gradient(135deg, rgba(170, 134, 83, 0.2) 0 1px, transparent 1px) 0 0 / 26px 26px,
    linear-gradient(180deg, #dfe4dc 0%, #cdd5c9 100%);
  border-radius: 0 0 0 88px;
}

.boutique-treatment::before {
  content: "";
  position: absolute;
  inset: 20px 20px auto auto;
  width: 58px;
  height: 86px;
  border-top: 1px solid rgba(170, 134, 83, 0.5);
  border-right: 1px solid rgba(170, 134, 83, 0.5);
}

.boutique-treatment-copy {
  position: relative;
  z-index: 2;
  max-width: 292px;
}

.boutique-treatment h2 {
  font-size: clamp(2.35rem, 11vw, 3.35rem);
  line-height: 1.02;
}

.boutique-treatment h2 span {
  display: block;
  margin-top: 8px;
  color: rgba(41, 39, 34, 0.55);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.5rem;
  font-style: italic;
}

.boutique-treatment-copy p {
  margin: 18px 0;
  max-width: 252px;
  font-size: 0.92rem;
}

.boutique-treatment-photo {
  position: relative;
  width: min(52vw, 210px);
  height: 342px;
  margin: -100px -4px 38px auto;
  overflow: hidden;
  border-radius: 120px 120px 16px 16px;
  box-shadow: 0 34px 64px rgba(52, 43, 31, 0.18);
}

.boutique-menu-lines {
  position: relative;
  z-index: 2;
  display: grid;
  margin-top: 26px;
}

.boutique-menu-lines a {
  grid-template-columns: 70px 1fr;
  border-color: rgba(41, 39, 34, 0.18);
}

.boutique-menu-lines a:last-child {
  border-bottom: 1px solid rgba(41, 39, 34, 0.18);
}

.boutique-menu-lines strong {
  font-size: 1.02rem;
}

.boutique-access {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 112px;
  gap: 18px;
  padding: 112px 20px 94px;
}

.boutique-route {
  position: absolute;
  left: 26px;
  right: 34px;
  top: 44px;
  height: 146px;
  border-top: 1px solid rgba(170, 134, 83, 0.28);
  border-right: 1px solid rgba(170, 134, 83, 0.28);
  border-radius: 0 52px 0 0;
}

.boutique-route::before,
.boutique-route::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  background: var(--bt-brass);
}

.boutique-route::before {
  width: 7px;
  height: 7px;
  left: -3px;
  top: -4px;
}

.boutique-route::after {
  width: 11px;
  height: 11px;
  right: -6px;
  bottom: -5px;
  background: var(--bt-rose);
}

.boutique-access-copy {
  position: relative;
  z-index: 2;
  padding-top: 72px;
}

.boutique-access h2 {
  font-size: clamp(1.96rem, 9vw, 2.62rem);
  line-height: 1.32;
}

.boutique-access-copy p {
  margin: 18px 0 22px;
  font-size: 0.9rem;
}

.boutique-access-photo {
  position: relative;
  z-index: 2;
  align-self: end;
  height: 354px;
  margin: 0;
  overflow: hidden;
  border-radius: 999px;
  box-shadow: 0 24px 52px rgba(52, 43, 31, 0.15);
}

.boutique-guide-links {
  display: grid;
  padding: 0 20px 108px;
}

.boutique-guide-links a {
  grid-template-columns: 1fr auto;
  gap: 8px 16px;
  padding: 34px 0;
}

.boutique-guide-links a:nth-child(2) {
  width: 86%;
  margin-left: auto;
}

.boutique-guide-links span {
  font-size: 0.92rem;
}

.boutique-guide-links strong {
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.44rem;
  font-style: normal;
}

.boutique-guide-links small {
  grid-column: 1 / -1;
}

.boutique-reserve {
  position: relative;
  min-height: 620px;
  padding: 106px 20px 82px;
  background: linear-gradient(180deg, #fffaf4 0%, #ebe4d8 100%);
}

.boutique-reserve > .boutique-script-ghost {
  position: absolute;
  top: 84px;
  left: -54px;
  color: rgba(170, 134, 83, 0.16);
}

.boutique-reserve-copy {
  position: relative;
  z-index: 2;
  width: min(300px, 100%);
  margin-left: auto;
  padding-top: 152px;
}

.boutique-reserve h2 {
  font-size: clamp(2.06rem, 9.8vw, 2.86rem);
  line-height: 1.22;
}

.boutique-reserve-copy p:not(.boutique-kicker) {
  margin: 20px 0 28px;
}

.boutique-reserve-button {
  min-height: 52px;
  padding: 0 22px;
  border: 1px solid rgba(170, 134, 83, 0.45);
  border-radius: 999px;
  background: rgba(255, 252, 246, 0.62);
  box-shadow: 0 20px 44px rgba(52, 43, 31, 0.11);
}

.home-body .site-footer {
  width: min(430px, 100vw);
  padding: 54px 20px 86px;
  background: #ebe4d8;
  color: rgba(41, 39, 34, 0.66);
}

.boutique-footer-script {
  margin: 0 0 8px;
  color: rgba(170, 134, 83, 0.28);
  font-family: "Parisienne", cursive;
  font-size: clamp(5rem, 26vw, 7rem);
  line-height: 0.82;
}

.home-body .site-footer p {
  line-height: 1.8;
}

.home-body .footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 18px;
}

.home-body .text-link {
  color: var(--bt-ink);
  text-decoration-color: rgba(170, 134, 83, 0.42);
}

@media (min-width: 861px) {
  .home-body .nav-wrap {
    width: min(1180px, calc(100vw - 64px));
  }

  .home-body .menu-toggle {
    display: none;
  }

  .home-body .site-nav {
    position: static;
    display: flex;
    align-items: center;
    width: auto;
    padding: 12px 0 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
  }

  .home-body .site-nav a,
  .home-body .nav-cta {
    padding: 0;
    border: 0;
    font-size: 1.12rem;
  }

  .boutique-hero,
  .boutique-index,
  .boutique-concept,
  .boutique-treatment,
  .boutique-access,
  .boutique-guide-links,
  .boutique-reserve,
  .home-body .site-footer {
    width: min(1180px, calc(100vw - 64px));
  }

  .boutique-hero {
    min-height: 920px;
    padding-top: 156px;
  }

  .boutique-hero-photo {
    width: min(36vw, 460px);
    height: 640px;
    margin-right: 8vw;
  }

  .boutique-hero-copy {
    width: 520px;
    margin-top: -250px;
    margin-left: 5vw;
  }

  .boutique-hero h1 {
    font-size: clamp(4.3rem, 7vw, 6.6rem);
  }

  .boutique-index {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 28px;
  }

  .boutique-index a,
  .boutique-index a:nth-child(n) {
    margin-left: 0;
  }

  .boutique-concept {
    grid-template-columns: 80px minmax(0, 0.92fr) minmax(340px, 0.68fr);
    align-items: start;
  }

  .boutique-concept-photo {
    grid-column: 3;
    margin-top: 0;
  }

  .boutique-treatment {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(260px, 0.45fr);
    gap: 48px;
    padding-inline: clamp(42px, 7vw, 92px);
  }

  .boutique-treatment-photo {
    width: 280px;
    height: 420px;
    margin: 0;
  }

  .boutique-menu-lines {
    grid-column: 1 / -1;
  }

  .boutique-access {
    grid-template-columns: minmax(0, 0.72fr) 260px;
    gap: 64px;
  }

  .boutique-access-photo {
    height: 480px;
  }
}

/* Boutique reservation page */
.reserve-body {
  --bt-ivory: #f7f1e8;
  --bt-paper: #fffcf6;
  --bt-ink: #292722;
  --bt-muted: rgba(41, 39, 34, 0.68);
  --bt-sage: #87917d;
  --bt-sage-soft: #e0e5dc;
  --bt-brass: #aa8653;
  color: var(--bt-ink);
  background:
    linear-gradient(90deg, rgba(170, 134, 83, 0.08) 0 1px, transparent 1px) 7vw 0 / 1px 100% no-repeat,
    linear-gradient(180deg, #f8f1e8 0%, #fffaf4 52%, #eee8dd 100%);
}

.reserve-body .site-header {
  background: rgba(247, 241, 232, 0.8);
  border-bottom: 1px solid rgba(170, 134, 83, 0.16);
}

.reserve-main {
  padding: 128px 0 0;
}

.reserve-hero,
.reserve-layout {
  width: min(430px, 100vw);
  margin: 0 auto;
}

.reserve-hero {
  display: grid;
  gap: 28px;
  padding: 0 20px 56px;
}

.reserve-hero h1 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(2rem, 9vw, 2.86rem);
  line-height: 1.22;
  letter-spacing: 0;
}

.reserve-hero-note {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 0 14px;
  border-top: 1px solid rgba(170, 134, 83, 0.32);
  border-bottom: 1px solid rgba(170, 134, 83, 0.32);
}

.reserve-hero-note span,
.reserve-hero-note p {
  margin: 0;
  padding: 14px 0;
  border-bottom: 1px solid rgba(170, 134, 83, 0.16);
}

.reserve-hero-note span:nth-last-child(2),
.reserve-hero-note p:last-child {
  border-bottom: 0;
}

.reserve-hero-note span {
  color: var(--bt-brass);
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
}

.reserve-hero-note p {
  color: rgba(41, 39, 34, 0.66);
  line-height: 1.65;
}

.reserve-layout {
  display: grid;
  gap: 28px;
  padding: 0 20px 84px;
}

.reserve-side {
  display: grid;
  gap: 18px;
  align-items: start;
}

.reserve-side > img {
  width: 100%;
  height: clamp(280px, 72vw, 430px);
  border-radius: 34px 34px 96px 34px;
  object-fit: cover;
  object-position: center 68%;
  box-shadow: 0 24px 52px rgba(52, 43, 31, 0.15);
}

.reserve-side-card {
  padding: 24px 0;
  border-top: 1px solid rgba(170, 134, 83, 0.34);
  border-bottom: 1px solid rgba(170, 134, 83, 0.34);
}

.reserve-side-card h2 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.42rem;
  line-height: 1.42;
}

.reserve-side-card p {
  color: var(--bt-muted);
  line-height: 1.85;
}

.reserve-form-panel {
  min-width: 0;
}

.reserve-body .contact-form {
  padding: clamp(22px, 6vw, 34px);
  border: 1px solid rgba(170, 134, 83, 0.28);
  border-radius: 26px;
  background: rgba(255, 252, 246, 0.88);
  box-shadow: 0 26px 62px rgba(52, 43, 31, 0.12);
}

.reserve-body .contact-form input,
.reserve-body .contact-form select,
.reserve-body .contact-form textarea {
  border-color: rgba(170, 134, 83, 0.24);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--bt-ink);
}

.reserve-body .contact-form input:focus,
.reserve-body .contact-form select:focus,
.reserve-body .contact-form textarea:focus {
  border-color: rgba(170, 134, 83, 0.62);
  box-shadow: 0 0 0 3px rgba(170, 134, 83, 0.16);
}

.reserve-body .booking-check,
.reserve-body .booking-optional,
.reserve-body .booking-challenge-prompt {
  border-color: rgba(170, 134, 83, 0.2);
  background: rgba(247, 241, 232, 0.72);
}

.reserve-body .submit-button {
  min-height: 54px;
  border-radius: 999px;
  background: linear-gradient(180deg, #9c8f77 0%, #68735f 100%) !important;
  box-shadow: 0 20px 42px rgba(52, 43, 31, 0.16);
}

.reserve-body .booking-feedback {
  margin-bottom: 22px;
  border: 1px solid rgba(170, 134, 83, 0.3);
  border-radius: 24px;
  background: rgba(255, 252, 246, 0.92);
}

.availability-tool {
  margin-bottom: 22px;
  padding: clamp(22px, 6vw, 34px);
  border: 1px solid rgba(170, 134, 83, 0.3);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(255, 252, 246, 0.94), rgba(237, 230, 217, 0.84)),
    radial-gradient(circle at 85% 10%, rgba(170, 134, 83, 0.14), transparent 34%);
  box-shadow: 0 26px 62px rgba(52, 43, 31, 0.12);
  overflow: hidden;
}

.availability-head {
  display: grid;
  gap: 18px;
}

.availability-head h2 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.42rem;
  line-height: 1.35;
  letter-spacing: 0;
}

.availability-head p:not(.subpage-kicker) {
  margin: 10px 0 0;
  color: var(--bt-muted);
  line-height: 1.75;
}

.availability-controls {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(170, 134, 83, 0.22);
  border-radius: 999px;
  background: rgba(255, 252, 246, 0.74);
}

.availability-nav {
  width: 42px;
  height: 42px;
  border: 1px solid rgba(170, 134, 83, 0.28);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.68);
  color: var(--bt-ink);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.45rem;
  line-height: 1;
  cursor: pointer;
}

.availability-nav:disabled {
  opacity: 0.36;
  cursor: default;
}

#availability-month {
  margin: 0;
  text-align: center;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.34rem;
  font-weight: 600;
  color: var(--bt-ink);
}

.availability-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin: 20px 0 14px;
  color: rgba(41, 39, 34, 0.64);
  font-size: 0.78rem;
}

.availability-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.availability-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  display: inline-block;
}

.availability-dot-open {
  background: #7e8a73;
}

.availability-dot-few {
  background: #b49563;
}

.availability-dot-closed {
  background: rgba(41, 39, 34, 0.24);
}

.availability-weekdays,
.availability-calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.availability-weekdays span {
  text-align: center;
  color: rgba(41, 39, 34, 0.48);
  font-size: 0.72rem;
  font-weight: 700;
}

.availability-calendar {
  margin-top: 8px;
}

.availability-day {
  min-width: 0;
  aspect-ratio: 1 / 1.08;
  border: 1px solid rgba(170, 134, 83, 0.2);
  border-radius: 14px;
  background: rgba(255, 252, 246, 0.62);
  color: var(--bt-ink);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  cursor: pointer;
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease,
    background 180ms ease;
}

.availability-day.is-empty {
  visibility: hidden;
}

.availability-day:disabled {
  color: rgba(41, 39, 34, 0.34);
  cursor: default;
  background: rgba(255, 255, 255, 0.28);
  border-color: rgba(41, 39, 34, 0.08);
}

.availability-day:not(:disabled):hover,
.availability-day:not(:disabled):focus-visible {
  border-color: rgba(170, 134, 83, 0.58);
  box-shadow: 0 10px 20px rgba(52, 43, 31, 0.11);
  transform: translateY(-1px);
}

.availability-day.is-open:not(:disabled) {
  background: rgba(255, 252, 246, 0.88);
}

.availability-day.is-few:not(:disabled) {
  background: rgba(245, 235, 217, 0.92);
}

.availability-day.is-selected:not(:disabled) {
  border-color: rgba(104, 115, 95, 0.78);
  background: linear-gradient(180deg, rgba(255, 252, 246, 0.94), rgba(224, 229, 220, 0.9));
  box-shadow: inset 0 0 0 1px rgba(104, 115, 95, 0.24), 0 14px 28px rgba(52, 43, 31, 0.12);
}

.availability-day.is-today .availability-day-number {
  text-decoration: underline;
  text-decoration-color: rgba(170, 134, 83, 0.7);
  text-underline-offset: 3px;
}

.availability-day-number {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.08rem;
  font-weight: 600;
}

.availability-day-status {
  color: rgba(41, 39, 34, 0.58);
  font-size: 0.76rem;
  line-height: 1;
}

.availability-slots {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid rgba(170, 134, 83, 0.22);
}

.availability-slots-head {
  display: grid;
  gap: 6px;
}

.availability-slots h3 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.06rem;
  line-height: 1.4;
}

.availability-selected {
  margin: 0;
  color: rgba(41, 39, 34, 0.58);
  font-size: 0.82rem;
  line-height: 1.55;
}

.availability-slot-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.availability-slot,
.availability-empty {
  min-width: 0;
  min-height: 44px;
  margin: 0;
  border: 1px solid rgba(170, 134, 83, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.56);
  color: var(--bt-ink);
  font-size: 0.88rem;
  line-height: 1.2;
}

.availability-slot {
  padding: 0 14px;
  cursor: pointer;
}

.availability-slot.is-few {
  background: rgba(245, 235, 217, 0.9);
}

.availability-slot.is-selected {
  border-color: rgba(104, 115, 95, 0.78);
  background: #68735f;
  color: #fffaf4;
  box-shadow: 0 12px 24px rgba(52, 43, 31, 0.14);
}

.availability-empty {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  color: rgba(41, 39, 34, 0.56);
}

@media (min-width: 861px) {
  .reserve-hero,
  .reserve-layout {
    width: min(1040px, calc(100vw - 72px));
  }

  .reserve-hero {
    grid-template-columns: minmax(0, 0.9fr) minmax(300px, 0.42fr);
    align-items: end;
    padding-top: 42px;
  }

  .reserve-layout {
    grid-template-columns: minmax(280px, 340px) minmax(0, 620px);
    align-items: start;
    justify-content: center;
    gap: 64px;
  }

  .reserve-side {
    position: sticky;
    top: 120px;
  }

  .reserve-side > img {
    height: 520px;
    border-radius: 150px 150px 32px 32px;
  }

  .reserve-form-panel {
    max-width: 620px;
  }

  .availability-head {
    grid-template-columns: minmax(0, 1fr) 194px;
    align-items: start;
  }

  .availability-slot-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 420px) {
  .reserve-main {
    padding-top: 116px;
  }

  .reserve-hero,
  .reserve-layout {
    width: 100%;
  }

  .reserve-hero {
    padding-inline: 18px;
    padding-bottom: 44px;
  }

  .reserve-layout {
    gap: 22px;
    padding-inline: 14px;
  }

  .reserve-side > img {
    height: 276px;
    border-radius: 28px 28px 82px 28px;
  }

  .reserve-side-card {
    padding: 18px 0;
  }

  .reserve-side-card h2 {
    font-size: 1.24rem;
  }

  .availability-tool {
    padding: 20px 16px;
    border-radius: 22px;
  }

  .availability-controls {
    grid-template-columns: 38px minmax(0, 1fr) 38px;
    gap: 8px;
    padding: 8px;
  }

  .availability-nav {
    width: 38px;
    height: 38px;
  }

  .availability-calendar,
  .availability-weekdays {
    gap: 4px;
  }

  .availability-day {
    border-radius: 10px;
  }

  .availability-day-number {
    font-size: 1rem;
  }

  .availability-slot-list {
    grid-template-columns: 1fr;
  }

  .reserve-body .contact-form {
    padding: 20px 16px;
    border-radius: 22px;
  }

  .reserve-body .field-row,
  .reserve-body .booking-challenge-row {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .reserve-body .contact-form input,
  .reserve-body .contact-form select,
  .reserve-body .contact-form textarea {
    min-height: 48px;
    padding: 13px 14px;
  }

  .reserve-body .booking-check {
    padding: 16px;
  }
}

/* Boutique poster redesign */
.home-body {
  --poster-ivory: #fbf7ef;
  --poster-paper: #fffdf8;
  --poster-ink: #272622;
  --poster-muted: rgba(39, 38, 34, 0.63);
  --poster-brass: #b08b56;
  --poster-sage: #8d9889;
  --poster-sage-deep: #758070;
  background:
    linear-gradient(90deg, transparent 0 16px, rgba(176, 139, 86, 0.16) 16px 17px, transparent 17px),
    radial-gradient(circle at 72% 8%, rgba(209, 199, 184, 0.42), transparent 25%),
    linear-gradient(180deg, #fbf7ef 0%, #fffdf8 46%, #f0ebe2 100%);
  color: var(--poster-ink);
}

.home-body .site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 100;
  pointer-events: none;
}

.home-body .nav-wrap {
  width: min(430px, 100vw);
  padding: 22px 28px 0;
  align-items: flex-start;
  pointer-events: auto;
}

.home-body .brand-copy-script strong {
  font-size: clamp(2.25rem, 11vw, 3rem);
  line-height: 0.74;
  color: var(--poster-ink);
  text-shadow: none;
}

.home-body .brand-copy-script small {
  margin-top: 2px;
  margin-left: 18px;
  color: rgba(39, 38, 34, 0.58);
  font-size: 0.56rem;
  letter-spacing: 0.24em;
}

.home-body .menu-toggle {
  width: 38px;
  height: 38px;
  margin-top: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}

.home-body .menu-toggle span {
  width: 26px;
  height: 1px;
  background: var(--poster-ink);
}

.home-body .site-nav {
  top: 74px;
  left: 20px;
  right: 20px;
  border-radius: 0;
  border-color: rgba(176, 139, 86, 0.28);
  background: rgba(255, 253, 248, 0.96);
}

.boutique-main {
  overflow: hidden;
  background:
    linear-gradient(90deg, transparent 0 17px, rgba(176, 139, 86, 0.13) 17px 18px, transparent 18px),
    radial-gradient(circle at 14% 88%, rgba(239, 232, 220, 0.86), transparent 22%),
    linear-gradient(180deg, var(--poster-ivory) 0%, var(--poster-paper) 52%, #efe9df 100%);
}

.boutique-main .reveal {
  opacity: 1;
  filter: none;
  transform: none;
}

.boutique-hero,
.boutique-index,
.boutique-concept,
.boutique-treatment,
.boutique-access,
.boutique-guide-links,
.boutique-reserve,
.home-body .site-footer {
  width: min(430px, 100vw);
}

.boutique-hero {
  min-height: 690px;
  padding: 0 0 34px;
  isolation: isolate;
}

.boutique-hero::before {
  content: "";
  position: absolute;
  left: 28px;
  top: 176px;
  width: 1px;
  height: 138px;
  background: rgba(176, 139, 86, 0.46);
  z-index: 4;
}

.boutique-hero-location {
  position: absolute;
  top: 30px;
  left: 50%;
  z-index: 6;
  margin: 0;
  width: max-content;
  transform: translateX(-50%);
  color: rgba(39, 38, 34, 0.62);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.83rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: none;
}

.boutique-script-ghost {
  color: rgba(176, 139, 86, 0.13);
  font-size: clamp(8rem, 42vw, 11rem);
  line-height: 0.74;
}

.boutique-hero > .boutique-script-ghost {
  top: 114px;
  left: 150px;
  z-index: 1;
  transform: rotate(-7deg);
}

.boutique-hero-photo {
  position: absolute;
  top: 132px;
  right: -86px;
  z-index: 2;
  width: 276px;
  height: 438px;
  margin: 0;
  border-radius: 150px 0 0 0;
  box-shadow: 0 26px 62px rgba(64, 50, 32, 0.13);
}

.boutique-hero-photo img {
  object-position: 47% 50%;
}

.boutique-hero-photo::after,
.boutique-concept-photo::after,
.boutique-treatment-photo::after {
  display: none;
}

.boutique-hero-copy {
  position: absolute;
  left: 48px;
  top: 206px;
  z-index: 5;
  width: 228px;
  margin: 0;
}

.boutique-hero-copy .boutique-kicker {
  display: none;
}

.boutique-hero h1 {
  width: 214px;
  font-size: clamp(2.25rem, 10.4vw, 2.85rem);
  line-height: 1.46;
  letter-spacing: 0.03em;
}

.boutique-hero h1::after {
  content: "";
  display: block;
  width: 54px;
  height: 1px;
  margin: 18px 0 0;
  background: var(--poster-brass);
}

.boutique-hero-copy p:last-of-type {
  max-width: 184px;
  margin: 20px 0 0;
  color: rgba(39, 38, 34, 0.68);
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 0.78rem;
  line-height: 2.12;
}

.boutique-hero-links {
  gap: 30px;
  margin-top: 28px;
}

.boutique-hero-links a,
.boutique-inline-link {
  gap: 16px;
  color: var(--poster-ink);
  font-family: "Cormorant Garamond", "Hiragino Mincho ProN", serif;
  font-size: 1rem;
  font-weight: 600;
}

.boutique-hero-links a::after,
.boutique-inline-link::after {
  width: 34px;
  background: var(--poster-brass);
}

.boutique-index {
  position: relative;
  padding: 42px 28px 72px 72px;
  background: rgba(255, 253, 248, 0.72);
}

.boutique-index::before,
.boutique-guide-links::before {
  content: "NAVIGATION";
  position: absolute;
  left: 28px;
  top: 52px;
  writing-mode: vertical-rl;
  color: rgba(176, 139, 86, 0.82);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.9rem;
  letter-spacing: 0.24em;
}

.boutique-index::after,
.boutique-guide-links::after {
  content: "";
  position: absolute;
  left: 36px;
  top: 158px;
  width: 1px;
  height: 92px;
  background: rgba(176, 139, 86, 0.5);
}

.boutique-index a,
.boutique-menu-lines a,
.boutique-guide-links a {
  display: grid;
  grid-template-columns: 44px 86px 1fr 18px;
  gap: 0 16px;
  align-items: center;
  padding: 14px 0;
  border-top: 0;
  color: var(--poster-ink);
}

.boutique-index a:nth-child(n) {
  margin-left: 0;
}

.boutique-index a::before,
.boutique-menu-lines a::before,
.boutique-guide-links a::before {
  content: "";
  grid-column: 3;
  height: 1px;
  background: rgba(176, 139, 86, 0.5);
}

.boutique-index a::after,
.boutique-menu-lines a::after,
.boutique-guide-links a::after {
  content: "→";
  grid-column: 4;
  width: auto;
  height: auto;
  background: transparent;
  color: rgba(39, 38, 34, 0.72);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.06rem;
  line-height: 1;
}

.boutique-index span,
.boutique-menu-lines span,
.boutique-guide-links span {
  grid-column: 1;
  grid-row: 1;
  color: var(--poster-brass);
  font-size: 1.36rem;
  line-height: 1;
}

.boutique-index strong {
  grid-column: 2;
  grid-row: 1;
  font-size: 1.1rem;
  font-style: normal;
}

.boutique-index small {
  display: none;
}

.boutique-concept {
  position: relative;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  min-height: 548px;
  gap: 18px;
  padding: 48px 0 70px 26px;
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.95), rgba(250, 245, 237, 0.94));
}

.boutique-section-label {
  grid-row: 1 / span 2;
  padding-top: 22px;
}

.boutique-section-label span {
  color: rgba(176, 139, 86, 0.82);
  font-size: 1rem;
  letter-spacing: 0.16em;
}

.boutique-section-label::after {
  height: 172px;
  margin-top: 18px;
  background: rgba(176, 139, 86, 0.42);
}

.boutique-concept-copy {
  position: relative;
  z-index: 3;
  padding-top: 68px;
}

.boutique-concept-copy h2 {
  width: 242px;
  font-size: clamp(1.96rem, 8.7vw, 2.48rem);
  line-height: 1.62;
  letter-spacing: 0.04em;
}

.boutique-concept-copy p {
  width: 198px;
  margin-top: 22px;
  color: rgba(39, 38, 34, 0.64);
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 0.78rem;
  line-height: 2.14;
}

.boutique-concept-photo {
  position: absolute;
  right: -98px;
  bottom: 70px;
  z-index: 2;
  width: 245px;
  height: 300px;
  margin: 0;
  border-radius: 170px 0 0 170px;
  box-shadow: none;
}

.boutique-concept-photo img {
  object-position: 49% 62%;
}

.boutique-concept-photo figcaption {
  display: none;
}

.boutique-treatment {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 18px;
  padding: 70px 26px 78px;
  overflow: hidden;
  border-radius: 0;
  clip-path: polygon(0 5%, 100% 0, 100% 94%, 0 100%);
  background:
    linear-gradient(90deg, rgba(117, 128, 112, 0.94), rgba(141, 152, 137, 0.9)),
    url("./assets/photos/boutique-room-arch-v1.webp") 112% 50% / 52% auto no-repeat;
}

.boutique-treatment::before {
  content: "TREATMENT";
  position: static;
  grid-column: 1;
  grid-row: 1 / span 3;
  width: auto;
  height: auto;
  border: 0;
  writing-mode: vertical-rl;
  align-self: start;
  color: rgba(255, 253, 248, 0.76);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.92rem;
  letter-spacing: 0.24em;
}

.boutique-treatment-copy {
  grid-column: 2;
  max-width: 290px;
}

.boutique-treatment .boutique-kicker {
  display: none;
}

.boutique-treatment h2 {
  color: #fffdf8;
  font-size: clamp(2rem, 8.7vw, 2.64rem);
  line-height: 1.15;
  letter-spacing: 0.04em;
}

.boutique-treatment h2 span {
  display: inline;
  margin-left: 8px;
  color: rgba(255, 253, 248, 0.86);
  font-size: 1.18rem;
}

.boutique-treatment-copy p {
  margin: 14px 0 22px;
  max-width: 268px;
  color: rgba(255, 253, 248, 0.82);
  font-size: 0.78rem;
  line-height: 1.95;
}

.boutique-treatment .boutique-inline-link {
  color: rgba(255, 253, 248, 0.88);
}

.boutique-treatment .boutique-inline-link::after {
  background: rgba(255, 253, 248, 0.58);
}

.boutique-treatment-photo {
  position: absolute;
  right: -50px;
  bottom: 18px;
  width: 144px;
  height: 196px;
  margin: 0;
  border-radius: 100px 0 0 100px;
  opacity: 0.55;
  box-shadow: none;
}

.boutique-treatment-photo img {
  object-position: 55% 38%;
}

.boutique-menu-lines {
  grid-column: 2;
  margin-top: 8px;
  padding-right: 38px;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 74px 18px;
  padding: 14px 0;
  border-top: 1px solid rgba(255, 253, 248, 0.34);
}

.boutique-menu-lines a::before {
  display: none;
}

.boutique-menu-lines a::after {
  grid-column: 3;
  color: rgba(255, 253, 248, 0.78);
}

.boutique-menu-lines span {
  display: none;
}

.boutique-menu-lines strong {
  grid-column: 1;
  color: rgba(255, 253, 248, 0.94);
  font-size: 0.83rem;
  font-weight: 600;
}

.boutique-menu-lines small {
  grid-column: 2;
  color: rgba(255, 253, 248, 0.78);
  font-size: 0.68rem;
  line-height: 1.4;
  text-align: right;
}

.boutique-access {
  display: grid;
  grid-template-columns: 136px minmax(0, 1fr);
  gap: 24px;
  padding: 76px 28px 68px;
  background: rgba(255, 253, 248, 0.92);
}

.boutique-route {
  left: auto;
  right: 0;
  top: 44px;
  width: 166px;
  height: 160px;
  border-color: rgba(176, 139, 86, 0.28);
  transform: rotate(-8deg);
}

.boutique-access-photo {
  grid-column: 1;
  grid-row: 1;
  align-self: start;
  width: 136px;
  height: 188px;
  border-radius: 0;
  box-shadow: none;
}

.boutique-access-photo img {
  object-position: 45% 45%;
}

.boutique-access-copy {
  grid-column: 2;
  position: relative;
  z-index: 2;
  padding-top: 10px;
}

.boutique-access-copy .boutique-kicker {
  margin-bottom: 10px;
  color: var(--poster-brass);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
}

.boutique-access h2 {
  font-size: clamp(1.65rem, 7vw, 2.2rem);
  line-height: 1.3;
}

.boutique-access h2::after {
  content: "";
  display: block;
  width: 42px;
  height: 1px;
  margin-top: 12px;
  background: var(--poster-brass);
}

.boutique-access-copy p:not(.boutique-kicker) {
  margin: 18px 0;
  color: rgba(39, 38, 34, 0.63);
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 0.75rem;
  line-height: 2;
}

.boutique-guide-links {
  position: relative;
  display: grid;
  padding: 26px 28px 62px 72px;
  background: rgba(255, 253, 248, 0.94);
}

.boutique-guide-links::before {
  content: "GUIDE";
  top: 44px;
}

.boutique-guide-links::after {
  top: 112px;
  height: 74px;
}

.boutique-guide-links a {
  grid-template-columns: 44px 112px 1fr 18px;
  padding: 16px 0;
}

.boutique-guide-links a:nth-child(2) {
  width: 100%;
  margin-left: 0;
}

.boutique-guide-links span {
  font-size: 1.28rem;
}

.boutique-guide-links strong {
  grid-column: 2;
  grid-row: 1;
  font-family: "Cormorant Garamond", serif;
  font-size: 1rem;
}

.boutique-guide-links small {
  display: none;
}

.boutique-reserve {
  min-height: 412px;
  padding: 72px 28px 74px;
  overflow: hidden;
  text-align: center;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.72), rgba(255, 253, 248, 0.9)),
    url("./assets/photos/reservation-preparation-v1.webp") center bottom / cover no-repeat;
}

.boutique-reserve > .boutique-script-ghost {
  top: 118px;
  left: 32px;
  color: rgba(176, 139, 86, 0.1);
  transform: rotate(-8deg);
}

.boutique-reserve-copy {
  width: min(320px, 100%);
  margin: 0 auto;
  padding-top: 78px;
}

.boutique-reserve-copy .boutique-kicker {
  display: none;
}

.boutique-reserve h2 {
  font-size: clamp(2rem, 8.8vw, 2.6rem);
  line-height: 1.25;
  letter-spacing: 0.04em;
}

.boutique-reserve-copy p:not(.boutique-kicker) {
  margin: 14px auto 24px;
  max-width: 240px;
  color: rgba(39, 38, 34, 0.6);
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 0.78rem;
  line-height: 1.9;
}

.boutique-reserve-button {
  justify-content: center;
  min-width: 250px;
  min-height: 54px;
  border: 0;
  border-radius: 999px;
  background: var(--poster-sage-deep);
  color: #fffdf8;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1rem;
  font-weight: 500;
  box-shadow: 0 18px 40px rgba(64, 72, 58, 0.18);
}

.boutique-reserve-button::after {
  content: "→";
  margin-left: 18px;
  font-family: "Cormorant Garamond", serif;
}

.home-body .site-footer {
  padding: 28px 28px 44px;
  background: rgba(255, 253, 248, 0.95);
}

.boutique-footer-script {
  color: var(--poster-ink);
  font-size: clamp(2.8rem, 15vw, 4.2rem);
}

.home-body .site-footer > p:not(.boutique-footer-script):not(.footer-links) {
  display: none;
}

.home-body .footer-links {
  justify-content: center;
  gap: 10px 16px;
  font-family: "Cormorant Garamond", serif;
  font-size: 0.82rem;
}

@media (min-width: 861px) {
  .home-body .nav-wrap,
  .boutique-hero,
  .boutique-index,
  .boutique-concept,
  .boutique-treatment,
  .boutique-access,
  .boutique-guide-links,
  .boutique-reserve,
  .home-body .site-footer {
    width: min(1180px, calc(100vw - 64px));
  }

  .boutique-hero {
    min-height: 760px;
  }

  .boutique-hero-photo {
    right: 0;
    width: min(42vw, 520px);
    height: 610px;
  }

  .boutique-hero-copy {
    left: clamp(72px, 8vw, 120px);
    top: 210px;
    width: 480px;
  }

  .boutique-hero h1 {
    width: 440px;
    font-size: clamp(3.7rem, 5vw, 5.4rem);
    line-height: 1.34;
  }

  .boutique-hero-copy p:last-of-type {
    max-width: 320px;
  }

  .boutique-index,
  .boutique-guide-links {
    padding-right: clamp(72px, 8vw, 120px);
    padding-left: clamp(120px, 12vw, 180px);
  }

  .boutique-concept {
    min-height: 560px;
    padding-left: clamp(70px, 8vw, 120px);
  }

  .boutique-concept-copy h2 {
    width: 480px;
  }

  .boutique-concept-copy p {
    width: 340px;
  }

  .boutique-concept-photo {
    right: 0;
    width: min(42vw, 520px);
    height: 380px;
  }

  .boutique-treatment {
    grid-template-columns: 82px minmax(0, 680px);
    padding-inline: clamp(70px, 8vw, 120px);
    background:
      linear-gradient(90deg, rgba(117, 128, 112, 0.94), rgba(141, 152, 137, 0.88)),
      url("./assets/photos/boutique-room-arch-v1.webp") 96% 50% / 330px auto no-repeat;
  }

  .boutique-treatment-photo {
    right: 80px;
    width: 230px;
    height: 290px;
  }

  .boutique-access {
    grid-template-columns: 260px minmax(0, 520px);
    padding-inline: clamp(70px, 8vw, 120px);
  }

  .boutique-access-photo {
    width: 260px;
    height: 260px;
  }
}

/* Poster refinement v2: closer to the remembered boutique mock */
.boutique-main {
  background:
    linear-gradient(90deg, transparent 0 17px, rgba(176, 139, 86, 0.12) 17px 18px, transparent 18px),
    radial-gradient(circle at 76% 13%, rgba(176, 139, 86, 0.08), transparent 28%),
    radial-gradient(circle at 14% 86%, rgba(141, 152, 137, 0.12), transparent 24%),
    linear-gradient(180deg, #fbf7ef 0%, #fffdf8 48%, #f2ede4 100%);
}

.boutique-hero {
  min-height: 708px;
  background:
    linear-gradient(110deg, rgba(255, 253, 248, 0.96) 0 54%, rgba(255, 253, 248, 0.2) 54% 100%),
    radial-gradient(circle at 84% 9%, rgba(176, 139, 86, 0.1), transparent 28%);
}

.boutique-hero::before {
  left: 30px;
  top: 158px;
  height: 170px;
  background: rgba(176, 139, 86, 0.4);
}

.boutique-hero::after {
  content: "";
  position: absolute;
  right: -108px;
  top: 95px;
  z-index: 1;
  width: 285px;
  height: 520px;
  border-radius: 190px 0 0 0;
  background:
    linear-gradient(90deg, rgba(251, 247, 239, 0.58), transparent 32%),
    rgba(176, 139, 86, 0.08);
  pointer-events: none;
}

.boutique-hero > .boutique-script-ghost {
  top: 100px;
  left: 132px;
  color: rgba(176, 139, 86, 0.1);
  font-size: clamp(9.5rem, 48vw, 12.6rem);
  transform: rotate(-8deg);
}

.boutique-hero-photo {
  top: 108px;
  right: -48px;
  width: 262px;
  height: 500px;
  border-radius: 190px 0 0 0;
  box-shadow: none;
}

.boutique-hero-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(251, 247, 239, 0.36), transparent 28%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.2), transparent 32%, rgba(39, 38, 34, 0.05));
  pointer-events: none;
}

.boutique-hero-photo img {
  object-position: 47% 53%;
}

.boutique-hero-copy {
  left: 50px;
  top: 184px;
  width: 236px;
}

.boutique-hero h1 {
  width: 236px;
  font-size: clamp(2.18rem, 10vw, 2.72rem);
  line-height: 1.52;
}

.boutique-hero-copy p:last-of-type {
  max-width: 190px;
  margin-top: 18px;
  color: rgba(39, 38, 34, 0.62);
  font-size: 0.76rem;
}

.boutique-hero-links {
  margin-top: 26px;
}

.boutique-hero-links a {
  min-width: 74px;
}

.boutique-index {
  padding: 32px 26px 72px 76px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.75), rgba(255, 253, 248, 0.94)),
    linear-gradient(90deg, transparent 0 18px, rgba(176, 139, 86, 0.08) 18px 19px, transparent 19px);
}

.boutique-index::before {
  left: 30px;
  top: 44px;
  font-size: 0.86rem;
}

.boutique-index::after {
  left: 38px;
  top: 152px;
  height: 96px;
}

.boutique-index a {
  grid-template-columns: 44px 78px minmax(80px, 1fr) 20px;
  gap: 0 18px;
  padding: 13px 0;
}

.boutique-index span {
  font-size: 1.45rem;
}

.boutique-index strong {
  font-size: 1.05rem;
}

.boutique-index a::before {
  background: rgba(176, 139, 86, 0.43);
}

.boutique-concept {
  min-height: 580px;
  padding-top: 62px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.96), rgba(250, 246, 239, 0.96)),
    radial-gradient(circle at 84% 72%, rgba(141, 152, 137, 0.1), transparent 30%);
}

.boutique-concept-photo {
  right: -78px;
  bottom: 78px;
  width: 254px;
  height: 312px;
  border-radius: 172px 0 0 172px;
}

.boutique-concept-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(90deg, rgba(255, 253, 248, 0.26), transparent 34%);
  pointer-events: none;
}

.boutique-treatment {
  grid-template-columns: 50px minmax(0, 1fr);
  min-height: 440px;
  padding: 58px 24px 64px;
  clip-path: polygon(0 6%, 100% 0, 100% 92%, 0 100%);
  background:
    linear-gradient(90deg, rgba(130, 142, 124, 0.86), rgba(166, 176, 160, 0.76)),
    url("./assets/photos/reservation-preparation-v1.webp") 126% 46% / 245px auto no-repeat;
}

.boutique-treatment::before {
  color: rgba(255, 253, 248, 0.62);
  font-size: 0.86rem;
}

.boutique-treatment-copy {
  max-width: 280px;
}

.boutique-treatment h2 {
  font-size: clamp(1.86rem, 8.2vw, 2.46rem);
  line-height: 1.22;
}

.boutique-treatment-copy p {
  max-width: 238px;
  margin: 12px 0 20px;
  color: rgba(255, 253, 248, 0.78);
}

.boutique-treatment-photo {
  right: -64px;
  bottom: 24px;
  width: 168px;
  height: 214px;
  opacity: 0.34;
  filter: saturate(0.82) brightness(1.08);
}

.boutique-menu-lines {
  margin-top: 2px;
  padding-right: 18px;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 88px 18px;
  padding: 12px 0;
  border-color: rgba(255, 253, 248, 0.27);
}

.boutique-menu-lines strong {
  font-size: 0.8rem;
}

.boutique-menu-lines small {
  font-size: 0.64rem;
}

.boutique-access {
  padding-top: 86px;
  padding-bottom: 74px;
  background:
    radial-gradient(circle at 92% 16%, rgba(176, 139, 86, 0.08), transparent 28%),
    rgba(255, 253, 248, 0.94);
}

.boutique-route {
  right: -12px;
  top: 38px;
  width: 188px;
  height: 176px;
  border-color: rgba(176, 139, 86, 0.22);
}

.boutique-route::before {
  background: rgba(176, 139, 86, 0.58);
}

.boutique-route::after {
  background: rgba(141, 152, 137, 0.72);
}

.boutique-access-photo {
  width: 142px;
  height: 194px;
}

.boutique-guide-links {
  padding-top: 18px;
  padding-bottom: 54px;
}

.boutique-guide-links a {
  grid-template-columns: 44px 102px minmax(70px, 1fr) 18px;
  gap: 0 16px;
}

.boutique-reserve {
  min-height: 474px;
  padding: 64px 28px 82px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.9) 0%, rgba(255, 253, 248, 0.78) 42%, rgba(255, 253, 248, 0.94) 100%),
    url("./assets/photos/reservation-preparation-v1.webp") center bottom / 128% auto no-repeat;
}

.boutique-reserve::before {
  content: "";
  position: absolute;
  left: 22px;
  bottom: 52px;
  z-index: 1;
  width: 84px;
  height: 118px;
  border-radius: 999px 999px 12px 12px;
  background: url("./assets/photos/boutique-room-arch-v1.webp") 48% 48% / cover no-repeat;
  opacity: 0.86;
  box-shadow: 0 18px 36px rgba(64, 50, 32, 0.12);
}

.boutique-reserve::after {
  content: "";
  position: absolute;
  right: -10px;
  bottom: 66px;
  z-index: 1;
  width: 96px;
  height: 112px;
  border-radius: 90px 0 0 90px;
  background: url("./assets/photos/boutique-hero-treatment-v1.webp") 52% 58% / cover no-repeat;
  opacity: 0.48;
}

.boutique-reserve > .boutique-script-ghost {
  top: 106px;
  left: 12px;
  font-size: clamp(9rem, 50vw, 12.5rem);
  color: rgba(176, 139, 86, 0.085);
}

.boutique-reserve-copy {
  z-index: 2;
  padding-top: 86px;
}

.boutique-reserve h2 {
  font-size: clamp(2.06rem, 9.2vw, 2.74rem);
}

.boutique-reserve-button {
  min-width: 268px;
  min-height: 58px;
  background: linear-gradient(180deg, #8b967f 0%, #697563 100%);
  box-shadow: 0 22px 46px rgba(83, 93, 76, 0.22);
}

@media (min-width: 861px) {
  .boutique-hero-photo {
    right: 2vw;
    width: min(43vw, 550px);
    height: 640px;
  }

  .boutique-hero-copy {
    top: 196px;
  }

  .boutique-treatment {
    min-height: 430px;
    background:
      linear-gradient(90deg, rgba(130, 142, 124, 0.86), rgba(166, 176, 160, 0.76)),
      url("./assets/photos/reservation-preparation-v1.webp") 94% 42% / 340px auto no-repeat;
  }

  .boutique-reserve {
    background:
      linear-gradient(180deg, rgba(255, 253, 248, 0.88), rgba(255, 253, 248, 0.96)),
      url("./assets/photos/reservation-preparation-v1.webp") center 76% / cover no-repeat;
  }
}

/* Generated asset integration v3 */
.boutique-hero {
  min-height: 726px;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.88) 0 48%, rgba(255, 253, 248, 0.34) 70%, rgba(255, 253, 248, 0.08) 100%),
    #fbf7ef;
}

.boutique-hero::after {
  display: none;
}

.boutique-hero > .boutique-script-ghost {
  top: 108px;
  left: 118px;
  z-index: 2;
  color: rgba(176, 139, 86, 0.095);
}

.boutique-hero-photo {
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 726px;
  border-radius: 0;
  box-shadow: none;
  opacity: 1;
}

.boutique-hero-photo::before {
  background:
    linear-gradient(90deg, rgba(251, 247, 239, 0.82) 0 40%, rgba(251, 247, 239, 0.38) 58%, rgba(251, 247, 239, 0.04) 100%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.28), transparent 54%, rgba(251, 247, 239, 0.2));
}

.boutique-hero-photo img {
  object-position: 53% 45%;
}

.boutique-hero-copy {
  top: 190px;
  left: 48px;
}

.boutique-hero-location {
  color: rgba(39, 38, 34, 0.7);
}

.boutique-treatment {
  min-height: 430px;
  padding-top: 54px;
  background:
    linear-gradient(90deg, rgba(127, 139, 121, 0.9) 0%, rgba(145, 158, 139, 0.76) 48%, rgba(145, 158, 139, 0.46) 100%),
    url("./assets/photos/boutique-treatment-still-v2.webp") 73% 50% / auto 100% no-repeat;
}

.boutique-treatment-copy p {
  color: rgba(255, 253, 248, 0.84);
}

.boutique-treatment-photo {
  display: none;
}

.boutique-menu-lines {
  padding-right: 6px;
}

.boutique-reserve {
  min-height: 456px;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.74), rgba(255, 253, 248, 0.4) 42%, rgba(255, 253, 248, 0.7)),
    linear-gradient(180deg, rgba(255, 253, 248, 0.72), rgba(255, 253, 248, 0.96)),
    url("./assets/photos/boutique-reserve-cta-v2.webp") center bottom / cover no-repeat;
}

.boutique-reserve::before,
.boutique-reserve::after {
  display: none;
}

.boutique-reserve > .boutique-script-ghost {
  left: 8px;
  color: rgba(176, 139, 86, 0.075);
}

.boutique-reserve-copy {
  padding-top: 74px;
}

.boutique-reserve-button {
  background: linear-gradient(180deg, #8f9a85 0%, #68735f 100%);
}

@media (min-width: 861px) {
  .boutique-hero {
    min-height: 820px;
  }

  .boutique-hero-photo {
    inset: 0;
    width: 100%;
    height: 820px;
  }

  .boutique-hero-copy {
    top: 220px;
  }

  .boutique-treatment {
    min-height: 430px;
    background:
      linear-gradient(90deg, rgba(127, 139, 121, 0.9) 0%, rgba(145, 158, 139, 0.72) 45%, rgba(145, 158, 139, 0.36) 100%),
      url("./assets/photos/boutique-treatment-still-v2.webp") 86% 50% / auto 100% no-repeat;
  }

  .boutique-reserve {
    background:
      linear-gradient(90deg, rgba(255, 253, 248, 0.78), rgba(255, 253, 248, 0.42), rgba(255, 253, 248, 0.78)),
      url("./assets/photos/boutique-reserve-cta-v2.webp") center 58% / cover no-repeat;
  }
}

/* Unified boutique subpages */
.subpage-body {
  --bt-ivory: #f7f1e8;
  --bt-paper: #fffdf8;
  --bt-ink: #292722;
  --bt-muted: rgba(41, 39, 34, 0.66);
  --bt-sage: #7f8b79;
  --bt-sage-dark: #68735f;
  --bt-brass: #aa8653;
  min-height: 100vh;
  color: var(--bt-ink);
  background:
    linear-gradient(90deg, rgba(170, 134, 83, 0.08) 0 1px, transparent 1px) 7vw 0 / 1px 100% no-repeat,
    linear-gradient(180deg, #f8f1e8 0%, #fffaf4 52%, #eee8dd 100%);
}

.subpage-body .site-header {
  background: rgba(247, 241, 232, 0.84);
  border-bottom: 1px solid rgba(170, 134, 83, 0.16);
}

.subpage-main {
  padding: 124px 0 0;
}

.subpage-hero,
.subpage-section {
  width: min(430px, 100vw);
  margin: 0 auto;
  padding-inline: 20px;
}

.subpage-hero {
  position: relative;
  display: grid;
  gap: 28px;
  padding-bottom: 70px;
}

.subpage-hero::before {
  content: "Veilo";
  position: absolute;
  top: 18px;
  right: 14px;
  z-index: 0;
  color: rgba(176, 139, 86, 0.1);
  font-family: "Parisienne", cursive;
  font-size: clamp(5.4rem, 26vw, 9rem);
  line-height: 1;
  pointer-events: none;
}

.subpage-hero-copy {
  position: relative;
  z-index: 1;
}

.subpage-kicker {
  color: var(--bt-brass);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.subpage-hero h1,
.subpage-heading h2,
.note-band h2 {
  margin: 0;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  letter-spacing: 0;
}

.subpage-hero h1 {
  max-width: 720px;
  font-size: clamp(2.08rem, 9vw, 3.7rem);
  line-height: 1.22;
}

.subpage-lead,
.subpage-heading p,
.subpage-card p,
.price-card p,
.faq-item p,
.note-band p {
  color: var(--bt-muted);
  line-height: 1.86;
}

.subpage-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.subpage-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(170, 134, 83, 0.3);
  font-size: 0.88rem;
  font-weight: 800;
}

.subpage-button-primary {
  background: linear-gradient(180deg, #8f9a85 0%, #68735f 100%);
  color: #fffaf4;
  box-shadow: 0 16px 32px rgba(52, 43, 31, 0.14);
}

.subpage-button-secondary {
  background: rgba(255, 252, 246, 0.72);
  color: var(--bt-ink);
}

.subpage-hero-media {
  position: relative;
  z-index: 1;
  width: min(250px, 68vw);
  justify-self: end;
}

.subpage-hero-media img {
  width: 100%;
  aspect-ratio: 0.58 / 1;
  height: auto;
  min-height: 342px;
  border-radius: 999px;
  object-fit: cover;
  box-shadow: 0 28px 64px rgba(52, 43, 31, 0.16);
}

.subpage-section {
  padding-block: 54px;
  border-top: 1px solid rgba(170, 134, 83, 0.24);
}

.subpage-heading {
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}

.subpage-heading h2 {
  font-size: clamp(1.55rem, 7vw, 2.45rem);
  line-height: 1.35;
}

.subpage-grid,
.subpage-grid-two {
  display: grid;
  gap: 14px;
}

.price-card,
.subpage-card,
.faq-item {
  min-width: 0;
  padding: 22px 0;
  border-top: 1px solid rgba(170, 134, 83, 0.22);
  background: transparent;
  box-shadow: none;
}

.price-card:first-child,
.subpage-card:first-child,
.faq-item:first-child {
  border-top-color: rgba(170, 134, 83, 0.34);
}

.price-card-featured {
  padding: 24px 20px;
  border: 1px solid rgba(170, 134, 83, 0.32);
  border-radius: 26px;
  background:
    linear-gradient(135deg, rgba(255, 252, 246, 0.92), rgba(224, 229, 220, 0.72));
}

.price-card h3,
.subpage-card h3,
.faq-item h3 {
  margin: 0 0 10px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.12rem;
  line-height: 1.45;
}

.price-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin: 18px 0 8px;
}

.price-main {
  color: var(--bt-sage-dark);
  font-family: "Cormorant Garamond", serif;
  font-size: 2.05rem;
  font-weight: 600;
  line-height: 1;
}

.price-sub {
  color: var(--bt-brass);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.14em;
}

.flow-list {
  display: grid;
  gap: 0;
  margin-top: 28px;
}

.flow-step {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 16px;
  padding: 20px 0;
  border-top: 1px solid rgba(170, 134, 83, 0.22);
  background: transparent;
  box-shadow: none;
}

.flow-number {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(170, 134, 83, 0.36);
  color: var(--bt-brass);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.14rem;
  font-weight: 600;
}

.flow-step h3 {
  margin: 0 0 8px;
}

.note-band {
  padding: 28px 0;
  border-top: 1px solid rgba(170, 134, 83, 0.34);
  border-bottom: 1px solid rgba(170, 134, 83, 0.34);
}

.site-footer {
  width: min(1120px, calc(100vw - 40px));
  margin-inline: auto;
  color: rgba(41, 39, 34, 0.64);
}

.site-footer .text-link,
.footer-links .text-link {
  color: var(--bt-sage-dark);
}

.legal-page {
  --bt-ivory: #f7f1e8;
  --bt-paper: #fffdf8;
  --bt-ink: #292722;
  --bt-muted: rgba(41, 39, 34, 0.66);
  --bt-sage-dark: #68735f;
  --bt-brass: #aa8653;
  color: var(--bt-ink);
  background:
    linear-gradient(90deg, rgba(170, 134, 83, 0.08) 0 1px, transparent 1px) 7vw 0 / 1px 100% no-repeat,
    linear-gradient(180deg, #f8f1e8 0%, #fffaf4 52%, #eee8dd 100%);
}

.legal-wrap,
.guide-wrap {
  width: min(980px, calc(100vw - 40px));
  max-width: none;
  padding: 94px 0 80px;
}

.guide-wrap > .text-link:first-child,
.legal-wrap > .text-link:first-child {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid rgba(170, 134, 83, 0.28);
  border-radius: 999px;
  background: rgba(255, 252, 246, 0.74);
  color: var(--bt-sage-dark);
  font-size: 0.86rem;
  font-weight: 800;
}

.guide-page .eyebrow,
.legal-page .eyebrow,
.mini-label {
  color: var(--bt-brass);
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  letter-spacing: 0.18em;
}

.guide-page h1,
.legal-page h1 {
  max-width: 820px;
  margin: 22px 0 18px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: clamp(2rem, 8vw, 3.6rem);
  line-height: 1.24;
  letter-spacing: 0;
}

.guide-page .lead,
.legal-page .lead {
  max-width: 760px;
  color: var(--bt-muted);
  line-height: 1.88;
}

.guide-link-grid {
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: 42px;
  border-top: 1px solid rgba(170, 134, 83, 0.28);
}

.guide-link-card,
.legal-stack .policy-card {
  padding: 24px 0;
  border: 0;
  border-bottom: 1px solid rgba(170, 134, 83, 0.22);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.guide-link-card h3,
.legal-stack .policy-card h3 {
  margin: 0 0 12px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.18rem;
  line-height: 1.45;
}

.guide-link-card p,
.legal-stack .policy-card p {
  color: var(--bt-muted);
  line-height: 1.86;
}

.guide-page .text-link,
.legal-page .text-link {
  color: var(--bt-sage-dark);
  font-weight: 800;
}

.guide-links {
  gap: 10px;
  margin-top: 30px;
}

.guide-links .text-link {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 14px;
  border: 1px solid rgba(170, 134, 83, 0.24);
  border-radius: 999px;
  background: rgba(255, 252, 246, 0.66);
}

@media (min-width: 861px) {
  .subpage-hero,
  .subpage-section {
    width: min(1120px, calc(100vw - 64px));
    padding-inline: 0;
  }

  .subpage-hero {
    grid-template-columns: minmax(0, 0.86fr) minmax(300px, 0.42fr);
    align-items: center;
    min-height: 640px;
    padding-top: 44px;
  }

  .subpage-hero::before {
    left: 32%;
    right: auto;
    top: 94px;
    font-size: 11rem;
  }

  .subpage-hero-media {
    width: min(310px, 100%);
    justify-self: center;
  }

  .subpage-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
  }

  .subpage-grid-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 32px;
  }

  .flow-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0 42px;
  }

  .guide-link-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 32px;
    border-top: 0;
  }

  .guide-link-card {
    border-top: 1px solid rgba(170, 134, 83, 0.28);
  }
}

@media (max-width: 420px) {
  .subpage-main {
    padding-top: 112px;
  }

  .subpage-actions {
    display: grid;
  }

  .subpage-button {
    width: 100%;
  }

  .subpage-hero-media {
    width: min(216px, 64vw);
  }

  .subpage-hero-media img {
    min-height: 310px;
  }
}

/* TOP editorial HP polish */
.home-body {
  --bt-deep: #343a31;
  --bt-line: rgba(170, 134, 83, 0.28);
}

.boutique-hero {
  min-height: 760px;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(251, 247, 239, 0.96) 0 38%, rgba(251, 247, 239, 0.62) 57%, rgba(251, 247, 239, 0.05) 100%),
    #fbf7ef;
}

.boutique-hero::before {
  left: 28px;
  top: 155px;
  width: 1px;
  height: 202px;
  background: rgba(170, 134, 83, 0.42);
}

.boutique-hero > .boutique-script-ghost {
  top: 112px;
  left: 126px;
  color: rgba(170, 134, 83, 0.08);
  transform: rotate(-10deg);
}

.boutique-hero-photo {
  height: 760px;
}

.boutique-hero-photo::before {
  background:
    linear-gradient(90deg, rgba(251, 247, 239, 0.9) 0 35%, rgba(251, 247, 239, 0.48) 57%, rgba(251, 247, 239, 0.02) 100%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.16), transparent 44%, rgba(251, 247, 239, 0.35));
}

.boutique-hero-photo::after {
  content: "";
  position: absolute;
  left: 30px;
  bottom: 34px;
  z-index: 2;
  width: 118px;
  height: 1px;
  border: 0;
  border-radius: 0;
  background: rgba(170, 134, 83, 0.44);
}

.boutique-hero-photo img {
  object-position: 56% 45%;
}

.boutique-hero-copy {
  top: 178px;
  left: clamp(34px, 9vw, 58px);
  width: min(322px, calc(100% - 68px));
}

.boutique-hero h1 {
  width: auto;
  max-width: 318px;
  font-size: clamp(2.08rem, 8.8vw, 2.9rem);
  line-height: 1.34;
  letter-spacing: 0;
}

.boutique-hero h1 span {
  display: block;
  white-space: nowrap;
}

.boutique-hero-copy p:last-of-type {
  max-width: 236px;
  color: rgba(39, 38, 34, 0.7);
  font-size: 0.82rem;
  line-height: 1.92;
}

.boutique-hero-links {
  gap: 24px;
  align-items: center;
  margin-top: 28px;
}

.boutique-hero-links a {
  min-width: auto;
  letter-spacing: 0.03em;
}

.boutique-hero-links a:first-child {
  min-height: 40px;
  padding: 0 16px;
  border: 1px solid rgba(170, 134, 83, 0.36);
  border-radius: 999px;
  background: rgba(255, 253, 248, 0.58);
  box-shadow: 0 14px 34px rgba(52, 43, 31, 0.1);
}

.boutique-hero-links a:first-child::after {
  width: 22px;
}

.boutique-index {
  position: relative;
  padding: 34px 24px 86px 88px;
  background:
    linear-gradient(90deg, transparent 0 48px, rgba(170, 134, 83, 0.16) 48px 49px, transparent 49px),
    linear-gradient(180deg, rgba(255, 253, 248, 0.94), rgba(255, 253, 248, 0.82));
}

.boutique-index::before {
  left: 28px;
  top: 42px;
  color: rgba(170, 134, 83, 0.86);
}

.boutique-index::after {
  left: 36px;
  top: 146px;
  height: 112px;
  background: rgba(170, 134, 83, 0.28);
}

.boutique-index a {
  grid-template-columns: 40px minmax(0, 1fr) 34px;
  gap: 6px 16px;
  padding: 17px 0;
}

.boutique-index a:nth-child(2) {
  margin-left: 26px;
}

.boutique-index a:nth-child(3) {
  margin-left: 6px;
}

.boutique-index a:nth-child(4) {
  margin-left: 42px;
}

.boutique-index a::before {
  grid-column: 3;
  align-self: center;
  width: 100%;
  height: 1px;
  background: rgba(170, 134, 83, 0.38);
}

.boutique-index a::after {
  content: "→";
  grid-column: 3;
  grid-row: 1 / span 2;
  align-self: center;
  justify-self: end;
  width: auto;
  height: auto;
  background: transparent;
  color: rgba(39, 38, 34, 0.76);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.15rem;
}

.boutique-index span {
  font-size: 1.22rem;
}

.boutique-index strong {
  font-size: 1.28rem;
}

.boutique-index small {
  grid-column: 2;
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}

.boutique-concept {
  padding-top: 76px;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.96), rgba(250, 246, 239, 0.9)),
    radial-gradient(circle at 92% 70%, rgba(141, 152, 137, 0.18), transparent 28%);
}

.boutique-concept-copy h2 {
  max-width: 320px;
}

.boutique-concept-photo {
  border-radius: 24px 148px 24px 148px;
}

.boutique-treatment {
  min-height: 492px;
  padding-top: 68px;
  background:
    linear-gradient(90deg, rgba(52, 58, 49, 0.94) 0%, rgba(74, 86, 68, 0.82) 50%, rgba(74, 86, 68, 0.48) 100%),
    url("./assets/photos/subpage-menu-boutique-v1.webp") 78% 50% / auto 105% no-repeat;
}

.boutique-treatment::before {
  border-color: rgba(255, 253, 248, 0.42);
}

.boutique-treatment h2,
.boutique-treatment .boutique-kicker,
.boutique-treatment .boutique-inline-link,
.boutique-treatment h2 span {
  color: #fffdf8;
}

.boutique-treatment-copy p {
  color: rgba(255, 253, 248, 0.82);
}

.boutique-menu-lines {
  margin-top: 20px;
}

.boutique-menu-lines a {
  border-color: rgba(255, 253, 248, 0.22);
}

.boutique-menu-lines strong,
.boutique-menu-lines small {
  color: rgba(255, 253, 248, 0.86);
}

.boutique-access {
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.94), rgba(246, 239, 229, 0.9));
}

.boutique-access-photo {
  width: 154px;
  height: 214px;
  border-radius: 88px 88px 18px 18px;
}

.boutique-guide-links {
  padding-top: 18px;
  background: rgba(255, 253, 248, 0.84);
}

.boutique-guide-links a {
  border-color: rgba(170, 134, 83, 0.28);
}

.boutique-guide-links a:first-child {
  width: 92%;
}

.boutique-guide-links a:nth-child(2) {
  width: 78%;
}

.boutique-reserve {
  min-height: 532px;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.9) 0%, rgba(255, 253, 248, 0.7) 44%, rgba(255, 253, 248, 0.28) 100%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.72), rgba(255, 253, 248, 0.92)),
    url("./assets/photos/subpage-reserve-boutique-v1.webp") 68% 58% / cover no-repeat;
}

.boutique-reserve-copy {
  width: min(318px, 100%);
  margin-left: 0;
  padding-top: 122px;
}

@media (max-width: 420px) {
  .boutique-hero {
    min-height: 740px;
  }

  .boutique-hero-location {
    margin-right: 58px;
    font-size: 0.62rem;
    letter-spacing: 0.16em;
  }

  .boutique-hero-photo {
    height: 740px;
  }

  .boutique-hero-copy {
    left: 34px;
    width: min(304px, calc(100% - 64px));
  }

  .boutique-hero h1 {
    font-size: clamp(2rem, 8.6vw, 2.34rem);
    max-width: 286px;
  }

  .boutique-index {
    padding-left: 76px;
  }

  .boutique-index a:nth-child(4) {
    margin-left: 30px;
  }
}

@media (min-width: 861px) {
  .boutique-hero {
    min-height: 820px;
  }

  .boutique-hero-photo {
    height: 820px;
  }

  .boutique-hero-copy {
    top: 214px;
    left: clamp(64px, 9vw, 112px);
    width: 560px;
  }

  .boutique-hero h1 {
    max-width: 560px;
    font-size: clamp(4.3rem, 6.5vw, 6rem);
    line-height: 1.08;
  }

  .boutique-hero-copy p:last-of-type {
    max-width: 390px;
    font-size: 0.94rem;
  }

  .boutique-index {
    grid-template-columns: 0.94fr 1.08fr 0.94fr 1.02fr;
    padding: 54px 42px 108px 108px;
  }

  .boutique-index a:nth-child(n) {
    margin-left: 0;
  }

  .boutique-index a:nth-child(2),
  .boutique-index a:nth-child(4) {
    margin-top: 42px;
  }

  .boutique-treatment {
    background:
      linear-gradient(90deg, rgba(52, 58, 49, 0.94) 0%, rgba(74, 86, 68, 0.84) 44%, rgba(74, 86, 68, 0.28) 100%),
      url("./assets/photos/subpage-menu-boutique-v1.webp") 88% 50% / auto 118% no-repeat;
  }

  .boutique-access-photo {
    width: auto;
    height: 480px;
  }

  .boutique-reserve {
    background:
      linear-gradient(90deg, rgba(255, 253, 248, 0.92) 0%, rgba(255, 253, 248, 0.76) 46%, rgba(255, 253, 248, 0.18) 100%),
      url("./assets/photos/subpage-reserve-boutique-v1.webp") 76% 56% / cover no-repeat;
  }

  .boutique-reserve-copy {
    margin-left: 7vw;
  }
}

/* TOP lower-page entrance v2 */
.boutique-index {
  display: grid;
  gap: 0;
  padding: 42px 22px 96px 70px;
  background:
    linear-gradient(90deg, transparent 0 38px, rgba(170, 134, 83, 0.2) 38px 39px, transparent 39px),
    linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(248, 242, 232, 0.78));
}

.boutique-index::before {
  left: 22px;
  top: 54px;
}

.boutique-index::after {
  left: 30px;
  top: 176px;
  height: 154px;
}

.boutique-index-link {
  min-height: 118px;
  grid-template-columns: 34px 74px minmax(0, 1fr) 24px;
  align-items: center;
  gap: 0 14px;
  padding: 18px 0;
  border-top: 1px solid rgba(170, 134, 83, 0.25);
}

.boutique-index-link:nth-child(2),
.boutique-index-link:nth-child(3),
.boutique-index-link:nth-child(4) {
  margin-left: 0;
}

.boutique-index-link:nth-child(2) {
  transform: translateX(24px);
}

.boutique-index-link:nth-child(3) {
  transform: translateX(-8px);
}

.boutique-index-link:nth-child(4) {
  transform: translateX(36px);
  border-bottom: 1px solid rgba(170, 134, 83, 0.25);
}

.boutique-index-link::before {
  display: none;
}

.boutique-index-link::after {
  grid-column: 4;
  grid-row: 1;
  color: rgba(39, 38, 34, 0.68);
}

.boutique-index-number {
  grid-column: 1;
  grid-row: 1;
  align-self: start;
  padding-top: 8px;
  font-size: 1.04rem;
}

.boutique-index-thumb {
  grid-column: 2;
  grid-row: 1;
  width: 74px;
  height: 92px;
  margin: 0;
  overflow: hidden;
  border-radius: 999px 999px 12px 12px;
  box-shadow: 0 18px 34px rgba(52, 43, 31, 0.12);
}

.boutique-index-link:nth-child(even) .boutique-index-thumb {
  height: 76px;
  border-radius: 16px 999px 999px 16px;
}

.boutique-index-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.boutique-index-link-menu .boutique-index-thumb img {
  object-position: 48% 58%;
}

.boutique-index-link-first .boutique-index-thumb img {
  object-position: 44% 58%;
}

.boutique-index-link-access .boutique-index-thumb img {
  object-position: 52% 44%;
}

.boutique-index-link-faq .boutique-index-thumb img {
  object-position: 50% 58%;
}

.boutique-index-text {
  grid-column: 3;
  grid-row: 1;
  min-width: 0;
}

.boutique-index-text strong {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.48rem;
  font-style: italic;
  font-weight: 600;
  line-height: 1.05;
}

.boutique-index-text small {
  display: block;
  margin-top: 6px;
  color: rgba(41, 39, 34, 0.54);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  line-height: 1.5;
}

.boutique-treatment {
  clip-path: polygon(0 4%, 100% 0, 100% 96%, 0 100%);
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.18), rgba(255, 253, 248, 0) 22%),
    linear-gradient(90deg, rgba(64, 73, 59, 0.9) 0%, rgba(86, 101, 79, 0.78) 48%, rgba(86, 101, 79, 0.34) 100%),
    url("./assets/photos/subpage-menu-boutique-v1.webp") 80% 50% / auto 105% no-repeat;
}

.boutique-treatment::after {
  content: "";
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 28px;
  height: 1px;
  background: rgba(255, 253, 248, 0.2);
}

.boutique-reserve {
  min-height: 568px;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.94) 0%, rgba(255, 253, 248, 0.74) 42%, rgba(255, 253, 248, 0.22) 100%),
    url("./assets/photos/subpage-reserve-boutique-v1.webp") 68% 56% / cover no-repeat;
}

.boutique-reserve-calendar {
  position: absolute;
  right: 20px;
  top: 92px;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 10px);
  gap: 8px;
  padding: 18px;
  border: 1px solid rgba(170, 134, 83, 0.25);
  border-radius: 28px 28px 10px 28px;
  background: rgba(255, 253, 248, 0.64);
  box-shadow: 0 22px 48px rgba(52, 43, 31, 0.12);
  backdrop-filter: blur(10px);
}

.boutique-reserve-calendar span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(170, 134, 83, 0.34);
}

.boutique-reserve-calendar span:nth-child(3),
.boutique-reserve-calendar span:nth-child(7),
.boutique-reserve-calendar span:nth-child(10) {
  background: rgba(104, 115, 95, 0.76);
}

.boutique-reserve-copy {
  padding-top: 156px;
}

@media (max-width: 420px) {
  .boutique-index {
    padding-left: 64px;
    padding-right: 18px;
  }

  .boutique-index-link {
    grid-template-columns: 30px 66px minmax(0, 1fr) 20px;
    gap: 0 12px;
    min-height: 108px;
  }

  .boutique-index-link:nth-child(2) {
    transform: translateX(16px);
  }

  .boutique-index-link:nth-child(4) {
    transform: translateX(18px);
  }

  .boutique-index-thumb {
    width: 66px;
    height: 82px;
  }

  .boutique-index-link:nth-child(even) .boutique-index-thumb {
    height: 70px;
  }

  .boutique-index-text strong {
    font-size: 1.34rem;
  }

  .boutique-reserve-calendar {
    right: 16px;
    top: 76px;
    grid-template-columns: repeat(4, 9px);
    gap: 7px;
    padding: 15px;
  }
}

@media (min-width: 861px) {
  .boutique-index {
    grid-template-columns: 1.05fr 0.96fr 1.08fr 0.92fr;
    gap: 28px;
    padding: 64px 46px 116px 116px;
  }

  .boutique-index-link {
    display: grid;
    min-height: 246px;
    grid-template-columns: 36px minmax(0, 1fr) 24px;
    grid-template-rows: auto 1fr;
    align-items: start;
    padding: 18px 0 0;
  }

  .boutique-index-link:nth-child(n) {
    transform: none;
  }

  .boutique-index-link:nth-child(2),
  .boutique-index-link:nth-child(4) {
    margin-top: 56px;
  }

  .boutique-index-thumb {
    grid-column: 2 / 4;
    grid-row: 2;
    align-self: end;
    width: 100%;
    height: 138px;
    margin-top: 22px;
    border-radius: 999px 999px 12px 12px;
  }

  .boutique-index-link:nth-child(even) .boutique-index-thumb {
    height: 112px;
    border-radius: 18px 999px 999px 18px;
  }

  .boutique-index-text {
    grid-column: 2;
    grid-row: 1;
  }

  .boutique-treatment {
    background:
      linear-gradient(180deg, rgba(255, 253, 248, 0.16), rgba(255, 253, 248, 0) 22%),
      linear-gradient(90deg, rgba(64, 73, 59, 0.9) 0%, rgba(86, 101, 79, 0.76) 44%, rgba(86, 101, 79, 0.22) 100%),
      url("./assets/photos/subpage-menu-boutique-v1.webp") 88% 50% / auto 116% no-repeat;
  }

  .boutique-reserve-calendar {
    right: clamp(72px, 12vw, 160px);
    top: 120px;
    transform: rotate(4deg);
  }
}

/* Boutique17 final alignment */
.home-body .page-shell::before,
.home-body .page-shell::after {
  opacity: 0.55;
}

.boutique-index {
  isolation: isolate;
  padding: 32px 18px 66px 56px;
  background:
    linear-gradient(90deg, transparent 0 31px, rgba(170, 134, 83, 0.24) 31px 32px, transparent 32px),
    repeating-linear-gradient(135deg, rgba(170, 134, 83, 0.055) 0 1px, transparent 1px 18px),
    linear-gradient(180deg, rgba(255, 253, 248, 0.99), rgba(248, 242, 232, 0.78));
}

.boutique-index::before {
  left: 16px;
  top: 34px;
  color: rgba(170, 134, 83, 0.88);
  font-size: 0.62rem;
}

.boutique-index::after {
  left: 24px;
  top: 124px;
  height: 124px;
  background: rgba(170, 134, 83, 0.3);
}

.boutique-index-link {
  min-height: 88px;
  grid-template-columns: 27px 52px minmax(0, 1fr) 18px;
  gap: 0 10px;
  padding: 11px 0;
  border-top-color: rgba(170, 134, 83, 0.24);
}

.boutique-index-link:nth-child(2) {
  transform: translateX(10px);
}

.boutique-index-link:nth-child(3) {
  transform: translateX(-4px);
}

.boutique-index-link:nth-child(4) {
  transform: translateX(14px);
  border-bottom-color: rgba(170, 134, 83, 0.24);
}

.boutique-index-number {
  padding-top: 6px;
  font-size: 0.88rem;
}

.boutique-index-thumb {
  width: 52px;
  height: 66px;
  border-radius: 999px 999px 10px 10px;
  box-shadow: 0 14px 26px rgba(52, 43, 31, 0.11);
}

.boutique-index-link:nth-child(even) .boutique-index-thumb {
  height: 54px;
  border-radius: 12px 999px 999px 12px;
}

.boutique-index-text strong {
  font-size: 1.14rem;
  line-height: 1.02;
}

.boutique-index-text small {
  margin-top: 4px;
  color: rgba(41, 39, 34, 0.62);
  font-size: 0.67rem;
  letter-spacing: 0.02em;
  line-height: 1.42;
}

.boutique-index-link-menu .boutique-index-number,
.menu-body .subpage-kicker {
  color: #a87f49;
}

.boutique-index-link-first .boutique-index-number,
.guide-body .subpage-kicker {
  color: #7a886f;
}

.boutique-index-link-access .boutique-index-number,
.access-body .subpage-kicker {
  color: #9a8465;
}

.boutique-index-link-faq .boutique-index-number,
.faq-body .subpage-kicker {
  color: #6e7768;
}

.boutique-treatment {
  color: var(--bt-ink);
  clip-path: polygon(0 3%, 100% 0, 100% 97%, 0 100%);
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.52), rgba(255, 253, 248, 0) 26%, rgba(255, 253, 248, 0.2) 100%),
    linear-gradient(90deg, rgba(239, 241, 233, 0.98) 0%, rgba(212, 221, 206, 0.9) 48%, rgba(212, 221, 206, 0.36) 100%),
    url("./assets/photos/subpage-menu-boutique-v1.webp") 82% 50% / auto 103% no-repeat;
}

.boutique-treatment::before {
  border-color: rgba(170, 134, 83, 0.34);
}

.boutique-treatment::after {
  background: rgba(170, 134, 83, 0.24);
}

.boutique-treatment h2,
.boutique-treatment h2 span,
.boutique-treatment .boutique-inline-link {
  color: var(--bt-ink);
}

.boutique-treatment .boutique-kicker {
  color: var(--bt-brass);
}

.boutique-treatment-copy p,
.boutique-treatment .boutique-menu-lines strong,
.boutique-treatment .boutique-menu-lines small {
  color: rgba(41, 39, 34, 0.7);
}

.boutique-treatment .boutique-inline-link::after {
  background: rgba(170, 134, 83, 0.7);
}

.boutique-reserve {
  min-height: 552px;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.96) 0%, rgba(255, 253, 248, 0.78) 42%, rgba(255, 253, 248, 0.28) 100%),
    url("./assets/photos/subpage-reserve-boutique-v1.webp") 70% 56% / cover no-repeat;
}

.boutique-reserve-calendar {
  right: 18px;
  top: 74px;
  grid-template-columns: repeat(7, 7px);
  gap: 6px;
  width: auto;
  padding: 14px;
  border-radius: 18px 18px 8px 18px;
  background: rgba(255, 253, 248, 0.76);
  box-shadow: 0 18px 38px rgba(52, 43, 31, 0.12);
}

.boutique-reserve-calendar span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(41, 39, 34, 0.18);
}

.boutique-reserve-calendar .reserve-calendar-head {
  grid-column: 1 / -1;
  width: auto;
  height: 6px;
  margin-bottom: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(170, 134, 83, 0.56), rgba(104, 115, 95, 0.5));
}

.boutique-reserve-calendar .reserve-calendar-dot.is-open {
  background: rgba(104, 115, 95, 0.8);
  box-shadow: 0 0 0 3px rgba(104, 115, 95, 0.1);
}

.boutique-reserve-calendar .reserve-calendar-slot {
  grid-column: span 2;
  width: auto;
  height: 16px;
  margin-top: 4px;
  border-radius: 999px;
  background: rgba(170, 134, 83, 0.22);
}

.boutique-reserve-calendar .reserve-calendar-slot.is-open {
  grid-column: span 3;
  background: rgba(104, 115, 95, 0.72);
}

.boutique-reserve-copy {
  padding-top: 138px;
}

.menu-body .subpage-hero::before {
  content: "Menu";
}

.guide-body .subpage-hero::before {
  content: "First";
}

.access-body .subpage-hero::before {
  content: "Access";
}

.faq-body .subpage-hero::before {
  content: "FAQ";
}

.menu-body .subpage-hero-media img {
  border-radius: 999px 999px 26px 26px;
  object-position: 48% 58%;
}

.guide-body .subpage-hero-media {
  justify-self: start;
}

.guide-body .subpage-hero-media img {
  border-radius: 28px 999px 999px 28px;
  object-position: 44% 58%;
}

.access-body .subpage-hero-media img {
  border-radius: 34px 34px 120px 34px;
  object-position: 52% 44%;
}

.faq-body .subpage-hero-media {
  width: min(280px, 72vw);
}

.faq-body .subpage-hero-media img {
  aspect-ratio: 0.72 / 1;
  border-radius: 28px;
  object-position: 50% 58%;
}

.menu-body .price-card-featured {
  background:
    linear-gradient(135deg, rgba(255, 252, 246, 0.94), rgba(229, 224, 214, 0.76)),
    repeating-linear-gradient(135deg, rgba(170, 134, 83, 0.06) 0 1px, transparent 1px 18px);
  border-radius: 18px 18px 52px 18px;
}

.guide-body .flow-step {
  position: relative;
  grid-template-columns: 34px 1fr;
  gap: 14px;
}

.guide-body .flow-step::after {
  content: "";
  position: absolute;
  left: 17px;
  top: 58px;
  bottom: -1px;
  width: 1px;
  background: rgba(170, 134, 83, 0.22);
}

.guide-body .flow-step:nth-last-child(1)::after {
  display: none;
}

.access-body .subpage-grid .subpage-card {
  padding-left: 18px;
  border-left: 1px solid rgba(170, 134, 83, 0.3);
}

.access-body .note-band {
  position: relative;
  padding-left: 22px;
}

.access-body .note-band::before {
  content: "";
  position: absolute;
  left: 0;
  top: 30px;
  bottom: 30px;
  border-left: 1px dashed rgba(170, 134, 83, 0.52);
}

.faq-body .subpage-grid-two {
  gap: 0;
  border-top: 1px solid rgba(170, 134, 83, 0.26);
}

.faq-body .faq-item {
  position: relative;
  padding-left: 42px;
  border-top: 0;
  border-bottom: 1px solid rgba(170, 134, 83, 0.2);
}

.faq-body .faq-item::before {
  content: "Q";
  position: absolute;
  left: 0;
  top: 24px;
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border: 1px solid rgba(170, 134, 83, 0.32);
  border-radius: 50%;
  color: var(--bt-brass);
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
}

.reserve-hero {
  position: relative;
}

.reserve-hero::before {
  content: "予約";
  position: absolute;
  right: 18px;
  top: -8px;
  z-index: 0;
  color: rgba(176, 139, 86, 0.12);
  font-family: "Parisienne", cursive;
  font-size: clamp(5rem, 24vw, 9rem);
  line-height: 1;
  pointer-events: none;
}

.reserve-hero-copy,
.reserve-hero-note {
  position: relative;
  z-index: 1;
}

.availability-tool {
  border-radius: 18px;
  background:
    repeating-linear-gradient(135deg, rgba(170, 134, 83, 0.045) 0 1px, transparent 1px 18px),
    linear-gradient(135deg, rgba(255, 252, 246, 0.96), rgba(239, 234, 224, 0.9));
}

.availability-controls {
  border-radius: 14px;
}

.availability-calendar,
.availability-weekdays {
  gap: 5px;
}

.availability-day {
  border-radius: 8px;
  background: rgba(255, 253, 248, 0.7);
}

.availability-day.is-selected:not(:disabled) {
  border-color: rgba(104, 115, 95, 0.86);
  background: linear-gradient(180deg, rgba(246, 249, 243, 0.96), rgba(207, 218, 200, 0.86));
}

.reserve-body .contact-form {
  border-radius: 18px;
  background: rgba(255, 252, 246, 0.92);
}

@media (max-width: 420px) {
  .boutique-index {
    padding: 28px 16px 58px 52px;
  }

  .boutique-index-link {
    min-height: 84px;
    grid-template-columns: 25px 48px minmax(0, 1fr) 16px;
    gap: 0 9px;
    padding: 10px 0;
  }

  .boutique-index-link:nth-child(2) {
    transform: translateX(6px);
  }

  .boutique-index-link:nth-child(3) {
    transform: translateX(-3px);
  }

  .boutique-index-link:nth-child(4) {
    transform: translateX(8px);
  }

  .boutique-index-thumb {
    width: 48px;
    height: 60px;
  }

  .boutique-index-link:nth-child(even) .boutique-index-thumb {
    height: 50px;
  }

  .boutique-index-text strong {
    font-size: 1.08rem;
  }

  .boutique-index-text small {
    font-size: 0.64rem;
  }

  .boutique-treatment {
    background:
      linear-gradient(180deg, rgba(255, 253, 248, 0.56), rgba(255, 253, 248, 0) 24%, rgba(255, 253, 248, 0.26) 100%),
      linear-gradient(90deg, rgba(239, 241, 233, 0.98) 0%, rgba(212, 221, 206, 0.92) 54%, rgba(212, 221, 206, 0.42) 100%),
      url("./assets/photos/subpage-menu-boutique-v1.webp") 84% 50% / auto 100% no-repeat;
  }

  .boutique-reserve-calendar {
    right: 14px;
    top: 68px;
    grid-template-columns: repeat(7, 6px);
    gap: 5px;
    padding: 12px;
  }

  .reserve-hero::before {
    right: 12px;
    top: -4px;
  }
}

@media (min-width: 861px) {
  .boutique-index {
    grid-template-columns: 1.05fr 0.96fr 1.08fr 0.92fr;
    gap: 26px;
    padding: 54px 46px 96px 108px;
  }

  .boutique-index::before {
    left: 34px;
    top: 58px;
  }

  .boutique-index::after {
    left: 42px;
    top: 162px;
    height: 146px;
  }

  .boutique-index-link {
    min-height: 214px;
    grid-template-columns: 34px minmax(0, 1fr) 22px;
    padding-top: 16px;
  }

  .boutique-index-link:nth-child(2),
  .boutique-index-link:nth-child(4) {
    margin-top: 40px;
  }

  .boutique-index-thumb {
    width: 100%;
    height: 124px;
  }

  .boutique-index-link:nth-child(even) .boutique-index-thumb {
    height: 102px;
  }

  .boutique-index-text strong {
    font-size: 1.42rem;
  }

  .boutique-index-text small {
    font-size: 0.72rem;
  }

  .boutique-treatment {
    background:
      linear-gradient(180deg, rgba(255, 253, 248, 0.42), rgba(255, 253, 248, 0) 24%, rgba(255, 253, 248, 0.14) 100%),
      linear-gradient(90deg, rgba(239, 241, 233, 0.98) 0%, rgba(212, 221, 206, 0.88) 45%, rgba(212, 221, 206, 0.22) 100%),
      url("./assets/photos/subpage-menu-boutique-v1.webp") 88% 50% / auto 112% no-repeat;
  }

  .boutique-reserve-calendar {
    right: clamp(76px, 12vw, 170px);
    top: 118px;
    transform: rotate(3deg);
  }

  .subpage-hero {
    min-height: 610px;
  }

  .guide-body .subpage-hero {
    grid-template-columns: minmax(300px, 0.42fr) minmax(0, 0.86fr);
  }

  .guide-body .subpage-hero-copy {
    grid-column: 2;
    grid-row: 1;
  }

  .guide-body .subpage-hero-media {
    grid-column: 1;
    grid-row: 1;
  }

  .faq-body .subpage-grid-two {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .reserve-hero,
  .reserve-layout {
    width: min(1120px, calc(100vw - 72px));
  }

  .reserve-layout {
    grid-template-columns: minmax(260px, 310px) minmax(0, 690px);
    gap: 54px;
  }

  .reserve-form-panel {
    max-width: none;
  }

  .reserve-side > img {
    height: 500px;
  }
}

/* Boutique17 index specificity fix */
.boutique-index .boutique-index-link {
  display: grid;
  min-height: 88px;
  grid-template-columns: 27px 52px minmax(0, 1fr) 18px;
  align-items: center;
  gap: 0 10px;
  margin-left: 0;
  padding: 11px 0;
}

.boutique-index .boutique-index-link:nth-child(2) {
  transform: translateX(10px);
}

.boutique-index .boutique-index-link:nth-child(3) {
  transform: translateX(-4px);
}

.boutique-index .boutique-index-link:nth-child(4) {
  transform: translateX(14px);
}

.boutique-index .boutique-index-link::before {
  display: none;
}

.boutique-index .boutique-index-link::after {
  grid-column: 4;
  grid-row: 1;
  align-self: center;
  justify-self: end;
}

.boutique-index .boutique-index-number {
  grid-column: 1;
  grid-row: 1;
  padding-top: 6px;
  font-size: 0.88rem;
}

.boutique-index .boutique-index-thumb {
  grid-column: 2;
  grid-row: 1;
  width: 52px;
  height: 66px;
}

.boutique-index .boutique-index-link:nth-child(even) .boutique-index-thumb {
  height: 54px;
}

.boutique-index .boutique-index-text {
  grid-column: 3;
  grid-row: 1;
  min-width: 0;
}

.boutique-index .boutique-index-text strong {
  display: block;
  font-size: 1.14rem;
  line-height: 1.04;
}

.boutique-index .boutique-index-text small {
  display: block;
  grid-column: auto;
  margin-top: 4px;
  font-size: 0.67rem;
  letter-spacing: 0.02em;
  line-height: 1.42;
}

@media (max-width: 420px) {
  .boutique-index .boutique-index-link {
    min-height: 84px;
    grid-template-columns: 25px 48px minmax(0, 1fr) 16px;
    gap: 0 9px;
    padding: 10px 0;
  }

  .boutique-index .boutique-index-link:nth-child(2) {
    transform: translateX(6px);
  }

  .boutique-index .boutique-index-link:nth-child(3) {
    transform: translateX(-3px);
  }

  .boutique-index .boutique-index-link:nth-child(4) {
    transform: translateX(8px);
  }

  .boutique-index .boutique-index-thumb {
    width: 48px;
    height: 60px;
  }

  .boutique-index .boutique-index-link:nth-child(even) .boutique-index-thumb {
    height: 50px;
  }

  .boutique-index .boutique-index-text strong {
    font-size: 1.08rem;
  }

  .boutique-index .boutique-index-text small {
    font-size: 0.64rem;
  }

  .reserve-hero {
    gap: 22px;
  }

  .reserve-hero h1 {
    max-width: 100%;
    font-size: clamp(1.42rem, 6.2vw, 1.72rem);
    line-height: 1.34;
    overflow-wrap: anywhere;
  }

  .reserve-hero .subpage-lead {
    font-size: 0.9rem;
    line-height: 1.82;
  }

  .reserve-hero-note {
    grid-template-columns: 36px 1fr;
    gap: 0 10px;
  }

  .availability-tool {
    padding: 18px 8px;
  }

  .availability-controls {
    grid-template-columns: 34px minmax(0, 1fr) 34px;
    gap: 6px;
    padding: 6px;
  }

  .availability-nav {
    width: 34px;
    height: 34px;
  }

  #availability-month {
    font-size: 1.08rem;
  }

  .availability-calendar,
  .availability-weekdays {
    gap: 2px;
  }

  .availability-day {
    min-height: 38px;
    border-radius: 7px;
  }

  .availability-day-number {
    font-size: 0.86rem;
  }

  .availability-day-status {
    font-size: 0.62rem;
  }
}

@media (max-width: 420px) {
  .reserve-body .reserve-hero h1 {
    max-width: 100%;
    font-size: clamp(1.42rem, 6.2vw, 1.72rem);
    line-height: 1.34;
    overflow-wrap: anywhere;
  }

  .reserve-body .availability-tool {
    padding-inline: 8px;
  }

  .reserve-body .availability-calendar,
  .reserve-body .availability-weekdays {
    gap: 2px;
  }

  .reserve-body .availability-day {
    min-height: 38px;
    border-radius: 7px;
  }
}

@media (min-width: 861px) {
  .boutique-index .boutique-index-link {
    min-height: 214px;
    grid-template-columns: 34px minmax(0, 1fr) 22px;
    grid-template-rows: auto 1fr;
    align-items: start;
    padding: 16px 0 0;
  }

  .boutique-index .boutique-index-link:nth-child(n) {
    transform: none;
  }

  .boutique-index .boutique-index-link:nth-child(2),
  .boutique-index .boutique-index-link:nth-child(4) {
    margin-top: 40px;
  }

  .boutique-index .boutique-index-number {
    grid-column: 1;
    grid-row: 1;
    font-size: 1.04rem;
  }

  .boutique-index .boutique-index-thumb {
    grid-column: 2 / 4;
    grid-row: 2;
    align-self: end;
    width: 100%;
    height: 124px;
    margin-top: 20px;
  }

  .boutique-index .boutique-index-link:nth-child(even) .boutique-index-thumb {
    height: 102px;
  }

  .boutique-index .boutique-index-text {
    grid-column: 2;
    grid-row: 1;
  }

  .boutique-index .boutique-index-text strong {
    font-size: 1.42rem;
  }

  .boutique-index .boutique-index-text small {
    font-size: 0.72rem;
  }
}

/* Reserve page readable sizing */
.reserve-body .reserve-hero h1 {
  max-width: 100%;
  font-size: clamp(1.42rem, 6.2vw, 2rem);
  line-height: 1.34;
  overflow-wrap: anywhere;
}

.reserve-body .availability-tool {
  overflow: hidden;
}

.reserve-body .availability-head,
.reserve-body .availability-controls,
.reserve-body .availability-calendar,
.reserve-body .availability-weekdays {
  min-width: 0;
}

.reserve-body .availability-calendar,
.reserve-body .availability-weekdays {
  gap: 2px;
}

.reserve-body .availability-day {
  min-height: 38px;
  border-radius: 7px;
}

@media (min-width: 861px) {
  .reserve-body .reserve-hero h1 {
    font-size: clamp(2.1rem, 4.4vw, 3.2rem);
    line-height: 1.22;
  }

  .reserve-body .availability-calendar,
  .reserve-body .availability-weekdays {
    gap: 5px;
  }

  .reserve-body .availability-day {
    min-height: 0;
    border-radius: 8px;
  }
}

/* Boutique18 reference rebuild */
.home-body,
.subpage-body {
  --ref-paper: #f8f0e4;
  --ref-paper-light: #fffaf2;
  --ref-ink: #282621;
  --ref-muted: rgba(40, 38, 33, 0.62);
  --ref-faint: rgba(170, 134, 83, 0.18);
  --ref-line: rgba(170, 134, 83, 0.34);
  --ref-gold: #ad8147;
  --ref-olive: #747c65;
  --ref-shadow: rgba(64, 50, 32, 0.16);
  overflow-x: clip;
  color: var(--ref-ink);
  background:
    linear-gradient(90deg, rgba(173, 129, 71, 0.1) 0 1px, transparent 1px) 7.2vw 0 / 1px 100% no-repeat,
    linear-gradient(90deg, transparent 0 calc(100% - 7.2vw), rgba(173, 129, 71, 0.08) calc(100% - 7.2vw) calc(100% - 7.2vw + 1px), transparent calc(100% - 7.2vw + 1px)),
    linear-gradient(180deg, #f8f0e4 0%, #fffaf2 42%, #ede3d4 100%);
}

.home-body .page-shell,
.subpage-body .page-shell {
  overflow: clip;
}

.home-body .ambient,
.subpage-body .ambient {
  display: none;
}

.home-body .site-header,
.subpage-body .site-header {
  border-bottom: 1px solid rgba(173, 129, 71, 0.18);
  background: rgba(248, 240, 228, 0.78);
  backdrop-filter: blur(14px);
}

.home-body .topbar,
.subpage-body .topbar {
  display: none;
}

.home-body .nav-wrap,
.subpage-body .nav-wrap {
  min-height: 72px;
  padding: 12px 20px 10px;
}

.home-body .brand-copy-script strong,
.subpage-body .brand-copy-script strong {
  color: rgba(40, 38, 33, 0.86);
  font-size: clamp(2.3rem, 10vw, 4.6rem);
  font-weight: 400;
  letter-spacing: 0;
}

.home-body .brand-copy-script small,
.subpage-body .brand-copy-script small {
  margin-left: 16px;
  margin-top: -12px;
  color: rgba(173, 129, 71, 0.78);
  font-size: 0.68rem;
  letter-spacing: 0.28em;
}

.home-body .menu-toggle,
.subpage-body .menu-toggle {
  border-color: rgba(173, 129, 71, 0.28);
  background: rgba(255, 250, 242, 0.62);
}

.home-body .site-nav,
.subpage-body .site-nav {
  background: rgba(255, 250, 242, 0.94);
}

.boutique-main {
  position: relative;
  background:
    repeating-linear-gradient(135deg, rgba(173, 129, 71, 0.045) 0 1px, transparent 1px 22px),
    linear-gradient(180deg, rgba(255, 250, 242, 0.58), rgba(248, 240, 228, 0));
}

.boutique-hero {
  width: 100%;
  min-height: 776px;
  padding: 94px 0 0;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) 26px;
  grid-template-rows: 70px 1fr 124px;
  isolation: isolate;
  overflow: hidden;
  background:
    linear-gradient(90deg, transparent 0 28px, rgba(173, 129, 71, 0.26) 28px 29px, transparent 29px),
    linear-gradient(180deg, rgba(248, 240, 228, 0.2), rgba(255, 250, 242, 0.86) 74%, #fffaf2 100%);
}

.boutique-hero::before {
  content: "";
  position: absolute;
  left: 22px;
  top: 146px;
  z-index: 3;
  width: 1px;
  height: 222px;
  background: linear-gradient(180deg, rgba(173, 129, 71, 0), rgba(173, 129, 71, 0.72), rgba(173, 129, 71, 0));
}

.boutique-hero::after {
  content: "Suite";
  position: absolute;
  left: 42px;
  bottom: 62px;
  z-index: 3;
  color: rgba(173, 129, 71, 0.42);
  font-family: "Cormorant Garamond", serif;
  font-size: 5.8rem;
  font-style: italic;
  line-height: 0.8;
  pointer-events: none;
}

.boutique-hero > .boutique-script-ghost {
  top: 118px;
  left: auto;
  right: -34px;
  z-index: 1;
  color: rgba(173, 129, 71, 0.09);
  font-size: clamp(7.6rem, 42vw, 12rem);
  transform: rotate(-7deg);
}

.boutique-hero-location {
  position: absolute;
  top: 98px;
  right: 20px;
  z-index: 6;
  margin: 0;
  color: rgba(40, 38, 33, 0.72);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.boutique-hero-photo {
  position: absolute;
  inset: 82px -84px auto auto;
  z-index: 0;
  width: min(356px, 92vw);
  height: 632px;
  border-radius: 999px 0 0 999px;
  overflow: hidden;
  box-shadow: -26px 36px 76px rgba(64, 50, 32, 0.12);
}

.boutique-hero-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(248, 240, 228, 0.88) 0%, rgba(248, 240, 228, 0.56) 26%, rgba(248, 240, 228, 0.08) 72%),
    linear-gradient(180deg, rgba(255, 250, 242, 0.2), rgba(255, 250, 242, 0.88) 100%);
}

.boutique-hero-photo::after {
  content: "";
  position: absolute;
  inset: 18px 18px 18px 18px;
  z-index: 3;
  border: 1px solid rgba(255, 250, 242, 0.48);
  border-radius: inherit;
  pointer-events: none;
}

.boutique-hero-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 52% 48%;
  filter: saturate(0.92) contrast(0.98);
}

.boutique-hero-copy {
  grid-column: 2 / 4;
  grid-row: 2;
  position: relative;
  z-index: 4;
  align-self: start;
  width: min(320px, calc(100vw - 58px));
  margin-top: 64px;
  padding-left: 18px;
}

.boutique-hero-copy::before {
  content: "";
  position: absolute;
  left: 0;
  top: 38px;
  width: 1px;
  height: 174px;
  background: rgba(173, 129, 71, 0.42);
}

.boutique-hero .boutique-kicker {
  margin-left: 2px;
  color: rgba(173, 129, 71, 0.86);
  font-size: 0.66rem;
  letter-spacing: 0.2em;
}

.boutique-hero h1 {
  margin-top: 16px;
  color: var(--ref-ink);
  font-size: clamp(3rem, 15vw, 4.25rem);
  line-height: 1.04;
  letter-spacing: 0;
  text-shadow: 0 14px 34px rgba(255, 250, 242, 0.7);
}

.boutique-hero h1 span {
  display: block;
}

.boutique-hero-copy p:last-of-type {
  width: min(238px, 76vw);
  margin-top: 22px;
  color: rgba(40, 38, 33, 0.68);
  font-size: 0.84rem;
  line-height: 2.02;
}

.boutique-hero-links {
  display: flex;
  align-items: center;
  gap: 22px;
  margin-top: 24px;
}

.boutique-hero-links a {
  color: var(--ref-ink);
  font-family: "Cormorant Garamond", "Hiragino Mincho ProN", serif;
  font-size: 1rem;
  font-weight: 600;
}

.boutique-hero-links a:first-child {
  min-height: 42px;
  padding: 0 20px;
  border: 1px solid rgba(173, 129, 71, 0.34);
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.82);
  box-shadow: 0 18px 40px rgba(64, 50, 32, 0.1);
}

.boutique-hero-links a::after {
  content: "";
  display: inline-block;
  width: 34px;
  height: 1px;
  margin-left: 12px;
  vertical-align: middle;
  background: rgba(173, 129, 71, 0.62);
}

.boutique-index {
  position: relative;
  min-height: 596px;
  padding: 42px 22px 80px 54px;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-template-rows: repeat(12, 34px);
  gap: 0;
  background:
    linear-gradient(90deg, transparent 0 31px, rgba(173, 129, 71, 0.2) 31px 32px, transparent 32px),
    repeating-linear-gradient(135deg, rgba(173, 129, 71, 0.052) 0 1px, transparent 1px 18px),
    linear-gradient(180deg, #fffaf2 0%, #f6ede1 100%);
}

.boutique-index::before {
  content: "NAVIGATION";
  position: absolute;
  left: 18px;
  top: 72px;
  color: rgba(173, 129, 71, 0.72);
  font-size: 0.6rem;
  letter-spacing: 0.28em;
  writing-mode: vertical-rl;
}

.boutique-index::after {
  left: 26px;
  top: 182px;
  height: 198px;
  background: rgba(173, 129, 71, 0.28);
}

.boutique-index .boutique-index-link {
  display: block;
  min-height: 0;
  margin: 0;
  padding: 0;
  border: 0;
  color: var(--ref-ink);
  transform: none;
}

.boutique-index .boutique-index-link::before,
.boutique-index .boutique-index-link::after {
  display: none;
}

.boutique-index .boutique-index-link-menu {
  grid-column: 1 / 5;
  grid-row: 1 / 6;
}

.boutique-index .boutique-index-link-first {
  grid-column: 4 / 7;
  grid-row: 4 / 8;
}

.boutique-index .boutique-index-link-access {
  grid-column: 1 / 4;
  grid-row: 7 / 12;
}

.boutique-index .boutique-index-link-faq {
  grid-column: 3 / 7;
  grid-row: 10 / 13;
}

.boutique-index .boutique-index-number {
  position: absolute;
  z-index: 3;
  padding: 0;
  color: var(--ref-gold);
  font-size: 0.9rem;
}

.boutique-index .boutique-index-thumb {
  position: absolute;
  inset: auto;
  z-index: 1;
  width: auto;
  height: auto;
  margin: 0;
  overflow: hidden;
  box-shadow: 0 20px 42px rgba(64, 50, 32, 0.14);
}

.boutique-index .boutique-index-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.boutique-index .boutique-index-text {
  position: absolute;
  z-index: 4;
}

.boutique-index .boutique-index-text strong {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.42rem;
  font-style: italic;
  font-weight: 600;
  line-height: 0.95;
}

.boutique-index .boutique-index-text small {
  display: block;
  margin-top: 6px;
  color: rgba(40, 38, 33, 0.56);
  font-size: 0.68rem;
  letter-spacing: 0.02em;
  line-height: 1.48;
}

.boutique-index-link-menu .boutique-index-number {
  left: 8px;
  top: 16px;
}

.boutique-index-link-menu .boutique-index-thumb {
  left: 48px;
  top: 8px;
  width: 82px;
  height: 118px;
  border-radius: 999px 999px 14px 14px;
}

.boutique-index-link-menu .boutique-index-text {
  left: 142px;
  top: 42px;
}

.boutique-index-link-first .boutique-index-number {
  left: -6px;
  top: 8px;
}

.boutique-index-link-first .boutique-index-thumb {
  right: 6px;
  top: 34px;
  width: 78px;
  height: 78px;
  border-radius: 16px 999px 999px 16px;
}

.boutique-index-link-first .boutique-index-text {
  right: 82px;
  top: 58px;
  text-align: right;
}

.boutique-index-link-access .boutique-index-number {
  left: 6px;
  top: 18px;
}

.boutique-index-link-access .boutique-index-thumb {
  left: 52px;
  top: 16px;
  width: 86px;
  height: 132px;
  border-radius: 18px 18px 999px 18px;
}

.boutique-index-link-access .boutique-index-text {
  left: 150px;
  top: 56px;
}

.boutique-index-link-faq .boutique-index-number {
  left: 12px;
  top: 0;
}

.boutique-index-link-faq .boutique-index-thumb {
  right: 8px;
  top: 12px;
  width: 94px;
  height: 72px;
  border-radius: 999px 999px 18px 18px;
}

.boutique-index-link-faq .boutique-index-text {
  right: 106px;
  top: 24px;
  text-align: right;
}

.boutique-concept {
  position: relative;
  min-height: 640px;
  padding: 86px 28px 88px 66px;
  display: block;
  background:
    linear-gradient(180deg, #fffaf2 0%, #f6ede1 72%, #fffaf2 100%);
}

.boutique-section-label {
  position: absolute;
  left: 28px;
  top: 86px;
  color: rgba(173, 129, 71, 0.7);
  font-family: "Cormorant Garamond", serif;
  font-size: 1.08rem;
  font-style: italic;
  letter-spacing: 0.18em;
  writing-mode: vertical-rl;
}

.boutique-concept-copy {
  position: relative;
  z-index: 4;
  max-width: 276px;
  padding-top: 76px;
}

.boutique-concept-copy::before {
  content: "";
  position: absolute;
  left: -24px;
  top: 92px;
  width: 1px;
  height: 170px;
  background: rgba(173, 129, 71, 0.34);
}

.boutique-concept-copy h2 {
  margin: 0;
  font-size: clamp(2.5rem, 12vw, 3.6rem);
  line-height: 1.34;
  letter-spacing: 0;
}

.boutique-concept-copy p {
  width: min(226px, 68vw);
  margin-top: 24px;
  color: var(--ref-muted);
  font-size: 0.84rem;
  line-height: 2.02;
}

.boutique-concept-photo {
  position: absolute;
  right: -78px;
  top: 166px;
  z-index: 2;
  width: 254px;
  height: 372px;
  border-radius: 999px 0 0 999px;
  overflow: hidden;
  box-shadow: -28px 34px 68px rgba(64, 50, 32, 0.12);
}

.boutique-concept-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 250, 242, 0.4), rgba(255, 250, 242, 0.06));
}

.boutique-concept-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 46% 52%;
}

.boutique-concept-photo figcaption {
  position: absolute;
  left: 22px;
  bottom: 20px;
  z-index: 2;
  color: rgba(255, 250, 242, 0.78);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
}

.boutique-treatment {
  position: relative;
  min-height: 706px;
  padding: 88px 24px 98px 58px;
  clip-path: polygon(0 3%, 100% 0, 100% 97%, 0 100%);
  color: #fffaf2;
  background:
    linear-gradient(90deg, rgba(46, 50, 41, 0.84) 0%, rgba(80, 87, 69, 0.68) 48%, rgba(80, 87, 69, 0.22) 100%),
    url("./assets/photos/boutique-treatment-still-v2.webp") 64% 50% / auto 112% no-repeat;
}

.boutique-treatment::before {
  inset: 34px 22px auto auto;
  width: 74px;
  height: 104px;
  border-color: rgba(255, 250, 242, 0.36);
}

.boutique-treatment::after {
  left: 24px;
  right: 24px;
  bottom: 46px;
  background: rgba(255, 250, 242, 0.28);
}

.boutique-treatment-copy {
  position: relative;
  z-index: 4;
  max-width: 286px;
}

.boutique-treatment h2,
.boutique-treatment h2 span,
.boutique-treatment .boutique-kicker,
.boutique-treatment .boutique-inline-link {
  color: #fffaf2;
}

.boutique-treatment h2 {
  font-size: clamp(2.2rem, 10vw, 3.2rem);
  line-height: 1.06;
}

.boutique-treatment h2 span {
  display: block;
  margin-top: 10px;
  font-size: 1.2rem;
  font-style: italic;
  opacity: 0.84;
}

.boutique-treatment-copy p {
  color: rgba(255, 250, 242, 0.82);
  line-height: 1.9;
}

.boutique-treatment-photo {
  position: absolute;
  right: -56px;
  top: 108px;
  width: 162px;
  height: 332px;
  border-radius: 999px 0 0 999px;
  overflow: hidden;
  opacity: 0.88;
  box-shadow: -18px 26px 56px rgba(22, 22, 18, 0.18);
}

.boutique-treatment-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 42% 50%;
}

.boutique-menu-lines {
  position: relative;
  z-index: 4;
  margin-top: 62px;
  display: grid;
  gap: 0;
}

.boutique-menu-lines a {
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 8px 14px;
  padding: 18px 0;
  border-color: rgba(255, 250, 242, 0.24);
  color: #fffaf2;
}

.boutique-menu-lines span,
.boutique-treatment .boutique-menu-lines strong,
.boutique-treatment .boutique-menu-lines small {
  color: rgba(255, 250, 242, 0.86);
}

.boutique-menu-lines strong {
  font-size: 1.02rem;
}

.boutique-access {
  position: relative;
  min-height: 632px;
  padding: 92px 28px 88px;
  display: grid;
  align-items: start;
  background:
    linear-gradient(180deg, #fffaf2 0%, #f6ede1 100%);
}

.boutique-route {
  right: -40px;
  top: 76px;
  width: 236px;
  height: 236px;
  opacity: 0.7;
}

.boutique-access-photo {
  position: absolute;
  left: 28px;
  top: 84px;
  width: 142px;
  height: 214px;
  border-radius: 999px 999px 18px 18px;
  overflow: hidden;
  box-shadow: 0 24px 48px rgba(64, 50, 32, 0.13);
}

.boutique-access-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 52% 44%;
}

.boutique-access-copy {
  position: relative;
  z-index: 4;
  width: min(258px, 72vw);
  margin-left: auto;
  padding-top: 144px;
}

.boutique-access h2 {
  margin: 0;
  font-size: clamp(2rem, 9.6vw, 3rem);
  line-height: 1.36;
  letter-spacing: 0;
}

.boutique-access p:not(.boutique-kicker) {
  color: var(--ref-muted);
  font-size: 0.86rem;
  line-height: 1.94;
}

.boutique-guide-links {
  position: relative;
  padding: 24px 24px 76px 54px;
  display: grid;
  gap: 0;
  background: #f6ede1;
}

.boutique-guide-links a {
  display: grid;
  grid-template-columns: 1fr 34px;
  padding: 28px 0;
  border-top: 1px solid rgba(173, 129, 71, 0.3);
  background: transparent;
  color: var(--ref-ink);
}

.boutique-guide-links a:last-child {
  border-bottom: 1px solid rgba(173, 129, 71, 0.3);
  transform: translateX(18px);
}

.boutique-guide-links span {
  color: var(--ref-gold);
  font-family: "Cormorant Garamond", serif;
  font-size: 0.82rem;
  font-style: italic;
}

.boutique-guide-links strong {
  grid-column: 1;
  margin-top: 8px;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", serif;
  font-size: 1.42rem;
  line-height: 1.3;
}

.boutique-guide-links small {
  grid-column: 1;
  margin-top: 8px;
  color: var(--ref-muted);
  font-size: 0.7rem;
  letter-spacing: 0.06em;
}

.boutique-guide-links a::after {
  content: "";
  grid-column: 2;
  grid-row: 1 / span 3;
  align-self: center;
  width: 34px;
  height: 1px;
  background: rgba(173, 129, 71, 0.62);
}

.boutique-reserve {
  position: relative;
  min-height: 612px;
  padding: 96px 26px 96px;
  background:
    linear-gradient(90deg, rgba(255, 250, 242, 0.96) 0%, rgba(255, 250, 242, 0.72) 46%, rgba(255, 250, 242, 0.22) 100%),
    url("./assets/photos/subpage-reserve-boutique-v1.webp") 68% 52% / cover no-repeat;
}

.boutique-reserve::before {
  content: "Book";
  position: absolute;
  left: 18px;
  top: 64px;
  width: auto;
  height: auto;
  border: 0;
  background: transparent;
  color: rgba(173, 129, 71, 0.28);
  font-family: "Parisienne", cursive;
  font-size: 6.6rem;
  line-height: 1;
  box-shadow: none;
}

.boutique-reserve::after {
  content: "";
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 50px;
  z-index: 1;
  width: auto;
  height: 1px;
  background: rgba(173, 129, 71, 0.32);
  box-shadow: none;
}

.boutique-reserve > .boutique-script-ghost {
  right: -90px;
  bottom: 110px;
  color: rgba(173, 129, 71, 0.12);
  font-size: 9rem;
}

.boutique-reserve-calendar {
  right: 18px;
  top: 76px;
  padding: 14px;
  border-color: rgba(173, 129, 71, 0.3);
  background: rgba(255, 250, 242, 0.76);
}

.boutique-reserve-copy {
  position: relative;
  z-index: 4;
  width: min(272px, 76vw);
  padding-top: 172px;
}

.boutique-reserve h2 {
  font-size: clamp(2.1rem, 9.8vw, 3.1rem);
  line-height: 1.24;
}

.boutique-reserve-copy p:not(.boutique-kicker) {
  color: var(--ref-muted);
  line-height: 1.86;
}

.boutique-reserve-button {
  border: 1px solid rgba(173, 129, 71, 0.34);
  background: rgba(255, 250, 242, 0.78);
  color: var(--ref-ink);
}

.site-footer {
  background: #f6ede1;
}

.boutique-footer-script {
  color: rgba(173, 129, 71, 0.28);
}

@media (min-width: 861px) {
  .home-body .nav-wrap,
  .subpage-body .nav-wrap {
    min-height: 86px;
    padding-inline: 42px;
  }

  .home-body .site-nav,
  .subpage-body .site-nav {
    background: transparent;
  }

  .boutique-hero {
    min-height: 820px;
    grid-template-columns: minmax(54px, 7vw) minmax(0, 580px) minmax(360px, 1fr);
    padding-top: 112px;
  }

  .boutique-hero-photo {
    right: 0;
    top: 96px;
    width: min(54vw, 670px);
    height: 680px;
    border-radius: 999px 0 0 999px;
  }

  .boutique-hero-copy {
    grid-column: 2;
    width: 560px;
    margin-top: 108px;
    padding-left: 36px;
  }

  .boutique-hero h1 {
    font-size: clamp(4.5rem, 8vw, 7.4rem);
  }

  .boutique-hero-copy p:last-of-type {
    width: 338px;
  }

  .boutique-hero-location {
    right: 48px;
    top: 118px;
  }

  .boutique-index {
    width: min(1180px, calc(100vw - 72px));
    min-height: 474px;
    margin: 0 auto;
    padding: 56px 60px 86px 96px;
    grid-template-rows: repeat(8, 38px);
  }

  .boutique-index .boutique-index-link-menu {
    grid-column: 1 / 3;
    grid-row: 1 / 6;
  }

  .boutique-index .boutique-index-link-first {
    grid-column: 3 / 5;
    grid-row: 2 / 7;
  }

  .boutique-index .boutique-index-link-access {
    grid-column: 5 / 6;
    grid-row: 1 / 7;
  }

  .boutique-index .boutique-index-link-faq {
    grid-column: 6 / 7;
    grid-row: 3 / 8;
  }

  .boutique-index-link-menu .boutique-index-thumb,
  .boutique-index-link-access .boutique-index-thumb {
    width: 132px;
    height: 188px;
  }

  .boutique-index-link-first .boutique-index-thumb,
  .boutique-index-link-faq .boutique-index-thumb {
    width: 150px;
    height: 122px;
  }

  .boutique-index-link-first .boutique-index-text,
  .boutique-index-link-faq .boutique-index-text {
    text-align: left;
  }

  .boutique-concept {
    min-height: 650px;
    padding: 104px max(8vw, 92px);
  }

  .boutique-concept-copy {
    max-width: 520px;
    padding-top: 86px;
  }

  .boutique-concept-copy h2 {
    font-size: clamp(3.2rem, 5.6vw, 5rem);
  }

  .boutique-concept-photo {
    right: max(6vw, 70px);
    top: 104px;
    width: 330px;
    height: 500px;
  }

  .boutique-treatment {
    min-height: 660px;
    padding: 118px max(7vw, 92px) 108px;
    background:
      linear-gradient(90deg, rgba(46, 50, 41, 0.88) 0%, rgba(80, 87, 69, 0.7) 42%, rgba(80, 87, 69, 0.16) 100%),
      url("./assets/photos/boutique-treatment-still-v2.webp") 78% 50% / auto 120% no-repeat;
  }

  .boutique-treatment-copy {
    max-width: 410px;
  }

  .boutique-treatment-photo {
    right: max(7vw, 90px);
    width: 220px;
    height: 430px;
  }

  .boutique-menu-lines {
    max-width: 560px;
  }

  .boutique-access {
    min-height: 630px;
    padding: 118px max(8vw, 92px);
    grid-template-columns: 340px minmax(0, 560px);
    gap: 76px;
  }

  .boutique-access-photo {
    position: relative;
    left: auto;
    top: auto;
    width: 280px;
    height: 420px;
  }

  .boutique-access-copy {
    width: auto;
    margin: 0;
    padding-top: 86px;
  }

  .boutique-access h2 {
    font-size: clamp(3rem, 4.6vw, 4.2rem);
  }

  .boutique-guide-links {
    width: min(980px, calc(100vw - 96px));
    margin: 0 auto;
    padding: 56px 0 96px;
    grid-template-columns: 1fr 1fr;
    gap: 54px;
  }

  .boutique-guide-links a:last-child {
    transform: translateY(44px);
  }

  .boutique-reserve {
    min-height: 560px;
    padding: 110px max(8vw, 92px);
    background:
      linear-gradient(90deg, rgba(255, 250, 242, 0.98) 0%, rgba(255, 250, 242, 0.7) 42%, rgba(255, 250, 242, 0.1) 100%),
      url("./assets/photos/subpage-reserve-boutique-v1.webp") 78% 48% / auto 118% no-repeat;
  }

  .boutique-reserve-copy {
    width: 430px;
    padding-top: 92px;
  }
}

/* Boutique18 subpage and reservation alignment */
.subpage-main {
  padding-top: 96px;
}

.subpage-hero,
.subpage-section {
  width: min(430px, 100vw);
  padding-inline: 24px;
}

.subpage-hero {
  position: relative;
  min-height: 650px;
  padding-top: 58px;
  padding-bottom: 86px;
  display: block;
  overflow: hidden;
}

.subpage-hero::before {
  top: 78px;
  right: -20px;
  color: rgba(173, 129, 71, 0.12);
  font-size: clamp(6.6rem, 34vw, 10rem);
  transform: rotate(-8deg);
}

.subpage-hero::after {
  content: "";
  position: absolute;
  left: 22px;
  top: 138px;
  z-index: 2;
  width: 1px;
  height: 188px;
  background: rgba(173, 129, 71, 0.34);
}

.subpage-hero-copy {
  position: relative;
  z-index: 4;
  width: min(310px, 82vw);
  padding-top: 42px;
}

.subpage-hero h1 {
  font-size: clamp(2.32rem, 10.8vw, 3.35rem);
  line-height: 1.22;
  letter-spacing: 0;
}

.subpage-lead {
  margin-top: 20px;
  font-size: 0.88rem;
  line-height: 1.92;
}

.subpage-actions {
  gap: 12px;
  margin-top: 28px;
}

.subpage-button {
  min-height: 42px;
  padding-inline: 16px;
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.72);
}

.subpage-button-primary {
  border-color: rgba(173, 129, 71, 0.36);
  background: rgba(40, 38, 33, 0.86);
  color: #fffaf2;
  box-shadow: 0 18px 38px rgba(64, 50, 32, 0.13);
}

.subpage-button-secondary {
  border-color: rgba(173, 129, 71, 0.3);
  background: rgba(255, 250, 242, 0.66);
}

.subpage-hero-media {
  position: absolute;
  right: -54px;
  bottom: 48px;
  z-index: 1;
  width: 232px;
  height: 356px;
  border-radius: 999px 0 0 999px;
  overflow: hidden;
  box-shadow: -22px 28px 62px rgba(64, 50, 32, 0.14);
}

.subpage-hero-media img {
  width: 100%;
  height: 100%;
  min-height: 0;
  aspect-ratio: auto;
  border-radius: 0;
  object-fit: cover;
  box-shadow: none;
}

.menu-body .subpage-hero-media img {
  border-radius: 0;
}

.guide-body .subpage-hero-media {
  left: -44px;
  right: auto;
  border-radius: 0 999px 999px 0;
}

.guide-body .subpage-hero-copy {
  margin-left: auto;
}

.access-body .subpage-hero-media {
  right: -36px;
  width: 250px;
  border-radius: 36px 0 0 120px;
}

.faq-body .subpage-hero-media {
  width: 250px;
  height: 314px;
  border-radius: 22px 0 0 22px;
}

.subpage-section {
  padding-block: 60px;
  border-top: 1px solid rgba(173, 129, 71, 0.28);
}

.subpage-heading {
  position: relative;
  gap: 12px;
  margin-bottom: 30px;
}

.subpage-heading::before {
  content: "";
  position: absolute;
  left: -20px;
  top: 8px;
  width: 1px;
  height: 80px;
  background: rgba(173, 129, 71, 0.28);
}

.subpage-heading h2 {
  font-size: clamp(1.82rem, 8vw, 2.72rem);
  line-height: 1.32;
}

.subpage-heading p,
.subpage-card p,
.price-card p,
.faq-item p,
.note-band p {
  color: var(--ref-muted);
}

.subpage-grid,
.subpage-grid-two {
  gap: 0;
}

.price-card,
.subpage-card,
.faq-item {
  position: relative;
  padding: 24px 0;
  border-top: 1px solid rgba(173, 129, 71, 0.24);
}

.price-card::after,
.subpage-card::after,
.faq-item::after {
  content: "";
  position: absolute;
  right: 0;
  top: 34px;
  width: 34px;
  height: 1px;
  background: rgba(173, 129, 71, 0.42);
}

.price-card-featured {
  margin: 12px -10px;
  padding: 28px 20px;
  border-color: rgba(173, 129, 71, 0.36);
  border-radius: 0 0 72px 0;
  background:
    linear-gradient(135deg, rgba(255, 250, 242, 0.92), rgba(226, 219, 205, 0.78)),
    repeating-linear-gradient(135deg, rgba(173, 129, 71, 0.055) 0 1px, transparent 1px 18px);
}

.price-card-featured h3,
.price-card-featured p {
  color: var(--ref-ink);
}

.price-main {
  color: var(--ref-olive);
}

.flow-list {
  gap: 0;
}

.flow-step {
  grid-template-columns: 38px 1fr;
  gap: 14px;
  padding: 22px 0;
}

.flow-number {
  border-color: rgba(173, 129, 71, 0.36);
  color: var(--ref-gold);
}

.note-band {
  padding: 30px 0 30px 22px;
  border-color: rgba(173, 129, 71, 0.34);
  border-left: 1px solid rgba(173, 129, 71, 0.28);
}

.reserve-main {
  padding-top: 96px;
}

.reserve-hero {
  position: relative;
  min-height: 570px;
  padding: 60px 24px 70px;
  display: block;
  overflow: hidden;
}

.reserve-hero::before {
  right: -34px;
  top: 78px;
  color: rgba(173, 129, 71, 0.12);
  font-size: clamp(6.8rem, 35vw, 10rem);
  transform: rotate(-8deg);
}

.reserve-hero::after {
  content: "";
  position: absolute;
  right: -64px;
  bottom: 28px;
  z-index: 0;
  width: 256px;
  height: 360px;
  border-radius: 999px 0 0 999px;
  background:
    linear-gradient(90deg, rgba(255, 250, 242, 0.72), rgba(255, 250, 242, 0.1)),
    url("./assets/photos/subpage-reserve-boutique-v1.webp") 52% 50% / cover no-repeat;
  box-shadow: -22px 30px 60px rgba(64, 50, 32, 0.12);
}

.reserve-hero-copy {
  position: relative;
  z-index: 2;
  width: min(314px, 84vw);
  padding-top: 44px;
}

.reserve-body .reserve-hero h1 {
  font-size: clamp(2rem, 9.6vw, 3rem);
  line-height: 1.2;
}

.reserve-hero .subpage-lead {
  color: var(--ref-muted);
  font-size: 0.88rem;
}

.reserve-hero-note {
  position: relative;
  z-index: 2;
  width: min(318px, 86vw);
  margin-top: 38px;
  grid-template-columns: 38px 1fr;
  border-color: rgba(173, 129, 71, 0.32);
}

.reserve-hero-note span {
  color: var(--ref-gold);
}

.reserve-layout {
  width: min(430px, 100vw);
  gap: 26px;
  padding: 0 18px 90px;
}

.reserve-side > img {
  height: 410px;
  border-radius: 999px 999px 26px 26px;
  object-position: center 62%;
}

.reserve-side-card {
  padding: 28px 0;
  border-color: rgba(173, 129, 71, 0.34);
}

.reserve-side-card h2,
.availability-head h2 {
  font-size: 1.62rem;
}

.availability-tool,
.reserve-body .contact-form,
.reserve-body .booking-feedback {
  border-radius: 0 0 58px 0;
  border-color: rgba(173, 129, 71, 0.3);
  background:
    repeating-linear-gradient(135deg, rgba(173, 129, 71, 0.042) 0 1px, transparent 1px 18px),
    rgba(255, 250, 242, 0.9);
  box-shadow: 0 26px 58px rgba(64, 50, 32, 0.1);
}

.availability-controls {
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.78);
}

.availability-day {
  border-radius: 999px 999px 8px 8px;
  background: rgba(255, 250, 242, 0.7);
}

.availability-slot,
.availability-empty {
  border-radius: 999px;
}

.reserve-body .contact-form input,
.reserve-body .contact-form select,
.reserve-body .contact-form textarea {
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
}

.reserve-body .contact-form textarea {
  border-radius: 22px;
}

@media (max-width: 420px) {
  .reserve-body .availability-tool {
    padding-inline: 8px;
  }

  .reserve-body .availability-legend {
    gap: 6px;
    font-size: 0.68rem;
  }

  .reserve-body .availability-weekdays span {
    font-size: 0.62rem;
  }

  .reserve-body .availability-day {
    min-height: 34px;
    aspect-ratio: auto;
    gap: 0;
  }

  .reserve-body .availability-day-number {
    font-size: 0.8rem;
  }

  .reserve-body .availability-day-status {
    font-size: 0.56rem;
  }
}

@media (min-width: 861px) {
  .subpage-main {
    padding-top: 116px;
  }

  .subpage-hero,
  .subpage-section {
    width: min(1120px, calc(100vw - 84px));
    padding-inline: 0;
  }

  .subpage-hero {
    min-height: 680px;
    padding-top: 70px;
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.5fr);
    align-items: center;
  }

  .subpage-hero-copy {
    width: min(620px, 100%);
  }

  .subpage-hero h1 {
    font-size: clamp(3.2rem, 5.4vw, 5.2rem);
  }

  .subpage-hero-media {
    position: relative;
    right: auto;
    bottom: auto;
    justify-self: end;
    width: 330px;
    height: 500px;
  }

  .guide-body .subpage-hero-media {
    left: auto;
  }

  .guide-body .subpage-hero-copy {
    margin-left: 0;
  }

  .subpage-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 30px;
  }

  .subpage-grid-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 42px;
  }

  .reserve-main {
    padding-top: 116px;
  }

  .reserve-hero,
  .reserve-layout {
    width: min(1120px, calc(100vw - 84px));
  }

  .reserve-hero {
    min-height: 520px;
    padding-top: 70px;
  }

  .reserve-hero-copy {
    width: min(650px, 62vw);
  }

  .reserve-body .reserve-hero h1 {
    font-size: clamp(3rem, 5.2vw, 5rem);
  }

  .reserve-hero-note {
    width: 420px;
  }

  .reserve-layout {
    grid-template-columns: minmax(280px, 340px) minmax(0, 690px);
    gap: 76px;
  }

  .reserve-side > img {
    height: 540px;
  }
}

/* Boutique18 mobile composition trim */
@media (max-width: 860px) {
  .boutique-hero {
    min-height: 748px;
  }

  .boutique-hero-photo {
    right: -92px;
    width: min(344px, 90vw);
  }

  .boutique-hero-copy {
    grid-column: 2 / 3;
    width: min(282px, calc(100vw - 78px));
    margin-top: 88px;
    padding-left: 16px;
  }

  .boutique-hero h1 {
    font-size: clamp(2.62rem, 11.6vw, 3.12rem);
    line-height: 1.08;
  }

  .boutique-hero-copy p:last-of-type {
    width: min(224px, 66vw);
  }

  .boutique-index {
    min-height: 612px;
    grid-template-rows: repeat(12, 36px);
    padding-right: 18px;
  }

  .boutique-index .boutique-index-link {
    position: relative;
  }

  .boutique-index .boutique-index-text strong {
    font-size: 1.22rem;
  }

  .boutique-index .boutique-index-text small {
    font-size: 0.62rem;
    line-height: 1.42;
  }

  .boutique-index-link-menu .boutique-index-thumb {
    left: 38px;
    top: 6px;
    width: 82px;
    height: 118px;
  }

  .boutique-index-link-menu .boutique-index-text {
    left: 132px;
    top: 42px;
    width: 128px;
  }

  .boutique-index-link-first .boutique-index-thumb {
    left: 22px;
    right: auto;
    top: 16px;
    width: 76px;
    height: 76px;
  }

  .boutique-index-link-first .boutique-index-text {
    left: 8px;
    right: auto;
    top: 102px;
    width: 118px;
    text-align: left;
  }

  .boutique-index-link-access .boutique-index-thumb {
    left: 38px;
    top: 18px;
    width: 86px;
    height: 130px;
  }

  .boutique-index-link-access .boutique-index-text {
    left: 132px;
    top: 56px;
    width: 120px;
  }

  .boutique-index-link-faq .boutique-index-thumb {
    left: 4px;
    right: auto;
    top: 14px;
    width: 88px;
    height: 70px;
  }

  .boutique-index-link-faq .boutique-index-text {
    left: 62px;
    right: auto;
    top: 92px;
    width: 132px;
    text-align: left;
  }

  .boutique-concept-copy {
    max-width: 258px;
  }

  .boutique-concept-copy h2 {
    font-size: clamp(2.38rem, 10.8vw, 3rem);
  }

  .boutique-concept-copy p {
    width: min(216px, 64vw);
  }

  .boutique-concept-photo {
    right: -92px;
    width: 246px;
  }

  .boutique-treatment {
    padding-left: 46px;
    background:
      linear-gradient(90deg, rgba(46, 50, 41, 0.9) 0%, rgba(80, 87, 69, 0.72) 54%, rgba(80, 87, 69, 0.26) 100%),
      url("./assets/photos/boutique-treatment-still-v2.webp") 70% 50% / auto 112% no-repeat;
  }

  .boutique-treatment-copy {
    max-width: 218px;
    margin-left: 0;
  }

  .boutique-treatment h2 {
    max-width: 218px;
    font-size: clamp(1.58rem, 7vw, 1.92rem);
    line-height: 1.18;
    overflow-wrap: anywhere;
  }

  .boutique-treatment-photo {
    right: -80px;
    opacity: 0.7;
  }

  .boutique-menu-lines a {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
  }

  .boutique-menu-lines span,
  .boutique-menu-lines strong,
  .boutique-menu-lines small {
    grid-column: 1;
    min-width: 0;
  }

  .boutique-menu-lines strong {
    font-size: 0.94rem;
  }

  .boutique-menu-lines small {
    justify-self: start;
    text-align: left;
    white-space: normal;
    font-size: 0.62rem;
    line-height: 1.45;
  }

  .boutique-access-copy {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
    width: min(272px, 74vw);
    margin-left: 52px !important;
    margin-right: 0 !important;
    justify-self: start;
    padding-top: 286px;
  }

  .boutique-access h2 {
    max-width: 258px;
    font-size: clamp(1.58rem, 7.2vw, 2rem);
    line-height: 1.36;
    overflow-wrap: anywhere;
  }

  .boutique-reserve-copy {
    width: min(246px, 68vw);
  }

  .boutique-reserve h2 {
    font-size: clamp(1.78rem, 8.4vw, 2.52rem);
  }
}

/* Boutique19 reference lock: poster-like HP */
.home-body {
  --b19-bg: #efe4d4;
  --b19-paper: #f9f1e6;
  --b19-ink: #221f1b;
  --b19-deep: #333a2d;
  --b19-gold: #b0824c;
  --b19-line: rgba(176, 130, 76, 0.36);
  --b19-muted: rgba(34, 31, 27, 0.66);
  background: #d8c8b3;
}

.home-body .page-shell {
  background:
    linear-gradient(90deg, rgba(34, 31, 27, 0.1) 0 1px, transparent 1px) 22px 0 / 1px 100% no-repeat,
    linear-gradient(90deg, transparent calc(100% - 22px), rgba(34, 31, 27, 0.08) calc(100% - 22px) calc(100% - 21px), transparent calc(100% - 21px)),
    var(--b19-paper);
}

.home-body .site-header {
  position: fixed;
  height: 64px;
  border: 0;
  background: linear-gradient(180deg, rgba(249, 241, 230, 0.94), rgba(249, 241, 230, 0.46));
}

.home-body .nav-wrap {
  min-height: 64px;
  padding: 8px 22px;
}

.home-body .brand-copy-script strong {
  color: rgba(34, 31, 27, 0.82);
  font-size: 2.54rem;
}

.home-body .brand-copy-script small {
  color: rgba(176, 130, 76, 0.8);
}

.home-body .boutique-main {
  width: min(430px, 100vw);
  margin: 0 auto;
  background:
    linear-gradient(90deg, rgba(176, 130, 76, 0.15) 0 1px, transparent 1px) 22px 0 / 1px 100% no-repeat,
    repeating-linear-gradient(135deg, rgba(176, 130, 76, 0.035) 0 1px, transparent 1px 26px),
    var(--b19-paper);
  box-shadow: 0 0 0 1px rgba(34, 31, 27, 0.04);
}

.boutique-hero {
  min-height: 812px;
  padding: 0;
  display: block;
  background: var(--b19-paper);
}

.boutique-hero::before {
  left: 40px;
  top: 148px;
  height: 286px;
  background: linear-gradient(180deg, transparent, rgba(176, 130, 76, 0.72), transparent);
}

.boutique-hero::after {
  content: "Private";
  left: auto;
  right: -18px;
  bottom: 92px;
  color: rgba(176, 130, 76, 0.26);
  font-size: 5.4rem;
  transform: rotate(-90deg);
  transform-origin: right bottom;
}

.boutique-hero-location {
  top: 92px;
  right: 24px;
  z-index: 6;
  color: rgba(34, 31, 27, 0.72);
  font-size: 0.58rem;
  letter-spacing: 0.34em;
}

.boutique-hero > .boutique-script-ghost {
  top: 72px;
  right: -68px;
  color: rgba(176, 130, 76, 0.11);
  font-size: 12.6rem;
  transform: rotate(-9deg);
}

.boutique-hero-photo {
  top: 88px;
  right: -58px;
  width: 318px;
  height: 586px;
  border-radius: 172px 0 0 172px;
  box-shadow: -30px 42px 86px rgba(70, 50, 29, 0.18);
}

.boutique-hero-photo::before {
  background:
    linear-gradient(90deg, rgba(249, 241, 230, 0.94) 0%, rgba(249, 241, 230, 0.54) 36%, rgba(249, 241, 230, 0.04) 78%),
    linear-gradient(180deg, rgba(249, 241, 230, 0.12), rgba(249, 241, 230, 0.84) 100%);
}

.boutique-hero-copy {
  position: absolute;
  left: 54px;
  top: 338px;
  z-index: 5;
  width: 284px;
  margin: 0;
  padding: 0 0 0 18px;
}

.boutique-hero-copy::before {
  top: -18px;
  height: 216px;
  background: rgba(176, 130, 76, 0.4);
}

.boutique-hero .boutique-kicker {
  margin: 0 0 18px;
  color: var(--b19-gold);
  font-size: 0.58rem;
  letter-spacing: 0.24em;
}

.boutique-hero h1 {
  margin: 0;
  font-size: 3.08rem;
  line-height: 1.02;
  letter-spacing: 0;
  color: var(--b19-ink);
  text-shadow: 0 18px 34px rgba(249, 241, 230, 0.86);
}

.boutique-hero-copy p:last-of-type {
  width: 226px;
  margin-top: 24px;
  color: var(--b19-muted);
  font-size: 0.76rem;
  line-height: 1.95;
}

.boutique-hero-links {
  margin-top: 24px;
  gap: 18px;
}

.boutique-hero-links a:first-child {
  min-height: 38px;
  padding-inline: 18px;
  background: rgba(249, 241, 230, 0.9);
  border-color: rgba(176, 130, 76, 0.4);
}

.boutique-index {
  min-height: 520px;
  margin-top: -58px;
  padding: 58px 20px 54px 54px;
  grid-template-columns: repeat(8, 1fr);
  grid-template-rows: repeat(10, 38px);
  background:
    linear-gradient(90deg, rgba(34, 31, 27, 0.08) 0 1px, transparent 1px) 22px 0 / 1px 100% no-repeat,
    repeating-linear-gradient(135deg, rgba(176, 130, 76, 0.048) 0 1px, transparent 1px 22px),
    #f6ecdf;
}

.boutique-index::before {
  left: 18px;
  top: 70px;
  color: rgba(176, 130, 76, 0.82);
}

.boutique-index::after {
  left: 27px;
  top: 184px;
  height: 180px;
}

.boutique-index .boutique-index-text strong {
  color: var(--b19-ink);
  font-size: 1.28rem;
}

.boutique-index .boutique-index-text small {
  color: rgba(34, 31, 27, 0.58);
}

.boutique-index-link-menu .boutique-index-thumb {
  left: 54px;
  top: 8px;
  width: 96px;
  height: 132px;
}

.boutique-index-link-menu .boutique-index-text {
  left: 162px;
  top: 54px;
  width: 140px;
}

.boutique-index-link-first .boutique-index-thumb {
  left: 228px;
  top: 72px;
  width: 92px;
  height: 72px;
}

.boutique-index-link-first .boutique-index-text {
  left: 188px;
  top: 160px;
  width: 126px;
}

.boutique-index-link-access .boutique-index-thumb {
  left: 70px;
  top: 178px;
  width: 104px;
  height: 142px;
}

.boutique-index-link-access .boutique-index-text {
  left: 184px;
  top: 218px;
  width: 132px;
}

.boutique-index-link-faq .boutique-index-thumb {
  left: 214px;
  top: 298px;
  width: 92px;
  height: 70px;
}

.boutique-index-link-faq .boutique-index-text {
  left: 168px;
  top: 374px;
  width: 132px;
}

.boutique-concept {
  min-height: 648px;
  margin-top: -1px;
  padding: 102px 28px 88px 66px;
  background:
    linear-gradient(180deg, #f6ecdf 0%, #f9f1e6 100%);
}

.boutique-concept-copy {
  max-width: 260px;
  padding-top: 70px;
}

.boutique-concept-copy h2 {
  font-size: 3.02rem;
  line-height: 1.26;
  color: var(--b19-ink);
}

.boutique-concept-copy p {
  width: 218px;
  font-size: 0.76rem;
  line-height: 1.95;
}

.boutique-concept-photo {
  right: -72px;
  top: 170px;
  width: 238px;
  height: 346px;
  opacity: 0.92;
}

.boutique-treatment {
  min-height: 724px;
  margin-top: -30px;
  padding: 112px 30px 102px 52px;
  clip-path: polygon(0 4%, 100% 0, 100% 96%, 0 100%);
  background:
    linear-gradient(90deg, rgba(35, 41, 32, 0.94) 0%, rgba(55, 66, 50, 0.82) 50%, rgba(55, 66, 50, 0.38) 100%),
    url("./assets/photos/boutique-treatment-still-v2.webp") 66% 50% / auto 116% no-repeat;
}

.boutique-treatment-copy {
  max-width: 226px;
}

.boutique-treatment h2 {
  max-width: 226px;
  font-size: 2.06rem;
  line-height: 1.1;
}

.boutique-treatment-copy p {
  color: rgba(255, 250, 242, 0.84);
  font-size: 0.76rem;
  line-height: 1.9;
}

.boutique-treatment-photo {
  right: -54px;
  top: 134px;
  width: 142px;
  height: 306px;
  opacity: 0.74;
}

.boutique-menu-lines {
  width: 236px;
  margin-top: 62px;
}

.boutique-menu-lines a {
  grid-template-columns: 1fr;
  padding: 16px 0;
}

.boutique-menu-lines small {
  justify-self: start;
  text-align: left;
  color: rgba(255, 250, 242, 0.76);
  white-space: normal;
}

.boutique-access {
  min-height: 650px;
  margin-top: -22px;
  display: block;
  padding: 104px 28px 82px;
  background: #f9f1e6;
}

.boutique-access-photo {
  left: 50px;
  top: 88px;
  width: 150px;
  height: 230px;
  border-radius: 999px 999px 18px 18px;
}

.boutique-route {
  right: -72px;
  top: 78px;
  width: 250px;
  height: 250px;
  opacity: 0.54;
}

.boutique-access-copy {
  position: relative;
  z-index: 3;
  width: 260px !important;
  margin-left: 50px !important;
  padding-top: 300px !important;
}

.boutique-access h2 {
  max-width: 260px;
  font-size: 2rem;
  line-height: 1.34;
  color: var(--b19-ink);
}

.boutique-access p:not(.boutique-kicker) {
  font-size: 0.76rem;
  line-height: 1.92;
}

.boutique-guide-links {
  margin-top: -24px;
  padding: 42px 28px 86px 62px;
  background: #f9f1e6;
}

.boutique-guide-links a {
  padding: 22px 0;
  border-color: var(--b19-line);
}

.boutique-guide-links a:last-child {
  transform: translateX(18px);
}

.boutique-reserve {
  min-height: 610px;
  margin-top: -32px;
  padding: 96px 26px 96px;
  background:
    linear-gradient(90deg, rgba(249, 241, 230, 0.96) 0%, rgba(249, 241, 230, 0.68) 52%, rgba(249, 241, 230, 0.1) 100%),
    url("./assets/photos/subpage-reserve-boutique-v1.webp") 68% 52% / cover no-repeat;
}

.boutique-reserve-copy {
  width: 248px;
  padding-top: 174px;
}

.boutique-reserve h2 {
  font-size: 2.24rem;
  line-height: 1.22;
}

.boutique-reserve-calendar {
  right: 18px;
  top: 72px;
}

.boutique-index .boutique-index-link {
  position: static !important;
}

/* Boutique19 nav clipping fix */
.boutique-index .boutique-index-link {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  overflow: visible !important;
  min-height: 0 !important;
  width: auto !important;
  height: auto !important;
  transform: none !important;
  border: 0 !important;
}

.boutique-index .boutique-index-link::before,
.boutique-index .boutique-index-link::after {
  display: none !important;
}

.boutique-index .boutique-index-link-menu .boutique-index-number,
.boutique-index .boutique-index-link-first .boutique-index-number,
.boutique-index .boutique-index-link-access .boutique-index-number,
.boutique-index .boutique-index-link-faq .boutique-index-number,
.boutique-index .boutique-index-link-menu .boutique-index-thumb,
.boutique-index .boutique-index-link-first .boutique-index-thumb,
.boutique-index .boutique-index-link-access .boutique-index-thumb,
.boutique-index .boutique-index-link-faq .boutique-index-thumb,
.boutique-index .boutique-index-link-menu .boutique-index-text,
.boutique-index .boutique-index-link-first .boutique-index-text,
.boutique-index .boutique-index-link-access .boutique-index-text,
.boutique-index .boutique-index-link-faq .boutique-index-text {
  position: absolute !important;
}

/* Boutique19 stable poster index */
.boutique-index {
  min-height: 560px !important;
  padding: 56px 22px 60px 64px !important;
}

.boutique-index .boutique-index-number,
.boutique-index .boutique-index-thumb,
.boutique-index .boutique-index-text {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.boutique-index .boutique-index-number {
  z-index: 5 !important;
  color: var(--b19-gold) !important;
}

.boutique-index .boutique-index-thumb {
  z-index: 3 !important;
  overflow: hidden !important;
}

.boutique-index .boutique-index-text {
  z-index: 6 !important;
}

.boutique-index .boutique-index-text strong {
  font-size: 1.18rem !important;
}

.boutique-index .boutique-index-text small {
  font-size: 0.6rem !important;
}

.boutique-index-link-menu .boutique-index-number {
  left: 74px !important;
  top: 58px !important;
}

.boutique-index-link-menu .boutique-index-thumb {
  left: 112px !important;
  top: 58px !important;
  width: 86px !important;
  height: 120px !important;
  border-radius: 999px 999px 12px 12px !important;
}

.boutique-index-link-menu .boutique-index-text {
  left: 212px !important;
  top: 92px !important;
  width: 120px !important;
}

.boutique-index-link-first .boutique-index-number {
  left: 248px !important;
  top: 198px !important;
}

.boutique-index-link-first .boutique-index-thumb {
  left: 202px !important;
  top: 216px !important;
  width: 84px !important;
  height: 72px !important;
  border-radius: 14px 999px 999px 14px !important;
}

.boutique-index-link-first .boutique-index-text {
  left: 102px !important;
  top: 222px !important;
  width: 112px !important;
  text-align: right !important;
}

.boutique-index-link-access .boutique-index-number {
  left: 76px !important;
  top: 322px !important;
}

.boutique-index-link-access .boutique-index-thumb {
  left: 104px !important;
  top: 332px !important;
  width: 94px !important;
  height: 126px !important;
  border-radius: 16px 16px 999px 16px !important;
}

.boutique-index-link-access .boutique-index-text {
  left: 212px !important;
  top: 366px !important;
  width: 118px !important;
}

.boutique-index-link-faq .boutique-index-number {
  left: 248px !important;
  top: 458px !important;
}

.boutique-index-link-faq .boutique-index-thumb {
  left: 178px !important;
  top: 466px !important;
  width: 86px !important;
  height: 66px !important;
  border-radius: 999px 999px 14px 14px !important;
}

.boutique-index-link-faq .boutique-index-text {
  left: 76px !important;
  top: 472px !important;
  width: 96px !important;
  text-align: right !important;
}

@media (min-width: 861px) {
  .home-body .boutique-main {
    width: min(1280px, 100vw);
  }

  .boutique-hero {
    min-height: 820px;
  }

  .boutique-hero-photo {
    right: 0;
    width: min(55vw, 680px);
    height: 680px;
  }

  .boutique-hero-copy {
    left: max(10vw, 126px);
    top: 294px;
    width: 560px;
  }

  .boutique-hero h1 {
    font-size: clamp(5rem, 8.2vw, 7rem);
  }

  .boutique-hero-copy p:last-of-type {
    width: 340px;
  }

  .boutique-index {
    width: min(1120px, calc(100vw - 96px));
    min-height: 460px;
    margin-top: -42px;
  }

  .boutique-concept,
  .boutique-treatment,
  .boutique-access,
  .boutique-reserve {
    width: min(1120px, calc(100vw - 96px));
    margin-inline: auto;
  }

  .boutique-concept-copy h2 {
    font-size: clamp(3.6rem, 5vw, 5rem);
  }

  .boutique-treatment h2 {
    font-size: clamp(3rem, 4vw, 4.4rem);
    max-width: 460px;
  }

  .boutique-treatment-copy {
    max-width: 460px;
  }
}

/* Boutique19 lower pages */
.subpage-body,
.reserve-body {
  background:
    linear-gradient(90deg, rgba(34, 31, 27, 0.08) 0 1px, transparent 1px) 22px 0 / 1px 100% no-repeat,
    linear-gradient(180deg, #efe4d4 0%, #f9f1e6 45%, #e7d8c6 100%);
}

.subpage-body .site-header,
.reserve-body .site-header {
  border: 0;
  background: linear-gradient(180deg, rgba(249, 241, 230, 0.94), rgba(249, 241, 230, 0.58));
}

.subpage-body .nav-wrap,
.reserve-body .nav-wrap {
  min-height: 64px;
  padding: 8px 22px;
}

.subpage-main,
.reserve-main {
  padding-top: 78px;
}

.subpage-hero,
.reserve-hero {
  width: min(430px, 100vw);
  min-height: 612px;
  padding: 80px 28px 84px 38px;
  background:
    repeating-linear-gradient(135deg, rgba(176, 130, 76, 0.035) 0 1px, transparent 1px 26px),
    #f9f1e6;
}

.subpage-hero::after {
  left: 24px;
  top: 132px;
  height: 230px;
}

.subpage-hero-copy,
.reserve-hero-copy {
  width: min(306px, 82vw);
  padding-top: 70px;
}

.subpage-hero h1,
.reserve-body .reserve-hero h1 {
  font-size: clamp(2.58rem, 11.4vw, 3.35rem);
  line-height: 1.16;
}

.subpage-lead,
.reserve-hero .subpage-lead {
  font-size: 0.78rem;
  line-height: 1.96;
}

.subpage-hero-media {
  right: -62px;
  bottom: 58px;
  width: 240px;
  height: 360px;
  opacity: 0.94;
}

.subpage-section,
.reserve-layout {
  width: min(430px, 100vw);
  padding-inline: 28px;
  background: #f9f1e6;
}

.subpage-section {
  padding-block: 64px;
}

.subpage-heading h2,
.reserve-side-card h2,
.availability-head h2 {
  font-size: clamp(1.82rem, 8.2vw, 2.56rem);
}

.price-card-featured,
.availability-tool,
.reserve-body .contact-form,
.reserve-body .booking-feedback {
  border-radius: 0 0 84px 0;
  background:
    linear-gradient(135deg, rgba(249, 241, 230, 0.94), rgba(223, 213, 197, 0.82)),
    repeating-linear-gradient(135deg, rgba(176, 130, 76, 0.05) 0 1px, transparent 1px 22px);
}

.reserve-hero::after {
  right: -76px;
  width: 250px;
  height: 370px;
}

.reserve-layout {
  padding: 0 18px 90px;
}

.reserve-side > img {
  border-radius: 180px 180px 24px 24px;
}

@media (max-width: 420px) {
  .reserve-body .availability-tool {
    padding: 18px 8px;
  }
}

@media (min-width: 861px) {
  .subpage-hero,
  .subpage-section,
  .reserve-hero,
  .reserve-layout {
    width: min(1120px, calc(100vw - 96px));
  }
}

/* Reference1: remembered mobile boutique mock alignment */
.home-body {
  --ref-paper: #fbf7f0;
  --ref-ink: #302c27;
  --ref-muted: #807465;
  --ref-gold: #ae8650;
  --ref-line: rgba(174, 134, 80, 0.42);
  --ref-sage: #818979;
  min-width: 0 !important;
  background: #171512 !important;
  color: var(--ref-ink) !important;
  font-family: "Cormorant Garamond", "Yu Mincho", "Hiragino Mincho ProN", serif !important;
}

.home-body .page-shell {
  width: min(100%, 460px) !important;
  min-height: 100vh !important;
  margin: 0 auto !important;
  overflow: hidden !important;
  background: var(--ref-paper) !important;
  border-radius: 8px !important;
  box-shadow: 0 18px 70px rgba(0, 0, 0, 0.24) !important;
}

.home-body .page-shell::before,
.home-body .page-shell::after,
.home-body .ambient,
.boutique-main::before,
.boutique-main::after {
  display: none !important;
  content: none !important;
}

.home-body .site-header {
  position: absolute !important;
  inset: 0 0 auto !important;
  z-index: 20 !important;
  width: min(100%, 460px) !important;
  height: 64px !important;
  margin: 0 auto !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
  opacity: 1 !important;
}

.home-body .topbar {
  display: none !important;
}

.home-body .nav-wrap {
  position: relative !important;
  width: 100% !important;
  min-height: 64px !important;
  padding: 12px 18px 0 24px !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  background: transparent !important;
}

.home-body .nav-wrap::after {
  content: "Private Salon" !important;
  position: absolute !important;
  top: 24px !important;
  right: 48px !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.55rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.home-body .brand {
  width: auto !important;
  height: auto !important;
  color: #a5793f !important;
  text-decoration: none !important;
}

.home-body .brand-copy-script strong {
  display: block !important;
  color: #9f743e !important;
  font-family: "Parisienne", cursive !important;
  font-size: 3.05rem !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.72 !important;
}

.home-body .brand-copy-script small {
  display: block !important;
  margin-top: -2px !important;
  padding-left: 46px !important;
  color: #9f743e !important;
  font-size: 0.56rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.28em !important;
  line-height: 1 !important;
}

.home-body .menu-toggle {
  display: inline-grid !important;
  place-items: center !important;
  width: 22px !important;
  height: 22px !important;
  margin-top: 4px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.home-body .menu-toggle span {
  width: 14px !important;
  height: 1px !important;
  margin: 0 !important;
  background: #b0834d !important;
}

.home-body .site-nav {
  top: 48px !important;
  right: 16px !important;
  width: 176px !important;
  padding: 14px !important;
  border: 1px solid rgba(174, 134, 80, 0.22) !important;
  background: rgba(251, 247, 240, 0.96) !important;
}

.boutique-main {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  background: var(--ref-paper) !important;
}

.boutique-main img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.boutique-main .reveal {
  opacity: 1 !important;
  transform: none !important;
}

.boutique-hero {
  position: relative !important;
  width: 100% !important;
  min-height: 352px !important;
  height: 352px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 0 !important;
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.98) 0 50%, rgba(251, 247, 240, 0.66) 50% 100%),
    #fbf7f0 !important;
}

.boutique-hero::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 51px !important;
  top: 115px !important;
  width: 1px !important;
  height: 154px !important;
  background: linear-gradient(180deg, transparent, var(--ref-line) 12%, var(--ref-line) 88%, transparent) !important;
  z-index: 3 !important;
}

.boutique-hero::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 176px !important;
  bottom: -8px !important;
  width: 155px !important;
  height: 78px !important;
  border-radius: 999px 999px 0 0 !important;
  background: rgba(255, 255, 255, 0.58) !important;
  z-index: 4 !important;
}

.boutique-hero-location {
  position: absolute !important;
  top: 36px !important;
  right: 74px !important;
  z-index: 6 !important;
  margin: 0 !important;
  color: #6e6459 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.45rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  line-height: 1 !important;
  text-transform: none !important;
}

.boutique-hero > .boutique-script-ghost {
  position: absolute !important;
  left: 38px !important;
  top: 86px !important;
  z-index: 2 !important;
  display: block !important;
  margin: 0 !important;
  color: rgba(174, 134, 80, 0.46) !important;
  font-family: "Parisienne", cursive !important;
  font-size: 8.6rem !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 0.66 !important;
  opacity: 1 !important;
  transform: rotate(-8deg) !important;
  pointer-events: none !important;
}

.boutique-hero-photo {
  position: absolute !important;
  right: 18px !important;
  top: 58px !important;
  z-index: 1 !important;
  width: 190px !important;
  height: 292px !important;
  overflow: hidden !important;
  border-radius: 160px 160px 0 0 !important;
  background: #e9dfd2 !important;
  box-shadow: none !important;
  opacity: 1 !important;
}

.boutique-hero-photo::before,
.boutique-hero-photo::after {
  display: none !important;
  content: none !important;
}

.boutique-hero-photo img {
  object-position: 61% 50% !important;
  filter: saturate(0.82) brightness(1.06) contrast(0.95) !important;
}

.boutique-hero-copy {
  position: absolute !important;
  left: 47px !important;
  top: 166px !important;
  z-index: 8 !important;
  width: 188px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.boutique-hero .boutique-kicker {
  display: none !important;
}

.boutique-hero h1 {
  margin: 0 !important;
  color: #26231f !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 1.62rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.34 !important;
}

.boutique-hero h1::after {
  content: "" !important;
  display: block !important;
  width: 36px !important;
  height: 1px !important;
  margin: 11px 0 13px !important;
  background: var(--ref-line) !important;
}

.boutique-hero h1 span {
  display: block !important;
}

.boutique-hero-copy p:last-of-type {
  width: 164px !important;
  margin: 0 !important;
  color: #6e665d !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 0.58rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.9 !important;
}

.boutique-hero-links {
  display: flex !important;
  align-items: center !important;
  gap: 31px !important;
  margin-top: 16px !important;
}

.boutique-hero-links a {
  position: relative !important;
  min-width: 0 !important;
  height: auto !important;
  padding: 0 26px 4px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--ref-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #4a4037 !important;
  box-shadow: none !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 0.65rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
}

.boutique-hero-links a::after {
  content: "" !important;
  position: absolute !important;
  right: 0 !important;
  top: 0.38em !important;
  width: 18px !important;
  height: 1px !important;
  background: var(--ref-line) !important;
  transform: none !important;
}

.boutique-index {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-height: 121px !important;
  height: 121px !important;
  margin: 0 !important;
  padding: 14px 50px 13px 54px !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: rgba(255, 253, 249, 0.96) !important;
  box-shadow: none !important;
}

.boutique-index::before,
.boutique-index::after {
  display: none !important;
  content: none !important;
}

.boutique-index .boutique-index-link {
  position: relative !important;
  inset: auto !important;
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) 24px !important;
  align-items: center !important;
  width: 100% !important;
  height: 23px !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(174, 134, 80, 0.36) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--ref-ink) !important;
  text-decoration: none !important;
  box-shadow: none !important;
  transform: none !important;
}

.boutique-index .boutique-index-link + .boutique-index-link {
  margin-top: 1px !important;
}

.boutique-index .boutique-index-link::before {
  display: none !important;
  content: none !important;
}

.boutique-index .boutique-index-link::after {
  content: "" !important;
  display: block !important;
  justify-self: end !important;
  width: 18px !important;
  height: 1px !important;
  background: var(--ref-line) !important;
  transform: none !important;
}

.boutique-index .boutique-index-number,
.boutique-index .boutique-index-thumb,
.boutique-index .boutique-index-text {
  position: static !important;
  inset: auto !important;
  transform: none !important;
}

.boutique-index .boutique-index-number {
  grid-column: 1 !important;
  color: #a77945 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.98rem !important;
  font-weight: 600 !important;
  font-style: normal !important;
  letter-spacing: 0.09em !important;
  line-height: 1 !important;
}

.boutique-index .boutique-index-thumb {
  display: none !important;
}

.boutique-index .boutique-index-text {
  grid-column: 2 !important;
  display: block !important;
  width: auto !important;
  text-align: left !important;
}

.boutique-index .boutique-index-text strong {
  display: block !important;
  color: #3b342d !important;
  font-family: "Cormorant Garamond", "Yu Mincho", serif !important;
  font-size: 0.74rem !important;
  font-weight: 500 !important;
  font-style: normal !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
}

.boutique-index .boutique-index-text small {
  display: none !important;
}

.boutique-concept {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-height: 204px !important;
  height: 204px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #fbf7f0 !important;
}

.boutique-section-label {
  position: absolute !important;
  left: 46px !important;
  top: 34px !important;
  display: block !important;
  margin: 0 !important;
  color: #a77945 !important;
  writing-mode: horizontal-tb !important;
  transform: none !important;
  z-index: 4 !important;
}

.boutique-section-label span {
  display: inline-block !important;
  font-size: 0.62rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  text-transform: none !important;
}

.boutique-section-label::after {
  content: "" !important;
  display: inline-block !important;
  width: 28px !important;
  height: 1px !important;
  margin-left: 8px !important;
  vertical-align: middle !important;
  background: var(--ref-line) !important;
}

.boutique-concept-copy {
  position: absolute !important;
  left: 47px !important;
  top: 70px !important;
  z-index: 4 !important;
  width: 152px !important;
  padding: 0 !important;
}

.boutique-concept-copy::before {
  content: "" !important;
  position: absolute !important;
  left: -1px !important;
  bottom: -26px !important;
  width: 42px !important;
  height: 12px !important;
  border-bottom: 1px solid var(--ref-line) !important;
  border-radius: 50% !important;
  transform: rotate(-3deg) !important;
}

.boutique-concept-copy h2 {
  margin: 0 0 14px !important;
  color: #292622 !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 1.16rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.78 !important;
}

.boutique-concept-copy p {
  margin: 0 !important;
  color: #6f665b !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 0.52rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.8 !important;
}

.boutique-concept-photo {
  position: absolute !important;
  right: 0 !important;
  top: 18px !important;
  z-index: 2 !important;
  width: 212px !important;
  height: 156px !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 0 !important;
  background: #e9dfd2 !important;
  box-shadow: none !important;
}

.boutique-concept-photo::before,
.boutique-concept-photo::after,
.boutique-concept-photo figcaption {
  display: none !important;
  content: none !important;
}

.boutique-concept-photo img {
  object-position: 58% 45% !important;
  filter: saturate(0.78) brightness(1.08) contrast(0.96) !important;
}

.boutique-treatment {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-height: 166px !important;
  height: 166px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    linear-gradient(90deg, rgba(89, 94, 78, 0.56) 0%, rgba(119, 127, 107, 0.74) 42%, rgba(96, 105, 91, 0.82) 100%),
    url("./assets/photos/boutique-treatment-still-v2.webp") 47% 50% / cover no-repeat !important;
  color: #fffaf2 !important;
  box-shadow: none !important;
}

.boutique-treatment::before,
.boutique-treatment::after {
  display: none !important;
  content: none !important;
}

.boutique-treatment-photo {
  display: none !important;
}

.boutique-treatment-copy {
  position: absolute !important;
  right: 42px !important;
  top: 25px !important;
  z-index: 3 !important;
  width: 205px !important;
  max-width: 205px !important;
  padding: 0 !important;
  text-align: center !important;
  color: #fffaf2 !important;
}

.boutique-treatment .boutique-kicker {
  margin: 0 0 4px !important;
  color: rgba(255, 250, 242, 0.72) !important;
  font-size: 0.48rem !important;
  letter-spacing: 0.12em !important;
  text-transform: none !important;
}

.boutique-treatment .boutique-kicker::before {
  content: "o" !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 0 2px !important;
  background: transparent !important;
  color: #ead8bf !important;
  font-size: 0.62rem !important;
}

.boutique-treatment h2 {
  margin: 0 !important;
  color: #fffaf2 !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 1.26rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.03em !important;
  line-height: 1.35 !important;
}

.boutique-treatment h2 span {
  display: inline !important;
  color: #fffaf2 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.72rem !important;
  font-style: italic !important;
  letter-spacing: 0.02em !important;
}

.boutique-treatment-copy p {
  margin: 7px 0 0 !important;
  color: rgba(255, 250, 242, 0.86) !important;
  font-size: 0.55rem !important;
  line-height: 1.65 !important;
}

.boutique-treatment .boutique-inline-link {
  display: inline-block !important;
  margin-top: 8px !important;
  padding: 0 34px 0 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #fffaf2 !important;
  font-size: 0.58rem !important;
  letter-spacing: 0 !important;
}

.boutique-treatment .boutique-inline-link::after {
  right: 0 !important;
  width: 24px !important;
  background: rgba(255, 250, 242, 0.52) !important;
}

.boutique-menu-lines {
  position: absolute !important;
  left: 122px !important;
  right: 40px !important;
  bottom: 18px !important;
  z-index: 4 !important;
  display: block !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}

.boutique-menu-lines a {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 6px !important;
  align-items: center !important;
  min-height: 20px !important;
  padding: 4px 0 !important;
  border: 0 !important;
  border-top: 1px solid rgba(255, 250, 242, 0.34) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #fffaf2 !important;
}

.boutique-menu-lines a::before,
.boutique-menu-lines a::after {
  display: none !important;
  content: none !important;
}

.boutique-menu-lines span {
  display: none !important;
}

.boutique-menu-lines strong {
  grid-column: 1 !important;
  color: rgba(255, 250, 242, 0.9) !important;
  font-size: 0.54rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
}

.boutique-menu-lines small {
  grid-column: 2 !important;
  color: rgba(255, 250, 242, 0.88) !important;
  font-size: 0.52rem !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
}

.boutique-access {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 92px 94px !important;
  gap: 12px !important;
  align-items: center !important;
  width: 100% !important;
  min-height: 151px !important;
  height: 151px !important;
  margin: 0 !important;
  padding: 22px 38px 20px 46px !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #fbf7f0 !important;
  box-shadow: none !important;
}

.boutique-access-copy {
  position: relative !important;
  grid-column: 1 !important;
  z-index: 3 !important;
  width: auto !important;
  max-width: none !important;
  padding: 0 !important;
}

.boutique-access-copy .boutique-kicker {
  margin: 0 0 16px !important;
  color: #a77945 !important;
  font-size: 0.62rem !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.boutique-access-copy .boutique-kicker::after {
  content: "" !important;
  display: block !important;
  width: 32px !important;
  height: 1px !important;
  margin-top: 10px !important;
  background: var(--ref-line) !important;
}

.boutique-access h2 {
  display: none !important;
}

.boutique-access p:not(.boutique-kicker) {
  width: 132px !important;
  margin: 0 !important;
  color: #766d62 !important;
  font-size: 0.52rem !important;
  line-height: 1.75 !important;
}

.boutique-access .boutique-inline-link {
  display: inline-block !important;
  margin-top: 13px !important;
  padding: 0 32px 3px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--ref-line) !important;
  color: #8d693e !important;
  background: transparent !important;
  font-size: 0.56rem !important;
}

.boutique-access .boutique-inline-link::after {
  right: 0 !important;
  width: 18px !important;
  background: var(--ref-line) !important;
}

.boutique-access-photo {
  position: relative !important;
  grid-column: 2 !important;
  z-index: 2 !important;
  width: 92px !important;
  height: 92px !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.boutique-access-photo img {
  object-position: 54% 48% !important;
  filter: saturate(0.82) brightness(1.02) contrast(0.94) !important;
}

.boutique-route {
  position: absolute !important;
  right: 34px !important;
  top: 18px !important;
  z-index: 1 !important;
  width: 94px !important;
  height: 118px !important;
  margin: 0 !important;
  opacity: 1 !important;
  background:
    linear-gradient(115deg, transparent 0 44%, var(--ref-line) 44% 45%, transparent 45%),
    linear-gradient(64deg, transparent 0 49%, var(--ref-line) 49% 50%, transparent 50%),
    linear-gradient(90deg, transparent 0 59%, var(--ref-line) 59% 60%, transparent 60%) !important;
}

.boutique-route::before,
.boutique-route::after {
  content: "" !important;
  position: absolute !important;
  display: block !important;
  border: 1px solid var(--ref-line) !important;
  border-radius: 50% !important;
  background: var(--ref-paper) !important;
}

.boutique-route::before {
  right: 44px !important;
  top: 50px !important;
  width: 10px !important;
  height: 10px !important;
}

.boutique-route::after {
  right: 35px !important;
  top: 41px !important;
  width: 4px !important;
  height: 4px !important;
}

.boutique-guide-links {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  width: 100% !important;
  min-height: 82px !important;
  height: 82px !important;
  margin: 0 !important;
  padding: 0 38px 0 52px !important;
  overflow: hidden !important;
  border: 0 !important;
  border-top: 1px solid rgba(174, 134, 80, 0.25) !important;
  border-bottom: 1px solid rgba(174, 134, 80, 0.18) !important;
  background: rgba(255, 253, 249, 0.94) !important;
  box-shadow: none !important;
}

.boutique-guide-links::before,
.boutique-guide-links::after {
  display: none !important;
  content: none !important;
}

.boutique-guide-links a {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 31px minmax(0, 1fr) 22px !important;
  align-items: center !important;
  min-height: 82px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #3b342d !important;
}

.boutique-guide-links a:first-child {
  border-right: 1px solid rgba(174, 134, 80, 0.28) !important;
  padding-right: 15px !important;
}

.boutique-guide-links a:last-child {
  padding-left: 15px !important;
}

.boutique-guide-links a::after {
  content: "" !important;
  justify-self: end !important;
  width: 16px !important;
  height: 1px !important;
  background: var(--ref-line) !important;
  transform: none !important;
}

.boutique-guide-links span {
  grid-column: 1 !important;
  grid-row: 1 !important;
  color: #a77945 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0 !important;
  letter-spacing: 0 !important;
}

.boutique-guide-links a:first-child span::before {
  content: "01" !important;
}

.boutique-guide-links a:last-child span::before {
  content: "02" !important;
}

.boutique-guide-links span::before {
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
}

.boutique-guide-links strong {
  grid-column: 2 !important;
  grid-row: 1 !important;
  color: #332d27 !important;
  font-family: "Cormorant Garamond", "Yu Mincho", serif !important;
  font-size: 0 !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
}

.boutique-guide-links a:first-child strong::before {
  content: "Column" !important;
}

.boutique-guide-links a:last-child strong::before {
  content: "FAQ" !important;
}

.boutique-guide-links strong::before {
  font-size: 0.74rem !important;
}

.boutique-guide-links small {
  display: none !important;
}

.boutique-reserve {
  position: relative !important;
  display: grid !important;
  place-items: center !important;
  width: 100% !important;
  min-height: 128px !important;
  height: 128px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 0 !important;
  border-radius: 0 !important;
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.92) 0%, rgba(251, 247, 240, 0.74) 48%, rgba(251, 247, 240, 0.4) 100%),
    url("./assets/photos/boutique-reserve-cta-v2.webp") 50% 60% / cover no-repeat !important;
  box-shadow: none !important;
}

.boutique-reserve::before,
.boutique-reserve::after {
  display: none !important;
  content: none !important;
}

.boutique-reserve > .boutique-script-ghost {
  position: absolute !important;
  left: 54px !important;
  top: 38px !important;
  display: block !important;
  color: rgba(174, 134, 80, 0.18) !important;
  font-family: "Parisienne", cursive !important;
  font-size: 5.7rem !important;
  line-height: 0.8 !important;
  transform: rotate(-7deg) !important;
  opacity: 1 !important;
}

.boutique-reserve-calendar {
  display: none !important;
}

.boutique-reserve-copy {
  position: relative !important;
  z-index: 3 !important;
  width: 230px !important;
  max-width: 230px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  text-align: center !important;
  color: var(--ref-ink) !important;
}

.boutique-reserve-copy .boutique-kicker {
  display: none !important;
}

.boutique-reserve h2 {
  margin: 0 0 8px !important;
  color: #342f29 !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 1.18rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.08em !important;
  line-height: 1.25 !important;
}

.boutique-reserve h2::before,
.boutique-reserve h2::after {
  content: "" !important;
  display: inline-block !important;
  width: 38px !important;
  height: 1px !important;
  margin: 0 9px 0.35em !important;
  background: var(--ref-line) !important;
}

.boutique-reserve-copy p:not(.boutique-kicker) {
  margin: 0 0 10px !important;
  color: #776d63 !important;
  font-size: 0.52rem !important;
  line-height: 1.55 !important;
}

.boutique-reserve-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 158px !important;
  height: 26px !important;
  padding: 0 34px 0 30px !important;
  border: 1px solid rgba(174, 134, 80, 0.62) !important;
  border-radius: 999px !important;
  background: rgba(255, 253, 249, 0.62) !important;
  color: #8b663c !important;
  box-shadow: none !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif !important;
  font-size: 0.62rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.08em !important;
}

.boutique-reserve-button::after {
  content: "" !important;
  position: absolute !important;
  right: 22px !important;
  width: 22px !important;
  height: 1px !important;
  background: var(--ref-line) !important;
}

.home-body .site-footer {
  position: relative !important;
  width: 100% !important;
  min-height: 61px !important;
  margin: 0 !important;
  padding: 12px 26px 13px !important;
  border: 0 !important;
  background: #fbf7f0 !important;
  color: #6c6258 !important;
  box-shadow: none !important;
}

.boutique-footer-script {
  position: absolute !important;
  left: 26px !important;
  top: 10px !important;
  margin: 0 !important;
  color: #a77945 !important;
  font-family: "Parisienne", cursive !important;
  font-size: 2.35rem !important;
  line-height: 0.8 !important;
}

.home-body .site-footer > p:not(.boutique-footer-script):not(.footer-links) {
  display: none !important;
}

.home-body .footer-links {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 23px 0 0 92px !important;
  padding: 0 !important;
  flex-wrap: nowrap !important;
}

.home-body .footer-links a {
  display: inline-block !important;
  color: #6c6258 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

.home-body .footer-links a:nth-child(1)::before {
  content: "Menu" !important;
}

.home-body .footer-links a:nth-child(2)::before {
  content: "Column" !important;
}

.home-body .footer-links a:nth-child(3)::before {
  content: "Access" !important;
}

.home-body .footer-links a:nth-child(4)::before {
  content: "FAQ" !important;
}

.home-body .footer-links a:nth-child(5)::before {
  content: "予約" !important;
}

.home-body .footer-links a:nth-child(n+6) {
  display: none !important;
}

.home-body .footer-links a::before {
  font-size: 0.48rem !important;
}

@media (max-width: 374px) {
  .home-body .brand-copy-script strong {
    font-size: 2.7rem !important;
  }

  .home-body .nav-wrap::after {
    right: 42px !important;
  }

  .boutique-hero-copy {
    left: 40px !important;
  }

  .boutique-hero-photo {
    right: 10px !important;
    width: 178px !important;
  }

  .boutique-index {
    padding-inline: 44px 42px !important;
  }

  .boutique-concept-copy {
    left: 40px !important;
    width: 145px !important;
  }

  .boutique-concept-photo {
    width: 196px !important;
  }

  .boutique-treatment-copy {
    right: 30px !important;
  }

  .boutique-access {
    grid-template-columns: minmax(0, 1fr) 82px 82px !important;
    padding-inline: 38px 28px !important;
  }

  .boutique-access-photo {
    width: 82px !important;
    height: 82px !important;
  }
}

@media (min-width: 461px) {
  .home-body .site-header {
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
  }
}

/* Reference1 micro-fit */
.boutique-hero > .boutique-script-ghost {
  left: 44px !important;
  top: 92px !important;
  color: rgba(174, 134, 80, 0.38) !important;
  font-size: 7.45rem !important;
}

.boutique-hero-photo {
  right: 18px !important;
  width: 172px !important;
}

.boutique-hero-copy {
  width: 158px !important;
}

.boutique-hero h1 {
  font-size: 1.45rem !important;
  line-height: 1.38 !important;
}

.boutique-hero-copy p:last-of-type {
  width: 150px !important;
}

.boutique-concept-copy {
  width: 151px !important;
  left: 46px !important;
}

.boutique-concept-copy h2 {
  width: 151px !important;
  max-width: 151px !important;
  font-size: 1.08rem !important;
  line-height: 1.72 !important;
}

.boutique-concept-copy p {
  width: 136px !important;
  max-width: 136px !important;
}

.boutique-concept-photo {
  right: 0 !important;
  left: auto !important;
  width: 202px !important;
}

.boutique-access-copy,
.boutique-access-photo {
  inset: auto !important;
}

.boutique-access-copy {
  justify-self: start !important;
  align-self: center !important;
}

.boutique-access-photo {
  align-self: center !important;
  justify-self: start !important;
}

.boutique-reserve-copy {
  width: 220px !important;
  max-width: 220px !important;
}

.boutique-reserve h2 {
  font-size: 1.24rem !important;
}

.boutique-access {
  display: block !important;
  padding: 0 !important;
}

.boutique-access-copy {
  position: absolute !important;
  left: 46px !important;
  top: 24px !important;
  width: 136px !important;
  height: auto !important;
}

.boutique-access-photo {
  position: absolute !important;
  left: 205px !important;
  top: 35px !important;
  width: 92px !important;
  height: 92px !important;
}

.boutique-route {
  right: 30px !important;
  top: 16px !important;
}

.home-body .nav-wrap {
  position: static !important;
  min-height: 64px !important;
  padding: 0 !important;
}

.home-body .brand {
  position: absolute !important;
  left: 24px !important;
  top: 13px !important;
}

.home-body .nav-wrap::after {
  top: 25px !important;
  right: 54px !important;
}

.home-body .menu-toggle {
  position: absolute !important;
  right: 22px !important;
  top: 17px !important;
  margin: 0 !important;
}

.home-body .site-nav {
  top: 48px !important;
  right: 18px !important;
}

.boutique-treatment-copy {
  right: 30px !important;
  width: 228px !important;
  max-width: 228px !important;
}

.boutique-menu-lines {
  left: 84px !important;
  right: 40px !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) minmax(82px, auto) !important;
  gap: 4px !important;
}

.boutique-menu-lines strong {
  font-size: 0.5rem !important;
}

.boutique-menu-lines small {
  font-size: 0.44rem !important;
  text-align: right !important;
}

.home-body {
  margin: 0 !important;
  padding: 0 !important;
}

.home-body .page-shell {
  width: 100% !important;
  max-width: 460px !important;
}

.home-body .site-header::after {
  content: "Private Salon" !important;
  position: absolute !important;
  top: 25px !important;
  left: 286px !important;
  z-index: 4 !important;
  width: 58px !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.5rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.home-body .nav-wrap::after,
.boutique-hero-location {
  display: none !important;
  content: none !important;
}

.home-body .menu-toggle {
  left: 348px !important;
  right: auto !important;
}

.boutique-treatment-copy {
  right: 54px !important;
  width: 210px !important;
  max-width: 210px !important;
}

.boutique-menu-lines {
  left: 76px !important;
  right: 66px !important;
}

.boutique-menu-lines small {
  font-size: 0.4rem !important;
}

.boutique-treatment-copy {
  right: 74px !important;
  width: 185px !important;
  max-width: 185px !important;
}

.boutique-treatment-copy p {
  font-size: 0.48rem !important;
  line-height: 1.55 !important;
}

.boutique-menu-lines {
  left: 94px !important;
  right: 86px !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) minmax(68px, auto) !important;
}

.boutique-menu-lines strong {
  font-size: 0.46rem !important;
}

.boutique-menu-lines small {
  font-size: 0.34rem !important;
}

.boutique-treatment-copy p {
  white-space: normal !important;
  overflow-wrap: normal !important;
}

.boutique-treatment-copy {
  left: 150px !important;
  right: auto !important;
  width: 180px !important;
  max-width: 180px !important;
}

.boutique-menu-lines {
  left: 104px !important;
  right: 82px !important;
}

/* Reference7: close remaining visual gaps with the saved reference */
html {
  background: #171512 !important;
}

body.home-body {
  width: 100% !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
}

.home-body .page-shell {
  width: 100vw !important;
  max-width: 460px !important;
  margin: 0 auto !important;
}

@media (max-width: 460px) {
  .home-body .page-shell {
    max-width: none !important;
    border-radius: 0 !important;
  }
}

.home-body .site-header::after {
  content: "Kanayama Private Salon" !important;
  left: auto !important;
  right: 53px !important;
  top: 25px !important;
  width: auto !important;
  font-size: 0.45rem !important;
}

.home-body .menu-toggle {
  left: auto !important;
  right: 20px !important;
}

.boutique-hero {
  height: 352px !important;
  min-height: 352px !important;
}

.boutique-hero > .boutique-script-ghost {
  left: 38px !important;
  top: 92px !important;
  color: rgba(174, 134, 80, 0.34) !important;
  font-size: 7.25rem !important;
}

.boutique-hero-photo {
  right: 12px !important;
  top: 58px !important;
  width: 180px !important;
  height: 292px !important;
  border-radius: 170px 170px 0 0 !important;
}

.boutique-hero-photo img {
  object-position: 50% 52% !important;
  filter: saturate(0.78) brightness(1.08) contrast(0.94) !important;
}

.boutique-hero::after {
  left: 176px !important;
  bottom: -3px !important;
  width: 148px !important;
  height: 72px !important;
  background: rgba(255, 255, 255, 0.5) !important;
}

.boutique-hero-copy {
  left: 47px !important;
  top: 165px !important;
  width: 188px !important;
}

.boutique-hero h1 {
  width: 188px !important;
  font-size: 1.24rem !important;
  line-height: 1.54 !important;
}

.boutique-hero-copy p:last-of-type {
  width: 158px !important;
  margin-top: 0 !important;
}

.boutique-hero-links {
  margin-top: 14px !important;
}

.boutique-concept-photo {
  right: 0 !important;
  top: 18px !important;
  width: 222px !important;
  height: 158px !important;
}

.boutique-concept-photo img {
  object-position: 50% 48% !important;
}

.boutique-treatment {
  height: 166px !important;
  min-height: 166px !important;
  background:
    linear-gradient(90deg, rgba(103, 111, 96, 0.86), rgba(116, 124, 106, 0.9)),
    #78816f !important;
}

.boutique-treatment::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  z-index: 1 !important;
  width: 145px !important;
  height: 166px !important;
  background: url("./assets/photos/boutique-treatment-still-v2.webp") 75% 50% / cover no-repeat !important;
  opacity: 0.92 !important;
  transform: scaleX(-1) !important;
  transform-origin: center !important;
}

.boutique-treatment::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  background:
    linear-gradient(90deg, rgba(77, 82, 68, 0.1) 0 34%, rgba(103, 111, 96, 0.58) 42%, rgba(103, 111, 96, 0.42) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), transparent 58%) !important;
  pointer-events: none !important;
}

.boutique-treatment-copy {
  left: 171px !important;
  top: 22px !important;
  z-index: 4 !important;
  width: 170px !important;
  max-width: 170px !important;
}

.boutique-treatment h2 {
  font-size: 1.17rem !important;
}

.boutique-treatment h2 span {
  font-size: 0.68rem !important;
}

.boutique-treatment-copy p {
  font-size: 0.43rem !important;
  line-height: 1.55 !important;
}

.boutique-treatment .boutique-inline-link {
  margin-top: 6px !important;
  font-size: 0.53rem !important;
}

.boutique-menu-lines {
  left: 116px !important;
  right: 42px !important;
  bottom: 17px !important;
  z-index: 4 !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 78px !important;
  min-height: 17px !important;
  padding: 3px 0 !important;
}

.boutique-menu-lines strong {
  font-size: 0.43rem !important;
}

.boutique-menu-lines small {
  font-size: 0.34rem !important;
}

.boutique-route {
  right: 14px !important;
  top: 11px !important;
  width: 124px !important;
  height: 132px !important;
  opacity: 1 !important;
  background:
    linear-gradient(115deg, transparent 0 43%, rgba(174, 134, 80, 0.62) 43% 44%, transparent 44%),
    linear-gradient(64deg, transparent 0 49%, rgba(174, 134, 80, 0.62) 49% 50%, transparent 50%),
    linear-gradient(90deg, transparent 0 59%, rgba(174, 134, 80, 0.5) 59% 60%, transparent 60%) !important;
}

.boutique-route::before {
  right: 58px !important;
  top: 57px !important;
  width: 11px !important;
  height: 11px !important;
}

.boutique-route::after {
  right: 45px !important;
  top: 44px !important;
  width: 4px !important;
  height: 4px !important;
}

.boutique-access-photo {
  left: 222px !important;
  top: 35px !important;
  width: 86px !important;
  height: 92px !important;
}

.boutique-access-photo img {
  object-position: 47% 52% !important;
}

.boutique-reserve {
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.82) 0%, rgba(251, 247, 240, 0.68) 42%, rgba(251, 247, 240, 0.28) 100%),
    url("./assets/photos/boutique-reserve-cta-v2.webp") 54% 62% / cover no-repeat !important;
}

.boutique-reserve > .boutique-script-ghost {
  color: rgba(174, 134, 80, 0.22) !important;
}

.home-body .site-footer {
  min-height: 56px !important;
  padding-top: 9px !important;
  padding-bottom: 9px !important;
}

.boutique-footer-script {
  top: 8px !important;
  font-size: 2.18rem !important;
}

.home-body .footer-links {
  margin-top: 22px !important;
}

/* Reference8: typography placement lock */
.boutique-hero-copy,
.boutique-concept-copy,
.boutique-treatment-copy,
.boutique-access-copy,
.boutique-reserve-copy,
.boutique-section-label,
.boutique-index .boutique-index-number,
.boutique-index .boutique-index-text {
  margin: 0 !important;
}

.boutique-hero-copy {
  left: 47px !important;
  top: 172px !important;
  width: 190px !important;
}

.boutique-hero h1 {
  width: 190px !important;
  margin: 0 !important;
  font-size: 1.18rem !important;
  line-height: 1.56 !important;
}

.boutique-hero h1 span {
  display: block !important;
  white-space: nowrap !important;
}

.boutique-hero h1::after {
  width: 36px !important;
  margin: 8px 0 12px !important;
}

.boutique-hero-copy p:last-of-type {
  width: 162px !important;
  margin: 0 !important;
  font-size: 0.55rem !important;
  line-height: 1.86 !important;
}

.boutique-hero-links {
  gap: 32px !important;
  margin-top: 14px !important;
}

.boutique-index {
  padding: 14px 50px 13px 54px !important;
}

.boutique-index .boutique-index-link {
  grid-template-columns: 42px minmax(0, 1fr) 24px !important;
}

.boutique-index .boutique-index-number {
  justify-self: start !important;
}

.boutique-index .boutique-index-text {
  justify-self: start !important;
  text-align: left !important;
}

.boutique-concept-copy {
  left: 46px !important;
  top: 75px !important;
  width: 156px !important;
}

.boutique-section-label {
  left: 46px !important;
  top: 41px !important;
  width: auto !important;
  height: 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  line-height: 1 !important;
  writing-mode: horizontal-tb !important;
  white-space: nowrap !important;
}

.boutique-section-label span {
  writing-mode: horizontal-tb !important;
  transform: none !important;
  display: block !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
}

.boutique-section-label::after {
  display: block !important;
  flex: 0 0 28px !important;
  width: 28px !important;
  height: 1px !important;
  margin: 0 !important;
}

.boutique-concept-copy h2 {
  width: 156px !important;
  max-width: 156px !important;
  margin: 0 0 12px !important;
  font-size: 1.03rem !important;
  line-height: 1.74 !important;
}

.boutique-concept-copy p {
  width: 138px !important;
  max-width: 138px !important;
  margin: 0 !important;
  font-size: 0.52rem !important;
  line-height: 1.76 !important;
}

.boutique-treatment-copy {
  left: 170px !important;
  top: 23px !important;
  width: 172px !important;
  max-width: 172px !important;
  margin: 0 !important;
  text-align: center !important;
}

.boutique-treatment .boutique-kicker {
  display: block !important;
  height: 0 !important;
  margin: 0 !important;
  opacity: 0 !important;
  overflow: hidden !important;
}

.boutique-treatment h2 {
  margin: 0 !important;
  font-size: 1.14rem !important;
  line-height: 1.32 !important;
}

.boutique-treatment h2 span {
  font-size: 0.66rem !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 172px !important;
  margin: 7px 0 0 !important;
  font-size: 0.42rem !important;
  line-height: 1.55 !important;
}

.boutique-treatment .boutique-inline-link {
  margin-top: 6px !important;
}

.boutique-menu-lines {
  left: 114px !important;
  right: 43px !important;
  bottom: 17px !important;
}

.boutique-access-copy {
  left: 47px !important;
  top: 23px !important;
  width: 145px !important;
  margin: 0 !important;
}

.boutique-access-copy .boutique-kicker {
  width: 145px !important;
  margin: 0 0 16px !important;
  font-size: 0.62rem !important;
  line-height: 1.2 !important;
}

.boutique-access p:not(.boutique-kicker) {
  width: 136px !important;
  margin: 0 !important;
  font-size: 0.52rem !important;
  line-height: 1.75 !important;
}

.boutique-access .boutique-inline-link {
  margin-top: 12px !important;
}

.boutique-guide-links {
  padding-left: 52px !important;
  padding-right: 38px !important;
}

.boutique-guide-links a {
  grid-template-columns: 31px minmax(0, 1fr) 22px !important;
}

.boutique-guide-links a:first-child strong::before,
.boutique-guide-links a:last-child strong::before {
  display: inline-block !important;
  line-height: 1.1 !important;
}

.boutique-reserve-copy {
  width: 224px !important;
  max-width: 224px !important;
  margin: 0 auto !important;
}

.boutique-reserve h2 {
  margin: 0 0 8px !important;
  font-size: 1.18rem !important;
  line-height: 1.22 !important;
}

.boutique-reserve-copy p:not(.boutique-kicker) {
  margin: 0 0 10px !important;
}

.home-body .site-header::after {
  content: "Kanayama Private Salon" !important;
  right: 48px !important;
  top: 25px !important;
  font-size: 0.5rem !important;
  color: #6f6559 !important;
}

/* Reference13: final visual balance pass */
.boutique-hero {
  height: 354px !important;
  min-height: 354px !important;
}

.boutique-hero > .boutique-script-ghost {
  left: 39px !important;
  top: 103px !important;
  color: rgba(174, 134, 80, 0.27) !important;
  font-size: 6.82rem !important;
  line-height: 0.68 !important;
}

.boutique-hero-photo {
  right: 8px !important;
  top: 58px !important;
  width: 196px !important;
  height: 294px !important;
  border-radius: 172px 172px 0 0 !important;
}

.boutique-hero-photo img {
  object-position: 43% 52% !important;
  filter: saturate(0.74) brightness(1.11) contrast(0.92) !important;
}

.boutique-hero::before {
  top: 122px !important;
  height: 148px !important;
}

.boutique-hero::after {
  left: 178px !important;
  bottom: 0 !important;
  width: 142px !important;
  height: 67px !important;
  background: rgba(255, 255, 255, 0.44) !important;
}

.boutique-hero-copy {
  left: 47px !important;
  top: 162px !important;
  width: 198px !important;
}

.boutique-hero h1 {
  width: 198px !important;
  font-size: 1.15rem !important;
  line-height: 1.56 !important;
  letter-spacing: 0 !important;
}

.boutique-hero h1::after {
  margin: 10px 0 14px !important;
}

.boutique-hero-copy p:last-of-type {
  width: 158px !important;
  font-size: 0.54rem !important;
  line-height: 1.95 !important;
}

.boutique-hero-links {
  margin-top: 16px !important;
  gap: 35px !important;
}

.boutique-index {
  height: 120px !important;
  min-height: 120px !important;
  padding-top: 13px !important;
  padding-bottom: 12px !important;
}

.boutique-concept {
  height: 206px !important;
  min-height: 206px !important;
}

.boutique-section-label {
  top: 37px !important;
}

.boutique-concept-copy {
  top: 73px !important;
  width: 158px !important;
}

.boutique-concept-copy h2 {
  width: 158px !important;
  max-width: 158px !important;
  font-size: 1.04rem !important;
  line-height: 1.76 !important;
  margin-bottom: 12px !important;
}

.boutique-concept-copy p {
  width: 139px !important;
  max-width: 139px !important;
  line-height: 1.82 !important;
}

.boutique-concept-photo {
  right: 0 !important;
  top: 18px !important;
  width: 230px !important;
  height: 160px !important;
}

.boutique-concept-photo img {
  object-position: 42% 49% !important;
  filter: saturate(0.74) brightness(1.1) contrast(0.92) !important;
}

.boutique-treatment {
  height: 168px !important;
  min-height: 168px !important;
  background:
    linear-gradient(90deg, rgba(103, 111, 96, 0.8), rgba(116, 124, 106, 0.9)),
    #78816f !important;
}

.boutique-treatment::before {
  width: 152px !important;
  height: 168px !important;
  background-position: 70% 50% !important;
  opacity: 0.96 !important;
}

.boutique-treatment::after {
  background:
    linear-gradient(90deg, rgba(77, 82, 68, 0.02) 0 34%, rgba(103, 111, 96, 0.56) 43%, rgba(103, 111, 96, 0.36) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.11), transparent 62%) !important;
}

.boutique-treatment-copy {
  left: 164px !important;
  top: 22px !important;
  width: 184px !important;
  max-width: 184px !important;
}

.boutique-treatment h2 {
  font-size: 1.18rem !important;
  line-height: 1.3 !important;
}

.boutique-treatment h2 span {
  margin-left: 4px !important;
  font-size: 0.67rem !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 184px !important;
  margin-top: 8px !important;
  font-size: 0.44rem !important;
  line-height: 1.62 !important;
}

.boutique-treatment .boutique-inline-link {
  margin-top: 7px !important;
  font-size: 0.55rem !important;
}

.boutique-menu-lines {
  left: 108px !important;
  right: 42px !important;
  bottom: 16px !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 82px !important;
  min-height: 18px !important;
}

.boutique-menu-lines strong {
  font-size: 0.45rem !important;
}

.boutique-menu-lines small {
  font-size: 0.33rem !important;
  opacity: 0.86 !important;
}

.boutique-access {
  height: 151px !important;
  min-height: 151px !important;
}

.boutique-access-copy {
  left: 46px !important;
  top: 24px !important;
  width: 138px !important;
}

.boutique-access-copy .boutique-kicker {
  width: 138px !important;
  margin-bottom: 15px !important;
}

.boutique-access p:not(.boutique-kicker) {
  width: 132px !important;
  line-height: 1.78 !important;
}

.boutique-access-photo {
  left: 206px !important;
  top: 35px !important;
  width: 91px !important;
  height: 92px !important;
}

.boutique-route {
  right: 22px !important;
  top: 12px !important;
  width: 102px !important;
  height: 128px !important;
  opacity: 0.86 !important;
}

.boutique-route::before {
  right: 48px !important;
  top: 55px !important;
}

.boutique-route::after {
  right: 37px !important;
  top: 42px !important;
}

.boutique-guide-links {
  height: 80px !important;
  min-height: 80px !important;
}

.boutique-guide-links a {
  min-height: 80px !important;
}

.boutique-reserve {
  height: 132px !important;
  min-height: 132px !important;
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.76) 0%, rgba(251, 247, 240, 0.6) 42%, rgba(251, 247, 240, 0.22) 100%),
    url("./assets/photos/boutique-reserve-cta-v2.webp") 47% 57% / 112% auto no-repeat !important;
}

.boutique-reserve > .boutique-script-ghost {
  left: 47px !important;
  top: 34px !important;
  color: rgba(174, 134, 80, 0.25) !important;
  font-size: 5.9rem !important;
}

.boutique-reserve-copy {
  width: 226px !important;
  max-width: 226px !important;
}

.boutique-reserve h2 {
  margin-bottom: 9px !important;
}

.boutique-reserve-button {
  height: 28px !important;
  min-width: 162px !important;
}

.home-body .site-footer {
  min-height: 54px !important;
}

/* Reference14: center Treatment text inside the green panel */
.boutique-treatment-copy {
  left: 164px !important;
  top: 22px !important;
  width: 214px !important;
  max-width: 214px !important;
  text-align: center !important;
}

.boutique-treatment h2 {
  width: 214px !important;
  font-size: 1.18rem !important;
  line-height: 1.28 !important;
  text-align: center !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 214px !important;
  font-size: 0.43rem !important;
  line-height: 1.62 !important;
  text-align: center !important;
}

.boutique-treatment .boutique-inline-link {
  display: inline-block !important;
  padding-right: 30px !important;
  text-align: center !important;
}

.boutique-menu-lines {
  left: 154px !important;
  right: 38px !important;
  bottom: 16px !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 74px !important;
}

.boutique-menu-lines strong {
  text-align: left !important;
}

.boutique-menu-lines small {
  text-align: right !important;
}

/* Reference15: refine reserve CTA button size */
.boutique-reserve-button {
  min-width: 126px !important;
  width: 126px !important;
  height: 25px !important;
  min-height: 25px !important;
  padding: 0 28px 0 24px !important;
  border-radius: 999px !important;
  font-size: 0.55rem !important;
  line-height: 1 !important;
  letter-spacing: 0.04em !important;
  box-shadow: none !important;
}

.boutique-reserve-button::after {
  right: 16px !important;
  width: 18px !important;
}

.boutique-reserve-copy {
  width: 210px !important;
  max-width: 210px !important;
}

/* Reference16: prevent reserve heading/content overlap */
.boutique-reserve {
  isolation: isolate !important;
}

.boutique-reserve > .boutique-script-ghost {
  left: 212px !important;
  top: 42px !important;
  z-index: 1 !important;
  color: rgba(174, 134, 80, 0.14) !important;
  font-size: 5.3rem !important;
  pointer-events: none !important;
}

.boutique-reserve-copy {
  position: relative !important;
  z-index: 4 !important;
  width: 206px !important;
  max-width: 206px !important;
}

.boutique-reserve h2 {
  position: relative !important;
  z-index: 5 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: auto !important;
  margin: 0 0 8px !important;
  padding: 0 8px !important;
  background: rgba(251, 247, 240, 0.74) !important;
  font-size: 1.08rem !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
}

.boutique-reserve h2::before,
.boutique-reserve h2::after {
  flex: 0 0 34px !important;
  width: 34px !important;
  margin: 0 !important;
}

.boutique-reserve-copy p:not(.boutique-kicker) {
  position: relative !important;
  z-index: 5 !important;
  margin: 0 0 10px !important;
  background: rgba(251, 247, 240, 0.56) !important;
}

.boutique-reserve-button {
  position: relative !important;
  z-index: 5 !important;
}

/* Reference18: generated boutique assets and tighter reference typography */
.boutique-main {
  background: #fbf7f0 !important;
}

.boutique-hero {
  height: 356px !important;
  min-height: 356px !important;
  overflow: hidden !important;
}

.boutique-hero > .boutique-script-ghost {
  left: 38px !important;
  top: 100px !important;
  z-index: 2 !important;
  color: rgba(174, 134, 80, 0.25) !important;
  font-size: 6.95rem !important;
  line-height: 0.68 !important;
  letter-spacing: 0 !important;
}

.boutique-hero-photo {
  right: 8px !important;
  top: 58px !important;
  z-index: 3 !important;
  width: 196px !important;
  height: 294px !important;
  border-radius: 174px 174px 0 0 !important;
}

.boutique-hero-photo::before,
.boutique-hero-photo::after {
  display: none !important;
}

.boutique-hero-photo img {
  object-position: 56% 50% !important;
  filter: saturate(0.76) brightness(1.1) contrast(0.93) !important;
}

.boutique-hero::before {
  top: 122px !important;
  height: 148px !important;
  opacity: 0.36 !important;
}

.boutique-hero::after {
  left: 177px !important;
  bottom: -1px !important;
  width: 145px !important;
  height: 67px !important;
  background: rgba(255, 255, 255, 0.42) !important;
}

.boutique-hero-copy {
  left: 47px !important;
  top: 162px !important;
  z-index: 5 !important;
  width: 198px !important;
}

.boutique-hero h1 {
  width: 198px !important;
  margin: 0 !important;
  font-size: 1.15rem !important;
  line-height: 1.56 !important;
  letter-spacing: 0 !important;
}

.boutique-hero h1::after {
  width: 36px !important;
  margin: 10px 0 13px !important;
}

.boutique-hero-copy p:last-of-type {
  width: 158px !important;
  margin: 0 !important;
  font-size: 0.54rem !important;
  line-height: 1.9 !important;
}

.boutique-hero-links {
  gap: 35px !important;
  margin-top: 15px !important;
}

.boutique-concept {
  height: 206px !important;
  min-height: 206px !important;
}

.boutique-section-label {
  left: 46px !important;
  top: 37px !important;
}

.boutique-concept-copy {
  left: 46px !important;
  top: 73px !important;
  width: 158px !important;
}

.boutique-concept-copy h2 {
  width: 158px !important;
  max-width: 158px !important;
  margin: 0 0 12px !important;
  font-size: 1.04rem !important;
  line-height: 1.76 !important;
  letter-spacing: 0 !important;
}

.boutique-concept-copy p {
  width: 139px !important;
  max-width: 139px !important;
  margin: 0 !important;
  line-height: 1.82 !important;
}

.boutique-concept-photo {
  right: 0 !important;
  top: 18px !important;
  width: 232px !important;
  height: 160px !important;
}

.boutique-concept-photo::before,
.boutique-concept-photo::after,
.boutique-concept-photo figcaption {
  display: none !important;
}

.boutique-concept-photo img {
  object-position: 61% 50% !important;
  filter: saturate(0.78) brightness(1.08) contrast(0.94) !important;
}

.boutique-treatment {
  height: 168px !important;
  min-height: 168px !important;
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.08) 0 36%, rgba(92, 103, 87, 0.48) 39% 100%),
    url("./assets/photos/ref13-treatment-band.webp") 0 51% / cover no-repeat !important;
}

.boutique-treatment::before {
  display: none !important;
  content: none !important;
}

.boutique-treatment::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  background:
    linear-gradient(90deg, transparent 0 35%, rgba(86, 98, 82, 0.28) 43%, rgba(86, 98, 82, 0.22) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 60%) !important;
  pointer-events: none !important;
}

.boutique-treatment-photo {
  display: none !important;
}

.boutique-treatment-copy {
  left: 164px !important;
  top: 22px !important;
  z-index: 4 !important;
  width: 214px !important;
  max-width: 214px !important;
  text-align: center !important;
}

.boutique-treatment h2 {
  width: 214px !important;
  margin: 0 !important;
  font-size: 1.18rem !important;
  line-height: 1.28 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
}

.boutique-treatment h2 span {
  margin-left: 4px !important;
  font-size: 0.67rem !important;
  letter-spacing: 0 !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 214px !important;
  margin: 8px 0 0 !important;
  font-size: 0.43rem !important;
  line-height: 1.62 !important;
  text-align: center !important;
}

.boutique-treatment .boutique-inline-link {
  display: inline-block !important;
  margin-top: 7px !important;
  padding-right: 30px !important;
  font-size: 0.55rem !important;
  text-align: center !important;
}

.boutique-menu-lines {
  left: 154px !important;
  right: 38px !important;
  bottom: 16px !important;
  z-index: 4 !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 74px !important;
  min-height: 18px !important;
}

.boutique-menu-lines strong {
  font-size: 0.45rem !important;
  text-align: left !important;
}

.boutique-menu-lines small {
  font-size: 0.33rem !important;
  opacity: 0.88 !important;
  text-align: right !important;
}

.boutique-reserve {
  height: 132px !important;
  min-height: 132px !important;
  isolation: isolate !important;
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.72) 0%, rgba(251, 247, 240, 0.56) 48%, rgba(251, 247, 240, 0.38) 100%),
    url("./assets/photos/ref13-reserve-cta.webp") 50% 55% / cover no-repeat !important;
}

.boutique-reserve::before,
.boutique-reserve::after {
  display: none !important;
}

.boutique-reserve > .boutique-script-ghost {
  left: 214px !important;
  top: 43px !important;
  z-index: 1 !important;
  color: rgba(174, 134, 80, 0.12) !important;
  font-size: 5rem !important;
  letter-spacing: 0 !important;
  pointer-events: none !important;
}

.boutique-reserve-calendar {
  display: none !important;
}

.boutique-reserve-copy {
  position: relative !important;
  z-index: 4 !important;
  width: 206px !important;
  max-width: 206px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.boutique-reserve h2 {
  position: relative !important;
  z-index: 5 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  width: auto !important;
  margin: 0 0 8px !important;
  padding: 0 8px !important;
  background: rgba(251, 247, 240, 0.72) !important;
  font-size: 1.08rem !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

.boutique-reserve h2::before,
.boutique-reserve h2::after {
  flex: 0 0 34px !important;
  width: 34px !important;
  margin: 0 !important;
}

.boutique-reserve-copy p:not(.boutique-kicker) {
  position: relative !important;
  z-index: 5 !important;
  margin: 0 0 10px !important;
  background: rgba(251, 247, 240, 0.52) !important;
}

.boutique-reserve-button {
  position: relative !important;
  z-index: 5 !important;
  width: 126px !important;
  min-width: 126px !important;
  height: 25px !important;
  min-height: 25px !important;
}

/* Reference19: closer to the saved mobile reference */
.home-body .site-header {
  height: 82px !important;
}

.home-body .nav-wrap {
  min-height: 82px !important;
  padding: 23px 18px 0 25px !important;
}

.home-body .brand-copy-script strong {
  font-size: 3.05rem !important;
  line-height: 0.72 !important;
}

.home-body .brand-copy-script small {
  margin-top: -2px !important;
  padding-left: 46px !important;
}

.home-body .nav-wrap::after,
.home-body .site-header::after {
  right: 48px !important;
  top: 31px !important;
  font-size: 0.48rem !important;
  letter-spacing: 0 !important;
}

.home-body .menu-toggle {
  position: absolute !important;
  right: 19px !important;
  top: 27px !important;
  width: 22px !important;
  height: 22px !important;
  margin: 0 !important;
}

.home-body .menu-toggle span {
  width: 14px !important;
  height: 1px !important;
}

.boutique-hero > .boutique-script-ghost {
  left: 41px !important;
  top: 104px !important;
  color: rgba(174, 134, 80, 0.19) !important;
  font-size: 6.28rem !important;
  line-height: 0.7 !important;
  transform: rotate(-8deg) !important;
}

.boutique-hero-photo {
  right: 8px !important;
  top: 58px !important;
  width: 196px !important;
  height: 294px !important;
  border-radius: 174px 174px 0 0 !important;
}

.boutique-hero-photo img {
  object-position: 52% 50% !important;
  filter: saturate(0.75) brightness(1.1) contrast(0.93) !important;
}

.boutique-hero-copy {
  left: 47px !important;
  top: 166px !important;
  width: 198px !important;
}

.boutique-hero h1 {
  width: 198px !important;
  font-size: 1.12rem !important;
  line-height: 1.58 !important;
}

.boutique-hero-copy p:last-of-type {
  width: 158px !important;
  font-size: 0.53rem !important;
  line-height: 1.88 !important;
}

.boutique-concept-photo {
  right: 0 !important;
  top: 18px !important;
  width: 232px !important;
  height: 160px !important;
}

.boutique-concept-photo img {
  object-position: 100% 51% !important;
  filter: saturate(0.78) brightness(1.07) contrast(0.94) !important;
}

.boutique-treatment {
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.08) 0 36%, rgba(92, 103, 87, 0.5) 39% 100%),
    url("./assets/photos/ref13-treatment-band.webp") 0 51% / cover no-repeat !important;
}

.boutique-treatment-copy {
  left: 164px !important;
  top: 22px !important;
  width: 214px !important;
  max-width: 214px !important;
  text-align: center !important;
}

.boutique-menu-lines {
  left: 152px !important;
  right: 20px !important;
  bottom: 16px !important;
  overflow: visible !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 88px !important;
  overflow: visible !important;
}

.boutique-menu-lines small {
  font-size: 0.32rem !important;
  text-align: right !important;
  white-space: nowrap !important;
}

.boutique-reserve {
  background:
    linear-gradient(90deg, rgba(251, 247, 240, 0.74) 0%, rgba(251, 247, 240, 0.58) 48%, rgba(251, 247, 240, 0.36) 100%),
    url("./assets/photos/ref13-reserve-cta.webp") 50% 55% / cover no-repeat !important;
}

/* Reference20: header and small text cleanup */
.home-body .site-header::after {
  display: none !important;
  content: none !important;
}

.home-body .nav-wrap::after {
  content: "Private Salon" !important;
  right: 50px !important;
  top: 31px !important;
  z-index: 31 !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.48rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.home-body .menu-toggle {
  z-index: 32 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
}

.home-body .menu-toggle span {
  display: block !important;
  flex: 0 0 1px !important;
  width: 14px !important;
  height: 1px !important;
  background: #b0834d !important;
}

.boutique-menu-lines {
  left: 150px !important;
  right: 18px !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 96px !important;
}

.boutique-menu-lines small {
  font-size: 0.3rem !important;
}

/* Reference21: draw the mobile menu mark at the header layer */
.home-body .site-header {
  overflow: visible !important;
}

.home-body .site-header::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  right: 19px !important;
  top: 31px !important;
  z-index: 80 !important;
  width: 15px !important;
  height: 7px !important;
  border-top: 1px solid #b0834d !important;
  border-bottom: 1px solid #b0834d !important;
  pointer-events: none !important;
}

.home-body .nav-wrap::after {
  content: "Private Salon" !important;
  display: block !important;
  position: absolute !important;
  right: 47px !important;
  top: 31px !important;
  z-index: 79 !important;
}

/* Reference22: real header right-side marks */
.home-body .header-micro {
  display: block !important;
  position: absolute !important;
  right: 47px !important;
  top: 31px !important;
  z-index: 90 !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.48rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  pointer-events: none !important;
}

.home-body .header-menu-mark {
  display: block !important;
  position: absolute !important;
  right: 19px !important;
  top: 31px !important;
  z-index: 91 !important;
  width: 15px !important;
  height: 7px !important;
  border-top: 1px solid #b0834d !important;
  border-bottom: 1px solid #b0834d !important;
  pointer-events: none !important;
}

/* Reference23: independent right header marks */
.home-body .page-shell {
  position: relative !important;
}

.home-body .floating-header-micro {
  display: block !important;
  position: absolute !important;
  right: 47px !important;
  top: 31px !important;
  z-index: 220 !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.48rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  pointer-events: none !important;
}

.home-body .floating-header-menu {
  display: block !important;
  position: absolute !important;
  right: 19px !important;
  top: 31px !important;
  z-index: 221 !important;
  width: 15px !important;
  height: 7px !important;
  border-top: 1px solid #b0834d !important;
  border-bottom: 1px solid #b0834d !important;
  pointer-events: none !important;
}

/* Reference24: correct text relationships against the reference image */
.boutique-hero > .boutique-script-ghost {
  left: 48px !important;
  top: 103px !important;
  z-index: 1 !important;
  color: rgba(174, 134, 80, 0.13) !important;
  font-size: 6.1rem !important;
  line-height: 0.72 !important;
}

.boutique-hero-copy {
  left: 47px !important;
  top: 169px !important;
  z-index: 6 !important;
  width: 178px !important;
}

.boutique-hero h1 {
  width: 178px !important;
  font-size: 1.08rem !important;
  line-height: 1.62 !important;
}

.boutique-hero h1::after {
  margin: 9px 0 12px !important;
}

.boutique-hero-copy p:last-of-type {
  width: 150px !important;
  font-size: 0.52rem !important;
  line-height: 1.92 !important;
}

.boutique-hero-links {
  gap: 34px !important;
  margin-top: 14px !important;
}

.boutique-hero-links a {
  font-size: 0.62rem !important;
  padding-right: 25px !important;
}

.boutique-concept-copy {
  left: 47px !important;
  top: 72px !important;
  width: 150px !important;
}

.boutique-concept-copy h2 {
  width: 150px !important;
  max-width: 150px !important;
  margin-bottom: 11px !important;
  font-size: 1.02rem !important;
  line-height: 1.76 !important;
}

.boutique-concept-copy p {
  width: 134px !important;
  max-width: 134px !important;
  font-size: 0.5rem !important;
  line-height: 1.86 !important;
}

.boutique-concept-photo {
  right: -8px !important;
  top: 22px !important;
  width: 214px !important;
  height: 158px !important;
}

.boutique-concept-photo img {
  object-position: 94% 51% !important;
}

.boutique-treatment-copy {
  left: 158px !important;
  top: 22px !important;
  width: 206px !important;
  max-width: 206px !important;
}

.boutique-treatment h2 {
  width: 206px !important;
  font-size: 1.1rem !important;
  line-height: 1.28 !important;
}

.boutique-treatment h2 span {
  font-size: 0.6rem !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 206px !important;
  margin-top: 7px !important;
  font-size: 0.39rem !important;
  line-height: 1.58 !important;
}

.boutique-treatment .boutique-inline-link {
  margin-top: 6px !important;
  font-size: 0.5rem !important;
}

.boutique-menu-lines {
  left: 148px !important;
  right: 30px !important;
  bottom: 16px !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 78px !important;
  min-height: 17px !important;
  padding: 3px 0 !important;
}

.boutique-menu-lines strong {
  font-size: 0.4rem !important;
}

.boutique-menu-lines small {
  font-size: 0.25rem !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

/* Reference25: keep Concept copy inside its section */
.boutique-concept {
  height: 216px !important;
  min-height: 216px !important;
}

.boutique-section-label {
  top: 35px !important;
}

.boutique-concept-copy {
  top: 66px !important;
  width: 150px !important;
}

.boutique-concept-copy h2 {
  margin-bottom: 9px !important;
  font-size: 0.99rem !important;
  line-height: 1.7 !important;
}

.boutique-concept-copy p {
  width: 136px !important;
  max-width: 136px !important;
  font-size: 0.47rem !important;
  line-height: 1.68 !important;
}

.boutique-concept-photo {
  top: 24px !important;
  height: 160px !important;
}

/* Reference26: place the small hero header text where the reference has it */
.boutique-hero-location {
  display: block !important;
  position: absolute !important;
  top: 31px !important;
  right: 47px !important;
  z-index: 15 !important;
  margin: 0 !important;
  width: auto !important;
  height: 10px !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.48rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
  white-space: nowrap !important;
}

.boutique-hero-location::before {
  display: none !important;
  content: none !important;
}

.boutique-hero-location::after {
  content: "" !important;
  position: absolute !important;
  left: calc(100% + 13px) !important;
  top: 0 !important;
  display: block !important;
  width: 15px !important;
  height: 7px !important;
  border-top: 1px solid #b0834d !important;
  border-bottom: 1px solid #b0834d !important;
}

/* Reference28: lock line breaks and center Treatment like the reference */
.boutique-hero-copy {
  left: 47px !important;
  top: 172px !important;
  width: 190px !important;
}

.boutique-hero h1 {
  width: 190px !important;
  font-size: 1.13rem !important;
  line-height: 1.54 !important;
  white-space: nowrap !important;
}

.boutique-hero-copy p:last-of-type {
  width: 178px !important;
  font-size: 0.51rem !important;
  line-height: 1.88 !important;
}

.boutique-hero-links {
  margin-top: 16px !important;
}

.boutique-concept-copy {
  left: 47px !important;
  top: 70px !important;
  width: 178px !important;
  z-index: 5 !important;
}

.boutique-concept-copy h2 {
  width: 178px !important;
  max-width: 178px !important;
  margin-bottom: 12px !important;
  font-size: 1.02rem !important;
  line-height: 1.72 !important;
  white-space: nowrap !important;
}

.boutique-concept-copy p {
  width: 160px !important;
  max-width: 160px !important;
  font-size: 0.45rem !important;
  line-height: 1.72 !important;
}

.boutique-concept-photo {
  right: 0 !important;
  top: 25px !important;
  width: 214px !important;
  height: 158px !important;
  z-index: 2 !important;
}

.boutique-treatment-copy {
  left: 152px !important;
  right: 0 !important;
  top: 20px !important;
  width: 238px !important;
  max-width: 238px !important;
  text-align: center !important;
}

.boutique-treatment .boutique-kicker {
  display: block !important;
  height: auto !important;
  margin: 0 0 4px !important;
  overflow: visible !important;
  opacity: 1 !important;
  color: rgba(255, 250, 242, 0.7) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.43rem !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
}

.boutique-treatment .boutique-kicker::before {
  content: "o" !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 0 2px !important;
  background: transparent !important;
  color: rgba(255, 238, 205, 0.75) !important;
  font-size: 0.56rem !important;
  line-height: 1 !important;
}

.boutique-treatment h2 {
  display: flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 7px !important;
  width: 238px !important;
  margin: 0 !important;
  font-size: 1.18rem !important;
  line-height: 1.22 !important;
  text-align: center !important;
  white-space: nowrap !important;
}

.boutique-treatment h2 span {
  margin-left: 0 !important;
  font-size: 0.58rem !important;
  line-height: 1 !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 238px !important;
  margin: 7px 0 0 !important;
  font-size: 0.41rem !important;
  line-height: 1.5 !important;
  text-align: center !important;
}

.boutique-treatment .boutique-inline-link {
  margin-top: 7px !important;
  padding-right: 28px !important;
  font-size: 0.51rem !important;
  text-align: center !important;
}

.boutique-menu-lines {
  left: 152px !important;
  right: 38px !important;
  bottom: 17px !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 80px !important;
  min-height: 18px !important;
  padding: 3px 0 !important;
}

.boutique-menu-lines strong {
  font-size: 0.39rem !important;
}

.boutique-menu-lines small {
  font-size: 0.25rem !important;
}

/* Reference29: Treatment text centered on the section, not pushed to the right */
.boutique-treatment-copy {
  left: 128px !important;
  right: auto !important;
  top: 20px !important;
  width: 236px !important;
  max-width: 236px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
}

.boutique-treatment .boutique-kicker {
  width: 236px !important;
  text-align: center !important;
}

.boutique-treatment h2 {
  width: 236px !important;
  max-width: 236px !important;
  display: flex !important;
  justify-content: center !important;
  align-items: baseline !important;
  gap: 7px !important;
  text-align: center !important;
  white-space: nowrap !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 236px !important;
  max-width: 236px !important;
  text-align: center !important;
}

.boutique-treatment .boutique-inline-link {
  align-self: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

/* Reference30: generated one-piece Treatment background with centered text */
.boutique-treatment {
  height: 168px !important;
  min-height: 168px !important;
  background: url("./assets/photos/ref15-treatment-onepiece.webp") 50% 50% / cover no-repeat !important;
  color: #fffaf2 !important;
}

.boutique-treatment::before,
.boutique-treatment::after,
.boutique-treatment-photo {
  display: none !important;
  content: none !important;
}

.boutique-treatment-copy {
  left: 140px !important;
  right: auto !important;
  top: 19px !important;
  width: 222px !important;
  max-width: 222px !important;
  transform: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
}

.boutique-treatment .boutique-kicker,
.boutique-treatment h2,
.boutique-treatment-copy p:not(.boutique-kicker),
.boutique-treatment .boutique-inline-link {
  width: 222px !important;
  max-width: 222px !important;
  text-align: center !important;
}

.boutique-treatment h2 {
  display: flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 7px !important;
  margin: 0 !important;
  font-size: 1.16rem !important;
  line-height: 1.22 !important;
  white-space: nowrap !important;
}

.boutique-treatment h2 span {
  margin-left: 0 !important;
  font-size: 0.58rem !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  margin: 7px 0 0 !important;
  font-size: 0.4rem !important;
  line-height: 1.5 !important;
}

.boutique-treatment .boutique-inline-link {
  display: block !important;
  position: relative !important;
  margin: 7px auto 0 !important;
  padding: 0 28px 0 0 !important;
  font-size: 0.51rem !important;
}

.boutique-treatment .boutique-inline-link::after {
  right: 48px !important;
}

.boutique-menu-lines {
  left: 148px !important;
  right: 28px !important;
  bottom: 16px !important;
  z-index: 4 !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 82px !important;
  min-height: 17px !important;
  padding: 3px 0 !important;
}

.boutique-menu-lines strong {
  font-size: 0.39rem !important;
  text-align: left !important;
}

.boutique-menu-lines small {
  font-size: 0.25rem !important;
  text-align: right !important;
  white-space: nowrap !important;
}

/* Legal pages final alignment */
body.legal-body {
  background: #171512 !important;
}

body.legal-body .page-shell {
  width: min(100%, 460px) !important;
  min-height: 100vh !important;
  margin: 0 auto !important;
  overflow: hidden !important;
  background: #fbf8f2 !important;
  color: #302b26 !important;
  border-radius: 8px !important;
}

body.legal-body .site-header {
  position: relative !important;
  height: 82px !important;
  min-height: 82px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body.legal-body .nav-wrap {
  min-height: 82px !important;
  padding: 14px 48px 0 24px !important;
}

body.legal-body .brand {
  position: absolute !important;
  left: 24px !important;
  top: 14px !important;
  text-decoration: none !important;
}

body.legal-body .brand-copy-script strong {
  color: #9f743e !important;
  font-family: "Parisienne", cursive !important;
  font-size: 2.32rem !important;
  font-weight: 400 !important;
  line-height: 0.72 !important;
}

body.legal-body .brand-copy-script small {
  display: block !important;
  margin-top: -6px !important;
  padding-left: 42px !important;
  color: #9f743e !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.48rem !important;
  letter-spacing: 0.28em !important;
}

body.legal-body .legal-page {
  padding: 14px 0 0 !important;
  background: #fbf8f2 !important;
}

body.legal-body .legal-wrap {
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 38px 34px 52px !important;
  background: transparent !important;
  border-top: 1px solid rgba(176, 131, 77, 0.24) !important;
}

body.legal-body .legal-page h1 {
  margin-top: 16px !important;
  color: #302b26 !important;
  font-family: "Hiragino Mincho ProN", "Yu Mincho", YuMincho, serif !important;
  font-size: 1.58rem !important;
  line-height: 1.55 !important;
  letter-spacing: 0 !important;
}

body.legal-body .legal-page .lead {
  color: rgba(48, 43, 38, 0.68) !important;
  font-size: 0.72rem !important;
  line-height: 2 !important;
}

body.legal-body .legal-table div,
body.legal-body .legal-stack .policy-card {
  background: rgba(255, 252, 246, 0.56) !important;
  border: 1px solid rgba(176, 131, 77, 0.2) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body.legal-body .site-footer {
  padding: 30px 34px 34px !important;
  color: rgba(255, 250, 242, 0.88) !important;
  background: #596353 !important;
}

body.legal-body .site-footer p {
  margin: 0 !important;
  font-family: "Cormorant Garamond", "Yu Mincho", serif !important;
  font-size: 0.72rem !important;
  line-height: 1.6 !important;
}

body.legal-body .footer-links {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  margin-top: 14px !important;
}

body.legal-body .site-footer a {
  color: rgba(255, 250, 242, 0.78) !important;
  text-decoration: none !important;
}

@media (max-width: 430px) {
  body.legal-body .page-shell {
    border-radius: 0 !important;
  }
}

/* Reference39: final homepage overrides after legacy appended blocks. */
body.home-body .hero-boundary-svg,
body.home-body .boutique-route {
  display: none !important;
  content: none !important;
}

body.home-body .site-header::after {
  content: "Private Salon" !important;
  right: 48px !important;
  top: 25px !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.5rem !important;
  letter-spacing: 0 !important;
}

body.home-body .boutique-access h2 {
  display: block !important;
  visibility: visible !important;
  width: 148px !important;
  max-width: 148px !important;
  margin: 0 !important;
  color: #221f1b !important;
  font-size: 0.86rem !important;
  line-height: 1.72 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
}

body.home-body .boutique-access-copy {
  display: block !important;
}

body.home-body .boutique-access-photo {
  display: block !important;
}

body.home-body .boutique-access-photo img {
  display: block !important;
}

/* Reference38: calmer copy, generated photo assets, no decorative SVG/map lines on the homepage. */
body.home-body .hero-boundary-svg,
body.home-body .boutique-route {
  display: none !important;
  content: none !important;
}

body.home-body .site-header::after {
  content: "Private Salon" !important;
  right: 48px !important;
  top: 25px !important;
  color: #6f6559 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.5rem !important;
  letter-spacing: 0 !important;
}

body.home-body .boutique-hero-location {
  color: #6f6559 !important;
}

body.home-body .boutique-hero-photo img {
  object-position: 52% 49% !important;
  filter: saturate(0.9) brightness(1.02) contrast(0.96) !important;
}

body.home-body .boutique-hero h1 {
  width: 198px !important;
  max-width: 198px !important;
  font-size: 1.08rem !important;
  line-height: 1.58 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

body.home-body .boutique-hero-copy p:last-of-type {
  width: 178px !important;
  max-width: 178px !important;
  margin-top: 13px !important;
  font-size: 0.5rem !important;
  line-height: 1.92 !important;
}

body.home-body .boutique-index-text small,
body.home-body .boutique-guide-links small,
body.home-body .site-footer,
body.home-body .site-footer p {
  letter-spacing: 0 !important;
}

body.home-body .boutique-concept-copy p {
  width: 164px !important;
  max-width: 164px !important;
  font-size: 0.45rem !important;
  line-height: 1.82 !important;
}

body.home-body .treatment-spotlight-lead {
  font-size: 0.39rem !important;
}

body.home-body .boutique-access {
  position: relative !important;
  display: block !important;
  height: 170px !important;
  min-height: 170px !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #fbf8f2 !important;
}

body.home-body .boutique-access-copy {
  position: absolute !important;
  left: 46px !important;
  top: 26px !important;
  z-index: 3 !important;
  width: 148px !important;
  max-width: 148px !important;
  padding: 0 !important;
}

body.home-body .boutique-access-copy .boutique-kicker {
  margin-bottom: 12px !important;
  font-size: 0.48rem !important;
}

body.home-body .boutique-access-copy .boutique-kicker::after {
  width: 28px !important;
}

body.home-body .boutique-access h2 {
  width: 148px !important;
  max-width: 148px !important;
  font-size: 0.86rem !important;
  line-height: 1.72 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
}

body.home-body .boutique-access p:not(.boutique-kicker) {
  width: 148px !important;
  max-width: 148px !important;
  margin: 12px 0 12px !important;
  color: rgba(56, 48, 42, 0.72) !important;
  font-size: 0.42rem !important;
  line-height: 1.7 !important;
}

body.home-body .boutique-access .boutique-inline-link {
  margin-top: 0 !important;
  font-size: 0.49rem !important;
}

body.home-body .boutique-access-photo {
  position: absolute !important;
  left: 214px !important;
  top: 28px !important;
  z-index: 2 !important;
  width: 118px !important;
  height: 118px !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

body.home-body .boutique-access-photo::before,
body.home-body .boutique-access-photo::after {
  display: none !important;
  content: none !important;
}

body.home-body .boutique-access-photo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: 51% 64% !important;
  filter: saturate(0.88) brightness(1.02) contrast(0.94) !important;
}

body.home-body .boutique-reserve-copy {
  width: 218px !important;
  max-width: 218px !important;
}

body.home-body .boutique-reserve h2 {
  font-size: 1.12rem !important;
}

body.home-body .boutique-reserve-copy p:not(.boutique-kicker) {
  font-size: 0.52rem !important;
  line-height: 1.7 !important;
}

.policy::before,
.compliance::before,
.faq::before,
.contact::before {
  background: none !important;
  animation: none !important;
}

.promo {
  background-image: none !important;
}

/* Reference36: isolated Treatment spotlight. */
body.home-body .treatment-spotlight {
  --treatment-copy-center: calc(50% + 72px);
  --treatment-copy-width: 226px;
  position: relative !important;
  display: block !important;
  width: 100% !important;
  height: 168px !important;
  min-height: 168px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  color: #fffaf2 !important;
  background: url("./assets/photos/ref15-treatment-onepiece.webp") center center / cover no-repeat !important;
  isolation: isolate !important;
}

body.home-body .treatment-spotlight::before,
body.home-body .treatment-spotlight::after {
  display: none !important;
  content: none !important;
}

body.home-body .treatment-spotlight-copy {
  position: absolute !important;
  left: var(--treatment-copy-center) !important;
  top: 17px !important;
  z-index: 2 !important;
  width: var(--treatment-copy-width) !important;
  max-width: var(--treatment-copy-width) !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
  box-sizing: border-box !important;
}

body.home-body .treatment-spotlight-kicker {
  display: block !important;
  width: var(--treatment-copy-width) !important;
  max-width: var(--treatment-copy-width) !important;
  height: auto !important;
  margin: 0 0 4px !important;
  padding: 0 !important;
  color: rgba(255, 250, 242, 0.72) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.43rem !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
  opacity: 1 !important;
  overflow: visible !important;
}

body.home-body .treatment-spotlight-kicker::before {
  content: "o" !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 0 2px !important;
  padding: 0 !important;
  color: rgba(255, 238, 205, 0.75) !important;
  background: transparent !important;
  font-size: 0.56rem !important;
  line-height: 1 !important;
  text-align: center !important;
}

body.home-body .treatment-spotlight-title {
  display: block !important;
  width: var(--treatment-copy-width) !important;
  max-width: var(--treatment-copy-width) !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #fffaf2 !important;
  font-family: "M PLUS Rounded 1c", "Yu Gothic", sans-serif !important;
  font-size: 1.16rem !important;
  font-weight: 700 !important;
  line-height: 1.22 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
  white-space: nowrap !important;
}

body.home-body .treatment-spotlight-title span {
  display: inline !important;
  margin-left: 7px !important;
  color: rgba(255, 250, 242, 0.92) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.58rem !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  vertical-align: baseline !important;
}

body.home-body .treatment-spotlight-lead {
  display: block !important;
  width: var(--treatment-copy-width) !important;
  max-width: var(--treatment-copy-width) !important;
  margin: 7px 0 0 !important;
  padding: 0 !important;
  color: rgba(255, 250, 242, 0.88) !important;
  font-family: "M PLUS Rounded 1c", "Yu Gothic", sans-serif !important;
  font-size: 0.4rem !important;
  font-weight: 500 !important;
  line-height: 1.5 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
}

body.home-body .treatment-spotlight-link {
  position: relative !important;
  display: inline-block !important;
  width: auto !important;
  max-width: none !important;
  margin: 7px auto 0 !important;
  padding: 0 30px 0 0 !important;
  color: #fffaf2 !important;
  font-family: "M PLUS Rounded 1c", "Yu Gothic", sans-serif !important;
  font-size: 0.51rem !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
  text-decoration: none !important;
}

body.home-body .treatment-spotlight-link::after {
  content: "" !important;
  position: absolute !important;
  right: 0 !important;
  top: 50% !important;
  width: 20px !important;
  height: 1px !important;
  background: rgba(255, 250, 242, 0.8) !important;
  transform: translateY(-50%) !important;
}

body.home-body .treatment-spotlight-lines {
  position: absolute !important;
  left: var(--treatment-copy-center) !important;
  bottom: 15px !important;
  z-index: 2 !important;
  width: var(--treatment-copy-width) !important;
  max-width: var(--treatment-copy-width) !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: translateX(-50%) !important;
  display: block !important;
  box-sizing: border-box !important;
}

body.home-body .treatment-spotlight-lines a {
  display: grid !important;
  grid-template-columns: 34px minmax(0, 1fr) 84px !important;
  align-items: center !important;
  min-height: 17px !important;
  margin: 0 !important;
  padding: 3px 0 !important;
  color: rgba(255, 250, 242, 0.86) !important;
  border-top: 1px solid rgba(255, 250, 242, 0.42) !important;
  text-decoration: none !important;
  box-sizing: border-box !important;
}

body.home-body .treatment-spotlight-lines a:last-child {
  border-bottom: 1px solid rgba(255, 250, 242, 0.42) !important;
}

body.home-body .treatment-spotlight-lines span {
  display: block !important;
  color: rgba(255, 250, 242, 0.64) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.29rem !important;
  line-height: 1 !important;
  text-align: left !important;
}

body.home-body .treatment-spotlight-lines strong {
  display: block !important;
  min-width: 0 !important;
  color: rgba(255, 250, 242, 0.92) !important;
  font-family: "M PLUS Rounded 1c", "Yu Gothic", sans-serif !important;
  font-size: 0.39rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
  text-align: left !important;
  white-space: nowrap !important;
}

body.home-body .treatment-spotlight-lines small {
  display: block !important;
  color: rgba(255, 250, 242, 0.78) !important;
  font-family: "M PLUS Rounded 1c", "Yu Gothic", sans-serif !important;
  font-size: 0.25rem !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
  text-align: right !important;
  white-space: nowrap !important;
}

@media (min-width: 700px) {
  body.home-body .treatment-spotlight {
    --treatment-copy-center: calc(50% + 110px);
    --treatment-copy-width: 300px;
    height: 210px !important;
    min-height: 210px !important;
  }

  body.home-body .treatment-spotlight-copy,
  body.home-body .treatment-spotlight-lines {
    width: 300px !important;
    max-width: 300px !important;
  }

  body.home-body .treatment-spotlight-kicker,
  body.home-body .treatment-spotlight-title,
  body.home-body .treatment-spotlight-lead {
    width: 300px !important;
    max-width: 300px !important;
  }
}

/* Reference34: Treatment text truly centered in the whole section */
body.home-body .boutique-treatment {
  position: relative !important;
  display: block !important;
  height: 168px !important;
  min-height: 168px !important;
  overflow: hidden !important;
  background: url("./assets/photos/ref15-treatment-onepiece.webp") 50% 50% / cover no-repeat !important;
}

body.home-body .boutique-treatment::before,
body.home-body .boutique-treatment::after,
body.home-body .boutique-treatment-photo {
  display: none !important;
  content: none !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy {
  position: absolute !important;
  inset: auto 0 auto 0 !important;
  top: 18px !important;
  z-index: 5 !important;
  width: 232px !important;
  max-width: 232px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  transform: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy .boutique-kicker {
  display: block !important;
  width: 232px !important;
  height: auto !important;
  margin: 0 0 4px !important;
  overflow: visible !important;
  opacity: 1 !important;
  color: rgba(255, 250, 242, 0.72) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.43rem !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy .boutique-kicker::before {
  content: "o" !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 0 2px !important;
  background: transparent !important;
  color: rgba(255, 238, 205, 0.75) !important;
  font-size: 0.56rem !important;
  line-height: 1 !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy h2 {
  display: block !important;
  width: 232px !important;
  max-width: 232px !important;
  margin: 0 !important;
  color: #fffaf2 !important;
  font-size: 1.14rem !important;
  line-height: 1.24 !important;
  text-align: center !important;
  white-space: nowrap !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy h2 span {
  display: inline !important;
  margin-left: 7px !important;
  font-size: 0.58rem !important;
  line-height: 1 !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy p:not(.boutique-kicker) {
  width: 232px !important;
  max-width: 232px !important;
  margin: 7px 0 0 !important;
  color: rgba(255, 250, 242, 0.88) !important;
  font-size: 0.4rem !important;
  line-height: 1.5 !important;
  text-align: center !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy .boutique-inline-link {
  display: inline-block !important;
  position: relative !important;
  width: auto !important;
  max-width: none !important;
  margin: 7px auto 0 !important;
  padding: 0 30px 0 0 !important;
  color: #fffaf2 !important;
  font-size: 0.51rem !important;
  text-align: center !important;
}

body.home-body .boutique-treatment > .boutique-treatment-copy .boutique-inline-link::after {
  right: 0 !important;
}

body.home-body .boutique-treatment > .boutique-menu-lines {
  position: absolute !important;
  inset: auto 0 16px 0 !important;
  z-index: 5 !important;
  width: 232px !important;
  margin: 0 auto !important;
  transform: none !important;
}

body.home-body .boutique-treatment > .boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 80px !important;
  min-height: 17px !important;
  padding: 3px 0 !important;
}

body.home-body .boutique-treatment > .boutique-menu-lines strong {
  font-size: 0.39rem !important;
  text-align: left !important;
}

body.home-body .boutique-treatment > .boutique-menu-lines small {
  font-size: 0.25rem !important;
  text-align: right !important;
  white-space: nowrap !important;
}

/* Reference33: clean Treatment layout on the generated one-piece background */
.boutique-treatment {
  position: relative !important;
  height: 168px !important;
  min-height: 168px !important;
  overflow: hidden !important;
  background: url("./assets/photos/ref15-treatment-onepiece.webp") 50% 50% / cover no-repeat !important;
}

.boutique-treatment::before,
.boutique-treatment::after,
.boutique-treatment-photo {
  display: none !important;
  content: none !important;
}

.boutique-treatment-copy {
  position: absolute !important;
  left: 156px !important;
  right: auto !important;
  top: 18px !important;
  z-index: 4 !important;
  width: 220px !important;
  max-width: 220px !important;
  padding: 0 !important;
  transform: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}

.boutique-treatment .boutique-kicker {
  display: block !important;
  width: 220px !important;
  height: auto !important;
  margin: 0 0 4px !important;
  overflow: visible !important;
  opacity: 1 !important;
  color: rgba(255, 250, 242, 0.72) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: 0.43rem !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
}

.boutique-treatment .boutique-kicker::before {
  content: "o" !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 0 2px !important;
  background: transparent !important;
  color: rgba(255, 238, 205, 0.75) !important;
  font-size: 0.56rem !important;
  line-height: 1 !important;
}

.boutique-treatment h2 {
  display: flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 7px !important;
  width: 220px !important;
  max-width: 220px !important;
  margin: 0 !important;
  color: #fffaf2 !important;
  font-size: 1.15rem !important;
  line-height: 1.22 !important;
  text-align: center !important;
  white-space: nowrap !important;
}

.boutique-treatment h2 span {
  margin-left: 0 !important;
  font-size: 0.58rem !important;
  line-height: 1 !important;
}

.boutique-treatment-copy p:not(.boutique-kicker) {
  width: 220px !important;
  max-width: 220px !important;
  margin: 7px 0 0 !important;
  color: rgba(255, 250, 242, 0.88) !important;
  font-size: 0.4rem !important;
  line-height: 1.5 !important;
  text-align: center !important;
}

.boutique-treatment .boutique-inline-link {
  display: inline-block !important;
  position: relative !important;
  width: auto !important;
  max-width: none !important;
  margin: 7px auto 0 !important;
  padding: 0 30px 0 0 !important;
  color: #fffaf2 !important;
  font-size: 0.51rem !important;
  text-align: center !important;
}

.boutique-treatment .boutique-inline-link::after {
  right: 0 !important;
}

.boutique-menu-lines {
  position: absolute !important;
  left: 154px !important;
  right: 38px !important;
  bottom: 16px !important;
  z-index: 4 !important;
  width: auto !important;
  transform: none !important;
}

.boutique-menu-lines a {
  grid-template-columns: minmax(0, 1fr) 80px !important;
  min-height: 17px !important;
  padding: 3px 0 !important;
}

.boutique-menu-lines strong {
  font-size: 0.39rem !important;
  text-align: left !important;
}

.boutique-menu-lines small {
  font-size: 0.25rem !important;
  text-align: right !important;
  white-space: nowrap !important;
}
