/* public/style.css — Preset A (SaaS / clean / trustworthy / minimal) */

/* ------------------------------
   Design Tokens
------------------------------ */

:root {
  /* Layout */
  --container: 1180px;

  /* Typography */
  --font-sans: "Avenir Next", "Hiragino Sans", "Yu Gothic", "BIZ UDPGothic", "Noto Sans JP", sans-serif;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  --text-xs: 0.8125rem;  /* 13px */
  --text-sm: 0.875rem;   /* 14px */
  --text-md: 1rem;       /* 16px */
  --text-lg: 1.125rem;   /* 18px */
  --text-xl: 1.25rem;    /* 20px */
  --text-2xl: 1.5rem;    /* 24px */
  --text-3xl: 2rem;      /* 32px */
  --text-4xl: 2.5rem;    /* 40px */

  --leading-tight: 1.2;
  --leading-normal: 1.65;

  /* Spacing */
  --space-1: 0.25rem; /* 4 */
  --space-2: 0.5rem;  /* 8 */
  --space-3: 0.75rem; /* 12 */
  --space-4: 1rem;    /* 16 */
  --space-5: 1.5rem;  /* 24 */
  --space-6: 2rem;    /* 32 */
  --space-7: 3rem;    /* 48 */
  --space-8: 4rem;    /* 64 */
  --space-9: 5rem;    /* 80 */

  /* Radius (中) */
  --radius-1: 10px;
  --radius-2: 14px;
  --radius-3: 20px;

  /* Border */
  --border-w: 1px;

  /* Shadow（弱〜中） */
  --shadow-1: 0 1px 2px rgba(15, 23, 42, 0.08), 0 1px 1px rgba(15, 23, 42, 0.06);
  --shadow-2: 0 8px 24px rgba(15, 23, 42, 0.10), 0 2px 6px rgba(15, 23, 42, 0.06);
  --shadow-3: 0 18px 50px rgba(15, 23, 42, 0.16), 0 6px 16px rgba(15, 23, 42, 0.10);

  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-1: 140ms;
  --dur-2: 220ms;
  --dur-3: 360ms;

  /* Color scheme base (auto: default light; dark via media query) */
  color-scheme: light dark;

  /* Light theme */
  --bg: #f3efe7;
  --bg-elev: #fffdf8;
  --surface: #fffaf3;
  --surface-2: #efe6d8;
  --surface-3: #e7ddcd;

  --text: #17212a;
  --text-muted: #4d5d67;
  --text-faint: #6f7e87;

  --border: rgba(15, 23, 42, 0.12);

  /* Accent (Preset A recommended) */
  --accent: #0f766e;
  --accent-2: #f97316;
  --accent-contrast: #f8fffd;

  --success: #16a34a;
  --warning: #f59e0b;
  --danger: #ef4444;

  --ring: rgba(15, 118, 110, 0.28);
  --ring-strong: rgba(15, 118, 110, 0.48);

  --nav-bg: rgba(243, 239, 231, 0.76);
  --nav-border: rgba(23, 33, 42, 0.09);

  --bg-decor-1: rgba(15, 118, 110, 0.18);
  --bg-decor-2: rgba(249, 115, 22, 0.12);
}

/* Manual override (optional) */
:root[data-theme="light"] {
  color-scheme: light;
}
:root[data-theme="dark"] {
  color-scheme: dark;
  --bg: #11171b;
  --bg-elev: #151e23;
  --surface: #182227;
  --surface-2: #203038;
  --surface-3: #253943;

  --text: #e8ece5;
  --text-muted: #bec9c2;
  --text-faint: #93a59f;

  --border: rgba(229, 231, 235, 0.14);

  --accent: #59c4b7;
  --accent-2: #fb923c;
  --accent-contrast: #0f1518;

  --ring: rgba(89, 196, 183, 0.34);
  --ring-strong: rgba(89, 196, 183, 0.58);

  --nav-bg: rgba(21, 30, 35, 0.72);
  --nav-border: rgba(229, 231, 235, 0.10);

  --shadow-1: 0 1px 2px rgba(0, 0, 0, 0.45);
  --shadow-2: 0 10px 30px rgba(0, 0, 0, 0.45);
  --shadow-3: 0 22px 60px rgba(0, 0, 0, 0.55);

  --bg-decor-1: rgba(89, 196, 183, 0.16);
  --bg-decor-2: rgba(251, 146, 60, 0.12);
}

/* Auto dark */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    color-scheme: dark;
    --bg: #11171b;
    --bg-elev: #151e23;
    --surface: #182227;
    --surface-2: #203038;
    --surface-3: #253943;

    --text: #e8ece5;
    --text-muted: #bec9c2;
    --text-faint: #93a59f;

    --border: rgba(229, 231, 235, 0.14);

    --accent: #59c4b7;
    --accent-2: #fb923c;
    --accent-contrast: #0f1518;

    --ring: rgba(89, 196, 183, 0.34);
    --ring-strong: rgba(89, 196, 183, 0.58);

    --nav-bg: rgba(21, 30, 35, 0.72);
    --nav-border: rgba(229, 231, 235, 0.10);

    --shadow-1: 0 1px 2px rgba(0, 0, 0, 0.45);
    --shadow-2: 0 10px 30px rgba(0, 0, 0, 0.45);
    --shadow-3: 0 22px 60px rgba(0, 0, 0, 0.55);

    --bg-decor-1: rgba(89, 196, 183, 0.16);
    --bg-decor-2: rgba(251, 146, 60, 0.12);
  }
}

/* ------------------------------
   Reset / Base
------------------------------ */

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

html {
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: var(--leading-normal);
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0) 24%),
    radial-gradient(1200px 620px at 8% -10%, var(--bg-decor-1) 0%, rgba(0, 0, 0, 0) 62%),
    radial-gradient(980px 540px at 105% 8%, var(--bg-decor-2) 0%, rgba(0, 0, 0, 0) 56%),
    linear-gradient(rgba(23, 33, 42, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(23, 33, 42, 0.025) 1px, transparent 1px),
    var(--bg);
  background-size: auto, auto, auto, 38px 38px, 38px 38px, auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

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

[hidden] {
  display: none !important;
}

a {
  color: inherit;
  text-decoration: underline;
  text-decoration-color: color-mix(in srgb, var(--accent) 55%, transparent);
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1px;
}
a:hover {
  text-decoration-color: var(--accent);
}

p {
  margin: 0;
}

hr {
  border: 0;
  border-top: var(--border-w) solid var(--border);
  margin: var(--space-6) 0;
}

:where(ul, ol) {
  margin: 0;
  padding-left: 1.1em;
}

:where(button, input, select, textarea) {
  font: inherit;
  color: inherit;
}

:where(button) {
  cursor: pointer;
}

::selection {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
}

:focus-visible {
  outline: 3px solid var(--ring-strong);
  outline-offset: 2px;
}

@supports not selector(:focus-visible) {
  :focus {
    outline: 3px solid var(--ring-strong);
    outline-offset: 2px;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}

/* ------------------------------
   Layout
------------------------------ */

.container {
  width: min(var(--container), calc(100% - (var(--space-6) * 2)));
  margin-inline: auto;
}

.section {
  padding-block: var(--space-8);
}

.section--tight {
  padding-block: var(--space-6);
}

.section--alt {
  background: color-mix(in srgb, var(--surface) 66%, transparent);
  border-top: var(--border-w) solid var(--border);
  border-bottom: var(--border-w) solid var(--border);
}

.section--hero {
  padding-top: var(--space-7);
}

.stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.stack--lg {
  gap: var(--space-6);
}

.cluster {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}

.grid {
  --grid-min: 260px;
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--grid-min)), 1fr));
}

.hero-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.95fr);
  align-items: stretch;
}

.hero-panel {
  position: relative;
  overflow: hidden;
  padding: clamp(1.5rem, 2vw, 2.5rem);
  border-radius: calc(var(--radius-3) + 2px);
  border: var(--border-w) solid color-mix(in srgb, var(--border) 92%, transparent);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0) 48%),
    color-mix(in srgb, var(--surface) 90%, transparent);
  box-shadow: var(--shadow-2);
}

.hero-panel::after {
  content: "";
  position: absolute;
  inset: auto -12% -26% auto;
  width: 220px;
  aspect-ratio: 1;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  filter: blur(8px);
}

.hero-panel--accent {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-2) 18%, transparent), transparent 50%),
    linear-gradient(160deg, color-mix(in srgb, var(--accent) 14%, var(--surface)) 0%, color-mix(in srgb, var(--surface) 88%, transparent) 65%);
}

.hero-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-3);
}

.hero-metric {
  padding: 1rem 1.05rem;
  border-radius: 18px;
  border: var(--border-w) solid color-mix(in srgb, var(--border) 88%, transparent);
  background: color-mix(in srgb, var(--bg-elev) 76%, transparent);
}

.hero-metric strong {
  display: block;
  font-size: var(--text-sm);
  letter-spacing: -0.01em;
}

.hero-metric span {
  display: block;
  margin-top: var(--space-2);
  color: var(--text-muted);
  font-size: var(--text-sm);
}

.section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  justify-content: space-between;
  gap: var(--space-4);
}

.spacer {
  height: var(--space-6);
}

@media (max-width: 640px) {
  .section { padding-block: var(--space-7); }
  .container { width: min(var(--container), calc(100% - (var(--space-4) * 2))); }
}

@media (max-width: 980px) {
  .hero-grid {
    grid-template-columns: 1fr;
  }
}

/* ------------------------------
   Navigation
------------------------------ */

.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--nav-bg);
  border-bottom: var(--border-w) solid var(--nav-border);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-block: var(--space-3);
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 800;
  letter-spacing: -0.02em;
  text-decoration: none;
}

.nav__brand::before {
  content: "";
  width: 0.9rem;
  height: 0.9rem;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent);
}

.nav__links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.nav__link {
  display: inline-flex;
  align-items: center;
  padding: 0.55rem 0.75rem;
  border-radius: 999px;
  text-decoration: none;
  color: var(--text-muted);
  transition: background var(--dur-2) var(--ease-out), color var(--dur-2) var(--ease-out);
}
.nav__link:hover {
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 80%, transparent);
}

.nav__link[aria-current="page"] {
  color: var(--text);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: var(--border-w) solid color-mix(in srgb, var(--accent) 22%, var(--border));
}

/* Optional: skip link for accessibility */
.skip-link {
  position: absolute;
  left: var(--space-4);
  top: var(--space-2);
  padding: 0.6rem 0.9rem;
  background: var(--surface);
  border: var(--border-w) solid var(--border);
  border-radius: 999px;
  box-shadow: var(--shadow-2);
  transform: translateY(-160%);
  transition: transform var(--dur-2) var(--ease-out);
  text-decoration: none;
  z-index: 100;
}
.skip-link:focus-visible {
  transform: translateY(0);
}

/* ------------------------------
   Typography
------------------------------ */

.h1,
h1 {
  font-size: clamp(2rem, 3.2vw, 2.7rem);
  line-height: var(--leading-tight);
  letter-spacing: -0.03em;
  margin: 0;
}

.h2,
h2 {
  font-size: clamp(1.5rem, 2.1vw, 2rem);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0;
}

h3 {
  font-size: 1.125rem;
  line-height: 1.35;
  margin: 0;
}

.kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.lead {
  font-size: var(--text-lg);
  color: var(--text-muted);
  max-width: 70ch;
}

.muted {
  color: var(--text-muted);
}

.note {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-top: var(--space-4);
  text-align: center;
}

.faint {
  color: var(--text-faint);
}

.center {
  text-align: center;
}

.prose {
  max-width: 75ch;
}

.prose :where(p, ul, ol) {
  margin-top: var(--space-4);
}

.prose :where(h1, h2, h3) {
  margin-top: var(--space-7);
}

.prose :where(h1 + p, h2 + p, h3 + p) {
  margin-top: var(--space-3);
}

.prose :where(a) {
  color: var(--accent);
  text-decoration-color: color-mix(in srgb, var(--accent) 55%, transparent);
}

.prose :where(code) {
  font-family: var(--font-mono);
  font-size: 0.95em;
  padding: 0.15em 0.35em;
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface-2) 80%, transparent);
  border: var(--border-w) solid var(--border);
}

.prose :where(pre) {
  margin-top: var(--space-5);
  padding: var(--space-4);
  border-radius: var(--radius-2);
  background: color-mix(in srgb, var(--surface-2) 82%, transparent);
  border: var(--border-w) solid var(--border);
  overflow: auto;
}

.prose :where(pre code) {
  padding: 0;
  border: 0;
  background: transparent;
}

/* ------------------------------
   Buttons
------------------------------ */

.btn {
  --btn-bg: var(--surface);
  --btn-fg: var(--text);
  --btn-bd: var(--border);
  --btn-shadow: none;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 0.85rem 1.05rem;
  border-radius: 18px;
  border: var(--border-w) solid var(--btn-bd);
  background: var(--btn-bg);
  color: var(--btn-fg);
  text-decoration: none;
  font-weight: 700;
  line-height: 1;
  box-shadow: var(--btn-shadow);
  transition:
    transform var(--dur-2) var(--ease-out),
    background var(--dur-2) var(--ease-out),
    border-color var(--dur-2) var(--ease-out),
    box-shadow var(--dur-2) var(--ease-out),
    filter var(--dur-2) var(--ease-out);
}

.btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-1);
}

.btn:active {
  transform: translateY(0);
}

.btn[aria-disabled="true"],
.btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.btn--primary {
  --btn-bg: var(--accent);
  --btn-fg: var(--accent-contrast);
  --btn-bd: color-mix(in srgb, var(--accent) 65%, #000 0%);
  --btn-shadow: 0 10px 30px color-mix(in srgb, var(--accent) 22%, transparent);
}
.btn--primary:hover {
  filter: brightness(0.98) saturate(1.02);
}

.btn--secondary {
  --btn-bg: color-mix(in srgb, var(--surface) 80%, var(--surface-2));
  --btn-fg: var(--text);
  --btn-bd: var(--border);
}
.btn--secondary:hover {
  background: color-mix(in srgb, var(--surface) 70%, var(--surface-2));
}

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--text-muted);
  --btn-bd: transparent;
  box-shadow: none;
}
.btn--ghost:hover {
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 70%, transparent);
  border-color: color-mix(in srgb, var(--border) 70%, transparent);
  box-shadow: none;
}

.btn--sm {
  padding: 0.6rem 0.85rem;
  font-size: var(--text-sm);
}

.btn--wide {
  width: 100%;
}

.btn--disabled,
a[aria-disabled="true"] {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
}

.btn--disabled {
  filter: grayscale(0.1);
}

/* ------------------------------
   Cards
------------------------------ */

.card {
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.32), rgba(255, 255, 255, 0) 52%),
    color-mix(in srgb, var(--surface) 92%, transparent);
  border: var(--border-w) solid color-mix(in srgb, var(--border) 92%, transparent);
  border-radius: calc(var(--radius-2) + 2px);
  box-shadow: var(--shadow-2);
  padding: var(--space-6);
}

.card--interactive {
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
}
.card--interactive:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}

.card__title {
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0;
}

.card__body {
  margin-top: var(--space-3);
  color: var(--text-muted);
}

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

.media-placeholder,
.video-placeholder {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-2);
  border: var(--border-w) dashed color-mix(in srgb, var(--border) 80%, transparent);
  background: color-mix(in srgb, var(--surface-2) 80%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
  text-align: center;
  color: var(--text-muted);
}

.media-placeholder__inner {
  display: grid;
  gap: var(--space-2);
}

.media-placeholder__inner strong {
  color: var(--text);
  font-size: var(--text-md);
}

.demo-embed {
  position: relative;
  width: 100%;
  height: clamp(360px, 70vh, 760px);
  border-radius: var(--radius-2);
  border: var(--border-w) solid var(--border);
  overflow: hidden;
  background: var(--surface-2);
  box-shadow: var(--shadow-1);
}

.demo-embed__frame {
  --demo-scale: 0.82;
  width: calc(100% / var(--demo-scale));
  height: calc(100% / var(--demo-scale));
  border: 0;
  display: block;
  transform: scale(var(--demo-scale));
  transform-origin: top left;
  pointer-events: none;
}

.demo-embed__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: var(--space-4);
  color: #ffffff;
  text-decoration: none;
  font-weight: 700;
  background: linear-gradient(180deg, rgba(12, 12, 12, 0) 55%, rgba(12, 12, 12, 0.6) 100%);
}

.demo-embed__overlay span {
  background: rgba(12, 12, 12, 0.7);
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  font-size: var(--text-sm);
}

.demo-embed--hero {
  height: clamp(420px, 78vh, 880px);
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.35rem 0.6rem;
  font-size: var(--text-xs);
  font-weight: 700;
  border-radius: 999px;
  border: var(--border-w) solid color-mix(in srgb, var(--accent) 22%, var(--border));
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--text);
}

/* ------------------------------
   Pricing
------------------------------ */

.price {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.price__amount {
  font-size: clamp(2rem, 3vw, 2.6rem);
  font-weight: 900;
  letter-spacing: -0.03em;
}

.price__period {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.list {
  margin-top: var(--space-4);
  color: var(--text-muted);
}
.list li {
  margin-top: var(--space-2);
}

.list--compact {
  margin-top: 0;
}

.list--compact li {
  margin-top: 0.6rem;
}

/* ------------------------------
   Blog
------------------------------ */

.blog-hero {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.blog-hero__image {
  width: 100%;
  border-radius: var(--radius-2);
  border: var(--border-w) solid var(--border);
  background: var(--surface-2);
  box-shadow: var(--shadow-1);
}

.blog-grid {
  --grid-min: 280px;
}

.blog-card {
  padding: 0;
  overflow: hidden;
}

.blog-card__link {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-5);
  text-decoration: none;
  color: inherit;
  height: 100%;
}

.blog-card__media {
  aspect-ratio: 16 / 9;
  border-radius: var(--radius-2);
  overflow: hidden;
  border: var(--border-w) solid var(--border);
  background: var(--surface-2);
}

.blog-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.blog-card__title {
  font-size: var(--text-lg);
  margin: 0;
}

.blog-card__cta {
  align-self: flex-start;
  padding-inline: 0.7rem;
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.tag {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.6rem;
  font-size: var(--text-xs);
  font-weight: 700;
  border-radius: 999px;
  border: var(--border-w) solid color-mix(in srgb, var(--accent) 18%, var(--border));
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--text);
  text-decoration: none;
  transition:
    background var(--dur-2) var(--ease-out),
    border-color var(--dur-2) var(--ease-out),
    color var(--dur-2) var(--ease-out);
}

.tag:hover {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 36%, var(--border));
}

.tag-filter {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  border-radius: var(--radius-2);
  border: var(--border-w) solid var(--border);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.tag-filter__title {
  font-size: var(--text-sm);
  font-weight: 800;
  color: var(--text);
}

.tag-filter__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.tag-filter__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.45rem 0.75rem;
  border-radius: 16px;
  border: var(--border-w) solid var(--border);
  background: color-mix(in srgb, var(--surface) 90%, transparent);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--text);
  transition: background var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out);
}

.tag-filter__btn:hover {
  background: color-mix(in srgb, var(--surface) 70%, transparent);
}

.tag-filter__btn[aria-pressed="true"] {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
  background: color-mix(in srgb, var(--accent) 18%, transparent);
}

.tag-filter__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.6em;
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 800;
  color: var(--text-muted);
  background: color-mix(in srgb, var(--surface-2) 70%, transparent);
}

/* ------------------------------
   FAQ (details / summary)
------------------------------ */

details {
  border-radius: var(--radius-2);
}

details.faq {
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  border: var(--border-w) solid var(--border);
  box-shadow: var(--shadow-1);
  padding: var(--space-4);
}

details.faq > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  font-weight: 800;
  color: var(--text);
  padding: var(--space-2) var(--space-2);
  border-radius: 12px;
  user-select: none;
  transition: background var(--dur-2) var(--ease-out);
}

details.faq > summary:hover {
  background: color-mix(in srgb, var(--surface-2) 65%, transparent);
}

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

details.faq > summary::marker {
  content: "";
}

details.faq > summary::after {
  content: "";
  width: 0.65rem;
  height: 0.65rem;
  border-right: 2px solid color-mix(in srgb, var(--text) 55%, transparent);
  border-bottom: 2px solid color-mix(in srgb, var(--text) 55%, transparent);
  transform: rotate(45deg);
  transition: transform var(--dur-2) var(--ease-out);
  flex: 0 0 auto;
  margin-right: var(--space-1);
}

details.faq[open] > summary::after {
  transform: rotate(-135deg);
}

details.faq[open] > summary {
  margin-bottom: var(--space-2);
}

details.faq > :not(summary) {
  padding: 0 var(--space-2) var(--space-2);
  color: var(--text-muted);
}

details.faq > :not(summary) :where(p) {
  margin-top: var(--space-3);
}

/* ------------------------------
   Forms (support page)
------------------------------ */

.form {
  display: grid;
  gap: var(--space-4);
}

.field {
  display: grid;
  gap: var(--space-2);
}

.label {
  font-size: var(--text-sm);
  font-weight: 800;
  color: var(--text);
}

.input,
.textarea,
.select {
  width: 100%;
  padding: 0.85rem 1rem;
  border-radius: 12px;
  border: var(--border-w) solid var(--border);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
  transition:
    border-color var(--dur-2) var(--ease-out),
    box-shadow var(--dur-2) var(--ease-out),
    background var(--dur-2) var(--ease-out);
}

.textarea {
  min-height: 140px;
  resize: vertical;
}

.input:focus,
.textarea:focus,
.select:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 55%, var(--border));
  box-shadow: 0 0 0 4px var(--ring);
}

.help {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.finder-group {
  display: grid;
  gap: var(--space-2);
}

.finder-shell {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.8fr);
  align-items: start;
}

.finder-main,
.finder-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.finder-sidebar .card {
  padding: var(--space-5);
}

.finder-panel {
  position: sticky;
  top: calc(72px + var(--space-4));
}

.finder-statusbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.surface-note {
  padding: 1rem 1.1rem;
  border-radius: 16px;
  border: var(--border-w) solid color-mix(in srgb, var(--border) 88%, transparent);
  background: color-mix(in srgb, var(--surface-2) 68%, transparent);
}

.choice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-2);
}

.choice {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.7rem 0.85rem;
  border-radius: 12px;
  border: var(--border-w) solid var(--border);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  color: var(--text);
}

.choice input {
  accent-color: color-mix(in srgb, var(--accent) 80%, white);
}

.table-wrap {
  overflow-x: auto;
  border-radius: var(--radius-2);
  border: var(--border-w) solid var(--border);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
}

.table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.table th,
.table td {
  padding: 0.9rem 1rem;
  border-bottom: var(--border-w) solid var(--border);
  vertical-align: top;
  text-align: left;
}

.table th {
  font-size: var(--text-sm);
  color: var(--text);
  background: color-mix(in srgb, var(--surface-2) 72%, transparent);
}

.table tbody tr:hover {
  background: color-mix(in srgb, var(--surface-2) 48%, transparent);
}

.status-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: 800;
  border: var(--border-w) solid var(--border);
}

