/* =========================================================
   ShopMaatje design system
   ========================================================= */

:root {
  color-scheme: light;
  --bg: #faf9f6;
  --bg-elevated: #ffffff;
  --surface: #ffffff;
  --surface-strong: #ffffff;
  --surface-sunken: #f4f3ef;
  --ink: #0f0f0f;
  --ink-soft: #1a1a1a;
  --ink-inverse: #fafafa;
  --muted: #6b6b6b;
  --muted-strong: #4a4a4a;
  --line: rgba(15, 15, 15, 0.08);
  --line-strong: rgba(15, 15, 15, 0.14);
  --accent: #e8553d;
  --accent-hover: #d6452e;
  --accent-deep: #a73820;
  --accent-soft: rgba(232, 85, 61, 0.12);
  --accent-soft-strong: rgba(232, 85, 61, 0.18);
  --accent-ink: #ffffff;
  --brand-surface: #0f0f0f;
  --brand-surface-muted: rgba(255, 255, 255, 0.1);
  --brand-surface-muted-hover: rgba(255, 255, 255, 0.16);
  --brand-ink: #fafafa;
  --brand-ink-muted: rgba(255, 255, 255, 0.72);
  --brand-ink-soft: rgba(255, 255, 255, 0.6);
  --brand-line: rgba(255, 255, 255, 0.15);
  --warning: #dc2626;
  --shadow-sm: 0 1px 2px rgba(15, 15, 15, 0.04);
  --shadow: 0 2px 8px rgba(15, 15, 15, 0.05), 0 1px 2px rgba(15, 15, 15, 0.03);
  --shadow-lg: 0 12px 32px rgba(15, 15, 15, 0.08), 0 2px 6px rgba(15, 15, 15, 0.04);
  --radius-xs: 8px;
  --radius-sm: 12px;
  --radius-md: 12px;
  --radius-lg: 18px;
  --radius-full: 999px;
  --btn-sm: 36px;
  --btn-md: 42px;
  --btn-lg: 48px;
  --font-display: "Bricolage Grotesque", -apple-system, BlinkMacSystemFont, "Inter", sans-serif;
  --font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono: ui-monospace, "SF Mono", Menlo, monospace;
  --ease: cubic-bezier(0.25, 0.1, 0.25, 1);
  --transition: all 0.2s var(--ease);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  background: var(--bg);
}

body {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--bg);
  font-size: 0.9375rem;
  line-height: 1.6;
  font-feature-settings: "cv11", "ss01", "ss03";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background-color 0.2s var(--ease), color 0.2s var(--ease);
}

.page-shell {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  padding: 20px 0 80px;
}

.catalog-shell {
  width: min(1440px, calc(100% - 32px));
  margin: 0 auto;
}

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

button {
  font: inherit;
}

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

h1, h2, h3, h4 {
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0;
  color: var(--ink);
}

h1 {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 5.5vw, 4.6rem);
  font-weight: 400;
  letter-spacing: -0.025em;
  line-height: 1;
}

h2 {
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  letter-spacing: -0.022em;
}

h3 {
  font-size: 1.05rem;
  letter-spacing: -0.015em;
}

.display-serif {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: -0.02em;
}

.eyebrow {
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--muted);
  margin: 0 0 10px;
}

.hero-text, .compact-text, .section-heading + * {
  color: var(--muted);
  font-size: 0.975rem;
  line-height: 1.65;
}

.compact-text {
  margin-top: 8px;
  max-width: 56ch;
}

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

.hidden {
  display: none !important;
}

.full-width {
  width: 100%;
  text-align: center;
}

/* ---- Topbar ---- */

.app-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 24px;
  padding: 12px 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  position: sticky;
  top: 12px;
  z-index: 10;
  backdrop-filter: saturate(180%) blur(12px);
}

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

.brand-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: inherit;
  text-decoration: none;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.brand-mark {
  width: 32px;
  height: 32px;
  display: inline-grid;
  place-items: center;
  background: var(--ink);
  color: var(--ink-inverse);
  border-radius: var(--radius-xs);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.brand-name {
  font-size: 1rem;
  letter-spacing: -0.015em;
}

.app-topbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.app-topbar-nav {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* ---- Nav dropdown (hover-activated) ---- */

.nav-dropdown {
  position: relative;
  display: inline-flex;
}

.nav-dropdown::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 10px;
  pointer-events: auto;
}

.nav-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 240px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: 6px;
  z-index: 30;
  animation: nav-dropdown-in 0.12s var(--ease);
}

@keyframes nav-dropdown-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu {
  display: grid;
  gap: 2px;
}

.nav-dropdown-menu:empty {
  display: none !important;
}

.nav-dropdown-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  color: var(--ink);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 500;
  transition: var(--transition);
  white-space: nowrap;
  align-items: center;
}

.nav-dropdown-item:hover {
  background: var(--surface-sunken);
}

.nav-dropdown-item-count {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--surface-sunken);
}

.nav-dropdown-item:hover .nav-dropdown-item-count {
  background: var(--surface);
}

.nav-dropdown-empty {
  padding: 10px 14px;
  font-size: 0.85rem;
  color: var(--muted);
  font-style: italic;
}

@media (max-width: 720px) {
  .nav-dropdown-menu {
    display: none !important;
  }
}

.topbar-menu-button {
  display: none;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--ink);
  transition: var(--transition);
  padding: 0;
}

.topbar-menu-button:hover {
  background: var(--surface-sunken);
}

.topbar-menu-button svg {
  width: 18px;
  height: 18px;
}

.topbar-menu-button .icon-close { display: none; }
.app-topbar.is-open .topbar-menu-button .icon-menu { display: none; }
.app-topbar.is-open .topbar-menu-button .icon-close { display: block; }

.credit-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  border-radius: var(--radius-full);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--muted);
}

.credit-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

.credit-pill strong {
  color: var(--ink);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.credit-label {
  display: none;
}

.theme-toggle {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: var(--radius-sm);
  cursor: pointer;
  color: var(--ink);
  transition: var(--transition);
  flex-shrink: 0;
  padding: 0;
}

.theme-toggle:hover {
  background: var(--surface-sunken);
  border-color: var(--line-strong);
}

.theme-toggle svg {
  width: 16px;
  height: 16px;
}

.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: block; }
[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
[data-theme="dark"] .theme-toggle .icon-moon { display: none; }

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

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  padding: 0 18px;
  min-height: var(--btn-md);
  font-weight: 500;
  font-size: 0.875rem;
  letter-spacing: -0.005em;
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}

.button-primary {
  background: var(--ink);
  color: var(--ink-inverse);
  border-color: var(--ink);
}

.button-primary:hover {
  background: var(--ink-soft);
  transform: translateY(-1px);
}

.button-secondary {
  background: var(--surface);
  color: var(--ink);
  border-color: var(--line-strong);
}

.button-secondary:hover {
  background: var(--surface-sunken);
  border-color: var(--line-strong);
}

.button-ghost {
  background: transparent;
  color: var(--ink-soft);
  border-color: transparent;
}

.button-ghost:hover {
  background: var(--surface-sunken);
  color: var(--ink);
}

.text-action-button {
  border: 0;
  background: transparent;
  padding: 0;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--accent);
  cursor: pointer;
  transition: var(--transition);
}

.text-action-button:hover {
  color: var(--accent-hover);
}

/* ---- Panel / Card base ---- */

.panel-card,
.dashboard-card,
.dashboard-hero,
.pricing-card,
.pricing-detail-card,
.faq-card,
.comparison-card,
.cta-card,
.saved-card,
.activity-item,
.ai-insight-banner,
.auth-intro,
.auth-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}

.panel-card {
  padding: 22px;
}

.panel-title,
.result-brand {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 12px;
}

.panel-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.panel-title-row .panel-title {
  margin: 0;
}

.section {
  margin-bottom: 24px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 32px;
}

.section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 24px;
}

/* =========================================================
   Catalog Page (search + filters + results)
   ========================================================= */

.catalog-layout {
  display: block;
}

.catalog-main {
  display: grid;
  gap: 20px;
  min-width: 0;
}

.catalog-support-grid {
  display: grid;
  gap: 20px;
  margin-top: 12px;
}

/* ---- Search utility bar (Concept A: compact, no hero) ---- */

.hero-search {
  position: relative;
  padding: 28px 0 20px;
  display: grid;
  justify-items: center;
  gap: 14px;
  text-align: center;
  overflow: visible;
}

.hero-search-title,
.hero-search-subtitle {
  display: none;
}

.hero-search-form {
  width: 100%;
  max-width: 820px;
  margin-top: 0;
}

.hero-search-inputs {
  position: relative;
  display: block;
}

.hero-search-form textarea {
  width: 100%;
  min-height: 56px;
  resize: none;
  border-radius: 100px;
  border: 1px solid var(--card-border, #e8e4df);
  padding: 16px 60px 16px 22px;
  font: inherit;
  font-family: var(--font-sans);
  font-size: 0.96rem;
  line-height: 1.45;
  background: var(--surface);
  color: var(--ink);
  transition: var(--transition);
  box-shadow: 0 1px 2px rgba(15, 15, 15, 0.03), 0 6px 18px rgba(15, 15, 15, 0.04);
}

.hero-search-form textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft), 0 6px 18px rgba(232, 85, 61, 0.1);
}

.hero-search-form textarea::placeholder {
  color: var(--muted);
}

.hero-search-button {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  min-height: 40px;
  padding: 0;
  border-radius: 50%;
  background: var(--accent);
  color: var(--accent-ink);
  border: 0;
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  transition: var(--transition);
}

.hero-search-button:hover {
  background: var(--accent-hover);
  transform: translateY(-50%) scale(1.04);
}

.hero-search-button svg {
  width: 18px;
  height: 18px;
}

.hero-suggestions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 6px;
}

.suggestion-chip {
  padding: 8px 16px;
  border-radius: var(--radius-full);
  border: 1px solid var(--line);
  background: var(--surface);
  font: inherit;
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  transition: var(--transition);
}

.suggestion-chip:hover {
  border-color: var(--accent);
  color: var(--accent-deep);
  background: var(--accent-soft);
}

.persona-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-size: 0.82rem;
  color: var(--muted);
  cursor: pointer;
  user-select: none;
}

.persona-toggle input {
  width: 15px;
  height: 15px;
  accent-color: var(--accent);
}

/* ---- Results meta (replaces catalog-header-card + toolbar) ---- */

.results-meta {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  padding: 20px 0 6px;
  margin-top: 8px;
  border-top: 1px solid var(--line);
  padding-top: 28px;
}

.results-meta-left {
  display: grid;
  gap: 2px;
}

.results-meta-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.5rem, 2.4vw, 2.1rem);
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--ink);
}

.results-meta-copy {
  margin: 2px 0 0;
  font-size: 0.9rem;
  color: var(--muted);
  line-height: 1.5;
  max-width: 54ch;
}

.results-meta-range {
  margin: 6px 0 0;
  font-size: 0.78rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
}

.results-meta-right {
  flex-shrink: 0;
}

.sort-control {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.sort-dropdown {
  position: relative;
}

.sort-trigger {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 160px;
  height: var(--btn-md);
  padding: 0 12px 0 14px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  border-radius: var(--radius-sm);
  font: inherit;
  font-weight: 500;
  font-size: 0.88rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink);
  cursor: pointer;
  transition: var(--transition);
  justify-content: space-between;
}

.sort-trigger:hover {
  border-color: var(--line-strong);
  background: var(--surface-sunken);
}

.sort-trigger svg {
  width: 14px;
  height: 14px;
  color: var(--muted);
  transition: transform 0.2s var(--ease);
  flex-shrink: 0;
}

.sort-dropdown.is-open .sort-trigger {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.sort-dropdown.is-open .sort-trigger svg {
  transform: rotate(180deg);
  color: var(--ink);
}

.sort-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 100%;
  padding: 6px;
  margin: 0;
  list-style: none;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-lg);
  z-index: 20;
  display: grid;
  gap: 2px;
  animation: sort-menu-in 0.15s var(--ease);
}

@keyframes sort-menu-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

.sort-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px 9px 32px;
  border-radius: var(--radius-xs);
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  white-space: nowrap;
  letter-spacing: 0;
  text-transform: none;
  position: relative;
  transition: var(--transition);
}

.sort-option:hover,
.sort-option:focus-visible {
  background: var(--surface-sunken);
  color: var(--ink);
  outline: none;
}

.sort-option.is-selected {
  color: var(--ink);
}

.sort-option.is-selected::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 50%;
  width: 12px;
  height: 12px;
  transform: translateY(-50%);
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e8553d' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center / contain no-repeat;
}

[data-theme="dark"] .sort-option.is-selected::before {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff7555' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
}

.results-toolbar-copy {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
}

/* ---- Summary chips ---- */

.summary-chip-wrap {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.summary-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  border-radius: var(--radius-full);
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-size: 0.82rem;
  font-weight: 600;
  border: 0;
}

/* ---- Product grid (Concept A: masonry via CSS columns) ---- */

.catalog-products-grid {
  column-count: 4;
  column-gap: 18px;
  column-fill: balance;
}

@media (max-width: 1280px) {
  .catalog-products-grid {
    column-count: 4;
  }
}

@media (max-width: 1080px) {
  .catalog-products-grid {
    column-count: 3;
  }
}

@media (max-width: 720px) {
  .catalog-products-grid {
    column-count: 2;
    column-gap: 12px;
  }
}

@media (max-width: 480px) {
  .catalog-products-grid {
    column-count: 1;
  }
}

.catalog-products-grid .result-card {
  min-height: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  cursor: pointer;
  overflow: visible;
  display: block;
  gap: 0;
  padding: 0;
  position: relative;
  break-inside: avoid;
  margin-bottom: 28px;
  width: 100%;
}

.catalog-products-grid .result-card > * + * {
  margin-top: 12px;
}

.catalog-products-grid .result-card:hover .result-image {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(15, 15, 15, 0.08);
}

.catalog-products-grid .result-image {
  min-height: 0;
  aspect-ratio: auto;
  background: var(--surface-sunken);
  border-radius: 8px;
  overflow: hidden;
  transition: transform 0.25s var(--ease), box-shadow 0.25s var(--ease);
  position: relative;
  display: block;
}

/* Varied aspect ratios for true editorial masonry feel */
.catalog-products-grid .result-card:nth-child(6n+1) .result-image { aspect-ratio: 3 / 4; }
.catalog-products-grid .result-card:nth-child(6n+2) .result-image { aspect-ratio: 4 / 5; }
.catalog-products-grid .result-card:nth-child(6n+3) .result-image { aspect-ratio: 1 / 1; }
.catalog-products-grid .result-card:nth-child(6n+4) .result-image { aspect-ratio: 3 / 4; }
.catalog-products-grid .result-card:nth-child(6n+5) .result-image { aspect-ratio: 4 / 5; }
.catalog-products-grid .result-card:nth-child(6n+6) .result-image { aspect-ratio: 5 / 7; }

/* First card is featured - spans visually larger */
.catalog-products-grid .result-card:first-child .result-image {
  aspect-ratio: 3 / 5;
}

.catalog-products-grid .result-body {
  padding: 0;
  display: grid;
  gap: 4px;
  align-content: start;
}

.catalog-products-grid .result-head {
  display: grid;
  gap: 2px;
}

.catalog-products-grid .result-head h3 {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: 0.94rem;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.005em;
  margin: 0;
}

.catalog-products-grid .result-brand {
  margin: 0 0 2px;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.catalog-products-grid .result-price {
  font-size: 0.95rem;
  font-family: var(--font-sans);
  font-weight: 600;
  margin: 2px 0 0;
  color: var(--ink);
}

.catalog-products-grid .result-description,
.catalog-products-grid .result-meta-line,
.catalog-products-grid .result-tags,
.catalog-products-grid .result-badges {
  display: none;
}

.catalog-products-grid .result-actions {
  display: none;
}

.catalog-products-grid .favorite-icon-button {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 36px;
  height: 36px;
  font-size: 0.95rem;
  background: rgba(255, 255, 255, 0.82);
  border-color: transparent;
  backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity 0.2s var(--ease), transform 0.2s var(--ease), background 0.2s var(--ease);
  z-index: 2;
}

.catalog-products-grid .favorite-icon-button.is-favorite,
.catalog-products-grid .result-card:hover .favorite-icon-button {
  opacity: 1;
}

.catalog-products-grid .result-card > .favorite-icon-button {
  display: grid;
}

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

.product-card-image-placeholder {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 20px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 500;
  background: var(--surface-sunken);
}

/* Accent tints (for placeholder backgrounds on products) */
.accent-sand {
  background: linear-gradient(135deg, #f2e8d8, #e9dcc6);
}

.accent-clay {
  background: linear-gradient(135deg, #e8d2c0, #d9bfa8);
}

[data-theme="dark"] .accent-sand {
  background: linear-gradient(135deg, #3a342a, #2b2620);
}

[data-theme="dark"] .accent-clay {
  background: linear-gradient(135deg, #3d302a, #2e2420);
}

/* ---- Empty state ---- */

.empty-state-card {
  grid-column: 1 / -1;
  grid-template-columns: 1fr;
  padding: 48px 32px;
  text-align: center;
  border: 1px dashed var(--line-strong) !important;
  background: var(--surface-sunken) !important;
  border-radius: var(--radius-md) !important;
}

.empty-state-card .result-body {
  padding: 0;
  gap: 8px;
  justify-items: center;
}

/* ---- Pagination ---- */

.catalog-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding-top: 12px;
}

.pagination-pages {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: center;
}

.pagination-button {
  min-height: 38px;
  min-width: 84px;
  font-size: 0.82rem;
}

.pagination-page {
  min-width: 36px;
  min-height: 36px;
  border-radius: var(--radius-xs);
  border: 1px solid transparent;
  background: transparent;
  font: inherit;
  font-weight: 500;
  font-size: 0.85rem;
  color: var(--ink-soft);
  cursor: pointer;
  transition: var(--transition);
}

.pagination-page:hover {
  background: var(--surface-sunken);
}

.pagination-page.is-active {
  background: var(--ink);
  color: var(--ink-inverse);
  border-color: var(--ink);
}

/* =========================================================
   AI Filter Bar (chips as AI understanding)
   ========================================================= */

.ai-filter-bar {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 14px 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}

.ai-filter-bar-label {
  font-size: 0.7rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  flex-shrink: 0;
}

.ai-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
}

.ai-filter-chips:empty::before {
  content: "geen specifieke filters afgeleid";
  color: var(--muted);
  font-size: 0.85rem;
  font-style: italic;
}

.ai-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 6px 5px 12px;
  border-radius: var(--radius-full);
  border: 0;
  background: var(--accent-soft);
  color: var(--accent-deep);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
}

.ai-filter-chip:hover {
  background: var(--accent-soft-strong);
}

.ai-filter-chip-close {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  background: rgba(0, 0, 0, 0.08);
  font-size: 0.9rem;
  line-height: 1;
}

[data-theme="dark"] .ai-filter-chip-close {
  background: rgba(255, 255, 255, 0.08);
}

.ai-filter-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
  flex-shrink: 0;
}

.ai-filter-add {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px 6px 10px;
  border: 1px dashed var(--line-strong);
  background: transparent;
  border-radius: var(--radius-full);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--muted-strong);
  cursor: pointer;
  transition: var(--transition);
}

