:root {
  --text: #f7f4ef;
  --muted: rgba(255, 255, 255, 0.68);
  --line: rgba(255, 255, 255, 0.12);
  --accent: #ff1c1c;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  height: 100%;
  background: #000;
  color: var(--text);
  font-family: "Noto Sans SC", sans-serif;
  overflow: hidden;
}

body {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 92px 92px;
}

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

.top-fade-layer {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 172px;
  z-index: 18;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      rgba(0, 0, 0, 0.78) 0%,
      rgba(0, 0, 0, 0.56) 26%,
      rgba(0, 0, 0, 0.28) 56%,
      rgba(0, 0, 0, 0.08) 78%,
      rgba(0, 0, 0, 0) 100%
    );
}

.fullpage-shell {
  height: 100vh;
  overflow-y: auto;
  scroll-snap-type: y mandatory;
  scrollbar-width: none;
}

.fullpage-shell::-webkit-scrollbar {
  width: 0;
}

.panel {
  position: relative;
  height: 100vh;
  overflow: hidden;
  scroll-snap-align: start;
}

.product-panel {
  background: #07090b;
}

.panel-bg,
.panel-vignette,
.scene {
  position: absolute;
  inset: 0;
}

.panel-bg {
  background:
    radial-gradient(circle at 52% 24%, rgba(255, 235, 204, 0.12), transparent 18%),
    radial-gradient(circle at 58% 72%, rgba(125, 152, 91, 0.22), transparent 14%),
    linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.18) 36%, rgba(0, 0, 0, 0.56) 100%);
}

.panel-vignette {
  background:
    radial-gradient(circle at 0% 50%, rgba(0, 0, 0, 0.8), transparent 24%),
    radial-gradient(circle at 100% 50%, rgba(0, 0, 0, 0.72), transparent 22%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.6), transparent 16%, transparent 80%, rgba(0, 0, 0, 0.5));
}

.tone-1 {
  background: linear-gradient(120deg, #0b1014 0%, #182126 48%, #302717 100%);
}

.tone-2 {
  background: linear-gradient(120deg, #091019 0%, #121b29 46%, #151313 100%);
}

.tone-3 {
  background: linear-gradient(120deg, #130e15 0%, #2b1722 50%, #211418 100%);
}

.tone-4 {
  background: linear-gradient(120deg, #0e1212 0%, #202622 48%, #2c2a23 100%);
}

.tone-5 {
  background: linear-gradient(120deg, #0d1017 0%, #192434 46%, #22262d 100%);
}

.scene {
  z-index: 1;
}

.scene-foreground,
.scene-character {
  position: absolute;
  border-radius: 48% 52% 46% 54%;
}

.scene-character-shell {
  position: absolute;
  left: 50%;
  bottom: 9vh;
  width: min(28vw, 420px);
  height: min(56vw, 780px);
  transform: translateX(-10%);
  z-index: 2;
}

.scene-character-shell.has-image {
  width: min(38vw, 560px);
  height: min(62vw, 860px);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.35);
}

.scene-product-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.scene-foreground.left,
.scene-foreground.right {
  top: -4vh;
  width: 21vw;
  min-width: 240px;
  max-width: 380px;
  height: 110vh;
  background: linear-gradient(180deg, rgba(170, 176, 183, 0.95), rgba(62, 67, 75, 0.96));
  filter: blur(1.3px);
  opacity: 0.78;
}

.scene-foreground.left {
  left: -7vw;
  transform: rotate(10deg);
}

.scene-foreground.right {
  right: -5vw;
  transform: rotate(-8deg);
}

.scene-character {
  left: 50%;
  bottom: 9vh;
  width: min(28vw, 420px);
  height: min(56vw, 780px);
  transform: translateX(-10%);
}

.scene-character::before,
.scene-character::after {
  content: "";
  position: absolute;
  border-radius: 999px;
}

.scene-character::before {
  inset: 8% 28% 42% 28%;
  background: linear-gradient(180deg, #ffd6bf, #df8d66);
  border-radius: 48% 52% 42% 58%;
}

.scene-character::after {
  inset: 40% 24% 8% 24%;
  background: linear-gradient(180deg, #ff6e73, #b61d30);
  clip-path: polygon(14% 0, 100% 14%, 84% 100%, 0 84%);
  border-radius: 0;
}

.char-1 {
  background:
    radial-gradient(circle at 56% 12%, rgba(231, 182, 109, 0.94), rgba(190, 123, 72, 0.88) 20%, transparent 21%),
    linear-gradient(180deg, transparent 0 14%, rgba(255, 208, 173, 0.96) 14% 44%, rgba(224, 142, 104, 0.96) 44% 100%);
}

.char-2 {
  background:
    radial-gradient(circle at 56% 12%, rgba(174, 211, 255, 0.92), rgba(84, 123, 174, 0.88) 20%, transparent 21%),
    linear-gradient(180deg, transparent 0 14%, rgba(217, 228, 255, 0.96) 14% 44%, rgba(90, 116, 146, 0.96) 44% 100%);
}

.char-3 {
  background:
    radial-gradient(circle at 56% 12%, rgba(255, 173, 196, 0.94), rgba(194, 87, 128, 0.88) 20%, transparent 21%),
    linear-gradient(180deg, transparent 0 14%, rgba(255, 214, 236, 0.96) 14% 44%, rgba(190, 110, 142, 0.96) 44% 100%);
}

.char-4 {
  background:
    radial-gradient(circle at 56% 12%, rgba(234, 231, 211, 0.94), rgba(171, 164, 128, 0.88) 20%, transparent 21%),
    linear-gradient(180deg, transparent 0 14%, rgba(246, 237, 214, 0.96) 14% 44%, rgba(180, 166, 127, 0.96) 44% 100%);
}

.char-5 {
  background:
    radial-gradient(circle at 56% 12%, rgba(173, 219, 255, 0.94), rgba(82, 134, 194, 0.88) 20%, transparent 21%),
    linear-gradient(180deg, transparent 0 14%, rgba(211, 232, 255, 0.96) 14% 44%, rgba(82, 121, 176, 0.96) 44% 100%);
}

.side-brand {
  position: absolute;
  left: 34px;
  top: 28px;
  z-index: 3;
}

.side-brand-global {
  position: fixed;
  z-index: 20;
}

.brand-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-family: "Cormorant Garamond", serif;
  font-size: 2.8rem;
  line-height: 0.78;
  font-weight: 600;
}

.brand-row {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: "Cormorant Garamond", serif;
}

.brand-row-image {
  display: block;
  max-width: 300px;
  max-height: 100px;
  width: auto;
  height: auto;
  object-fit: contain;
  flex: 0 0 auto;
}

.brand-row-mark {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 50%;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1;
}

.brand-row-text {
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
}

.top-nav {
  position: absolute;
  top: 28px;
  left: 160px;
  right: 36px;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.top-nav-global {
  position: fixed;
  z-index: 20;
  padding-top: 18px;
}

.top-nav nav {
  position: relative;
  z-index: 20;
  display: flex;
  gap: 28px;
  flex: 1;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}

.top-nav nav a,
.top-button,
.panel-tags span,
.panel-cta,
.contact-links a {
  letter-spacing: 0.04em;
}

.top-nav nav a {
  font-size: 0.9rem;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.92);
  white-space: nowrap;
}

.lang-switcher {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: 14px;
}

.lang-switcher-button {
  border: 0;
  padding: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.66);
  font: inherit;
  font-size: 0.84rem;
  font-weight: 700;
  cursor: pointer;
}

.lang-switcher-button.is-active {
  color: #fff;
}

.lang-switcher-sep {
  color: rgba(255, 255, 255, 0.36);
  font-size: 0.82rem;
}

.nav-divider {
  width: 1px;
  height: 16px;
  background: rgba(255, 255, 255, 0.32);
}

.top-button {
  position: relative;
  z-index: 20;
  padding: 14px 28px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.02);
}

.contact-jump-button {
  position: fixed;
  right: 6px;
  top: 50%;
  z-index: 24;
  display: grid;
  gap: 8px;
  align-content: center;
  justify-items: center;
  width: 56px;
  min-height: 210px;
  padding: 18px 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(18, 19, 24, 0.9), rgba(18, 19, 24, 0.62)),
    radial-gradient(circle at top, rgba(255, 84, 84, 0.24), transparent 56%);
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  cursor: pointer;
  transform: translateY(-50%);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.28);
  transition:
    transform 240ms ease,
    border-color 240ms ease,
    background 240ms ease,
    box-shadow 240ms ease;
}

.contact-jump-button:hover,
.contact-jump-button:focus-visible {
  border-color: rgba(255, 84, 84, 0.58);
  background:
    linear-gradient(180deg, rgba(24, 25, 31, 0.96), rgba(24, 25, 31, 0.72)),
    radial-gradient(circle at top, rgba(255, 84, 84, 0.36), transparent 56%);
  transform: translateY(-50%) translateX(-4px);
  box-shadow: 0 22px 44px rgba(0, 0, 0, 0.34);
}

.contact-jump-button span {
  display: block;
  line-height: 1;
}

.panel-copy {
  position: absolute;
  left: 96px;
  bottom: 22vh;
  z-index: 3;
  max-width: 680px;
}

.panel-kicker {
  margin: 0 0 18px;
  font-size: 0.84rem;
  letter-spacing: 0.18em;
  color: rgba(255, 255, 255, 0.82);
}

.panel-copy h1,
.panel-rail-focus h2 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
}

.panel-copy h1 {
  max-width: 8ch;
  font-size: clamp(3.3rem, 5vw, 5.9rem);
  line-height: 0.98;
  text-shadow: 0 12px 28px rgba(0, 0, 0, 0.34);
}

.panel-copy h1 span {
  display: block;
}

.panel-tags {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.panel-tags span {
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  font-size: 0.82rem;
  font-weight: 700;
}

.panel-cta {
  margin-top: 28px;
  display: inline-flex;
  min-width: 164px;
  justify-content: center;
  padding: 20px 26px;
  border-radius: 8px;
  background: #fff;
  color: #d41313;
  font-size: 1rem;
  font-weight: 800;
}

.panel-rail {
  position: absolute;
  top: 24vh;
  right: 62px;
  z-index: 3;
  width: 320px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  text-align: right;
}

.panel-rail-focus h2 {
  font-size: 1.08rem;
  font-weight: 800;
}

.panel-rail-focus p {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.64);
  font-weight: 700;
}

.panel-rail ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 22px;
}

.panel-rail li {
  color: rgba(255, 255, 255, 0.48);
  font-weight: 700;
}

.panel-rail li.active,
.panel.is-active .panel-rail li.active {
  color: #fff;
}

.scroll-indicator {
  position: absolute;
  left: 50%;
  bottom: 26px;
  z-index: 3;
  transform: translateX(-50%);
  font-size: 3rem;
  font-family: "Cormorant Garamond", serif;
  color: var(--accent);
}

.contact-panel {
  background: linear-gradient(180deg, #f8f5ef 0%, #f4f0ea 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: #22252c;
  overflow: hidden;
  height: auto;
  min-height: 34vh;
}

.contact-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(255, 251, 245, 0.34) 0%,
    rgba(255, 251, 245, 0.2) 36%,
    rgba(255, 251, 245, 0.08) 68%,
    rgba(255, 251, 245, 0.02) 100%
  );
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  mask-image: linear-gradient(180deg, #000 0%, rgba(0, 0, 0, 0.82) 42%, rgba(0, 0, 0, 0.28) 78%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, #000 0%, rgba(0, 0, 0, 0.82) 42%, rgba(0, 0, 0, 0.28) 78%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}

.contact-layout {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 28px;
  padding: 28px min(5vw, 56px) 4px;
  position: relative;
  z-index: 1;
  max-width: 1160px;
  width: calc(100% - 48px);
  margin: 0 auto;
}

.contact-panel::before {
  content: "HASUKI HASUKI HASUKI HASUKI HASUKI HASUKI";
  position: absolute;
  left: 0;
  right: auto;
  top: 50%;
  bottom: auto;
  font-size: clamp(9rem, 30vw, 20rem);
  font-weight: 800;
  letter-spacing: 0.12em;
  line-height: 0.9;
  color: rgba(197, 136, 88, 0.045);
  pointer-events: none;
  white-space: nowrap;
  animation: contact-marquee 30s linear infinite;
}

.contact-brand-block {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 280px;
  flex: 0 0 280px;
  align-self: flex-start;
  margin-left: -20%;
}

.contact-logo-lockup {
  display: flex;
  align-items: center;
  gap: 20px;
  color: inherit;
  text-decoration: none;
}

.contact-logo-image {
  display: block;
  max-width: 260px;
  max-height: 104px;
  width: auto;
  height: auto;
  object-fit: contain;
  flex: 0 0 auto;
}

.contact-logo-lockup .brand-row-mark {
  width: 72px;
  height: 72px;
  font-size: 2.1rem;
}

.contact-logo-word {
  font-size: 1.48rem;
  font-weight: 800;
  letter-spacing: 0.18em;
}

.contact-office-block {
  display: grid;
  gap: 8px;
}

.contact-office-address {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.75;
  color: rgba(34, 37, 44, 0.72);
}

.contact-office-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
}

.contact-office-link {
  color: rgba(34, 37, 44, 0.66);
  font-size: 0.88rem;
  text-decoration: none;
}

.contact-office-link:hover {
  color: #111;
}

.contact-hotlines {
  display: grid;
  gap: 14px;
}

.contact-hotline {
  display: grid;
  gap: 6px;
  color: inherit;
  text-decoration: none;
}

.contact-hotline-label {
  font-size: 0.98rem;
  color: rgba(34, 37, 44, 0.62);
}

.contact-hotline strong {
  font-size: clamp(1.42rem, 1.8vw, 1.96rem);
  line-height: 1.1;
}

.contact-link-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(126px, 174px));
  gap: 24px;
  flex: 0 1 470px;
  align-content: start;
  justify-content: end;
  margin-left: auto;
  margin-right: -20px;
}

.contact-link-group {
  display: grid;
  gap: 4px;
  justify-items: start;
  text-align: left;
}

.contact-link-group h3 {
  margin: 0 0 2px;
  font-size: 1.18rem;
}

.contact-link-group:last-child {
  gap: 0;
  align-content: start;
}

.contact-link-group:last-child h3 {
  margin-bottom: 0;
  line-height: 1;
}

.contact-link-group:last-child a {
  margin-top: 15px;
  line-height: 1.1;
}

.contact-link-group a {
  font-size: 1rem;
  color: rgba(34, 37, 44, 0.72);
  text-decoration: none;
}

.contact-link-group a:hover,
.contact-meta a:hover {
  color: #111;
}

.contact-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 14px;
  padding: 0 min(5vw, 56px) 10px;
  position: relative;
  z-index: 1;
  max-width: 1160px;
  width: calc(100% - 48px);
  margin: 0 auto;
}

.contact-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-start;
  align-items: flex-start;
  text-align: left;
  font-size: 0.76rem;
  color: rgba(34, 37, 44, 0.64);
  max-width: 70%;
}

.contact-meta a {
  color: rgba(34, 37, 44, 0.72);
  text-decoration: none;
}

.contact-socials {
  display: flex;
  gap: 10px;
  margin-right: -10px;
  align-items: flex-end;
}

.contact-socials a,
.contact-social-button {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.96);
  color: #8a8a8a;
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(55, 44, 28, 0.04);
  border: 1px solid rgba(0, 0, 0, 0.05);
  cursor: pointer;
}

.contact-socials a img,
.contact-social-button img {
  width: 32px;
  height: 32px;
  display: block;
  object-fit: contain;
  filter: grayscale(1) brightness(0.62);
}

.contact-social-qr {
  position: relative;
  display: flex;
}

.contact-qr-popover {
  position: absolute;
  right: 0;
  bottom: calc(100% + 14px);
  width: 166px;
  padding: 10px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.12);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
}

.contact-social-qr:hover .contact-qr-popover,
.contact-social-qr:focus-within .contact-qr-popover {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.contact-qr-popover img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 12px;
}

.contact-qr-popover span {
  display: block;
  color: rgba(34, 37, 44, 0.72);
  font-size: 0.84rem;
  line-height: 1.5;
  text-align: center;
}

.contact-qr-popover.is-empty {
  width: 152px;
}

.about-body {
  min-height: 100vh;
  margin: 0;
  overflow-x: hidden;
  overflow-y: auto;
  background: #000;
  color: #181716;
}

.about-nav a[aria-current="page"] {
  color: #111;
}

.about-page {
  min-height: 100vh;
  padding: 116px 0 0;
  display: flex;
  flex-direction: column;
}

.about-simple-page {
  width: 100%;
  margin: 0;
  padding: 0;
  background: #000;
}

.animate-fade-up {
  opacity: 0;
  transform: translateY(40px);
  transition: 0.6s ease;
}

.animate-fade-up.visible {
  opacity: 1;
  transform: translateY(0);
}

.about-rx-hero,
.about-rx-intro,
.about-rx-business,
.about-rx-ip,
.about-rx-coop {
  width: 100%;
}

.about-rx-hero {
  position: relative;
  min-height: 62vh;
  overflow: hidden;
  background: #111;
}

.about-rx-hero-media {
  position: absolute;
  inset: 0;
}

.about-rx-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-rx-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
}

.about-rx-hero-copy {
  position: relative;
  z-index: 1;
  min-height: 62vh;
  display: grid;
  place-content: center;
  text-align: center;
  padding: 52px 20px;
}

.about-rx-hero-copy h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(3rem, 7vw, 6rem);
  font-weight: 800;
}

.about-rx-hero-copy p {
  margin: 14px 0 0;
  color: #bfbfbf;
  font-size: 18px;
  line-height: 1.7;
}