.status-badge--published {
  background: color-mix(in srgb, #0ea5e9 18%, transparent);
  border-color: color-mix(in srgb, #0ea5e9 38%, var(--border));
}

.status-badge--draft {
  background: color-mix(in srgb, #94a3b8 18%, transparent);
  border-color: color-mix(in srgb, #94a3b8 38%, var(--border));
}

.status-badge--hold {
  background: color-mix(in srgb, #f59e0b 18%, transparent);
  border-color: color-mix(in srgb, #f59e0b 38%, var(--border));
}

.status-badge--excluded {
  background: color-mix(in srgb, #ef4444 18%, transparent);
  border-color: color-mix(in srgb, #ef4444 38%, var(--border));
}

@media (max-width: 980px) {
  .finder-shell {
    grid-template-columns: 1fr;
  }

  .finder-panel {
    position: static;
  }
}

/* ------------------------------
   Footer
------------------------------ */

.footer {
  padding-block: var(--space-7);
  border-top: var(--border-w) solid var(--border);
  background: color-mix(in srgb, var(--surface) 75%, transparent);
}

.footer__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer__links {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.footer__links a {
  text-decoration: none;
  color: var(--text-muted);
}
.footer__links a:hover {
  color: var(--text);
  text-decoration: underline;
  text-decoration-color: color-mix(in srgb, var(--accent) 55%, transparent);
}

/* ------------------------------
   Utilities
------------------------------ */

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

.divider {
  height: 1px;
  background: var(--border);
  margin: var(--space-6) 0;
}

/* ------------------------------
   Finder / Archive Extensions
------------------------------ */

.finder-mode {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.cluster--spread {
  width: 100%;
  justify-content: space-between;
}

.result-card {
  min-height: 100%;
  justify-content: flex-start;
}

.result-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.result-reason {
  padding-left: var(--space-3);
  border-left: 3px solid color-mix(in srgb, var(--accent) 42%, transparent);
}

.finder-group {
  padding: var(--space-4);
  border-radius: var(--radius-2);
  border: var(--border-w) solid color-mix(in srgb, var(--border) 92%, transparent);
  background: color-mix(in srgb, var(--surface) 88%, transparent);
}

.finder-group .help {
  margin-top: -0.2rem;
}

.surface-note {
  padding: var(--space-4);
  border-radius: var(--radius-2);
  border: var(--border-w) solid color-mix(in srgb, var(--accent) 20%, var(--border));
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--accent) 12%, var(--surface)),
    color-mix(in srgb, var(--accent-2) 10%, var(--surface))
  );
}

.card--interactive .pill {
  width: fit-content;
}

.choice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-2);
}

.choice {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  padding: 0.8rem 0.95rem;
  border-radius: 14px;
  border: var(--border-w) solid color-mix(in srgb, var(--border) 90%, transparent);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.choice input {
  margin-top: 0.2rem;
}

.table-wrap {
  overflow-x: auto;
}

.table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.table th,
.table td {
  padding: 0.9rem 0.8rem;
  border-bottom: var(--border-w) solid color-mix(in srgb, var(--border) 92%, transparent);
  vertical-align: top;
  text-align: left;
}

.table th {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

@media (max-width: 720px) {
  .cluster--spread,
  .result-meta {
    align-items: flex-start;
    flex-direction: column;
  }

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

/* ------------------------------
   Reference UI Override
   Main reference: Booking.com search results style
------------------------------ */

:root {
  color-scheme: light;
  --bg: #f5f7fa;
  --bg-elev: #ffffff;
  --surface: #ffffff;
  --surface-2: #f0f5fb;
  --surface-3: #e6eef8;
  --text: #1a1f36;
  --text-muted: #4d5b76;
  --text-faint: #73809a;
  --border: rgba(26, 31, 54, 0.12);
  --accent: #006ce4;
  --accent-2: #febb02;
  --accent-contrast: #ffffff;
  --ring: rgba(0, 108, 228, 0.18);
  --ring-strong: rgba(0, 108, 228, 0.36);
  --nav-bg: rgba(255, 255, 255, 0.96);
  --nav-border: rgba(26, 31, 54, 0.08);
  --shadow-1: 0 1px 2px rgba(16, 24, 40, 0.04), 0 1px 1px rgba(16, 24, 40, 0.03);
  --shadow-2: 0 8px 24px rgba(16, 24, 40, 0.06), 0 2px 8px rgba(16, 24, 40, 0.04);
  --shadow-3: 0 18px 50px rgba(16, 24, 40, 0.08), 0 6px 18px rgba(16, 24, 40, 0.05);
}

body {
  background: linear-gradient(180deg, #f7f9fc 0%, #f3f6fa 100%);
}

.section {
  padding-block: var(--space-7);
}

.section--alt {
  background: transparent;
  border-top: 0;
  border-bottom: 0;
}

.nav {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.nav__inner {
  padding-block: 0.95rem;
}

.nav__brand {
  font-size: 1.05rem;
  font-weight: 800;
  color: #003b95;
}

.nav__brand::before {
  width: 1rem;
  height: 1rem;
  border-radius: 10px;
  background: linear-gradient(135deg, #003b95 0%, #006ce4 100%);
  box-shadow: none;
}

.nav__link {
  border-radius: 10px;
  padding: 0.55rem 0.7rem;
  font-weight: 600;
}

.hero-panel,
.card {
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(26, 31, 54, 0.12);
  box-shadow: var(--shadow-1);
}

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

.hero-panel--accent {
  background: #ffffff;
}

.btn {
  border-radius: 10px;
}

.btn--primary {
  --btn-bg: #006ce4;
  --btn-fg: #ffffff;
  --btn-bd: #0060cc;
  --btn-shadow: none;
}

.btn--secondary {
  --btn-bg: #ffffff;
  --btn-fg: #1a1f36;
  --btn-bd: rgba(26, 31, 54, 0.16);
}

.tag,
.pill {
  border-radius: 8px;
  font-weight: 700;
}

.search-page {
  gap: 1.25rem;
}

.search-hero {
  display: grid;
  gap: 1rem;
  padding: 1.25rem;
  border-top: 4px solid #febb02;
}

.search-hero__intro {
  gap: 0.55rem;
}

.search-toolbar {
  display: grid;
  gap: 0.9rem;
  grid-template-columns: minmax(0, 1.8fr) minmax(150px, 0.8fr) minmax(220px, 1fr) auto;
  align-items: end;
}

.search-toolbar__actions {
  display: flex;
  gap: 0.65rem;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.segmented-control {
  display: inline-flex;
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(26, 31, 54, 0.12);
  background: #ffffff;
  overflow: hidden;
}

.segmented-control__btn {
  flex: 1 1 0;
  border: 0;
  background: transparent;
  padding: 0.82rem 0.9rem;
  font-weight: 700;
  color: var(--text-muted);
}

.segmented-control__btn[aria-pressed="true"] {
  background: rgba(0, 108, 228, 0.08);
  color: #003b95;
}

.finder-shell--reference {
  display: grid;
  gap: 1rem;
  grid-template-columns: 300px minmax(0, 1fr);
}

.finder-sidebar--left {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  order: 1;
}

.finder-main {
  order: 2;
  gap: 1rem;
}

.finder-filter-card {
  padding: 1rem;
}

.finder-panel {
  position: static;
}

.finder-group {
  gap: 0.65rem;
  padding: 0;
  border: 0;
  background: transparent;
}

.tag-filter__list {
  flex-direction: column;
}

.tag-filter__btn--row {
  width: 100%;
  justify-content: space-between;
  align-items: center;
  border-radius: 10px;
  padding: 0.72rem 0.82rem;
  background: #ffffff;
}

.tag-filter__btn--row[aria-pressed="true"] {
  background: rgba(0, 108, 228, 0.08);
  border-color: rgba(0, 108, 228, 0.4);
  color: #003b95;
}

.tag-filter__btn--row .tag-filter__count {
  background: #eef4fb;
  color: #46526a;
}

.results-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
}

.results-head__main {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.results-head__links {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.active-filter-list {
  gap: 0.55rem;
}

.active-filter-list .tag-filter__btn {
  border-radius: 999px;
  padding: 0.45rem 0.75rem;
  background: #ffffff;
}

.result-list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.result-card {
  text-decoration: none;
  color: inherit;
}

.result-card--list {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 150px;
  gap: 1rem;
  padding: 1rem;
  align-items: stretch;
}

.result-card--compact {
  padding: 1rem;
}

.result-card__media {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.55rem;
  min-height: 180px;
  padding: 1rem;
  border-radius: 12px;
  background:
    linear-gradient(180deg, rgba(0, 59, 149, 0.04), rgba(0, 108, 228, 0.14)),
    linear-gradient(135deg, #eef5ff 0%, #dcecff 100%);
  border: 1px solid rgba(0, 108, 228, 0.14);
}

.result-card__media-type {
  display: inline-flex;
  width: fit-content;
  padding: 0.35rem 0.55rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  font-size: 0.78rem;
  font-weight: 700;
  color: #003b95;
}

.result-card__media-title {
  font-size: 1rem;
  color: #003b95;
}

.result-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  min-width: 0;
}

.result-card__title {
  margin: 0;
  font-size: 1.3rem;
  line-height: 1.25;
  color: #003b95;
}

.result-card__side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.75rem;
  min-width: 0;
}

.result-card__side-meta {
  text-align: right;
}

.result-meta {
  justify-content: flex-start;
}

.result-reason {
  padding: 0.7rem 0.8rem;
  border-left: 0;
  border-radius: 10px;
  background: #f5f8fc;
}

.finder-statusbar {
  justify-content: flex-start;
}

.input,
.textarea,
.select {
  border-radius: 10px;
  background: #ffffff;
}

.table {
  min-width: 780px;
}

@media (max-width: 1080px) {
  .search-toolbar {
    grid-template-columns: 1fr 1fr;
  }

  .search-toolbar__actions {
    justify-content: flex-start;
  }

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

  .finder-sidebar--left,
  .finder-main {
    order: initial;
  }

  .result-card--list {
    grid-template-columns: 1fr;
  }

  .result-card__side {
    align-items: flex-start;
  }

  .result-card__side-meta {
    text-align: left;
  }
}

@media (max-width: 720px) {
  .search-toolbar {
    grid-template-columns: 1fr;
  }

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

  .result-card__media {
    min-height: 120px;
  }
}

/* ------------------------------
   Reference Expansion
   Extend the Booking-inspired language across the whole site
------------------------------ */

.landing-hero {
  padding-block: 1.5rem 2.5rem;
  background:
    linear-gradient(180deg, #003b95 0%, #0057b8 58%, #f5f7fa 58%, #f5f7fa 100%);
}

.landing-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.95fr);
  gap: 1.25rem;
  align-items: start;
}

.landing-hero__content {
  display: grid;
  gap: 0.8rem;
  padding: 0.75rem 0;
  color: #ffffff;
}

.landing-hero__eyebrow {
  margin: 0;
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.84);
}

.landing-hero__title {
  margin: 0;
  max-width: 14ch;
  font-size: clamp(2.35rem, 5vw, 4rem);
  line-height: 1.05;
  letter-spacing: -0.05em;
}

.landing-hero__lead,
.landing-hero__sub {
  margin: 0;
  max-width: 60ch;
  color: rgba(255, 255, 255, 0.9);
}

.landing-search {
  display: grid;
  gap: 1rem;
  padding: 0.95rem;
  border-radius: 16px;
  border: 3px solid #febb02;
  background: #ffffff;
  box-shadow: 0 12px 32px rgba(0, 59, 149, 0.14);
}

.landing-search__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.9rem;
  align-items: end;
}

.landing-search__field {
  display: grid;
  gap: 0.45rem;
}

.landing-search__input {
  min-height: 52px;
  font-size: 1rem;
}

.landing-search__submit {
  min-height: 52px;
  padding-inline: 1.25rem;
}

.landing-search__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.landing-search__chips .tag {
  background: #f5f8fc;
  border-color: rgba(0, 108, 228, 0.16);
}

.trust-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.trust-strip__item {
  display: grid;
  gap: 0.35rem;
  padding: 1rem 1.05rem;
  border-radius: 14px;
  border: 1px solid rgba(26, 31, 54, 0.1);
  background: #ffffff;
  box-shadow: var(--shadow-1);
}

.trust-strip__item strong {
  color: #003b95;
}

.booking-page-header {
  display: grid;
  gap: 0.45rem;
  padding: 1.35rem;
  border-top: 4px solid #febb02;
}

.booking-page-header .h1,
.booking-page-header .h2 {
  margin: 0;
}

.booking-page-header .muted,
.booking-page-header .lead {
  max-width: 72ch;
}

.booking-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.booking-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.booking-two-column {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.8fr);
  gap: 1rem;
  align-items: start;
}

.booking-aside {
  display: grid;
  gap: 1rem;
}

.booking-sticky-card {
  position: sticky;
  top: calc(72px + 1rem);
  border-top: 4px solid #febb02;
}

.booking-detail-page {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.78fr);
  gap: 1rem;
  align-items: start;
}

.booking-detail-main,
.booking-detail-side {
  display: grid;
  gap: 1rem;
}

.booking-detail-header {
  gap: 0.75rem;
  padding: 1.25rem;
  border-top: 4px solid #febb02;
}

.booking-detail-header .lead {
  margin: 0;
}

.booking-detail-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.booking-detail-main > .card,
.booking-aside > .card,
.booking-detail-side > .card {
  padding: 1.15rem;
}

.result-list--cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.result-list--cards > .card {
  min-height: 100%;
}

.collection-card--compact,
.collection-card--list {
  color: inherit;
  text-decoration: none;
}

.collection-card--compact {
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
}

.collection-card--list {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  padding: 1rem;
}

.collection-card__body {
  display: grid;
  gap: 0.7rem;
}

.collection-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.collection-card__side {
  display: grid;
  justify-items: end;
  gap: 0.6rem;
}

.collection-card__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  background: #f0f5fb;
  color: #003b95;
  font-weight: 800;
  font-size: 0.82rem;
}

.result-card--compact {
  display: grid;
  gap: 0.8rem;
  align-content: start;
  min-height: 100%;
}

.result-card--compact .result-meta {
  gap: 0.45rem;
}

.result-card--compact .tag-list {
  margin-top: auto;
}

.result-card:hover,
.collection-card--compact:hover,
.collection-card--list:hover,
.card--interactive:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-2);
}

[data-article-search] {
  padding: 1.2rem;
}

[data-article-search] .tag-filter__list {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  gap: 0.55rem;
}

[data-article-search] .tag-filter__btn {
  border-radius: 999px;
  background: #ffffff;
}

[data-search-results] {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

[data-search-results] > * {
  min-height: 100%;
}

@media (max-width: 1080px) {
  .landing-hero__inner,
  .booking-two-column,
  .booking-detail-page {
    grid-template-columns: 1fr;
  }

  .booking-sticky-card {
    position: static;
  }

  .booking-info-grid,
  .booking-feature-grid {
    grid-template-columns: 1fr 1fr;
  }

  .trust-strip {
    grid-template-columns: 1fr;
  }

  .collection-card--list {
    grid-template-columns: 1fr;
  }

  .collection-card__side {
    justify-items: start;
  }
}

@media (max-width: 720px) {
  .landing-hero {
    padding-block: 1rem 2rem;
    background:
      linear-gradient(180deg, #003b95 0%, #0057b8 68%, #f5f7fa 68%, #f5f7fa 100%);
  }

  .landing-search__row,
  .booking-detail-info-grid,
  .booking-info-grid,
  .booking-feature-grid,
  .result-list--cards,
  [data-search-results] {
    grid-template-columns: 1fr;
  }

  .landing-hero__title {
    max-width: none;
  }
}

/* ------------------------------
   Finder Experience Override
   Inspired by Google Flights / Airbnb / Steam search surfaces
------------------------------ */

:root,
:root[data-theme="dark"] {
  color-scheme: dark;
  --bg: #07111f;
  --bg-elev: #0c1729;
  --surface: #101b31;
  --surface-2: #152440;
  --surface-3: #1b2c4c;
  --text: #f2f6ff;
  --text-muted: #9eb1d0;
  --text-faint: #6f86ab;
  --border: rgba(183, 206, 255, 0.12);
  --accent: #7cc0ff;
  --accent-2: #ffb357;
  --accent-contrast: #08111f;
  --ring: rgba(124, 192, 255, 0.24);
  --ring-strong: rgba(124, 192, 255, 0.42);
  --nav-bg: rgba(7, 17, 31, 0.82);
  --nav-border: rgba(183, 206, 255, 0.08);
  --shadow-1: 0 1px 2px rgba(0, 0, 0, 0.46);
  --shadow-2: 0 18px 40px rgba(0, 0, 0, 0.34);
  --shadow-3: 0 24px 64px rgba(0, 0, 0, 0.45);
}

body {
  background:
    radial-gradient(circle at top left, rgba(26, 76, 146, 0.32), transparent 36%),
    radial-gradient(circle at top right, rgba(255, 179, 87, 0.12), transparent 28%),
    linear-gradient(180deg, #07111f 0%, #0a1425 46%, #0b162a 100%);
  color: var(--text);
}

.nav {
  background: var(--nav-bg);
  border-bottom-color: var(--nav-border);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.nav__brand {
  color: #f8fbff;
}

.nav__brand::before {
  background: linear-gradient(135deg, #7cc0ff 0%, #ffb357 100%);
}

.nav__link {
  color: var(--text-muted);
}

.nav__link:hover,
.nav__link[aria-current="page"] {
  background: rgba(124, 192, 255, 0.12);
  color: #ffffff;
}

.hero-panel,
.card,
.table-wrap {
  background: linear-gradient(180deg, rgba(19, 30, 54, 0.98), rgba(14, 24, 44, 0.98));
  border-color: var(--border);
  box-shadow: var(--shadow-1);
}

.footer {
  background: rgba(7, 17, 31, 0.92);
  border-top-color: rgba(183, 206, 255, 0.08);
}

.footer__links a {
  color: var(--text-muted);
}

.btn {
  border-radius: 12px;
}

.btn--primary {
  --btn-bg: #7cc0ff;
  --btn-fg: #07111f;
  --btn-bd: #6bb5fb;
}

.btn--secondary {
  --btn-bg: rgba(124, 192, 255, 0.08);
  --btn-fg: #ecf5ff;
  --btn-bd: rgba(124, 192, 255, 0.18);
}

.btn--ghost {
  --btn-fg: var(--text-muted);
}

.input,
.textarea,
.select {
  background: rgba(9, 17, 31, 0.72);
  color: var(--text);
  border-color: rgba(183, 206, 255, 0.12);
}

.tag,
.pill,
.tag-filter__btn {
  background: rgba(124, 192, 255, 0.08);
  border-color: rgba(124, 192, 255, 0.18);
  color: #ebf5ff;
}

.tag--search-shortcut {
  background: rgba(255, 179, 87, 0.08);
  border-color: rgba(255, 179, 87, 0.18);
}

.landing-hero {
  background:
    radial-gradient(circle at left top, rgba(124, 192, 255, 0.24), transparent 34%),
    radial-gradient(circle at right top, rgba(255, 179, 87, 0.15), transparent 28%),
    linear-gradient(180deg, #07111f 0%, #091525 76%, rgba(7, 17, 31, 0) 100%);
}

.landing-search {
  background: linear-gradient(180deg, rgba(13, 22, 39, 0.96), rgba(11, 19, 35, 0.96));
  border-color: rgba(255, 179, 87, 0.72);
}

.landing-search__chips .tag {
  background: rgba(124, 192, 255, 0.08);
}

.trust-strip__item {
  background: linear-gradient(180deg, rgba(19, 30, 54, 0.98), rgba(13, 22, 39, 0.98));
  border-color: var(--border);
}

.quick-dashboard {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.finder-mini-list {
  display: grid;
  gap: 0.75rem;
}

.finder-mini-link {
  display: block;
  padding: 0.9rem 1rem;
  border-radius: 14px;
  border: 1px solid rgba(183, 206, 255, 0.12);
  background: rgba(124, 192, 255, 0.05);
  color: inherit;
  text-decoration: none;
}

.finder-mini-link--saved {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: center;
}

.finder-mini-link--button {
  display: block;
}

.finder-mini-link__body {
  display: grid;
  gap: 0.25rem;
}

.finder-experience {
  gap: 1.5rem;
}

.finder-command {
  display: grid;
  gap: 1.2rem;
  padding: 1.4rem;
  border-top: 1px solid rgba(255, 179, 87, 0.5);
}

.finder-command__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(220px, 0.8fr) minmax(220px, 0.8fr);
  gap: 0.9rem;
  align-items: end;
}

.finder-command__field {
  display: grid;
  gap: 0.45rem;
}

.finder-command__field--wide {
  grid-column: span 1;
}

.finder-command__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.finder-preset-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.finder-preset-strip__block {
  gap: 0.55rem;
}

.finder-layout-v2 {
  display: grid;
  grid-template-columns: minmax(310px, 0.86fr) minmax(0, 1.35fr);
  gap: 1rem;
  align-items: start;
}

.finder-sidebar-v2,
.finder-results-v2 {
  display: grid;
  gap: 1rem;
}

.finder-panel-v2 {
  padding: 1.15rem;
}

.finder-group-v2 {
  gap: 0.75rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(183, 206, 255, 0.08);
}

.finder-group-v2:first-child {
  border-top: 0;
  padding-top: 0;
}

.finder-tag-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: center;
  padding: 0.8rem 0.9rem;
  border-radius: 14px;
  border: 1px solid rgba(183, 206, 255, 0.08);
  background: rgba(255, 255, 255, 0.02);
}

.finder-tag-row--include {
  border-color: rgba(124, 192, 255, 0.28);
  background: rgba(124, 192, 255, 0.08);
}

.finder-tag-row--exclude {
  border-color: rgba(255, 120, 120, 0.22);
  background: rgba(255, 120, 120, 0.06);
}

.finder-tag-row__info {
  display: grid;
  gap: 0.2rem;
}

.finder-tag-row__controls {
  display: inline-flex;
  gap: 0.4rem;
}

.finder-state-btn {
  min-width: 64px;
  padding: 0.5rem 0.65rem;
  border-radius: 10px;
  border: 1px solid rgba(183, 206, 255, 0.12);
  background: rgba(7, 17, 31, 0.54);
  color: var(--text-muted);
  font-weight: 700;
}

.finder-state-btn[aria-pressed="true"] {
  background: rgba(124, 192, 255, 0.18);
  color: #ffffff;
  border-color: rgba(124, 192, 255, 0.38);
}

.finder-state-btn--exclude[aria-pressed="true"] {
  background: rgba(255, 120, 120, 0.16);
  border-color: rgba(255, 120, 120, 0.32);
}

.finder-state-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.segmented-control--finder {
  background: rgba(7, 17, 31, 0.64);
  border-color: rgba(183, 206, 255, 0.12);
}

.finder-summary-bar {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 1rem;
  align-items: start;
  padding: 1.2rem;
  position: sticky;
  top: calc(72px + 1rem);
  z-index: 8;
}

.finder-summary-bar__aside {
  justify-items: start;
}

.finder-empty-state {
  padding: 1.2rem;
}

.finder-relax-list {
  display: grid;
  gap: 0.75rem;
}

.finder-relax-item {
  display: grid;
  gap: 0.35rem;
  padding: 0.85rem 0.95rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 179, 87, 0.16);
  background: rgba(255, 179, 87, 0.05);
}

.finder-relax-btn {
  width: fit-content;
  padding: 0.6rem 0.8rem;
  border-radius: 10px;
  border: 1px solid rgba(255, 179, 87, 0.28);
  background: rgba(255, 179, 87, 0.12);
  color: #fff1de;
  font-weight: 700;
}

.compare-dock {
  padding: 1.2rem;
}

.finder-compare-items {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.compare-pill {
  display: grid;
  gap: 0.4rem;
  min-width: 220px;
  padding: 0.85rem 0.95rem;
  border-radius: 14px;
  border: 1px solid rgba(183, 206, 255, 0.12);
  background: rgba(124, 192, 255, 0.06);
}

.finder-compare-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
}

.compare-column {
  padding: 1rem;
}

.result-list--finder {
  display: grid;
  gap: 1rem;
}

.work-card {
  display: grid;
  gap: 0.9rem;
  padding: 1rem 1.05rem;
  border-radius: 18px;
}

.work-card__body {
  display: grid;
  gap: 0.75rem;
}

.work-card__header,
.work-card__meta,
.work-card__footer,
.work-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
}

.work-card__meta {
  color: var(--text-faint);
}

.work-card__title {
  margin: 0;
  color: #f7fbff;
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1.2;
  text-decoration: none;
}

.work-card__title:hover {
  color: var(--accent);
}

.work-card__reason {
  margin: 0;
  padding: 0.8rem 0.95rem;
  border-radius: 14px;
  background: rgba(124, 192, 255, 0.08);
  border: 1px solid rgba(124, 192, 255, 0.14);
  color: #e8f4ff;
}

.work-card__footer {
  justify-content: space-between;
  margin-top: auto;
}

.work-card__footer--solo {
  justify-content: flex-end;
}

/*
   =========================================================
   Site Shell Polish
   ========================================================= */

.nav__utility {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-left: auto;
}

.nav__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5rem;
  padding: 0.65rem 0.9rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.nav__cta:hover {
  transform: translateY(-1px);
}

.nav__cta--primary {
  color: #04101d;
  background: linear-gradient(135deg, #8cd4ff 0%, #5fb5ff 100%);
  box-shadow: 0 14px 28px rgba(28, 118, 183, 0.22);
}

.nav__cta--secondary {
  color: var(--text-muted);
  border: 1px solid rgba(183, 206, 255, 0.12);
  background: rgba(9, 18, 31, 0.76);
}

.footer__inner {
  display: grid;
  gap: 1.5rem;
}

.footer__lead {
  display: grid;
  gap: 1rem;
  padding: 1.25rem 1.35rem;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(10, 22, 38, 0.96) 0%, rgba(17, 32, 52, 0.94) 100%);
  border: 1px solid rgba(183, 206, 255, 0.1);
}

.footer__eyebrow {
  margin: 0;
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.footer__lead-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

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

.footer__column {
  display: grid;
  gap: 0.75rem;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  background: rgba(9, 18, 31, 0.7);
  border: 1px solid rgba(183, 206, 255, 0.08);
}

.footer__column-title {
  margin: 0;
  font-size: 0.95rem;
  color: #f4f8ff;
}

.footer__column-links {
  display: grid;
  gap: 0.55rem;
}

.footer__column-links a {
  color: var(--text-muted);
  text-decoration: none;
}

.footer__column-links a:hover {
  color: var(--accent);
}

.footer__bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.9rem;
  align-items: center;
}

.page-hero {
  position: relative;
  overflow: hidden;
  padding: clamp(1.35rem, 3vw, 2rem);
  border-radius: 24px;
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top right, rgba(124, 192, 255, 0.16), transparent 34%),
    linear-gradient(160deg, rgba(10, 21, 36, 0.98) 0%, rgba(15, 28, 45, 0.94) 100%);
  pointer-events: none;
}

.page-hero > * {
  position: relative;
  z-index: 1;
}

.page-hero--guide::before {
  background:
    radial-gradient(circle at top right, rgba(251, 191, 36, 0.17), transparent 34%),
    linear-gradient(160deg, rgba(10, 21, 36, 0.98) 0%, rgba(15, 28, 45, 0.94) 100%);
}

.page-hero--article::before {
  background:
    radial-gradient(circle at top right, rgba(156, 178, 255, 0.18), transparent 34%),
    linear-gradient(160deg, rgba(10, 21, 36, 0.98) 0%, rgba(15, 28, 45, 0.94) 100%);
}

.page-hero--support::before {
  background:
    radial-gradient(circle at top right, rgba(96, 211, 177, 0.16), transparent 34%),
    linear-gradient(160deg, rgba(10, 21, 36, 0.98) 0%, rgba(15, 28, 45, 0.94) 100%);
}

.page-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(280px, 0.9fr);
  gap: 1.25rem;
  align-items: start;
}

.page-layout--guide-hub {
  grid-template-columns: minmax(0, 1.55fr) minmax(290px, 0.85fr);
}

.page-main,
.page-rail,
.guide-detail-main,
.guide-detail-aside {
  min-width: 0;
}

.page-rail {
  display: grid;
  gap: 1rem;
}

.apply-form__actions {
  display: flex;
  justify-content: flex-start;
}

.apply-form__actions .btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.apply-field-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.apply-work-list {
  display: grid;
  gap: 1rem;
}

.apply-work-item {
  display: grid;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid #dfdfdf;
  border-radius: 18px;
  background: #fafafa;
}

.apply-work-item__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.apply-work-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.apply-add-button,
.apply-remove-button {
  flex: 0 0 auto;
}

.rail-card {
  padding: 1.15rem 1.2rem;
}

.contact-simple-page {
  background: linear-gradient(180deg, #f4f7fb 0%, #eef2f6 100%);
}

.contact-simple-shell {
  width: min(720px, 100%);
  margin: 0 auto;
  padding: clamp(0.75rem, 2vw, 1.5rem) 0 clamp(2.5rem, 5vw, 4rem);
  display: grid;
  gap: 1rem;
}

.contact-simple-card {
  display: grid;
  gap: 1.15rem;
  padding: clamp(1.25rem, 2.8vw, 1.8rem);
  border-radius: 28px;
  background: #ffffff;
  border: 1px solid rgba(222, 229, 238, 0.96);
  box-shadow: 0 24px 60px rgba(45, 63, 92, 0.08);
}

.contact-simple-header {
  display: flex;
  align-items: flex-start;
  gap: 0.95rem;
}

.contact-simple-header__icon {
  width: 48px;
  height: 48px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: #eef3f8;
  color: #5f7088;
  font-size: 1rem;
  font-weight: 800;
}

.contact-simple-header__body {
  display: grid;
  gap: 0.35rem;
}

.contact-simple-header__eyebrow {
  margin: 0;
  color: #6a7b91;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contact-simple-header__body .h2 {
  margin: 0;
  font-size: clamp(1.45rem, 2.6vw, 1.8rem);
}

.contact-simple-header__body .muted {
  margin: 0;
  line-height: 1.7;
}

.contact-simple-note {
  display: grid;
  gap: 0.45rem;
  padding: 1rem 1.05rem;
  border-radius: 18px;
  border: 1px solid #e8edf4;
  background: #fafbfd;
}

.contact-simple-note p {
  margin: 0;
  line-height: 1.7;
}

.contact-simple-form {
  display: grid;
  gap: 0.95rem;
}

.contact-simple-form__field {
  display: grid;
  gap: 0.42rem;
}

.contact-simple-form__field span {
  color: #273244;
  font-size: 0.92rem;
  font-weight: 800;
}

.contact-simple-form__field input,
.contact-simple-form__field select,
.contact-simple-form__field textarea {
  width: 100%;
  border: 1px solid #e5eaf1;
  border-radius: 14px;
  background: #fbfcfe;
  color: #243042;
  font: inherit;
}

.contact-simple-form__field input,
.contact-simple-form__field select {
  min-height: 50px;
  padding: 0 0.95rem;
}

.contact-simple-form__field textarea {
  min-height: 240px;
  padding: 0.95rem;
  resize: vertical;
}

.contact-simple-form__field input::placeholder,
.contact-simple-form__field textarea::placeholder {
  color: #9aa7b8;
}

.contact-simple-form__hint {
  margin: 0;
  color: #66758a;
  font-size: 0.84rem;
  line-height: 1.7;
}

.contact-simple-submit {
  min-height: 54px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #ffb8c4, #f99db1);
  color: #ffffff;
  font: inherit;
  font-size: 0.98rem;
  font-weight: 800;
  cursor: pointer;
}

.contact-simple-submit:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.contact-simple-form__status {
  margin: 0;
  padding: 0.9rem 1rem;
  border-radius: 14px;
  font-size: 0.9rem;
  line-height: 1.7;
}

.contact-simple-form__status[data-state="success"] {
  background: #eef8f0;
  border: 1px solid #cfe7d5;
  color: #275936;
}

.contact-simple-form__status[data-state="error"] {
  background: #fff4f4;
  border: 1px solid #f1d0d0;
  color: #8a2b2b;
}

.contact-simple-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.7rem;
}

.contact-simple-links a {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(223, 229, 238, 0.96);
  color: #55657b;
  text-decoration: none;
  font-size: 0.84rem;
  font-weight: 700;
}

.contact-simple-links a:hover {
  background: #ffffff;
}

.guide-search-panel {
  padding: 1.2rem;
}

.guide-results-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.guide-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(290px, 0.85fr);
  gap: 1.25rem;
  align-items: start;
}

.guide-detail-aside {
  position: relative;
}

.guide-callout,
.guide-article-card,
.guide-action-row {
  width: 100%;
}

.guide-hero-media {
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(233, 226, 214, 0.92), rgba(249, 245, 238, 0.96));
}

.guide-hero-media__frame {
  overflow: hidden;
  border-radius: 20px;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #dfd4c2, #f6f0e8);
}

.guide-hero-media__frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.guide-hero-media__caption {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: space-between;
  align-items: center;
}

.guide-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.guide-feature-card {
  display: grid;
  gap: 0.45rem;
  padding: 1rem 1.05rem;
  border-radius: 18px;
  border: 1px solid var(--retail-line);
  background: rgba(255, 255, 255, 0.82);
}

.guide-inline-note {
  padding: 1rem 1.1rem;
  border-left: 4px solid var(--accent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--accent) 10%, #ffffff);
}

.guide-article-figure {
  display: grid;
  gap: 0.75rem;
  margin: 0;
}

.guide-article-figure img {
  width: 100%;
  border-radius: 20px;
  border: 1px solid var(--retail-line);
  background: #f5efe6;
}

.guide-article-figure figcaption {
  color: var(--retail-muted);
  font-size: 0.95rem;
}

.guide-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.15rem;
}

.guide-faq-stack {
  display: grid;
  gap: 0.8rem;
}

.article-meta-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}

.guide-related-list {
  display: grid;
  gap: 0.75rem;
}

.guide-mini-link {
  display: grid;
  gap: 0.3rem;
  padding: 0.85rem 0.95rem;
  border-radius: 16px;
  color: #f4f8ff;
  text-decoration: none;
  background: rgba(9, 18, 31, 0.72);
  border: 1px solid rgba(183, 206, 255, 0.08);
  transition: transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.guide-mini-link:hover {
  transform: translateY(-1px);
  border-color: rgba(124, 192, 255, 0.26);
  background: rgba(11, 23, 39, 0.9);
}

.guide-mini-link strong {
  color: #f9fbff;
}

@media (max-width: 1120px) {
  .nav__inner {
    gap: 0.9rem;
  }

  .nav__utility {
    width: 100%;
    justify-content: flex-end;
  }

  .page-layout,
  .page-layout--guide-hub,
  .guide-detail-layout,
  .landing-hero__inner,
  .booking-two-column,
  .booking-detail-page,
  .apply-work-grid {
    grid-template-columns: 1fr;
  }

  .guide-results-grid,
  .footer__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .nav__utility {
    justify-content: stretch;
  }

  .nav__cta {
    flex: 1 1 0;
  }

  .footer__bottom,
  .guide-action-row {
    flex-direction: column;
    align-items: stretch;
  }

  .guide-results-grid {
    grid-template-columns: 1fr;
  }
}

/*
   =========================================================
   Retail Shell Override
   ========================================================= */

html,
body {
  background: #ffffff;
  color: #111111;
}

body {
  font-family: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
}

.container {
  max-width: 1440px;
}

.section,
.section--alt,
.section--tight,
.footer {
  background: #ffffff;
}

.muted,
.help {
  color: #484848;
}

.card,
.booking-page-header,
.booking-detail-header,
.booking-sticky-card,
.finder-command,
.finder-panel-v2,
.finder-summary-bar,
.compare-dock,
.finder-empty-state,
.page-hero,
.rail-card,
.guide-search-panel {
  background: #ffffff;
  color: #111111;
  border: 1px solid #dfdfdf;
  box-shadow: none;
}

.card a:not(.btn),
.collection-card__title,
.work-card__title {
  color: #111111;
}

.btn {
  border-radius: 999px;
  font-weight: 700;
}

.btn--primary {
  background: #111111;
  color: #ffffff;
  border: 1px solid #111111;
}

.btn--secondary,
.btn--ghost {
  background: #ffffff;
  color: #111111;
  border: 1px solid #111111;
}

.tag,
.pill {
  background: #f5f5f5;
  color: #111111;
  border: 1px solid #d9d9d9;
}

.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #ffffff;
  border-bottom: 1px solid #dfdfdf;
}

.nav__inner {
  display: grid;
  gap: 0.75rem;
  padding-block: 0.75rem 1rem;
}

.nav__topbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid #ededed;
  font-size: 0.9rem;
}