.ai-filter-add svg {
  width: 14px;
  height: 14px;
}

.ai-filter-add:hover {
  border-color: var(--accent);
  color: var(--accent);
  border-style: solid;
}

.ai-filter-bar.is-open .ai-filter-add {
  border-color: var(--accent);
  color: var(--accent);
  border-style: solid;
}

/* Popover with filter groups */

.ai-filter-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: min(440px, calc(100vw - 32px));
  max-height: 70vh;
  overflow-y: auto;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: 22px;
  z-index: 20;
  display: grid;
  gap: 18px;
}

.ai-filter-popover .filter-group + .filter-group {
  margin-top: 0;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

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

.filter-group + .filter-group {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}

.filter-group > span {
  font-weight: 600;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.choice-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.choice {
  border: 1px solid var(--line-strong);
  background: transparent;
  border-radius: var(--radius-full);
  padding: 6px 14px;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  transition: var(--transition);
}

.choice:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.choice.active {
  background: var(--ink);
  color: var(--ink-inverse);
  border-color: var(--ink);
}

/* ---- Price filter ---- */

.price-filter {
  display: grid;
  gap: 14px;
}

.price-input-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.price-input-shell {
  display: flex;
  align-items: center;
  gap: 2px;
  min-width: 0;
  min-height: 40px;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line-strong);
  background: var(--surface);
  transition: var(--transition);
}

.price-input-shell:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.price-prefix {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--muted);
  flex: 0 0 auto;
}

.price-input {
  width: 100%;
  min-width: 0;
  border: none;
  background: transparent;
  padding: 0;
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.15;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  appearance: textfield;
  -moz-appearance: textfield;
}

.price-input:focus {
  outline: none;
}

.price-input::-webkit-outer-spin-button,
.price-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.price-divider {
  color: var(--muted);
  font-size: 0.85rem;
  padding-inline: 2px;
}

.price-range-wrap {
  position: relative;
  height: 28px;
  display: flex;
  align-items: center;
}

.price-track,
.price-selected-track {
  position: absolute;
  height: 3px;
  border-radius: var(--radius-full);
}

.price-track {
  inset-inline: 0;
  background: var(--line-strong);
}

.price-selected-track {
  background: var(--accent);
}

.price-range {
  position: absolute;
  inset-inline: 0;
  width: 100%;
  pointer-events: none;
  appearance: none;
  background: transparent;
  margin: 0;
}

.price-range::-webkit-slider-thumb {
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  background: var(--surface);
  cursor: pointer;
  pointer-events: auto;
  border: 2px solid var(--accent);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}

.price-range::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  background: var(--surface);
  cursor: pointer;
  pointer-events: auto;
  border: 2px solid var(--accent);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}

.price-range::-webkit-slider-runnable-track,
.price-range::-moz-range-track {
  background: transparent;
}

.price-scale {
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

/* =========================================================
   Result card (wide / fallback)
   ========================================================= */

.result-card {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  overflow: hidden;
  min-height: 240px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}

.result-image {
  min-height: 100%;
  background: var(--surface-sunken);
}

.result-body {
  padding: 20px;
  display: grid;
  gap: 12px;
  align-content: start;
}

.result-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.result-brand {
  margin: 0 0 4px;
}

.result-price {
  margin: 0;
  font-weight: 600;
  font-size: 1.15rem;
  letter-spacing: -0.015em;
  font-variant-numeric: tabular-nums;
}

.result-description {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
  font-size: 0.88rem;
  max-width: 56ch;
}

.result-meta-line {
  margin: 0;
  font-size: 0.82rem;
  color: var(--muted);
}

.result-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.result-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--accent-soft);
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.result-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.result-tags span {
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  font-size: 0.76rem;
  font-weight: 500;
  color: var(--muted-strong);
}

.result-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.result-actions .button {
  min-height: 40px;
  padding-inline: 14px;
  font-size: 0.82rem;
}

.favorite-icon-button {
  flex: 0 0 44px;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1;
  cursor: pointer;
  transition: var(--transition);
  display: grid;
  place-items: center;
}

.favorite-icon-button:hover {
  color: var(--accent);
  border-color: var(--accent);
}

.favorite-icon-button.is-favorite {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}


/* =========================================================
   AI insight banner
   ========================================================= */

.ai-insight-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 24px 28px;
  background: var(--accent-soft);
  border-color: var(--accent-soft-strong);
  color: var(--ink);
  flex-wrap: wrap;
}

.ai-insight-banner .panel-title {
  color: var(--accent-deep);
  margin-bottom: 8px;
}

.ai-insight-banner p {
  color: var(--ink-soft);
  font-size: 0.9rem;
  line-height: 1.55;
  margin: 0;
  max-width: 58ch;
}

.ai-insight-banner .banner-actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.ai-insight-banner .button-secondary {
  background: var(--surface);
  color: var(--ink);
  border-color: var(--line-strong);
}

.ai-insight-banner .button-secondary:hover {
  background: var(--surface-sunken);
}

.ai-insight-banner .button-primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.ai-insight-banner .button-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

/* =========================================================
   Favorites Page
   ========================================================= */

.favorites-layout {
  display: grid;
  gap: 24px;
}

.favorites-hero {
  padding: 48px 0 12px;
  display: grid;
  gap: 8px;
  justify-items: start;
  text-align: left;
}

.favorites-hero .eyebrow {
  color: var(--accent);
  margin: 0;
}

.favorites-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.4rem, 4.5vw, 4rem);
  line-height: 1;
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--ink);
}

.favorites-title em {
  font-style: normal;
  color: var(--accent-deep);
}

.favorites-subtitle {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.favorites-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: space-between;
}

.favorites-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  flex: 1;
  min-width: 0;
}

.favorites-tab {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  border-radius: var(--radius-full);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--ink-soft);
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}

.favorites-tab:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.favorites-tab.is-active {
  background: var(--ink);
  color: var(--ink-inverse);
  border-color: var(--ink);
}

.favorites-tab-count {
  font-size: 0.76rem;
  font-weight: 600;
  opacity: 0.7;
  font-variant-numeric: tabular-nums;
}

.favorites-tab-create {
  border-style: dashed;
  color: var(--muted-strong);
  flex-shrink: 0;
}

.favorites-tab-create:hover {
  border-color: var(--accent);
  color: var(--accent-deep);
  border-style: solid;
  background: var(--accent-soft);
}

.favorites-tab-create svg {
  width: 14px;
  height: 14px;
}

.favorites-create-form {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.favorites-create-input {
  flex: 1;
  min-width: 200px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font: inherit;
  font-size: 0.92rem;
  background: var(--surface);
  color: var(--ink);
  transition: var(--transition);
}

.favorites-create-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.favorites-collection-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 0 6px;
  border-top: 1px solid var(--line);
}

.favorites-collection-description {
  margin: 0;
  font-size: 0.88rem;
  color: var(--muted);
}

.favorites-delete-button {
  color: var(--warning);
}

.favorites-delete-button:hover {
  color: #b81e1e;
}

.favorites-empty {
  display: grid;
  justify-items: center;
  gap: 12px;
  padding: 80px 24px;
  text-align: center;
}

.favorites-empty-title {
  font-family: var(--font-display);
  font-size: 1.8rem;
  font-weight: 400;
  margin: 0;
  letter-spacing: -0.02em;
}

.favorites-empty-copy {
  margin: 0;
  max-width: 40ch;
  color: var(--muted);
  font-size: 0.95rem;
}

.favorites-empty .button {
  margin-top: 8px;
}

.favorites-login-required {
  display: grid;
  justify-items: start;
  gap: 14px;
  padding: 72px 0 40px;
  max-width: 560px;
}

.favorites-login-required .eyebrow {
  color: var(--accent);
  margin: 0;
}

.favorites-login-copy {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.55;
}

.favorites-login-actions {
  display: flex;
  gap: 10px;
  margin-top: 8px;
  flex-wrap: wrap;
}

.favorites-login-actions .button {
  min-height: var(--btn-md);
}

/* =========================================================
   Collection Popover (heart → pick collection)
   ========================================================= */

.collection-popover {
  position: absolute;
  min-width: 280px;
  max-width: 320px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: 16px;
  z-index: 50;
  display: grid;
  gap: 12px;
  animation: popover-in 0.15s var(--ease);
}

@keyframes popover-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

.collection-popover-title {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.collection-popover-list {
  display: grid;
  gap: 2px;
  max-height: 240px;
  overflow-y: auto;
}

.collection-option {
  display: grid;
  grid-template-columns: 20px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 10px;
  border: 0;
  background: transparent;
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  text-align: left;
  transition: var(--transition);
}

.collection-option:hover {
  background: var(--surface-sunken);
}

.collection-option-check {
  width: 20px;
  height: 20px;
  border-radius: var(--radius-xs);
  border: 1.5px solid var(--line-strong);
  display: grid;
  place-items: center;
  transition: var(--transition);
}

.collection-option.is-checked .collection-option-check {
  background: var(--accent);
  border-color: var(--accent);
}

.collection-option-check svg {
  width: 12px;
  height: 12px;
  color: var(--accent-ink);
  opacity: 0;
  transition: opacity 0.15s var(--ease);
}

.collection-option.is-checked .collection-option-check svg {
  opacity: 1;
}

.collection-option-count {
  font-size: 0.78rem;
  color: var(--muted);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

.collection-popover-create {
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.collection-popover-create-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 0;
  background: transparent;
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--accent-deep);
  cursor: pointer;
  transition: var(--transition);
  width: 100%;
  text-align: left;
}

.collection-popover-create-trigger:hover {
  background: var(--accent-soft);
}

.collection-popover-create-trigger svg {
  width: 16px;
  height: 16px;
}

.collection-popover-create-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  padding-top: 4px;
}

.collection-popover-create-input {
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  font: inherit;
  font-size: 0.9rem;
  background: var(--surface);
  color: var(--ink);
  transition: var(--transition);
}

.collection-popover-create-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.collection-popover-create-submit {
  min-height: var(--btn-sm);
  padding: 0 14px;
  font-size: 0.85rem;
  background: var(--accent);
  border-color: var(--accent);
  color: var(--accent-ink);
}

.collection-popover-create-submit:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

/* =========================================================
   Modals
   ========================================================= */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(6px);
  display: grid;
  place-items: center;
  padding: 20px;
  z-index: 100;
  animation: modal-fade 0.15s var(--ease);
}

@keyframes modal-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}

.premium-modal,
.product-modal {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 32px;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  animation: modal-slide 0.2s var(--ease);
}

@keyframes modal-slide {
  from { transform: translateY(12px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

.premium-modal {
  width: min(640px, 100%);
}

.premium-modal h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 2rem;
  letter-spacing: -0.02em;
  margin: 6px 0 10px;
}

.product-modal {
  width: min(960px, 100%);
  padding: 0;
}

.product-modal-layout {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 0;
}

.product-modal-visual-wrap {
  background: var(--surface-sunken);
  border-top-left-radius: var(--radius-lg);
  border-bottom-left-radius: var(--radius-lg);
  overflow: hidden;
}

.product-modal-visual {
  min-height: 460px;
  overflow: hidden;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
}

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

.product-modal-image-placeholder {
  display: grid;
  place-items: center;
  width: calc(100% - 40px);
  height: calc(100% - 40px);
  border-radius: var(--radius-sm);
  border: 1px dashed rgba(0, 0, 0, 0.15);
  background: rgba(255, 255, 255, 0.4);
  color: var(--muted);
  font-weight: 500;
  text-align: center;
  padding: 24px;
  font-size: 0.88rem;
}

.product-modal-content {
  display: grid;
  gap: 14px;
  align-content: start;
  padding: 36px;
}

.product-modal-content .eyebrow {
  color: var(--accent);
}

.product-modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.product-modal-head h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 4px 0 0;
  max-width: 20ch;
}

.product-modal-price {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.product-modal-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--radius-sm);
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  margin-top: 4px;
}

.product-modal-meta > div {
  display: grid;
  gap: 2px;
}

.modal-text {
  color: var(--muted);
  line-height: 1.65;
  max-width: 58ch;
  font-size: 0.92rem;
  margin: 0;
}

.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: var(--surface);
  font-size: 1.1rem;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: var(--transition);
  color: var(--ink);
  z-index: 2;
}

.modal-close:hover {
  background: var(--surface-sunken);
  border-color: var(--line-strong);
}

.modal-plan-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 20px 0;
}

.modal-plan {
  padding: 18px;
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}

.modal-plan .plan-name {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  margin: 0 0 8px;
  font-weight: 600;
}

.modal-plan p {
  margin: 0;
  font-size: 0.85rem;
  color: var(--muted);
  line-height: 1.5;
}

.featured-modal-plan {
  background: var(--brand-surface);
  border-color: var(--brand-surface);
}

.featured-modal-plan .plan-name {
  color: var(--accent);
}

.featured-modal-plan p {
  color: var(--brand-ink-muted);
}

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

.modal-actions .button-primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.modal-actions .button-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

/* =========================================================
   Dashboard / Account
   ========================================================= */

.dashboard-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 24px;
  align-items: start;
}

.dashboard-sidebar {
  position: sticky;
  top: 84px;
  display: grid;
  gap: 16px;
}

.dashboard-main {
  display: grid;
  gap: 20px;
  min-width: 0;
}

.dashboard-section {
  display: grid;
  gap: 16px;
}

.dashboard-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.dashboard-hero {
  padding: 36px 32px;
  position: relative;
  overflow: hidden;
}

.dashboard-hero::before {
  content: none;
}

.dashboard-hero > div {
  position: relative;
}

.dashboard-hero .eyebrow {
  color: var(--accent);
}

.dashboard-hero-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 3.2vw, 2.8rem);
  line-height: 1;
  letter-spacing: -0.025em;
  margin: 0 0 10px;
}

.dashboard-hero .hero-text {
  max-width: 50ch;
}

.dashboard-card {
  padding: 26px;
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 100%;
}

.dashboard-card .panel-title {
  color: var(--accent);
  margin-bottom: 6px;
}

.dashboard-number {
  margin: 4px 0 6px;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.6rem, 4.5vw, 4rem);
  line-height: 1;
  letter-spacing: -0.03em;
  font-variant-numeric: tabular-nums;
}

.dashboard-label {
  margin: 4px 0 10px;
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.dashboard-copy {
  margin: 0;
  color: var(--muted);
  line-height: 1.6;
  font-size: 0.9rem;
}

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

.dashboard-button {
  min-height: 42px;
  padding-inline: 18px;
  font-size: 0.86rem;
}

.highlight-card {
  background: var(--accent-soft);
  color: var(--ink);
  border-color: var(--accent-soft-strong);
}

.highlight-card .panel-title {
  color: var(--accent-deep);
}

.highlight-card .dashboard-number {
  color: var(--ink);
}

.highlight-card .dashboard-copy {
  color: var(--ink-soft);
}

.highlight-card .button-primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.highlight-card .button-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.highlight-card .button-secondary {
  background: var(--surface);
  color: var(--ink);
  border-color: var(--line-strong);
}

.highlight-card .button-secondary:hover {
  background: var(--surface-sunken);
}

/* ---- Persona card ---- */

.persona-card {
  padding: 28px;
  display: grid;
  gap: 18px;
}

.persona-card h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.6rem;
  letter-spacing: -0.02em;
  margin: 4px 0 0;
}

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

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

.persona-textarea-wrap {
  grid-column: 1 / -1;
}

.dashboard-heading {
  margin-bottom: 0;
}

.dashboard-heading h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.6rem;
  letter-spacing: -0.02em;
  margin: 4px 0 0;
}

/* ---- Saved grid ---- */

.saved-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

.saved-card {
  overflow: hidden;
  display: grid;
  grid-template-rows: 220px auto;
}