.about-rx-intro {
  padding: 100px 20px;
  background: #000;
}

.about-rx-hero + .about-rx-intro {
  margin-top: clamp(22px, 3vw, 42px);
}

.about-rx-intro-logo {
  margin: 0 auto 34px;
  width: min(200px, 60vw);
  min-height: 44px;
  display: grid;
  place-items: center;
}

.about-rx-intro-logo img {
  width: 100%;
  height: auto;
  max-width: 200px;
  object-fit: contain;
}

.about-rx-logo-fallback {
  color: #fff;
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.about-rx-intro-copy {
  width: min(900px, 100%);
  margin: 0 auto;
  text-align: center;
  display: grid;
  gap: 18px;
}

.about-rx-intro-copy p {
  margin: 0;
  color: #d0d0d0;
  font-size: 16px;
  line-height: 1.8;
}

.about-rx-business {
  padding: 100px 0px;
  background: #000;
}

.about-rx-section-head {
  text-align: center;
  margin-bottom: 60px;
}

.about-rx-section-head h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(2rem, 3.4vw, 3rem);
  font-weight: 800;
  letter-spacing: 0.04em;
}

.about-rx-section-head p {
  margin: 10px 0 0;
  color: #cfcfcf;
  font-size: clamp(1rem, 1.7vw, 1.35rem);
  font-weight: 500;
}

.about-rx-business-grid {
  width: min(1800px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 100px;
}

.about-rx-business-item {
  font-size: 14px;
  aspect-ratio: 1 / 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 12px;
  padding: 30px;
  border: 1px solid rgb(109, 109, 109);
  background:
    linear-gradient(180deg, rgba(10, 18, 42, 0.7), rgba(7, 12, 28, 0.82)),
    repeating-linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.02) 0px,
      rgba(255, 255, 255, 0.02) 2px,
      transparent 2px,
      transparent 34px
    );
  transition: 0.4s;
}

.about-rx-business-item:hover {
  background: #fff;
  border-color: #fff;
  transform: translateY(-4px);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.24);
}

.about-rx-business-item:hover .about-rx-business-no {
  -webkit-text-stroke: 1px rgba(0, 0, 0, 0.9);
}

.about-rx-business-item:hover .about-rx-business-divider {
  background: rgba(0, 0, 0, 0.9);
}

.about-rx-business-item:hover .about-rx-business-copy h3,
.about-rx-business-item:hover .about-rx-business-copy p {
  color: #111;
}

.about-rx-business-no {
  color: transparent;
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.78);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.04em;
}

.about-rx-business-divider {
  width: 36px;
  height: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.88);
}

.about-rx-business-copy {
  max-width: 92%;
  text-align: center;
}

.about-rx-business-copy h3 {
  margin: 2px 0 0;
  color: #fff;
  font-size: clamp(1.35rem, 2.2vw, 1.95rem);
  font-weight: 700;
  transition: color 0.22s ease;
}

.about-rx-business-copy p {
  margin: 16px 0 0;
  color: #d4d9e5;
  font-size: 14px;
  line-height: 1.75;
  transition: color 0.22s ease;
}

.about-rx-collab {
  padding: 86px 20px 96px;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.05), transparent 30%),
    radial-gradient(circle at 80% 100%, rgba(255, 255, 255, 0.04), transparent 34%),
    radial-gradient(circle, rgba(255, 255, 255, 0.05) 0 1px, transparent 1px 100%),
    linear-gradient(180deg, #161616, #101010);
  background-size: auto, auto, 16px 16px, auto;
}

.about-rx-collab-track {
  width: min(1380px, 100%);
  margin: 0 auto;
  display: flex;
  gap: 12px;
  min-height: 460px;
}

.about-rx-collab-card {
  position: relative;
  flex: 1 1 0;
  min-width: 90px;
  border-radius: 14px;
  overflow: hidden;
  background: var(--collab-bg, #2b2b2b);
  transition: flex-basis 0.45s ease, flex-grow 0.45s ease, opacity 0.35s ease, filter 0.35s ease;
}

.about-rx-collab-card.is-active {
  flex: 3.6 1 0;
}

.about-rx-collab-card.is-muted {
  opacity: 0.52;
  filter: grayscale(0.3);
}

.about-rx-collab-poster {
  position: absolute;
  inset: 0;
}

.about-rx-collab-poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.45s ease;
}

.about-rx-collab-card.is-active .about-rx-collab-poster img {
  transform: scale(1.06) translateX(1.5%);
}

.about-rx-collab-mask {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7, 7, 9, 0.35), rgba(7, 7, 9, 0.84));
  transition: background 0.35s ease;
}

.about-rx-collab-card.is-active .about-rx-collab-mask {
  background: linear-gradient(180deg, rgba(7, 7, 9, 0.18), rgba(7, 7, 9, 0.7));
}

.about-rx-collab-info {
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 26px;
  z-index: 1;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.about-rx-collab-card.is-active .about-rx-collab-info {
  opacity: 1;
  transform: translateY(0);
}

.about-rx-collab-ip {
  display: inline-block;
  margin-bottom: 8px;
  color: #fff;
  font-size: 0.84rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.about-rx-collab-info h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.2rem, 2vw, 1.7rem);
  line-height: 1.35;
}

.about-rx-collab-info p {
  margin: 12px 0 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.94rem;
  line-height: 1.72;
  max-width: 38ch;
}

.about-rx-collab-info a {
  display: inline-flex;
  margin-top: 16px;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.58);
  background: rgba(0, 0, 0, 0.26);
  text-decoration: none;
  font-size: 0.88rem;
  transition: background 0.25s ease, color 0.25s ease;
}

.about-rx-collab-info a:hover {
  background: #fff;
  color: #111;
}

.about-rx-collab-tabs {
  width: min(1380px, 100%);
  margin: 18px auto 0;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}

.about-rx-collab-tab {
  min-height: 44px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.03);
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.9rem;
  cursor: pointer;
  transition: color 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}

.about-rx-collab-tab.is-active {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.36);
  background: rgba(255, 255, 255, 0.12);
}

.about-rx-coop {
  padding: 100px 20px;
  background: #000;
}

.about-rx-coop-grid {
  width: min(1320px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 20px 16px;
}

.about-rx-coop-item {
  min-height: 84px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.01);
}

.about-rx-coop-item img {
  max-width: min(150px, 100%);
  max-height: 56px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(1);
  transition: filter 0.2s ease;
}

.about-rx-coop-item:hover img {
  filter: grayscale(0);
}

.about-simple-page > section + section {
  margin-top: clamp(56px, 8vw, 124px);
}

.about-v2-hero {
  position: relative;
  min-height: 58vh;
  overflow: hidden;
  border-radius: 0;
  box-shadow: none;
}

.about-v2-hero-image {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, #1a1c23 0%, #0f1116 100%);
}

.about-v2-hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-v2-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8, 9, 12, 0.26) 0%, rgba(8, 9, 12, 0.54) 100%),
    linear-gradient(90deg, rgba(8, 9, 12, 0.58) 0%, rgba(8, 9, 12, 0.18) 38%, rgba(8, 9, 12, 0.12) 100%);
}

.about-v2-hero-copy {
  position: relative;
  z-index: 1;
  min-height: 58vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
  padding: 72px clamp(28px, 5vw, 96px);
  color: #fff;
}

.about-v2-hero-copy h1 {
  margin: 0;
  font-size: clamp(3.2rem, 7vw, 6rem);
  font-weight: 800;
  line-height: 0.94;
  letter-spacing: -0.03em;
}

.about-v2-hero-copy p {
  margin: 0;
  font-size: clamp(1.1rem, 2vw, 1.7rem);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
}

.about-v2-intro {
  margin-top: 0;
  border-radius: 0;
  background: #f1f1f1;
  box-shadow: none;
  padding: 160px clamp(20px, 5vw, 82px);
}

.about-v2-intro-head {
  text-align: center;
  max-width: 980px;
  margin: 0 auto;
}

.about-v2-intro-head h2 {
  margin: 0;
  font-size: clamp(2rem, 3.6vw, 3.4rem);
  font-weight: 900;
  letter-spacing: 0.06em;
  color: #141414;
}

.about-v2-intro-head p {
  margin: 10px 0 0;
  font-size: clamp(1.15rem, 1.8vw, 1.5rem);
  font-weight: 700;
  color: rgba(20, 20, 20, 0.86);
}

.about-v2-intro-body {
  margin: 36px auto 0;
  display: grid;
  gap: 18px;
  max-width: 1100px;
}

.about-v2-intro-body p {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: rgba(20, 20, 20, 0.8);
  font-size: 1.04rem;
  line-height: 1.9;
}

.about-v2-intro-body .about-v2-intro-lead {
  background: transparent;
  color: #171717;
  font-size: 1.12rem;
  font-weight: 700;
}

.about-v2-ip {
  position: relative;
  margin: 0;
  padding: 136px 0 168px;
  overflow: hidden;
  background: #0f1116;
}

.about-v2-ip::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(10, 11, 15, 0.58) 0%, rgba(10, 11, 15, 0.88) 100%),
    radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0) 56%);
}

.about-v2-ip-hero {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  min-height: 0;
  background: linear-gradient(180deg, #1a1d27 0%, #12141d 100%);
}

.about-v2-ip-hero img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  filter: saturate(0.8) brightness(0.62);
}

.about-v2-ip-head {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 156px 20px 60px;
}

.about-v2-ip-head h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(2rem, 3.8vw, 3.1rem);
  font-weight: 900;
  letter-spacing: 0.06em;
}

.about-v2-ip-head p {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: clamp(1.12rem, 2vw, 1.5rem);
  font-weight: 600;
}

.about-v2-ip-list {
  position: relative;
  z-index: 2;
  width: min(1380px, calc(100vw - 56px));
  margin: 0 auto;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(176px, 1fr);
  gap: 0;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 8px 0 16px;
  scrollbar-width: thin;
}

.about-v2-ip-list::-webkit-scrollbar {
  height: 8px;
}

.about-v2-ip-list::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.24);
  border-radius: 999px;
}

.about-v2-ip-card {
  min-width: 176px;
}

.about-v2-ip-card-image {
  width: 100%;
  aspect-ratio: 3 / 4;
  background: #20222c;
}

.about-v2-ip-card-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.about-v2-ip-card p {
  margin: 12px 0 0;
  text-align: center;
  color: #fff;
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.about-v2-team {
  position: relative;
  margin: 0;
  padding: 146px clamp(18px, 6vw, 88px) 176px;
  overflow: hidden;
  background: #0a0b10;
}

.about-v2-team-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(180deg, #11131b 0%, #090a10 100%);
}

.about-v2-team-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(0.86) brightness(0.66);
}

.about-v2-team-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 50% 0%, rgba(8, 9, 12, 0.1) 0%, rgba(8, 9, 12, 0.86) 76%),
    linear-gradient(180deg, rgba(8, 9, 12, 0.68) 0%, rgba(8, 9, 12, 0.92) 100%);
}

.about-v2-team-head {
  position: relative;
  z-index: 2;
  text-align: center;
}

.about-v2-team-head h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(2rem, 3.7vw, 3rem);
  font-weight: 900;
  letter-spacing: 0.05em;
}

.about-v2-team-head p {
  margin: 10px 0 0;
  color: rgba(255, 210, 56, 0.95);
  font-size: clamp(1.08rem, 2vw, 1.42rem);
  font-weight: 600;
}

.about-v2-team-grid {
  position: relative;
  z-index: 2;
  width: min(1320px, 100%);
  margin: 54px auto 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(22px, 3.6vw, 56px);
}

.about-v2-team-card {
  display: grid;
  grid-template-columns: 168px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.about-v2-team-avatar {
  width: 168px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.24);
}

.about-v2-team-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-v2-team-avatar span {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.88);
  font-size: 2rem;
  font-weight: 800;
}

.about-v2-team-copy h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 1.05;
}

.about-v2-team-copy h4 {
  margin: 10px 0 0;
  color: #ffd73a;
  font-size: clamp(1.04rem, 1.6vw, 1.48rem);
  font-weight: 600;
  line-height: 1.4;
}

.about-v2-team-copy p {
  margin: 18px 0 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: clamp(0.95rem, 1.2vw, 1.16rem);
  line-height: 1.82;
}

.about-v2-coop {
  margin: 0;
  padding: 142px clamp(18px, 6vw, 88px) 186px;
  background: #f1f1f1;
}

.about-v2-coop-head {
  text-align: center;
}

.about-v2-coop-head h2 {
  margin: 0;
  color: #141414;
  font-size: clamp(2.2rem, 3.8vw, 3.5rem);
  font-weight: 900;
  letter-spacing: 0.05em;
}

.about-v2-coop-head p {
  margin: 10px 0 0;
  color: rgba(20, 20, 20, 0.86);
  font-size: clamp(1.1rem, 2vw, 1.6rem);
  font-weight: 600;
}

.about-v2-coop-grid {
  width: min(1360px, 100%);
  margin: 72px auto 0;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 34px 42px;
}

.about-v2-coop-item {
  min-height: 70px;
  display: grid;
  place-items: center;
}

.about-v2-coop-item img {
  display: block;
  max-width: min(180px, 100%);
  max-height: 76px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(100%);
  transition: filter 0.2s ease, transform 0.2s ease;
}

.about-v2-coop-item:hover img {
  filter: grayscale(0%);
  transform: translateY(-2px);
}

.about-kicker {
  margin: 0 0 14px;
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.8rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.about-section-head {
  text-align: center;
}

.about-section-head h2,
.about-hero-copy h1 {
  margin: 0;
  font-family: "Noto Sans SC", sans-serif;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
}

.about-hero-panel {
  position: relative;
  min-height: 680px;
  padding: 0;
  overflow: hidden;
  border-radius: 38px;
  box-shadow: 0 34px 84px rgba(10, 10, 16, 0.28);
}

.about-hero-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 100%),
    linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 18px 18px, 72px 72px, 72px 72px;
  opacity: 0.58;
  pointer-events: none;
  z-index: 2;
}

.about-hero-backdrop {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, #20222b 0%, #101218 100%);
}

.about-hero-backdrop img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(7, 8, 11, 0.34) 0%, rgba(7, 8, 11, 0.16) 28%, rgba(7, 8, 11, 0.52) 100%),
    linear-gradient(90deg, rgba(8, 9, 12, 0.62) 0%, rgba(8, 9, 12, 0.18) 36%, rgba(8, 9, 12, 0.12) 100%);
  pointer-events: none;
  z-index: 1;
}

.about-hero-copy {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  max-width: 520px;
  color: #fff;
}

.about-hero-copy-wide {
  min-height: 680px;
  padding: 74px clamp(26px, 5vw, 72px);
}

.about-hero-copy h1 {
  font-size: clamp(3.8rem, 7vw, 6.8rem);
}

.about-intro-panel,
.about-ip-panel {
  margin-top: 34px;
  border-radius: 34px;
  overflow: hidden;
}

.about-intro-panel {
  padding: 56px clamp(22px, 4vw, 54px);
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 216, 92, 0.18), transparent 24%),
    radial-gradient(circle at 100% 18%, rgba(255, 122, 122, 0.18), transparent 22%),
    linear-gradient(180deg, #fff9ef 0%, #fff7fb 50%, #fdfcff 100%);
  box-shadow: 0 24px 62px rgba(34, 26, 22, 0.08);
}

.about-intro-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.62fr);
  gap: 28px;
  margin-top: 26px;
  align-items: start;
}

.about-intro-copy {
  display: grid;
  gap: 18px;
}

.about-intro-lead {
  margin: 0;
  padding: 26px 28px;
  color: #1a1a1a;
  font-size: 1.16rem;
  font-weight: 700;
  line-height: 1.85;
  border: 1px solid rgba(24, 23, 22, 0.06);
  background: linear-gradient(135deg, rgba(255, 242, 204, 0.9), rgba(255, 231, 242, 0.86));
  box-shadow: 0 18px 40px rgba(29, 24, 18, 0.06);
}

.about-intro-copy p,
.about-intro-quote {
  border: 1px solid rgba(24, 23, 22, 0.06);
  background: rgba(255, 255, 255, 0.64);
  box-shadow: 0 18px 40px rgba(29, 24, 18, 0.06);
}

.about-intro-copy p {
  margin: 0;
  padding: 24px 26px;
  color: rgba(24, 23, 22, 0.74);
  line-height: 1.9;
}

.about-intro-quote {
  padding: 26px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 247, 220, 0.9)),
    rgba(255, 255, 255, 0.84);
}

.about-intro-quote blockquote {
  margin: 0;
  font-family: "Noto Sans SC", sans-serif;
  font-size: clamp(1.9rem, 3vw, 2.8rem);
  font-weight: 800;
  line-height: 1.18;
}

.about-ip-panel {
  padding: 56px clamp(22px, 4vw, 54px);
  background:
    radial-gradient(circle at top, rgba(255, 214, 102, 0.08), transparent 30%),
    linear-gradient(180deg, #171922 0%, #101218 100%);
  box-shadow: 0 26px 70px rgba(16, 15, 24, 0.26);
}

.about-ip-panel .about-kicker,
.about-ip-panel .about-section-head h2 {
  color: #f7f4ef;
}

.about-ip-hero {
  margin-top: 28px;
  overflow: hidden;
  border-radius: 28px;
  aspect-ratio: 16 / 5.6;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}

.about-ip-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-ip-grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(220px, 220px);
  gap: 18px;
  margin-top: 30px;
  overflow-x: auto;
  padding-bottom: 10px;
  scrollbar-width: thin;
}