.nav__topbar-links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.nav__topbar-links a {
  color: #484848;
  text-decoration: none;
}

.nav__topbar-links a:hover {
  color: #111111;
}

.nav__main {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  color: #111111;
  text-decoration: none;
  font-weight: 800;
  font-size: 1rem;
}

.nav__brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.6rem;
  height: 2.1rem;
  border-radius: 999px;
  background: #0058a3;
  color: #fbd914;
  font-size: 0.85rem;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.nav__brand-text {
  line-height: 1.1;
}

.nav__search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
}

.nav__search-input {
  width: 100%;
  min-height: 3rem;
  padding: 0.8rem 1rem;
  border-radius: 999px;
  border: 1px solid #d9d9d9;
  background: #f5f5f5;
  color: #111111;
}

.nav__search-button {
  min-width: 5.5rem;
  min-height: 3rem;
  border-radius: 999px;
  border: 1px solid #111111;
  background: #111111;
  color: #ffffff;
  font-weight: 700;
}

.nav__utility {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.nav__cta--primary {
  background: #111111;
  color: #ffffff;
  box-shadow: none;
}

.nav__cta--secondary {
  background: #ffffff;
  color: #111111;
  border: 1px solid #111111;
}

.nav__links,
.nav__categories {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.nav__link,
.nav__category-link {
  color: #111111;
  text-decoration: none;
  font-weight: 700;
}

.nav__link[aria-current="page"] {
  text-decoration: underline;
  text-underline-offset: 0.28em;
}

.nav__category-link {
  padding: 0.2rem 0;
  color: #484848;
  font-weight: 600;
}

.nav__category-link:hover {
  color: #111111;
}

.nav__promo {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  padding: 0.9rem 1rem;
  border-radius: 18px;
  background: #fbd914;
}

.nav__promo-text {
  margin: 0;
  color: #111111;
  font-weight: 700;
}

.nav__promo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.nav__promo-link {
  color: #111111;
  font-weight: 700;
  text-decoration: none;
}

.nav__promo-link--secondary {
  color: #0058a3;
}

.footer {
  border-top: 1px solid #dfdfdf;
}

.footer__lead,
.footer__column {
  background: #ffffff;
  border: 1px solid #dfdfdf;
}

.footer__eyebrow {
  color: #0058a3;
}

.footer__column-title,
.guide-mini-link strong {
  color: #111111;
}

.footer__column-links a,
.guide-mini-link,
.finder-mini-link {
  color: #484848;
}

.catalog-hero {
  padding: 1.5rem 0 2rem;
}

.catalog-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(340px, 0.9fr);
  gap: 1rem;
}

.catalog-promo {
  border-radius: 22px;
  padding: 1.4rem;
  border: 1px solid #dfdfdf;
}

.catalog-promo--primary {
  min-height: 26rem;
  justify-content: end;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.1), rgba(255,255,255,0.1)),
    linear-gradient(135deg, #f7f7f7 0%, #e7eef9 100%);
}

.catalog-promo--secondary,
.catalog-promo--tertiary {
  background: #f5f5f5;
}

.catalog-promo-stack {
  display: grid;
  gap: 1rem;
}

.catalog-promo__eyebrow {
  margin: 0;
  color: #0058a3;
  font-size: 0.9rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.catalog-promo__title {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1.05;
}

.catalog-promo__lead,
.catalog-promo__sub {
  margin: 0;
  max-width: 54rem;
  font-size: 1.05rem;
  color: #333333;
}

.catalog-promo__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.catalog-search-panel {
  max-width: 46rem;
}

.catalog-search-panel__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
}

.catalog-search-panel__input {
  min-height: 3.4rem;
  border-radius: 999px;
  border: 1px solid #d1d1d1;
  padding: 0.9rem 1.1rem;
  background: #ffffff;
  color: #111111;
}

.catalog-search-panel__button {
  min-height: 3.4rem;
  padding: 0 1.25rem;
  border-radius: 999px;
  border: 1px solid #111111;
  background: #111111;
  color: #ffffff;
  font-weight: 700;
}

.catalog-utility-strip {
  padding-bottom: 1rem;
}

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

.catalog-utility-item {
  display: grid;
  gap: 0.4rem;
  padding: 1rem 1.1rem;
  border-radius: 18px;
  border: 1px solid #dfdfdf;
  background: #ffffff;
}

.catalog-section-head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  align-items: end;
}

.catalog-section-head__link {
  color: #111111;
  font-weight: 700;
  text-decoration: none;
}

.catalog-section-head__link:hover {
  text-decoration: underline;
}

.catalog-category-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.catalog-category-card {
  min-height: 13rem;
}

.catalog-card-row,
.catalog-product-grid,
.result-list--finder {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

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

.catalog-editorial-card {
  min-height: 12rem;
}

.work-card,
.collection-card {
  display: grid;
  gap: 0;
  overflow: hidden;
  border-radius: 18px;
}

.work-card__visual,
.collection-card__visual {
  min-height: 12.5rem;
  padding: 1rem;
  display: flex;
  align-items: end;
  background: linear-gradient(135deg, #f5f5f5 0%, #e8eef8 100%);
  border-bottom: 1px solid #dfdfdf;
}

.work-card__visual-meta,
.collection-card__visual-title {
  display: grid;
  gap: 0.35rem;
}

.work-card__visual-label,
.collection-card__visual-label {
  display: inline-flex;
  width: fit-content;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  background: #0058a3;
  color: #ffffff;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.05em;
}

.work-card__visual strong,
.collection-card__visual strong {
  color: #111111;
  font-size: 1rem;
}

.work-card__body,
.collection-card__body {
  padding: 1rem 1rem 1.1rem;
}

.work-card__reason {
  background: #f5f5f5;
  border: 0;
  color: #111111;
  padding: 0.8rem;
}

.work-card__meta {
  color: #484848;
}

.work-action-chip {
  background: #ffffff;
  color: #111111;
  border: 1px solid #d1d1d1;
}

.work-action-chip[aria-pressed="true"] {
  background: #111111;
  color: #ffffff;
  border-color: #111111;
}

.collection-card__count {
  background: #f5f5f5;
  color: #111111;
  border: 1px solid #d9d9d9;
}

.finder-experience {
  gap: 1.2rem;
}

.finder-command {
  background: #fbd914;
  border-color: #e5c100;
}

.finder-command .lead,
.finder-command .help,
.finder-command .muted,
.finder-command .label {
  color: #111111;
}

.finder-command .input,
.finder-command .select {
  background: #ffffff;
  color: #111111;
  border: 1px solid #cfcfcf;
}

.finder-layout-v2 {
  grid-template-columns: minmax(280px, 320px) minmax(0, 1fr);
  gap: 1rem;
}

.finder-panel-v2,
.finder-summary-bar,
.compare-dock,
.finder-empty-state {
  border-radius: 18px;
}

.finder-group-v2 {
  padding: 0.4rem 0;
}

.finder-tag-row {
  background: #ffffff;
  border: 1px solid #e3e3e3;
}

.finder-state-btn {
  background: #ffffff;
  color: #111111;
  border: 1px solid #d0d0d0;
}

.finder-state-btn[aria-pressed="true"],
.finder-state-btn--include[aria-pressed="true"] {
  background: #0058a3;
  color: #ffffff;
  border-color: #0058a3;
}

.finder-state-btn--exclude[aria-pressed="true"] {
  background: #111111;
  color: #ffffff;
  border-color: #111111;
}

.active-filter-list .tag-filter__btn {
  background: #f5f5f5;
  color: #111111;
}

.compare-pill {
  background: #f5f5f5;
  border: 1px solid #dfdfdf;
}

.finder-mini-link,
.guide-mini-link {
  background: #ffffff;
  border: 1px solid #dfdfdf;
}

.page-hero::before,
.page-hero--guide::before,
.page-hero--article::before,
.page-hero--support::before {
  background: linear-gradient(135deg, #f7f7f7 0%, #ececec 100%);
}

.page-hero,
.page-hero .lead,
.page-hero .muted {
  color: #111111;
}

.booking-detail-page,
.booking-two-column,
.page-layout,
.guide-detail-layout {
  gap: 1rem;
}

.booking-sticky-card,
.rail-card {
  position: sticky;
  top: 10.5rem;
}

@media (max-width: 1200px) {
  .catalog-hero__grid,
  .nav__main,
  .finder-layout-v2,
  .page-layout,
  .guide-detail-layout {
    grid-template-columns: 1fr;
  }

  .contact-simple-shell {
    width: min(680px, 100%);
  }

  .catalog-category-grid,
  .catalog-card-row,
  .catalog-product-grid,
  .result-list--finder,
  .catalog-editorial-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

@media (max-width: 760px) {
  .nav__topbar,
  .nav__promo,
  .catalog-section-head {
    grid-template-columns: 1fr;
    display: grid;
  }

  .nav__search,
  .catalog-search-panel__row {
    grid-template-columns: 1fr;
  }

  .nav__categories {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 0.35rem;
  }

  .catalog-utility-strip__grid,
  .catalog-category-grid,
  .catalog-card-row,
  .catalog-product-grid,
  .result-list--finder,
  .catalog-editorial-grid {
    grid-template-columns: 1fr;
  }
}

.work-card__actions {
  gap: 0.5rem;
}

.work-action-chip {
  padding: 0.5rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(183, 206, 255, 0.12);
  background: rgba(7, 17, 31, 0.64);
  color: var(--text-muted);
  font-weight: 700;
}

.work-action-chip[aria-pressed="true"] {
  background: rgba(124, 192, 255, 0.18);
  color: #ffffff;
  border-color: rgba(124, 192, 255, 0.34);
}

.work-card--compact .work-card__title {
  font-size: 1.12rem;
}

.work-card__footnote {
  margin: 0;
}

.collection-card__body {
  gap: 0.75rem;
}

.collection-card__title {
  color: #f8fbff;
  text-decoration: none;
}

.collection-card__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  justify-content: space-between;
}

.collection-card__count {
  background: rgba(124, 192, 255, 0.12);
  color: #f1f7ff;
}

.active-filter-list .tag-filter__btn {
  background: rgba(124, 192, 255, 0.12);
  color: #f1f7ff;
}

.booking-page-header,
.booking-detail-header,
.booking-sticky-card {
  background: linear-gradient(180deg, rgba(20, 31, 57, 0.98), rgba(12, 20, 37, 0.98));
  border-top-color: rgba(255, 179, 87, 0.58);
}

.booking-info-grid,
.booking-feature-grid {
  gap: 1rem;
}

.booking-detail-page,
.booking-two-column {
  gap: 1rem;
}

.work-meta-strip {
  gap: 0.6rem;
}

.section-head .btn {
  margin-left: auto;
}

@media (max-width: 1180px) {
  .finder-command__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .finder-layout-v2 {
    grid-template-columns: 1fr;
  }

  .finder-summary-bar {
    position: static;
    grid-template-columns: 1fr;
  }

  .quick-dashboard {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .finder-command__grid,
  .finder-preset-strip,
  .booking-detail-info-grid,
  .booking-info-grid,
  .booking-feature-grid,
  .finder-compare-grid {
    grid-template-columns: 1fr;
  }

  .finder-tag-row {
    grid-template-columns: 1fr;
  }

  .finder-tag-row__controls {
    width: 100%;
  }

  .finder-state-btn {
    flex: 1 1 0;
  }

  .work-card__footer,
  .collection-card__footer {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* Storefront Reconstruction */

:root {
  --retail-bg: #ffffff;
  --retail-tint: #f5f5f5;
  --retail-tint-2: #fbfbfb;
  --retail-line: #d9d9d9;
  --retail-line-strong: #bfbfbf;
  --retail-text: #111111;
  --retail-muted: #484848;
  --retail-blue: #0058a3;
  --retail-yellow: #ffdb00;
  --retail-shadow: 0 1px 4px rgba(17, 17, 17, 0.08);
  --retail-shadow-strong: 0 8px 24px rgba(17, 17, 17, 0.08);
}

html[data-theme="light"] {
  color-scheme: light;
}

html[data-theme="light"] body {
  background: var(--retail-bg);
  color: var(--retail-text);
  font-family: "Noto Sans JP", "Hiragino Sans", "Helvetica Neue", Arial, sans-serif;
}

body {
  background: var(--retail-bg);
  color: var(--retail-text);
}

a {
  color: var(--retail-text);
}

.container {
  width: min(100% - 32px, 1440px);
  max-width: 1440px;
}

.section {
  padding: 40px 0 56px;
}

.section--tight {
  padding: 28px 0 48px;
}

.card {
  background: var(--retail-bg);
  border: 1px solid var(--retail-line);
  border-radius: 18px;
  box-shadow: var(--retail-shadow);
  color: var(--retail-text);
}

.h1,
.h2,
.h3,
h1,
h2,
h3 {
  color: var(--retail-text);
  letter-spacing: -0.03em;
}

.lead,
.muted,
.help {
  color: var(--retail-muted);
}

.pill,
.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  min-height: 36px;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--retail-line);
  background: var(--retail-tint-2);
  color: var(--retail-text);
  text-decoration: none;
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.btn {
  border-radius: 999px;
  font-weight: 700;
  box-shadow: none;
}

.btn--primary {
  background: #111111;
  border-color: #111111;
  color: #ffffff;
}

.btn--secondary {
  background: #ffffff;
  border-color: #111111;
  color: #111111;
}

.btn--ghost {
  background: transparent;
  border-color: transparent;
  color: #111111;
}

.input,
.textarea,
.select {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid var(--retail-line);
  background: #ffffff;
  color: var(--retail-text);
}

.apply-form .label,
.apply-form .apply-work-item__header strong {
  color: #111111;
}

.apply-form .input,
.apply-form .textarea {
  border-color: #bfbfbf;
  background: #ffffff;
  color: #111111;
  -webkit-text-fill-color: #111111;
}

.apply-form .input::placeholder,
.apply-form .textarea::placeholder {
  color: #4b5563;
  opacity: 1;
}

.apply-form .help {
  color: #222222;
}

.storefront-eyebrow {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--retail-blue);
}

.nav {
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(17, 17, 17, 0.08);
}

.nav__inner {
  display: block;
  padding: 0;
}

.nav__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.7rem 0;
  border-bottom: 1px solid rgba(17, 17, 17, 0.08);
  font-size: 0.9rem;
}

.nav__topbar-links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.nav__topbar-links a {
  text-decoration: none;
  color: var(--retail-muted);
}

.nav__main {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 1.4rem;
  align-items: center;
  padding: 1rem 0;
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
  min-width: 0;
  text-decoration: none;
  color: var(--retail-text);
}

.nav__brand-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 86px;
  height: 50px;
  border-radius: 999px;
  background: var(--retail-blue);
  color: var(--retail-yellow);
  font-weight: 900;
  letter-spacing: 0.08em;
}

.nav__brand-text {
  font-size: 1.18rem;
  font-weight: 800;
  white-space: nowrap;
}

.nav__search {
  display: flex;
  align-items: center;
  min-height: 56px;
  border-radius: 999px;
  border: 1px solid var(--retail-line);
  background: var(--retail-tint);
  overflow: hidden;
}

.nav__search-input {
  flex: 1 1 auto;
  min-width: 0;
  height: 100%;
  border: none;
  background: transparent;
  padding: 0 1.25rem;
  color: var(--retail-text);
}

.nav__search-button {
  min-width: 88px;
  height: 56px;
  border: none;
  border-left: 1px solid rgba(17, 17, 17, 0.08);
  background: transparent;
  color: var(--retail-text);
  font-weight: 700;
}

.nav__utility {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
}

.nav__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 1.15rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
}

.nav__cta--primary {
  background: #111111;
  color: #ffffff;
}

.nav__cta--secondary {
  background: #ffffff;
  border: 1px solid #111111;
  color: #111111;
}

.nav__links,
.nav__categories {
  display: flex;
  gap: 1.2rem;
  overflow-x: auto;
  padding: 0.85rem 0;
}

.nav__links::-webkit-scrollbar,
.nav__categories::-webkit-scrollbar {
  display: none;
}

.nav__link,
.nav__category-link {
  white-space: nowrap;
  text-decoration: none;
  color: var(--retail-text);
  font-weight: 700;
}

.nav__link[aria-current="page"] {
  text-decoration: underline;
  text-underline-offset: 0.4rem;
}

.nav__category-link {
  color: var(--retail-muted);
}

.nav__promo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 1.4rem;
  padding: 0.95rem 1.2rem;
  border-radius: 14px;
  background: var(--retail-yellow);
}

.nav__promo-text {
  margin: 0;
  color: #111111;
  font-weight: 700;
}

.nav__promo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.nav__promo-link {
  text-decoration: none;
  color: #111111;
  font-weight: 800;
}

.footer {
  background: var(--retail-tint);
  border-top: 1px solid rgba(17, 17, 17, 0.08);
}

.footer__inner {
  display: grid;
  gap: 1.5rem;
  padding: 48px 0;
}

.footer__lead {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: end;
}

.footer__eyebrow {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--retail-blue);
}

.footer__lead-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.75rem;
}

.footer__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.footer__column {
  display: grid;
  gap: 0.9rem;
}

.footer__column-title {
  margin: 0;
  font-size: 1rem;
}

.footer__column-links {
  display: grid;
  gap: 0.7rem;
}

.footer__column-links a {
  text-decoration: none;
  color: var(--retail-muted);
}

.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid rgba(17, 17, 17, 0.08);
  padding-top: 1rem;
}

.storefront-hero {
  padding: 32px 0 40px;
}

.storefront-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(320px, 0.95fr);
  gap: 1.25rem;
}

.storefront-hero-card {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.9fr);
  min-height: 560px;
  overflow: hidden;
  border-radius: 24px;
  background: var(--retail-tint);
  border: 1px solid rgba(17, 17, 17, 0.08);
}

.storefront-hero-card__content {
  padding: 2rem;
}

.storefront-hero-card__title {
  margin: 0;
  font-size: clamp(2.5rem, 5vw, 4.8rem);
  line-height: 1.02;
}

.storefront-hero-card__lead,
.storefront-hero-card__note {
  margin: 0;
  max-width: 58ch;
  color: var(--retail-muted);
}

.storefront-search-box {
  display: flex;
  align-items: center;
  min-height: 64px;
  max-width: 720px;
  border-radius: 999px;
  border: 1px solid var(--retail-line);
  background: #ffffff;
  overflow: hidden;
}

.storefront-search-box__input {
  flex: 1 1 auto;
  min-width: 0;
  height: 64px;
  border: none;
  background: transparent;
  padding: 0 1.4rem;
  color: var(--retail-text);
}

.storefront-search-box__button {
  min-width: 108px;
  height: 64px;
  border: none;
  background: #111111;
  color: #ffffff;
  font-weight: 800;
}

.storefront-hero-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.storefront-hero__aside {
  display: grid;
  gap: 1.25rem;
}

.storefront-promo-card {
  display: grid;
  min-height: 268px;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(17, 17, 17, 0.08);
  background: var(--retail-bg);
}

.storefront-promo-card__body {
  padding: 1.4rem;
}

.storefront-promo-card--subtle {
  background: var(--retail-tint);
}

.storefront-visual,
.storefront-hero-card__media,
.storefront-promo-card__media,
.work-card__visual,
.collection-card__visual,
.pdp-gallery__visual,
.collection-detail-hero__visual {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.storefront-visual::before,
.storefront-hero-card__media::before,
.storefront-promo-card__media::before,
.work-card__visual::before,
.collection-card__visual::before,
.pdp-gallery__visual::before,
.collection-detail-hero__visual::before {
  content: "";
  position: absolute;
  inset: auto 12% 10% auto;
  width: 58%;
  height: 54%;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 20px 40px rgba(17, 17, 17, 0.08);
}

.storefront-visual::after,
.storefront-hero-card__media::after,
.storefront-promo-card__media::after,
.work-card__visual::after,
.collection-card__visual::after,
.pdp-gallery__visual::after,
.collection-detail-hero__visual::after {
  content: "";
  position: absolute;
  inset: 12% auto auto 10%;
  width: 28%;
  height: 22%;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.08);
}

.storefront-hero-card__media,
.storefront-promo-card__media,
.storefront-visual {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.5rem;
}