.saved-image {
  min-height: 220px;
  background: var(--surface-sunken);
}

.saved-body {
  padding: 16px 18px 20px;
  display: grid;
  gap: 8px;
}

.saved-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.saved-title {
  margin: 0;
  font-size: 0.98rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.25;
}

.saved-body .result-price {
  font-size: 1.05rem;
}

.saved-favorite-button {
  margin-left: auto;
}

/* ---- Activity ---- */

.activity-list {
  display: grid;
  gap: 8px;
}

.activity-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 22px;
}

.activity-title {
  margin: 0 0 2px;
  font-weight: 500;
  font-size: 0.9rem;
  letter-spacing: -0.005em;
}

.activity-meta {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
}

.activity-credit {
  font-weight: 600;
  color: var(--accent);
  white-space: nowrap;
  font-size: 0.85rem;
  font-variant-numeric: tabular-nums;
}

/* ---- Profile (sidebar) ---- */

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

.profile-avatar {
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  border-radius: var(--radius-sm);
  background: var(--ink);
  color: var(--ink-inverse);
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 400;
  flex-shrink: 0;
}

.profile-name {
  margin: 0 0 2px;
  font-weight: 600;
  font-size: 0.98rem;
  letter-spacing: -0.01em;
}

.profile-meta {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.4;
  word-break: break-word;
}

.profile-preferences {
  display: grid;
  gap: 14px;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.profile-label {
  display: block;
  margin-bottom: 3px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.profile-preferences strong {
  font-weight: 500;
  font-size: 0.88rem;
  color: var(--ink-soft);
}

.profile-edit-form {
  display: grid;
  gap: 12px;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.profile-edit-feedback {
  min-height: 1.2em;
  margin: 0;
  color: var(--accent);
  font-weight: 500;
  font-size: 0.82rem;
}

.profile-logout-button {
  margin-top: 6px;
}

.dashboard-sidebar .panel-card {
  padding: 24px;
}

.sidebar-list {
  margin: 0 0 18px;
  padding-left: 16px;
  color: var(--muted-strong);
  line-height: 1.7;
  font-size: 0.88rem;
}

.sidebar-list li {
  margin-bottom: 4px;
}

/* ---- Premium card ---- */

.premium-card {
  background: var(--accent-soft);
  color: var(--ink);
  border-color: var(--accent-soft-strong);
}

.premium-card .panel-title {
  color: var(--accent-deep);
}

.premium-card p,
.premium-card li {
  color: var(--ink-soft);
}

.premium-card .sidebar-list {
  color: var(--ink-soft);
}

.premium-card .button-primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.premium-card .button-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.dashboard-sidebar .dashboard-actions .dashboard-button,
.profile-edit-form .dashboard-actions .dashboard-button {
  flex: 1 1 140px;
}

/* =========================================================
   Auth pages
   ========================================================= */

.auth-shell {
  padding-bottom: 40px;
}

.auth-layout {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 24px;
  align-items: start;
  margin-top: 20px;
}

.auth-intro,
.auth-card {
  padding: 40px 36px;
}

.auth-intro .eyebrow {
  color: var(--accent);
  margin-bottom: 14px;
}

.auth-intro h1 {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 4vw, 3.4rem);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.025em;
  max-width: 14ch;
  margin: 0 0 16px;
}

.auth-benefits {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 22px;
}

.auth-tabs {
  display: inline-flex;
  gap: 2px;
  padding: 3px;
  border-radius: var(--radius-sm);
  background: var(--surface-sunken);
  border: 1px solid var(--line);
  margin-bottom: 24px;
}

.auth-tab {
  border: none;
  background: transparent;
  color: var(--muted);
  font: inherit;
  font-weight: 500;
  font-size: 0.85rem;
  padding: 8px 16px;
  border-radius: 7px;
  cursor: pointer;
  transition: var(--transition);
}

.auth-tab:hover {
  color: var(--ink-soft);
}

.auth-tab.is-active {
  background: var(--surface);
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}

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

.auth-label {
  font-weight: 500;
  font-size: 0.78rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.auth-input {
  width: 100%;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line-strong);
  padding: 12px 14px;
  font: inherit;
  font-size: 0.92rem;
  background: var(--surface);
  color: var(--ink);
  transition: var(--transition);
  font-family: var(--font-sans);
}

.auth-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.auth-input::placeholder {
  color: var(--muted);
}

.auth-textarea {
  min-height: 100px;
  resize: vertical;
  line-height: 1.5;
}

.auth-footnote {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
}

.auth-form .button {
  margin-top: 6px;
  min-height: 46px;
}

/* =========================================================
   Pricing page
   ========================================================= */

.pricing-section {
  padding: 40px 32px;
}

.pricing-section-heading {
  display: grid;
  gap: 8px;
  margin-bottom: 24px;
}

.pricing-section-heading .eyebrow {
  color: var(--accent);
  margin-bottom: 0;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.pricing-card {
  padding: 28px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 100%;
  gap: 8px;
  position: relative;
  background: var(--surface);
}

.plan-status {
  min-height: 1.2em;
  margin: 0 0 4px;
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.plan-name {
  margin: 0 0 8px;
  font-size: 0.82rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
}

.plan-price {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 2.8rem;
  line-height: 1;
  letter-spacing: -0.03em;
  margin: 0 0 16px;
  color: var(--ink);
}

.plan-price span {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.88rem;
  color: var(--muted);
  font-weight: 500;
  letter-spacing: 0;
  margin-top: 6px;
}

.pricing-card ul {
  padding-left: 18px;
  margin: 0;
  flex: 1;
  line-height: 1.7;
  font-size: 0.88rem;
  color: var(--muted-strong);
}

.pricing-card ul li {
  margin-bottom: 4px;
}

.pricing-card .button {
  margin-top: 24px;
  width: 100%;
  min-height: 48px;
  font-size: 0.88rem;
}

.plan-badge {
  position: absolute;
  top: 20px;
  right: 20px;
  display: inline-block;
  padding: 5px 12px;
  border-radius: var(--radius-full);
  background: var(--accent-soft);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.featured-plan {
  background: var(--brand-surface);
  color: var(--brand-ink);
  border-color: var(--brand-surface);
}

.featured-plan .plan-price {
  color: var(--brand-ink);
}

.featured-plan .plan-name {
  color: var(--accent);
}

.featured-plan .plan-price span {
  color: var(--brand-ink-soft);
}

.featured-plan .plan-status {
  color: var(--accent);
}

.featured-plan ul {
  color: var(--brand-ink-muted);
}

.featured-plan .plan-badge {
  background: var(--accent);
  color: var(--accent-ink);
}

.featured-plan .button-primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.featured-plan .button-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

/* ---- Pack selector ---- */

.pack-selector {
  display: grid;
  gap: 10px;
  width: 100%;
  margin-top: auto;
}

.pack-choice-grid {
  display: grid;
  gap: 6px;
  width: 100%;
}

.pack-choice-button {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-sm);
  background: var(--surface);
  padding: 12px 14px;
  text-align: left;
  font: inherit;
  font-weight: 500;
  font-size: 0.88rem;
  color: var(--ink);
  cursor: pointer;
  transition: var(--transition);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 6px 12px;
}

.pack-choice-button span {
  justify-self: end;
  color: var(--muted);
  font-size: 0.85rem;
  font-weight: 500;
}

.pack-choice-button strong {
  grid-column: 1 / -1;
  justify-self: start;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-top: 2px;
}

.pack-choice-button:hover {
  border-color: var(--ink);
}

.pack-choice-button.is-selected {
  background: var(--brand-surface);
  color: var(--brand-ink);
  border-color: var(--brand-surface);
}

.pack-choice-button.is-selected span {
  color: var(--brand-ink-soft);
}

.pack-choice-button.is-selected strong {
  background: var(--brand-line);
  color: var(--brand-ink);
}

.pricing-cta-button {
  margin-top: 6px !important;
}

/* ---- Pricing detail, comparison, FAQ, CTA ---- */

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

.pricing-detail-card,
.faq-card {
  padding: 28px;
  background: var(--surface);
}

.pricing-detail-card h3,
.faq-card h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.25rem;
  letter-spacing: -0.015em;
  margin-bottom: 10px;
}

.pricing-detail-card p,
.faq-card p {
  font-size: 0.9rem;
  line-height: 1.6;
  margin: 0;
  color: var(--muted-strong);
}

.pricing-detail-section .section-heading h2,
.comparison-section .section-heading h2,
.faq-section .section-heading h2,
.cta-section .section-heading h2,
.cta-card h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 2.8vw, 2.4rem);
  letter-spacing: -0.025em;
  line-height: 1.05;
  max-width: 16ch;
}

.comparison-card {
  overflow: hidden;
  background: var(--surface);
}

.comparison-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 16px;
  padding: 16px 24px;
  border-bottom: 1px solid var(--line);
  line-height: 1.55;
  font-size: 0.9rem;
  color: var(--ink-soft);
}

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

.comparison-row > div:first-child {
  font-weight: 500;
  color: var(--ink);
}

.comparison-row-head {
  background: var(--brand-surface);
  color: var(--brand-ink);
  font-weight: 600;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.comparison-row-head > div:first-child {
  color: var(--brand-ink);
  font-weight: 600;
}

/* ---- CTA ---- */

.cta-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 40px;
  background: var(--brand-surface);
  border-color: var(--brand-surface);
  color: var(--brand-ink);
  flex-wrap: wrap;
}

.cta-card .eyebrow {
  color: var(--accent);
}

.cta-card h2 {
  color: var(--brand-ink);
  margin-bottom: 10px;
}

.cta-card p {
  color: var(--brand-ink-muted);
  max-width: 50ch;
  margin: 0;
}

.cta-card .hero-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.cta-card .button-primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.cta-card .button-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.cta-card .button-ghost {
  color: var(--brand-ink);
}

.cta-card .button-ghost:hover {
  background: var(--brand-surface-muted);
  color: var(--brand-ink);
}

/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 1080px) {
  .catalog-products-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .catalog-layout,
  .dashboard-layout,
  .auth-layout,
  .pricing-grid,
  .pricing-detail-grid,
  .faq-grid,
  .catalog-header-top,
  .catalog-search-card {
    grid-template-columns: 1fr;
  }

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

  .dashboard-sidebar {
    position: static;
  }

  .ai-filter-bar {
    flex-direction: column;
    align-items: stretch;
  }

  .ai-filter-actions {
    margin-left: 0;
    justify-content: space-between;
  }

  .ai-filter-popover {
    right: auto;
    left: 0;
    width: 100%;
  }

  .hero-search {
    padding: 48px 20px 32px;
  }

  .results-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

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

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

  .ai-insight-banner {
    flex-direction: column;
    align-items: flex-start;
  }

  .comparison-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .product-modal-layout,
  .product-modal-meta {
    grid-template-columns: 1fr;
  }

  .product-modal-visual-wrap {
    border-radius: 0;
    border-top-left-radius: var(--radius-lg);
    border-top-right-radius: var(--radius-lg);
  }

  .featured-plan {
    transform: none;
  }

  .cta-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .app-topbar {
    padding: 10px 14px;
  }
}

@media (max-width: 720px) {
  .page-shell,
  .catalog-shell {
    width: calc(100% - 20px);
    padding-top: 12px;
  }

  .app-topbar {
    padding: 10px 14px;
    flex-wrap: nowrap;
  }

  .app-topbar-right {
    flex-wrap: nowrap;
  }

  .topbar-menu-button {
    display: inline-grid;
  }

  .app-topbar-nav {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    left: 0;
    flex-direction: column;
    align-items: stretch;
    padding: 12px;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    gap: 6px;
    z-index: 15;
  }

  .app-topbar {
    position: relative;
  }

  .app-topbar.is-open .app-topbar-nav {
    display: flex;
  }

  .app-topbar-nav .button {
    width: 100%;
    justify-content: flex-start;
    min-height: var(--btn-md);
  }

  .app-topbar-right .credit-pill {
    flex-shrink: 0;
  }

  .section,
  .pricing-section {
    padding: 24px 20px;
  }

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

  .catalog-products-grid .result-image {
    min-height: 220px;
  }

  .panel-card,
  .ai-insight-banner,
  .dashboard-hero,
  .dashboard-card,
  .activity-item,
  .auth-intro,
  .auth-card {
    padding: 22px;
  }

  .catalog-pagination {
    flex-direction: column;
  }

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

  .result-image {
    min-height: 200px;
  }

  h1 {
    font-size: clamp(2rem, 10vw, 3rem);
  }

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

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

  .modal-plan-grid {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   Concept A - Editorial Minimal overrides
   (Masonry grid, pill-shape search bar with inline chips,
   warm off-white palette)
   ========================================================= */

:root {
  --bg: #faf9f7;
  --chip-bg: #f1ede8;
  --card-border: #e8e4df;
}

/* ---- Hero search pill with inline chips ---- */

.hero-search {
  padding: 64px 24px 24px;
  gap: 16px;
}

.hero-search-title {
  font-size: clamp(2.4rem, 4.5vw, 3.6rem);
}

.hero-search-subtitle {
  font-size: 0.98rem;
}

.hero-search-form {
  max-width: 720px;
}

.hero-search-inputs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  background: #fff;
  border: 1.5px solid var(--card-border);
  border-radius: 100px;
  padding: 10px 12px 10px 22px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
  transition: border-color 0.15s var(--ease), box-shadow 0.15s var(--ease);
}

.hero-search-inputs:focus-within {
  border-color: var(--ink);
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.1);
}

.hero-search-form textarea {
  flex: 1;
  min-width: 120px;
  min-height: unset;
  height: 38px;
  max-height: 120px;
  padding: 8px 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  font-size: 0.95rem;
  resize: none;
  line-height: 1.4;
}

.hero-search-form textarea:focus {
  outline: none;
  border: 0;
  box-shadow: none;
}

.hero-search-button {
  position: static;
  width: 40px;
  height: 40px;
  min-height: 40px;
  flex-shrink: 0;
}

.hero-search-button svg {
  width: 16px;
  height: 16px;
}

/* Chips that live inside the search bar (rendered by JS) */
.search-inline-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--chip-bg);
  border: 0;
  border-radius: 100px;
  padding: 5px 10px 5px 12px;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--ink);
  white-space: nowrap;
  cursor: default;
}

.search-inline-chip-close {
  width: 16px;
  height: 16px;
  display: inline-grid;
  place-items: center;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 0.85rem;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  border-radius: 50%;
  transition: background 0.15s var(--ease), color 0.15s var(--ease);
}

.search-inline-chip-close:hover {
  background: rgba(15, 15, 15, 0.08);
  color: var(--ink);
}

/* ---- Hide legacy AI filter bar (chips moved into search bar) ---- */

.ai-filter-bar {
  display: none !important;
}

/* ---- Masonry product grid (Concept A) ---- */

.catalog-products-grid {
  display: block;
  column-count: 4;
  column-gap: 16px;
  grid-template-columns: unset;
}

@media (max-width: 1280px) {
  .catalog-products-grid {
    column-count: 3;
  }
}

@media (max-width: 860px) {
  .catalog-products-grid {
    column-count: 2;
  }
}

@media (max-width: 540px) {
  .catalog-products-grid {
    column-count: 1;
  }
}

.catalog-products-grid .result-card {
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  display: block;
  margin: 0 0 16px;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid transparent;
  transition: border-color 0.15s var(--ease), box-shadow 0.15s var(--ease), transform 0.15s var(--ease);
}

.catalog-products-grid .result-card:hover {
  border-color: var(--card-border);
  box-shadow: 0 8px 24px rgba(15, 15, 15, 0.06);
  transform: translateY(-2px);
}

.catalog-products-grid .result-card:hover .result-image {
  transform: none;
  box-shadow: none;
}

.catalog-products-grid .result-image {
  aspect-ratio: unset;
  min-height: unset;
  border-radius: 0;
  width: 100%;
  overflow: hidden;
}

/* Masonry variation classes (applied by JS in round-robin) */
.catalog-products-grid .result-card.card-tall .result-image {
  height: 420px;
}

.catalog-products-grid .result-card.card-mid .result-image {
  height: 340px;
}

.catalog-products-grid .result-card.card-short .result-image {
  height: 260px;
}

.catalog-products-grid .product-card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.catalog-products-grid .result-body {
  padding: 12px 0 0;
  gap: 4px;
}

.catalog-products-grid .result-head {
  display: grid;
  gap: 2px;
}

.catalog-products-grid .result-head h3 {
  font-size: 0.88rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.catalog-products-grid .result-brand {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 2px;
}

.catalog-products-grid .result-price {
  font-size: 0.9rem;
  font-weight: 600;
  margin: 4px 0 0;
}

/* Heart button bottom-right, always visible but subtle */
.catalog-products-grid .favorite-icon-button {
  top: auto;
  bottom: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  font-size: 0.88rem;
  background: #fff;
  border: 1.5px solid var(--card-border);
  opacity: 1;
  color: var(--muted);
  z-index: 2;
}

.catalog-products-grid .favorite-icon-button:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.catalog-products-grid .favorite-icon-button.is-favorite {
  color: var(--accent);
  border-color: var(--accent);
  background: #fff;
}

/* ---- Results meta: cleaner, less prominent ---- */

.results-meta {
  padding-top: 8px;
  border-bottom: 0;
}

.results-meta-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
}

.results-meta-copy {
  font-size: 0.85rem;
  color: var(--muted);
}

.results-meta-range {
  display: none;
}

/* ========== Feature 1 - Chat-to-refine dock ========== */

