    :root {
      color-scheme: light;
      --ink: #2f2b28;
      --ink-soft: #625a54;
      --ink-faint: #958c84;
      --line: rgba(74, 61, 50, 0.11);
      --line-strong: rgba(74, 61, 50, 0.18);
      --gold: #b49a72;
      --charcoal: #322c28;
      --panel: rgba(255, 252, 247, 0.88);
      --placeholder-top: #f4ede5;
      --placeholder-bottom: #efe6dc;
      --shadow-soft: 0 18px 38px rgba(86, 67, 51, 0.05);
      --radius-xl: 36px;
      --radius-lg: 28px;
      --radius-md: 22px;
      --shell: min(1180px, calc(100% - 32px));
      --font-sans: "Zen Kaku Gothic New", "Hiragino Sans", "Yu Gothic", sans-serif;
      --font-serif: "Shippori Mincho", "Yu Mincho", serif;
      --section-space: clamp(88px, 10vw, 124px);
      --content-gap: clamp(36px, 4vw, 56px);
      --card-gap: clamp(20px, 2.8vw, 28px);
    }

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

    html {
      scroll-behavior: smooth;
    }

    body {
      margin: 0;
      min-width: 320px;
      color: var(--ink);
      background:
        radial-gradient(circle at 0 0, rgba(180, 154, 114, 0.12), transparent 26%),
        radial-gradient(circle at 100% 8%, rgba(143, 124, 101, 0.08), transparent 24%),
        linear-gradient(180deg, #fffdf9 0%, #f8f3ec 42%, #f4eee7 100%);
      font-family: var(--font-sans);
      line-height: 1.84;
      letter-spacing: 0.01em;
      overflow-x: hidden;
    }

    body::before {
      position: fixed;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(74, 61, 50, 0.02) 1px, transparent 1px),
        linear-gradient(180deg, rgba(74, 61, 50, 0.016) 1px, transparent 1px);
      background-size: 44px 44px;
      mask: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.55) 12%, rgba(0, 0, 0, 0.55) 90%, transparent);
      content: "";
      pointer-events: none;
      z-index: -2;
    }

    img,
    svg {
      display: block;
      max-width: 100%;
    }

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

    h1,
    h2,
    h3,
    p,
    ul,
    ol,
    li {
      margin: 0;
    }

    ul,
    ol {
      padding: 0;
    }

    .shell {
      width: var(--shell);
      margin: 0 auto;
    }

    .page {
      position: relative;
    }

    .topbar {
      --menu-topbar-bg: transparent;
      --menu-line: rgba(71, 55, 42, 0.12);
      --menu-line-strong: rgba(71, 55, 42, 0.2);
      --menu-active-color: #231b16;
      --menu-brand-color: #231b16;
      --menu-sub-color: rgba(35, 27, 22, 0.66);
      --menu-page-bg: rgba(255, 255, 255, 0.54);
      --menu-page-color: #5a493d;
      --menu-page-hover-color: #231b16;
      --menu-page-current-bg: #231b16;
      --menu-page-current-color: #fffdfa;
      --menu-nav-color: #5a493d;
      --menu-nav-active-color: #231b16;
      --menu-nav-indicator: #231b16;

      position: absolute;
      top: 0;
      right: 0;
      left: 0;
      border-bottom: 1px solid rgba(88, 68, 52, 0.08);
      background:
        linear-gradient(90deg, rgba(245, 240, 232, 0.96) 0%, rgba(245, 240, 232, 0.96) 43%, rgba(245, 240, 232, 0.56) 62%, rgba(245, 240, 232, 0.18) 100%);
      backdrop-filter: blur(12px);
    }

    .hero,
    .section {
      position: relative;
    }

    .hero {
      padding: 0;
    }

    .hero::before,
    .hero::after,
    .section::before {
      position: absolute;
      content: "";
      pointer-events: none;
      z-index: -1;
    }

    .hero::before {
      top: 26px;
      right: -90px;
      width: 340px;
      height: 340px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(180, 154, 114, 0.16) 0%, rgba(180, 154, 114, 0) 72%);
      filter: blur(10px);
    }

    .hero::after {
      bottom: -70px;
      left: -90px;
      width: 420px;
      height: 420px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(126, 108, 92, 0.1) 0%, rgba(126, 108, 92, 0) 74%);
      filter: blur(12px);
    }

    .hero--split {
      --hero-min-height: max(720px, 86svh);
      --hero-outer-pad: clamp(110px, 12vh, 140px);
      min-height: var(--hero-min-height);
      padding-block: var(--hero-outer-pad);
      overflow: hidden;
      isolation: isolate;
      background:
        radial-gradient(circle at 16% 18%, rgba(255, 253, 249, 0.94) 0%, rgba(255, 253, 249, 0.78) 22%, transparent 52%),
        radial-gradient(circle at 78% 72%, rgba(181, 129, 110, 0.24) 0%, rgba(181, 129, 110, 0.08) 30%, transparent 62%),
        linear-gradient(135deg, #fffdf9 0%, #f4ecdf 42%, #dcc4ab 100%);
    }

    .hero--split::before,
    .hero--split::after {
      content: "";
      pointer-events: none;
    }

    .hero--split::before {
      inset: 0;
      background:
        linear-gradient(180deg, rgba(15, 10, 8, 0.16) 0%, rgba(15, 10, 8, 0.06) 24%, rgba(15, 10, 8, 0.14) 100%),
        radial-gradient(circle at 76% 30%, rgba(192, 105, 131, 0.16) 0%, rgba(192, 105, 131, 0) 42%),
        radial-gradient(circle at 80% 74%, rgba(68, 42, 34, 0.18) 0%, rgba(68, 42, 34, 0) 44%);
      filter: none;
      opacity: 1;
      z-index: 2;
    }

    .hero--split::after {
      inset: 0;
      background:
        linear-gradient(90deg, rgba(255, 252, 247, 0.98) 0%, rgba(255, 252, 247, 0.93) 24%, rgba(255, 252, 247, 0.8) 38%, rgba(255, 252, 247, 0.36) 48%, rgba(255, 252, 247, 0.08) 60%, transparent 74%);
      opacity: 1;
      z-index: 3;
    }

    .section {
      padding: var(--section-space) 0;
      isolation: isolate;
    }

    .section::before {
      top: 12px;
      right: calc(50% - 50vw);
      bottom: 12px;
      left: calc(50% - 50vw);
      background:
        linear-gradient(180deg, rgba(255, 252, 248, 0.46), rgba(246, 239, 231, 0.24)),
        linear-gradient(90deg, rgba(74, 61, 50, 0.008) 1px, transparent 1px),
        linear-gradient(180deg, rgba(74, 61, 50, 0.007) 1px, transparent 1px);
      background-size: auto, 48px 48px, 48px 48px;
      z-index: -2;
    }

    h1,
    h2,
    h3 {
      font-family: var(--font-serif);
      line-height: 1.24;
      letter-spacing: 0.03em;
    }

    h1 {
      font-size: clamp(3rem, 7.2vw, 5.4rem);
      line-height: 1.06;
      text-wrap: balance;
    }

    h2 {
      font-size: clamp(2rem, 3.5vw, 3.1rem);
      text-wrap: balance;
    }

    h3 {
      font-size: 1.12rem;
      line-height: 1.46;
    }

    .section__head p,
    .service-panel__lead,
    .service-panel__body,
    .step-card p {
      color: var(--ink-soft);
    }

    .hero__layout {
      min-height: calc(var(--hero-min-height) - (var(--hero-outer-pad) * 2));
      position: relative;
      z-index: 4;
      display: flex;
      align-items: center;
    }

    .hero__content {
      --hero-content-shift: -10px;
      position: relative;
      z-index: 4;
      display: flex;
      flex-direction: column;
      justify-content: center;
      width: min(47%, 560px);
      max-width: 560px;
      padding-left: clamp(32px, 4vw, 72px);
      padding-right: clamp(18px, 2.4vw, 28px);
      padding-block: clamp(72px, 9vh, 116px) clamp(48px, 6vh, 72px);
      transform: translateY(var(--hero-content-shift));
    }

    .hero__kicker {
      margin: 0 0 clamp(28px, 3vw, 36px);
      color: #231b16;
      font-size: 11px;
      font-weight: 500;
      letter-spacing: 0.24em;
      opacity: 0.7;
      text-transform: uppercase;
    }

    .hero__title {
      margin: 0 0 clamp(32px, 3.4vw, 40px);
      color: #231b16;
      font-family: 'Shippori Mincho', serif;
      font-weight: 600;
      font-size: clamp(78px, 7.4vw, 120px);
      line-height: 1.08;
      letter-spacing: -0.055em;
      writing-mode: horizontal-tb;
      text-orientation: mixed;
      inline-size: fit-content;
      max-width: 100%;
    }

    .hero__title-line {
      display: block;
      line-height: 1.08;
    }

    .hero__title-line:first-child {
      font-size: 0.72em;
      letter-spacing: -0.02em;
      opacity: 0.75;
    }

    .hero__title-line--main {
      font-size: 1em;
      white-space: nowrap;
    }

    .hero__title-line + .hero__title-line {
      margin-top: clamp(8px, 1vw, 10px);
    }

    .hero__lead {
      max-width: 420px;
      margin: 0 0 clamp(40px, 4vw, 48px);
      color: rgba(35, 27, 22, 0.72);
      font-size: clamp(1rem, 1.05vw, 1.0625rem);
      line-height: 2;
      letter-spacing: 0.04em;
    }

    .service-panel {
      background: var(--panel);
      backdrop-filter: blur(14px);
      box-shadow: var(--shadow-soft);
    }

    .service-panel__eyebrow {
      display: block;
      margin-bottom: 12px;
      color: var(--gold);
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 0.18em;
      text-transform: uppercase;
    }

    .hero__actions {
      margin-top: 0;
      align-self: flex-start;
    }

    .hero__visual {
      position: absolute;
      isolation: isolate;
      top: -3%;
      right: -5%;
      bottom: -6%;
      z-index: 1;
      width: clamp(54%, 58vw, 60%);
      display: flex;
      align-items: center;
      justify-content: center;
      max-width: none;
      padding: 0;
      overflow: hidden;
      pointer-events: none;
      transform: none;
    }

    .hero__visual--carousel {
      display: block;
    }

    .hero__visual::before {
      position: absolute;
      inset: 4% -8% 0 20%;
      content: "";
      background:
        radial-gradient(circle at 58% 46%, rgba(205, 92, 136, 0.26) 0%, rgba(205, 92, 136, 0.12) 28%, rgba(214, 176, 132, 0.08) 50%, transparent 74%);
      filter: none;
      opacity: 0.18;
      transform: none;
      z-index: 0;
    }

    .hero__visual::after {
      content: "";
      position: absolute;
      inset: 0 34% 0 -20%;
      z-index: 2;
      pointer-events: none;
      background:
        radial-gradient(circle at 12% 50%, rgba(255, 246, 235, 0.08) 0%, rgba(255, 246, 235, 0) 38%),
        linear-gradient(90deg, rgba(18, 13, 11, 0.38) 0%, rgba(18, 13, 11, 0.22) 22%, rgba(18, 13, 11, 0.08) 46%, transparent 70%);
      filter: none;
      opacity: 0.32;
    }

    .hero-carousel {
      position: relative;
      z-index: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 100%;
      height: 100%;
      max-height: none;
      background: #0d0d0d;
      overflow: hidden;
    }

    .hero-carousel::after {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(11, 9, 8, 0.28) 0%, rgba(11, 9, 8, 0.14) 18%, rgba(11, 9, 8, 0.05) 38%, transparent 58%),
        linear-gradient(180deg, rgba(12, 9, 8, 0.14) 0%, rgba(12, 9, 8, 0.03) 26%, rgba(12, 9, 8, 0.06) 58%, rgba(12, 9, 8, 0.18) 100%),
        radial-gradient(circle at 76% 42%, rgba(255, 255, 255, 0.03) 0%, rgba(255, 255, 255, 0) 34%);
      opacity: 0.34;
      pointer-events: none;
    }

    .hero-carousel__image {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: var(--hero-image-position, 72% 48%);
      opacity: 1;
      filter: none;
      transform: none;
      transition: none;
      will-change: auto;
      image-rendering: auto;
      backface-visibility: hidden;
    }

    .hero-carousel__image--perfume2 {
      position: relative;
      inset: auto;
      display: block;
      width: 94%;
      height: 94%;
      object-fit: contain;
      object-position: center center;
      transform: none;
      filter: none;
    }

    .hero-carousel__image.is-active {
      opacity: 1;
    }

    .js .hero__content {
      opacity: 0;
      transform: translateY(calc(var(--hero-content-shift) + 14px));
      transition: opacity 0.95s ease 0.4s, transform 0.95s ease 0.4s;
    }

    .js .hero--ready .hero__content {
      opacity: 1;
      transform: translateY(var(--hero-content-shift));
    }

    .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 52px;
      padding: 0 24px;
      border-radius: 999px;
      font-size: 0.88rem;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      transition:
        transform 220ms ease,
        background-color 220ms ease,
        border-color 220ms ease,
        color 220ms ease,
        box-shadow 220ms ease;
    }

    .button:hover,
    .button:focus-visible {
      outline: none;
      transform: translateY(-1px);
    }

    .button--primary {
      background: var(--charcoal);
      color: #fffdfa;
      box-shadow: var(--shadow-soft);
    }

    .button--primary:hover,
    .button--primary:focus-visible {
      background: #27221f;
    }

    .hero__actions .button {
      min-height: 56px;
      padding: 14px 28px;
      border-radius: 20px;
      font-size: 14px;
      letter-spacing: 0.05em;
      box-shadow: 0 14px 28px rgba(47, 38, 31, 0.1);
    }

    .hero__actions .button:hover,
    .hero__actions .button:focus-visible {
      background: #312b27;
      box-shadow: 0 18px 34px rgba(47, 38, 31, 0.12);
      transform: translateY(-2px);
    }

    .button--secondary {
      border: 1px solid var(--line-strong);
      background: rgba(255, 252, 247, 0.78);
      color: var(--charcoal);
    }

    .button--secondary:hover,
    .button--secondary:focus-visible {
      border-color: rgba(74, 61, 50, 0.28);
      background: rgba(255, 252, 247, 0.94);
    }

    .section__head {
      display: grid;
      gap: 14px;
    }

    .section__head--narrow {
      max-width: 760px;
    }

    #products {
      padding-bottom: clamp(64px, 8vw, 92px);
      background: linear-gradient(180deg, #fffbf6 0%, #f8f1e8 100%);
    }

    #products::before {
      top: 0;
      bottom: 0;
      background:
        linear-gradient(180deg, rgba(255, 252, 248, 0.34), rgba(246, 239, 231, 0.14)),
        linear-gradient(90deg, rgba(74, 61, 50, 0.008) 1px, transparent 1px),
        linear-gradient(180deg, rgba(74, 61, 50, 0.007) 1px, transparent 1px);
      background-size: auto, 48px 48px, 48px 48px;
    }

    #flow {
      padding-top: clamp(116px, 11vw, 140px);
      padding-bottom: clamp(116px, 11vw, 140px);
      background: linear-gradient(180deg, #f8f2e8 0%, #fdfaf5 100%);
    }

    #flow::before {
      top: 0;
      right: calc(50% - 50vw);
      bottom: 0;
      left: calc(50% - 50vw);
      background:
        radial-gradient(circle at 82% 28%, rgba(196, 167, 129, 0.18) 0%, rgba(196, 167, 129, 0.04) 28%, transparent 58%),
        linear-gradient(180deg, rgba(255, 250, 243, 0.32), rgba(239, 229, 217, 0.16)),
        linear-gradient(90deg, rgba(74, 61, 50, 0.008) 1px, transparent 1px),
        linear-gradient(180deg, rgba(74, 61, 50, 0.007) 1px, transparent 1px);
      background-size: auto, auto, 48px 48px, 48px 48px;
    }

    #cta {
      padding-top: clamp(104px, 10vw, 120px);
      padding-bottom: clamp(116px, 11vw, 140px);
      background: #fffaf3;
    }

    #cta::before {
      top: 0;
      bottom: 0;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.42), rgba(255, 250, 243, 0.14)),
        linear-gradient(90deg, rgba(74, 61, 50, 0.006) 1px, transparent 1px),
        linear-gradient(180deg, rgba(74, 61, 50, 0.005) 1px, transparent 1px);
      background-size: auto, 52px 52px, 52px 52px;
    }

    .step-grid {
      display: grid;
      gap: clamp(20px, 2.8vw, 30px);
      margin-top: clamp(42px, 4.6vw, 58px);
      grid-template-columns: repeat(2, minmax(0, 1fr));
      list-style: none;
    }

    .step-card {
      position: relative;
      background: var(--panel);
      backdrop-filter: blur(14px);
      box-shadow: var(--shadow-soft);
    }

    .step-card span {
      display: block;
      color: var(--ink-faint);
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 0.18em;
    }

    .service-stack {
      display: grid;
      gap: clamp(28px, 4vw, 44px);
      margin-top: var(--content-gap);
    }

    .service-panel {
      display: grid;
      grid-template-columns: minmax(260px, 0.88fr) minmax(0, 1.12fr);
      gap: clamp(24px, 4vw, 42px);
      align-items: center;
      padding: clamp(24px, 4vw, 36px);
      border-radius: var(--radius-xl);
    }

    .service-panel--reverse .service-panel__visual {
      order: 2;
    }

    .service-panel--reverse .service-panel__content {
      order: 1;
    }

    .service-panel__visual {
      position: relative;
      display: block;
      width: 100%;
      aspect-ratio: 4 / 3;
      min-height: 420px;
      overflow: hidden;
      border-radius: var(--radius-lg);
      background: #15110f;
      transform: translateY(18px);
    }

    .service-panel:nth-of-type(even) .service-panel__visual {
      transform: translateY(-18px);
    }

    .service-panel__visual--space {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 0;
      aspect-ratio: auto;
      overflow: visible;
      border-radius: 0;
      background: transparent;
    }

    .service-panel__visual > .placeholder {
      display: none;
    }

    .service-panel__image {
      position: absolute;
      inset: 0;
      z-index: 1;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      display: block;
    }

    .service-panel__image--perfume14 {
      position: static;
      inset: auto;
      width: 88%;
      max-width: 88%;
      height: auto;
      max-height: 400px;
      object-fit: contain;
      object-position: center center;
      display: block;
      border-radius: 24px;
      box-shadow: 0 12px 40px rgba(0, 0, 0, 0.06);
      margin-inline: auto;
    }

    .service-panel__image--perfume15 {
      object-fit: cover;
      object-position: center center;
    }

    .service-panel__content {
      display: grid;
      gap: 14px;
    }

    .service-panel__lead {
      color: var(--charcoal);
      font-size: 1.02rem;
      line-height: 1.74;
    }

    .service-panel__body {
      font-size: 0.96rem;
    }

    .service-panel__uses {
      display: flex;
      flex-wrap: wrap;
      gap: 10px 12px;
      margin-top: 4px;
      list-style: none;
    }

    .service-panel__uses li {
      padding: 10px 14px;
      border: 1px solid var(--line-strong);
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.54);
      color: var(--charcoal);
      font-size: 0.82rem;
      font-weight: 700;
      letter-spacing: 0.03em;
      line-height: 1.4;
    }

    .journey-layout {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(300px, 0.82fr);
      gap: clamp(32px, 5vw, 68px);
      align-items: start;
    }

    .journey-layout__content {
      max-width: 680px;
    }

    .journey-layout__visual {
      position: relative;
      isolation: isolate;
      width: min(100%, 468px);
      min-height: 590px;
      justify-self: end;
      aspect-ratio: 2 / 3;
      overflow: visible;
      transform: translateY(40px);
    }

    .journey-layout__visual::before {
      position: absolute;
      inset: 28px -10px 18px 14%;
      border-radius: 44px;
      background:
        radial-gradient(circle at 36% 24%, rgba(255, 251, 246, 0.64) 0%, rgba(255, 251, 246, 0.18) 34%, transparent 68%),
        linear-gradient(180deg, rgba(232, 219, 203, 0.34), rgba(232, 219, 203, 0.08));
      content: "";
      z-index: 0;
    }

    .journey-layout__visual::after {
      position: absolute;
      inset: 0;
      border-radius: 40px;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 248, 240, 0.04) 44%, rgba(225, 211, 196, 0.1));
      content: "";
      pointer-events: none;
      z-index: 2;
    }

    .journey-layout__image {
      position: relative;
      z-index: 1;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 46%;
      border-radius: 40px;
      display: block;
      box-shadow: 0 40px 100px rgba(90, 70, 50, 0.14);
      filter: saturate(0.92) contrast(0.98) brightness(1.02);
    }

    .step-card {
      display: grid;
      gap: 12px;
      padding: 28px 24px 26px 28px;
      border-radius: var(--radius-lg);
      background: rgba(255, 255, 255, 0.72);
      border: 1px solid rgba(255, 255, 255, 0.42);
      backdrop-filter: blur(12px);
      box-shadow: 0 24px 60px rgba(80, 60, 40, 0.08);
    }

    .step-card::before {
      position: absolute;
      top: 22px;
      bottom: 22px;
      left: 24px;
      width: 1px;
      background: linear-gradient(180deg, rgba(180, 150, 110, 0.36), rgba(180, 150, 110, 0.08));
      content: "";
    }

    .step-card > * {
      position: relative;
      z-index: 1;
    }

    .step-card h3 {
      font-size: 1.02rem;
      padding-left: 22px;
    }

    .step-card p {
      padding-left: 22px;
    }

    .step-card span {
      position: relative;
      padding-left: 22px;
      color: rgba(150, 120, 80, 0.72);
    }

    .step-card span::before {
      position: absolute;
      top: 50%;
      left: 0;
      width: 11px;
      height: 11px;
      border-radius: 50%;
      background: linear-gradient(180deg, #d7be97 0%, #b59874 100%);
      box-shadow: 0 0 0 6px rgba(255, 250, 242, 0.9);
      content: "";
      transform: translateY(-50%);
    }

    .cta-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 24px;
      justify-content: center;
    }

    .placeholder {
      position: relative;
      overflow: hidden;
      background:
        linear-gradient(180deg, rgba(255, 253, 249, 0.54), rgba(239, 230, 220, 0.92)),
        linear-gradient(135deg, var(--placeholder-top), var(--placeholder-bottom));
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.62),
        inset 0 -22px 44px rgba(112, 88, 69, 0.05),
        var(--shadow-soft);
    }

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

    .placeholder::before {
      inset: 0;
      background:
        radial-gradient(circle at 18% 22%, rgba(255, 255, 255, 0.3), transparent 22%),
        radial-gradient(circle at 82% 74%, rgba(226, 214, 201, 0.38), transparent 28%);
      mix-blend-mode: screen;
    }

    .placeholder::after {
      inset: 18px;
      border-radius: inherit;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.12), transparent 28%, transparent 72%, rgba(74, 61, 50, 0.04)),
        linear-gradient(90deg, rgba(180, 154, 114, 0.04) 1px, transparent 1px),
        linear-gradient(180deg, rgba(180, 154, 114, 0.034) 1px, transparent 1px);
      background-size: auto, 26px 26px, 26px 26px;
      opacity: 0.66;
    }

    .placeholder--hero {
      aspect-ratio: 4 / 5;
      border-radius: var(--radius-xl);
    }

    .placeholder--service {
      aspect-ratio: 4 / 3;
      border-radius: var(--radius-lg);
    }

    .page-footer {
      width: var(--shell);
      margin: 0 auto;
      padding: 12px 0 42px;
    }

    @media (max-width: 900px) {
      .journey-layout {
        grid-template-columns: minmax(0, 1fr);
      }

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

      .service-panel__visual {
        min-height: 320px;
        transform: none;
      }

      .service-panel__visual--space {
        min-height: 0;
      }

      .service-panel--reverse .service-panel__visual,
      .service-panel--reverse .service-panel__content {
        order: initial;
      }

      .journey-layout__visual {
        justify-self: stretch;
        width: 100%;
        max-width: min(100%, 540px);
        min-height: 0;
        height: clamp(340px, 72vw, 460px);
        margin-inline: auto;
        aspect-ratio: auto;
        transform: translateY(16px);
      }

      .hero__layout {
        min-height: calc(var(--hero-min-height) - (var(--hero-outer-pad) * 2));
        display: flex;
      }

      .hero__content {
        max-width: 100%;
        padding-left: clamp(12px, 1.8vw, 24px);
        padding-right: clamp(18px, 2.4vw, 28px);
      }

      .hero__visual {
        width: clamp(52%, 58vw, 62%);
      }

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

    @media (max-width: 1040px) {
      .hero--split {
        --hero-outer-pad: clamp(92px, 10vh, 120px);
        min-height: 0;
      }

      .hero--split::before {
        opacity: 1;
      }

      .hero--split::after {
        background:
          linear-gradient(180deg, rgba(255, 251, 245, 0.94) 0%, rgba(255, 251, 245, 0.74) 30%, rgba(255, 251, 245, 0.34) 58%, rgba(255, 251, 245, 0.14) 100%),
          linear-gradient(90deg, rgba(255, 251, 245, 0.96) 0%, rgba(255, 251, 245, 0.88) 26%, rgba(255, 251, 245, 0.64) 44%, rgba(255, 251, 245, 0.2) 58%, transparent 76%);
        opacity: 1;
      }

      .hero__layout {
        min-height: calc(var(--hero-min-height) - (var(--hero-outer-pad) * 2));
        display: flex;
        align-items: center;
      }

      .hero__content {
        --hero-content-shift: 0px;
        gap: 0;
        width: min(100%, 560px);
        max-width: 560px;
        padding-left: clamp(8px, 2.2vw, 20px);
        padding-right: clamp(8px, 2.2vw, 20px);
        padding-block: clamp(96px, 16vw, 132px) clamp(40px, 8vw, 64px);
      }

      .hero__visual {
        inset: -2% -4% -4% 24%;
        width: auto;
        max-width: none;
        margin: 0;
        padding: 0;
        display: flex;
        overflow: hidden;
        pointer-events: none;
        transform: none;
      }

      .hero__visual::before {
        inset: 10% -12% 2% 26%;
        transform: none;
      }

      .hero__visual::after {
        inset: 0 22% 0 -18%;
        filter: none;
      }

      .hero__visual--carousel {
        display: block;
      }

      .hero-carousel {
        width: 100%;
        height: 100%;
      }

      .hero-carousel__image {
        object-position: var(--hero-image-position-mobile, var(--hero-image-position, 66% 46%));
        filter: none;
      }

      .hero-carousel__image--perfume2 {
        width: 96%;
        height: 96%;
        object-position: center center;
        transform: none;
        filter: none;
      }
    }

    @media (max-width: 768px) {
      :root {
        --shell: min(100% - 24px, 1180px);
        --section-space: clamp(80px, 18vw, 108px);
      }

      .hero--split {
        --hero-min-height: max(620px, 82svh);
        --hero-outer-pad: clamp(88px, 10vh, 108px);
        min-height: var(--hero-min-height);
        background:
          radial-gradient(circle at 40% 10%, rgba(255, 252, 246, 0.58) 0%, rgba(255, 252, 246, 0.18) 24%, transparent 46%),
          radial-gradient(circle at 78% 74%, rgba(181, 129, 110, 0.18) 0%, rgba(181, 129, 110, 0.05) 28%, transparent 58%),
          linear-gradient(160deg, #fcf6ee 0%, #f0e5d8 50%, #cdb8a3 100%);
      }

      .hero--split::before {
        opacity: 1;
      }

      .hero--split::after {
        background:
          linear-gradient(180deg, rgba(255, 250, 244, 0.96) 0%, rgba(255, 250, 244, 0.86) 18%, rgba(255, 250, 244, 0.76) 38%, rgba(255, 250, 244, 0.42) 62%, rgba(255, 250, 244, 0.18) 82%, rgba(255, 250, 244, 0.1) 100%),
          linear-gradient(90deg, rgba(255, 250, 244, 0.96) 0%, rgba(255, 250, 244, 0.9) 34%, rgba(255, 250, 244, 0.68) 56%, rgba(255, 250, 244, 0.28) 76%, rgba(255, 250, 244, 0.08) 92%, transparent 100%);
        opacity: 1;
      }

      .topbar {
        background: rgba(245, 240, 232, 0.94);
      }

      h1 {
        font-size: clamp(2.5rem, 12.8vw, 4rem);
      }

      h2 {
        font-size: clamp(1.78rem, 8vw, 2.4rem);
      }

      .hero__lead,
      .section__head p,
      .service-panel__lead,
      .service-panel__body,
      .step-card p {
        font-size: 0.96rem;
      }

      .hero__layout {
        min-height: calc(var(--hero-min-height) - (var(--hero-outer-pad) * 2));
        display: flex;
        align-items: center;
      }

      .hero__content {
        --hero-content-shift: 0px;
        gap: 0;
        width: min(100%, 430px);
        max-width: 430px;
        padding-left: 0;
        padding-right: 0;
        padding-block: clamp(110px, 22vw, 146px) clamp(36px, 10vw, 58px);
      }

      .hero__title {
        margin-bottom: 28px;
        font-size: clamp(2.75rem, 13vw, 3.875rem);
        line-height: 1.08;
      }

      .hero__title-line--main {
        white-space: nowrap;
      }

      .hero__title-line + .hero__title-line {
        margin-top: 8px;
      }

      .hero__kicker {
        margin-bottom: 28px;
        font-size: 10.5px;
        letter-spacing: 0.22em;
      }

      .hero__lead {
        max-width: 26ch;
        margin-bottom: 36px;
        font-size: clamp(1rem, 3.9vw, 1.0625rem);
        line-height: 1.9;
      }

      .hero__actions {
        margin-top: 0;
      }

      .hero__visual {
        inset: 0;
        width: auto;
        max-width: none;
        margin: 0;
        padding: 0;
      }

      .hero__visual::before {
        inset: 14% -18% 6% 18%;
        filter: none;
        opacity: 0.18;
      }

      .hero__visual::after {
        inset: 0 12% 0 -18%;
        opacity: 0.24;
        filter: none;
      }

      .hero-carousel {
        width: 100%;
        height: 100%;
      }

      .hero-carousel__image {
        object-position: var(--hero-image-position-mobile, 60% 44%);
        filter: none;
      }

      .hero-carousel__image--perfume2 {
        width: 96%;
        height: 96%;
        object-position: center center;
        transform: none;
        filter: none;
      }

      .step-card,
      .service-panel {
        padding: 24px 20px;
      }

      .step-card {
        padding: 24px 20px 22px 24px;
      }

      .step-card::before {
        left: 20px;
      }

      .service-panel__visual--space {
        min-height: 0;
      }

      .service-panel__image--perfume14 {
        width: 84%;
        max-width: 84%;
        max-height: 280px;
      }

      .cta-actions {
        flex-direction: column;
      }

      .cta-actions .button {
        width: 100%;
      }
    }

    @media (max-width: 380px) {
      .hero__title {
        font-size: clamp(2.375rem, 11vw, 3rem);
        letter-spacing: -0.055em;
      }

      .hero__title-line--main {
        transform: translateY(-2px);
      }
    }

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

      .hero-carousel__image {
        transition: none;
      }

      .js .hero__content {
        opacity: 1;
        transform: none;
        transition: none;
      }
    }