.storefront-visual--room,
.storefront-hero-card__media {
  background: linear-gradient(135deg, #dbcbb1, #f5eee3);
}

.storefront-visual--product {
  background: linear-gradient(135deg, #d8e3ef, #f1f5f9);
}

.storefront-visual--collection {
  min-height: 100%;
  background: linear-gradient(135deg, #e5ddd1, #f7f3ee);
}

.storefront-visual__badge,
.pdp-gallery__badge {
  position: relative;
  z-index: 1;
  margin: 0;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--retail-blue);
}

.storefront-visual__title,
.pdp-gallery__visual strong {
  position: relative;
  z-index: 1;
  font-size: 1.6rem;
  line-height: 1.08;
}

.storefront-visual__text,
.pdp-gallery__visual p {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: 24ch;
  color: rgba(17, 17, 17, 0.8);
}

.storefront-utility-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
}

.storefront-utility-card {
  display: grid;
  gap: 0.35rem;
  min-height: 110px;
  padding: 1.15rem;
  border: 1px solid rgba(17, 17, 17, 0.08);
  border-radius: 18px;
  background: var(--retail-tint);
}

.storefront-utility-card strong {
  font-size: 1rem;
}

.storefront-utility-card span {
  color: var(--retail-muted);
}

.storefront-section {
  padding: 36px 0 52px;
}

.storefront-section--tint {
  background: linear-gradient(180deg, #fafafa, #f5f5f5);
}

.storefront-section__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
}

.storefront-section__link {
  color: var(--retail-text);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.3rem;
  white-space: nowrap;
}

.storefront-category-grid,
.collections-directory {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.storefront-category-card,
.storefront-editorial-card,
.collections-intro,
.plp-panel,
.plp-shortcut-card {
  padding: 1.25rem;
}

.storefront-category-card,
.storefront-editorial-card {
  display: grid;
  gap: 0.8rem;
  min-height: 220px;
}

.storefront-shelf {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.15rem;
}

.storefront-product-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.15rem;
}

.result-list--finder {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.15rem;
}

.storefront-editorial-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.work-card,
.collection-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  border-radius: 18px;
  background: #ffffff;
}

.work-card__visual {
  min-height: 260px;
}

.work-card[data-tone="sun"] .work-card__visual {
  background: linear-gradient(135deg, #f5e6ab, #fff8e0);
}

.work-card[data-tone="sky"] .work-card__visual {
  background: linear-gradient(135deg, #dce8f5, #f5f9ff);
}

.work-card[data-tone="clay"] .work-card__visual {
  background: linear-gradient(135deg, #e8d9cf, #f7f0eb);
}

.work-card[data-tone="mint"] .work-card__visual {
  background: linear-gradient(135deg, #dcece3, #f1faf5);
}

.work-card[data-tone="stone"] .work-card__visual {
  background: linear-gradient(135deg, #e8e5df, #f8f7f4);
}

.collection-card[data-tone="sun"] .collection-card__visual {
  background: linear-gradient(135deg, #f4e8b8, #fff6de);
}

.collection-card[data-tone="sky"] .collection-card__visual {
  background: linear-gradient(135deg, #dee7f5, #f7faff);
}

.collection-card[data-tone="clay"] .collection-card__visual {
  background: linear-gradient(135deg, #e6d7ca, #f5eee8);
}

.collection-card[data-tone="mint"] .collection-card__visual {
  background: linear-gradient(135deg, #dcebe1, #f2f9f5);
}

.collection-card[data-tone="stone"] .collection-card__visual {
  background: linear-gradient(135deg, #e6e3db, #f7f6f2);
}

.collection-card__visual {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.45rem;
  min-height: 220px;
  padding: 1.25rem;
}

.work-card__visual-link {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.5rem;
  min-height: 260px;
  padding: 1.35rem;
  color: var(--retail-text);
  text-decoration: none;
}

.work-card__visual-kind,
.collection-card__visual-label {
  position: relative;
  z-index: 1;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--retail-blue);
}

.work-card__visual-title,
.collection-card__visual-title {
  position: relative;
  z-index: 1;
  font-size: 1.5rem;
  line-height: 1.08;
}

.work-card__visual-meta {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  color: rgba(17, 17, 17, 0.8);
}

.work-card__visual-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 0.75rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(17, 17, 17, 0.08);
  color: #111111;
  font-size: 0.72rem;
  font-weight: 800;
}

.work-card__body,
.collection-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1.25rem;
}

.work-card__header,
.collection-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.work-card__creator,
.collection-card__creator {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6b7280;
}

.work-card__title,
.collection-card__title {
  color: var(--retail-text);
  text-decoration: none;
}

.work-card__title {
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1.1;
}

.collection-card__title {
  font-size: 1.3rem;
  line-height: 1.12;
}

.work-card__summary,
.collection-card__summary {
  margin: 0;
  color: var(--retail-text);
}

.work-card__meta {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.2rem 0 0.1rem;
  border-top: 1px solid rgba(17, 17, 17, 0.08);
}

.work-card__format {
  font-size: 1.45rem;
  font-weight: 800;
}

.work-card__reason {
  margin: 0;
  color: var(--retail-muted);
  font-size: 0.96rem;
}

.work-card__footer,
.collection-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: auto;
  padding-top: 0.3rem;
}

.work-card__footer--solo {
  justify-content: flex-start;
}

.work-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.work-action-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--retail-line);
  background: #ffffff;
  color: #111111;
  font-weight: 700;
}

.work-action-chip[aria-pressed="true"] {
  background: #111111;
  color: #ffffff;
  border-color: #111111;
}

.collection-card__count {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--retail-line);
  background: var(--retail-tint);
  color: #111111;
  font-weight: 800;
}

.work-card__footnote {
  margin: 0;
  padding: 0 1.25rem 1.2rem;
}

.finder-mini-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.finder-mini-link,
.finder-mini-link--button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--retail-line);
  border-radius: 14px;
  background: #ffffff;
  text-decoration: none;
  color: var(--retail-text);
}

.finder-mini-link__body {
  display: grid;
  gap: 0.2rem;
}

.finder-mini-link--saved {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.7rem;
  align-items: start;
}

.plp-page {
  background: #ffffff;
}

.plp-hero {
  padding: 28px 0 20px;
}

.plp-breadcrumb {
  margin: 0;
  color: #6b7280;
  font-size: 0.92rem;
}

.plp-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.85fr);
  gap: 1.25rem;
  align-items: end;
}

.plp-hero__title {
  margin: 0;
  font-size: clamp(2.3rem, 4vw, 3.8rem);
  line-height: 1.05;
}

.plp-hero__description {
  margin: 0;
  max-width: 62ch;
  color: var(--retail-muted);
}

.plp-hero__aside {
  display: grid;
  gap: 1rem;
  padding: 1.35rem;
  border: 1px solid var(--retail-line);
  border-radius: 18px;
  background: var(--retail-tint);
}

.plp-search-box {
  display: grid;
  gap: 1rem;
  padding: 1.35rem;
  border-radius: 20px;
}

.plp-search-box__grid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1.2fr) minmax(220px, 0.9fr) minmax(220px, 0.9fr);
  gap: 1rem;
}

.plp-search-box__field {
  display: grid;
  gap: 0.45rem;
}

.plp-search-box__field--wide {
  grid-column: span 1;
}

.plp-search-box__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.plp-shortcuts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.plp-layout {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 1.25rem;
  align-items: start;
}

.plp-sidebar {
  position: sticky;
  top: 108px;
  display: grid;
  gap: 1rem;
  align-self: start;
}

.plp-skip-link {
  color: var(--retail-text);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.3rem;
}

.plp-panel {
  display: grid;
  gap: 1rem;
  border-radius: 20px;
}

.plp-filter-group {
  display: grid;
  gap: 0.75rem;
  border-top: 1px solid rgba(17, 17, 17, 0.08);
  padding-top: 1rem;
}

.plp-filter-group:first-child {
  border-top: none;
  padding-top: 0;
}

.plp-filter-group[open] .plp-filter-group__summary::after {
  transform: rotate(180deg);
}

.plp-filter-group__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  list-style: none;
  cursor: pointer;
  font-weight: 800;
}

.plp-filter-group__summary::-webkit-details-marker {
  display: none;
}

.plp-filter-group__summary::after {
  content: "⌄";
  color: #6b7280;
  transition: transform 180ms ease;
}

.plp-filter-group__description {
  margin: 0;
}

.plp-filter-group__body {
  display: grid;
  gap: 0.75rem;
}

.plp-filter-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  padding: 0.85rem 0;
  border-bottom: 1px solid rgba(17, 17, 17, 0.06);
}

.plp-filter-row:last-child {
  border-bottom: none;
}

.plp-filter-row__info {
  display: grid;
  gap: 0.2rem;
}

.plp-filter-row__controls {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  justify-content: flex-end;
}

.plp-filter-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 0.8rem;
  border-radius: 999px;
  border: 1px solid var(--retail-line);
  background: #ffffff;
  color: #111111;
  font-weight: 700;
}

.plp-filter-chip[aria-pressed="true"] {
  background: #111111;
  border-color: #111111;
  color: #ffffff;
}

.plp-filter-chip--include[aria-pressed="true"] {
  background: var(--retail-blue);
  border-color: var(--retail-blue);
}

.plp-results {
  display: grid;
  gap: 1rem;
}

.plp-results-toolbar {
  position: sticky;
  top: 108px;
  z-index: 8;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  padding: 1.2rem 1.35rem;
  border-radius: 20px;
}

.plp-results-toolbar__aside {
  display: grid;
  justify-items: end;
  gap: 0.75rem;
}

.active-filter-list {
  justify-content: flex-end;
}

.active-filter-list .tag-filter__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--retail-line);
  background: var(--retail-tint-2);
  color: #111111;
  font-weight: 700;
}

.compare-dock {
  padding: 1.25rem;
  border-radius: 20px;
}

.finder-compare-items {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.compare-pill {
  display: grid;
  gap: 0.35rem;
  min-width: 220px;
  padding: 0.9rem 1rem;
  border-radius: 16px;
  border: 1px solid var(--retail-line);
  background: var(--retail-tint);
}

.finder-compare-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.compare-column {
  padding: 1rem;
}

.finder-empty-state {
  padding: 1.35rem;
  border-radius: 20px;
  background: linear-gradient(180deg, #faf6eb, #fffdf8);
}

.finder-relax-list {
  display: grid;
  gap: 0.75rem;
}

.finder-relax-item {
  display: grid;
  gap: 0.25rem;
}

.finder-relax-btn {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 44px;
  padding: 0 1rem;
  border-radius: 999px;
  border: 1px solid #111111;
  background: #ffffff;
  color: #111111;
  font-weight: 700;
}

.pdp-layout,
.collection-detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 1.25rem;
  align-items: start;
}

.pdp-main,
.collection-detail-main {
  min-width: 0;
}

.pdp-side,
.collection-detail-side {
  position: sticky;
  top: 108px;
  align-self: start;
}

.pdp-breadcrumb {
  margin: 0;
  color: #6b7280;
}

.pdp-overview {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.9fr);
  gap: 1.25rem;
  align-items: start;
}

.pdp-gallery {
  padding: 1rem;
  border-radius: 20px;
}

.pdp-gallery__caption {
  margin-top: 0.85rem;
}

.pdp-gallery__hero {
  min-height: 520px;
}

.pdp-gallery__visual {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.45rem;
  height: 100%;
  padding: 1.5rem;
  border-radius: 16px;
  background: linear-gradient(135deg, #e5ddd1, #f8f3ea);
}

.pdp-gallery__visual--image {
  padding: 0;
}

.pdp-gallery__visual--image::before,
.pdp-gallery__visual--image::after {
  display: none;
}

.pdp-gallery__visual--generated {
  background: #eef3fb;
}

.pdp-gallery__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pdp-gallery__visual--generated .pdp-gallery__image {
  object-fit: contain;
}

.pdp-gallery__overlay {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 0.45rem;
  height: 100%;
  padding: 1.5rem;
  color: #ffffff;
  background: linear-gradient(180deg, rgba(17, 17, 17, 0.06), rgba(17, 17, 17, 0.68));
}

.pdp-gallery__overlay p {
  margin: 0;
  max-width: 32ch;
  color: rgba(255, 255, 255, 0.84);
}

.pdp-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 0.75rem;
}

.pdp-gallery__thumb {
  position: relative;
  overflow: hidden;
  height: 90px;
  border-radius: 14px;
  border: 1px solid var(--retail-line);
  background: linear-gradient(135deg, #ece8e1, #f8f6f2);
}

.pdp-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pdp-gallery__thumb[data-active="true"] {
  box-shadow: inset 0 0 0 2px var(--accent);
}

.pdp-gallery__thumb-label {
  position: absolute;
  left: 0.6rem;
  bottom: 0.6rem;
  z-index: 1;
  padding: 0.2rem 0.45rem;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.68);
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.pdp-gallery__thumb--placeholder {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 0.85rem;
}

.pdp-gallery__thumb--placeholder strong {
  position: relative;
  z-index: 1;
  font-size: 0.85rem;
}

.pdp-summary {
  display: grid;
  gap: 0.9rem;
}

.pdp-summary-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.pdp-summary-metric {
  display: grid;
  gap: 0.3rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--retail-line);
  border-radius: 16px;
  background: var(--retail-tint);
}

.pdp-summary-metric span {
  color: var(--retail-muted);
  font-size: 0.82rem;
}

.pdp-summary-metric strong {
  font-size: 1rem;
  line-height: 1.25;
}

.pdp-highlight-box,
.pdp-buybox,
.collection-detail-aside {
  padding: 1.25rem;
  border-radius: 20px;
}

.pdp-detail-grid,
.collection-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.collections-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 1.25rem;
  align-items: start;
}

.collections-hero__aside {
  padding: 1.25rem;
  border-radius: 20px;
}

.collection-detail-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
  gap: 1.25rem;
  align-items: stretch;
  padding: 1.5rem;
  border-radius: 24px;
  background: var(--retail-tint);
}

.collection-detail-hero__copy {
  min-width: 0;
}

.collection-detail-hero__visual {
  min-height: 320px;
  border-radius: 18px;
}

.guide-shell,
.static-page-shell {
  background: #ffffff;
}

.page-shell .card,
.guide-page .card,
.legal-page .card {
  background: #ffffff;
  border-color: var(--retail-line);
  color: var(--retail-text);
}

@media (max-width: 1240px) {
  .storefront-hero__grid,
  .collections-hero,
  .collection-detail-hero,
  .pdp-overview,
  .pdp-layout,
  .collection-detail-layout {
    grid-template-columns: 1fr;
  }

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

  .storefront-shelf,
  .storefront-product-grid,
  .storefront-category-grid,
  .storefront-editorial-grid,
  .result-list--finder,
  .collections-directory {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .plp-layout {
    grid-template-columns: 1fr;
  }

  .plp-sidebar,
  .plp-results-toolbar,
  .pdp-side,
  .collection-detail-side {
    position: static;
  }

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

@media (max-width: 880px) {
  .nav__main,
  .footer__lead,
  .footer__grid,
  .plp-hero__grid,
  .guide-feature-grid,
  .pdp-detail-grid,
  .collection-detail-grid,
  .finder-compare-grid,
  .plp-shortcuts {
    grid-template-columns: 1fr;
  }

  .nav__utility,
  .footer__lead-actions,
  .footer__bottom {
    justify-content: flex-start;
  }

  .nav__promo,
  .storefront-section__head,
  .plp-results-toolbar {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .nav__promo,
  .footer__bottom,
  .plp-results-toolbar {
    display: grid;
  }

  .active-filter-list {
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .container {
    width: min(100% - 24px, 1440px);
  }

  .storefront-hero-card {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .storefront-hero-card__content,
  .storefront-promo-card__body,
  .plp-search-box,
  .plp-panel,
  .pdp-buybox,
  .collection-detail-aside {
    padding: 1rem;
  }

  .storefront-utility-grid,
  .storefront-shelf,
  .storefront-product-grid,
  .storefront-category-grid,
  .storefront-editorial-grid,
  .result-list--finder,
  .collections-directory,
  .pdp-summary-metrics,
  .pdp-gallery__thumbs {
    grid-template-columns: 1fr;
  }

  .plp-search-box__grid,
  .plp-filter-row {
    grid-template-columns: 1fr;
  }

  .plp-filter-row__controls,
  .work-card__footer,
  .collection-card__footer,
  .footer__lead-actions {
    justify-content: flex-start;
  }

  .nav__brand-text {
    font-size: 1rem;
  }

  .nav__brand-mark {
    width: 74px;
    height: 44px;
  }

  .nav__search,
  .storefront-search-box {
    min-height: 54px;
  }

  .storefront-search-box__button,
  .nav__search-button {
    min-width: 84px;
    height: 54px;
  }
}

/* --------------------------------------------------------------------------
   Catalog-style UI refresh for top page and finder
-------------------------------------------------------------------------- */

:root {
  color-scheme: light;
  --catalog-blue: #0058a3;
  --catalog-blue-deep: #004f93;
  --catalog-blue-soft: #eaf3fb;
  --catalog-yellow: #ffdb00;
  --catalog-yellow-soft: #fff5b8;
  --catalog-ink: #111111;
  --catalog-muted: #484848;
  --catalog-border: #dfdfdf;
  --catalog-border-strong: #c8c8c8;
  --catalog-surface: #ffffff;
  --catalog-surface-soft: #f5f5f5;
  --catalog-surface-soft-2: #f0f0f0;
  --catalog-success: #0a7a3b;
  --catalog-danger: #b3261e;
  --catalog-shadow: 0 8px 24px rgba(17, 17, 17, 0.08);
  --catalog-shadow-lg: 0 14px 40px rgba(17, 17, 17, 0.12);
  --hnf-content-max: 1440px;
}

body {
  background: #ffffff;
  color: var(--catalog-ink);
  font-family: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
}

.nav,
.footer {
  width: 100%;
}

.main {
  min-height: 60vh;
}

.hri-content-container,
.plp-content-container,
.hnf-content-container {
  width: min(var(--hnf-content-max), calc(100% - 48px));
  margin-inline: auto;
}

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

.hnf-btn,
.search-box-btn,
.hri-btn,
.plp-btn {
  appearance: none;
  border: 0;
  border-radius: 999px;
  font: inherit;
  text-decoration: none;
  cursor: pointer;
}

.hnf-btn__inner,
.search-box-btn__inner,
.plp-btn__inner {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.hnf-btn__label,
.search-box-btn__label {
  font-size: 0.875rem;
  font-weight: 700;
}

.hnf-link,
.hnf-link:hover,
.hri-section-link,
.hri-section-link:hover,
.content-card__link,
.content-card__link:hover,
.plp-product-card__title,
.plp-product-card__title:hover,
.hri-mini-link,
.hri-mini-link:hover {
  color: inherit;
  text-decoration: none;
}

.hnf-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.hnf-skip-to-content {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 60;
  transform: translateY(-160%);
  background: #ffffff;
  border: 1px solid var(--catalog-border);
  box-shadow: var(--catalog-shadow);
  transition: transform 180ms ease;
}

.hnf-skip-to-content .hnf-btn__inner {
  min-height: 44px;
  padding: 0 1rem;
}

.hnf-skip-to-content:focus {
  transform: translateY(0);
}

.hnf-messages {
  background: var(--catalog-blue);
  color: #ffffff;
}

.hnf-utilities {
  min-height: 44px;
}

.hnf-utilities__wrapper {
  display: grid;
  grid-template-columns: minmax(0, 240px) minmax(0, 1fr) minmax(0, 360px);
  gap: 1rem;
  align-items: center;
  min-height: 44px;
  padding: 0.25rem 0;
}

.hnf-utilities__block {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.hnf-utilities__block--vp {
  justify-content: center;
}

.hnf-utilities__block--pickers {
  justify-content: flex-end;
}

.hnf-utilities__chip,
.hnf-vp {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  font-size: 0.8125rem;
  font-weight: 600;
}

.hnf-utilities__chip svg,
.hnf-vp svg,
.hnf-header__action svg,
.search-box-search__icon,
.search-box-btn__icon,
.plp-btn__icon,
.content-card__icon svg,
.hri-mini-link__icon svg {
  flex: none;
}

.hnf-utilities__chip span:last-child,
.hnf-vp span:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hnf-header {
  background: #ffffff;
  border-bottom: 1px solid var(--catalog-border);
  position: sticky;
  top: 0;
  z-index: 40;
}

.hnf-header__container {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) minmax(320px, 420px) auto;
  gap: 1.25rem;
  align-items: center;
  padding: 1rem 0;
}

.hnf-header__logo {
  display: flex;
  align-items: center;
}

.hnf-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
}

.hnf-logo__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 88px;
  height: 56px;
  border-radius: 999px;
  background: var(--catalog-yellow);
  color: var(--catalog-blue);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.hnf-logo__lockup {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
}

.hnf-logo__eyebrow {
  color: var(--catalog-muted);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.hnf-logo__name {
  color: var(--catalog-ink);
  font-size: 1.125rem;
  font-weight: 800;
  line-height: 1.2;
}

.hnf-megamenu__entrypoints {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.375rem;
}

.hnf-megamenu__entrypoint {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 0.9rem;
  border-radius: 999px;
  color: var(--catalog-ink);
  font-size: 0.95rem;
  font-weight: 700;
  transition: background-color 180ms ease, color 180ms ease;
}

.hnf-megamenu__entrypoint:hover,
.hnf-megamenu__entrypoint[aria-current="page"] {
  background: var(--catalog-blue-soft);
  color: var(--catalog-blue);
}

.hnf-header__search {
  min-width: 0;
}

.search-box-form {
  width: 100%;
}

.search-box-search {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto auto;
  align-items: center;
  min-height: 56px;
  border: 2px solid #111111;
  border-radius: 999px;
  background: #ffffff;
  overflow: hidden;
}

.search-box-search--hero {
  min-height: 68px;
  box-shadow: var(--catalog-shadow-lg);
}

.search-box-search__icon {
  margin-left: 1.1rem;
  color: var(--catalog-ink);
}

.search-box-search__input {
  min-width: 0;
  padding: 0.95rem 0.65rem;
  border: 0;
  background: transparent;
  color: var(--catalog-ink);
  font-size: 1rem;
}

.search-box-search__input::placeholder {
  color: #676767;
}

.search-box-search__divider {
  width: 1px;
  height: 28px;
  background: var(--catalog-border);
}

.search-box-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  min-width: 52px;
  padding: 0 0.9rem;
  border-radius: 0;
  background: transparent;
  color: var(--catalog-ink);
}

.search-box-search__clear {
  color: #707070;
}

.search-box-search__action {
  background: var(--catalog-yellow);
  color: var(--catalog-ink);
  font-weight: 800;
}

.hnf-header__actions {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.hnf-header__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  border-radius: 999px;
  color: var(--catalog-ink);
}

.hnf-header__action:hover {
  background: var(--catalog-surface-soft);
}

.hnf-header__action span {
  display: none;
}

.hri-eyebrow {
  margin: 0;
  color: var(--catalog-blue);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.hri-home-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.95fr);
  gap: 1.5rem;
  padding: 2rem 0 2.5rem;
}

.hri-home-hero__lead,
.hri-feature-card,
.plp-search-panel,
.plp-filter-side-bar,
.plp-results-panel,
.plp-inline-message,
.plp-compare-section,
.hnf-footer__featuredLink,
.plp-compare-column {
  background: #ffffff;
  border: 1px solid var(--catalog-border);
  border-radius: 24px;
  box-shadow: var(--catalog-shadow);
}

.hri-home-hero__lead {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  padding: 2rem;
  background:
    radial-gradient(circle at top right, rgba(255, 219, 0, 0.24), transparent 34%),
    radial-gradient(circle at bottom left, rgba(0, 88, 163, 0.12), transparent 44%),
    #ffffff;
}

.hri-home-hero__title {
  margin: 0;
  font-size: clamp(2rem, 3vw, 3.4rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.hri-home-hero__description,
.hri-home-hero__note,
.plp-summary-note,
.plp-results-description {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 1rem;
  line-height: 1.7;
}

.hri-home-hero__note {
  font-size: 0.95rem;
}

.hri-home-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.hri-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 1.2rem;
  border-radius: 999px;
  font-size: 0.95rem;
  font-weight: 800;
}

.hri-btn--primary {
  background: var(--catalog-yellow);
  color: var(--catalog-ink);
}

.hri-btn--secondary {
  border: 1px solid var(--catalog-border-strong);
  background: #ffffff;
  color: var(--catalog-ink);
}

.hri-home-hero__aside {
  display: grid;
  gap: 1rem;
}

.hri-feature-card {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.35rem 1.35rem 1.2rem;
}

.hri-feature-card--accent {
  background:
    linear-gradient(180deg, rgba(0, 88, 163, 0.04), rgba(0, 88, 163, 0)),
    linear-gradient(135deg, rgba(255, 219, 0, 0.18), rgba(255, 255, 255, 0));
}

.hri-feature-card__head {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.hri-section-title,
.plp-typography-heading-m,
.plp-typography-heading-s,
.hri-section-title-sm {
  margin: 0;
  color: var(--catalog-ink);
  font-weight: 800;
  line-height: 1.2;
}

.hri-section-title {
  font-size: 1.75rem;
}

.plp-typography-heading-m {
  font-size: 1.7rem;
}

.plp-typography-heading-s,
.hri-section-title-sm {
  font-size: 1.25rem;
}

.plp-typography-heading-l {
  margin: 0;
  color: var(--catalog-ink);
  font-size: clamp(1.9rem, 2.2vw, 2.6rem);
  font-weight: 800;
  line-height: 1.12;
}

.hri-pill-list,
.plp-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.hri-pill,
.plp-chip,
.tag-filter__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 38px;
  padding: 0 0.9rem;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #ffffff;
  color: var(--catalog-ink);
  font-size: 0.87rem;
  font-weight: 700;
  text-decoration: none;
}

.hri-pill:hover,
.plp-chip:hover {
  background: var(--catalog-surface-soft);
}

.hri-mini-stack {
  display: grid;
  gap: 0.7rem;
}

.hri-mini-stack__item {
  display: grid;
  gap: 0.5rem;
}

.hri-mini-link {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
  padding: 0.95rem 1rem;
  border: 1px solid var(--catalog-border);
  border-radius: 18px;
  background: #ffffff;
}

.hri-mini-link__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--catalog-surface-soft);
  color: var(--catalog-blue);
}

.hri-mini-link__body {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
  min-width: 0;
}

.hri-mini-link__title {
  font-size: 0.95rem;
  font-weight: 800;
}

.hri-mini-link__meta {
  color: var(--catalog-muted);
  font-size: 0.82rem;
  line-height: 1.55;
}

.hri-section,
.plp-component-spacing {
  padding: 1.35rem 0 2.25rem;
}

.hri-section-heading,
.plp-shelfcarousel-heading,
.plp-results-subhead,
.plp-results-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: end;
  margin-bottom: 1rem;
}

.hri-section-link {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 1rem;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  font-size: 0.875rem;
  font-weight: 800;
}

.plp-carousel {
  position: relative;
}

.plp-carousel__wrapper {
  overflow: hidden;
}

.plp-carousel__content {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 1fr);
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 0.25rem;
  scrollbar-width: none;
}

.plp-carousel__content::-webkit-scrollbar {
  display: none;
}

.plp-carousel__content > * {
  scroll-snap-align: start;
}

.plp-carousel__button {
  position: absolute;
  top: calc(50% - 24px);
  left: -20px;
  z-index: 2;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #ffffff;
  border: 1px solid var(--catalog-border);
  box-shadow: var(--catalog-shadow);
}

.plp-carousel__button--right {
  right: -20px;
  left: auto;
}

.plp-carousel__button[disabled] {
  opacity: 0.4;
  cursor: default;
}

.plp-scroll-indicator {
  margin-top: 0.9rem;
}

.plp-scroll-indicator__bar-wrapper {
  display: block;
  width: 100%;
  height: 4px;
  border-radius: 999px;
  background: #e3e3e3;
}

.plp-scroll-indicator__bar {
  display: block;
  width: 18%;
  height: 100%;
  border-radius: inherit;
  background: var(--catalog-ink);
  transform: translateX(0);
  transition: transform 180ms ease, width 180ms ease;
}

.content-card {
  display: block;
  min-height: 100%;
  border: 1px solid var(--catalog-border);
  border-radius: 22px;
  background: #ffffff;
  overflow: hidden;
  box-shadow: var(--catalog-shadow);
}

.content-card__link {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

.content-card__image {
  position: relative;
  min-height: 180px;
  background:
    radial-gradient(circle at top right, rgba(255, 219, 0, 0.5), transparent 35%),
    linear-gradient(135deg, rgba(0, 88, 163, 0.9), rgba(0, 88, 163, 0.18));
}

.content-card--tag .content-card__image {
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.28), transparent 32%),
    linear-gradient(135deg, rgba(0, 88, 163, 0.88), rgba(17, 17, 17, 0.25));
}