.refine-dock {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  z-index: 40;
  width: min(640px, calc(100vw - 32px));
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--card-border);
  border-radius: 22px;
  box-shadow: 0 12px 40px rgba(15, 15, 15, 0.12), 0 2px 6px rgba(15, 15, 15, 0.04);
  transition: transform 0.25s var(--ease), opacity 0.25s var(--ease);
}

.refine-dock.hidden {
  display: none;
}

.refine-dock-suggestions {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 2px 2px 0;
  scrollbar-width: none;
}

.refine-dock-suggestions::-webkit-scrollbar {
  display: none;
}

.refine-suggestion {
  flex-shrink: 0;
  background: var(--chip-bg);
  border: 0;
  border-radius: 100px;
  padding: 6px 12px;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  transition: background 0.15s var(--ease), transform 0.1s var(--ease);
}

.refine-suggestion:hover {
  background: #e8e3dc;
}

.refine-suggestion:active {
  transform: scale(0.96);
}

.refine-dock-form {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 1.5px solid var(--card-border);
  border-radius: 100px;
  padding: 6px 6px 6px 16px;
  transition: border-color 0.15s var(--ease), box-shadow 0.15s var(--ease);
}

.refine-dock-form:focus-within {
  border-color: var(--ink);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

.refine-dock-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  flex-shrink: 0;
}

.refine-dock-icon svg {
  width: 18px;
  height: 18px;
}

.refine-dock-input {
  flex: 1;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  font-family: var(--font-sans);
  font-size: 0.92rem;
  color: var(--ink);
  padding: 8px 0;
}

.refine-dock-input::placeholder {
  color: var(--muted);
}

.refine-dock-submit {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s var(--ease), transform 0.1s var(--ease);
}

.refine-dock-submit:hover {
  background: #d64832;
}

.refine-dock-submit:active {
  transform: scale(0.94);
}

.refine-dock-submit svg {
  width: 16px;
  height: 16px;
}

.refine-dock-status {
  margin: 2px 10px 0;
  font-size: 0.78rem;
  color: var(--muted);
  min-height: 1em;
}

.refine-dock-status.is-thinking::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  margin-right: 6px;
  animation: refine-dot-pulse 1.2s ease-in-out infinite;
  vertical-align: middle;
}

@keyframes refine-dot-pulse {
  0%, 100% { opacity: 0.3; transform: scale(0.85); }
  50% { opacity: 1; transform: scale(1.2); }
}

/* Push page content up a bit so the dock never overlaps last card */
.catalog-shell main {
  padding-bottom: 140px;
}

@media (max-width: 640px) {
  .refine-dock {
    bottom: 16px;
    width: calc(100vw - 24px);
    padding: 8px;
  }
  .refine-dock-input {
    font-size: 0.88rem;
  }
}

/* ========== Feature 2 - Variant selectors (maat & kleur) ========== */

.product-variant-block {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin: 4px 0 20px;
  padding: 18px 0;
  border-top: 1px solid var(--card-border);
  border-bottom: 1px solid var(--card-border);
}

.product-variant-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.product-variant-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.product-variant-hint {
  font-size: 0.72rem;
  color: var(--muted);
  font-style: italic;
}

.product-variant-current {
  font-size: 0.82rem;
  color: var(--ink);
  font-weight: 500;
}

.product-variant-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.variant-pill {
  min-width: 42px;
  height: 38px;
  padding: 0 14px;
  border: 1.5px solid var(--card-border);
  background: #fff;
  border-radius: 100px;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  transition: border-color 0.15s var(--ease), background 0.15s var(--ease), transform 0.1s var(--ease);
}

.variant-pill:hover:not(.is-disabled) {
  border-color: var(--ink);
}

.variant-pill[aria-checked="true"] {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.variant-pill:active:not(.is-disabled) {
  transform: scale(0.96);
}

.variant-pill.is-disabled {
  opacity: 0.4;
  cursor: not-allowed;
  text-decoration: line-through;
  text-decoration-color: rgba(0, 0, 0, 0.35);
  text-decoration-thickness: 1.5px;
}

.variant-swatch {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--swatch, #ddd);
  border: 2px solid #fff;
  box-shadow: 0 0 0 1.5px var(--card-border);
  cursor: pointer;
  padding: 0;
  transition: box-shadow 0.15s var(--ease), transform 0.1s var(--ease);
  position: relative;
}

.variant-swatch:hover:not(.is-disabled) {
  box-shadow: 0 0 0 1.5px var(--ink);
}

.variant-swatch.is-selected {
  box-shadow: 0 0 0 2px var(--accent);
}

.variant-swatch:active:not(.is-disabled) {
  transform: scale(0.92);
}

.variant-swatch.is-disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.variant-swatch.is-disabled::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-top: 1.5px solid rgba(0, 0, 0, 0.45);
  transform: rotate(-45deg);
  transform-origin: center;
  top: 50%;
  left: 0;
  right: 0;
  height: 0;
}

/* ========================================================= */
/* ========== Concept A v2 - app-wide consistency ========== */
/* =========================================================
   Scope: rolls Concept A (warm editorial minimal) out to:
   - all pages (favorites, account, login, results)
   - product modal
   - legacy cards/panels
   ========================================================= */

:root {
  --bg: #faf9f7;
  --surface-sunken: #f1ede8;
  --line: rgba(15, 15, 15, 0.06);
  --line-strong: rgba(15, 15, 15, 0.10);
  --card-border: #e8e4df;
  --chip-bg: #f1ede8;
}

body {
  background: var(--bg);
}

/* Topbar: flat, transparent, no hard border on scroll */
.app-topbar {
  background: transparent;
  border-bottom: 0;
  padding-top: 14px;
  padding-bottom: 14px;
}

.brand-mark {
  background: var(--ink);
  color: #fff;
  border-radius: 8px;
  font-family: var(--font-display);
  font-weight: 600;
}

.brand-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: -0.02em;
  color: var(--accent-deep);
}

.brand-name::first-letter {
  color: var(--accent-deep);
}