.about-ip-card {
  display: grid;
  gap: 16px;
  min-height: 320px;
  overflow: hidden;
  padding: 16px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.about-ip-card-visual {
  overflow: hidden;
  border-radius: 22px;
  aspect-ratio: 1 / 1.15;
  background: rgba(255, 255, 255, 0.08);
}

.about-ip-card-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-ip-card-visual span {
  display: grid;
  place-items: center;
  height: 100%;
  color: rgba(255, 255, 255, 0.75);
  font-size: 1.6rem;
  font-weight: 800;
}

.about-ip-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
  text-align: center;
}

.about-ip-copy h3 {
  margin: 0;
  color: #fff8ef;
  font-size: 1.08rem;
  line-height: 1.35;
}

.about-ip-card.accent-1 {
  background:
    linear-gradient(180deg, rgba(255, 133, 92, 0.14), rgba(255, 255, 255, 0.05)),
    rgba(255, 255, 255, 0.06);
}

.about-ip-card.accent-2 {
  background:
    linear-gradient(180deg, rgba(138, 133, 255, 0.16), rgba(255, 255, 255, 0.05)),
    rgba(255, 255, 255, 0.06);
}

.about-ip-card.accent-3 {
  background:
    linear-gradient(180deg, rgba(73, 183, 255, 0.14), rgba(255, 255, 255, 0.05)),
    rgba(255, 255, 255, 0.06);
}

.about-ip-card.accent-4 {
  background:
    linear-gradient(180deg, rgba(255, 216, 111, 0.14), rgba(255, 255, 255, 0.05)),
    rgba(255, 255, 255, 0.06);
}

.contact-page-shell {
  width: min(1240px, calc(100vw - 72px));
  margin: 0 auto;
  padding: 34px 0 74px;
}

.contact-page-head {
  max-width: 860px;
  padding-bottom: 28px;
}

.contact-page-head h1 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(3.2rem, 8vw, 6rem);
  line-height: 0.96;
  letter-spacing: -0.03em;
}

.contact-hero-card {
  position: relative;
  display: grid;
  align-items: center;
  min-height: 520px;
  margin-bottom: 34px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(185, 219, 241, 0.95), rgba(226, 233, 243, 0.82)),
    linear-gradient(120deg, #dfe9f4, #bfcddd 48%, #8ca6c4 100%);
  box-shadow: 0 24px 66px rgba(25, 32, 44, 0.12);
}

.contact-hero-visual {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.2), transparent 26%),
    repeating-linear-gradient(
      90deg,
      rgba(14, 36, 63, 0.12) 0,
      rgba(14, 36, 63, 0.12) 2px,
      transparent 2px,
      transparent 60px
    ),
    linear-gradient(180deg, rgba(14, 64, 113, 0.06), rgba(9, 34, 65, 0.42));
  transform: scale(1.04);
}

.contact-hero-visual::after {
  content: "HASUKI";
  position: absolute;
  right: 4%;
  bottom: 8%;
  color: rgba(255, 84, 84, 0.24);
  font-size: clamp(4rem, 11vw, 10rem);
  font-weight: 800;
  letter-spacing: 0.04em;
}

.contact-hq-card {
  position: relative;
  z-index: 1;
  width: min(420px, calc(100% - 56px));
  margin-left: clamp(28px, 7vw, 96px);
  padding: 34px 36px;
  border: 1px solid rgba(18, 24, 34, 0.08);
  background: rgba(255, 255, 255, 0.84);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 20px 50px rgba(24, 30, 42, 0.12);
}

.contact-hq-card h2 {
  margin: 8px 0 18px;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  line-height: 1.08;
}

.contact-hq-card ul {
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.contact-hq-card li {
  display: grid;
  gap: 4px;
}

.contact-hq-card li strong {
  color: rgba(22, 28, 37, 0.9);
  font-size: 0.92rem;
}

.contact-hq-card li span {
  color: rgba(22, 28, 37, 0.64);
  line-height: 1.7;
}

.contact-service-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.contact-service-card {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 18px;
  padding: 26px 8px 26px 0;
  border-top: 1px solid rgba(24, 23, 22, 0.08);
}

.contact-service-icon {
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #dd2236;
  color: #fff;
  font-size: 1.55rem;
  box-shadow: 0 10px 20px rgba(221, 34, 54, 0.18);
}

.contact-service-copy h3 {
  margin: 0 0 8px;
  font-size: 1.28rem;
}

.contact-service-copy p {
  margin: 0;
  color: rgba(24, 23, 22, 0.64);
  line-height: 1.8;
}

.contact-service-copy p + p {
  margin-top: 4px;
}

@keyframes contact-marquee {
  0% {
    transform: translate3d(-18%, -50%, 0);
  }

  100% {
    transform: translate3d(-58%, -50%, 0);
  }
}

.catalog-body {
  min-height: 100vh;
  overflow: auto;
  background: #f2f2f0;
  color: #111216;
}

.catalog-top-fade {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 110px;
  z-index: 18;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.96) 0%, rgba(0, 0, 0, 0.96) 100%);
}

.catalog-nav .top-button,
.catalog-nav nav a,
.catalog-body .brand-row-mark,
.catalog-body .brand-row-text {
  color: #fff;
}

.catalog-page {
  padding: 156px 48px 56px;
}

.catalog-nav .top-button {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.34);
}

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 46px;
}

.catalog-card {
  position: relative;
  display: block;
  aspect-ratio: 0.86 / 1;
  overflow: hidden;
  background: #1b1c22;
}

.catalog-card-image,
.catalog-card-overlay {
  position: absolute;
  inset: 0;
}

.catalog-card-image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.catalog-card-image::before,
.catalog-card-image::after {
  content: "";
  position: absolute;
}

.catalog-card-image.has-cover::before,
.catalog-card-image.has-cover::after {
  display: none;
}

.catalog-card-overlay {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px 22px;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.02) 42%, rgba(0, 0, 0, 0.58) 100%);
}

.catalog-card-overlay h2 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.7rem, 2vw, 2.3rem);
  font-weight: 800;
  line-height: 1.12;
}

.catalog-card-overlay p {
  margin: 6px 0 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.95rem;
  font-weight: 700;
}

.catalog-card-tags {
  margin-top: 18px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.catalog-card-tags span {
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.26);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
}