.content-card--collection .content-card__image {
  background:
    radial-gradient(circle at top right, rgba(255, 219, 0, 0.45), transparent 35%),
    linear-gradient(135deg, rgba(17, 17, 17, 0.82), rgba(0, 88, 163, 0.28));
}

.content-card--work .content-card__image {
  background:
    radial-gradient(circle at top right, rgba(255, 219, 0, 0.55), transparent 35%),
    linear-gradient(135deg, rgba(0, 88, 163, 0.84), rgba(0, 0, 0, 0.15));
}

.content-card__image-inner {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 180px;
  padding: 1rem;
  color: #ffffff;
}

.content-card__image-kicker {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.content-card__image-title {
  margin-top: 0.35rem;
  font-size: 1.28rem;
  font-weight: 800;
  line-height: 1.15;
}

.content-card__wrapper {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  padding: 1rem;
}

.content-card__type {
  color: var(--catalog-blue);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.content-card__title {
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.35;
}

.content-card__description,
.content-card__meta {
  color: var(--catalog-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.content-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: auto;
}

.content-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--catalog-surface-soft);
  color: var(--catalog-ink);
}

.content-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.content-card__chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 0.7rem;
  border-radius: 999px;
  background: var(--catalog-surface-soft);
  color: var(--catalog-ink);
  font-size: 0.78rem;
  font-weight: 700;
}

.hri-home-utility-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
  gap: 1rem;
}

.hri-support-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.9rem;
}

.hri-support-card {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 1rem;
  border: 1px solid var(--catalog-border);
  border-radius: 18px;
  background: var(--catalog-surface-soft);
}

.hri-support-card__title {
  font-size: 1rem;
  font-weight: 800;
}

.hri-support-card__body {
  color: var(--catalog-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.search-page-container {
  padding: 1.4rem 0 2.5rem;
}

.search-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: 1.25rem;
  align-items: start;
  padding-bottom: 1.25rem;
}

.search-summary__content {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.search-summary__aside {
  display: flex;
  justify-content: flex-end;
}

.plp-catalog-product-list {
  display: grid;
  grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
  gap: 1.25rem;
  align-items: start;
}

.plp-filter-container {
  position: sticky;
  top: 110px;
  display: grid;
  gap: 1rem;
}

.plp-skip-content__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 1rem;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  background: #ffffff;
  color: var(--catalog-ink);
  font-size: 0.875rem;
  font-weight: 800;
}

.plp-search-panel,
.plp-filter-side-bar,
.plp-results-panel {
  padding: 1rem;
}

.plp-search-panel {
  display: grid;
  gap: 1rem;
}

.plp-search-panel__subfields {
  display: grid;
  gap: 0.85rem;
}

.plp-field {
  display: grid;
  gap: 0.4rem;
}

.plp-field__label {
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--catalog-blue);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.plp-field__input,
.plp-field__select {
  min-height: 48px;
  padding: 0 0.95rem;
  border: 1px solid var(--catalog-border-strong);
  border-radius: 14px;
  background: #ffffff;
  color: var(--catalog-ink);
}

.plp-field__help {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.82rem;
}

.plp-toggle-group {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.plp-toggle-btn,
.plp-filter-chip,
.finder-relax-btn {
  min-height: 38px;
  padding: 0 0.9rem;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #ffffff;
  color: var(--catalog-ink);
  font-size: 0.84rem;
  font-weight: 800;
}

.plp-toggle-btn[aria-pressed="true"],
.plp-filter-chip[aria-pressed="true"] {
  border-color: var(--catalog-blue);
  background: var(--catalog-blue-soft);
  color: var(--catalog-blue);
}

.plp-filter-chip--exclude[aria-pressed="true"] {
  border-color: #8d2c27;
  background: #fff1f0;
  color: #8d2c27;
}

.plp-search-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.plp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 0.95rem;
  border: 1px solid transparent;
  background: #ffffff;
  color: var(--catalog-ink);
  font-size: 0.84rem;
  font-weight: 800;
}

.plp-btn--secondary {
  border-color: var(--catalog-border-strong);
}

.plp-btn--tertiary {
  background: var(--catalog-surface-soft);
}

.plp-btn--icon-primary {
  border-color: var(--catalog-border);
}

.plp-btn--icon-primary,
.plp-btn--icon-primary .plp-btn__inner {
  padding: 0;
}

.plp-accordion-list,
.plp-filter-groups {
  display: grid;
  gap: 0.75rem;
}

.plp-accordion-item,
.plp-filter-panel {
  border: 1px solid var(--catalog-border);
  border-radius: 18px;
  background: #ffffff;
  overflow: hidden;
}

.plp-accordion-heading,
.plp-filter-panel__heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-height: 54px;
  padding: 0.85rem 1rem;
  border: 0;
  background: #ffffff;
  color: var(--catalog-ink);
  font-size: 0.95rem;
  font-weight: 800;
  text-align: left;
}

.plp-accordion-heading[aria-expanded="true"] svg,
.plp-filter-panel__heading[aria-expanded="true"] svg {
  transform: rotate(180deg);
}

.plp-accordion-content,
.plp-filter-panel__body {
  padding: 0 1rem 1rem;
}

.plp-accordion-content[hidden],
.plp-filter-panel__body[hidden] {
  display: none;
}

.plp-guide-list {
  display: grid;
  gap: 0.65rem;
  margin: 0;
  padding-left: 1.1rem;
  color: var(--catalog-muted);
  font-size: 0.88rem;
}

.plp-filter-options {
  display: grid;
  gap: 0.7rem;
}

.plp-filter-option {
  display: grid;
  gap: 0.6rem;
  padding: 0.9rem;
  border-radius: 14px;
  background: var(--catalog-surface-soft);
}

.plp-filter-option__main {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.75rem;
}

.plp-filter-option__title {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.plp-filter-option__title strong {
  font-size: 0.95rem;
}

.plp-filter-option__meta {
  color: var(--catalog-muted);
  font-size: 0.8rem;
}

.plp-filter-option__count {
  flex: none;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 0.65rem;
  border-radius: 999px;
  background: #ffffff;
  color: var(--catalog-muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.plp-filter-option__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.plp-results-header {
  margin-bottom: 1.25rem;
  align-items: start;
}

.plp-results-status {
  margin: 0.5rem 0 0;
  color: var(--catalog-muted);
  font-size: 0.92rem;
  line-height: 1.6;
}

.plp-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(265px, 1fr));
  gap: 1rem;
}

.plp-product-grid--compact {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.plp-product-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  border: 1px solid var(--catalog-border);
  border-radius: 22px;
  background: #ffffff;
  overflow: hidden;
  box-shadow: var(--catalog-shadow);
}

.plp-product-card__media {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 200px;
  padding: 1rem;
  color: #ffffff;
  background:
    radial-gradient(circle at top right, rgba(255, 219, 0, 0.52), transparent 32%),
    linear-gradient(135deg, rgba(0, 88, 163, 0.9), rgba(0, 0, 0, 0.2));
}

.plp-product-card__label {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 0.7rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.plp-product-card__media-title {
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1.2;
}

.plp-product-card__media-meta {
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.85rem;
  line-height: 1.5;
}

.plp-product-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 0.7rem;
  padding: 1rem;
}

.plp-product-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  color: var(--catalog-muted);
  font-size: 0.82rem;
}

.plp-product-card__title {
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.4;
}

.plp-product-card__description,
.plp-product-card__reason {
  color: var(--catalog-muted);
  font-size: 0.88rem;
  line-height: 1.62;
}

.plp-product-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.plp-product-card__chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 0.7rem;
  border-radius: 999px;
  background: var(--catalog-surface-soft);
  color: var(--catalog-ink);
  font-size: 0.77rem;
  font-weight: 700;
}

.plp-product-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: auto;
}

.plp-product-card__actions .plp-btn {
  flex: 1 1 auto;
}

.plp-product-card__actions .plp-btn--primary {
  background: var(--catalog-yellow);
}

.plp-inline-message {
  margin-bottom: 1rem;
}

.plp-inline-message__content {
  display: grid;
  gap: 0.7rem;
  padding: 1.2rem;
}

.finder-relax-list {
  display: grid;
  gap: 0.7rem;
}

.finder-relax-item {
  display: grid;
  gap: 0.35rem;
}

.finder-relax-item p {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.82rem;
}

.plp-compare-section {
  display: grid;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 1rem;
}

.plp-compare-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.9rem;
}

.plp-compare-column {
  display: grid;
  gap: 0.6rem;
  padding: 1rem;
}

.relatedSearches__heading {
  margin: 0 0 0.8rem;
}

.relatedSearches__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.relatedSearches__list-item {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.relatedSearches__link {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 0.9rem;
  border-radius: 999px;
  background: var(--catalog-surface-soft);
  color: var(--catalog-ink);
  font-size: 0.86rem;
  font-weight: 700;
}

.relatedSearches__count {
  color: var(--catalog-muted);
  font-size: 0.82rem;
}

.footer {
  margin-top: 2rem;
}

.hnf-footer {
  background: var(--catalog-surface-soft);
  border-top: 1px solid var(--catalog-border);
}

.hnf-footer__container {
  display: grid;
  gap: 1.5rem;
  padding: 2.5rem 0 2rem;
}

.hnf-footer__featuredLinks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.hnf-footer__featuredLink {
  display: grid;
  gap: 0.75rem;
  padding: 1.35rem;
}

.hnf-footer__featuredLink h3,
.hnf-footer__linkColumn h3 {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 800;
}

.hnf-footer__featuredLink p,
.hnf-footer__meta {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.88rem;
  line-height: 1.62;
}

.hnf-footer__featuredLinkActions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.hnf-footer__linkGroups {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.hnf-footer__linkColumn {
  display: grid;
  gap: 0.8rem;
}

.hnf-footer__linkColumn ul {
  display: grid;
  gap: 0.6rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hnf-footer__linkColumn a {
  color: var(--catalog-ink);
  font-size: 0.88rem;
  text-decoration: none;
}

.hnf-footer__bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.75rem;
  padding-top: 1rem;
  border-top: 1px solid var(--catalog-border);
}

@media (max-width: 1180px) {
  .hnf-header__container {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .hnf-header__search,
  .hnf-header__actions {
    grid-column: 1 / -1;
  }

  .plp-catalog-product-list {
    grid-template-columns: 1fr;
  }

  .plp-filter-container {
    position: static;
  }

  .search-summary,
  .hri-home-hero,
  .hri-home-utility-grid,
  .hnf-footer__featuredLinks,
  .hnf-footer__linkGroups {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 920px) {
  .hnf-utilities__wrapper {
    grid-template-columns: 1fr;
    justify-items: start;
    padding: 0.55rem 0;
  }

  .hnf-utilities__block--vp,
  .hnf-utilities__block--pickers {
    justify-content: flex-start;
  }

  .plp-carousel__button {
    display: none;
  }
}

@media (max-width: 640px) {
  .hri-content-container,
  .plp-content-container,
  .hnf-content-container {
    width: min(var(--hnf-content-max), calc(100% - 24px));
  }

  .hnf-logo__mark {
    width: 72px;
    height: 46px;
    font-size: 0.86rem;
  }

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

  .search-box-search__divider,
  .search-box-search__clear .search-box-btn__label,
  .search-box-search__action .search-box-btn__label {
    display: none;
  }

  .search-box-search__clear,
  .search-box-search__action {
    min-width: 48px;
    padding: 0;
  }

  .hri-home-hero__lead,
  .hri-feature-card,
  .plp-search-panel,
  .plp-filter-side-bar,
  .plp-results-panel {
    padding: 1rem;
  }

  .plp-product-grid,
  .plp-compare-grid {
    grid-template-columns: 1fr;
  }
}

/* Catalog-like remaster */

:root {
  --catalog-blue: #0058a3;
  --catalog-yellow: #ffdb00;
  --catalog-black: #111111;
  --catalog-text: #1d1d1f;
  --catalog-muted: #6b6b6b;
  --catalog-border: #dfdfdf;
  --catalog-panel: #f5f5f5;
  --catalog-panel-2: #fafafa;
  --catalog-shadow: 0 16px 40px rgba(17, 17, 17, 0.08);
  --catalog-radius: 20px;
  --catalog-shell-width: min(1440px, calc(100% - 72px));
}

html,
body {
  background: #fff;
  color: var(--catalog-text);
  font-family: "Noto Sans JP", "Helvetica Neue", Arial, sans-serif;
}

body {
  margin: 0;
}

.hnf-skip-to-content {
  position: absolute;
  left: 16px;
  top: -80px;
  z-index: 200;
  padding: 12px 16px;
  border-radius: 999px;
  background: var(--catalog-yellow);
  color: var(--catalog-black);
  font-weight: 700;
  text-decoration: none;
}

.hnf-skip-to-content:focus {
  top: 16px;
}

.nav,
.footer {
  width: 100%;
}

.catalog-shell__utilityBar {
  background: var(--catalog-black);
  color: #fff;
}

.catalog-shell__utilityInner,
.catalog-shell__headerInner,
.catalog-footer__inner,
.catalog-page-shell {
  width: var(--catalog-shell-width);
  margin: 0 auto;
}

.catalog-shell__utilityInner {
  min-height: 40px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 20px;
  font-size: 0.84rem;
}

.catalog-shell__utilityGroup {
  display: flex;
  align-items: center;
  gap: 18px;
}

.catalog-shell__utilityGroup--center {
  justify-content: center;
}

.catalog-shell__utilityGroup--right {
  justify-content: flex-end;
}

.catalog-shell__utilityLink {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: inherit;
  text-decoration: none;
  white-space: nowrap;
}

.catalog-shell__utilityLink svg {
  width: 16px;
  height: 16px;
}

.catalog-shell__header {
  border-bottom: 1px solid #ececec;
  background: #fff;
}

.catalog-shell__headerInner {
  min-height: 86px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
}

.catalog-shell__logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.catalog-shell__logoFrame {
  width: 94px;
  height: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  background: var(--catalog-blue);
}

.catalog-shell__logoOval {
  width: 76px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--catalog-yellow);
  color: var(--catalog-blue);
  font-weight: 900;
  letter-spacing: 0.08em;
  font-size: 1.35rem;
  line-height: 1;
}

.catalog-shell__menu {
  display: flex;
  align-items: center;
  gap: 32px;
}

.catalog-shell__menuLink {
  color: var(--catalog-text);
  text-decoration: none;
  font-weight: 700;
  font-size: 1rem;
  white-space: nowrap;
}

.catalog-shell__menuLink[aria-current="page"] {
  color: var(--catalog-blue);
}

.catalog-shell__searchForm {
  width: min(340px, 100%);
}

.catalog-shell__search {
  min-height: 54px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto auto;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-radius: 999px;
  background: var(--catalog-panel);
}

.catalog-shell__searchIcon,
.catalog-shell__searchFilter svg,
.catalog-shell__searchSubmit svg,
.catalog-shell__searchClear svg,
.catalog-shell__iconLink svg,
.catalog-footer__locale svg {
  width: 22px;
  height: 22px;
}

.catalog-shell__searchInput {
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--catalog-text);
  font: inherit;
  font-size: 1rem;
  outline: none;
}

.catalog-shell__searchInput::-webkit-search-decoration,
.catalog-shell__searchInput::-webkit-search-cancel-button,
.catalog-shell__searchInput::-webkit-search-results-button,
.catalog-shell__searchInput::-webkit-search-results-decoration {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}

.catalog-shell__searchClear,
.catalog-shell__searchFilter,
.catalog-shell__searchSubmit {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: var(--catalog-text);
  cursor: pointer;
}

.catalog-shell__searchFilter {
  color: var(--catalog-blue);
}

.catalog-shell__searchSubmit {
  background: var(--catalog-yellow);
}

.catalog-shell__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.catalog-shell__iconLink {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: var(--catalog-text);
  text-decoration: none;
}

.catalog-shell__iconLink span {
  display: none;
}

body.history-drawer-open {
  overflow: hidden;
}

body.search-filter-screen-open {
  overflow: hidden;
}

body.finder-tag-picker-open {
  overflow: hidden;
}

.catalog-history-drawer {
  position: fixed;
  inset: 0;
  z-index: 160;
}

.catalog-history-drawer[hidden] {
  display: none;
}

.catalog-history-drawer__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(17, 17, 17, 0.28);
  opacity: 0;
  cursor: pointer;
  transition: opacity 180ms ease;
}

.catalog-history-drawer__panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(420px, 100vw);
  height: 100%;
  display: flex;
  flex-direction: column;
  background: #fff;
  border-left: 1px solid #ececec;
  box-shadow: var(--catalog-shadow);
  transform: translateX(100%);
  transition: transform 220ms ease;
}

.catalog-history-drawer[data-open="true"] .catalog-history-drawer__backdrop {
  opacity: 1;
}

.catalog-history-drawer[data-open="true"] .catalog-history-drawer__panel {
  transform: translateX(0);
}

.catalog-history-drawer__header {
  padding: 22px 24px 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid #ececec;
}

.catalog-history-drawer__heading {
  display: grid;
  gap: 6px;
}

.catalog-history-drawer__eyebrow {
  margin: 0;
  color: var(--catalog-blue);
  font-size: 0.78rem;
  font-weight: 700;
}

.catalog-history-drawer__title {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.2;
}

.catalog-history-drawer__close {
  width: 40px;
  height: 40px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #ececec;
  border-radius: 50%;
  background: #fff;
  color: var(--catalog-text);
  cursor: pointer;
}

.catalog-history-drawer__body {
  padding: 20px 24px 28px;
  display: grid;
  gap: 16px;
  overflow-y: auto;
}

.catalog-history-drawer__lead,
.catalog-history-drawer__count,
.catalog-history-drawer__empty {
  margin: 0;
}

.catalog-history-drawer__lead,
.catalog-history-drawer__count,
.catalog-history-drawer__updated {
  color: var(--retail-muted);
  font-size: 0.88rem;
}

.catalog-history-drawer__list {
  gap: 12px;
}

.catalog-history-drawer__link {
  align-items: flex-start;
}

.catalog-history-drawer__updated {
  flex: 0 0 auto;
  padding-top: 2px;
  text-align: right;
}

.catalog-history-drawer__close:focus-visible,
.catalog-history-drawer__link:focus-visible {
  outline: 2px solid var(--catalog-blue);
  outline-offset: 2px;
}

.catalog-search-filter-screen {
  position: fixed;
  inset: 0;
  z-index: 165;
  display: grid;
  place-items: center;
  padding: 16px;
}

.catalog-search-filter-screen[hidden] {
  display: none;
}

.catalog-search-filter-screen__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(17, 17, 17, 0.24);
  cursor: pointer;
}

.catalog-search-filter-screen__panel {
  position: relative;
  width: min(720px, calc(100vw - 32px));
  max-height: calc(100dvh - 32px);
  background: #fff;
  border: 1px solid #ececec;
  border-radius: 28px;
  box-shadow: var(--catalog-shadow);
  overflow: hidden;
}

.catalog-search-filter-screen__form {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  max-height: inherit;
}

.catalog-search-filter-screen__header {
  padding: 22px 28px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid #ececec;
}

.catalog-search-filter-screen__title {
  margin: 0;
  font-size: 2rem;
  line-height: 1.12;
}

.catalog-search-filter-screen__close {
  width: 40px;
  height: 40px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: #8392a6;
  cursor: pointer;
}

.catalog-search-filter-screen__body {
  padding: 18px 28px 28px;
  display: grid;
  gap: 20px;
  overflow-y: auto;
}

.catalog-search-filter-screen__recent {
  display: grid;
  gap: 12px;
  padding-bottom: 20px;
  border-bottom: 1px solid #ececec;
}

.catalog-search-filter-screen__recentTop {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.catalog-search-filter-screen__recentHeading {
  font-size: 0.88rem;
}

.catalog-search-filter-screen__recentClear {
  border: 0;
  background: transparent;
  color: var(--catalog-blue);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
}

.catalog-search-filter-screen__recentList {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.catalog-search-filter-screen__recentChip {
  min-height: 34px;
  padding: 0 16px;
  border: 1px solid #cfd9e4;
  border-radius: 999px;
  background: #f8fbff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
}

.catalog-search-filter-screen__rows {
  display: grid;
}

.catalog-search-filter-screen__row {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  padding: 16px 0;
  border-bottom: 1px solid #ececec;
}

.catalog-search-filter-screen__label {
  padding-top: 14px;
  color: var(--catalog-text);
  font-size: 0.88rem;
  font-weight: 800;
}

.catalog-search-filter-screen__fieldBody {
  display: grid;
  gap: 8px;
}

.catalog-search-filter-screen__tagHeader {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.catalog-search-filter-screen__tagMore {
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--catalog-blue);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
}

.catalog-search-filter-screen__tagList {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.catalog-search-filter-screen__tagChip {
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.83rem;
  font-weight: 800;
  cursor: pointer;
}

.catalog-search-filter-screen__tagChip[aria-pressed="true"] {
  border-color: var(--catalog-blue);
  background: rgba(0, 88, 163, 0.08);
  color: var(--catalog-blue);
}

.catalog-search-filter-screen__input,
.catalog-search-filter-screen__select {
  width: 100%;
  min-height: 50px;
  padding: 0 16px;
  border: 1px solid #d6dde6;
  border-radius: 14px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.96rem;
}

.catalog-search-filter-screen__input::placeholder {
  color: #a2afbd;
}

.catalog-search-filter-screen__help,
.catalog-search-filter-screen__note {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.78rem;
  line-height: 1.6;
}

.catalog-search-filter-screen__check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--catalog-text);
  font-size: 0.88rem;
}

.catalog-search-filter-screen__check input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: #39b6c8;
}

.catalog-search-filter-screen__priceLabels {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--catalog-text);
  font-size: 0.88rem;
}

.catalog-search-filter-screen__priceTrack {
  position: relative;
  height: 6px;
  margin: 8px 10px 0;
  border-radius: 999px;
  background: #d9e5ec;
}

.catalog-search-filter-screen__priceAccent {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, #63d0df 0%, #34b7ca 100%);
}

.catalog-search-filter-screen__priceThumb {
  position: absolute;
  top: 50%;
  width: 28px;
  height: 28px;
  border: 2px solid #d5dde6;
  border-radius: 50%;
  background: #fff;
  transform: translateY(-50%);
}

.catalog-search-filter-screen__priceThumb:first-of-type {
  left: -6px;
}

.catalog-search-filter-screen__priceThumb:last-of-type {
  right: -6px;
}

.catalog-search-filter-screen__footer {
  padding: 20px 28px 24px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  border-top: 1px solid #ececec;
  background: #fff;
}

.catalog-search-filter-screen__secondary,
.catalog-search-filter-screen__primary {
  min-width: 140px;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 12px;
  font: inherit;
  font-size: 0.96rem;
  font-weight: 800;
  cursor: pointer;
}

.catalog-search-filter-screen__secondary {
  border: 1px solid #bfe0e7;
  background: #fff;
  color: #3aa9ba;
}

.catalog-search-filter-screen__primary {
  border: 0;
  background: #3ab2c2;
  color: #fff;
}

.catalog-search-filter-screen__close:focus-visible,
.catalog-search-filter-screen__recentClear:focus-visible,
.catalog-search-filter-screen__recentChip:focus-visible,
.catalog-search-filter-screen__tagMore:focus-visible,
.catalog-search-filter-screen__tagChip:focus-visible,
.catalog-search-filter-screen__input:focus-visible,
.catalog-search-filter-screen__select:focus-visible,
.catalog-search-filter-screen__secondary:focus-visible,
.catalog-search-filter-screen__primary:focus-visible,
.catalog-shell__searchFilter:focus-visible {
  outline: 2px solid var(--catalog-blue);
  outline-offset: 2px;
}

.catalog-tag-picker {
  position: fixed;
  inset: 0;
  z-index: 170;
  display: grid;
  place-items: center;
  padding: 24px;
}

.catalog-tag-picker[hidden] {
  display: none;
}

.catalog-tag-picker__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(17, 17, 17, 0.32);
  cursor: pointer;
}

.catalog-tag-picker__panel {
  position: relative;
  width: min(760px, calc(100vw - 32px));
  max-height: min(80dvh, 860px);
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #ececec;
  border-radius: 24px;
  box-shadow: var(--catalog-shadow);
  overflow: hidden;
}

.catalog-tag-picker__header {
  padding: 22px 24px 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid #ececec;
}

.catalog-tag-picker__heading {
  display: grid;
  gap: 6px;
}

.catalog-tag-picker__eyebrow {
  margin: 0;
  color: var(--catalog-blue);
  font-size: 0.78rem;
  font-weight: 700;
}

.catalog-tag-picker__title {
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.2;
}

.catalog-tag-picker__body {
  padding: 20px 24px 24px;
  display: grid;
  gap: 16px;
  overflow: hidden;
}