.app-topbar {
  border-bottom: 1px solid var(--card-border, #e8e4df);
  padding-top: 16px;
  padding-bottom: 16px;
  background: var(--bg, #faf9f7);
}

/* Eyebrow everywhere: muted + editorial, not bright red */
.eyebrow {
  color: var(--muted);
  letter-spacing: 0.14em;
  font-size: 0.68rem;
  font-weight: 600;
}

/* Exception: keep eyebrow colored only on marketing CTAs where it signals emphasis */
.favorites-hero .eyebrow,
.auth-intro .eyebrow,
.dashboard-hero .eyebrow,
.cta-card .eyebrow,
.pricing-section-heading .eyebrow {
  color: var(--accent);
}

/* Product modal: editorial refinement */
.product-modal {
  border-radius: 20px;
  border: 1px solid var(--card-border);
  box-shadow: 0 24px 60px rgba(15, 15, 15, 0.12), 0 2px 8px rgba(15, 15, 15, 0.04);
  background: #fff;
  overflow: hidden;
}

.product-modal-content .eyebrow {
  color: var(--muted);
}

.product-modal-visual {
  background: var(--surface-sunken);
  border-radius: 0;
}

.product-modal-head h2 {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.015em;
  font-size: 1.6rem;
}

.product-modal-price {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.01em;
}

.product-modal-meta {
  background: var(--surface-sunken);
  border: 0;
  border-radius: 14px;
  padding: 14px 16px;
  gap: 18px;
}

.product-modal-meta > div {
  border: 0;
}

.product-modal-meta .profile-label {
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.product-modal-meta strong {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 0.88rem;
}

.result-tags {
  gap: 6px;
}

.result-tags span {
  background: var(--chip-bg);
  color: var(--ink);
  border: 0;
  border-radius: 100px;
  padding: 6px 12px;
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0;
}

.result-badges span.result-badge {
  background: var(--accent-soft);
  color: var(--accent-deep);
  border: 0;
  border-radius: 100px;
  padding: 6px 12px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

/* Modal close button: subtle round */
.modal-close {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--card-border);
  color: var(--ink);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  font-size: 1rem;
}

.modal-close:hover {
  background: #fff;
  border-color: var(--ink);
}

/* Favorites page: warm bg + editorial collections */
.favorites-shell,
.auth-shell,
.app-shell {
  background: var(--bg);
}

.favorites-hero h1,
.auth-intro h1,
.dashboard-hero h1 {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
}

/* Account / dashboard cards: warm editorial panels */
.dashboard-card,
.profile-card,
.auth-card,
.section-card {
  background: #fff;
  border: 1px solid var(--card-border);
  border-radius: 18px;
  box-shadow: 0 1px 3px rgba(15, 15, 15, 0.03);
}

.profile-label {
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
}

/* Form inputs: pill-ish, soft border */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
textarea.persona-textarea,
textarea.modal-textarea {
  border: 1.5px solid var(--card-border);
  border-radius: 14px;
  background: #fff;
  transition: border-color 0.15s var(--ease), box-shadow 0.15s var(--ease);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
textarea.persona-textarea:focus,
textarea.modal-textarea:focus {
  border-color: var(--ink);
  box-shadow: 0 2px 10px rgba(15, 15, 15, 0.06);
  outline: 0;
}

/* Auth tabs (Inloggen / Account maken) */
.auth-tabs {
  background: var(--chip-bg);
  border-radius: 100px;
  padding: 4px;
  gap: 0;
}

.auth-tab {
  border-radius: 100px;
  font-family: var(--font-sans);
  font-weight: 500;
  color: var(--muted);
  padding: 8px 18px;
}

.auth-tab.is-active {
  background: #fff;
  color: var(--ink);
  box-shadow: 0 1px 3px rgba(15, 15, 15, 0.06);
}

/* Primary button: keep black (Concept A-compatible) but softer radius */
.button-primary {
  border-radius: 100px;
  font-family: var(--font-sans);
  font-weight: 500;
  letter-spacing: 0;
}

.button-secondary {
  border-radius: 100px;
  border: 1.5px solid var(--card-border);
  background: #fff;
  font-weight: 500;
}

.button-ghost {
  border-radius: 100px;
  font-weight: 500;
  color: var(--ink);
}

.button-ghost:hover {
  background: var(--chip-bg);
}

/* Preset suggestion chips below hero: match inline-chip pill */
.suggestion-chip {
  background: #fff;
  border: 1.5px solid var(--card-border);
  border-radius: 100px;
  padding: 10px 18px;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 0.82rem;
  color: var(--ink);
  cursor: pointer;
  transition: border-color 0.15s var(--ease), background 0.15s var(--ease);
}

.suggestion-chip:hover {
  border-color: var(--ink);
  background: #fff;
}

/* Sort dropdown: editorial pill */
.sort-trigger {
  border: 1.5px solid var(--card-border);
  border-radius: 100px;
  background: #fff;
  font-weight: 500;
  padding: 8px 14px 8px 16px;
  font-size: 0.86rem;
}

.sort-trigger:hover {
  border-color: var(--ink);
}

.sort-menu {
  border-radius: 14px;
  border: 1px solid var(--card-border);
  box-shadow: 0 12px 32px rgba(15, 15, 15, 0.08);
  padding: 6px;
}

.sort-option {
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 0.88rem;
}

.sort-option:hover {
  background: var(--chip-bg);
}

.sort-option.is-selected {
  background: var(--ink);
  color: #fff;
}

/* Hide price sidebar / ai-filter popover leftovers - Concept A uses refine-dock + chips */
.ai-filter-popover,
.price-filter-panel,
.filter-toggle-panel {
  display: none !important;
}

/* Fix results-meta typo that showed pre-existing "resultaaten" spelling - nothing to do in CSS */

/* Results summary is smaller, editorial */
.results-meta-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.1rem;
}

.results-meta-copy {
  color: var(--muted);
  font-size: 0.86rem;
}

/* Nav dropdown menu polish */
.nav-dropdown-menu {
  border-radius: 14px;
  border: 1px solid var(--card-border);
  box-shadow: 0 12px 32px rgba(15, 15, 15, 0.08);
}

/* Empty-state favorites */
.favorites-empty {
  background: #fff;
  border: 1px solid var(--card-border);
  border-radius: 18px;
  padding: 32px;
}

/* Login pillchips fit Concept A */
.auth-intro .pill-chip,
.auth-intro .tag-chip,
.auth-intro .result-tag {
  background: var(--accent-soft);
  color: var(--accent-deep);
  border: 0;
  border-radius: 100px;
  padding: 6px 12px;
  font-size: 0.76rem;
  font-weight: 500;
}

/* Remove hard blue focus rings everywhere, use Concept A soft */
:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
  border-radius: 6px;
}

/* Fix results-title pre-existing "resultaaten" spelling via JS override - noop here */

/* ========== Feature 3 - Soortgelijke items in productmodal ========== */

.similar-items {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--card-border);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.similar-items[hidden] { display: none; }

.similar-items-head {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.similar-items-heading {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--ink);
}

.similar-items-subtitle {
  margin: 0;
  font-size: 0.8rem;
  color: var(--muted);
}

.similar-items-row {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 4px 2px 4px;
  scrollbar-width: thin;
  margin: 0 -4px;
  padding-left: 4px;
  padding-right: 4px;
}

.similar-items-row::-webkit-scrollbar {
  height: 6px;
}

.similar-items-row::-webkit-scrollbar-thumb {
  background: var(--card-border);
  border-radius: 100px;
}

.similar-card {
  flex: 0 0 140px;
  scroll-snap-align: start;
  background: #fff;
  border: 1px solid var(--card-border);
  border-radius: 12px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.15s var(--ease), transform 0.15s var(--ease), box-shadow 0.15s var(--ease);
  text-align: left;
  padding: 0;
  font-family: inherit;
  display: flex;
  flex-direction: column;
}

.similar-card:hover {
  border-color: var(--ink);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(15, 15, 15, 0.06);
}

.similar-card-image {
  width: 100%;
  height: 160px;
  background: var(--surface-sunken);
  overflow: hidden;
  position: relative;
}

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

.similar-card-body {
  padding: 8px 10px 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.similar-card-brand {
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
  margin: 0;
}

.similar-card-title {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--ink);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.similar-card-price {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--ink);
  margin: 2px 0 0;
}

.similar-card-empty {
  color: var(--muted);
  font-size: 0.85rem;
  padding: 20px 0;
  text-align: center;
  width: 100%;
}

/* ========== Feature 4 - Deel-knop + toast ========== */

.modal-actions {
  align-items: center;
}

.product-share-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  font-size: 0.88rem;
}

.product-share-button svg {
  width: 15px;
  height: 15px;
}

.product-share-button:hover {
  border-color: var(--ink);
  background: var(--chip-bg);
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 40px;
  transform: translate(-50%, 0);
  background: var(--ink, #111);
  color: #fff;
  padding: 12px 22px;
  border-radius: 100px;
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  box-shadow: 0 18px 40px rgba(15, 15, 15, 0.28);
  opacity: 0;
  pointer-events: none;
  z-index: 9999;
}

@keyframes toast-pop {
  0% { opacity: 0; transform: translate(-50%, 12px); }
  20% { opacity: 1; transform: translate(-50%, 0); }
  80% { opacity: 1; transform: translate(-50%, 0); }
  100% { opacity: 0; transform: translate(-50%, 6px); }
}

.toast.is-visible {
  opacity: 1;
  animation: toast-pop 2200ms var(--ease) forwards;
}

/* ========== Feature 5 - Persona marketing (before/after) ========== */

.persona-marketing {
  margin-top: 48px;
  padding: 40px;
  background: var(--surface, #fff);
  border: 1px solid var(--card-border, #e8e4df);
  border-radius: 24px;
  box-shadow: 0 2px 24px rgba(22, 20, 18, 0.04);
}

.persona-marketing.is-hidden {
  display: none;
}

.persona-marketing-intro {
  max-width: 640px;
}

.persona-marketing-intro h2 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 10px 0 14px;
}

.persona-marketing-compare {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: stretch;
  gap: 20px;
  margin-top: 32px;
}

.persona-marketing-pane {
  background: var(--chip-bg, #f1ede8);
  border: 1px solid var(--card-border, #e8e4df);
  border-radius: 18px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-height: 260px;
}

.persona-marketing-after {
  background: #fffaf6;
  border-color: rgba(232, 85, 61, 0.25);
  box-shadow: 0 8px 28px rgba(232, 85, 61, 0.08);
  position: relative;
}

.persona-marketing-after::before {
  content: "";
  position: absolute;
  top: -1px;
  left: -1px;
  right: -1px;
  bottom: -1px;
  border-radius: 18px;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(232, 85, 61, 0.14), rgba(232, 85, 61, 0) 55%);
  z-index: 0;
}

.persona-marketing-after > * {
  position: relative;
  z-index: 1;
}

.persona-marketing-pane-head {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.persona-marketing-pill {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  padding: 6px 14px;
  border-radius: 100px;
  background: var(--surface, #fff);
  border: 1px solid var(--card-border, #e8e4df);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--muted, #6b655f);
  text-transform: uppercase;
}

.persona-marketing-pill-accent {
  background: var(--accent, #e8553d);
  border-color: var(--accent, #e8553d);
  color: #fff;
}

.persona-marketing-subtitle {
  margin: 0;
  font-size: 0.92rem;
  color: var(--muted, #6b655f);
  line-height: 1.4;
}

.persona-marketing-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.persona-marketing-list li {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: center;
  gap: 14px;
}

.persona-marketing-swatch {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--card-border, #e8e4df);
  background-size: cover;
  background-position: center;
}

.persona-marketing-swatch-neutral {
  background: linear-gradient(135deg, #d9d3cb 0%, #bdb6ac 100%);
  filter: grayscale(0.3) saturate(0.7);
  opacity: 0.82;
}

.persona-marketing-swatch-warm {
  background: linear-gradient(135deg, #e8553d 0%, #c96544 55%, #8a4a36 100%);
  box-shadow: inset 0 0 0 1px rgba(232, 85, 61, 0.35);
}

.persona-marketing-item-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink, #111);
  line-height: 1.3;
}

.persona-marketing-item-meta {
  margin: 2px 0 0;
  font-size: 0.84rem;
  color: var(--muted, #6b655f);
  line-height: 1.4;
}

.persona-marketing-arrow {
  display: grid;
  place-items: center;
  color: var(--muted, #6b655f);
  opacity: 0.6;
}

.persona-marketing-arrow svg {
  width: 28px;
  height: 28px;
}

.persona-marketing-cta {
  margin-top: 36px;
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--card-border, #e8e4df);
  padding-top: 28px;
}

.persona-marketing-cta-text {
  margin: 0;
  font-size: 0.98rem;
  color: var(--muted, #6b655f);
  max-width: 520px;
  line-height: 1.5;
}

.persona-marketing-actions {
  display: inline-flex;
  gap: 10px;
  flex-wrap: wrap;
}

@media (max-width: 860px) {
  .persona-marketing {
    padding: 28px 22px;
    margin-top: 36px;
    border-radius: 18px;
  }

  .persona-marketing-compare {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .persona-marketing-arrow {
    transform: rotate(90deg);
  }

  .persona-marketing-cta {
    flex-direction: column;
    align-items: stretch;
  }

  .persona-marketing-actions {
    justify-content: flex-start;
  }
}

/* ================================================================
   Concept A v4 - final layer
   - Floating rounded header panel-card (like concept A image 1)
   - Wider grid (4 cols earlier, products flow further to the edges)
   - Hover: only border + shadow (no transform - prevents column-flow
     repaint that was blanking some images)
   - Account hero typography: softer, fits editorial tone
   - Safety: hide suggestion chips & AI insight (removed from HTML)
   ================================================================ */

.page-shell.catalog-shell,
.page-shell.app-shell,
.page-shell.auth-shell {
  width: min(1440px, calc(100% - 32px));
  padding-top: 0;
}

/* Full-bleed clean header (Concept A image 1) - spans full viewport,
   subtle bottom border, no pill shape. */
html, body {
  overflow-x: clip;
}

.app-topbar {
  background: rgba(250, 249, 247, 0.88) !important;
  border: 0 !important;
  border-bottom: 1px solid var(--card-border, #e8e4df) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  /* Break out of page-shell to full viewport width */
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  margin-top: 0 !important;
  margin-bottom: 20px !important;
  /* Inner gutter aligns with page-shell's 1440px max + 16px padding */
  padding: 14px max(16px, calc((100vw - 1440px) / 2 + 16px)) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 30;
}

@media (max-width: 720px) {
  .app-topbar {
    padding: 12px 16px !important;
  }
}

/* Grid: JS-driven masonry - results.js wraps cards in N `.masonry-col`
   columns (shortest-column placement). Guarantees exact column count at
   every viewport AND preserves the independent-flow masonry look of
   Concept A (no waiting for tallest card in a row). */
.catalog-products-grid {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 18px !important;
  grid-template-columns: unset !important;
  column-count: unset !important;
  column-gap: unset !important;
}
.catalog-products-grid > .masonry-col {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
}
.catalog-products-grid > .masonry-col > * {
  margin: 0 !important;
  width: 100% !important;
  break-inside: unset !important;
  -webkit-column-break-inside: unset !important;
  page-break-inside: unset !important;
}
@media (max-width: 699px) {
  .catalog-products-grid { gap: 12px !important; }
  .catalog-products-grid > .masonry-col { gap: 12px !important; }
}

/* Hover: lift visual without transform - transform on cards inside
   column-flow can briefly blank images in some browsers. */
.catalog-products-grid .result-card {
  transform: none !important;
  will-change: auto;
}
.catalog-products-grid .result-card:hover {
  transform: none !important;
  border-color: var(--card-border) !important;
  box-shadow: 0 10px 28px rgba(15, 15, 15, 0.08) !important;
}
.catalog-products-grid .result-card:hover .result-image,
.catalog-products-grid .result-card:hover .product-card-image {
  transform: none !important;
  opacity: 1 !important;
}

/* Hide leftover landing UI (also removed from HTML, CSS safety net) */
.hero-suggestions,
.catalog-support-grid,
.ai-insight-banner {
  display: none !important;
}

/* Account hero - softer, more editorial, matches the rest of the site */
.dashboard-hero {
  padding: 8px 0 4px !important;
}
.dashboard-hero h1,
.dashboard-hero-title {
  font-family: var(--font-display) !important;
  font-weight: 500 !important;
  font-size: clamp(1.6rem, 2.4vw, 2.1rem) !important;
  letter-spacing: -0.02em !important;
  line-height: 1.15 !important;
}

/* Favorites & auth hero: match scale */
.favorites-hero h1,
.auth-intro h1 {
  font-weight: 500 !important;
  font-size: clamp(2rem, 3.4vw, 2.8rem) !important;
}

/* ================================================================
   Concept A v5 - fine-tuning pass
   - Split-color logo: "Shop" ink-black + "Maatje" coral accent
   - Magnifying glass sits on the pill edge (Concept A placement)
   - Tighter vertical rhythm between header, search, and grid
   - Lower breakpoint so 4 columns render on more laptop widths
   ================================================================ */

/* Split-color brand logo */
.brand-name {
  color: var(--ink) !important;
}
.brand-name::first-letter {
  color: var(--ink) !important;
}
.brand-name-dark {
  color: var(--ink);
  font-weight: 700;
}
.brand-name-accent {
  color: var(--accent, #E8553D);
  font-weight: 700;
}

/* Magnifying glass button - sits at pill edge (overflow slightly right) */
.hero-search-inputs {
  position: relative !important;
  padding-right: 56px !important;
}
.hero-search-button {
  position: absolute !important;
  right: 6px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 44px !important;
  height: 44px !important;
  min-height: 44px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  background: var(--accent, #E8553D) !important;
  color: #fff !important;
  border: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 2px 8px rgba(232, 85, 61, 0.25);
}
.hero-search-button:hover {
  transform: translateY(-50%) scale(1.04) !important;
  background: var(--accent-hover, var(--accent-deep, #d1452f)) !important;
}
.hero-search-button svg {
  width: 18px !important;
  height: 18px !important;
  stroke: #fff !important;
}
.hero-search-form textarea {
  padding-right: 12px !important;
}

/* Tighter vertical rhythm on landing */
.hero-search {
  padding: 20px 20px 16px !important;
  gap: 12px !important;
}
.catalog-layout {
  padding-top: 0 !important;
  gap: 20px !important;
}
.catalog-main {
  gap: 18px !important;
}
.results-meta {
  margin-top: 4px !important;
  padding-top: 4px !important;
}

/* Grid breakpoints unified above - see single block near v4 layer */

/* ================================================================
   Concept A v6 - product-card polish + modal image fix
   - Card typography: larger + bolder title/price (matches Concept A)
   - More whitespace between cards (24px, was 18)
   - Heart hover: subtle scale-up for a clear affordance
   - Card hover: no transforms anywhere (prevents layout jitter)
   - Product modal: bigger, cleaner, image fills properly (see JS change)
   ================================================================ */

/* Card typography tighter to Concept A */
.catalog-products-grid .result-body {
  padding: 14px 2px 6px !important;
  gap: 4px !important;
}
.catalog-products-grid .result-brand {
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--muted, #6b655f) !important;
  margin: 0 0 4px !important;
}
.catalog-products-grid .result-head h3 {
  font-size: 1rem !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: unset !important;
  margin: 0 !important;
  color: var(--ink, #111) !important;
}
.catalog-products-grid .result-price {
  font-size: 1.02rem !important;
  font-weight: 700 !important;
  margin: 6px 0 0 !important;
  color: var(--ink, #111) !important;
}

/* More generous whitespace between products */
.catalog-products-grid {
  gap: 24px !important;
}
.catalog-products-grid > .masonry-col {
  gap: 24px !important;
}
@media (max-width: 699px) {
  .catalog-products-grid,
  .catalog-products-grid > .masonry-col {
    gap: 14px !important;
  }
}

/* Heart button: subtle scale-up on hover for clear favoriet-affordance */
.catalog-products-grid .favorite-icon-button {
  transition: transform 0.18s cubic-bezier(0.16, 1, 0.3, 1),
              border-color 0.18s ease,
              color 0.18s ease,
              background 0.18s ease !important;
  transform-origin: center !important;
}
.catalog-products-grid .favorite-icon-button:hover {
  transform: scale(1.18) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}
.catalog-products-grid .favorite-icon-button.is-favorite:hover {
  transform: scale(1.18) !important;
}

/* Kill any residual card hover transforms - prevents image jitter */
.catalog-products-grid .result-card,
.catalog-products-grid .result-card:hover,
.catalog-products-grid .result-card:focus,
.catalog-products-grid .result-card:focus-within {
  transform: none !important;
  will-change: auto !important;
}

/* Product modal: bigger, image fills, Daydream-like layout */
.product-modal {
  max-width: min(1120px, calc(100% - 32px)) !important;
  width: 100% !important;
}
.product-modal-layout {
  grid-template-columns: 1.1fr 0.9fr !important;
  gap: 0 !important;
}
.product-modal-visual-wrap {
  background: var(--surface-sunken, #f3efe9) !important;
  min-height: 620px;
  position: relative;
}
.product-modal-visual {
  min-height: 620px !important;
  height: 100% !important;
  padding: 0 !important;
}
.product-modal-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
/* Heart overlay on modal image (Daydream-style) */
.product-modal-heart {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--card-border, #e8e4df);
  color: var(--muted, #6b655f);
  font-size: 1.1rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  transition: transform 0.18s cubic-bezier(0.16, 1, 0.3, 1),
              color 0.18s ease, border-color 0.18s ease;
}
.product-modal-heart:hover {
  transform: scale(1.15);
  color: var(--accent);
  border-color: var(--accent);
}
.product-modal-heart.is-favorite {
  color: var(--accent);
  border-color: var(--accent);
}

/* Modal content side: tighter, Daydream-esque */
.product-modal-content {
  padding: 44px 44px 40px !important;
  gap: 18px !important;
}
.product-modal-content .eyebrow {
  display: none !important;
}
.product-modal-head {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 16px !important;
  align-items: start !important;
}
.product-modal-content .result-brand {
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  color: var(--muted, #6b655f) !important;
  margin-bottom: 6px !important;
}
#product-modal-title {
  font-size: 1.7rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.015em !important;
  line-height: 1.15 !important;
  margin: 0 !important;
}
.product-modal-price {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  margin: 0 !important;
}

@media (max-width: 880px) {
  .product-modal-layout {
    grid-template-columns: 1fr !important;
  }
  .product-modal-visual-wrap,
  .product-modal-visual {
    min-height: 380px !important;
  }
  .product-modal-content {
    padding: 24px 20px 28px !important;
  }
  #product-modal-title {
    font-size: 1.4rem !important;
  }
}

/* ================================================================
   Concept A v7 - heart-icon refinement + card padding fix
   - Heart wordt een perfecte cirkel met outline SVG-glyph
   - Card-body horizontale padding: 12px (tekst niet meer tegen rand)
   - Card-body bottom padding: 14px (minder losse witruimte)
   - Modal-heart volgt hetzelfde patroon voor consistentie
   ================================================================ */

/* Card body: proper padding rondom */
.catalog-products-grid .result-body {
  padding: 14px 12px 14px !important;
  gap: 4px !important;
}

/* Heart-button op kaart - cirkel, subtiele default state */
.catalog-products-grid .favorite-icon-button {
  position: absolute !important;
  top: auto !important;
  bottom: 12px !important;
  right: 12px !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  border: 1px solid var(--card-border, #e8e4df) !important;
  background: #fff !important;
  color: var(--muted, #6b655f) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  font-size: 0 !important; /* unicode heart verdwijnt, SVG neemt over */
  cursor: pointer !important;
  z-index: 2 !important;
}

.catalog-products-grid .favorite-icon-button svg {
  width: 16px !important;
  height: 16px !important;
  stroke: currentColor !important;
  stroke-width: 1.8 !important;
  fill: none !important;
  display: block !important;
  transition: fill 0.18s ease, stroke 0.18s ease !important;
}

.catalog-products-grid .favorite-icon-button:hover {
  transform: scale(1.12) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

.catalog-products-grid .favorite-icon-button.is-favorite {
  color: var(--accent) !important;
  border-color: var(--accent) !important;
  background: #fff !important;
}
.catalog-products-grid .favorite-icon-button.is-favorite svg {
  fill: var(--accent) !important;
  stroke: var(--accent) !important;
}

/* Modal heart: zelfde SVG-logica */
.product-modal-heart {
  font-size: 0 !important;
}
.product-modal-heart svg {
  width: 20px !important;
  height: 20px !important;
  stroke: currentColor !important;
  stroke-width: 1.8 !important;
  fill: none !important;
  display: block !important;
  transition: fill 0.18s ease, stroke 0.18s ease !important;
}
.product-modal-heart.is-favorite svg {
  fill: var(--accent) !important;
  stroke: var(--accent) !important;
}

/* ================================================================
   Concept A v8 - tighter vertical rhythm on cards
   Body-padding en interne marges waren te royaal; hier matchen we
   Concept A nauwkeuriger (minder witruimte tussen brand/title/price
   en minder bodem-padding onder de prijs).
   ================================================================ */

.catalog-products-grid .result-body {
  padding: 12px 14px 12px !important;
  gap: 2px !important;
}
.catalog-products-grid .result-brand {
  margin: 0 0 2px !important;
  line-height: 1.2 !important;
}
.catalog-products-grid .result-head h3 {
  margin: 0 0 2px !important;
  line-height: 1.25 !important;
}
.catalog-products-grid .result-price {
  margin: 4px 0 0 !important;
  line-height: 1.25 !important;
}

/* Heart zit nu verticaal gecentreerd met de prijs-regel ipv onderin hangen */
.catalog-products-grid .result-card {
  position: relative !important;
}
.catalog-products-grid .favorite-icon-button {
  top: auto !important;
  bottom: 12px !important;
  right: 14px !important;
}

/* ================================================================
   Concept A v9 - Daydream-strakke kaart-stijl
   - Heart: outline-only SVG ON de foto (geen cirkel, geen bg)
   - Image: rounded corners, geen visuele kaart-rand rondom
   - Card-body: brand+prijs op 1 regel, titel als subtitel eronder
   - Card: volledig transparant, alleen kaart-content
   ================================================================ */

/* Card: volledig strippen van border/shadow/bg */
.catalog-products-grid .result-card {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: visible !important;
  position: relative !important;
}

/* Image: rounded corners, relative voor heart-absolute, overflow clip */
.catalog-products-grid .result-image {
  position: relative !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  margin: 0 !important;
}
.catalog-products-grid .product-card-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

/* Heart op de foto - geen cirkel, pure stroke SVG met drop-shadow voor contrast */
.catalog-products-grid .favorite-icon-button {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  bottom: auto !important;
  left: auto !important;
  width: 32px !important;
  height: 32px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  color: #111 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0 !important;
  cursor: pointer !important;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.22));
  z-index: 3 !important;
  transform: none !important;
}
.catalog-products-grid .favorite-icon-button svg {
  width: 22px !important;
  height: 22px !important;
  stroke: currentColor !important;
  stroke-width: 1.6 !important;
  fill: none !important;
  display: block !important;
  transition: fill 0.18s ease, stroke 0.18s ease,
              transform 0.18s cubic-bezier(0.16, 1, 0.3, 1) !important;
}
.catalog-products-grid .favorite-icon-button:hover {
  background: transparent !important;
  border: 0 !important;
  color: var(--accent) !important;
  transform: none !important;
}
.catalog-products-grid .favorite-icon-button:hover svg {
  transform: scale(1.15) !important;
  stroke: var(--accent) !important;
}
.catalog-products-grid .favorite-icon-button.is-favorite {
  color: var(--accent) !important;
  background: transparent !important;
  border: 0 !important;
}
.catalog-products-grid .favorite-icon-button.is-favorite svg {
  fill: var(--accent) !important;
  stroke: var(--accent) !important;
}

/* Card body - Daydream layout: bold brand + price op 1 regel, title als subtitel */
.catalog-products-grid .result-body {
  padding: 12px 4px 0 !important;
  gap: 0 !important;
  background: transparent !important;
  border: 0 !important;
}
.catalog-products-grid .result-head {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 10px !important;
  align-items: baseline !important;
}
.catalog-products-grid .result-head > div {
  min-width: 0;
}
/* Brand = hoofd-regel (bold, donker, ellipsis bij lange merken) */
.catalog-products-grid .result-brand {
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: var(--ink, #111) !important;
  margin: 0 !important;
  line-height: 1.25 !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Titel = subtitel (muted, klein, ellipsis) */
.catalog-products-grid .result-head h3 {
  font-size: 0.88rem !important;
  font-weight: 400 !important;
  color: var(--muted, #6b655f) !important;
  margin: 2px 0 0 !important;
  line-height: 1.35 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  letter-spacing: 0 !important;
}
/* Price rechts, zelfde gewicht als brand */
.catalog-products-grid .result-price {
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: var(--ink, #111) !important;
  margin: 0 !important;
  line-height: 1.25 !important;
  align-self: start;
  white-space: nowrap;
}

/* Image placeholder (als er geen imageUrl is) - zelfde rounded rect */
.catalog-products-grid .product-card-image-placeholder {
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--muted) !important;
  font-size: 0.8rem !important;
}

/* ================================================================
   Concept A v10 - AI-belofte hero, landing vs results mode,
                   marketing rails, unified pill, persona sharpening
   ================================================================ */

/* ---------- Landing / results mode toggle --------------------- */
body:not(.has-query) .results-sections { display: none !important; }
body.has-query .landing-sections       { display: none !important; }
body.has-query .persona-marketing      { display: none !important; }

/* ---------- Hero: AI-belofte zichtbaar maken ------------------ */
.hero-search.hero-search-landing {
  padding: 56px 20px 20px !important;
  gap: 18px !important;
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
}
.hero-search.hero-search-landing .hero-search-title,
.hero-search.hero-search-landing .hero-search-subtitle {
  display: block !important;
}
.hero-eyebrow {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  margin: 0 0 4px !important;
  padding: 6px 14px;
  background: var(--accent-soft);
  color: var(--accent-deep);
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.hero-eyebrow-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.hero-search-title {
  font-family: var(--font-display) !important;
  font-size: clamp(2.4rem, 4.8vw, 3.6rem) !important;
  font-weight: 600 !important;
  line-height: 1.08 !important;
  letter-spacing: -0.02em !important;
  color: var(--ink) !important;
  margin: 0 !important;
  max-width: 820px;
}
.hero-search-title em {
  font-style: normal;
  color: var(--accent);
  font-weight: 600;
}
.hero-search-subtitle {
  font-size: 1.05rem !important;
  line-height: 1.55 !important;
  color: var(--muted-strong) !important;
  max-width: 620px;
  margin: 0 auto !important;
}

/* ---------- Bigger search pill -------------------------------- */
.hero-search-form-large {
  max-width: 820px !important;
  margin-top: 8px !important;
}
.hero-search-form-large .hero-search-inputs {
  position: relative !important;
  padding-left: 52px !important;
  padding-right: 64px !important;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--card-border, #e8e4df);
  box-shadow: 0 1px 2px rgba(15,15,15,0.04), 0 12px 32px rgba(15,15,15,0.06);
  transition: var(--transition);
}
.hero-search-form-large .hero-search-inputs:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft), 0 12px 32px rgba(232,85,61,0.10);
}
.hero-search-form-large textarea {
  width: 100%;
  min-height: 68px !important;
  padding: 22px 4px !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  font-size: 1.02rem !important;
  line-height: 1.4 !important;
  resize: none;
}
.hero-search-form-large textarea:focus {
  box-shadow: none !important;
  border: 0 !important;
}
.hero-search-ai-icon {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  pointer-events: none;
}
.hero-search-ai-icon svg { width: 22px; height: 22px; }
.hero-search-form-large .hero-search-button {
  right: 10px !important;
  width: 48px !important;
  height: 48px !important;
  min-height: 48px !important;
}
.hero-search-form-large .hero-search-button svg {
  width: 20px !important;
  height: 20px !important;
}

/* ---------- Example-chips onder de search --------------------- */
.hero-search-examples {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 10px;
  margin-top: 2px;
}
.hero-search-examples-label {
  font-size: 0.85rem;
  color: var(--muted);
  margin-right: 4px;
}

/* ---------- Unified .pill class ------------------------------- */
.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 36px;
  padding: 0 16px;
  border: 1px solid var(--card-border, #e8e4df);
  background: var(--surface);
  color: var(--ink);
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
  text-decoration: none;
}
.pill:hover {
  border-color: var(--ink);
  color: var(--ink);
  background: var(--surface-sunken);
}
.pill-ghost {
  background: transparent;
  border-color: var(--line-strong);
  color: var(--muted-strong);
}
.pill-ghost:hover {
  background: var(--surface);
  border-color: var(--ink);
  color: var(--ink);
}
.pill-ink {
  background: var(--ink);
  color: var(--ink-inverse);
  border-color: var(--ink);
}
.pill-ink:hover {
  background: var(--ink-soft);
  color: var(--ink-inverse);
}
.pill-accent {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}
.pill-accent:hover {
  background: var(--accent-hover);
  color: var(--accent-ink);
  border-color: var(--accent-hover);
}
.pill.is-active,
.pill[aria-selected="true"],
.pill[aria-checked="true"] {
  background: var(--ink);
  color: var(--ink-inverse);
  border-color: var(--ink);
}

/* Apply unified pill-grammar to existing controls (override cascade) */
.sort-trigger {
  height: 36px !important;
  padding: 0 14px 0 16px !important;
  border-radius: 999px !important;
  border: 1px solid var(--card-border, #e8e4df) !important;
  background: var(--surface) !important;
  color: var(--ink) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  box-shadow: none !important;
  gap: 8px !important;
}
.sort-trigger:hover {
  border-color: var(--ink) !important;
  background: var(--surface-sunken) !important;
}
.sort-trigger svg {
  width: 14px !important;
  height: 14px !important;
}

.pagination-button {
  height: 36px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  border: 1px solid var(--card-border, #e8e4df) !important;
  background: var(--surface) !important;
  color: var(--ink) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  box-shadow: none !important;
}
.pagination-button:hover:not(:disabled) {
  border-color: var(--ink) !important;
  background: var(--surface-sunken) !important;
}
.pagination-pages {
  gap: 6px !important;
}
.pagination-pages button,
.pagination-pages a,
.pagination-pages span.page-number {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 36px !important;
  height: 36px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  color: var(--muted-strong) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  text-decoration: none !important;
}
.pagination-pages button:hover,
.pagination-pages a:hover {
  background: var(--surface-sunken) !important;
  color: var(--ink) !important;
}
.pagination-pages .is-current,
.pagination-pages [aria-current="page"] {
  background: var(--ink) !important;
  color: var(--ink-inverse) !important;
  border-color: var(--ink) !important;
}

/* refine suggestions use pill style */
.refine-suggestion {
  height: 32px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  border: 1px solid var(--card-border) !important;
  background: var(--surface) !important;
  color: var(--ink) !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
}
.refine-suggestion:hover {
  border-color: var(--ink) !important;
  background: var(--surface-sunken) !important;
}

/* filter-popover .choice buttons as pills */
.choice {
  height: 32px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  border: 1px solid var(--card-border) !important;
  background: var(--surface) !important;
  color: var(--ink) !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: var(--transition) !important;
}
.choice:hover {
  border-color: var(--ink) !important;
  background: var(--surface-sunken) !important;
}
.choice.active {
  background: var(--ink) !important;
  color: var(--ink-inverse) !important;
  border-color: var(--ink) !important;
}

/* ---------- Landing sections (rails + persona) ---------------- */
.landing-sections {
  display: flex;
  flex-direction: column;
  gap: 48px;
  margin-top: 24px;
}

/* Marketing rail */
.marketing-rail {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.marketing-rail-head {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.marketing-rail-head .eyebrow {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--accent-deep);
  margin: 0;
}
.marketing-rail-title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
}
.marketing-rail-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}
@media (max-width: 900px) {
  .marketing-rail-row { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .marketing-rail-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Rail product card = same Daydream-strak as grid but smaller */
.rail-card {
  display: block;
  cursor: pointer;
  background: transparent;
  border: 0;
  text-align: left;
  padding: 0;
  font: inherit;
  color: inherit;
}
.rail-card-image {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 14px;
  overflow: hidden;
  background: var(--surface-sunken);
}
.rail-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s var(--ease);
}
.rail-card:hover .rail-card-image img {
  transform: scale(1.03);
}
.rail-card-body {
  padding: 10px 2px 0;
}
.rail-card-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: baseline;
}
.rail-card-brand {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rail-card-title {
  font-size: 0.82rem;
  font-weight: 400;
  color: var(--muted);
  margin: 2px 0 0;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rail-card-price {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
  white-space: nowrap;
}

/* ---------- Persona marketing: sharpen before/after ----------- */
.persona-marketing-landing {
  margin-top: 0 !important;
}
.persona-marketing-before {
  background: var(--surface-sunken) !important;
  border: 1px dashed var(--line-strong) !important;
  box-shadow: none !important;
}
.persona-marketing-before .persona-marketing-pill {
  background: rgba(15,15,15,0.06) !important;
  color: var(--muted-strong) !important;
  border-color: transparent !important;
}
.persona-marketing-before .persona-marketing-subtitle,
.persona-marketing-before .persona-marketing-item-meta {
  color: var(--muted) !important;
}
.persona-marketing-before .persona-marketing-item-title {
  color: var(--muted-strong) !important;
}
/* Greyscale/cross marker on before items */
.persona-marketing-before .persona-marketing-swatch {
  background: repeating-linear-gradient(45deg, #d9d5cf, #d9d5cf 4px, #ebe7e2 4px, #ebe7e2 8px) !important;
  border: 1px solid var(--line-strong) !important;
  position: relative;
}
.persona-marketing-before .persona-marketing-swatch::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(45deg, transparent calc(50% - 1px), rgba(15,15,15,0.35) calc(50% - 1px), rgba(15,15,15,0.35) calc(50% + 1px), transparent calc(50% + 1px));
}

/* After pane: warmer, lifted, with accent border */
.persona-marketing-after {
  background: linear-gradient(180deg, rgba(232,85,61,0.06), rgba(232,85,61,0.02)) !important;
  border: 1px solid var(--accent) !important;
  box-shadow: 0 8px 28px rgba(232,85,61,0.10) !important;
  position: relative;
}
.persona-marketing-after .persona-marketing-pill-accent {
  background: var(--accent) !important;
  color: var(--accent-ink) !important;
  border-color: var(--accent) !important;
}
.persona-marketing-after .persona-marketing-item-title {
  color: var(--ink) !important;
  font-weight: 600 !important;
}
.persona-marketing-after .persona-marketing-swatch {
  box-shadow: 0 2px 6px rgba(15,15,15,0.08) !important;
  border: 1px solid rgba(15,15,15,0.08) !important;
  position: relative;
}
.persona-marketing-after .persona-marketing-swatch::after {
  content: "";
  position: absolute;
  right: -4px;
  bottom: -4px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--accent) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/10px no-repeat;
  border: 2px solid var(--bg);
}

/* Arrow between panes - accent accent */
.persona-marketing-arrow {
  color: var(--accent) !important;
  opacity: 0.9 !important;
}

/* ---------- AI filter bar hides on landing (safety) ----------- */
body:not(.has-query) .ai-filter-bar { display: none !important; }

/* ================================================================
   V11 LAYER - Hero shrink on results + Personalize dock
   ================================================================ */

/* ---------- Hero shrink zodra er resultaten zijn ---------------- */
/* Hogere specificiteit dan v10's .hero-search.hero-search-landing .hero-search-title override */
body.has-query .hero-search.hero-search-landing .hero-eyebrow,
body.has-query .hero-search.hero-search-landing .hero-search-title,
body.has-query .hero-search.hero-search-landing .hero-search-subtitle,
body.has-query .hero-search.hero-search-landing .hero-search-examples {
  display: none !important;
}

body.has-query .hero-search.hero-search-landing {
  padding: 14px 18px 0 !important;
  gap: 8px !important;
  margin-bottom: 14px !important;
}

body.has-query .hero-search-form.hero-search-form-large {
  gap: 8px !important;
}

body.has-query .hero-search-form-large .hero-search-inputs {
  padding: 8px 10px !important;
  box-shadow:
    0 1px 2px rgba(15, 15, 15, 0.04),
    0 4px 14px rgba(15, 15, 15, 0.04) !important;
  border-radius: 999px !important;
}

body.has-query .hero-search-form-large textarea {
  min-height: 44px !important;
  padding: 10px 4px !important;
  font-size: 0.95rem !important;
  line-height: 1.3 !important;
}

body.has-query .hero-search-form-large .hero-search-button {
  position: static !important;
  right: auto !important;
  top: auto !important;
  transform: none !important;
  width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  flex-shrink: 0 !important;
  margin-left: 4px !important;
}

body.has-query .hero-search-form-large .hero-search-button svg {
  width: 18px !important;
  height: 18px !important;
}

body.has-query .hero-search-ai-icon {
  position: static !important;
  left: auto !important;
  top: auto !important;
  transform: none !important;
  width: 28px !important;
  height: 28px !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
}

body.has-query .hero-search-ai-icon svg {
  width: 16px !important;
  height: 16px !important;
}

/* Chips mogen geen padding-left meer hebben (icon zit nu in flex-order) */
body.has-query .hero-search-form-large .search-inline-chips {
  padding-left: 0 !important;
  margin-left: 0 !important;
}

/* Textarea mag niet meer onder de absolute icon duiken */
body.has-query .hero-search-form-large textarea {
  padding-left: 4px !important;
}

/* ---------- Personalize dock (vervanger van refine-dock) -------- */
.personalize-dock {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: left !important;
  gap: 16px !important;
  padding: 14px 18px !important;
  max-width: 640px !important;
}

.personalize-dock.hidden {
  display: none !important;
}

.personalize-dock-icon {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.personalize-dock-icon svg {
  width: 20px;
  height: 20px;
}

.personalize-dock-body {
  flex: 1;
  min-width: 0;
}

.personalize-dock-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink);
  margin: 0;
  line-height: 1.3;
}

.personalize-dock-copy {
  font-size: 0.8rem;
  color: var(--muted-strong);
  margin: 2px 0 0;
  line-height: 1.4;
}

.personalize-dock-cta {
  flex-shrink: 0;
  white-space: nowrap;
}

.personalize-dock-close {
  width: 30px;
  height: 30px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}

.personalize-dock-close:hover {
  background: var(--surface-sunken);
  color: var(--ink);
}

.personalize-dock-close svg {
  width: 14px;
  height: 14px;
}

/* Verberg legacy refine-dock-elementen indien nog in DOM op andere pages */
.personalize-dock .refine-dock-suggestions,
.personalize-dock .refine-dock-form {
  display: none !important;
}

/* ---------- Rail-card favorite-heart overlay -------------------- */
.rail-card .favorite-icon-button {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  bottom: auto !important;
  left: auto !important;
  width: 32px !important;
  height: 32px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  color: #111 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0 !important;
  cursor: pointer !important;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.22));
  z-index: 3 !important;
  transform: none !important;
}
.rail-card .favorite-icon-button svg {
  width: 22px !important;
  height: 22px !important;
  stroke: currentColor !important;
  stroke-width: 1.6 !important;
  fill: none !important;
  display: block !important;
  transition: fill 0.18s ease, stroke 0.18s ease,
              transform 0.18s cubic-bezier(0.16, 1, 0.3, 1) !important;
}
.rail-card .favorite-icon-button:hover {
  background: transparent !important;
  border: 0 !important;
  color: var(--accent) !important;
  transform: none !important;
}
.rail-card .favorite-icon-button:hover svg {
  transform: scale(1.15) !important;
  stroke: var(--accent) !important;
}
.rail-card .favorite-icon-button.is-favorite {
  color: var(--accent) !important;
  background: transparent !important;
  border: 0 !important;
}
.rail-card .favorite-icon-button.is-favorite svg {
  fill: var(--accent) !important;
  stroke: var(--accent) !important;
}

/* Responsive - op smalle schermen compacter */
@media (max-width: 600px) {
  .personalize-dock {
    flex-wrap: wrap !important;
    gap: 10px !important;
    padding: 12px 14px !important;
  }
  .personalize-dock-body {
    flex: 1 1 100%;
    order: 2;
  }
  .personalize-dock-icon { order: 1; }
  .personalize-dock-cta {
    flex: 1 1 auto;
    order: 3;
    text-align: center;
  }
  .personalize-dock-close {
    order: 4;
  }
  .personalize-dock-copy {
    display: none;
  }
}

/* ================================================================
   V12 LAYER - Product modal redesign (conversion-focused, Bijenkorf-stijl)
   ================================================================ */

/* ---------- Modal shell: breder, lichter, meer lucht ------------ */
.product-modal-content-v2 {
  display: flex !important;
  flex-direction: column !important;
  gap: 22px !important;
  padding: 40px 44px 44px !important;
  overflow-y: auto !important;
}

/* ---------- Visual zijde: groter en clean --------------------- */
.product-modal .product-modal-visual-wrap {
  position: relative !important;
}
.product-modal .product-modal-visual {
  aspect-ratio: 4 / 5 !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  background: var(--surface-sunken) !important;
}
.product-modal .product-modal-visual img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

/* Heart in hoek (top-left) zoals Daydream/Bijenkorf */
.product-modal .product-modal-heart {
  position: absolute !important;
  top: 18px !important;
  left: 18px !important;
  right: auto !important;
  bottom: auto !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.94) !important;
  border: 0 !important;
  box-shadow: 0 2px 8px rgba(15, 15, 15, 0.08) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--ink) !important;
  cursor: pointer !important;
  transition: transform 0.15s, background 0.15s !important;
  z-index: 4 !important;
}
.product-modal .product-modal-heart:hover {
  background: #fff !important;
  transform: scale(1.04) !important;
  color: var(--accent) !important;
}
.product-modal .product-modal-heart svg {
  width: 20px !important;
  height: 20px !important;
  stroke: currentColor !important;
  stroke-width: 1.8 !important;
  fill: none !important;
}
.product-modal .product-modal-heart.is-favorite {
  background: #fff !important;
  color: var(--accent) !important;
}
.product-modal .product-modal-heart.is-favorite svg {
  fill: var(--accent) !important;
  stroke: var(--accent) !important;
}

/* ---------- Heading: brand GROOT, titel subtitel --------------- */
.product-modal-content-v2 .product-modal-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 24px !important;
  margin: 0 !important;
}
.product-modal-content-v2 .product-modal-head .result-brand {
  font-size: 2rem !important;
  font-weight: 700 !important;
  font-family: var(--font-display) !important;
  color: var(--ink) !important;
  line-height: 1.1 !important;
  margin: 0 0 6px !important;
  letter-spacing: -0.01em !important;
}
.product-modal-content-v2 .product-modal-head h2 {
  font-size: 1rem !important;
  font-weight: 400 !important;
  color: var(--muted-strong) !important;
  font-family: var(--font-sans) !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}
.product-modal-content-v2 .product-modal-price {
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding-top: 4px !important;
}

.product-modal-divider {
  height: 1px !important;
  background: var(--line-strong, rgba(15,15,15,0.08)) !important;
  margin: 4px 0 !important;
}

/* ---------- Variant: kleur + maat strakker --------------------- */
.product-modal-content-v2 .product-variant-block {
  display: flex !important;
  flex-direction: column !important;
  gap: 22px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
}
.product-modal-content-v2 .product-variant-head {
  display: flex !important;
  align-items: baseline !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin-bottom: 10px !important;
}
.product-modal-content-v2 .product-variant-head .profile-label {
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  color: var(--muted-strong) !important;
}
.product-modal-content-v2 .product-variant-current {
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
}
.product-modal-content-v2 .product-variant-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

/* Size pills: ronde circkels zoals Daydream */
.product-modal-content-v2 .variant-pill {
  width: 48px !important;
  height: 48px !important;
  border-radius: 999px !important;
  border: 1px solid var(--line-strong, rgba(15,15,15,0.12)) !important;
  background: #fff !important;
  color: var(--ink) !important;
  font-weight: 500 !important;
  font-size: 0.95rem !important;
  cursor: pointer !important;
  transition: border-color 0.15s, background 0.15s, color 0.15s !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.product-modal-content-v2 .variant-pill:hover:not(.is-disabled) {
  border-color: var(--ink) !important;
}
.product-modal-content-v2 .variant-pill[aria-checked="true"] {
  background: var(--ink) !important;
  color: #fff !important;
  border-color: var(--ink) !important;
}
.product-modal-content-v2 .variant-pill.is-disabled {
  opacity: 0.35 !important;
  cursor: not-allowed !important;
  text-decoration: line-through !important;
}

/* Color swatches */
.product-modal-content-v2 .variant-swatch {
  width: 34px !important;
  height: 34px !important;
  border-radius: 999px !important;
  border: 2px solid transparent !important;
  padding: 2px !important;
  background: transparent !important;
  position: relative !important;
  cursor: pointer !important;
  transition: border-color 0.15s !important;
}
.product-modal-content-v2 .variant-swatch::after {
  content: "" !important;
  position: absolute !important;
  inset: 2px !important;
  border-radius: 999px !important;
  background: var(--swatch) !important;
  border: 1px solid rgba(15,15,15,0.08) !important;
}
.product-modal-content-v2 .variant-swatch.is-selected {
  border-color: var(--accent) !important;
}
.product-modal-content-v2 .variant-swatch.is-disabled {
  opacity: 0.4 !important;
  cursor: not-allowed !important;
}

/* ---------- CTA: groot en primair ----------------------------- */
.product-modal-content-v2 .modal-actions-v2 {
  display: flex !important;
  gap: 10px !important;
  align-items: stretch !important;
  margin-top: 4px !important;
}
.product-modal-content-v2 .product-modal-cta {
  flex: 1 1 auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  height: 56px !important;
  min-height: 56px !important;
  padding: 0 24px !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  border-radius: 12px !important;
  text-decoration: none !important;
  background: var(--accent) !important;
  color: #fff !important;
  transition: transform 0.12s, background 0.15s, box-shadow 0.2s !important;
  box-shadow: 0 6px 18px rgba(216, 93, 62, 0.22) !important;
}
.product-modal-content-v2 .product-modal-cta:hover {
  background: var(--accent-deep, #b94a2d) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 22px rgba(216, 93, 62, 0.28) !important;
}
.product-modal-content-v2 .product-modal-cta svg {
  width: 18px !important;
  height: 18px !important;
}
.product-modal-content-v2 .product-share-button-v2 {
  width: 56px !important;
  height: 56px !important;
  min-width: 56px !important;
  border-radius: 12px !important;
  border: 1px solid var(--line-strong, rgba(15,15,15,0.12)) !important;
  background: #fff !important;
  color: var(--ink) !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  transition: border-color 0.15s, color 0.15s !important;
}
.product-modal-content-v2 .product-share-button-v2:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}
.product-modal-content-v2 .product-share-button-v2 svg {
  width: 20px !important;
  height: 20px !important;
}

/* ---------- Trust row: bezorging / retour / ai ---------------- */
.product-trust-row {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin: 6px 0 0 !important;
  padding: 14px 16px !important;
  list-style: none !important;
  background: var(--surface-sunken) !important;
  border-radius: 10px !important;
}
.product-trust-row li {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  font-size: 0.88rem !important;
  color: var(--ink) !important;
}
.product-trust-row li svg {
  width: 18px !important;
  height: 18px !important;
  color: var(--muted-strong) !important;
  flex-shrink: 0 !important;
}

/* ---------- Collapsible details ------------------------------- */
.product-modal-details {
  border-top: 1px solid var(--line-strong, rgba(15,15,15,0.08)) !important;
  padding-top: 18px !important;
}
.product-modal-details > summary {
  list-style: none !important;
  cursor: pointer !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  padding: 6px 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
}
.product-modal-details > summary::-webkit-details-marker { display: none !important; }
.product-modal-details > summary::after {
  content: "" !important;
  width: 10px !important;
  height: 10px !important;
  border-right: 2px solid var(--muted-strong) !important;
  border-bottom: 2px solid var(--muted-strong) !important;
  transform: rotate(45deg) !important;
  transition: transform 0.2s !important;
  margin-right: 6px !important;
}
.product-modal-details[open] > summary::after {
  transform: rotate(-135deg) !important;
  margin-bottom: -4px !important;
}
.product-modal-details-body {
  padding: 14px 0 4px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
}
.product-modal-details-body .modal-text {
  font-size: 0.95rem !important;
  line-height: 1.55 !important;
  color: var(--muted-strong) !important;
  margin: 0 !important;
}
.product-modal-details-body .product-modal-meta {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 12px !important;
  padding: 14px 16px !important;
  background: var(--surface-sunken) !important;
  border-radius: 10px !important;
  margin: 0 !important;
}
.product-modal-details-body .product-modal-meta > div {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}
.product-modal-details-body .profile-label {
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  color: var(--muted-strong) !important;
}
.product-modal-details-body .product-modal-meta strong {
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
}

/* ---------- Responsive: kleine schermen ----------------------- */
@media (max-width: 800px) {
  .product-modal-content-v2 {
    padding: 24px 20px 28px !important;
    gap: 18px !important;
  }
  .product-modal-content-v2 .product-modal-head .result-brand {
    font-size: 1.5rem !important;
  }
  .product-modal-content-v2 .product-modal-price {
    font-size: 1.15rem !important;
  }
  .product-modal-content-v2 .product-modal-cta {
    height: 52px !important;
    min-height: 52px !important;
  }
  .product-modal-content-v2 .product-share-button-v2 {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
  }
}

/* ==========================================================================
   v13 - Pagination: verberg Vorige/Volgende aan de randen
   Op pagina 1 heeft "Vorige" geen functie; op de laatste pagina "Volgende"
   niet. Disabled knoppen tonen zou dead space creëren - gewoon verbergen.
   ========================================================================== */
.pagination-button.is-hidden {
  display: none !important;
}


/* ==========================================================================
   v14 - Fashion Paspoort (account.html redesign)
   Een identity-card-stijl pagina: crème achtergrond, koraal koptekst,
   secties als paspoortpagina's, deelbare share card.
   ========================================================================== */

/* ── Page shell ─────────────────────────────────────────────────────────── */
.passport-page {
  min-height: calc(100vh - 64px);
  background: var(--surface-sunken, #F5F1EC);
  padding: 40px 20px 80px;
}

.passport-wrapper {
  max-width: 680px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ── Passport document ───────────────────────────────────────────────────── */
.passport-doc {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(28,23,20,0.10), 0 1px 4px rgba(28,23,20,0.06);
}

/* ── Cover ───────────────────────────────────────────────────────────────── */
.passport-cover {
  background: var(--accent, #D85D3E);
  padding: 28px 32px 20px;
  color: #fff;
}

.passport-cover-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
}

.passport-cover-eyebrow {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  opacity: 0.8;
  margin-bottom: 4px;
  font-family: var(--font-body, 'Inter', sans-serif);
}

.passport-cover-brand {
  font-size: 1.75rem;
  font-weight: 700;
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif);
  line-height: 1;
  margin-bottom: 4px;
}

.passport-cover-country {
  font-size: 0.75rem;
  opacity: 0.7;
  font-family: var(--font-body, 'Inter', sans-serif);
}

.passport-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255,255,255,0.25);
  border: 2px solid rgba(255,255,255,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif);
  flex-shrink: 0;
}

/* Progress bar in cover */
.passport-progress-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
}

.passport-progress-track {
  flex: 1;
  height: 4px;
  background: rgba(255,255,255,0.25);
  border-radius: 999px;
  overflow: hidden;
}

.passport-progress-fill {
  height: 100%;
  background: #fff;
  border-radius: 999px;
  transition: width 0.5s cubic-bezier(.4,0,.2,1);
}

.passport-progress-label {
  font-size: 0.7rem;
  opacity: 0.85;
  white-space: nowrap;
  font-family: var(--font-body, 'Inter', sans-serif);
  flex-shrink: 0;
}

/* ── Identity strip ──────────────────────────────────────────────────────── */
.passport-identity-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: var(--surface-sunken, #F5F1EC);
  border-bottom: 1px solid #EDE7DF;
}

.passport-id-field {
  padding: 14px 16px;
  border-right: 1px solid #EDE7DF;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.passport-id-field:last-child {
  border-right: none;
}

.passport-id-label {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--muted, #8C7B6E);
  font-family: var(--font-body, 'Inter', sans-serif);
}

.passport-id-value {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ink, #1C1714);
  font-family: var(--font-body, 'Inter', sans-serif);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Sections ────────────────────────────────────────────────────────────── */
.passport-section {
  padding: 24px 32px;
  border-top: 1px solid #F0E8E0;
}

.passport-section:first-of-type {
  border-top: none;
}

.passport-section-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.passport-section-num {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--accent, #D85D3E);
  background: #FFF0EC;
  border-radius: 6px;
  padding: 3px 8px;
  font-family: var(--font-body, 'Inter', sans-serif);
  flex-shrink: 0;
}

.passport-section-num-star {
  font-size: 0.9rem;
  letter-spacing: 0;
  padding: 2px 8px;
}

.passport-section-title {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink, #1C1714);
  font-family: var(--font-body, 'Inter', sans-serif);
  margin: 0;
}

.passport-section-desc {
  font-size: 0.8rem;
  color: var(--muted, #8C7B6E);
  margin-bottom: 14px;
  margin-top: -8px;
  font-family: var(--font-body, 'Inter', sans-serif);
}

/* ── Form elements ───────────────────────────────────────────────────────── */
.passport-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.passport-form-row-3 {
  grid-template-columns: 1fr 1fr 1fr;
}

.passport-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.passport-label {
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--muted, #8C7B6E);
  font-family: var(--font-body, 'Inter', sans-serif);
}

.passport-input {
  height: 40px;
  padding: 0 12px;
  border: 1px solid #E8E0D8;
  border-radius: 8px;
  background: #FAFAF8;
  font-size: 0.875rem;
  color: var(--ink, #1C1714);
  font-family: var(--font-body, 'Inter', sans-serif);
  transition: border-color 0.15s;
}

.passport-input:focus {
  outline: none;
  border-color: var(--accent, #D85D3E);
  box-shadow: 0 0 0 3px rgba(216,93,62,0.12);
}

.passport-input::placeholder {
  color: #C4B8AD;
}

/* ── Archetype grid ──────────────────────────────────────────────────────── */
.passport-archetype-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.passport-archetype-chip {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 12px 14px;
  border: 1.5px solid #E8E0D8;
  border-radius: 10px;
  background: #FAFAF8;
  cursor: pointer;
  text-align: left;
  transition: border-color 0.15s, background 0.15s;
}

.passport-archetype-chip:hover {
  border-color: var(--accent, #D85D3E);
  background: #FFF8F6;
}

.passport-archetype-chip.is-selected {
  border-color: var(--accent, #D85D3E);
  background: var(--accent, #D85D3E);
}

.passport-archetype-chip.is-selected .archetype-chip-label,
.passport-archetype-chip.is-selected .archetype-chip-desc {
  color: #fff;
}

.archetype-chip-label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink, #1C1714);
  font-family: var(--font-body, 'Inter', sans-serif);
}

.archetype-chip-desc {
  font-size: 0.72rem;
  color: var(--muted, #8C7B6E);
  font-family: var(--font-body, 'Inter', sans-serif);
}

/* ── Color grid ──────────────────────────────────────────────────────────── */
.passport-color-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.passport-color-swatch {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: transform 0.15s, box-shadow 0.15s;
}

.passport-color-swatch:hover {
  transform: scale(1.1);
}

.passport-color-swatch.is-selected {
  box-shadow: 0 0 0 3px #fff, 0 0 0 5px var(--accent, #D85D3E);
}

.swatch-check {
  width: 16px;
  height: 16px;
}

/* ── Tags ────────────────────────────────────────────────────────────────── */
.passport-tags-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
  min-height: 4px;
}

.passport-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 12px;
  background: var(--accent, #D85D3E);
  color: #fff;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 500;
  font-family: var(--font-body, 'Inter', sans-serif);
}

.passport-tag-remove {
  background: none;
  border: none;
  color: rgba(255,255,255,0.75);
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  padding: 0;
  display: flex;
  align-items: center;
  transition: color 0.1s;
}

.passport-tag-remove:hover {
  color: #fff;
}

.passport-tag-input-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

.passport-tag-input {
  flex: 1;
}

.passport-tag-add-btn {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  border: 1.5px solid var(--accent, #D85D3E);
  background: transparent;
  color: var(--accent, #D85D3E);
  font-size: 1.4rem;
  font-weight: 400;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}

.passport-tag-add-btn:hover {
  background: var(--accent, #D85D3E);
  color: #fff;
}

/* ── Budget chips ────────────────────────────────────────────────────────── */
.passport-budget-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.passport-budget-chip {
  padding: 8px 18px;
  border: 1.5px solid #E8E0D8;
  border-radius: 999px;
  background: #FAFAF8;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--ink, #1C1714);
  cursor: pointer;
  font-family: var(--font-body, 'Inter', sans-serif);
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}

.passport-budget-chip:hover {
  border-color: var(--accent, #D85D3E);
  color: var(--accent, #D85D3E);
}

.passport-budget-chip.is-selected {
  border-color: var(--accent, #D85D3E);
  background: var(--accent, #D85D3E);
  color: #fff;
}

/* ── AI summary section ──────────────────────────────────────────────────── */
.passport-ai-section {
  background: var(--surface-sunken, #F5F1EC);
}

.passport-ai-summary {
  font-size: 0.9rem;
  color: var(--ink, #1C1714);
  line-height: 1.6;
  font-style: italic;
  font-family: var(--font-body, 'Inter', sans-serif);
}

/* ── MRZ (machine-readable zone) ─────────────────────────────────────────── */
.passport-mrz {
  background: #F0E8E0;
  padding: 12px 32px;
  border-top: 1px dashed #DDD0C4;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.passport-mrz-line {
  font-family: 'Courier New', Courier, monospace;
  font-size: 0.65rem;
  letter-spacing: 0.05em;
  color: #B0A094;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: clip;
}

/* ── Actions bar ─────────────────────────────────────────────────────────── */
.passport-actions-bar {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.passport-save-btn {
  flex: 1 1 auto;
}

.passport-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.passport-save-feedback {
  font-size: 0.82rem;
  font-family: var(--font-body, 'Inter', sans-serif);
  min-height: 1.2em;
}

/* ── Share modal ─────────────────────────────────────────────────────────── */
.share-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(28,23,20,0.6);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(4px);
}

.share-modal-overlay.hidden {
  display: none;
}

.share-modal-box {
  background: #fff;
  border-radius: 20px;
  padding: 28px 24px 24px;
  width: 100%;
  max-width: 360px;
  position: relative;
  box-shadow: 0 20px 60px rgba(28,23,20,0.2);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.share-modal-close-btn {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: var(--surface-sunken, #F5F1EC);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink, #1C1714);
}

.share-modal-hint {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--muted, #8C7B6E);
  text-align: center;
  font-family: var(--font-body, 'Inter', sans-serif);
}

/* ── Share card ──────────────────────────────────────────────────────────── */
.share-card {
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(28,23,20,0.12);
  background: #fff;
}

.share-card-top {
  background: var(--accent, #D85D3E);
  padding: 20px 20px 16px;
  color: #fff;
}

.share-card-eyebrow {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  opacity: 0.8;
  font-family: var(--font-body, 'Inter', sans-serif);
  margin-bottom: 3px;
}

.share-card-brand {
  font-size: 1.4rem;
  font-weight: 700;
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif);
  line-height: 1;
}

.share-card-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.share-card-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--accent, #D85D3E);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  font-weight: 700;
  font-family: var(--font-display, 'Bricolage Grotesque', sans-serif);
}

.share-card-name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink, #1C1714);
  font-family: var(--font-body, 'Inter', sans-serif);
}

.share-card-archetype-badge {
  font-size: 0.75rem;
  font-weight: 600;
  background: #FFF0EC;
  color: var(--accent, #D85D3E);
  padding: 4px 12px;
  border-radius: 999px;
  font-family: var(--font-body, 'Inter', sans-serif);
}

.share-card-data {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid #F0E8E0;
}

.share-card-data-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.share-card-data-label {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--muted, #8C7B6E);
  font-family: var(--font-body, 'Inter', sans-serif);
  flex-shrink: 0;
}

.share-card-data-value {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--ink, #1C1714);
  font-family: var(--font-body, 'Inter', sans-serif);
  text-align: right;
}

.share-card-swatches {
  display: flex;
  gap: 5px;
}

.share-swatch {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-block;
}

.share-card-bottom {
  background: var(--surface-sunken, #F5F1EC);
  padding: 10px 20px;
  text-align: center;
  font-size: 0.7rem;
  color: var(--muted, #8C7B6E);
  font-family: var(--font-body, 'Inter', sans-serif);
}

.share-modal-actions {
  display: flex;
  gap: 10px;
}

.share-modal-actions .button {
  flex: 1;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .passport-page {
    padding: 20px 12px 60px;
  }
  .passport-cover {
    padding: 22px 20px 16px;
  }
  .passport-section {
    padding: 20px;
  }
  .passport-mrz {
    padding: 10px 20px;
  }
  .passport-form-row,
  .passport-form-row-3 {
    grid-template-columns: 1fr;
  }
  .passport-identity-strip {
    grid-template-columns: 1fr 1fr;
  }
  .passport-id-field:nth-child(2) {
    border-right: none;
  }
  .passport-id-field:nth-child(3) {
    border-top: 1px solid #EDE7DF;
  }
  .passport-id-field:nth-child(4) {
    border-top: 1px solid #EDE7DF;
    border-right: none;
  }
  .passport-archetype-grid {
    grid-template-columns: 1fr;
  }
  .passport-cover-brand {
    font-size: 1.4rem;
  }
  .passport-progress-label {
    display: none;
  }
  .passport-actions-bar {
    flex-direction: column;
  }
  .passport-save-btn,
  .passport-share-btn {
    width: 100%;
    justify-content: center;
  }
}


/* ==========================================================================
   v15 - Landing page (landing.html)
   Pre-launch landingspagina voor e-mail verzameling. Luchtig, veel witruimte,
   crème achtergrond met koraal accenten. Volgt de ShopMaatje huisstijl maar
   heeft een eigen rustigere typografie zonder topbar-navigatie.
   ========================================================================== */

/* ── Body + globale shell ─────────────────────────────────────────────────── */
.landing-body {
  background: #F5F1EC;
  color: #1C1714;
  min-height: 100vh;
}

/* ── Minimal header ─────────────────────────────────────────────────────── */
.landing-header {
  padding: 24px 0;
  background: transparent;
}
.landing-header-inner {
  width: min(1120px, calc(100% - 48px));
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.landing-header .brand-link {
  text-decoration: none;
}
.landing-header .brand-name {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.landing-header-socials {
  display: flex;
  gap: 12px;
}

/* Generic social icon (ook in footer) */
.landing-social-icon {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #1C1714;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  transition: color 0.2s var(--ease);
}
.landing-social-icon svg {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
}
.landing-social-icon:hover {
  color: var(--accent);
}

/* ── Main ───────────────────────────────────────────────────────────────── */
.landing-main {
  width: 100%;
}

.landing-section-inner {
  width: min(1120px, calc(100% - 48px));
  margin: 0 auto;
}

.landing-eyebrow,
.landing-section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 20px;
}
.landing-eyebrow-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

.landing-section-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0 0 20px;
  color: #1C1714;
}

/* ================= SECTIE 1 - HERO ================= */
.landing-hero {
  position: relative;
  padding: 40px 0 100px;
  overflow: hidden;
}
.landing-hero-inner {
  width: min(880px, calc(100% - 48px));
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 2;
}

.landing-hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 0 0 24px;
  color: #1C1714;
}
.landing-hero-title em {
  font-style: italic;
  color: var(--accent);
  font-weight: 500;
}

.landing-hero-sub {
  font-family: var(--font-sans);
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.6;
  color: rgba(28, 23, 20, 0.72);
  max-width: 560px;
  margin: 0 auto 40px;
}

/* Decoratieve achtergrond blob */
.landing-hero-blob {
  position: absolute;
  top: 10%;
  right: -10%;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232, 85, 61, 0.10) 0%, rgba(232, 85, 61, 0) 70%);
  pointer-events: none;
  z-index: 1;
}

/* ── Form ───────────────────────────────────────────────────────────────── */
.landing-form {
  max-width: 560px;
  margin: 0 auto 20px;
}
.landing-form-row {
  display: flex;
  gap: 8px;
  background: #fff;
  padding: 8px;
  border-radius: 999px;
  box-shadow: 0 4px 24px rgba(28, 23, 20, 0.06), 0 1px 3px rgba(28, 23, 20, 0.04);
  transition: box-shadow 0.2s var(--ease);
}
.landing-form-row:focus-within {
  box-shadow: 0 0 0 3px rgba(232, 85, 61, 0.15), 0 4px 24px rgba(28, 23, 20, 0.08);
}
.landing-input {
  flex: 1;
  min-width: 0;
  border: none;
  outline: none;
  background: transparent;
  padding: 14px 20px;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: #1C1714;
}
.landing-input::placeholder {
  color: rgba(28, 23, 20, 0.40);
}
.landing-submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--accent);
  color: #fff;
  border: none;
  padding: 14px 24px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.2s var(--ease), transform 0.15s var(--ease);
}
.landing-submit:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}
.landing-submit svg {
  width: 16px;
  height: 16px;
}
.landing-form-micro {
  margin: 14px 0 0;
  font-size: 0.85rem;
  color: rgba(28, 23, 20, 0.55);
  text-align: center;
}

.landing-form-success {
  margin: 14px auto 0;
  max-width: 560px;
  padding: 12px 18px;
  border-radius: 12px;
  background: rgba(34, 139, 87, 0.10);
  color: #1a6d3e;
  font-size: 0.92rem;
  text-align: center;
  font-weight: 500;
}

/* ── Sociale teller ─────────────────────────────────────────────────────── */
.landing-counter {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 20px 0 0;
  padding: 8px 16px;
  background: rgba(28, 23, 20, 0.04);
  border-radius: 999px;
  font-size: 0.9rem;
  color: rgba(28, 23, 20, 0.70);
}
.landing-counter-center {
  display: flex;
  margin: 20px auto 0;
  width: fit-content;
}
.landing-counter-star {
  color: var(--accent);
  font-size: 0.85rem;
}
.landing-counter-num {
  font-weight: 700;
  color: #1C1714;
  font-variant-numeric: tabular-nums;
}

.landing-social-hint {
  margin: 28px 0 0;
  font-size: 0.9rem;
  color: rgba(28, 23, 20, 0.55);
}
.landing-social-hint a {
  color: #1C1714;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 500;
}
.landing-social-hint a:hover {
  color: var(--accent);
}

/* ================= SECTIE 2 - PROBLEEM ================= */
.landing-problem {
  padding: 80px 0;
  background: #fff;
}
.landing-problem .landing-section-title {
  text-align: center;
  margin-bottom: 48px;
}
.landing-problem .landing-section-eyebrow {
  display: flex;
  justify-content: center;
}

.landing-problem-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 0 0 48px;
}
.landing-problem-card {
  background: #F5F1EC;
  padding: 36px 28px;
  border-radius: 20px;
  text-align: center;
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.landing-problem-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(28, 23, 20, 0.08);
}
.landing-problem-emoji {
  font-size: 2.5rem;
  margin-bottom: 16px;
  line-height: 1;
}
.landing-problem-quote {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1.4;
  color: #1C1714;
  font-style: italic;
}

.landing-problem-solution {
  margin: 16px 0 0;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--accent);
  line-height: 1.4;
}
.landing-problem-arrow {
  display: inline-block;
  margin-right: 4px;
  font-style: normal;
}

.landing-problem-bridge {
  text-align: center;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  line-height: 1.4;
  color: var(--accent);
  max-width: 620px;
  margin: 0 auto;
}
.landing-problem-bridge em {
  font-style: italic;
}

/* ================= SECTIE 3 - HOE HET WERKT ================= */
.landing-how {
  padding: 100px 0;
}
.landing-how .landing-section-title {
  text-align: center;
  margin-bottom: 56px;
}
.landing-how .landing-section-eyebrow {
  display: flex;
  justify-content: center;
}

.landing-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.landing-step {
  background: #fff;
  padding: 32px 28px;
  border-radius: 20px;
  position: relative;
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.landing-step:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(28, 23, 20, 0.10);
}
.landing-step-num {
  position: absolute;
  top: -18px;
  left: 28px;
  width: 36px;
  height: 36px;
  background: var(--accent);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(232, 85, 61, 0.30);
}
.landing-step-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 12px 0 12px;
  color: #1C1714;
}
.landing-step-body {
  margin: 0 0 24px;
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(28, 23, 20, 0.72);
}
.landing-step-body em {
  font-style: italic;
  color: #1C1714;
}

/* Step mocks (mini visuals per stap) */
.landing-step-mock {
  background: #F5F1EC;
  border-radius: 14px;
  padding: 16px 18px;
  min-height: 60px;
  display: flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: rgba(28, 23, 20, 0.70);
}

.landing-step-mock-prompt {
  display: flex;
  align-items: center;
  gap: 8px;
}
.landing-step-mock-cursor {
  display: inline-block;
  width: 2px;
  height: 14px;
  background: var(--accent);
  animation: landing-blink 1s infinite;
}
@keyframes landing-blink {
  0%, 50% { opacity: 1; }
  51%, 100% { opacity: 0; }
}

.landing-step-mock-scan {
  display: flex;
  align-items: center;
  gap: 10px;
}
.landing-step-mock-pulse {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  animation: landing-pulse 1.4s infinite;
}
@keyframes landing-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.4); opacity: 0.5; }
}

.landing-step-mock-cards {
  display: flex;
  gap: 8px;
  width: 100%;
}
.landing-step-mock-card {
  flex: 1;
  height: 44px;
  border-radius: 8px;
  background: linear-gradient(135deg, #e4d0b0 0%, #c8a878 100%);
  opacity: 0.75;
}
.landing-step-mock-card:nth-child(2) {
  background: linear-gradient(135deg, #b8a598 0%, #7a6c5d 100%);
}
.landing-step-mock-card:nth-child(3) {
  background: linear-gradient(135deg, #d8c5b8 0%, #a88f7a 100%);
}

/* ================= SECTIE 4 - EDIT PREVIEW ================= */
.landing-edit {
  padding: 100px 0;
  background: #fff;
}
.landing-edit .landing-section-title {
  text-align: center;
  margin-bottom: 56px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.landing-edit .landing-section-eyebrow {
  display: flex;
  justify-content: center;
}

.landing-edit-wrap {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 56px;
  align-items: start;
}

/* Mock newsletter card */
.landing-edit-mock {
  background: #F5F1EC;
  border-radius: 18px;
  padding: 28px;
  box-shadow: 0 12px 40px rgba(28, 23, 20, 0.10), 0 2px 6px rgba(28, 23, 20, 0.04);
  position: relative;
}
.landing-edit-mock::before {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid rgba(28, 23, 20, 0.06);
  border-radius: 18px;
  pointer-events: none;
}

.landing-edit-mock-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(28, 23, 20, 0.08);
  margin-bottom: 20px;
}
.landing-edit-mock-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
}
.landing-edit-mock-brand .brand-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1rem;
}
.landing-edit-mock-sep {
  color: rgba(28, 23, 20, 0.3);
}
.landing-edit-mock-issue {
  font-weight: 500;
  color: rgba(28, 23, 20, 0.6);
}
.landing-edit-mock-date {
  font-size: 0.8rem;
  color: rgba(28, 23, 20, 0.5);
}

.landing-edit-mock-title {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 0 0 10px;
  color: #1C1714;
}
.landing-edit-mock-intro {
  margin: 0 0 24px;
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(28, 23, 20, 0.72);
}

.landing-edit-mock-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 24px;
}
.landing-edit-mock-item {
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(28, 23, 20, 0.05);
}
.landing-edit-mock-img {
  width: 100%;
  aspect-ratio: 4 / 3;
}
.landing-edit-mock-meta {
  padding: 10px 12px 12px;
}
.landing-edit-mock-brand-small {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(28, 23, 20, 0.55);
  margin-bottom: 4px;
}
.landing-edit-mock-name {
  font-size: 0.85rem;
  font-weight: 500;
  color: #1C1714;
  margin-bottom: 4px;
  line-height: 1.3;
}
.landing-edit-mock-price {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--accent);
  display: flex;
  align-items: center;
  gap: 6px;
}
.landing-edit-mock-steal {
  font-family: var(--font-sans);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  background: var(--accent);
  color: #fff;
  padding: 2px 6px;
  border-radius: 4px;
}

.landing-edit-mock-tip {
  background: #fff;
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 18px;
  border-left: 3px solid var(--accent);
}
.landing-edit-mock-tip-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
}
.landing-edit-mock-tip p {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.5;
  color: rgba(28, 23, 20, 0.72);
}

.landing-edit-mock-cta {
  text-align: center;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--accent);
  padding: 12px;
  border-top: 1px dashed rgba(28, 23, 20, 0.15);
}

/* Benefits panel naast de mock */
.landing-edit-benefits {
  padding-top: 12px;
}
.landing-edit-benefits-title {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin: 0 0 24px;
  color: #1C1714;
}
.landing-edit-benefits-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.landing-edit-benefits-list li {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.landing-edit-bullet {
  color: var(--accent);
  font-size: 1rem;
  line-height: 1.55;
  flex-shrink: 0;
}
.landing-edit-benefits-list strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 600;
  color: #1C1714;
  margin-bottom: 4px;
}
.landing-edit-benefits-list p {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(28, 23, 20, 0.68);
}

/* ================= SECTIE 5 - TWEEDE CTA ================= */
.landing-cta2 {
  padding: 100px 0;
  background: #1C1714;
  color: #fff;
  text-align: center;
}
.landing-cta2 .landing-section-inner {
  max-width: 720px;
}
.landing-cta2-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin: 0 0 16px;
  color: #fff;
}
.landing-cta2-sub {
  margin: 0 0 40px;
  font-size: 1.05rem;
  color: rgba(255, 255, 255, 0.68);
}

.landing-form-cta2 .landing-form-row {
  background: #fff;
}
.landing-form-cta2 .landing-form-micro {
  color: rgba(255, 255, 255, 0.55);
}
.landing-cta2 .landing-counter {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.80);
}
.landing-cta2 .landing-counter-num {
  color: #fff;
}

/* ================= SECTIE 6 - FOOTER ================= */
.landing-footer {
  padding: 48px 0 32px;
  background: #F5F1EC;
  border-top: 1px solid rgba(28, 23, 20, 0.06);
}
.landing-footer-inner {
  width: min(1120px, calc(100% - 48px));
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 24px;
}
.landing-footer-brand .brand-name {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 600;
}
.landing-footer-tagline {
  margin: 4px 0 0;
  font-size: 0.85rem;
  color: rgba(28, 23, 20, 0.55);
}
.landing-footer-socials {
  display: flex;
  gap: 24px;
}
.landing-footer-legal {
  font-size: 0.82rem;
  color: rgba(28, 23, 20, 0.50);
}
.landing-footer-legal a {
  color: rgba(28, 23, 20, 0.70);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.landing-footer-legal a:hover {
  color: var(--accent);
}

/* ================= FAQ ================= */
.landing-faq {
  padding: 96px 0;
  background: var(--bg);
}
.landing-faq-list {
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--line-strong);
}
.landing-faq-item {
  border-bottom: 1px solid var(--line-strong);
}
.landing-faq-icon::before {
  content: '+';
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--muted);
  line-height: 1;
  transition: var(--transition);
}
.landing-faq-item[open] .landing-faq-icon::before {
  content: '−';
}
.landing-faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 0;
  font-family: var(--font-display);
  font-size: 1.0625rem;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.landing-faq-q::-webkit-details-marker {
  display: none;
}
.landing-faq-q:hover {
  color: var(--accent);
}
.landing-faq-a {
  margin: 0;
  padding: 0 0 24px;
  color: var(--muted);
  font-size: 0.9375rem;
  line-height: 1.7;
  max-width: 640px;
}

/* ================= RESPONSIVE ================= */
@media (max-width: 720px) {
  .landing-header {
    padding: 16px 0;
  }
  .landing-hero {
    padding: 20px 0 60px;
  }
  .landing-hero-blob {
    width: 360px;
    height: 360px;
    top: 20%;
    right: -40%;
  }
  .landing-problem,
  .landing-how,
  .landing-faq,
  .landing-cta2 {
    padding: 64px 0;
  }
  .landing-problem-grid,
  .landing-steps {
    grid-template-columns: 1fr;
  }
  .landing-form-row {
    flex-direction: column;
    padding: 10px;
    border-radius: 18px;
  }
  .landing-input {
    padding: 12px 16px;
    text-align: center;
  }
  .landing-submit {
    justify-content: center;
    width: 100%;
  }
  .landing-footer-inner {
    flex-direction: column;
    text-align: center;
  }
}