.card-style-1 .catalog-card-image {
  background:
    radial-gradient(circle at 44% 22%, rgba(255, 201, 173, 0.82), transparent 16%),
    linear-gradient(135deg, #8f8c8f 0%, #cac6c9 40%, #6b6466 100%);
}

.card-style-1 .catalog-card-image::before {
  left: 18%;
  top: 15%;
  width: 54%;
  height: 72%;
  border-radius: 46% 54% 42% 58%;
  background: linear-gradient(180deg, #ffd6bf 0%, #f7b397 40%, #f15565 68%, #d9152d 100%);
}

.card-style-1 .catalog-card-image::after {
  left: 6%;
  bottom: 22%;
  width: 52%;
  height: 10%;
  border-radius: 999px;
  background: #25272d;
  transform: rotate(-14deg);
}

.card-style-2 .catalog-card-image {
  background:
    radial-gradient(circle at 42% 18%, rgba(239, 245, 255, 0.94), transparent 18%),
    linear-gradient(135deg, #98efff 0%, #b8d8ef 42%, #f3d3c5 100%);
}

.card-style-2 .catalog-card-image::before {
  left: 22%;
  top: 12%;
  width: 56%;
  height: 78%;
  border-radius: 48% 52% 44% 56%;
  background: linear-gradient(180deg, #f5f6fb 0%, #dce1ef 34%, #c1c8d8 100%);
}

.card-style-2 .catalog-card-image::after {
  right: 18%;
  top: 20%;
  width: 22%;
  height: 32%;
  border-radius: 50%;
  border: 10px solid rgba(255, 255, 255, 0.6);
}

.card-style-3 .catalog-card-image {
  background:
    radial-gradient(circle at 72% 18%, rgba(208, 245, 255, 0.7), transparent 14%),
    linear-gradient(135deg, #0d1213 0%, #55756a 36%, #c7d9eb 100%);
}

.card-style-3 .catalog-card-image::before {
  left: 28%;
  top: 10%;
  width: 48%;
  height: 74%;
  border-radius: 44% 56% 42% 58%;
  background: linear-gradient(180deg, #edc088 0%, #d1a06d 36%, #9b7a5f 100%);
}

.card-style-3 .catalog-card-image::after {
  left: 34%;
  top: 24%;
  width: 22%;
  height: 18%;
  border-radius: 42% 58% 60% 40%;
  background: #1c1816;
}

.card-style-4 .catalog-card-image {
  background:
    radial-gradient(circle at 52% 18%, rgba(255, 244, 215, 0.74), transparent 16%),
    linear-gradient(135deg, #0c1015 0%, #244060 42%, #0f1620 100%);
}

.card-style-4 .catalog-card-image::before {
  left: 22%;
  top: 10%;
  width: 54%;
  height: 76%;
  border-radius: 46% 54% 40% 60%;
  background: linear-gradient(180deg, #f1e3c5 0%, #d3b87e 50%, #5d7ec9 100%);
}

.card-style-5 .catalog-card-image {
  background:
    radial-gradient(circle at 70% 20%, rgba(136, 220, 255, 0.52), transparent 14%),
    linear-gradient(135deg, #120d13 0%, #2d3041 38%, #0f1116 100%);
}

.card-style-5 .catalog-card-image::before {
  left: 28%;
  top: 14%;
  width: 48%;
  height: 72%;
  border-radius: 46% 54% 38% 62%;
  background: linear-gradient(180deg, #f2d9cf 0%, #d9a4bc 42%, #1d2128 100%);
}

.card-style-6 .catalog-card-image {
  background:
    radial-gradient(circle at 60% 18%, rgba(255, 242, 205, 0.54), transparent 14%),
    linear-gradient(135deg, #161820 0%, #302851 38%, #17212e 100%);
}

.card-style-6 .catalog-card-image::before {
  left: 24%;
  top: 16%;
  width: 52%;
  height: 72%;
  border-radius: 48% 52% 40% 60%;
  background: linear-gradient(180deg, #fff1db 0%, #b6b6ff 42%, #6a76d8 100%);
}

.card-style-7 .catalog-card-image {
  background:
    radial-gradient(circle at 50% 16%, rgba(180, 238, 255, 0.54), transparent 14%),
    linear-gradient(135deg, #181818 0%, #272727 38%, #0f161f 100%);
}

.card-style-7 .catalog-card-image::before {
  left: 26%;
  top: 18%;
  width: 48%;
  height: 68%;
  border-radius: 48% 52% 44% 56%;
  background: linear-gradient(180deg, #92d1ff 0%, #4aa2d9 48%, #222f3b 100%);
}

.card-style-8 .catalog-card-image {
  background:
    radial-gradient(circle at 70% 12%, rgba(255, 156, 156, 0.42), transparent 14%),
    linear-gradient(135deg, #12131a 0%, #232c3a 38%, #2b1821 100%);
}

.card-style-8 .catalog-card-image::before {
  left: 30%;
  top: 16%;
  width: 46%;
  height: 68%;
  border-radius: 46% 54% 38% 62%;
  background: linear-gradient(180deg, #ffe4d4 0%, #f0b0c2 42%, #20242d 100%);
}

.card-style-8 .catalog-card-image::after {
  left: 42%;
  top: 24%;
  width: 18%;
  height: 12%;
  border-radius: 50%;
  background: #090b0e;
}

.detail-body {
  overflow: auto;
  background: #f4f1ea !important;
  background-image: none !important;
  color: #111111;
}

.detail-page,
.detail-hero {
  min-height: 100vh;
}

body.detail-body .detail-page,
body.detail-body .detail-hero {
  min-height: auto;
}

body.detail-body .detail-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

.detail-hero {
  position: relative;
  overflow: hidden;
}

.detail-brand-link {
  color: inherit;
}

.detail-maincard {
  position: absolute;
  left: 46px;
  top: 34vh;
  z-index: 3;
  width: 568px;
  min-height: 452px;
  padding: 40px 48px;
  background: transparent;
}

.detail-mainpanel {
  display: none;
}

.detail-mainpanel.is-active {
  display: block;
}

.detail-mainpanel h2 {
  margin: 0 0 42px;
  font-size: 3.35rem;
  line-height: 1;
  font-weight: 800;
}

.detail-cover {
  margin-bottom: 26px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.05);
}

.detail-cover img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.detail-sidecard {
  position: absolute;
  top: 25vh;
  right: 48px;
  z-index: 3;
  width: 292px;
  min-height: 348px;
  padding: 28px 0;
  background: transparent;
}

.detail-sidecard-head h2 {
  margin: 0 0 0 auto;
  width: fit-content;
  font-size: 1rem;
  font-weight: 800;
}

.detail-tabs {
  margin-top: 28px;
  display: grid;
  gap: 18px;
}

.detail-tab {
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(255, 255, 255, 0.56);
  font: inherit;
  font-weight: 700;
  text-align: right;
  cursor: pointer;
}

.detail-tab.is-active {
  color: #fff;
}

.detail-info-row,
.detail-list-row {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 24px;
  padding: 16px 0;
}

.detail-info-row span,
.detail-list-row span {
  display: block;
  font-size: 0.95rem;
  color: #fff;
  font-weight: 800;
}

.detail-info-row strong {
  display: block;
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.54);
  font-weight: 500;
}

.detail-list-row {
  grid-template-columns: 1fr;
}

.detail-list-row span {
  color: rgba(255, 255, 255, 0.7);
  font-weight: 500;
}

.detail-gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.detail-gallery-card {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.05);
}

.detail-gallery-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.admin-body {
  min-height: 100vh;
  margin: 0;
  overflow: auto;
  background: #0c0f13;
  color: #f4f1ea;
  font-family: "Noto Sans SC", sans-serif;
}

.admin-auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px;
}

.admin-auth-card {
  width: min(100%, 420px);
  padding: 32px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
}

.admin-auth-card h1 {
  margin: 14px 0 10px;
  font-size: 2rem;
}

.admin-auth-copy {
  margin: 0 0 22px;
  color: rgba(255, 255, 255, 0.64);
}

.admin-auth-form {
  display: grid;
  gap: 16px;
}

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

.admin-auth-form button,
.admin-media-head button {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  padding: 12px 16px;
  cursor: pointer;
}

.admin-shell {
  display: grid;
  grid-template-columns: 340px 1fr;
  min-height: 100vh;
}

.admin-sidebar {
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  padding: 28px 22px;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  background: #11151a;
  overflow-x: hidden;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.admin-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.admin-brand-image {
  display: block;
  max-width: 112px;
  max-height: 52px;
  width: auto;
  height: auto;
  object-fit: contain;
  flex: 0 0 auto;
}

.admin-brand-text {
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.admin-sidebar-head,
.admin-main-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.admin-sidebar-head {
  margin-top: 28px;
}

.admin-sidebar-tools {
  margin-top: 14px;
  display: grid;
  gap: 10px;
}

.admin-sidebar-search input {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  padding: 11px 12px;
  box-sizing: border-box;
}

.admin-sidebar-search input::placeholder {
  color: rgba(255, 255, 255, 0.38);
}

.admin-filter-chips {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.admin-filter-chip {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.74);
  padding: 7px 12px;
  cursor: pointer;
  font: inherit;
}

.admin-filter-chip.is-active {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.24);
  color: #fff;
}

.admin-sidebar-summary {
  margin: 0;
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.86rem;
}

.admin-sidebar-head h1,
.admin-main-head h2 {
  margin: 0;
}

.admin-sidebar button,
.admin-actions button {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  padding: 10px 14px;
  cursor: pointer;
}

.admin-actions .danger {
  border-color: rgba(255, 85, 85, 0.4);
  color: #ff8e8e;
}

.admin-product-list {
  margin-top: 18px;
  display: grid;
  gap: 10px;
  max-height: 46vh;
  overflow: auto;
  padding-right: 4px;
}

.admin-product-group {
  display: grid;
  gap: 10px;
}

.admin-product-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 2px;
}

.admin-product-group-head strong {
  color: #ffffff;
  font-size: 0.96rem;
  letter-spacing: 0.03em;
}

.admin-product-group-head span {
  color: rgba(255, 255, 255, 0.42);
  font-size: 0.78rem;
}

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

.admin-list-empty {
  padding: 18px 14px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.58);
  line-height: 1.7;
}

.admin-product-item {
  padding: 14px;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: #fff;
  cursor: pointer;
}

.admin-product-item strong,
.admin-product-item span {
  display: block;
}

.admin-product-item strong {
  font-size: 0.95rem;
}

.admin-product-item span {
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.62);
}

.admin-product-item.is-active {
  border-color: rgba(255, 255, 255, 0.26);
  background: rgba(255, 255, 255, 0.08);
}

.admin-main {
  padding: 28px 30px 42px;
}

.admin-eyebrow {
  margin: 0 0 8px;
  color: rgba(255, 255, 255, 0.5);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.78rem;
}

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

.admin-editor-tabs {
  margin-top: 22px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.admin-editor-tab {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.7);
  padding: 11px 16px;
  cursor: pointer;
  font: inherit;
}

.admin-editor-tab.is-active {
  border-color: rgba(255, 255, 255, 0.24);
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.admin-user {
  color: rgba(255, 255, 255, 0.64);
  font-size: 0.9rem;
}

.admin-form {
  margin-top: 26px;
  display: grid;
  gap: 18px;
}

.admin-editor-panel {
  margin-top: 24px;
}

.admin-editor-panel[hidden] {
  display: none !important;
}

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

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

.admin-form span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.88rem;
}

.admin-form input,
.admin-form select,
.admin-form textarea {
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  padding: 12px 14px;
  font: inherit;
}

.admin-form select {
  background: rgba(18, 21, 28, 0.92);
  color: #fff;
}

.admin-form select option {
  background: #161a22;
  color: #fff;
}

.admin-media-section {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
}

.admin-media-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.admin-media-head h3 {
  margin: 0;
}

.admin-helper-copy {
  margin: 0;
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.88rem;
  line-height: 1.6;
}

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

.admin-cover-preview {
  min-height: 220px;
}

.admin-cover-card,
.admin-empty-state {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
}

.admin-empty-state {
  min-height: 120px;
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.48);
}

.admin-cover-card img {
  display: block;
  width: 100%;
  max-height: 360px;
  object-fit: cover;
}

.admin-gallery-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
}

.admin-gallery-card {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
}

.admin-gallery-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.admin-gallery-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
}

.admin-gallery-card-foot button {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: transparent;
  color: #fff;
  padding: 6px 10px;
  cursor: pointer;
}

.admin-status {
  margin: 20px 0 0;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
  border-radius: 14px;
  color: rgba(255, 255, 255, 0.76);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease,
    background 180ms ease, color 180ms ease;
}

.admin-status[data-error="true"] {
  color: #ffb0b0;
  border-color: rgba(255, 98, 98, 0.42);
  background: rgba(120, 16, 16, 0.3);
}

.admin-status[data-success="true"] {
  color: #b8ffd6;
  border-color: rgba(42, 176, 99, 0.42);
  background: rgba(15, 85, 46, 0.34);
}

.admin-status.is-flash {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
}

.admin-toast {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 1200;
  max-width: min(420px, calc(100vw - 32px));
  padding: 14px 18px;
  border-radius: 16px;
  border: 1px solid rgba(42, 176, 99, 0.42);
  background: rgba(15, 85, 46, 0.92);
  color: #eafff1;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.24);
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 180ms ease, transform 180ms ease;
}

.admin-toast[data-error="true"] {
  border-color: rgba(255, 98, 98, 0.42);
  background: rgba(120, 16, 16, 0.94);
  color: #ffe2e2;
}

.admin-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1100px) {
  .admin-sidebar {
    position: static;
    height: auto;
    overflow: visible;
  }

  .admin-product-list,
  .admin-category-list {
    max-height: none;
    overflow: visible;
  }

  .top-nav {
    left: 110px;
    right: 18px;
  }

  .top-nav nav {
    gap: 14px;
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .panel-copy {
    left: 60px;
  }

  .panel-rail {
    right: 24px;
    width: 236px;
  }

  .contact-socials {
    gap: 52px;
  }

  .detail-sidecard {
    right: 20px;
    width: 248px;
  }

  .detail-maincard {
    left: 24px;
    width: 480px;
    padding: 30px 32px;
  }

  .admin-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  html,
  body {
    overflow: auto;
  }

  .about-simple-page {
    width: 100%;
    padding: 0 0 48px;
  }

  .about-simple-page > section + section {
    margin-top: 64px;
  }

  .about-v2-hero {
    min-height: 44vh;
    border-radius: 0;
  }

  .about-v2-hero-copy {
    min-height: 44vh;
    padding: 32px 18px;
  }

  .about-v2-hero-copy h1 {
    font-size: clamp(2.6rem, 12vw, 3.8rem);
  }

  .about-v2-intro {
    margin-top: 0;
    padding: 88px 16px;
    border-radius: 0;
  }

  .about-v2-ip {
    padding: 62px 0 92px;
  }

  .about-v2-ip-hero img {
    height: 100%;
    min-height: 0;
  }

  .about-v2-ip-head {
    padding: 78px 16px 36px;
  }

  .about-v2-ip-list {
    width: calc(100vw - 24px);
    gap: 10px;
    grid-auto-columns: minmax(150px, 70vw);
    padding: 8px 0 12px;
  }

  .about-v2-team {
    padding: 84px 16px 112px;
  }

  .about-v2-team-grid {
    margin-top: 30px;
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .about-v2-team-card {
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 14px;
  }

  .about-v2-team-avatar {
    width: 96px;
  }

  .about-v2-team-copy h3 {
    font-size: 1.45rem;
  }

  .about-v2-team-copy h4 {
    font-size: 0.98rem;
  }

  .about-v2-team-copy p {
    margin-top: 12px;
    font-size: 0.92rem;
    line-height: 1.72;
  }

  .about-v2-coop {
    padding: 84px 16px 114px;
  }

  .about-v2-coop-grid {
    margin-top: 36px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 20px;
  }

  .about-v2-coop-item img {
    max-width: 132px;
    max-height: 56px;
  }

  .about-rx-hero,
  .about-rx-hero-copy {
    min-height: 48vh;
  }

  .about-rx-hero-copy {
    padding: 28px 14px;
  }

  .about-rx-hero-copy p {
    font-size: 16px;
  }

  .about-rx-intro,
  .about-rx-business,
  .about-rx-coop {
    padding: 64px 16px;
  }

  .about-rx-hero + .about-rx-intro {
    margin-top: 16px;
  }

  .about-rx-collab {
    padding: 64px 16px;
  }

  .about-rx-section-head {
    margin-bottom: 34px;
  }

  .about-rx-section-head p {
    margin-top: 8px;
    font-size: 0.96rem;
  }

  .about-rx-business-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px 16px;
  }

  .about-rx-business-item {
    aspect-ratio: 1 / 1;
    min-height: 0;
    gap: 10px;
    padding: 18px 12px;
  }

  .about-rx-business-no {
    font-size: 1.7rem;
  }

  .about-rx-business-copy h3 {
    font-size: 1.06rem;
  }

  .about-rx-business-copy p {
    font-size: 0.86rem;
    line-height: 1.6;
    margin-top: 10px;
  }

  .about-rx-collab-track {
    min-height: 420px;
    gap: 8px;
  }

  .about-rx-collab-card {
    flex: 1 1 0;
    min-width: 46px;
  }

  .about-rx-collab-card.is-active {
    flex: 5.2 1 0;
  }

  .about-rx-collab-info {
    left: 14px;
    right: 14px;
    bottom: 14px;
  }

  .about-rx-collab-info h3 {
    font-size: 1rem;
  }

  .about-rx-collab-info p {
    margin-top: 8px;
    font-size: 0.82rem;
    line-height: 1.5;
  }

  .about-rx-collab-info a {
    min-height: 34px;
    margin-top: 10px;
    padding: 0 10px;
    font-size: 0.76rem;
  }

  .about-rx-collab-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 12px;
  }

  .about-rx-coop-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }

  .about-rx-coop-item {
    min-height: 56px;
  }

  .contact-page-shell {
    width: min(100vw - 28px, 100%);
    padding: 22px 0 56px;
  }

  .contact-hero-card {
    min-height: auto;
    padding: 160px 0 0;
  }

  .contact-hq-card {
    width: calc(100% - 28px);
    margin: 0 14px 14px;
    padding: 24px 20px;
  }

  .contact-service-grid {
    grid-template-columns: 1fr;
  }

  .contact-service-card {
    grid-template-columns: 56px minmax(0, 1fr);
    padding: 18px 0;
  }

  .fullpage-shell {
    overflow-y: auto;
  }

  .side-brand {
    left: 16px;
    top: 16px;
  }

  .side-brand-global {
    position: fixed;
  }

  .brand-stack {
    font-size: 2rem;
  }

  .brand-row {
    gap: 10px;
  }

  .brand-row-mark {
    width: 28px;
    height: 28px;
    font-size: 1.05rem;
  }

  .brand-row-text {
    font-size: 1.3rem;
  }

  .top-nav {
    left: 76px;
    right: 16px;
    top: 18px;
  }

  .top-nav-global {
    position: fixed;
    padding-top: 8px;
  }

  .top-nav nav {
    display: none;
  }

  .top-button {
    padding: 10px 14px;
    font-size: 0.9rem;
  }

  .contact-jump-button {
    right: 2px;
    width: 48px;
    min-height: 176px;
    padding: 14px 8px;
    font-size: 0.82rem;
    gap: 6px;
  }

  .scene-foreground.left,
  .scene-foreground.right {
    display: none;
  }

  .scene-character {
    width: 300px;
    height: 520px;
    top: 86px;
    bottom: auto;
    transform: translateX(-18%);
  }

  .scene-character-shell {
    width: 300px;
    height: 520px;
    top: 86px;
    bottom: auto;
    transform: translateX(-18%);
  }

  .scene-character-shell.has-image {
    width: min(72vw, 360px);
    height: min(105vw, 520px);
  }

  .panel-copy {
    left: 16px;
    right: 16px;
    bottom: 180px;
  }

  .panel-copy h1 {
    font-size: clamp(2.8rem, 12vw, 4rem);
  }

  .panel-tags span {
    font-size: 0.76rem;
    padding: 8px 12px;
  }

  .panel-cta {
    min-width: 140px;
    padding: 16px 22px;
  }

  .panel-rail {
    display: none;
  }

  .scroll-indicator {
    bottom: 16px;
  }

  .contact-layout {
    flex-direction: column;
    padding: 40px 24px 14px;
    width: calc(100% - 32px);
    gap: 22px;
  }

  .contact-link-columns {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    justify-content: start;
  }

  .contact-bottom {
    flex-direction: column;
    align-items: flex-start;
    padding: 0 24px 14px;
    width: calc(100% - 32px);
  }

  .contact-meta {
    max-width: none;
    gap: 10px;
  }

  .contact-socials {
    justify-content: flex-start;
  }

  .catalog-page {
    padding: 112px 16px 32px;
  }

  .catalog-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .detail-gallery-grid {
    grid-template-columns: 1fr;
  }

  .admin-main {
    padding: 20px 16px 30px;
  }

  .admin-auth-shell,
  .admin-sidebar {
    padding-left: 16px;
    padding-right: 16px;
  }

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

  .admin-media-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .detail-maincard {
    position: relative;
    left: auto;
    top: auto;
    width: calc(100% - 32px);
    min-height: auto;
    margin: 380px 16px 0;
    padding: 24px;
  }

  .detail-mainpanel h2 {
    font-size: 2.4rem;
    margin-bottom: 24px;
  }

  .detail-sidecard {
    position: relative;
    top: auto;
    right: auto;
    width: calc(100% - 32px);
    margin: 20px 16px 0;
    min-height: auto;
    padding-top: 0;
  }
}

html:has(body.home-page) {
  overflow-y: auto;
}

body.home-page {
  height: auto;
  min-height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.08), transparent 34%),
    linear-gradient(180deg, #2f333a 0%, #25282e 100%);
}

body.landing-page {
  margin: 0;
  min-height: 100vh;
  background: #0b0d12;
  color: #ffffff;
}

.landing-cover {
  --landing-image: linear-gradient(135deg, #0f1118 0%, #1a2030 48%, #0b0d12 100%);
  position: relative;
  min-height: 100vh;
  width: 100%;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    linear-gradient(rgba(8, 10, 16, 0.16), rgba(8, 10, 16, 0.16)),
    var(--landing-image);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.landing-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.08), transparent 32%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.34));
  -webkit-backdrop-filter: blur(18px) saturate(108%);
  backdrop-filter: blur(0px) saturate(108%);
  pointer-events: none;
}

.landing-logo-link {
  position: relative;
  z-index: 1;
  display: inline-grid;
  place-items: center;
  min-width: min(76vw, 1040px);
  min-height: min(32vw, 440px);
  padding: 24px;
  text-decoration: none;
  transition: transform 240ms ease, opacity 240ms ease;
}

.landing-rotator {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(58vw, 760px);
  height: min(58vw, 760px);
  object-fit: contain;
  transform: translate(-50%, -50%);
  transform-origin: center;
  animation: landing-spin 24s linear infinite;
  pointer-events: none;
  opacity: 0.96;
  filter: drop-shadow(0 18px 44px rgba(0, 0, 0, 0.18));
}

.landing-logo-link:hover,
.landing-logo-link:focus-visible {
  transform: scale(1.03);
  opacity: 0.94;
}

.landing-logo {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
}

.landing-logo img {
  display: block;
  max-width: min(84vw, 800px);
  max-height: min(36vw, 300px);
  width: auto;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 18px 48px rgba(0, 0, 0, 0.34));
}

.landing-logo span {
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2.8rem, 7vw, 6rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #ffffff;
}

@keyframes landing-spin {
  from {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

body.home-page .fullpage-shell {
  min-height: 100vh;
  height: auto;
  overflow: visible;
  scroll-snap-type: none;
}

body.home-page .top-fade-layer {
  height: 192px;
}

body.home-page .side-brand-global .brand-row {
  gap: 0;
}

:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .side-brand-global {
  top: 0px;
}

:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .side-brand-global .brand-row {
  gap: 0;
}

:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .side-brand-global .brand-row-image {
  max-width: 416px;
  max-height: 128px;
  filter: none;
  opacity: 1;
}

:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .side-brand-global .brand-row-text {
  display: none;
}

:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .top-nav-global {
  left: 470px;
  top: 0px;
  min-height: 80px;
  display: flex;
  align-items: center;
}

:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .top-nav-global nav,
:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .top-nav-global .top-button {
  align-self: center;
}

:is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .top-nav-global nav {
  min-height: 80px;
  display: flex;
  align-items: center;
}

body.home-page .contact-panel {
  scroll-snap-align: unset;
  min-height: auto;
  padding: 0;
  width: 100%;
  margin-top: 28px;
  margin-left: 0;
  margin-right: 0;
  background: linear-gradient(180deg, #eeeeee 0%, #ffffff 100%);
  color: #1f232a;
  border-top: 1px solid rgba(31, 35, 42, 0.08);
  box-sizing: border-box;
}

body.home-page .contact-panel::before,
body.home-page .contact-panel::after {
  display: none;
}

body.home-page .contact-layout,
body.home-page .contact-bottom {
  max-width: none;
  width: 100%;
  margin: 0;
  padding-left: 24px;
  padding-right: 24px;
  box-sizing: border-box;
}

body.home-page .contact-layout {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 24px;
  padding-top: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(31, 35, 42, 0.08);
}

body.home-page .contact-brand-block {
  min-width: 0;
  flex: none;
  margin-left: 0;
  gap: 8px;
}

body.home-page .contact-logo-lockup {
  gap: 14px;
}

body.home-page .contact-logo-image {
  max-width: 300px;
  max-height: 100px;
}

body.home-page .contact-logo-lockup .brand-row-mark {
  width: 44px;
  height: 44px;
  font-size: 1.2rem;
  border-color: rgba(31, 35, 42, 0.18);
  color: #1f232a;
}

body.home-page .contact-logo-word {
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.14em;
}

body.home-page .contact-inline-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 0.9rem;
  color: rgba(31, 35, 42, 0.58);
}

body.home-page .contact-office-block {
  margin-top: 8px;
}

body.home-page .contact-inline-link {
  color: rgba(31, 35, 42, 0.7);
  text-decoration: none;
}

body.home-page .contact-inline-sep {
  color: rgba(31, 35, 42, 0.32);
}

body.home-page .contact-hotlines {
  display: none;
}

body.home-page .contact-link-columns {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 28px;
  margin: 0;
  flex: 1;
  max-width: none;
}

body.home-page .contact-link-columns > a {
  font-size: 0.92rem;
  font-weight: 600;
  color: rgba(31, 35, 42, 0.76);
  text-decoration: none;
}

body.home-page .contact-link-columns-extra {
  display: none;
}

body.home-page .contact-link-group {
  display: contents;
}

body.home-page .contact-link-group h3 {
  display: none;
}

body.home-page .contact-bottom {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 20px;
  padding-top: 16px;
  padding-bottom: 20px;
}

body.home-page .contact-meta {
  max-width: none;
  gap: 10px;
  font-size: 0.8rem;
  color: rgba(31, 35, 42, 0.58);
}

body.home-page .contact-meta a {
  color: rgba(31, 35, 42, 0.68);
}

body.home-page .contact-socials {
  margin-right: 0;
  gap: 12px;
}

body.home-page .contact-socials a,
body.home-page .contact-social-button {
  width: 38px;
  height: 38px;
  background: #fff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

body.home-page .contact-socials a img,
body.home-page .contact-social-button img {
  width: 24px;
  height: 24px;
}

body.home-page .contact-qr-popover {
  right: 0;
  bottom: calc(100% + 10px);
}

body.home-page #home-panels {
  position: relative;
  z-index: 2;
  padding: 108px 0 0;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-panel {
  scroll-snap-align: unset;
  min-height: auto;
  padding: 0;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
  margin-bottom: 0;
  background: linear-gradient(180deg, #eeeeee 0%, #ffffff 100%);
  color: #1f232a;
  box-sizing: border-box;
  border-top: 1px solid rgba(31, 35, 42, 0.08);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-panel::before,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-panel::after {
  display: none;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-layout,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-bottom {
  max-width: none;
  width: 100%;
  margin: 0;
  padding-left: 24px;
  padding-right: 24px;
  box-sizing: border-box;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-layout {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 24px;
  padding-top: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(31, 35, 42, 0.08);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-brand-block {
  min-width: 0;
  flex: none;
  margin-left: 0;
  gap: 8px;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-logo-lockup {
  gap: 14px;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-logo-image {
  max-width: 300px;
  max-height: 100px;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-logo-lockup .brand-row-mark {
  width: 44px;
  height: 44px;
  font-size: 1.2rem;
  border-color: rgba(31, 35, 42, 0.18);
  color: #1f232a;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-logo-word {
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.14em;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-hotlines {
  display: none;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-inline-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 0.9rem;
  color: rgba(31, 35, 42, 0.58);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-office-block {
  margin-top: 8px;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-inline-link {
  color: rgba(31, 35, 42, 0.7);
  text-decoration: none;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-inline-sep {
  color: rgba(31, 35, 42, 0.32);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-columns {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 28px;
  margin: 0;
  flex: 1;
  max-width: none;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-group {
  display: contents;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-group h3 {
  display: none;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-columns > a,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-group a {
  font-size: 0.92rem;
  font-weight: 600;
  color: rgba(31, 35, 42, 0.76);
  text-decoration: none;
  margin: 0;
  line-height: normal;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-columns-extra {
  display: none;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-bottom {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 20px;
  padding-top: 16px;
  padding-bottom: 20px;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-meta {
  max-width: none;
  gap: 10px;
  font-size: 0.8rem;
  color: rgba(31, 35, 42, 0.58);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-meta a {
  color: rgba(31, 35, 42, 0.68);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-socials {
  margin-right: 0;
  gap: 12px;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-socials a,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-social-button {
  width: 38px;
  height: 38px;
  background: #fff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-socials a img,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-social-button img {
  width: 24px;
  height: 24px;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-qr-popover {
  right: 0;
  bottom: calc(100% + 10px);
}

.home-ref-page {
  width: 100%;
}

.home-ref-stage {
  min-height: calc(100vh - 220px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.home-ref-shell {
  width: min(100%, 1600px);
  margin: 0 auto;
  display: grid;
  justify-items: center;
  gap: 30px;
}

.home-ref-stage-copy {
  display: grid;
  justify-items: center;
  gap: 12px;
  text-align: center;
  max-width: 820px;
}

.home-ref-kicker {
  font-size: 0.88rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.58);
}

.home-ref-stage-copy h1 {
  margin: 0;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(3rem, 5vw, 5.8rem);
  line-height: 0.94;
  text-transform: uppercase;
}

.home-ref-stage-copy p {
  margin: 0;
  max-width: 720px;
  color: rgba(255, 255, 255, 0.7);
  font-size: 1rem;
  line-height: 1.8;
}

.home-ref-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
}

.home-ref-primary,
.home-ref-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 156px;
  min-height: 52px;
  padding: 0 28px;
  border-radius: 999px;
  font-size: 0.94rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  transition:
    transform 240ms ease,
    border-color 240ms ease,
    background 240ms ease,
    color 240ms ease;
}

.home-ref-primary {
  background: #f3f0ea;
  color: #17191d;
}

.home-ref-secondary {
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: rgba(255, 255, 255, 0.88);
  background: rgba(255, 255, 255, 0.04);
}

.home-ref-primary:hover,
.home-ref-secondary:hover {
  transform: translateY(-2px);
}

.home-ref-hero-wrap {
  width: 100%;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) 64px;
  align-items: center;
  gap: clamp(18px, 3vw, 40px);
}

.home-ref-hero-track {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 0.3fr) minmax(0, 0.8fr) minmax(0, 0.3fr);
  align-items: center;
  gap: clamp(12px, 1.8vw, 22px);
}

.home-ref-arrow {
  width: 64px;
  height: 64px;
  border: 0;
  display: grid;
  place-items: center;
  border-radius: 50%;
  cursor: pointer;
  color: rgba(255, 255, 255, 0.88);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition:
    transform 220ms ease,
    background 220ms ease;
}

.home-ref-arrow:hover {
  transform: scale(1.04);
  background: rgba(255, 255, 255, 0.14);
}

.home-ref-arrow span {
  display: block;
  width: 14px;
  height: 14px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
}

.home-ref-arrow.is-prev span {
  transform: rotate(-135deg);
  margin-left: 6px;
}

.home-ref-arrow.is-next span {
  transform: rotate(45deg);
  margin-right: 6px;
}

.home-ref-preview,
.home-ref-hero {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
}

.home-ref-preview::before,
.home-ref-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), transparent 18%),
    linear-gradient(180deg, rgba(0, 0, 0, 0) 48%, rgba(0, 0, 0, 0.46) 100%);
  z-index: 1;
}

.home-ref-preview {
  aspect-ratio: 0.56;
  filter: blur(0.6px);
  opacity: 0.48;
  transform: scale(0.95);
}

.home-ref-hero {
  display: block;
  aspect-ratio: 0.66;
  box-shadow:
    0 42px 92px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.06);
  background:
    radial-gradient(circle at top, rgba(255, 255, 255, 0.2), transparent 32%),
    linear-gradient(180deg, rgba(15, 16, 20, 0.82) 0%, rgba(9, 10, 12, 0.96) 100%);
  transition:
    transform 260ms ease,
    box-shadow 260ms ease;
}

.home-ref-hero:hover {
  transform: translateY(-4px);
  box-shadow:
    0 48px 96px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(255, 255, 255, 0.08);
}

.home-ref-visual {
  position: absolute;
  inset: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.home-ref-visual.hero {
  background-size: cover;
}

.home-ref-visual.preview {
  transform: scale(1.08);
}

.home-ref-visual:not(.has-image) {
  display: grid;
  place-items: center;
  font-size: clamp(1.4rem, 3vw, 2.8rem);
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.86);
}

.fallback-tone-1 {
  background:
    radial-gradient(circle at top, rgba(255, 183, 121, 0.5), transparent 38%),
    linear-gradient(180deg, #463328 0%, #151312 100%);
}

.fallback-tone-2 {
  background:
    radial-gradient(circle at top, rgba(129, 198, 255, 0.48), transparent 38%),
    linear-gradient(180deg, #213444 0%, #141619 100%);
}

.fallback-tone-3 {
  background:
    radial-gradient(circle at top, rgba(255, 162, 201, 0.48), transparent 38%),
    linear-gradient(180deg, #442739 0%, #171315 100%);
}

.fallback-tone-4 {
  background:
    radial-gradient(circle at top, rgba(231, 209, 122, 0.42), transparent 38%),
    linear-gradient(180deg, #4a4027 0%, #181511 100%);
}

.fallback-tone-5 {
  background:
    radial-gradient(circle at top, rgba(119, 219, 255, 0.44), transparent 38%),
    linear-gradient(180deg, #25404a 0%, #121517 100%);
}

.home-ref-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.home-ref-dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.22);
  cursor: pointer;
  transition:
    transform 220ms ease,
    background 220ms ease,
    box-shadow 220ms ease;
}

.home-ref-dot.is-active {
  background: #f2f0ea;
  box-shadow: 0 0 0 6px rgba(255, 255, 255, 0.08);
  transform: scale(1.06);
}

.home-ref-meta {
  width: min(100%, 880px);
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 20px 28px;
  border-radius: 28px;
  color: #1c1f26;
  background: linear-gradient(180deg, #efefef 0%, #ffffff 100%);
}

.home-ref-meta-line {
  display: grid;
  gap: 4px;
}

.home-ref-meta-label {
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(28, 31, 38, 0.5);
}

.home-ref-meta strong,
.home-ref-meta a {
  font-size: 1.04rem;
  font-weight: 700;
  color: #1c1f26;
}

.home-ref-empty {
  min-height: 50vh;
  display: grid;
  place-items: center;
  text-align: center;
  color: rgba(255, 255, 255, 0.7);
}

@media (max-width: 1200px) {
  .home-ref-hero-wrap {
    grid-template-columns: 56px minmax(0, 1fr) 56px;
  }

  .home-ref-hero-track {
    grid-template-columns: 1fr;
  }

  .home-ref-preview {
    display: none;
  }

  .home-ref-hero {
    width: min(100%, 820px);
    margin: 0 auto;
  }
}

@media (max-width: 720px) {
  body.home-page #home-panels {
    padding: 112px 14px 64px;
  }

  .home-ref-stage {
    min-height: auto;
  }

  .home-ref-shell {
    gap: 20px;
  }

  .home-ref-stage-copy {
    gap: 10px;
  }

  .home-ref-stage-copy h1 {
    font-size: clamp(2.3rem, 12vw, 3.4rem);
  }

  .home-ref-stage-copy p {
    font-size: 0.94rem;
    line-height: 1.65;
  }

  .home-ref-hero-wrap {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .home-ref-arrow {
    display: none;
  }

  .home-ref-hero {
    aspect-ratio: 0.72;
    border-radius: 24px;
  }

  .home-ref-actions {
    width: 100%;
  }

  .home-ref-primary,
  .home-ref-secondary {
    min-width: calc(50% - 8px);
    padding: 0 16px;
  }

  .home-ref-meta {
    flex-direction: column;
    align-items: flex-start;
    padding: 18px 18px 20px;
    border-radius: 22px;
  }
}

.home-fade-page {
  width: 100%;
}

.home-fade-stage {
  min-height: calc(100vh - 108px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.home-fade-shell {
  width: 100%;
  margin: 0 auto;
  display: block;
}

.home-fade-slider {
  position: relative;
  width: 100%;
  user-select: none;
  -webkit-user-select: none;
  cursor: grab;
  --drag-offset: 0px;
  --drag-progress: 0;
}

.home-fade-slider.is-dragging {
  cursor: grabbing;
}

.home-fade-slides {
  position: relative;
  width: 100%;
  height: calc(100vh - 108px);
  min-height: 0;
  max-height: none;
  overflow: hidden;
  border-radius: 0;
  background: #0b0d10;
  box-shadow: none;
}

.home-fade-slide {
  position: absolute;
  inset: 0;
  display: block;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 1;
  transition:
    opacity 1400ms ease,
    visibility 1400ms ease,
    transform 1400ms cubic-bezier(0.22, 1, 0.36, 1),
    filter 1400ms ease;
  transform: scale(1.04);
  filter: saturate(0.92);
}

.home-fade-slide.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 3;
  transform: scale(1);
  filter: saturate(1);
}

.home-fade-slide.is-neighbor {
  visibility: visible;
  opacity: 0;
  z-index: 2;
}

.home-fade-slider.is-dragging .home-fade-slide {
  transition: none;
}

.home-fade-slider.is-dragging .home-fade-slide.is-active {
  transform: translateX(var(--drag-offset)) scale(1);
  opacity: 1;
}

.home-fade-slider.is-dragging .home-fade-slide {
  visibility: visible;
  pointer-events: none;
}

.home-fade-slider.is-dragging .home-fade-slide-image,
.home-fade-slider.is-dragging .home-fade-slide-image-main img {
  transition: transform 60ms linear;
}

.home-fade-slider.is-dragging .home-fade-slide.is-active .home-fade-slide-image,
.home-fade-slider.is-dragging .home-fade-slide.is-active .home-fade-slide-image-main img {
  transform: scale(1);
}

.home-fade-slider.is-dragging .home-fade-slide-image,
.home-fade-slider.is-dragging .home-fade-slide-image-main img {
  transform: scale(1);
}

.home-fade-slide-image {
  width: 100%;
  height: 100%;
  background-position: center 30%;
  background-repeat: no-repeat;
  background-size: cover;
  background-color: transparent;
}

.home-fade-slide-image-bg,
.home-fade-slide-image-main {
  position: absolute;
  inset: 0;
}

.home-fade-slide-image-main {
  z-index: 1;
  display: grid;
  place-items: center;
  background: #0b0d10;
}

.home-fade-slide-image-main img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  user-select: none;
  -webkit-user-drag: none;
}

.home-fade-slide-image span {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  font-size: clamp(2rem, 5vw, 4.8rem);
  font-weight: 800;
  letter-spacing: 0.22em;
  color: rgba(255, 255, 255, 0.88);
}

.home-fade-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.02) 0%, rgba(0, 0, 0, 0) 18%, rgba(0, 0, 0, 0.02) 100%);
}

.home-fade-dots {
  position: absolute;
  left: 50%;
  bottom: 28px;
  z-index: 4;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
}

.home-fade-dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.22);
  cursor: pointer;
  transition:
    transform 220ms ease,
    background 220ms ease,
    box-shadow 220ms ease;
}

.home-fade-dot.is-active {
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 0 0 6px rgba(255, 255, 255, 0.08);
  transform: scale(1.04);
}

.home-fade-empty {
  min-height: 52vh;
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 1200px) {
  .home-fade-slider {
    width: min(100%, calc((100vh - 108px) * 16 / 9));
  }

  .home-fade-slides {
    max-height: calc(100vh - 108px);
  }
}

@media (max-width: 720px) {
  body.home-page #home-panels {
    padding: 88px 0 0;
  }

  body.home-page .side-brand-global .brand-row-image {
    max-width: 220px;
    max-height: 68px;
  }

  body.home-page .side-brand-global {
    top: 10px;
  }

  body.home-page .top-nav-global {
    left: 240px;
    top: 8px;
    min-height: 56px;
  }

  body.home-page .contact-layout,
  body.home-page .contact-bottom {
    width: calc(100% - 28px);
  }

  body.home-page .contact-layout {
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 14px;
    padding-top: 18px;
    padding-bottom: 16px;
  }

  body.home-page .contact-link-columns {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 14px 18px;
  }

  body.home-page .contact-bottom {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 12px;
    padding-bottom: 18px;
  }

  :is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-layout,
  :is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-bottom {
    width: calc(100% - 28px);
  }

  :is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-layout {
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 14px;
    padding-top: 18px;
    padding-bottom: 16px;
  }

  :is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-columns {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 14px 18px;
  }

  :is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-bottom {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 12px;
    padding-bottom: 18px;
  }

  .home-fade-slider {
    width: 100%;
  }

  .home-fade-stage {
    min-height: auto;
  }

  .home-fade-slides {
    height: calc(100vh - 88px);
    max-height: none;
  }

  .home-fade-overlay {
    border-radius: 0;
  }

  .home-fade-dots {
    bottom: 18px;
  }
}

.catalog-body-line {
  min-height: 100vh;
  overflow-y: auto;
  background:
    linear-gradient(180deg, #f5f3ee 0%, #f8f6f1 36%, #f1efe8 100%),
    radial-gradient(circle at top, rgba(255, 220, 140, 0.18), transparent 24%);
  color: #111;
}

.catalog-body-line html,
.catalog-body-line body {
  overflow-y: auto;
}

.catalog-body-line .catalog-top-fade {
  background: linear-gradient(180deg, rgba(12, 15, 19, 0.82), rgba(12, 15, 19, 0.08) 78%, rgba(12, 15, 19, 0));
}

.catalog-line-page {
  padding: 130px 0 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.catalog-body-line .catalog-line-page {
  width: min(1440px, calc(100% - 72px));
  margin: 0 auto;
}

.catalog-hero {
  padding: 18px 32px 36px;
}

.catalog-hero-shell {
  position: relative;
  width: min(1380px, calc(100vw - 64px));
  margin: 0 auto;
  min-height: 700px;
  display: grid;
  place-items: center;
  overflow: hidden;
  touch-action: pan-y;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
}

.catalog-hero-shell.is-dragging {
  cursor: grabbing;
}

.catalog-hero-viewport {
  position: relative;
  z-index: 1;
  width: min(860px, 64vw);
  overflow: hidden;
  user-select: none;
  -webkit-user-select: none;
}

.catalog-hero-track {
  display: flex;
  align-items: flex-start;
  will-change: transform;
}

.catalog-hero-slide {
  flex: 0 0 100%;
  width: 100%;
  display: flex;
  justify-content: center;
}

.catalog-hero-blur {
  position: absolute;
  top: 24px;
  bottom: 96px;
  width: 24%;
  border-radius: 38px;
  background-position: center;
  background-size: cover;
  filter: blur(22px);
  opacity: 0.42;
  transform: scale(1.1);
}

.catalog-hero-blur::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.08);
}

.catalog-hero-blur-left {
  left: 0;
}

.catalog-hero-blur-right {
  right: 0;
}

.catalog-hero-card {
  position: relative;
  width: 100%;
  display: grid;
  gap: 18px;
  justify-items: center;
}

.catalog-hero-card.is-empty {
  min-height: 520px;
  place-content: center;
}

.catalog-hero-media {
  width: min(620px, 46vw);
  aspect-ratio: 3 / 4.2;
  overflow: hidden;
  border-radius: 18px;
  box-shadow: 0 32px 78px rgba(0, 0, 0, 0.18);
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.04));
}

.catalog-hero-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}

.catalog-hero-copy {
  text-align: center;
  color: #111;
}

.catalog-hero-kicker,
.catalog-line-kicker {
  margin: 0;
  font-size: 0.92rem;
  letter-spacing: 0.18em;
  font-weight: 800;
  color: rgba(17, 17, 17, 0.52);
}

.catalog-hero-copy h1,
.catalog-line-intro h2 {
  margin: 10px 0 0;
  font-family: "Cormorant Garamond", serif;
}

.catalog-hero-copy h1 {
  font-size: clamp(2.6rem, 4.4vw, 4.6rem);
  line-height: 0.96;
}

.catalog-hero-copy p:last-of-type {
  margin: 10px auto 0;
  max-width: 560px;
  color: rgba(17, 17, 17, 0.64);
}

.catalog-hero-tags {
  margin-top: 18px;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.catalog-hero-tags span {
  padding: 9px 14px;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.08);
  font-size: 0.78rem;
  font-weight: 700;
}

.catalog-hero-actions {
  margin-top: 22px;
}

.catalog-hero-actions .panel-cta {
  background: #111;
  color: #f5f3ee;
  min-width: 186px;
}

.catalog-hero-dots {
  margin-top: -52px;
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.catalog-hero-dot {
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 50%;
  background: rgba(17, 17, 17, 0.24);
  cursor: pointer;
}

.catalog-hero-dot.is-active {
  background: #111;
}

.catalog-line-intro {
  margin: 14px auto 28px;
  width: min(1240px, calc(100vw - 64px));
  text-align: center;
}

.catalog-line-intro h1,
.catalog-line-intro h2 {
  margin: 0;
  font-size: clamp(2.8rem, 5vw, 4.8rem);
  line-height: 1;
}

.catalog-line-tabs {
  margin-top: 28px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.catalog-line-tab {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid rgba(17, 17, 17, 0.12);
  background: rgba(255, 255, 255, 0.72);
  color: #111;
  cursor: pointer;
}

.catalog-line-tab.is-active {
  border-color: #111;
  background: #111;
  color: #fff;
}

.catalog-line-tab-icon,
.catalog-category-icon,
.admin-category-item-icon,
.admin-category-option-icon {
  display: inline-grid;
  place-items: center;
  flex-shrink: 0;
  overflow: hidden;
  background: rgba(17, 17, 17, 0.06);
}

.catalog-line-tab-icon,
.admin-category-option-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
}

.catalog-line-tab-icon img,
.catalog-category-icon img,
.admin-category-item-icon img,
.admin-category-option-icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.catalog-line-sections {
  width: min(1380px, calc(100vw - 64px));
  margin: 0 auto;
  display: grid;
  gap: 0;
}

.catalog-category-section {
  display: grid;
  grid-template-columns: 276px 1fr;
  gap: 34px;
  align-items: center;
  padding: 32px 14px;
  border-radius: 36px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.06);
}

.catalog-category-section-grid,
.catalog-category-section-grid.is-active {
  display: block;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.catalog-category-section.is-active {
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.1);
}

.catalog-category-heading {
  display: grid;
  justify-items: center;
  gap: 16px;
  padding: 10px;
  border: 0;
  background: transparent;
  color: #111;
  cursor: pointer;
}

.catalog-category-icon {
  width: 104px;
  height: 104px;
  border-radius: 50%;
  box-shadow: inset 0 0 0 6px #ffcb2d, 0 12px 24px rgba(0, 0, 0, 0.08);
}

.catalog-category-icon strong,
.catalog-line-tab-icon strong,
.admin-category-item-icon strong,
.admin-category-option-icon strong {
  font-size: 1.1rem;
  color: #111;
}

.catalog-category-copy {
  text-align: center;
}

.catalog-category-copy strong {
  display: block;
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.06;
}

.catalog-category-copy small {
  display: block;
  margin-top: 8px;
  color: rgba(17, 17, 17, 0.54);
}

.catalog-category-products {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  gap: 22px;
  justify-items: stretch;
}

.catalog-product-thumb {
  display: grid;
  gap: 12px;
  width: 100%;
}

.catalog-product-thumb-image {
  display: block;
  overflow: hidden;
  border-radius: 24px;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: rgba(17, 17, 17, 0.08);
}

.catalog-product-thumb-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 220ms ease;
}

.catalog-product-thumb:hover .catalog-product-thumb-image img {
  transform: scale(1.04);
}

.catalog-product-thumb-copy strong,
.catalog-product-thumb-copy small {
  display: block;
}

.catalog-product-thumb-copy strong {
  font-size: 1rem;
  color: #111;
}

.catalog-product-thumb-copy small {
  margin-top: 4px;
  color: rgba(17, 17, 17, 0.56);
}

.catalog-category-empty {
  grid-column: 1 / -1;
  padding: 24px;
  border-radius: 18px;
  background: rgba(17, 17, 17, 0.04);
  color: rgba(17, 17, 17, 0.56);
}

.admin-sidebar-section + .admin-sidebar-section {
  margin-top: 26px;
  padding-top: 26px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-sidebar-section:last-child {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.admin-sidebar-head h2 {
  margin: 0;
  font-size: 1.1rem;
}

.admin-product-item small,
.admin-category-item-copy small,
.admin-category-option-copy small {
  display: block;
  margin-top: 6px;
  color: rgba(255, 255, 255, 0.46);
}

.admin-category-list {
  margin-top: 18px;
  display: grid;
  gap: 10px;
  flex: 1;
  min-height: 220px;
  max-height: none;
  overflow: auto;
  padding-right: 4px;
}

.admin-category-item {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 12px;
  align-items: center;
  padding: 14px;
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  color: #fff;
  cursor: pointer;
}

.admin-category-item.is-active {
  border-color: rgba(255, 255, 255, 0.26);
  background: rgba(255, 255, 255, 0.08);
}

.admin-category-item-icon {
  width: 48px;
  height: 48px;
  border-radius: 16px;
}

.admin-category-item-copy strong,
.admin-category-option-copy strong {
  display: block;
}

.admin-category-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.admin-category-option {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  cursor: pointer;
}

.admin-category-option input {
  display: none;
}

.admin-category-option.is-selected {
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.08);
}

.admin-subpanel {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.admin-subpanel-head {
  margin-bottom: 6px;
}

.admin-grid-compact {
  grid-template-columns: 2fr 1fr;
}

@media (max-width: 1200px) {
  .catalog-hero-shell {
    width: calc(100vw - 40px);
    min-height: 620px;
  }

  .catalog-hero-card {
    width: min(680px, 64vw);
  }

  .catalog-hero-viewport {
    width: min(680px, 64vw);
  }

  .catalog-category-section {
    grid-template-columns: 1fr;
  }

  .catalog-category-heading {
    justify-items: start;
    grid-template-columns: 104px 1fr;
    display: grid;
  }

  .catalog-category-copy {
    text-align: left;
  }
}

@media (max-width: 840px) {
  .catalog-line-page {
    padding-top: 108px;
  }

  .catalog-hero {
    padding-inline: 14px;
  }

  .catalog-hero-shell,
  .catalog-line-intro,
  .catalog-line-sections {
    width: calc(100vw - 28px);
  }

  .catalog-hero-shell {
    min-height: 560px;
  }

  .catalog-hero-blur {
    display: none;
  }

  .catalog-hero-card {
    width: 100%;
  }

  .catalog-hero-viewport {
    width: 100%;
  }

  .catalog-hero-media {
    width: 100%;
    max-width: 460px;
  }

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

  .admin-shell {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .catalog-hero-shell {
    min-height: 500px;
  }

  .catalog-hero-media {
    border-radius: 20px;
  }

  .catalog-category-section {
    padding: 20px;
  }

  .catalog-category-products {
    grid-template-columns: 1fr;
  }

  .catalog-line-tab {
    width: 100%;
    justify-content: center;
  }

  .admin-category-picker,
  .admin-grid,
  .admin-grid-compact {
    grid-template-columns: 1fr;
  }
}

.catalog-hero-card {
  gap: 0;
}

.catalog-hero-card.is-empty {
  min-height: 520px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.7);
}

.catalog-hero-empty {
  display: grid;
  place-items: center;
  min-height: 520px;
  font-size: 1.4rem;
  font-weight: 700;
  color: rgba(17, 17, 17, 0.56);
}

.catalog-hero-media {
  display: block;
  width: min(620px, 46vw);
  aspect-ratio: 3 / 4.2;
  border-radius: 12px;
}

.catalog-hero-copy,
.catalog-hero-kicker,
.catalog-hero-tags,
.catalog-hero-actions {
  display: none;
}

.catalog-line-sections {
  gap: 0;
}

.catalog-category-section {
  grid-template-columns: 260px 1fr;
  gap: 22px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.catalog-category-section.is-active {
  background: transparent;
  box-shadow: none;
}

.catalog-category-section.is-right-led {
  grid-template-columns: 1fr 260px;
}

.catalog-category-section.is-right-led .catalog-category-heading {
  order: 2;
}

.catalog-category-section.is-right-led .catalog-category-products {
  order: 1;
}

.catalog-category-heading {
  align-self: center;
}

.catalog-category-products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px 34px;
  align-items: start;
  justify-items: center;
}

.catalog-category-section.is-right-led .catalog-category-products {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.catalog-product-thumb {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 0;
  width: min(100%, 258px);
  overflow: hidden;
  border-radius: 24px;
  border: 3px solid #d8a11a;
  background: linear-gradient(180deg, #ffe588 0%, #f4c752 100%);
  box-shadow:
    0 18px 36px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 251, 221, 0.92);
  text-decoration: none;
  transition: transform 220ms ease, box-shadow 220ms ease, filter 220ms ease;
}

.catalog-product-thumb.thumb-1 {
  transform: none;
}

.catalog-product-thumb.thumb-2 {
  transform: none;
}

.catalog-product-thumb.thumb-3 {
  transform: none;
}

.catalog-category-section.is-right-led .catalog-product-thumb.thumb-1 {
  transform: none;
}

.catalog-category-section.is-right-led .catalog-product-thumb.thumb-3 {
  transform: none;
}

.catalog-product-thumb-image {
  border-radius: 20px 20px 0 0;
  width: 100%;
  aspect-ratio: 0.76 / 1;
  background: #181b21;
  box-shadow: none;
}

.catalog-product-thumb-copy {
  display: grid;
  gap: 8px;
  min-height: 102px;
  padding: 14px 14px 16px;
  align-content: start;
  background: linear-gradient(180deg, #ffe588 0%, #f4c752 100%);
}

.catalog-product-thumb:hover {
  transform: translateY(-8px);
  box-shadow:
    0 24px 44px rgba(0, 0, 0, 0.34),
    0 0 0 1px rgba(255, 234, 151, 0.78);
  filter: saturate(1.04);
}

.catalog-product-thumb-copy strong {
  font-size: 1.02rem;
  font-weight: 800;
  line-height: 1.28;
  color: #b17600;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.catalog-product-thumb-copy small {
  color: rgba(58, 37, 4, 0.92);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 1200px) {
  .catalog-category-section,
  .catalog-category-section.is-right-led {
    grid-template-columns: 1fr;
  }

  .catalog-category-section.is-right-led .catalog-category-heading,
  .catalog-category-section.is-right-led .catalog-category-products {
    order: initial;
  }

.catalog-category-products,
.catalog-category-section.is-right-led .catalog-category-products {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
}

.catalog-category-section-grid .catalog-category-products {
  grid-template-columns: repeat(4, minmax(190px, 1fr));
}

@media (max-width: 840px) {
  .catalog-hero-media {
    width: min(520px, 74vw);
  }

  .catalog-product-thumb.thumb-1,
  .catalog-product-thumb.thumb-2,
  .catalog-product-thumb.thumb-3,
  .catalog-category-section.is-right-led .catalog-product-thumb.thumb-1,
  .catalog-category-section.is-right-led .catalog-product-thumb.thumb-3 {
    transform: none;
  }
}

@media (max-width: 560px) {
  .catalog-category-products,
  .catalog-category-section.is-right-led .catalog-category-products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 16px;
  }

  .catalog-body-line .catalog-line-page {
    width: min(100%, calc(100% - 28px));
    padding-top: 118px;
  }

  .catalog-line-intro h1,
  .catalog-line-intro h2 {
    font-size: clamp(2rem, 10vw, 3rem);
  }

  .catalog-hero-media {
    width: min(360px, 100%);
    aspect-ratio: 3 / 4.05;
  }
}

body.catalog-body-line .catalog-line-page {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-bottom: 0 !important;
}

body.catalog-body-line .catalog-line-intro {
  margin-bottom: 18px !important;
}

body.catalog-body-line #catalog-category-sections {
  display: block;
  width: min(1380px, calc(100vw - 64px));
  margin: 0 auto;
  padding: 0;
}

body.catalog-body-line #catalog-category-sections > .catalog-category-section-grid {
  display: block;
  margin: 0;
  padding: 0;
}

body.catalog-body-line #catalog-category-sections .catalog-category-products {
  margin: 0;
  padding: 0 0 8px;
  align-content: start;
}

body.catalog-body-line #contact-footer-panel {
  margin-top: 50px !important;
  padding-top: 0 !important;
  background: rgba(255, 255, 255, 0.98);
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) #contact-footer-panel,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) #contact {
  display: block !important;
  min-height: 0 !important;
  height: auto !important;
  overflow: visible !important;
}

:is(body.about-body, body.contact-page-body) #contact,
body.detail-body #contact-footer-panel {
  margin-top: auto !important;
  content-visibility: auto;
  contain-intrinsic-size: 420px;
}

.detail-modern-page {
  width: 100%;
  max-width: none;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: #f4f1ea;
}

.detail-modern-nav {
  position: fixed !important;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  width: 100vw !important;
  margin: 0;
  box-sizing: border-box;
  padding: 18px 28px 0 470px;
}

.detail-modern-brand {
  color: #111111;
  text-shadow: none;
  display: inline-flex;
  align-items: center;
  margin: 0;
}

.detail-modern-nav .brand-row-text,
.detail-modern-nav .brand-row-mark,
.detail-modern-nav .brand-row-image {
  color: #111111;
}

.detail-modern-brand .brand-row-image {
  max-width: 416px;
  max-height: 128px;
  width: auto;
  object-position: left center;
  transform: none;
  opacity: 1 !important;
  filter: brightness(0) saturate(100%) contrast(1.8) !important;
  mix-blend-mode: normal;
}

.detail-modern-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
  min-width: 0;
}

.detail-brand-aside {
  position: fixed !important;
  left: 34px;
  top: 18px;
  z-index: 51;
}

.detail-modern-nav .detail-modern-links a {
  color: rgba(17, 17, 17, 0.88) !important;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.96rem;
  text-shadow: none;
}

.detail-modern-nav .detail-modern-links a:hover,
.detail-modern-nav .detail-modern-links a:visited {
  color: rgba(17, 17, 17, 0.88) !important;
}

.detail-modern-nav .lang-switcher-button,
.detail-modern-nav .lang-switcher-sep,
.detail-modern-nav .top-button {
  color: #111111 !important;
}

.detail-modern-nav .top-button {
  border-color: rgba(17, 17, 17, 0.18) !important;
  background: rgba(255, 255, 255, 0.74) !important;
  justify-self: end;
}

.detail-modern-nav .nav-divider {
  background: rgba(17, 17, 17, 0.18) !important;
}

.detail-modern-shell {
  width: min(1380px, calc(100vw - 72px));
  margin: 0 auto;
  padding: 136px 0 88px;
  flex: 1 0 auto;
}

.detail-modern-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(320px, 0.72fr);
  gap: 48px;
  align-items: start;
}

.detail-media-column {
  display: grid;
  gap: 26px;
}

.detail-main-visual {
  display: grid;
  place-items: center;
  min-height: 640px;
  border-radius: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
  overflow: hidden;
  cursor: zoom-in;
  position: relative;
}

.detail-main-visual.has-image img {
  display: block;
  width: 100%;
  max-height: 640px;
  object-fit: contain;
}

.detail-main-visual.is-empty {
  color: rgba(24, 24, 24, 0.46);
  font-size: 1rem;
  font-weight: 600;
}

.detail-zoom-lens {
  --lens-size: 176px;
  position: absolute;
  left: calc(var(--lens-x, -999px) - (var(--lens-size) / 2));
  top: calc(var(--lens-y, -999px) - (var(--lens-size) / 2));
  width: var(--lens-size);
  height: var(--lens-size);
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.94);
  transition: opacity 120ms ease, transform 120ms ease;
  border: 2px solid rgba(255, 255, 255, 0.95);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.16);
  background-repeat: no-repeat;
  background-color: rgba(255, 255, 255, 0.14);
  background-size: 1000%;
  background-position: var(--bg-x, 50%) var(--bg-y, 50%);
}

.detail-main-visual.is-zooming .detail-zoom-lens {
  opacity: 1;
  transform: scale(1);
}

.detail-thumb-wall {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.detail-thumb-card {
  appearance: none;
  border: 0;
  padding: 0;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: none;
  cursor: pointer;
  transition: none;
  outline: 2px solid transparent;
}

.detail-thumb-card:hover,
.detail-thumb-card.is-active {
  transform: none;
  box-shadow: none;
  outline-color: rgba(220, 48, 27, 0.92);
}

.detail-thumb-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.detail-buy-column {
  position: relative;
  margin-top: 32px;
}

.detail-buy-panel {
  display: grid;
  gap: 18px;
  padding: 8px 30px 34px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: none;
}

.detail-buy-title {
  color: #111111;
  font-size: 20px;
  line-height: 28px;
  font-weight: 600;
  letter-spacing: 0;
  font-family: "PingFang SC", "Microsoft YaHei", sans-serif;
}

.detail-buy-intro {
  margin: 0;
  color: #1677ff;
  font-size: 0.95rem;
  line-height: 1.8;
}

.detail-buy-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 30px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff7a00, #ff4d00);
  color: #fff;
  text-decoration: none;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: none;
  transition: transform 180ms ease, box-shadow 180ms ease;
}

.detail-buy-button:hover {
  transform: translateY(-2px);
  box-shadow: none;
}

.detail-buy-meta {
  padding-top: 12px;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.detail-buy-meta h3 {
  margin: 0 0 12px;
  color: #333333;
  font-size: 0.95rem;
  font-weight: 800;
}

.detail-buy-meta-list {
  display: grid;
  gap: 10px;
}

.detail-buy-meta-list p {
  margin: 0;
  color: #666666;
  font-size: 0.9rem;
  line-height: 1.75;
}

.detail-modern-empty {
  width: min(960px, calc(100vw - 64px));
  margin: 120px auto;
  padding: 80px 40px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.88);
  text-align: center;
}

.detail-modern-empty h1 {
  margin: 0 0 12px;
  font-size: 2.6rem;
}

.detail-modern-empty p {
  margin: 0;
  color: rgba(28, 28, 28, 0.64);
}

@media (max-width: 1120px) {
  .detail-modern-layout {
    grid-template-columns: 1fr;
  }

  .detail-buy-column {
    position: static;
  }

  .detail-main-visual {
    min-height: 480px;
  }
}

@media (max-width: 720px) {
  .detail-modern-nav {
    grid-template-columns: 1fr;
    justify-items: start;
    padding: 18px 18px 0;
    gap: 16px;
  }

  .detail-modern-links {
    width: 100%;
    justify-content: flex-start;
    gap: 14px 18px;
    flex-wrap: wrap;
  }

  .detail-modern-nav .top-button {
    justify-self: start;
  }

  .detail-modern-shell {
    width: calc(100vw - 28px);
    padding: 28px 0 52px;
  }

  .detail-main-visual {
    min-height: 320px;
    padding: 0;
    border-radius: 0;
  }

  .detail-thumb-wall {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .detail-buy-panel {
    padding: 24px 20px 26px;
    border-radius: 20px;
  }

  .detail-buy-button {
    width: 100%;
  }

  .detail-zoom-lens {
    display: none;
  }
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) #contact-footer-panel .contact-layout,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) #contact .contact-layout {
  padding-top: 10px !important;
  padding-bottom: 12px !important;
  align-items: center !important;
}

:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) #contact-footer-panel .contact-bottom,
:is(body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) #contact .contact-bottom {
  padding-top: 10px !important;
  padding-bottom: 14px !important;
}

body.catalog-body-line #catalog-category-sections,
body.catalog-body-line #catalog-category-sections > .catalog-category-section-grid,
body.catalog-body-line #catalog-category-sections .catalog-category-products {
  margin-bottom: 0 !important;
}

body.catalog-body-line #catalog-category-sections .catalog-category-products {
  padding-bottom: 0 !important;
}

body.catalog-body-line #catalog-category-sections .catalog-product-thumb {
  margin-bottom: 0 !important;
}

body.catalog-body-line .catalog-line-page {
  width: 100%;
  margin: 0;
  padding: 156px 0 0 !important;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  border-radius: 0;
  overflow: visible;
}

body.catalog-body-line .series-page-title-block {
  display: block;
  width: 100%;
  min-height: 138px;
  margin: 0 0 18px !important;
  padding: 84px 20px 10px;
  visibility: hidden;
}

body.catalog-body-line .catalog-line-sections {
  width: 100%;
  margin: 0;
  padding: 28px 0 100px;
  display: block;
  flex: 1 0 auto;
  margin-bottom: 0;
  border-radius: 0;
  overflow: visible;
}

body.catalog-body-line .series-card-wall-stack {
  width: min(980px, calc(100vw - 64px));
  margin: 0 auto;
  display: grid;
  gap: 38px;
}

body.catalog-body-line .series-card-wall {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  width: 100%;
  margin: 0;
  gap: 50px;
  align-items: start;
}

body.catalog-body-line .series-product-card {
  display: grid;
  grid-template-rows: auto 1fr;
  width: 100%;
  min-width: 0;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  text-decoration: none;
  box-shadow: 0 14px 34px rgba(18, 24, 34, 0.12);
  transition: transform 220ms ease, box-shadow 220ms ease;
}

body.catalog-body-line .series-product-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 42px rgba(18, 24, 34, 0.16);
}

body.catalog-body-line .series-product-card-image {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #ffffff;
  padding: 10px;
  box-sizing: border-box;
}

body.catalog-body-line .series-product-card-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body.catalog-body-line .series-product-card-copy {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 78px;
  padding: 12px 12px 14px;
  justify-content: flex-start;
  align-items: flex-start;
  background: rgba(250, 247, 238, 0.96);
}

body.catalog-body-line .series-product-card-copy strong {
  color: #11151b;
  font-size: 0.94rem;
  font-weight: 800;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body.catalog-body-line .series-product-card-copy small {
  color: rgba(17, 21, 27, 0.62);
  font-size: 0.78rem;
  line-height: 1.42;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body.catalog-body-line .series-product-card-status {
  display: inline-flex;
  align-items: center;
  gap: 0;
  width: fit-content;
  min-height: 48px;
  padding: 0;
  border-radius: 0;
  font-size: 0;
  line-height: 0;
  background: transparent;
  margin-top: auto;
  margin-left: -50px;
  align-self: flex-start;
}

body.catalog-body-line .series-product-card-status-icon {
  width: 144px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 144px;
}

body.catalog-body-line .series-product-card-status-icon svg {
  width: 14px;
  height: 14px;
  display: block;
  fill: currentColor;
}

body.catalog-body-line .series-product-card-status-icon img {
  width: 144px;
  height: 48px;
  display: block;
  object-fit: contain;
}

body.catalog-body-line .series-product-card-status-text {
  display: none;
}

body.catalog-body-line .series-pagination {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

body.catalog-body-line .series-pagination-button {
  min-width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  background: rgba(255, 255, 255, 0.16);
  color: #ffffff;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  transition: background-color 180ms ease, color 180ms ease,
    border-color 180ms ease, transform 180ms ease;
}

body.catalog-body-line .series-pagination-button:hover {
  background: rgba(255, 255, 255, 0.26);
  transform: translateY(-1px);
}

body.catalog-body-line .series-pagination-button.is-active {
  background: #ffffff;
  color: #11151b;
  border-color: #ffffff;
}

@media (max-width: 1100px) {
  body.catalog-body-line .series-card-wall-stack {
    width: min(980px, calc(100vw - 40px));
  }

  body.catalog-body-line .series-card-wall {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  body.catalog-body-line .catalog-line-page {
    padding-top: 92px !important;
  }

  body.catalog-body-line .series-page-title-block {
    width: min(100%, calc(100vw - 28px));
    min-height: 92px;
    padding: 42px 12px 8px;
    margin-bottom: 18px !important;
  }

  body.catalog-body-line .catalog-line-sections {
    padding: 18px;
  }

  body.catalog-body-line .series-card-wall-stack {
    width: min(100%, calc(100vw - 28px));
    gap: 24px;
  }

  body.catalog-body-line .series-card-wall {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    margin: 0;
    gap: 16px;
  }

  body.catalog-body-line .series-pagination {
    gap: 8px;
  }

  body.catalog-body-line .series-pagination-button {
    min-width: 38px;
    height: 38px;
    font-size: 0.9rem;
  }
}

@media (max-width: 760px) {
  html,
  body {
    overflow-x: hidden;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .side-brand-global {
    left: 14px;
    top: 10px;
    max-width: calc(100vw - 28px);
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .side-brand-global .brand-row-image {
    max-width: min(58vw, 220px);
    max-height: 62px;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .top-nav-global,
  .detail-modern-nav {
    left: 14px;
    right: 14px;
    top: 70px;
    min-height: auto;
    padding-top: 0;
    gap: 10px;
    align-items: flex-start;
    flex-direction: column;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .top-nav-global nav,
  .detail-modern-links {
    width: 100%;
    min-height: 0;
    justify-content: flex-start;
    gap: 10px 14px;
    flex-wrap: wrap;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .top-nav-global .top-button,
  .detail-modern-nav .top-button {
    padding: 10px 16px;
    min-height: 40px;
  }

  body.home-page #home-panels {
    padding-top: 126px;
  }

  .home-fade-stage,
  .home-fade-slides {
    min-height: calc(100svh - 126px);
    height: calc(100svh - 126px);
  }

  .home-fade-slide-image-main img {
    object-position: center top;
  }

  body.home-page .contact-jump-button {
    right: 10px;
    width: 48px;
    min-height: 176px;
    padding: 14px 8px;
    font-size: 0.84rem;
  }

  body.catalog-body-line .catalog-line-page {
    padding-top: 138px !important;
  }

  body.catalog-body-line .series-page-title-block {
    min-height: 60px;
    padding-top: 18px;
  }

  body.catalog-body-line .catalog-line-sections {
    padding: 12px 14px 28px;
  }

  body.catalog-body-line .series-card-wall {
    grid-template-columns: 1fr;
    width: 100%;
    gap: 14px;
  }

  body.catalog-body-line .series-product-card {
    grid-template-columns: 112px minmax(0, 1fr);
    grid-template-rows: none;
    align-items: stretch;
  }

  body.catalog-body-line .series-product-card-image {
    aspect-ratio: auto;
    height: 112px;
    padding: 8px;
  }

  body.catalog-body-line .series-product-card-copy {
    min-height: 0;
    padding: 12px;
  }

  .detail-modern-page {
    min-height: auto;
  }

  .detail-modern-shell {
    width: calc(100vw - 28px);
    padding: 158px 0 44px;
  }

  .detail-modern-layout {
    gap: 22px;
  }

  .detail-main-visual {
    min-height: 0;
  }

  .detail-main-visual.has-image img {
    max-height: min(62svh, 460px);
  }

  .detail-thumb-wall {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
  }

  .detail-thumb-card {
    border-radius: 12px;
  }

  .detail-buy-panel {
    gap: 16px;
    padding: 20px 16px 22px;
    border-radius: 18px;
  }

  .detail-buy-title {
    font-size: clamp(1.8rem, 9vw, 2.5rem);
  }

  .detail-buy-intro,
  .detail-buy-meta-list p {
    line-height: 1.7;
  }

  .about-page {
    padding-top: 136px;
  }

  .contact-page-shell {
    width: calc(100vw - 28px);
    padding-top: 8px;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-layout,
  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-bottom {
    padding-left: 14px;
    padding-right: 14px;
    width: 100%;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-link-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, max-content));
    justify-content: flex-start;
    gap: 10px 16px;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-meta {
    font-size: 0.74rem;
    gap: 8px;
  }

  :is(body.home-page, body.about-body, body.contact-page-body, body.catalog-body-line, body.detail-body) .contact-socials {
    justify-content: flex-start;
  }

  .landing-logo-link {
    min-width: min(90vw, 1040px);
    min-height: min(56vw, 440px);
    padding: 16px;
  }

  .landing-rotator {
    width: min(82vw, 760px);
    height: min(82vw, 760px);
  }
}

body.detail-body .detail-brand-aside {
  position: fixed !important;
  top: 18px !important;
  left: 34px !important;
  right: auto !important;
  z-index: 70 !important;
  margin: 0 !important;
}

body.detail-body #detail-fixed-chrome {
  position: relative !important;
  inset: auto !important;
  width: 100% !important;
  height: 36px !important;
  z-index: auto !important;
  pointer-events: auto !important;
  background: #f4f1ea !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.detail-body #detail-fixed-chrome .detail-brand-aside,
body.detail-body #detail-fixed-chrome .detail-modern-nav.top-nav-global {
  pointer-events: auto !important;
}

body.detail-body .detail-modern-nav.top-nav-global {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  max-width: none !important;
  z-index: 11 !important;
  margin: 0 !important;
  padding: 0 28px 0 470px !important;
  box-sizing: border-box !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-direction: row !important;
  gap: 20px !important;
  transform: none !important;
  background: #f4f1ea !important;
  border-bottom: 1px solid rgba(17, 17, 17, 0.1) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.detail-body .detail-modern-nav.top-nav-global nav.detail-modern-links {
  display: flex !important;
  width: auto !important;
  min-height: 28px !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: nowrap !important;
  gap: 28px !important;
}

body.detail-body .detail-modern-nav.top-nav-global .top-button {
  align-self: center !important;
  min-height: 28px !important;
  padding: 4px 14px !important;
}

@media (max-width: 720px) {
  body.detail-body .detail-brand-aside {
    top: 10px !important;
    left: 14px !important;
  }

  body.detail-body #detail-fixed-chrome {
    height: 96px !important;
  }

  body.detail-body .detail-modern-nav.top-nav-global {
    top: 70px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    padding: 0 14px !important;
    gap: 10px !important;
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  body.detail-body .detail-modern-nav.top-nav-global nav.detail-modern-links {
    width: 100% !important;
    min-height: 0 !important;
    justify-content: flex-start !important;
    flex-wrap: wrap !important;
    gap: 10px 14px !important;
  }
}

body.detail-body #detail-fixed-chrome {
  position: relative !important;
  inset: auto !important;
  width: 100% !important;
  height: 108px !important;
  z-index: auto !important;
  pointer-events: auto !important;
  background: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.detail-body .detail-brand-aside {
  position: absolute !important;
  top: -20px !important;
  left: 34px !important;
  z-index: 12 !important;
}

body.detail-body .detail-modern-nav.top-nav-global {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 11 !important;
  background: #f4f1ea !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

body.detail-body .detail-modern-shell {
  padding-top: 0 !important;
  margin-top: -1px !important;
}

@media (max-width: 720px) {
  body.detail-body #detail-fixed-chrome {
    height: 132px !important;
  }

  body.detail-body .detail-brand-aside {
    top: 10px !important;
    left: 14px !important;
  }

  body.detail-body .detail-modern-nav.top-nav-global {
    top: 70px !important;
  }

  body.detail-body .detail-modern-shell {
    padding-top: 0 !important;
    margin-top: -1px !important;
  }
}

body.about-body .about-clean-page {
  width: 100%;
  background: #f6f1e8;
}

body.about-body .about-clean-page > section + section {
  margin-top: 0;
}

.about-clean-hero {
  position: relative;
  min-height: calc(100vh - 112px);
  overflow: hidden;
  background: #111;
}

.about-clean-hero-media {
  position: absolute;
  inset: 0;
}

.about-clean-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-clean-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10, 10, 10, 0.58) 0%, rgba(10, 10, 10, 0.2) 44%, rgba(10, 10, 10, 0.08) 100%);
}

.about-clean-hero-copy {
  position: relative;
  z-index: 1;
  min-height: calc(100vh - 112px);
  width: min(1280px, calc(100vw - 80px));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 16px;
}

.about-clean-kicker {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.about-clean-hero-copy h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(3.6rem, 7vw, 6.4rem);
  line-height: 1;
  font-weight: 800;
  max-width: 8ch;
}

.about-clean-intro,
.about-clean-values,
.about-clean-coop {
  background: #f6f1e8;
  padding: 92px 20px;
}

.about-clean-collab {
  background: #ffffff;
  padding: 92px 20px;
}

.about-clean-head {
  width: min(1100px, calc(100vw - 80px));
  margin: 0 auto 52px;
  text-align: center;
}

.about-clean-head h2 {
  margin: 0;
  color: #141414;
  font-size: clamp(2rem, 3.4vw, 3.35rem);
  line-height: 1.05;
  font-weight: 800;
}

.about-clean-head p {
  margin: 10px 0 0;
  color: #5c5c5c;
  font-size: 1.1rem;
  line-height: 1.5;
}

.about-clean-copy {
  width: min(900px, calc(100vw - 80px));
  margin: 0 auto;
  display: grid;
  gap: 18px;
  text-align: center;
}

.about-clean-copy p {
  margin: 0;
  color: #4b4b4b;
  font-size: 16px;
  line-height: 1.9;
}

.about-clean-copy blockquote {
  margin: 8px 0 0;
  color: #7a6952;
  font-size: 1rem;
  line-height: 1.8;
  font-style: italic;
}

.about-clean-values-grid {
  width: min(1240px, calc(100vw - 80px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.about-clean-value-item {
  aspect-ratio: 1 / 1;
  min-height: 0;
  border: 1px solid rgba(20, 20, 20, 0.14);
  background: rgba(255, 255, 255, 0.7);
  padding: 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 14px;
  transition: transform 220ms ease, border-color 220ms ease, background 220ms ease;
}

.about-clean-value-item:hover {
  transform: translateY(-4px);
  border-color: rgba(225, 181, 60, 0.55);
  background: #fffdf8;
}

.about-clean-value-no {
  color: transparent;
  -webkit-text-stroke: 1px rgba(20, 20, 20, 0.52);
  font-size: clamp(2.1rem, 3vw, 2.9rem);
  font-weight: 800;
  line-height: 1;
}

.about-clean-value-copy h3 {
  margin: 0;
  color: #181818;
  font-size: 1.4rem;
  line-height: 1.2;
  font-weight: 700;
}

.about-clean-value-copy p {
  margin: 14px 0 0;
  color: #595959;
  font-size: 0.95rem;
  line-height: 1.8;
}

.about-clean-collab-grid {
  width: min(1240px, calc(100vw - 80px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.about-clean-collab-card {
  background: #fff;
  border: 1px solid rgba(20, 20, 20, 0.08);
  overflow: hidden;
  transition: transform 220ms ease, box-shadow 220ms ease;
}

.about-clean-collab-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 42px rgba(18, 24, 34, 0.08);
}

.about-clean-collab-poster {
  aspect-ratio: 1 / 1;
  background: #f4efe8;
  overflow: hidden;
}

.about-clean-collab-poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-clean-collab-copy {
  padding: 16px 16px 18px;
}

.about-clean-collab-copy h3 {
  margin: 0;
  color: #171717;
  font-size: 1.02rem;
  line-height: 1.35;
  font-weight: 700;
}

.about-clean-collab-copy p {
  margin: 8px 0 0;
  color: #666;
  font-size: 0.88rem;
  line-height: 1.6;
}

.about-clean-coop-grid {
  width: min(1240px, calc(100vw - 80px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 16px;
}

.about-clean-coop-item {
  min-height: 92px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.66);
  border: 1px solid rgba(20, 20, 20, 0.06);
}

.about-clean-coop-item img {
  max-width: min(132px, 88%);
  max-height: 44px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(1);
  transition: filter 180ms ease;
}

.about-clean-coop-item:hover img {
  filter: grayscale(0);
}

@media (max-width: 1024px) {
  .about-clean-values-grid,
  .about-clean-collab-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-clean-coop-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .about-clean-hero,
  .about-clean-hero-copy {
    min-height: 62vh;
  }

  .about-clean-hero-copy {
    width: calc(100vw - 36px);
    padding-top: 34px;
  }

  .about-clean-hero-copy h1 {
    font-size: clamp(2.5rem, 12vw, 4rem);
  }

  .about-clean-intro,
  .about-clean-values,
  .about-clean-collab,
  .about-clean-coop {
    padding: 66px 18px;
  }

  .about-clean-head,
  .about-clean-copy,
  .about-clean-values-grid,
  .about-clean-collab-grid,
  .about-clean-coop-grid {
    width: 100%;
  }

  .about-clean-values-grid,
  .about-clean-collab-grid {
    grid-template-columns: 1fr;
  }

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

  .about-clean-value-item {
    aspect-ratio: auto;
    min-height: 220px;
  }
}

body.contact-page-body .contact-clean-page {
  width: 100%;
  background: #f7f4ef;
  color: #181818;
}

body.contact-page-body .contact-clean-page > section + section {
  margin-top: clamp(64px, 8vw, 112px);
}

body.contact-page-body .contact-clean-hero,
body.contact-page-body .contact-clean-main,
body.contact-page-body .contact-clean-services {
  width: min(1180px, calc(100vw - 80px));
  margin: 0 auto;
}

body.contact-page-body .contact-clean-hero {
  position: relative;
  min-height: clamp(360px, 48vw, 520px);
  overflow: hidden;
  background: #111111;
}

body.contact-page-body .contact-clean-hero-media,
body.contact-page-body .contact-clean-hero-media img {
  width: 100%;
  height: 100%;
}

body.contact-page-body .contact-clean-hero-media {
  position: absolute;
  inset: 0;
}

body.contact-page-body .contact-clean-hero-media img {
  display: block;
  object-fit: cover;
}

body.contact-page-body .contact-clean-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(8, 8, 8, 0.6) 0%, rgba(8, 8, 8, 0.16) 62%, rgba(8, 8, 8, 0.08) 100%);
}

body.contact-page-body .contact-clean-hero-copy {
  position: relative;
  z-index: 1;
  display: flex;
  min-height: inherit;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 14px;
  padding: clamp(42px, 7vw, 80px);
  max-width: 620px;
  color: #ffffff;
}

body.contact-page-body .contact-clean-kicker {
  display: inline-flex;
  align-items: center;
  padding: 7px 16px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body.contact-page-body .contact-clean-hero-copy h1 {
  margin: 0;
  font-size: clamp(2.8rem, 7vw, 5.4rem);
  line-height: 1;
  font-weight: 800;
}

body.contact-page-body .contact-clean-hero-copy p {
  margin: 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 1rem;
  line-height: 1.9;
}

body.contact-page-body .contact-clean-main {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr);
  gap: clamp(26px, 4vw, 48px);
  align-items: stretch;
}

body.contact-page-body .contact-clean-headquarter {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 30px;
  padding: clamp(34px, 4vw, 48px);
  background: #ffffff;
  border: 1px solid rgba(24, 24, 24, 0.08);
}

body.contact-page-body .contact-clean-head {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

body.contact-page-body .contact-clean-head h2 {
  margin: 0;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  line-height: 1.05;
  font-weight: 800;
}

body.contact-page-body .contact-clean-head p {
  margin: 0;
  color: #7d756d;
  font-size: 0.95rem;
  font-weight: 600;
}

body.contact-page-body .contact-clean-headquarter-body {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

body.contact-page-body .contact-clean-headquarter-body h3 {
  margin: 0;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.2;
}

body.contact-page-body .contact-clean-headquarter-body ul {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 18px;
  list-style: none;
}

body.contact-page-body .contact-clean-headquarter-body li {
  display: grid;
  gap: 6px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(24, 24, 24, 0.08);
}

body.contact-page-body .contact-clean-headquarter-body li:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

body.contact-page-body .contact-clean-headquarter-body strong {
  color: #a43d2a;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.contact-page-body .contact-clean-headquarter-body span {
  color: #3b3834;
  font-size: 1rem;
  line-height: 1.8;
}

body.contact-page-body .contact-clean-side-visual {
  min-height: 100%;
  overflow: hidden;
  background: #e9e3d8;
}

body.contact-page-body .contact-clean-side-visual img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

body.contact-page-body .contact-clean-services {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  padding-bottom: clamp(48px, 7vw, 84px);
}

body.contact-page-body .contact-clean-service-item {
  display: grid;
  gap: 18px;
  align-content: start;
  min-height: 240px;
  padding: 28px 26px 30px;
  background: #ffffff;
  border: 1px solid rgba(24, 24, 24, 0.08);
}

body.contact-page-body .contact-clean-service-no {
  color: rgba(164, 61, 42, 0.44);
  font-size: 2.4rem;
  line-height: 1;
  font-weight: 800;
}

body.contact-page-body .contact-clean-service-copy {
  display: grid;
  gap: 8px;
}

body.contact-page-body .contact-clean-service-copy h3 {
  margin: 0;
  color: #181818;
  font-size: 1.2rem;
  line-height: 1.3;
  font-weight: 700;
}

body.contact-page-body .contact-clean-service-copy p {
  margin: 0;
  color: #68615b;
  font-size: 0.95rem;
  line-height: 1.85;
}

@media (max-width: 1024px) {
  body.contact-page-body .contact-clean-main,
  body.contact-page-body .contact-clean-services {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  body.contact-page-body .contact-clean-hero,
  body.contact-page-body .contact-clean-main,
  body.contact-page-body .contact-clean-services {
    width: min(100%, calc(100vw - 36px));
  }

  body.contact-page-body .contact-clean-hero-copy {
    padding: 34px 24px;
  }

  body.contact-page-body .contact-clean-hero-copy h1 {
    font-size: 2.4rem;
  }

  body.contact-page-body .contact-clean-services {
    padding-bottom: 44px;
  }
}

body.contact-page-body .contact-studio-page {
  width: 100%;
  overflow: hidden;
  background:
    linear-gradient(180deg, #f3efe7 0%, #ffffff 46%, #f4f0e8 100%);
  color: #161616;
}

body.contact-page-body .contact-studio-page > section + section {
  margin-top: clamp(60px, 7vw, 104px);
}

body.contact-page-body .contact-studio-hero {
  position: relative;
  width: min(1280px, calc(100vw - 72px));
  min-height: clamp(460px, 56vw, 660px);
  margin: 0 auto;
  overflow: hidden;
  background:
    linear-gradient(135deg, #111111 0%, #2b211d 54%, #b44831 100%);
}

body.contact-page-body .contact-studio-hero-media {
  position: absolute;
  inset: 0;
}

body.contact-page-body .contact-studio-hero-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  opacity: 0.68;
  filter: saturate(0.94) contrast(1.06);
}

body.contact-page-body .contact-studio-hero-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(8, 8, 8, 0.78) 0%, rgba(8, 8, 8, 0.38) 46%, rgba(8, 8, 8, 0.08) 100%),
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 96px);
}

body.contact-page-body .contact-studio-hero-copy {
  position: relative;
  z-index: 1;
  width: min(650px, 68%);
  min-height: inherit;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  padding: clamp(54px, 7vw, 96px);
  color: #ffffff;
}

body.contact-page-body .contact-studio-hero-copy span,
body.contact-page-body .contact-studio-section-head span,
body.contact-page-body .contact-studio-info-title span {
  color: #d85b3f;
  font-size: 0.78rem;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body.contact-page-body .contact-studio-hero-copy h1 {
  margin: 0;
  font-size: clamp(4.6rem, 9vw, 8.4rem);
  line-height: 0.88;
  font-weight: 900;
}

body.contact-page-body .contact-studio-hero-copy p {
  width: min(520px, 100%);
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 1.02rem;
  line-height: 1.9;
}

body.contact-page-body .contact-studio-hq {
  position: absolute;
  right: clamp(26px, 4vw, 56px);
  bottom: clamp(24px, 4vw, 48px);
  z-index: 2;
  width: min(340px, calc(100% - 52px));
  padding: 24px 26px;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(18px);
}

body.contact-page-body .contact-studio-hq span {
  display: block;
  margin-bottom: 12px;
  color: rgba(255, 255, 255, 0.64);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
}

body.contact-page-body .contact-studio-hq strong {
  display: block;
  font-size: 1.25rem;
  line-height: 1.25;
}

body.contact-page-body .contact-studio-hq p {
  margin: 10px 0 0;
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.92rem;
  line-height: 1.75;
}

body.contact-page-body .contact-studio-directory,
body.contact-page-body .contact-studio-info {
  width: min(1180px, calc(100vw - 80px));
  margin-left: auto;
  margin-right: auto;
}

body.contact-page-body .contact-studio-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 28px;
  margin-bottom: 28px;
}

body.contact-page-body .contact-studio-section-head h2,
body.contact-page-body .contact-studio-info-title h2 {
  margin: 0;
  color: #171717;
  font-size: clamp(2.2rem, 5vw, 4.2rem);
  line-height: 0.96;
  font-weight: 900;
}

body.contact-page-body .contact-studio-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

body.contact-page-body .contact-studio-card {
  position: relative;
  min-height: 310px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 30px;
  overflow: hidden;
  background: #ffffff;
  border: 1px solid rgba(20, 20, 20, 0.1);
  transition: transform 0.28s ease, border-color 0.28s ease, background 0.28s ease;
}

body.contact-page-body .contact-studio-card::after {
  content: "";
  position: absolute;
  left: 30px;
  right: 30px;
  bottom: 0;
  height: 4px;
  background: #d85b3f;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.28s ease;
}

body.contact-page-body .contact-studio-card:hover {
  transform: translateY(-8px);
  border-color: rgba(216, 91, 63, 0.5);
  background: #fffaf5;
}

body.contact-page-body .contact-studio-card:hover::after {
  transform: scaleX(1);
}

body.contact-page-body .contact-studio-card-no {
  color: rgba(20, 20, 20, 0.16);
  font-size: 4.5rem;
  line-height: 0.8;
  font-weight: 900;
}

body.contact-page-body .contact-studio-card-copy {
  display: grid;
  gap: 9px;
}

body.contact-page-body .contact-studio-card-copy small {
  color: #d85b3f;
  font-size: 0.74rem;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0.12em;
}

body.contact-page-body .contact-studio-card-copy h3 {
  margin: 0;
  color: #171717;
  font-size: 1.45rem;
  line-height: 1.2;
  font-weight: 800;
}

body.contact-page-body .contact-studio-card-copy p {
  margin: 0;
  color: #625b55;
  font-size: 0.95rem;
  line-height: 1.78;
}

body.contact-page-body .contact-studio-info {
  display: grid;
  grid-template-columns: minmax(240px, 0.7fr) minmax(0, 1.3fr);
  gap: clamp(24px, 5vw, 70px);
  padding: 46px 0 clamp(64px, 8vw, 108px);
  border-top: 1px solid rgba(20, 20, 20, 0.12);
}

body.contact-page-body .contact-studio-info-title {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

body.contact-page-body .contact-studio-info-list {
  display: grid;
  gap: 0;
  margin: 0;
}

body.contact-page-body .contact-studio-info-list div {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 22px;
  padding: 22px 0;
  border-bottom: 1px solid rgba(20, 20, 20, 0.1);
}

body.contact-page-body .contact-studio-info-list div:first-child {
  padding-top: 0;
}

body.contact-page-body .contact-studio-info-list dt {
  color: #d85b3f;
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

body.contact-page-body .contact-studio-info-list dd {
  margin: 0;
  color: #282522;
  font-size: 1rem;
  line-height: 1.8;
}

@media (max-width: 1024px) {
  body.contact-page-body .contact-studio-card-grid,
  body.contact-page-body .contact-studio-info {
    grid-template-columns: 1fr;
  }

  body.contact-page-body .contact-studio-hero-copy {
    width: min(680px, 100%);
  }

  body.contact-page-body .contact-studio-hq {
    position: relative;
    right: auto;
    bottom: auto;
    margin: -110px 28px 28px auto;
  }
}

@media (max-width: 720px) {
  body.contact-page-body .contact-studio-hero,
  body.contact-page-body .contact-studio-directory,
  body.contact-page-body .contact-studio-info {
    width: min(100%, calc(100vw - 36px));
  }

  body.contact-page-body .contact-studio-hero {
    min-height: 520px;
  }

  body.contact-page-body .contact-studio-hero-copy {
    padding: 42px 24px;
  }

  body.contact-page-body .contact-studio-hero-copy h1 {
    font-size: 3.4rem;
  }

  body.contact-page-body .contact-studio-hq {
    width: auto;
    margin: -92px 18px 24px;
  }

  body.contact-page-body .contact-studio-section-head {
    align-items: flex-start;
    flex-direction: column;
  }

  body.contact-page-body .contact-studio-card {
    min-height: 260px;
    padding: 24px;
  }

body.contact-page-body .contact-studio-info-list div {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}

body.contact-page-body .contact-reference-page {
  width: 100%;
  background:
    radial-gradient(circle at 18% 30%, rgba(236, 226, 206, 0.34), transparent 30%),
    linear-gradient(180deg, #fbf8f2 0%, #ffffff 54%, #fbf8f2 100%);
  color: #171717;
}

body.contact-page-body .contact-ref-banner {
  width: 100%;
  height: clamp(210px, 25vw, 330px);
  overflow: hidden;
  background: #e8dfd2;
}

body.contact-page-body .contact-ref-banner img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

body.contact-page-body .contact-ref-heading {
  width: min(1180px, calc(100vw - 80px));
  margin: 0 auto;
  padding: clamp(44px, 5vw, 70px) 0 28px;
  text-align: center;
}

body.contact-page-body .contact-ref-heading h1 {
  margin: 0;
  color: #101010;
  font-family: "Noto Sans SC", "Microsoft YaHei", sans-serif;
  font-size: clamp(2.8rem, 4.8vw, 4.8rem);
  line-height: 1;
  font-weight: 900;
}

body.contact-page-body .contact-ref-heading p {
  position: relative;
  display: inline-block;
  margin: 14px 0 0;
  padding-bottom: 14px;
  color: #202020;
  font-size: 1.38rem;
  line-height: 1.35;
  font-weight: 500;
}

body.contact-page-body .contact-ref-heading p::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 28px;
  height: 3px;
  background: #d71920;
  transform: translateX(-50%);
}

body.contact-page-body .contact-ref-body {
  width: min(1180px, calc(100vw - 80px));
  margin: 0 auto;
  padding: 0 0 clamp(54px, 7vw, 92px);
  display: grid;
  grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1.22fr);
  gap: clamp(34px, 5vw, 70px);
  align-items: center;
}

body.contact-page-body .contact-ref-list {
  display: grid;
}

body.contact-page-body .contact-ref-item {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
  padding: 24px 0;
  border-bottom: 1px solid rgba(20, 20, 20, 0.16);
}

body.contact-page-body .contact-ref-item:first-child {
  padding-top: 0;
}

body.contact-page-body .contact-ref-item:last-child {
  border-bottom: none;
}

body.contact-page-body .contact-ref-icon {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: linear-gradient(145deg, #e31a25, #c90812);
  box-shadow: 0 12px 22px rgba(214, 17, 30, 0.22);
}

body.contact-page-body .contact-ref-icon svg {
  width: 30px;
  height: 30px;
  fill: none;
  stroke: #ffffff;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

body.contact-page-body .contact-ref-copy h2 {
  margin: 0 0 12px;
  color: #1d1d1d;
  font-size: 1.42rem;
  line-height: 1.25;
  font-weight: 800;
}

body.contact-page-body .contact-ref-copy p {
  margin: 5px 0 0;
  color: #68625c;
  font-size: 0.98rem;
  line-height: 1.65;
}

body.contact-page-body .contact-ref-location {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1fr);
  min-height: 320px;
  overflow: hidden;
  border-radius: 10px;
  background: #ffffff;
  box-shadow: 0 24px 58px rgba(38, 32, 24, 0.1);
}

body.contact-page-body .contact-ref-store {
  min-height: 320px;
  background: #e2d6c8;
}

body.contact-page-body .contact-ref-store img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

body.contact-page-body .contact-ref-map {
  position: relative;
  min-height: 320px;
  overflow: hidden;
  background:
    linear-gradient(115deg, rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.58)),
    linear-gradient(30deg, transparent 0 38%, rgba(204, 204, 204, 0.34) 38% 40%, transparent 40% 100%),
    linear-gradient(120deg, transparent 0 44%, rgba(204, 204, 204, 0.32) 44% 46%, transparent 46% 100%),
    repeating-linear-gradient(0deg, rgba(190, 190, 190, 0.18) 0 2px, transparent 2px 54px),
    repeating-linear-gradient(90deg, rgba(190, 190, 190, 0.18) 0 2px, transparent 2px 60px),
    #f2f1ee;
}

body.contact-page-body .contact-ref-pin {
  position: absolute;
  top: 28%;
  left: 50%;
  width: 68px;
  height: 68px;
  display: grid;
  place-items: center;
  color: #ffffff;
  background: #d71920;
  border-radius: 50% 50% 50% 0;
  transform: translate(-50%, -50%) rotate(-45deg);
  box-shadow: 0 18px 30px rgba(215, 25, 32, 0.24);
}

body.contact-page-body .contact-ref-pin span {
  font-size: 0.68rem;
  font-weight: 900;
  transform: rotate(45deg);
}

body.contact-page-body .contact-ref-address {
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 34px;
  padding: 22px 26px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 40px rgba(35, 35, 35, 0.08);
  backdrop-filter: blur(12px);
}

body.contact-page-body .contact-ref-address strong {
  display: block;
  color: #4a4038;
  font-size: 1rem;
  line-height: 1.6;
  font-weight: 800;
}

body.contact-page-body .contact-ref-address p {
  margin: 8px 0 0;
  color: #8a8178;
  font-size: 0.86rem;
  line-height: 1.6;
}

@media (max-width: 1024px) {
  body.contact-page-body .contact-ref-body,
  body.contact-page-body .contact-ref-location {
    grid-template-columns: 1fr;
  }

  body.contact-page-body .contact-ref-location {
    max-width: 680px;
    margin: 0 auto;
  }
}

@media (max-width: 720px) {
  body.contact-page-body .contact-ref-heading,
  body.contact-page-body .contact-ref-body {
    width: min(100%, calc(100vw - 36px));
  }

  body.contact-page-body .contact-ref-banner {
    height: 220px;
  }

  body.contact-page-body .contact-ref-heading h1 {
    font-size: 2.7rem;
  }

  body.contact-page-body .contact-ref-item {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 18px;
  }

  body.contact-page-body .contact-ref-icon {
    width: 48px;
    height: 48px;
  }

  body.contact-page-body .contact-ref-icon svg {
    width: 25px;
    height: 25px;
  }
}