.catalog-tag-picker__lead,
.catalog-tag-picker__count,
.catalog-tag-picker__groupCount,
.catalog-tag-picker__empty {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.catalog-tag-picker__close {
  width: 40px;
  height: 40px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #ececec;
  border-radius: 50%;
  background: #fff;
  color: var(--catalog-text);
  cursor: pointer;
}

.catalog-tag-picker__searchField {
  display: grid;
  gap: 8px;
}

.catalog-tag-picker__searchLabel {
  font-size: 0.82rem;
  font-weight: 800;
}

.catalog-tag-picker__searchInput {
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid var(--catalog-border);
  border-radius: 12px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
}

.catalog-tag-picker__results {
  display: grid;
  gap: 18px;
  overflow-y: auto;
  padding-right: 4px;
}

.catalog-tag-picker__group {
  display: grid;
  gap: 10px;
}

.catalog-tag-picker__groupHeader {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.catalog-tag-picker__groupTitle {
  margin: 0;
  font-size: 0.96rem;
}

.catalog-tag-picker__chipRow {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.catalog-tag-picker__close:focus-visible,
.catalog-tag-picker__searchInput:focus-visible {
  outline: 2px solid var(--catalog-blue);
  outline-offset: 2px;
}

@media (max-width: 640px) {
  .catalog-search-filter-screen {
    padding: 0;
  }

  .catalog-search-filter-screen__panel {
    width: 100vw;
    max-height: 100dvh;
    border: 0;
    border-radius: 0;
  }

  .catalog-search-filter-screen__header,
  .catalog-search-filter-screen__body,
  .catalog-search-filter-screen__footer {
    padding-left: 18px;
    padding-right: 18px;
  }

  .catalog-search-filter-screen__row {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .catalog-search-filter-screen__label {
    padding-top: 0;
  }

  .catalog-search-filter-screen__footer {
    justify-content: stretch;
    flex-direction: column-reverse;
  }

  .catalog-search-filter-screen__secondary,
  .catalog-search-filter-screen__primary {
    width: 100%;
  }

  .catalog-history-drawer__panel {
    width: 100vw;
    border-left: 0;
  }

  .catalog-history-drawer__header,
  .catalog-history-drawer__body {
    padding-left: 18px;
    padding-right: 18px;
  }

  .catalog-tag-picker {
    padding: 16px;
  }

  .catalog-tag-picker__panel {
    width: 100%;
    max-height: calc(100dvh - 32px);
  }

  .catalog-tag-picker__header,
  .catalog-tag-picker__body {
    padding-left: 18px;
    padding-right: 18px;
  }
}

.catalog-main {
  padding: 18px 0 64px;
}

.catalog-page-shell {
  display: flex;
  flex-direction: column;
  gap: 42px;
}

.catalog-section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 20px;
}

.catalog-section-heading__eyebrow {
  margin: 0 0 4px;
  color: var(--catalog-blue);
  font-size: 0.82rem;
  font-weight: 700;
}

.catalog-section-heading__title {
  margin: 0;
  font-size: 2rem;
  line-height: 1.12;
}

.catalog-section-heading__link {
  color: var(--catalog-text);
  font-weight: 700;
}

.catalog-home-categories__grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 24px;
}

.catalog-top-category-card {
  display: block;
  text-decoration: none;
  color: inherit;
}

.catalog-top-category-card__body {
  min-height: 188px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
  border-radius: 10px;
  background: #f7f7f7;
}

.catalog-top-category-card__title {
  display: block;
  text-align: center;
  font-size: 0.98rem;
  line-height: 1.4;
}

.catalog-category-visual,
.catalog-artwork {
  position: relative;
  width: 100%;
  margin: 0 auto;
}

.catalog-category-visual {
  height: 88px;
}

.catalog-category-visual__piece,
.catalog-artwork__piece {
  position: absolute;
  display: block;
  border-radius: 3px;
  background: #d9d9d9;
}

.catalog-category-visual[data-variant="storage"] .catalog-category-visual__piece:nth-child(1),
.catalog-category-visual[data-variant="storage"] .catalog-category-visual__piece:nth-child(2),
.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(1),
.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(2),
.catalog-category-visual[data-variant="bed"] .catalog-category-visual__piece:nth-child(1),
.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(1),
.catalog-category-visual[data-variant="box"] .catalog-category-visual__piece:nth-child(1),
.catalog-category-visual[data-variant="bowl"] .catalog-category-visual__piece:nth-child(1) {
  inset: auto;
}

.catalog-category-visual[data-variant="storage"] .catalog-category-visual__piece:nth-child(1) {
  left: 26%;
  top: 12px;
  width: 48%;
  height: 10px;
}

.catalog-category-visual[data-variant="storage"] .catalog-category-visual__piece:nth-child(2) {
  left: 30%;
  top: 20px;
  width: 8px;
  height: 56px;
}

.catalog-category-visual[data-variant="storage"] .catalog-category-visual__piece:nth-child(3) {
  right: 30%;
  top: 20px;
  width: 8px;
  height: 56px;
}

.catalog-category-visual[data-variant="storage"] .catalog-category-visual__piece:nth-child(4) {
  left: 32%;
  top: 36px;
  width: 36%;
  height: 8px;
}

.catalog-category-visual[data-variant="storage"] .catalog-category-visual__piece:nth-child(5) {
  left: 32%;
  top: 56px;
  width: 36%;
  height: 8px;
}

.catalog-category-visual[data-variant="sofa"] .catalog-category-visual__piece:nth-child(1) {
  left: 22%;
  top: 36px;
  width: 56%;
  height: 26px;
  border-radius: 10px;
  background: #d6c75f;
}

.catalog-category-visual[data-variant="sofa"] .catalog-category-visual__piece:nth-child(2) {
  left: 22%;
  top: 28px;
  width: 18%;
  height: 14px;
  background: #d6c75f;
}

.catalog-category-visual[data-variant="sofa"] .catalog-category-visual__piece:nth-child(3) {
  left: 41%;
  top: 28px;
  width: 18%;
  height: 14px;
  background: #d6c75f;
}

.catalog-category-visual[data-variant="sofa"] .catalog-category-visual__piece:nth-child(4) {
  left: 60%;
  top: 28px;
  width: 18%;
  height: 14px;
  background: #d6c75f;
}

.catalog-category-visual[data-variant="sofa"] .catalog-category-visual__piece:nth-child(5) {
  left: 28%;
  top: 60px;
  width: 44%;
  height: 6px;
  background: #a48f3f;
}

.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(1) {
  left: 26%;
  top: 20px;
  width: 48%;
  height: 10px;
  background: #d7bf9a;
}

.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(2),
.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(3) {
  width: 6px;
  height: 40px;
  top: 28px;
  background: #9c7f59;
}

.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(2) {
  left: 32%;
}

.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(3) {
  right: 32%;
}

.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(4) {
  left: 18%;
  top: 30px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #d9c4c8;
}

.catalog-category-visual[data-variant="desk"] .catalog-category-visual__piece:nth-child(5) {
  left: 16%;
  top: 48px;
  width: 20px;
  height: 18px;
  border-radius: 50% 50% 42% 42%;
  background: #d9c4c8;
}

.catalog-category-visual[data-variant="bed"] .catalog-category-visual__piece:nth-child(1) {
  left: 26%;
  top: 24px;
  width: 48%;
  height: 44px;
  border-radius: 10px;
  background: #2f4578;
}

.catalog-category-visual[data-variant="bed"] .catalog-category-visual__piece:nth-child(2) {
  left: 32%;
  top: 32px;
  width: 36%;
  height: 24px;
  background: #ffffff;
}

.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(1) {
  left: 26%;
  top: 20px;
  width: 48%;
  height: 10px;
  background: #b29162;
}

.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(2),
.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(3),
.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(4),
.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(5) {
  width: 6px;
  height: 42px;
  top: 28px;
  background: #a28b67;
}

.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(2) {
  left: 32%;
}

.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(3) {
  left: 44%;
}

.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(4) {
  right: 44%;
}

.catalog-category-visual[data-variant="table"] .catalog-category-visual__piece:nth-child(5) {
  right: 32%;
}

.catalog-category-visual[data-variant="box"] .catalog-category-visual__piece:nth-child(1) {
  left: 26%;
  top: 22px;
  width: 48%;
  height: 40px;
  background: #37633c;
}

.catalog-category-visual[data-variant="box"] .catalog-category-visual__piece:nth-child(2) {
  left: 34%;
  top: 34px;
  width: 14%;
  height: 8px;
  background: #1d2f20;
}

.catalog-category-visual[data-variant="bowl"] .catalog-category-visual__piece:nth-child(1) {
  left: 24%;
  top: 20px;
  width: 52%;
  height: 40px;
  border-radius: 0 0 999px 999px;
  background: #b2c5d5;
}

.catalog-home-heroGrid {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(320px, 1fr);
  gap: 14px;
  align-items: stretch;
}

.catalog-home-heroGrid__stack {
  display: grid;
  gap: 14px;
  grid-auto-rows: 1fr;
}

.catalog-home-heroGrid > [data-home-promo-primary] {
  display: flex;
}

.catalog-home-heroGrid > [data-home-promo-primary] > .catalog-home-promo {
  flex: 1 1 auto;
  min-height: 100%;
}

.catalog-home-heroGrid__stack > .catalog-home-promo {
  min-height: 252px;
}

.catalog-home-promo {
  position: relative;
  min-height: 320px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.75fr);
  align-items: stretch;
  overflow: hidden;
  border-radius: 0;
  color: inherit;
  text-decoration: none;
}

.catalog-home-promo--yellow {
  background: var(--catalog-yellow);
}

.catalog-home-promo--image {
  background: linear-gradient(135deg, #b28b1a 0%, #e6d6a3 42%, #f3f1ea 100%);
}

.catalog-home-promo__content {
  padding: 34px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 10px;
}

.catalog-home-promo__visual {
  padding: 28px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.catalog-home-promo__kicker {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  font-size: 0.82rem;
  font-weight: 700;
}

.catalog-home-promo__title {
  font-size: clamp(2.6rem, 5vw, 7.2rem);
  line-height: 0.92;
  letter-spacing: -0.04em;
}

.catalog-home-promo--image .catalog-home-promo__title {
  font-size: 2.2rem;
  line-height: 1.05;
}

.catalog-home-promo__description {
  margin: 0;
  max-width: 30ch;
  font-size: 1rem;
  line-height: 1.55;
}

.catalog-home-promo__link {
  display: inline-flex;
  width: fit-content;
  margin-top: 8px;
  font-weight: 700;
}

.catalog-home-section {
  display: flex;
  flex-direction: column;
}

.catalog-product-grid {
  display: grid;
  gap: 36px 28px;
}

.catalog-product-grid--home,
.catalog-product-grid--search {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.catalog-product-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}

.plp-product-card.catalog-product-card {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.catalog-product-card__mediaLink,
.catalog-product-card__title {
  color: inherit;
  text-decoration: none;
}

.catalog-product-card__media {
  position: relative;
  min-height: 232px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.catalog-product-card__badge {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
  display: inline-flex;
  padding: 6px 10px;
  background: #e31c79;
  color: #fff;
  font-size: 0.82rem;
  font-weight: 700;
}

.catalog-product-card__mediaVisuals {
  position: relative;
  width: 100%;
  min-height: 232px;
}

.catalog-product-card__mediaVisual {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    opacity 200ms ease,
    transform 220ms ease;
}

.catalog-product-card__mediaVisual--base {
  opacity: 1;
  transform: scale(1);
}

.catalog-product-card__mediaVisual--hover {
  opacity: 0;
  transform: scale(1.03);
}

.catalog-product-card__mainImage,
.catalog-product-card__hoverImage {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  background: #f5f5f5;
}

@media (hover: hover) {
  .catalog-product-card:hover .catalog-product-card__mediaVisuals--hoverSwap .catalog-product-card__mediaVisual--base,
  .catalog-product-card:focus-within .catalog-product-card__mediaVisuals--hoverSwap .catalog-product-card__mediaVisual--base {
    opacity: 0;
    transform: scale(0.985);
  }

  .catalog-product-card:hover .catalog-product-card__mediaVisuals--hoverSwap .catalog-product-card__mediaVisual--hover,
  .catalog-product-card:focus-within .catalog-product-card__mediaVisuals--hoverSwap .catalog-product-card__mediaVisual--hover {
    opacity: 1;
    transform: scale(1);
  }
}

.catalog-product-card__body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.catalog-product-card__title {
  font-weight: 800;
  font-size: 1.08rem;
  line-height: 1.28;
}

.catalog-product-card__subtitle,
.catalog-product-card__detail,
.catalog-product-card__reason,
.catalog-product-card__ratingCount,
.catalog-product-card__swatchLabel {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.92rem;
  line-height: 1.45;
}

.catalog-product-card__price {
  margin: 2px 0 0;
  color: var(--catalog-black);
  font-size: 2.1rem;
  font-weight: 900;
  line-height: 1;
}

.catalog-product-card__ratingRow,
.catalog-product-card__actionRow {
  display: flex;
  align-items: center;
  gap: 10px;
}

.catalog-rating {
  display: inline-flex;
  gap: 1px;
  color: var(--catalog-black);
  font-size: 0.98rem;
  line-height: 1;
}

.catalog-product-card__iconButton {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid var(--catalog-border);
  border-radius: 50%;
  background: #fff;
  color: var(--catalog-black);
  cursor: pointer;
  line-height: 0;
  flex-shrink: 0;
  appearance: none;
}

.catalog-product-card__iconButton svg {
  display: block;
  flex-shrink: 0;
}

.catalog-product-card__iconButton--favorite svg {
  width: 18px;
  height: 18px;
}

.catalog-product-card__iconButton--favorite path {
  fill: #fff;
  transition:
    fill 160ms ease,
    stroke 160ms ease;
}

.catalog-product-card__iconButton--compare {
  border-color: transparent;
  background: var(--catalog-blue);
  color: #fff;
}

.catalog-product-card__iconButton--favorite[aria-pressed="true"] {
  border-color: var(--catalog-border);
  background: #fff;
  color: #c92a4a;
}

.catalog-product-card__iconButton--favorite[aria-pressed="true"] path {
  fill: currentColor;
  stroke: currentColor;
}

.catalog-product-card__iconButton--compare[aria-pressed="true"] {
  box-shadow: 0 0 0 2px rgba(0, 88, 163, 0.12);
}

.catalog-swatch-list {
  display: flex;
  align-items: center;
  gap: 7px;
  min-height: 18px;
}

.catalog-swatch {
  width: 14px;
  height: 28px;
  display: inline-block;
  border: 1px solid var(--catalog-border);
  background: #fff;
}

.catalog-swatch[data-color="white"] {
  background: #f5f4ef;
}

.catalog-swatch[data-color="oak"] {
  background: #b79f73;
}

.catalog-swatch[data-color="black"] {
  background: #303030;
}

.catalog-swatch[data-color="green"] {
  background: #38613f;
}

.catalog-swatch[data-color="red"] {
  background: #a43d34;
}

.catalog-swatch[data-color="blue"] {
  background: #4f74a7;
}

.catalog-swatch[data-color="beige"] {
  background: #d8ccb5;
}

.catalog-swatch-list__more {
  font-size: 1rem;
  font-weight: 700;
  color: var(--catalog-text);
}

.catalog-artwork {
  height: 220px;
  max-width: 220px;
}

.catalog-artwork--compact {
  height: 180px;
}

.catalog-artwork[data-tone="white"] .catalog-artwork__piece {
  background: #f3f2ed;
}

.catalog-artwork[data-tone="sand"] .catalog-artwork__piece {
  background: #d0b48a;
}

.catalog-artwork[data-tone="sage"] .catalog-artwork__piece {
  background: #507b59;
}

.catalog-artwork[data-tone="blue"] .catalog-artwork__piece {
  background: #4c70a0;
}

.catalog-artwork[data-tone="charcoal"] .catalog-artwork__piece {
  background: #535353;
}

.catalog-artwork--ladder .catalog-artwork__piece:nth-child(1),
.catalog-artwork--ladder .catalog-artwork__piece:nth-child(2) {
  top: 12%;
  width: 10px;
  height: 76%;
}

.catalog-artwork--ladder .catalog-artwork__piece:nth-child(1) {
  left: 34%;
}

.catalog-artwork--ladder .catalog-artwork__piece:nth-child(2) {
  right: 34%;
}

.catalog-artwork--ladder .catalog-artwork__piece:nth-child(3),
.catalog-artwork--ladder .catalog-artwork__piece:nth-child(4),
.catalog-artwork--ladder .catalog-artwork__piece:nth-child(5) {
  left: 37%;
  width: 26%;
  height: 10px;
}

.catalog-artwork--ladder .catalog-artwork__piece:nth-child(3) {
  top: 25%;
}

.catalog-artwork--ladder .catalog-artwork__piece:nth-child(4) {
  top: 46%;
}

.catalog-artwork--ladder .catalog-artwork__piece:nth-child(5) {
  top: 67%;
}

.catalog-artwork--cube .catalog-artwork__piece {
  width: 56%;
  height: 62%;
  left: 22%;
  top: 18%;
}

.catalog-artwork--cube .catalog-artwork__piece:nth-child(2),
.catalog-artwork--cube .catalog-artwork__piece:nth-child(3),
.catalog-artwork--cube .catalog-artwork__piece:nth-child(4),
.catalog-artwork--cube .catalog-artwork__piece:nth-child(5) {
  width: 8px;
  height: 62%;
  top: 18%;
  background: rgba(255, 255, 255, 0.7);
}

.catalog-artwork--cube .catalog-artwork__piece:nth-child(2) {
  left: 22%;
}

.catalog-artwork--cube .catalog-artwork__piece:nth-child(3) {
  left: 46%;
}

.catalog-artwork--cube .catalog-artwork__piece:nth-child(4) {
  left: 58%;
}

.catalog-artwork--cube .catalog-artwork__piece:nth-child(5) {
  right: 22%;
}

.catalog-artwork--wide .catalog-artwork__piece:nth-child(1) {
  left: 12%;
  top: 34%;
  width: 76%;
  height: 18px;
}

.catalog-artwork--wide .catalog-artwork__piece:nth-child(2),
.catalog-artwork--wide .catalog-artwork__piece:nth-child(3),
.catalog-artwork--wide .catalog-artwork__piece:nth-child(4),
.catalog-artwork--wide .catalog-artwork__piece:nth-child(5) {
  width: 8px;
  height: 34%;
  top: 42%;
  background: rgba(255, 255, 255, 0.75);
}

.catalog-artwork--wide .catalog-artwork__piece:nth-child(2) {
  left: 18%;
}

.catalog-artwork--wide .catalog-artwork__piece:nth-child(3) {
  left: 40%;
}

.catalog-artwork--wide .catalog-artwork__piece:nth-child(4) {
  right: 40%;
}

.catalog-artwork--wide .catalog-artwork__piece:nth-child(5) {
  right: 18%;
}

.catalog-artwork--wide .catalog-artwork__piece:nth-child(6) {
  left: 14%;
  bottom: 16%;
  width: 72%;
  height: 10px;
}

.catalog-artwork--frame .catalog-artwork__piece:nth-child(1),
.catalog-artwork--frame .catalog-artwork__piece:nth-child(2),
.catalog-artwork--frame .catalog-artwork__piece:nth-child(3),
.catalog-artwork--frame .catalog-artwork__piece:nth-child(4) {
  background: currentColor;
}

.catalog-artwork--frame .catalog-artwork__piece:nth-child(1) {
  left: 18%;
  top: 16%;
  width: 64%;
  height: 8px;
}

.catalog-artwork--frame .catalog-artwork__piece:nth-child(2) {
  left: 18%;
  bottom: 16%;
  width: 64%;
  height: 8px;
}

.catalog-artwork--frame .catalog-artwork__piece:nth-child(3) {
  left: 18%;
  top: 16%;
  width: 8px;
  height: 68%;
}

.catalog-artwork--frame .catalog-artwork__piece:nth-child(4) {
  right: 18%;
  top: 16%;
  width: 8px;
  height: 68%;
}

.catalog-artwork--frame .catalog-artwork__piece:nth-child(5) {
  left: 27%;
  top: 38%;
  width: 46%;
  height: 8px;
  background: rgba(255, 255, 255, 0.75);
}

.catalog-artwork--grid .catalog-artwork__piece:nth-child(1) {
  left: 20%;
  top: 16%;
  width: 60%;
  height: 68%;
}

.catalog-artwork--grid .catalog-artwork__piece:nth-child(2),
.catalog-artwork--grid .catalog-artwork__piece:nth-child(3) {
  width: 8px;
  height: 68%;
  top: 16%;
  background: rgba(255, 255, 255, 0.75);
}

.catalog-artwork--grid .catalog-artwork__piece:nth-child(2) {
  left: 38%;
}

.catalog-artwork--grid .catalog-artwork__piece:nth-child(3) {
  right: 38%;
}

.catalog-artwork--grid .catalog-artwork__piece:nth-child(4),
.catalog-artwork--grid .catalog-artwork__piece:nth-child(5) {
  left: 24%;
  width: 52%;
  height: 8px;
  background: rgba(255, 255, 255, 0.75);
}

.catalog-artwork--grid .catalog-artwork__piece:nth-child(4) {
  top: 38%;
}

.catalog-artwork--grid .catalog-artwork__piece:nth-child(5) {
  top: 60%;
}

.catalog-banner-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.catalog-category-banner {
  display: block;
  color: inherit;
  text-decoration: none;
}

.catalog-category-banner__body {
  min-height: 150px;
  padding: 18px;
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  align-items: center;
  gap: 18px;
  background: #f7f7f7;
}

.catalog-category-banner__title {
  display: block;
  margin-bottom: 6px;
  font-size: 1.04rem;
}

.catalog-category-banner__description,
.catalog-category-banner__meta {
  margin: 0;
  color: var(--catalog-muted);
  line-height: 1.5;
}

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

.catalog-pill-cloud,
.catalog-mini-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.catalog-pill,
.catalog-pill-cloud .hri-pill {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  color: var(--catalog-text);
  background: #fff;
  text-decoration: none;
  font-weight: 700;
}

.hri-mini-link {
  min-width: 0;
  flex: 1 1 240px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--catalog-border);
  background: #fff;
  color: inherit;
  text-decoration: none;
}

.hri-mini-link__icon {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--catalog-panel);
}

.hri-mini-link__icon svg {
  width: 18px;
  height: 18px;
}

.hri-mini-link__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.hri-mini-link__meta {
  color: var(--catalog-muted);
  font-size: 0.88rem;
}

.catalog-search-alert {
  padding: 12px 18px;
  border-left: 4px solid var(--catalog-blue);
  background: #fff;
  box-shadow: var(--catalog-shadow);
  font-size: 0.95rem;
}

.catalog-search-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 28px;
}

.catalog-search-hero__title {
  margin: 0;
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  line-height: 1.02;
}

.catalog-search-hero__summary {
  margin: 14px 0 0;
  max-width: 72ch;
  color: var(--catalog-muted);
  line-height: 1.65;
}

.catalog-search-layout {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 34px;
  align-items: stretch;
}

.catalog-search-sidebar {
  position: sticky;
  top: 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-height: calc(100dvh - 32px);
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 6px;
  scrollbar-gutter: stable;
}

.catalog-search-sidebar .catalog-filter-groups {
  display: none !important;
}

.catalog-search-sidebar__skip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  color: var(--catalog-text);
  text-decoration: none;
}

.catalog-search-sidebar__card {
  padding: 18px;
  border-radius: 20px;
  border: 1px solid #ececec;
  background: #fff;
  box-shadow: var(--catalog-shadow);
}

.catalog-search-sidebar__card--compact {
  padding: 16px 18px;
  box-shadow: none;
}

.catalog-search-sidebar__card h2 {
  margin: 0 0 12px;
  font-size: 1.06rem;
}

.catalog-quick-filters {
  display: grid;
  gap: 16px;
}

.catalog-quick-filters__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.catalog-quick-filters__heading {
  display: grid;
  gap: 4px;
}

.catalog-quick-filters__heading h2 {
  margin: 0;
}

.catalog-quick-filters__eyebrow {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.catalog-quick-filters__clear {
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
}

.catalog-quick-filters__summary {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.catalog-quick-character-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid #ececec;
  border-radius: 18px;
  background: #fbfbfb;
}

.catalog-quick-character-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.catalog-quick-character-card__title {
  font-size: 0.98rem;
}

.catalog-quick-character-card__meta {
  color: var(--catalog-muted);
  font-size: 0.74rem;
  line-height: 1.5;
  text-align: right;
}

.catalog-quick-filter-field {
  display: grid;
  gap: 8px;
}

.catalog-quick-filter-field__labelRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.catalog-quick-filter-field__label {
  font-size: 0.92rem;
}

.catalog-quick-filter-field__link {
  color: var(--catalog-blue);
  font-size: 0.8rem;
  font-weight: 800;
  text-decoration: none;
}

.catalog-quick-filter-chipRow {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.catalog-quick-filter-field__more {
  justify-self: flex-start;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--catalog-blue);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
  cursor: pointer;
}

.catalog-quick-filter-input {
  width: 100%;
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid var(--catalog-border);
  border-radius: 12px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
}

.catalog-quick-filter-input::placeholder {
  color: var(--catalog-muted);
}

.catalog-quick-filter-chip {
  min-height: 36px;
  padding: 0 12px;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.83rem;
  font-weight: 800;
  cursor: pointer;
}

.catalog-quick-filter-chip[aria-pressed="true"] {
  border-color: var(--catalog-blue);
  background: rgba(0, 88, 163, 0.08);
  color: var(--catalog-blue);
}

.catalog-quick-filter-chip.plp-filter-chip--exclude[aria-pressed="true"] {
  border-color: #8d2c27;
  background: #fff1f0;
  color: #8d2c27;
}

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

.catalog-quick-filter-bodyButton {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--catalog-border);
  border-radius: 16px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  cursor: pointer;
}

.catalog-quick-filter-bodyButton[aria-pressed="true"] {
  border-color: var(--catalog-blue);
  background: rgba(0, 88, 163, 0.08);
  color: var(--catalog-blue);
}

.catalog-quick-filter-bodyButton__image {
  display: grid;
  place-items: center;
  aspect-ratio: 1 / 1;
  border-radius: 12px;
  background: #f4f4f4;
  overflow: hidden;
}

.catalog-quick-filter-bodyButton__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.catalog-quick-filter-bodyButton__fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  padding: 8px;
  color: var(--catalog-muted);
  font-size: 0.8rem;
  text-align: center;
}

.catalog-quick-filter-bodyButton__label {
  font-size: 0.8rem;
  font-weight: 800;
  text-align: center;
}

.catalog-quick-filters--articles {
  gap: 18px;
}

.catalog-quick-filters--articles .catalog-search-sidebar__field,
.catalog-search-sidebar__card--compact .catalog-search-sidebar__field {
  margin-top: 0;
}

.catalog-search-sidebar__details {
  padding: 0;
  overflow: hidden;
}

.catalog-search-sidebar__details > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 52px;
  padding: 14px 18px;
  list-style: none;
  cursor: pointer;
  font-size: 0.98rem;
  font-weight: 700;
}

.catalog-search-sidebar__details > summary::-webkit-details-marker {
  display: none;
}

.catalog-search-sidebar__details > summary::after {
  content: "⌄";
  color: var(--catalog-muted);
  transition: transform 180ms ease;
}

.catalog-search-sidebar__details[open] > summary::after {
  transform: rotate(180deg);
}

.catalog-search-sidebar__details > :not(summary) {
  padding: 0 18px 16px;
}

.catalog-search-sidebar__details .catalog-search-tips {
  margin-top: 0;
}

.catalog-inline-search__field,
.catalog-search-sidebar__field input,
.catalog-search-sidebar__field select {
  font: inherit;
}

.catalog-inline-search__field {
  min-height: 50px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  border-radius: 999px;
  border: 2px solid var(--catalog-black);
  background: #fff;
}

.catalog-inline-search__field svg {
  width: 18px;
  height: 18px;
}

.catalog-inline-search__field input {
  width: 100%;
  border: 0;
  background: transparent;
  outline: none;
}

.catalog-inline-search__field button {
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
}

.catalog-inline-search__field button[type="submit"] {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--catalog-yellow);
  font-weight: 700;
}

.catalog-search-sidebar__field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
  font-size: 0.94rem;
  font-weight: 700;
}

.catalog-search-sidebar__field input,
.catalog-search-sidebar__field select {
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid var(--catalog-border);
  border-radius: 12px;
  background: #fff;
}

.catalog-search-modeSwitch {
  display: flex;
  gap: 8px;
}

.catalog-search-modeSwitch button,
.catalog-search-sidebar__actions button,
.catalog-search-results__compare button {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.catalog-search-modeSwitch button[aria-pressed="true"] {
  border-color: var(--catalog-blue);
  background: rgba(0, 88, 163, 0.08);
  color: var(--catalog-blue);
}

.catalog-search-sidebar__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.catalog-search-sidebar__help {
  margin: 10px 0 0;
  color: var(--catalog-muted);
  font-size: 0.88rem;
}

.catalog-search-tips {
  margin: 0;
  padding-left: 18px;
  color: var(--catalog-muted);
  line-height: 1.6;
}

.catalog-filter-groups {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.catalog-filter-groups .plp-filter-panel {
  border-bottom: 1px solid var(--catalog-border);
}

.catalog-filter-groups .plp-filter-panel__heading {
  width: 100%;
  min-height: 56px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 1rem;
  font-weight: 700;
  color: var(--catalog-text);
}

.catalog-filter-groups .plp-filter-panel__heading::after {
  content: "⌄";
  font-size: 1rem;
}

.catalog-filter-groups .plp-filter-panel__body {
  padding: 0 0 16px;
}

.catalog-filter-groups .plp-filter-options {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.catalog-filter-groups .plp-filter-option {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.catalog-filter-groups .plp-filter-option__main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.catalog-filter-groups .plp-filter-option__title {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.catalog-filter-groups .plp-filter-option__meta,
.catalog-filter-groups .plp-filter-option__count,
.catalog-filter-groups .plp-field__help {
  color: var(--catalog-muted);
  font-size: 0.82rem;
}

.catalog-filter-groups .plp-filter-option__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.catalog-filter-groups .plp-filter-chip {
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  background: #fff;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
}

.catalog-filter-groups .plp-filter-chip[aria-pressed="true"] {
  border-color: var(--catalog-blue);
  background: rgba(0, 88, 163, 0.08);
  color: var(--catalog-blue);
}

.catalog-search-results {
  display: flex;
  flex-direction: column;
  gap: 34px;
  min-width: 0;
}

.catalog-search-results__toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}

.catalog-search-results__toolbar h2 {
  margin: 0 0 6px;
  font-size: 1.3rem;
}

.catalog-search-results__toolbar p {
  margin: 0;
  color: var(--catalog-muted);
  line-height: 1.6;
}

.catalog-article-pagination {
  display: grid;
  gap: 12px;
  justify-items: center;
}

.catalog-article-pagination__summary {
  margin: 0;
  color: var(--catalog-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}

.catalog-article-pagination__controls {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.catalog-article-pagination__button {
  min-height: 42px;
  min-width: 42px;
  padding: 0 16px;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
}

.catalog-article-pagination__button.is-current {
  border-color: var(--catalog-blue);
  background: rgba(0, 88, 163, 0.08);
  color: var(--catalog-blue);
}

.catalog-article-pagination__button:disabled {
  opacity: 0.45;
  cursor: default;
}

.catalog-search-results__pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--catalog-panel);
  color: var(--catalog-text);
  font-size: 0.86rem;
  font-weight: 700;
}

.catalog-search-results__compare,
.catalog-search-results__empty {
  padding: 22px;
  border-radius: 18px;
  border: 1px solid #ececec;
  background: #fff;
  box-shadow: var(--catalog-shadow);
}

.catalog-search-results__empty h2 {
  margin: 0 0 10px;
}

.catalog-search-results__empty p {
  margin: 0 0 14px;
  color: var(--catalog-muted);
}

.catalog-search-section {
  display: flex;
  flex-direction: column;
}

.catalog-related-searches {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.relatedSearches__list-item {
  margin: 0;
}

.relatedSearches__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  color: var(--catalog-text);
  text-decoration: none;
  font-weight: 700;
}

.relatedSearches__count {
  color: var(--catalog-muted);
}

.finder-relax-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.finder-relax-item {
  flex: 1 1 220px;
  padding: 12px 14px;
  border-radius: 14px;
  background: #faf5eb;
  border: 1px solid #efd7a8;
}

.finder-relax-btn {
  width: 100%;
  min-height: 42px;
  border: 0;
  border-radius: 999px;
  background: #fff;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.catalog-footer {
  background: #f5f5f5;
  border-top: 1px solid #ececec;
}

.catalog-footer__inner {
  padding: 52px 0 30px;
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.catalog-footer__top {
  display: grid;
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  gap: 40px;
}

.catalog-footer__featured h2 {
  margin: 0 0 14px;
  font-size: 2rem;
  line-height: 1.18;
}

.catalog-footer__featured p {
  margin: 0 0 14px;
  color: var(--catalog-muted);
  line-height: 1.75;
}

.catalog-footer__detailLink {
  display: inline-flex;
  margin-bottom: 16px;
  color: var(--catalog-text);
  font-weight: 700;
}

.catalog-footer__featuredButton {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--catalog-black);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}

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

.catalog-footer__column ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.catalog-footer__link {
  color: var(--catalog-text);
  text-decoration: none;
  line-height: 1.45;
}

.catalog-footer__socialRow,
.catalog-footer__legalRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.catalog-footer__socialList,
.catalog-footer__paymentList,
.catalog-footer__legalLinks {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.catalog-footer__socialBadge,
.catalog-footer__paymentBadge {
  min-width: 36px;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  background: #fff;
  color: var(--catalog-text);
  text-decoration: none;
  font-size: 0.86rem;
  font-weight: 700;
}

.catalog-footer__paymentBadge {
  min-width: 50px;
  border-radius: 8px;
}

.catalog-footer__locale {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--catalog-black);
  color: var(--catalog-text);
  text-decoration: none;
  font-weight: 700;
}

.catalog-footer__copyright,
.catalog-footer__legalLink {
  color: var(--catalog-muted);
  font-size: 0.88rem;
  text-decoration: none;
}

.catalog-footer__legalRow {
  padding-top: 24px;
  border-top: 1px solid #dddddd;
}

@media (max-width: 1320px) {
  .catalog-home-categories__grid,
  .catalog-product-grid--home,
  .catalog-product-grid--search,
  .catalog-banner-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .catalog-shell__headerInner {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "menu actions"
      "search search";
    gap: 18px;
    padding: 18px 0;
  }

  .catalog-shell__actions {
    grid-area: actions;
    justify-content: flex-end;
  }

  .catalog-shell__menu {
    grid-area: menu;
    flex-wrap: wrap;
    gap: 18px 24px;
  }

  .catalog-shell__searchForm {
    grid-area: search;
  }

  .catalog-shell__searchForm {
    grid-area: search;
    width: 100%;
  }
}

@media (max-width: 980px) {
  :root {
    --catalog-shell-width: min(100%, calc(100% - 32px));
  }

  .catalog-shell__utilityInner,
  .catalog-home-heroGrid,
  .catalog-home-assist,
  .catalog-search-layout,
  .catalog-footer__top,
  .catalog-search-hero,
  .catalog-footer__socialRow,
  .catalog-footer__legalRow {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: flex-start;
  }

  .catalog-shell__utilityBar {
    display: none;
  }
  .catalog-search-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }

  .catalog-product-grid--home,
  .catalog-product-grid--search,
  .catalog-home-categories__grid,
  .catalog-banner-row,
  .catalog-footer__groups {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .catalog-home-categories__grid,
  .catalog-product-grid--home,
  .catalog-product-grid--search,
  .catalog-banner-row,
  .catalog-footer__groups {
    grid-template-columns: 1fr;
  }

  .catalog-shell__menu {
    gap: 12px 18px;
  }

  .catalog-shell__menuLink {
    font-size: 0.94rem;
  }

  .catalog-home-promo,
  .catalog-category-banner__body {
    grid-template-columns: 1fr;
  }

  .catalog-home-promo__title {
    font-size: 2.4rem;
  }

  .catalog-search-hero__title,
  .catalog-section-heading__title,
  .catalog-footer__featured h2 {
    font-size: 1.8rem;
  }
}

.catalog-home-search-hero {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 26px;
  padding: 34px;
  border-radius: 24px;
  background: var(--catalog-yellow);
  color: var(--catalog-black);
}

.catalog-home-search-hero__content {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.catalog-home-search-hero__eyebrow {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.catalog-home-search-hero__title {
  margin: 0;
  font-size: clamp(2.4rem, 5vw, 3.7rem);
  line-height: 0.96;
}

.catalog-home-search-hero__description {
  max-width: 46ch;
  margin: 0;
  line-height: 1.6;
}

.catalog-home-search-hero__form {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.catalog-home-search-hero__field {
  flex: 1 1 320px;
}

.catalog-home-search-hero__field input {
  width: 100%;
  min-height: 54px;
  padding: 0 18px;
  border: 1px solid rgba(17, 17, 17, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.84);
  font: inherit;
}

.catalog-home-search-hero__submit {
  min-height: 54px;
  padding: 0 20px;
  border: 0;
  border-radius: 999px;
  background: var(--catalog-black);
  color: #fff;
  font-weight: 700;
}

.catalog-home-search-hero__quick {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.home-showcase-page {
  --home-showcase-hero-height: 232px;
  background: linear-gradient(180deg, #ffffff 0, #f7f8fb 18rem, #eef1f5 100%);
}

.home-showcase-shell {
  width: min(1360px, calc(100% - 24px));
  margin: 0 auto;
  padding: 20px 0 80px;
  display: grid;
  gap: 24px;
}

.home-showcase-hero {
  position: relative;
  display: grid;
  gap: 10px;
}

.home-showcase-hero__nav {
  position: absolute;
  top: calc(var(--home-showcase-hero-height) / 2);
  z-index: 4;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: #273041;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.16);
  transform: translateY(-50%);
  cursor: pointer;
}

.home-showcase-hero__nav span {
  display: block;
  font-size: 1.8rem;
  line-height: 1;
  font-weight: 400;
}

.home-showcase-hero__nav--prev {
  left: calc(50% - 50vw + 12px);
}

.home-showcase-hero__nav--next {
  right: calc(50% - 50vw + 12px);
}

.home-showcase-hero__rail {
  box-sizing: border-box;
  display: flex;
  gap: 10px;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding: 0 0 2px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
}

.home-showcase-hero__rail::-webkit-scrollbar {
  display: none;
}

.home-showcase-hero__item {
  flex: 0 0 auto;
  scroll-snap-align: start;
}

.home-showcase-hero__item--wide {
  width: calc((100vw - 17px) / 3);
}

.home-showcase-hero__item--medium {
  width: calc((100vw - 17px) / 3);
}

.home-showcase-hero__item--poster {
  width: calc((100vw - 17px) / 3);
}

.home-showcase-hero__footer {
  display: grid;
  justify-items: center;
  gap: 8px;
}

.home-showcase-hero__dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.home-showcase-hero__dot {
  width: 7px;
  height: 7px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: #d0d6e2;
}

.home-showcase-hero__dot[aria-pressed="true"] {
  background: #ef6c80;
}

.home-showcase-banner {
  position: relative;
  min-width: 0;
  min-height: var(--home-showcase-hero-height);
  height: var(--home-showcase-hero-height);
  display: grid;
  overflow: hidden;
  border-radius: 0;
  text-decoration: none;
  color: inherit;
  box-shadow: none;
}

.home-showcase-banner:hover,
.home-showcase-product:hover,
.home-showcase-category:hover,
.home-showcase-linkChip:hover {
  transform: translateY(-2px);
}

.home-showcase-banner--spotlight {
  background: #251744;
  color: #ffffff;
}

.home-showcase-banner__media,
.home-showcase-banner__image {
  width: 100%;
  height: 100%;
}

.home-showcase-banner__media {
  position: absolute;
  inset: 0;
}

.home-showcase-banner__image {
  display: block;
  object-fit: cover;
}

.home-showcase-banner__scrim {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(20, 12, 31, 0.08), rgba(20, 12, 31, 0.88)),
    linear-gradient(90deg, rgba(20, 12, 31, 0.82), rgba(20, 12, 31, 0.2));
}

.home-showcase-banner__copy,
.home-showcase-banner__intro {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: end;
  gap: 0.58rem;
  padding: 16px;
}

.home-showcase-banner__badge {
  display: inline-flex;
  width: fit-content;
  min-height: 26px;
  padding: 0 11px;
  align-items: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  color: inherit;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.home-showcase-banner__badge--light {
  background: rgba(237, 93, 113, 0.1);
  color: #d13e5d;
}

.home-showcase-banner__badge--pink {
  background: rgba(255, 92, 141, 0.12);
  color: #d54075;
}

.home-showcase-banner__title {
  display: grid;
  gap: 0.1rem;
  font-size: clamp(2.05rem, 2.85vw, 3.2rem);
  line-height: 0.9;
  letter-spacing: -0.05em;
}

.home-showcase-banner__titleLine {
  display: block;
  white-space: nowrap;
}

.home-showcase-banner__description,
.home-showcase-banner__sideDescription,
.home-showcase-poster__note,
.home-showcase-poster__footerText {
  margin: 0;
  line-height: 1.65;
}

.home-showcase-banner__description {
  max-width: 30ch;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.84rem;
}

.home-showcase-banner__thumbStrip {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 2px;
}

.home-showcase-banner__thumb {
  width: 46px;
  height: 60px;
  overflow: hidden;
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
}

.home-showcase-banner__thumbImage {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.home-showcase-banner__chipRow {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.home-showcase-banner__chip {
  display: inline-flex;
  min-height: 22px;
  align-items: center;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  color: #ffffff;
  font-size: 0.66rem;
  font-weight: 700;
}

.home-showcase-banner--collage,
.home-showcase-banner--poster {
  padding: 16px;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.home-showcase-banner--collage {
  gap: 14px;
  align-content: start;
}

.home-showcase-banner__yearTitle {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  letter-spacing: -0.05em;
}

.home-showcase-banner__yearNumber {
  font-size: clamp(2.35rem, 3vw, 3.35rem);
  line-height: 0.9;
}

.home-showcase-banner__yearLabel {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding-bottom: 5px;
  font-size: 1.2rem;
  font-weight: 800;
}

.home-showcase-banner__sideDescription {
  color: #68758a;
  font-size: 0.84rem;
}

.home-showcase-collage {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.home-showcase-collage__tile {
  position: relative;
  display: block;
  min-height: 64px;
  border-radius: 4px;
  overflow: hidden;
  background: #eef1f5;
}

.home-showcase-collage__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.home-showcase-banner--poster {
  align-content: space-between;
  background:
    linear-gradient(180deg, rgba(248, 250, 255, 0.94), rgba(255, 255, 255, 1)),
    #ffffff;
  border-color: rgba(64, 108, 207, 0.16);
}

.home-showcase-banner--compact {
  align-content: space-between;
  padding: 16px;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.home-showcase-banner--compactDark {
  background: linear-gradient(135deg, #153d63, #254d78);
  border-color: transparent;
  color: #ffffff;
}

.home-showcase-compact__title {
  display: grid;
  gap: 0.12rem;
  font-size: clamp(2.25rem, 3vw, 3.45rem);
  line-height: 0.84;
  letter-spacing: -0.08em;
  font-weight: 900;
}

.home-showcase-banner--compactDark .home-showcase-banner__sideDescription {
  color: rgba(255, 255, 255, 0.78);
}

.home-showcase-poster__headline {
  display: grid;
  gap: 0.15rem;
  margin-top: 2px;
}

.home-showcase-poster__headline span {
  color: #2a5fc9;
  font-size: clamp(2.1rem, 2.95vw, 3.45rem);
  line-height: 0.84;
  letter-spacing: -0.08em;
  font-weight: 900;
}

.home-showcase-poster__note {
  color: #68758a;
}

.home-showcase-poster__footer {
  display: grid;
  gap: 8px;
  align-content: end;
}

.home-showcase-poster__thumb {
  min-height: 74px;
  border-radius: 4px;
  overflow: hidden;
  background: #eef1f5;
}

.home-showcase-micro {
  display: grid;
  justify-items: center;
  gap: 6px;
  padding: 0;
}

.home-showcase-micro__eyebrow {
  margin: 0;
  color: #ff7b34;
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-showcase-micro__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.home-showcase-micro__action {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  color: #273041;
  text-decoration: none;
  font-size: 0.84rem;
  font-weight: 800;
}

.home-showcase-micro__action--accent {
  background: #f46f88;
  border-color: #f46f88;
  color: #ffffff;
}

.home-showcase-section {
  display: grid;
  gap: 16px;
}

.home-showcase-section__head {
  text-align: center;
  padding-top: 2px;
}

.home-showcase-section__head h2 {
  margin: 0;
  color: #2e3544;
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  letter-spacing: -0.04em;
}

.home-showcase-linkGrid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.home-showcase-linkChip {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  border-radius: 4px;
  color: #ffffff;
  text-decoration: none;
  font-size: 0.76rem;
  font-weight: 700;
  transition: transform 160ms ease;
}

.home-showcase-linkChip[data-tone="rose"] { background: #e46086; }
.home-showcase-linkChip[data-tone="blue"] { background: #5b8dde; }
.home-showcase-linkChip[data-tone="green"] { background: #57b88d; }
.home-showcase-linkChip[data-tone="violet"] { background: #8270d9; }
.home-showcase-linkChip[data-tone="yellow"] { background: #d2a93f; }
.home-showcase-linkChip[data-tone="orange"] { background: #e38d58; }
.home-showcase-linkChip[data-tone="pink"] { background: #dc9bd6; }
.home-showcase-linkChip[data-tone="sky"] { background: #70a9d9; }

.home-showcase-productGrid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.home-showcase-product {
  display: grid;
  gap: 12px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  transition: transform 160ms ease;
}

.home-showcase-product__media {
  position: relative;
  display: block;
  aspect-ratio: 0.78;
  border-radius: 4px;
  overflow: hidden;
  background: #eff2f6;
}

.home-showcase-product__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.home-showcase-product__badge {
  position: absolute;
  left: 6px;
  top: 6px;
  display: inline-flex;
  min-height: 22px;
  align-items: center;
  padding: 0 8px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.9);
  color: #d5486c;
  font-size: 0.66rem;
  font-weight: 800;
}

.home-showcase-product__body {
  display: grid;
  gap: 4px;
}

.home-showcase-product__creator,
.home-showcase-product__meta,
.home-showcase-product__detail {
  margin: 0;
  color: #6f7b8d;
  font-size: 0.82rem;
  line-height: 1.45;
}

.home-showcase-product__title {
  color: #222b39;
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.35;
}

.home-showcase-product__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 2px;
}

.home-showcase-product__price {
  color: #e05b65;
  font-size: 0.84rem;
  line-height: 1;
}

.home-showcase-categoryGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.home-showcase-category {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 58px;
  padding: 0 14px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(15, 23, 42, 0.08);
  color: #222b39;
  text-decoration: none;
  box-shadow: none;
  transition: transform 160ms ease;
}

.home-showcase-category__icon {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #f3f6fb;
  color: #76839b;
  flex-shrink: 0;
}

.home-showcase-category__icon svg {
  width: 20px;
  height: 20px;
}

.home-showcase-category__text {
  display: grid;
  gap: 3px;
}

.home-showcase-category__title {
  color: #2b3341;
}

.home-showcase-category__meta {
  color: #7a8698;
  font-size: 0.82rem;
}

.home-showcase-tagCloud {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.home-showcase-tag {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 23, 42, 0.08);
  color: #4f5c72;
  text-decoration: none;
  font-size: 0.84rem;
  font-weight: 700;
}

@media (max-width: 1180px) {
  .home-showcase-hero__item--wide {
    width: min(82vw, 560px);
  }

  .home-showcase-hero__item--medium {
    width: min(82vw, 560px);
  }

  .home-showcase-hero__item--poster {
    width: min(82vw, 560px);
  }

  .home-showcase-productGrid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

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

@media (max-width: 980px) {
  .home-showcase-page {
    --home-showcase-hero-height: 236px;
  }

  .home-showcase-shell {
    width: min(100%, calc(100% - 20px));
    padding-top: 8px;
  }

  .home-showcase-hero__rail {
    padding: 0 10px 2px;
  }

  .home-showcase-productGrid,
  .home-showcase-categoryGrid {
    grid-template-columns: 1fr;
  }

  .home-showcase-hero__item--wide {
    width: min(82vw, 520px);
  }

  .home-showcase-hero__item--medium {
    width: min(82vw, 520px);
  }

  .home-showcase-hero__item--poster {
    width: min(82vw, 520px);
  }

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

@media (max-width: 720px) {
  .contact-simple-card {
    border-radius: 22px;
  }

  .contact-simple-header {
    gap: 0.8rem;
  }

  .contact-simple-header__icon {
    width: 44px;
    height: 44px;
    border-radius: 14px;
  }

  .contact-simple-form__field textarea {
    min-height: 220px;
  }

  .contact-simple-links {
    justify-content: stretch;
  }

  .contact-simple-links a {
    width: 100%;
  }

  .home-showcase-shell {
    width: min(100%, calc(100% - 16px));
    gap: 22px;
  }

  .home-showcase-page {
    --home-showcase-hero-height: auto;
  }

  .home-showcase-hero {
    gap: 12px;
  }

  .home-showcase-hero__nav {
    display: none;
  }

  .home-showcase-hero__rail {
    gap: 12px;
    padding: 0 8px 4px;
    scroll-padding-inline: 8px;
    overscroll-behavior-x: contain;
  }

  .home-showcase-hero__item,
  .home-showcase-hero__item--wide,
  .home-showcase-hero__item--medium,
  .home-showcase-hero__item--poster {
    width: calc(100vw - 16px);
  }

  .home-showcase-banner {
    height: auto;
    min-height: 272px;
    border-radius: 20px;
  }

  .home-showcase-banner--spotlight {
    min-height: 320px;
  }

  .home-showcase-banner--collage,
  .home-showcase-banner--poster,
  .home-showcase-banner--compact {
    min-height: 284px;
  }

  .home-showcase-banner__copy,
  .home-showcase-banner__intro,
  .home-showcase-banner--poster,
  .home-showcase-banner--compact {
    padding: 20px 18px;
  }

  .home-showcase-banner__title {
    font-size: clamp(1.8rem, 9vw, 2.35rem);
    line-height: 0.92;
  }

  .home-showcase-banner__titleLine {
    white-space: normal;
  }

  .home-showcase-banner__sideTitle {
    font-size: 1.55rem;
  }

  .home-showcase-banner__description {
    max-width: none;
    font-size: 0.9rem;
  }

  .home-showcase-banner__thumbStrip,
  .home-showcase-banner__chipRow {
    gap: 8px;
  }

  .home-showcase-banner__thumb {
    width: 42px;
    height: 56px;
  }

  .home-showcase-banner__yearTitle {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }

  .home-showcase-banner__yearNumber {
    font-size: clamp(2.45rem, 13vw, 3rem);
  }

  .home-showcase-banner__yearLabel {
    min-height: 0;
    padding-bottom: 0;
    font-size: 0.96rem;
  }

  .home-showcase-collage {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .home-showcase-collage__tile,
  .home-showcase-poster__thumb {
    min-height: 88px;
    border-radius: 10px;
  }

  .home-showcase-compact__title,
  .home-showcase-poster__headline span {
    font-size: clamp(1.85rem, 9vw, 2.45rem);
  }

  .home-showcase-section__head {
    text-align: left;
    padding-inline: 4px;
  }

  .home-showcase-linkGrid {
    justify-content: flex-start;
  }

  .home-showcase-linkChip {
    width: 100%;
  }

  .home-showcase-tagCloud {
    justify-content: flex-start;
  }
}

.catalog-product-card__matchTags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.catalog-product-card__matchTag {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: #f2f4f5;
  color: var(--catalog-text);
  font-size: 0.76rem;
  font-weight: 700;
}

.catalog-product-card__metaRow {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.catalog-product-card__metaItem {
  color: var(--catalog-muted);
  font-size: 0.82rem;
}

.catalog-product-card__toolRow {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.catalog-product-card__tool {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  background: #fff;
  color: var(--catalog-text);
  font-size: 0.84rem;
  font-weight: 700;
  text-decoration: none;
}

.catalog-product-card__tool--button {
  cursor: pointer;
  font: inherit;
}

.catalog-affinity-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.catalog-affinity-link {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: #f2f4f5;
  color: var(--catalog-text);
  text-decoration: none;
  font-size: 0.82rem;
  font-weight: 700;
}

.catalog-search-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.catalog-search-hero__scope {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 8px;
}

.catalog-search-hero__scopeHeader {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.catalog-search-hero__scopeHeader strong {
  font-size: 0.9rem;
}

.catalog-search-hero__scopeHeader button {
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
}

.catalog-search-hero__link {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--catalog-black);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}

.catalog-search-hero__link--secondary {
  background: #fff;
  color: var(--catalog-text);
  border: 1px solid var(--catalog-border);
}

.catalog-builder-shell {
  padding: 24px 0 80px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.catalog-pill--muted {
  opacity: 0.82;
}

.catalog-promoted-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.catalog-promoted-filter {
  min-height: 40px;
  padding: 0 14px;
  border: 1px solid var(--catalog-border);
  border-radius: 999px;
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.86rem;
  font-weight: 700;
}

.catalog-search-empty-grid {
  margin-top: 20px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.catalog-search-empty-grid__column {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.catalog-search-empty-grid__column h3 {
  margin: 0;
  font-size: 0.96rem;
}

.catalog-builder-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  padding: 24px 0 8px;
  align-items: end;
}

.catalog-builder-hero__title {
  margin: 0;
  font-size: clamp(2.1rem, 4vw, 3rem);
  line-height: 1.02;
}

.catalog-builder-hero__summary {
  max-width: 66ch;
  margin: 14px 0 0;
  color: var(--catalog-muted);
  line-height: 1.7;
}

.catalog-builder-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.catalog-builder-hero__link {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--catalog-black);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}

.catalog-builder-hero__link--secondary {
  background: #fff;
  color: var(--catalog-text);
  border: 1px solid var(--catalog-border);
}

.catalog-builder-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(320px, 0.8fr);
  gap: 26px;
  align-items: start;
}

.catalog-builder-main {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.catalog-builder-card {
  padding: 24px;
  border-radius: 24px;
  border: 1px solid var(--catalog-border);
  background: #fff;
  box-shadow: 0 18px 40px rgba(17, 17, 17, 0.06);
}

.catalog-builder-card--sticky {
  position: sticky;
  top: 24px;
}

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

.catalog-builder-groups {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.catalog-builder-group {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.catalog-builder-group__title {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.catalog-builder-group__description {
  color: var(--catalog-muted);
  font-size: 0.9rem;
}

.catalog-builder-group__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.catalog-builder-chip {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--catalog-border);
  background: #fff;
  color: var(--catalog-text);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 700;
}

.catalog-builder-chip.is-active {
  border-color: var(--catalog-black);
  background: #111;
  color: #fff;
}

.catalog-builder-preview__summary {
  margin: 0 0 18px;
  color: var(--catalog-muted);
  line-height: 1.6;
}

.catalog-builder-preview__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.catalog-builder-preview__primary,
.catalog-builder-preview__actions button {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--catalog-black);
  background: #fff;
  color: var(--catalog-text);
  text-decoration: none;
  font: inherit;
  font-weight: 700;
}

.catalog-builder-preview__primary {
  background: var(--catalog-black);
  color: #fff;
}

@media (max-width: 980px) {
  .catalog-search-empty-grid,
  .catalog-builder-hero,
  .catalog-builder-layout,
  .catalog-builder-fields {
    grid-template-columns: 1fr;
  }

  .catalog-builder-card--sticky {
    position: static;
  }
}

@media (max-width: 720px) {
  .catalog-home-search-hero {
    padding: 24px;
  }

  .catalog-home-search-hero__title {
    font-size: 2.2rem;
  }
}

/* ------------------------------
   Editorial Detail Pages
------------------------------ */

.editorial-page {
  --editorial-bg: #f4f7fb;
  --editorial-surface: #ffffff;
  --editorial-surface-soft: #f8fbff;
  --editorial-border: rgba(15, 23, 42, 0.08);
  --editorial-border-strong: rgba(59, 130, 246, 0.2);
  --editorial-text: #0f172a;
  --editorial-muted: #58657a;
  --editorial-accent: #3b82f6;
  --editorial-accent-soft: #eef5ff;
  --editorial-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
  background:
    linear-gradient(180deg, #ffffff 0, #ffffff 10rem, var(--editorial-bg) 10rem, var(--editorial-bg) 100%);
  color: var(--editorial-text);
}

.editorial-page body,
.editorial-page .main,
.editorial-page .section,
.editorial-page .section--tight {
  background: transparent;
}

.editorial-page .nav {
  position: sticky;
  top: 0;
  z-index: 20;
  border-bottom: 1px solid var(--editorial-border);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(14px);
}

.editorial-page .nav__inner {
  min-height: 72px;
}

.editorial-page .nav__brand {
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.editorial-page .nav__link {
  color: var(--editorial-muted);
  font-size: 0.92rem;
}

.editorial-page .nav__link[aria-current="page"],
.editorial-page .nav__link:hover {
  color: var(--editorial-text);
}

.editorial-page .section--tight {
  padding-top: 2.3rem;
  padding-bottom: 4.4rem;
}

.detail-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, 300px);
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
  justify-content: center;
}

.detail-shell--article {
  grid-template-columns: minmax(0, 760px) minmax(250px, 300px);
}

.detail-shell--work {
  grid-template-columns: minmax(0, 780px) minmax(250px, 300px);
}

.detail-primary,
.detail-sidebar {
  min-width: 0;
}

.detail-primary {
  display: grid;
  gap: clamp(1.5rem, 2.4vw, 2.1rem);
}

.detail-sidebar {
  position: static;
  display: grid;
  gap: 1rem;
  align-content: start;
}

.detail-breadcrumb {
  margin: 0;
  color: var(--editorial-muted);
  font-size: 0.88rem;
  line-height: 1.7;
}

.detail-breadcrumb a {
  color: #3973d8;
  text-decoration: none;
}

.detail-breadcrumb a:hover {
  color: #2557b7;
}

.detail-header {
  display: grid;
  gap: 1.1rem;
  padding-bottom: 0.1rem;
  border-bottom: 0;
}

.detail-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  align-items: center;
}

.detail-badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.35rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(59, 130, 246, 0.16);
  background: rgba(59, 130, 246, 0.07);
  color: #285fca;
  font-size: 0.78rem;
  font-weight: 700;
}

.detail-badge--muted {
  border-color: var(--editorial-border);
  background: #f8fafc;
  color: var(--editorial-muted);
}

.editorial-page--article .detail-badge--muted {
  display: none;
}

.detail-title {
  margin: 0;
  max-width: 16ch;
  color: var(--editorial-text);
  font-size: clamp(2.35rem, 4.3vw, 3.4rem);
  line-height: 1.11;
  letter-spacing: -0.045em;
}

.detail-lead {
  margin: 0;
  max-width: 64ch;
  color: var(--editorial-muted);
  font-size: 1rem;
  line-height: 1.9;
}

.detail-byline {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding-top: 0.1rem;
}

.detail-byline__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #eff5ff, #dceaff);
  color: #285fca;
  font-size: 0.88rem;
  font-weight: 800;
}

.detail-byline__body {
  display: grid;
  gap: 0.15rem;
}

.detail-byline__body strong {
  font-size: 0.96rem;
}

.detail-byline__body span {
  color: var(--editorial-muted);
  font-size: 0.9rem;
}

.detail-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.editorial-page .tag,
.editorial-page .pill {
  border-radius: 999px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #f7faff;
  color: #284170;
  box-shadow: none;
}

.editorial-page .btn {
  border-radius: 12px;
  min-height: 46px;
  padding: 0.72rem 1rem;
  font-weight: 700;
  box-shadow: none;
}

.editorial-page .btn--primary {
  background: var(--editorial-accent);
  color: #ffffff;
  border-color: #2f6fd6;
}

.editorial-page .btn--secondary {
  background: #ffffff;
  color: var(--editorial-text);
  border-color: var(--editorial-border);
}

.detail-callout,
.detail-widget,
.detail-cta-band,
.detail-related-card,
.detail-work-card,
.detail-fact {
  border: 1px solid var(--editorial-border);
  background: var(--editorial-surface);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.04);
}

.detail-callout {
  display: grid;
  gap: 0.8rem;
  padding: 1.15rem 1.25rem;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(236, 244, 255, 0.98), rgba(247, 251, 255, 0.98)),
    var(--editorial-surface);
  box-shadow: none;
}

.detail-callout p {
  margin: 0;
  color: var(--editorial-text);
  line-height: 1.85;
}

.detail-callout__eyebrow,
.detail-widget__eyebrow,
.detail-section__eyebrow,
.detail-related__eyebrow,
.editorial-footer__eyebrow {
  margin: 0;
  color: var(--editorial-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.detail-summary-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.7rem;
}

.detail-summary-list li,
.detail-inline-list li {
  color: var(--editorial-text);
  line-height: 1.75;
}

.detail-summary-list li {
  padding-left: 1.1rem;
  position: relative;
}

.detail-summary-list li::before {
  content: "";
  position: absolute;
  top: 0.72rem;
  left: 0;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background: var(--editorial-accent);
}

.detail-prose {
  display: grid;
  gap: 1.45rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.detail-prose h2,
.detail-prose h3 {
  margin: 0;
  color: var(--editorial-text);
  letter-spacing: -0.03em;
}

.detail-prose h2 {
  padding-top: 1.15rem;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  font-size: clamp(1.5rem, 2.5vw, 1.9rem);
}

.detail-prose h3 {
  font-size: 1.2rem;
}

.detail-prose h2:first-of-type {
  padding-top: 0;
  border-top: 0;
}

.detail-prose p,
.detail-prose li {
  margin: 0;
  color: var(--editorial-text);
  line-height: 1.9;
}

.detail-prose ul,
.detail-prose ol {
  margin: 0;
  padding-left: 1.3rem;
  display: grid;
  gap: 0.7rem;
}

.detail-prose figure {
  margin: 0;
  display: grid;
  gap: 0.7rem;
  padding: 0.95rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 20px;
  background: #ffffff;
}

.detail-prose img {
  width: 100%;
  border-radius: 16px;
  border: 0;
}

.detail-prose figcaption {
  color: var(--editorial-muted);
  font-size: 0.92rem;
}

.detail-note-inline {
  padding: 1rem 1.05rem;
  border-radius: 16px;
  background: #edf4ff;
  border: 1px solid rgba(59, 130, 246, 0.14);
}

.editorial-page--article .detail-shell--article {
  grid-template-columns: minmax(0, 820px) minmax(270px, 300px);
  gap: 1rem;
}

.editorial-page--article .detail-primary {
  gap: 1rem;
}

.editorial-page--article .detail-sidebar {
  gap: 0.8rem;
}

.editorial-page--article .detail-header {
  gap: 0.55rem;
}

.editorial-page--article .detail-title {
  max-width: none;
  font-size: clamp(1.8rem, 2.9vw, 2.35rem);
  line-height: 1.04;
  letter-spacing: -0.035em;
}

.editorial-page--article .detail-lead {
  max-width: 62ch;
  font-size: 0.93rem;
  line-height: 1.72;
}

.editorial-page--article .detail-byline {
  gap: 0.65rem;
  padding-top: 0;
}

.editorial-page--article [data-article-meta-tags] {
  display: none;
}

.editorial-page--article .detail-callout {
  gap: 0.55rem;
  padding: 0.95rem 1rem;
  border-radius: 14px;
  background: #f3f8ff;
  border-color: rgba(59, 130, 246, 0.12);
}

.editorial-page--article .detail-callout__eyebrow {
  letter-spacing: 0.02em;
  text-transform: none;
}

.editorial-page--article .detail-summary-list {
  gap: 0.45rem;
}

.editorial-page--article .detail-summary-list li {
  line-height: 1.62;
}

.editorial-page--article .detail-note-inline {
  padding: 0.8rem 0.9rem;
  border-radius: 12px;
  font-size: 0.94rem;
  line-height: 1.75;
}

.editorial-page--article .detail-prose {
  gap: 1rem;
}

.editorial-page--article .detail-prose h2 {
  padding-top: 0.15rem;
  border-top: 0;
  font-size: clamp(1.32rem, 2.1vw, 1.6rem);
}

.editorial-page--article .detail-prose p,
.editorial-page--article .detail-prose li {
  line-height: 1.82;
}

.editorial-page--article .detail-prose figure {
  gap: 0.6rem;
  padding: 0.72rem;
  border-radius: 16px;
}

.editorial-page--article .detail-prose figcaption {
  font-size: 0.85rem;
}

.editorial-page--article .detail-author-card {
  margin-top: 0.15rem;
}

.editorial-page--article .detail-cta-band {
  justify-items: center;
  gap: 0.8rem;
  padding: 1.9rem 1.6rem;
  border-radius: 20px;
  text-align: center;
}

.editorial-page--article .detail-cta-band p {
  max-width: 58ch;
}

.editorial-page--article .detail-cta-band .detail-widget__actions {
  justify-content: center;
}

.editorial-page--article .detail-related {
  gap: 0.85rem;
}

.editorial-page--article .detail-related-grid {
  gap: 0.85rem;
}

.editorial-page--article .detail-related-card__thumb {
  min-height: 136px;
}

.editorial-page--article .detail-widget {
  gap: 0.7rem;
  padding: 0.95rem;
  border-radius: 16px;
}

.editorial-page--article .detail-widget__title {
  font-size: 1rem;
}

.editorial-page--article .detail-widget__text {
  font-size: 0.92rem;
  line-height: 1.7;
}

.editorial-page--article .detail-link-list,
.editorial-page--article .detail-category-list {
  gap: 0.55rem;
}

.editorial-page--article .detail-list-link {
  grid-template-columns: 60px minmax(0, 1fr);
  gap: 0.7rem;
  padding: 0.7rem 0.75rem;
}

.editorial-page--article .detail-list-link__thumb {
  min-height: 54px;
  border-radius: 10px;
}

.editorial-page--article .detail-list-link strong {
  font-size: 0.9rem;
}

.editorial-page--article .detail-list-link span,
.editorial-page--article .detail-category-chip span {
  font-size: 0.8rem;
}

.editorial-page--work .detail-shell--work {
  grid-template-columns: minmax(0, 820px) minmax(270px, 300px);
  gap: 1rem;
}

.editorial-page--work .detail-primary {
  gap: 1.2rem;
}

.editorial-page--work .detail-header {
  gap: 0.8rem;
}

.editorial-page--work .detail-sidebar {
  gap: 0.8rem;
}

.editorial-page--work .detail-title {
  max-width: none;
  font-size: clamp(1.95rem, 3.2vw, 2.6rem);
  line-height: 1.08;
}

.editorial-page--work .detail-lead {
  font-size: 0.95rem;
  line-height: 1.78;
}

.editorial-page--work .detail-work-cover {
  padding: 0.8rem;
  border-radius: 18px;
  box-shadow: none;
}

.editorial-page--work .detail-work-cover--article {
  padding: 0.9rem;
}

.editorial-page--work .pdp-gallery__hero {
  min-height: 360px;
}

.editorial-page--work .pdp-gallery__thumbs,
.editorial-page--work .pdp-gallery__caption {
  display: none;
}

.editorial-page--work .detail-fact-grid {
  gap: 0.55rem;
}

.editorial-page--work .detail-fact {
  padding: 0.75rem 0.8rem;
  border-radius: 12px;
}

.editorial-page--work .detail-callout {
  gap: 0.55rem;
  padding: 0.95rem 1rem;
  border-radius: 14px;
}

.editorial-page--work .detail-section-grid {
  gap: 0.8rem;
}

.editorial-page--work .detail-work-card {
  gap: 0.65rem;
  padding: 1rem;
  border-radius: 16px;
  box-shadow: none;
}

.editorial-page--work .detail-related {
  gap: 0.8rem;
}

.editorial-page--work .storefront-product-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.editorial-page--work .work-card__visual {
  min-height: 118px;
  border-radius: 16px;
}

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

.detail-work-card {
  display: grid;
  gap: 0.8rem;
  padding: 1.15rem 1.2rem;
  border-radius: 22px;
}

.detail-work-card h2,
.detail-work-card h3 {
  margin: 0;
  font-size: 1.15rem;
}

.detail-work-card p,
.detail-work-card li {
  margin: 0;
  line-height: 1.85;
}

.detail-work-card ul {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: 0.5rem;
}

.detail-character-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.8rem;
}

.detail-character-card {
  display: grid;
  gap: 0.7rem;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(15, 23, 42, 0.07);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(248, 250, 252, 0.98), rgba(241, 245, 249, 0.98)),
    #ffffff;
}

.detail-character-card__header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
}

.detail-character-card__iconRow {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.detail-character-card__bodyIcon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: #ffffff;
  border: 1px solid rgba(59, 130, 246, 0.12);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
}

.detail-character-card__bodyIcon img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.detail-character-card__copy {
  display: grid;
  gap: 0.28rem;
}

.detail-character-card__name {
  font-size: 0.98rem;
  line-height: 1.45;
}

.detail-character-card__meta {
  margin: 0;
  color: var(--editorial-muted);
  font-size: 0.84rem;
  line-height: 1.7;
}

.detail-character-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.detail-character-card__chip {
  display: inline-flex;
  align-items: center;
  padding: 0.28rem 0.62rem;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.08);
  color: #2557b7;
  font-size: 0.77rem;
  font-weight: 700;
}

.detail-work-hero {
  display: grid;
  grid-template-columns: minmax(280px, 320px) minmax(0, 1fr);
  gap: clamp(1.4rem, 2.6vw, 2rem);
  align-items: start;
}

.detail-work-cover {
  padding: 0.95rem;
  border-radius: 24px;
}

.detail-work-summary {
  display: grid;
  gap: 1rem;
  align-content: start;
}

.detail-fact-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.detail-fact {
  display: grid;
  gap: 0.25rem;
  padding: 0.95rem 1rem;
  border-radius: 16px;
  background: #f8fafc;
  box-shadow: none;
}

.detail-fact span {
  color: var(--editorial-muted);
  font-size: 0.82rem;
}

.detail-fact strong {
  font-size: 1rem;
  line-height: 1.35;
}

.detail-work-links,
.detail-work-actions,
.detail-work-search-links {
  display: grid;
  gap: 0.75rem;
}

.detail-work-links .btn,
.detail-sidebar .detail-widget__actions .btn {
  width: 100%;
  justify-content: center;
}

.detail-widget {
  display: grid;
  gap: 0.85rem;
  padding: 1.1rem;
  border-radius: 22px;
}

.detail-widget--cta {
  background:
    linear-gradient(180deg, rgba(236, 244, 255, 0.98), rgba(255, 255, 255, 0.98)),
    var(--editorial-surface);
  border-color: rgba(59, 130, 246, 0.12);
}

.detail-widget__title {
  margin: 0;
  font-size: 1.1rem;
  letter-spacing: -0.02em;
}

.detail-widget__text {
  margin: 0;
  color: var(--editorial-muted);
  line-height: 1.8;
}

.detail-widget__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.detail-link-list,
.detail-category-list {
  display: grid;
  gap: 0.7rem;
}

.detail-list-link,
.detail-category-chip {
  display: grid;
  gap: 0.2rem;
  padding: 0.82rem 0.9rem;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.06);
  background: #f8fafc;
  color: inherit;
  text-decoration: none;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease,
    background-color 0.2s ease;
}

.detail-list-link {
  grid-template-columns: 72px minmax(0, 1fr);
  align-items: center;
  gap: 0.8rem;
}

.detail-list-link__thumb {
  display: flex;
  align-items: flex-end;
  min-height: 62px;
  padding: 0.55rem;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border-radius: 12px;
  background: linear-gradient(135deg, #2563eb, #60a5fa);
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.35;
}

.detail-list-link__thumb::before,
.detail-related-card__thumb::before {
  content: "";
  position: absolute;
  inset: auto 10% 12% auto;
  width: 56%;
  height: 48%;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 10px 24px rgba(17, 24, 39, 0.12);
}

.detail-list-link__thumb::after,
.detail-related-card__thumb::after {
  content: "";
  position: absolute;
  inset: 16% auto auto 12%;
  width: 30%;
  height: 18%;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.22);
}

.detail-list-link[data-article-type="レビュー記事"] .detail-list-link__thumb {
  background: linear-gradient(135deg, #0f766e, #2dd4bf);
}

.detail-list-link[data-article-type="使い方ガイド"] .detail-list-link__thumb {
  background: linear-gradient(135deg, #2563eb, #7db2ff);
}

.detail-list-link__body {
  display: grid;
  gap: 0.22rem;
  min-width: 0;
}

.detail-list-link:hover,
.detail-category-chip:hover {
  transform: translateY(-1px);
  border-color: var(--editorial-border-strong);
  background: var(--editorial-accent-soft);
}

.detail-list-link strong {
  font-size: 0.95rem;
  line-height: 1.45;
}

.detail-list-link span,
.detail-category-chip span {
  color: var(--editorial-muted);
  font-size: 0.86rem;
}

.detail-category-chip {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.detail-author-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.95rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.detail-author-card__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #eff5ff, #dceaff);
  color: #285fca;
  font-size: 0.9rem;
  font-weight: 800;
}

.detail-author-card__body {
  display: grid;
  gap: 0.35rem;
}

.detail-author-card__body p {
  margin: 0;
  color: var(--editorial-muted);
  line-height: 1.8;
}

.detail-cta-band {
  display: grid;
  gap: 0.9rem;
  padding: 1.55rem 1.7rem;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(237, 244, 255, 0.98), rgba(247, 251, 255, 0.98)),
    var(--editorial-surface);
  box-shadow: none;
}

.detail-cta-band h2,
.detail-related h2 {
  margin: 0;
  font-size: clamp(1.35rem, 2.4vw, 1.8rem);
  letter-spacing: -0.03em;
}

.detail-cta-band p,
.detail-related p {
  margin: 0;
  color: var(--editorial-muted);
  line-height: 1.85;
}

.detail-related {
  display: grid;
  gap: 1rem;
}

.detail-related-grid,
.detail-related-grid--works {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.detail-related-card {
  display: grid;
  gap: 0;
  overflow: hidden;
  border-radius: 18px;
  color: inherit;
  text-decoration: none;
  box-shadow: none;
}

.detail-related-card__thumb {
  display: flex;
  align-items: flex-end;
  min-height: 154px;
  padding: 0.95rem;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: linear-gradient(135deg, #2563eb, #60a5fa);
  color: #ffffff;
}

.detail-related-card[data-article-type="比較記事"] .detail-related-card__thumb {
  background: linear-gradient(135deg, #2563eb, #60a5fa);
}

.detail-related-card[data-article-type="レビュー記事"] .detail-related-card__thumb {
  background: linear-gradient(135deg, #0f766e, #2dd4bf);
}

.detail-related-card[data-article-type="使い方ガイド"] .detail-related-card__thumb {
  background: linear-gradient(135deg, #1d4ed8, #93c5fd);
}

.detail-related-card__thumb span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.35rem 0.6rem;
  position: relative;
  z-index: 1;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  font-size: 0.78rem;
  font-weight: 700;
}

.detail-related-card__body {
  display: grid;
  gap: 0.55rem;
  padding: 0.95rem 1rem 1rem;
}

.detail-related-card__meta {
  color: var(--editorial-muted);
  font-size: 0.84rem;
}

.detail-related-card__body strong {
  font-size: 1rem;
  line-height: 1.45;
}

.detail-related-card__body p {
  color: var(--editorial-muted);
  font-size: 0.92rem;
  line-height: 1.75;
}

.editorial-page--work .pdp-gallery__hero {
  min-height: 380px;
}

.editorial-page--work .pdp-gallery__visual {
  background: linear-gradient(180deg, #f6f8fc, #edf3fb);
}

.editorial-page--work .pdp-gallery__overlay {
  padding: 1.2rem;
  background: linear-gradient(180deg, rgba(40, 63, 112, 0.04), rgba(40, 63, 112, 0.56));
}

.editorial-page--work .pdp-gallery__overlay strong {
  margin: 0;
  font-size: 1.22rem;
  line-height: 1.2;
}

.editorial-page--work .pdp-gallery__thumb {
  height: 78px;
}

.editorial-page--work .pdp-gallery__caption {
  margin-top: 0.65rem;
  color: var(--editorial-muted);
  font-size: 0.88rem;
  line-height: 1.65;
}

.editorial-page--work .storefront-product-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.editorial-page--work .work-card {
  border-radius: 24px;
  border: 1px solid var(--editorial-border);
  background: var(--editorial-surface);
  box-shadow: none;
}

.editorial-page--work .work-card__visual {
  min-height: 160px;
  border-radius: 20px;
}

.editorial-page--work .work-card__title {
  font-size: 1.1rem;
}

.editorial-footer {
  --editorial-bg: #f4f7fb;
  --editorial-surface: #ffffff;
  --editorial-surface-soft: #f8fbff;
  --editorial-border: rgba(15, 23, 42, 0.08);
  --editorial-border-strong: rgba(59, 130, 246, 0.2);
  --editorial-text: #0f172a;
  --editorial-muted: #58657a;
  --editorial-accent: #3b82f6;
  --editorial-accent-soft: #eef5ff;
  --editorial-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
  border-top: 1px solid var(--editorial-border);
  background: #ffffff;
  color: var(--editorial-text);
}

.editorial-footer__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) repeat(3, minmax(0, 0.7fr));
  gap: 1.4rem;
  padding: 2rem 0 1.2rem;
}

.editorial-footer__brand {
  display: grid;
  gap: 0.85rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.editorial-footer .btn {
  border-radius: 12px;
  min-height: 46px;
  padding: 0.72rem 1rem;
  font-weight: 700;
  box-shadow: none;
}

.editorial-footer .btn--primary {
  background: var(--editorial-accent);
  color: #ffffff;
  border-color: #2f6fd6;
}

.editorial-footer .btn--secondary {
  background: #ffffff;
  color: var(--editorial-text);
  border-color: var(--editorial-border);
}

.editorial-footer__brand h2,
.editorial-footer__column h3 {
  margin: 0;
  letter-spacing: -0.03em;
}

.editorial-footer__brand p {
  margin: 0;
  color: var(--editorial-muted);
  line-height: 1.8;
}

.editorial-footer__column {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

.editorial-footer__links {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.55rem;
}

.editorial-footer__links a {
  color: var(--editorial-muted);
  text-decoration: none;
}

.editorial-footer__links a:hover {
  color: var(--editorial-text);
}

.editorial-footer__bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0 0 2rem;
}

.editorial-footer__legal {
  margin: 0;
  color: var(--editorial-muted);
  font-size: 0.9rem;
}

.editorial-footer__bottom-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
}

.editorial-footer__bottom-links a {
  color: var(--editorial-muted);
  text-decoration: none;
  font-size: 0.9rem;
}

.editorial-footer__bottom-links a:hover {
  color: var(--editorial-text);
}

@media (max-width: 1180px) {
  .detail-shell {
    grid-template-columns: minmax(0, 1fr) 280px;
  }

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

@media (min-width: 981px) {
  .editorial-page--article .detail-title {
    white-space: nowrap;
  }
}

@media (max-width: 980px) {
  .detail-shell,
  .detail-shell--article,
  .detail-shell--work,
  .editorial-page--article .detail-shell--article,
  .editorial-page--work .detail-shell--work,
  .editorial-footer__inner,
  .detail-related-grid,
  .detail-related-grid--works {
    grid-template-columns: 1fr;
  }

  .editorial-page--article .detail-shell--article,
  .editorial-page--work .detail-shell--work {
    gap: 1rem;
  }

  .detail-sidebar {
    position: static;
  }

  .editorial-page--work .storefront-product-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .detail-section-grid,
  .detail-fact-grid {
    grid-template-columns: 1fr;
  }

  .detail-title {
    max-width: none;
  }

  .detail-byline {
    align-items: flex-start;
  }

  .editorial-page--article .detail-cta-band .detail-widget__actions,
  .editorial-page--work .detail-widget__actions {
    display: grid;
  }

  .detail-list-link,
  .editorial-page--article .detail-list-link {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 0.75rem;
  }

  .detail-list-link__thumb,
  .editorial-page--article .detail-list-link__thumb {
    width: 100%;
    min-height: 78px;
    padding: 0.75rem;
    border-radius: 14px;
  }

  .editorial-page--work .pdp-gallery__hero {
    min-height: 240px;
  }

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

  .detail-sidebar .detail-widget__actions {
    display: grid;
  }

  .editorial-footer__bottom {
    align-items: flex-start;
    flex-direction: column;
  }
}
