/* ════════════════════════════════════════════════════════════════════
   DOUBLEYOU — PASKAMER PRAAT
   Premium Design System v6.0
   Single source of truth — geen duplicaten, geen overrides
   ════════════════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ── */
:root {
  /* Kleurenpalet */
  --ink:        #1e1a0f;
  --ink-soft:   #3a3018;
  --ink-muted:  #7a6a3a;
  --cream:      #fdf8f0;
  --warm:       #f5edda;
  --parchment:  #e2cfa0;
  --clay:       #c67d06;
  --clay-l:     #d4910a;
  --clay-d:     #a56605;
  --white:      #fefcf5;
  --success:    #1a6b3a;
  --danger:     #c0392b;
  --border:     rgba(30,26,15,0.10);
  --border-m:   rgba(30,26,15,0.18);
  --clay-alpha: rgba(198,125,6,0.10);
  --clay-glow:  rgba(198,125,6,0.20);

  /* Spacing scale (4px base) */
  --sp-1: 0.25rem;   /* 4px */
  --sp-2: 0.5rem;    /* 8px */
  --sp-3: 0.75rem;   /* 12px */
  --sp-4: 1rem;      /* 16px */
  --sp-5: 1.25rem;   /* 20px */
  --sp-6: 1.5rem;    /* 24px */
  --sp-8: 2rem;      /* 32px */
  --sp-10: 2.5rem;   /* 40px */
  --sp-12: 3rem;     /* 48px */

  /* Border radii */
  --r-xs:   4px;
  --r-sm:   6px;
  --r-md:   10px;
  --r-lg:   14px;
  --r-xl:   20px;
  --r-pill: 100px;

  /* Typography scale */
  --t-xs:   0.65rem;   /* 10.4px — labels, badges */
  --t-sm:   0.75rem;   /* 12px — meta, timestamps */
  --t-base: 0.875rem;  /* 14px — body */
  --t-md:   1rem;      /* 16px — subheadings */
  --t-lg:   1.125rem;  /* 18px — section titles */
  --t-xl:   1.375rem;  /* 22px — page titles */
  --t-2xl:  1.75rem;   /* 28px — hero */
  --t-3xl:  2.25rem;   /* 36px — display */

  /* Shadows */
  --sh-sm:  0 1px 3px rgba(30,26,15,0.06), 0 1px 2px rgba(30,26,15,0.04);
  --sh-md:  0 4px 12px rgba(30,26,15,0.08), 0 2px 4px rgba(30,26,15,0.04);
  --sh-lg:  0 8px 24px rgba(30,26,15,0.10), 0 4px 8px rgba(30,26,15,0.04);

  /* Motion */
  --ease-out:   cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in:    cubic-bezier(0.55, 0, 1, 0.45);
  --ease-io:    cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast:   0.15s;
  --dur-mid:    0.25s;
  --dur-slow:   0.4s;

  /* Layout */
  --nav-h:      64px;
  --topbar-h:   56px;
  --max-w:      680px;
}

/* ── RESET ── */
*, *::before, *::after {
  margin: 0; padding: 0;
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}
html { scroll-behavior: smooth; overflow-x: hidden; }
::-webkit-scrollbar { display: none; }
* { scrollbar-width: none; }

/* ── BASE ── */
body {
  font-family: 'DM Sans', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: var(--t-base);
  line-height: 1.55;
  color: var(--ink);
  background: #e8dfd0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
html, body { max-width: 100vw; }

/* ── ACCESSIBILITY ── */
.dy-skip-link {
  position: absolute; top: -100%; left: 0;
  padding: var(--sp-2) var(--sp-4);
  background: var(--clay); color: var(--white);
  font-size: var(--t-sm); font-weight: 600;
  z-index: 9999; border-radius: 0 0 var(--r-sm) 0;
  text-decoration: none;
  transition: top var(--dur-fast);
}
.dy-skip-link:focus { top: 0; }
*:focus-visible { outline: 2px solid var(--clay); outline-offset: 2px; border-radius: var(--r-xs); }
button:focus:not(:focus-visible), a:focus:not(:focus-visible) { outline: none; }

/* ── ANIMATIONS ── */
@keyframes fadeIn    { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp   { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes shimmer   { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
@keyframes dotPulse  { 0%,80%,100% { transform: scale(0.5); opacity: 0.3; } 40% { transform: scale(1); opacity: 1; } }
@keyframes spin      { to { transform: rotate(360deg); } }
@keyframes dspPop    { 0% { transform: translateX(-50%) scale(0.85) translateY(8px); opacity: 0; } 60% { transform: translateX(-50%) scale(1.06) translateY(0); opacity: 1; } 100% { transform: translateX(-50%) scale(1); opacity: 1; } }
@keyframes pageIn    { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.dy-fade-in  { animation: fadeIn var(--dur-mid) var(--ease-out) both; }
.dy-slide-up { animation: slideUp var(--dur-slow) var(--ease-out) both; }

/* ── APP LAYOUT ── */
.dy-main {
  margin-top: var(--topbar-h);
  min-height: calc(100vh - var(--topbar-h) - var(--nav-h));
  padding-bottom: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px));
  background: var(--cream);
  animation: pageIn var(--dur-mid) var(--ease-out);
}
@media (min-width: 640px) {
  .dy-main { max-width: var(--max-w); margin: var(--topbar-h) auto 0; box-shadow: var(--sh-lg); }
}

/* ── TOPBAR ── */
.dy-topbar {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--topbar-h);
  background: var(--ink);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--sp-4);
  z-index: 100;
  border-bottom: 1px solid rgba(198,125,6,0.15);
}
@media (min-width: 640px) { .dy-topbar { padding: 0 var(--sp-6); } }
.dy-topbar-logo {
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem; font-weight: 800;
  color: var(--clay); letter-spacing: -0.02em;
  cursor: pointer; user-select: none;
}
.dy-topbar-logo em { color: rgba(198,125,6,0.45); font-style: normal; font-weight: 300; }
.dy-topbar-actions { display: flex; align-items: center; gap: var(--sp-1); }
.dy-topbar-btn {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: none; border: none;
  color: rgba(254,252,245,0.5); cursor: pointer;
  border-radius: var(--r-md);
  transition: color var(--dur-fast), background var(--dur-fast);
  position: relative;
}
.dy-topbar-btn:hover { color: var(--clay); background: rgba(198,125,6,0.08); }
.dy-topbar-btn svg { width: 20px; height: 20px; stroke-width: 1.5; }
.dy-topbar-badge {
  position: absolute; top: 6px; right: 6px;
  width: 7px; height: 7px;
  background: var(--clay); border-radius: 50%;
  border: 1.5px solid var(--ink);
}
#dy-profiel-avatar-btn {
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; color: var(--white); font-size: var(--t-xs);
  cursor: pointer; overflow: hidden; border: none;
  transition: opacity var(--dur-fast);
}
#dy-profiel-avatar-btn:hover { opacity: 0.85; }

/* ── BOTTOM NAV ── */
.dy-nav {
  position: fixed; bottom: 0; left: 0; right: 0;
  height: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
  background: var(--ink);
  display: flex;
  border-top: 1px solid rgba(198,125,6,0.12);
  z-index: 100;
}
@media (min-width: 640px) {
  .dy-nav { left: 50%; right: auto; transform: translateX(-50%); width: var(--max-w); }
}
.dy-nav-item {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 3px;
  color: rgba(254,252,245,0.28);
  font-size: 0.58rem; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  cursor: pointer; border: none; background: none;
  font-family: inherit;
  transition: color var(--dur-fast);
  min-height: 44px;
  -webkit-user-select: none; user-select: none;
}
.dy-nav-item svg { width: 22px; height: 22px; fill: currentColor; }
.dy-nav-item.active { color: var(--clay); }
.dy-nav-item:hover { color: rgba(198,125,6,0.6); }

/* Center Deel knop */
.dy-nav-center {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  position: relative; min-height: 44px;
}
.dy-nav-center-ring {
  position: absolute; top: -18px;
  width: 50px; height: 50px;
  background: var(--clay);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: none; cursor: pointer;
  box-shadow: 0 4px 16px rgba(198,125,6,0.35), 0 2px 4px rgba(198,125,6,0.2);
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast);
  -webkit-user-select: none; user-select: none;
}
.dy-nav-center-ring:hover { transform: scale(1.06); box-shadow: 0 6px 20px rgba(198,125,6,0.45); }
.dy-nav-center-ring:active { transform: scale(0.96); }
.dy-nav-center-ring svg { stroke: var(--white); }
.dy-nav-center-lbl {
  margin-top: 24px;
  font-size: 0.58rem; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: rgba(254,252,245,0.28);
}

/* ── STORIES ── */
.dy-stories {
  display: flex; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-3);
  overflow-x: auto;
  border-bottom: 1px solid var(--border);
  background: var(--cream);
}
.dy-story {
  display: flex; flex-direction: column;
  align-items: center; gap: var(--sp-1);
  cursor: pointer; flex-shrink: 0;
  transition: transform var(--dur-fast) var(--ease-out);
  -webkit-user-select: none; user-select: none;
}
.dy-story:active { transform: scale(0.93); }
.dy-story-ring {
  width: 60px; height: 60px; border-radius: 50%;
  padding: 2.5px;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
}
.dy-story-ring.viewed { background: var(--parchment); }
.dy-story-avatar {
  width: 100%; height: 100%; border-radius: 50%;
  background: var(--warm); border: 2.5px solid var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; color: var(--clay); font-size: 1rem;
  overflow: hidden;
}
.dy-story-avatar img { width: 100%; height: 100%; object-fit: cover; }
.dy-story-name {
  font-size: var(--t-xs); color: var(--ink-muted);
  max-width: 60px; text-align: center;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* ── FILTERS ── */
.dy-filters {
  display: flex; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  overflow-x: auto;
  background: var(--cream);
  border-bottom: 1px solid var(--border);
}
.dy-filter {
  padding: var(--sp-2) var(--sp-4);
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: var(--r-pill); color: var(--ink-muted);
  font-family: inherit; font-size: var(--t-sm); font-weight: 500;
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
  transition: all var(--dur-fast);
}
.dy-filter.active {
  background: var(--clay); border-color: var(--clay);
  color: var(--white); font-weight: 700;
}

/* ── FIT PROMPT ── */
.dy-fit-prompt {
  margin: var(--sp-2) var(--sp-3);
  background: rgba(198,125,6,0.05);
  border: 1px solid rgba(198,125,6,0.18);
  border-radius: var(--r-md); cursor: pointer;
  transition: all var(--dur-fast);
}
.dy-fit-prompt:hover { background: rgba(198,125,6,0.09); border-color: rgba(198,125,6,0.3); }
.dy-fit-prompt-inner {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
}
.dy-fit-prompt-icon { font-size: 1.25rem; flex-shrink: 0; }
.dy-fit-prompt-text { flex: 1; min-width: 0; }
.dy-fit-prompt-text strong { display: block; font-size: var(--t-base); font-weight: 700; color: var(--ink); }
.dy-fit-prompt-text span { font-size: var(--t-xs); color: var(--ink-muted); }

/* ── FEED GRID ── */
.dy-verhalen-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px; padding: 10px var(--sp-3);
}
@media (min-width: 480px) { .dy-verhalen-grid { grid-template-columns: repeat(3, 1fr); } }
.dy-verhalen-grid.dy-kaart-full { grid-template-columns: 1fr; }

/* ── KAART ── */
.dy-kaart {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: var(--sh-sm);
  transition: transform var(--dur-mid) var(--ease-out), box-shadow var(--dur-mid);
  cursor: pointer;
  -webkit-user-select: none; user-select: none;
}
.dy-kaart:hover { transform: translateY(-2px); box-shadow: var(--sh-md); }
.dy-kaart:active { transform: scale(0.98); }

/* Kaart header */
.dy-kaart-header {
  padding: var(--sp-2) var(--sp-3);
  display: flex; align-items: center; gap: var(--sp-2);
  border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.dy-kaart-auteur {
  display: flex; align-items: center; gap: var(--sp-2);
  flex: 1; overflow: hidden;
}
.dy-kaart-meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.dy-kaart-naam {
  font-size: var(--t-sm); font-weight: 700; color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 120px; display: block;
}
.dy-kaart-tijd { font-size: var(--t-xs); color: var(--ink-muted); white-space: nowrap; }
.dy-eigen-badge {
  font-size: var(--t-xs); font-weight: 600;
  background: var(--clay-alpha); color: var(--clay);
  border: 1px solid var(--clay-glow); border-radius: var(--r-pill);
  padding: 1px var(--sp-2); flex-shrink: 0; white-space: nowrap;
}

/* Kaart foto */
.dy-img-wrap {
  position: relative; aspect-ratio: 4/5;
  overflow: hidden; background: var(--warm); flex-shrink: 0;
}
.dy-kaart-foto {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 0.5s var(--ease-out);
}
.dy-kaart:hover .dy-kaart-foto { transform: scale(1.03); }
.dy-img-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: var(--sp-8) var(--sp-3) var(--sp-2);
  background: linear-gradient(transparent, rgba(30,26,15,0.85));
}
.dy-product-chip {
  display: inline-flex; align-items: center; gap: var(--sp-1);
  background: rgba(254,252,245,0.12); backdrop-filter: blur(8px);
  padding: 3px var(--sp-3); border-radius: var(--r-pill);
  font-size: var(--t-xs); font-weight: 500; color: var(--white);
}

/* Kaart body */
.dy-kaart-body { padding: var(--sp-2) var(--sp-3); flex: 1; }
.dy-match-badge {
  display: inline-block; font-size: var(--t-xs); font-weight: 600;
  background: var(--clay-alpha); color: var(--clay);
  border: 1px solid var(--clay-glow); border-radius: var(--r-pill);
  padding: 1px var(--sp-2); margin-bottom: var(--sp-1);
}
.dy-kaart-titel {
  font-size: var(--t-base); font-weight: 700; color: var(--ink);
  display: block; margin-bottom: var(--sp-1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dy-kaart-tekst {
  font-size: var(--t-sm); color: var(--ink-soft); line-height: 1.6;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  overflow: hidden;
}
.dy-kaart-stats { font-size: var(--t-xs); color: var(--ink-muted); margin-top: var(--sp-1); }

/* Kaart footer */


.dy-kaart-actie:hover, .dy-like-btn:hover, .dy-reactie-btn:hover, .dy-deel-btn:hover {
  background: var(--warm); color: var(--clay);
}
.dy-kaart-actie.liked, .dy-like-btn.liked { color: var(--danger); }
.dy-kaart-actie.liked svg, .dy-like-btn.liked svg { fill: var(--danger); }
.dy-kaart-actie svg, .dy-like-btn svg, .dy-reactie-btn svg, .dy-deel-btn svg {
  width: 15px; height: 15px; fill: currentColor; flex-shrink: 0;
}
.dy-lees-btn {
  margin-left: auto; color: var(--clay); font-size: var(--t-xs); font-weight: 700;
  background: none; border: none; cursor: pointer; font-family: inherit;
  padding: var(--sp-2); min-height: 44px; white-space: nowrap;
}

/* ── AVATAR ── */
.dy-avatar {
  width: 36px; height: 36px; min-width: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
  display: flex; align-items: center; justify-content: center;
  font-size: var(--t-xs); font-weight: 700; color: var(--white);
  overflow: hidden; flex-shrink: 0;
}
.dy-avatar img, .dy-avatar-foto { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.dy-avatar-lg { width: 48px; height: 48px; min-width: 48px; font-size: var(--t-sm); }
.dy-avatar-sm { width: 28px; height: 28px; min-width: 28px; font-size: var(--t-xs); }
.dy-avatar-pending { opacity: 0.6; }

/* ── FEED LEEG STATE ── */
.dy-feed-leeg {
  grid-column: 1/-1; text-align: center;
  padding: var(--sp-12) var(--sp-6);
}
.dy-feed-leeg-icon { font-size: 2.5rem; display: block; margin-bottom: var(--sp-3); opacity: 0.5; }
.dy-feed-leeg-titel { font-size: var(--t-lg); font-weight: 800; color: var(--ink); margin-bottom: var(--sp-2); }
.dy-feed-leeg-tekst {
  font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.7;
  max-width: 260px; margin: 0 auto var(--sp-5);
}

/* ── EMPTY STATE ── */
.dy-empty { text-align: center; padding: var(--sp-12) var(--sp-6); }
.dy-empty-icon { font-size: 2.25rem; display: block; margin-bottom: var(--sp-3); opacity: 0.45; }
.dy-empty-title { font-size: var(--t-md); font-weight: 700; color: var(--ink); margin-bottom: var(--sp-2); }
.dy-empty-text { font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.7; max-width: 240px; margin: 0 auto var(--sp-4); }
.dy-leeg { grid-column: 1/-1; text-align: center; padding: var(--sp-8) var(--sp-4); }
.dy-leeg p { font-size: var(--t-sm); color: var(--ink-muted); }
.dy-leeg-tekst { font-size: var(--t-sm); color: var(--ink-muted); padding: var(--sp-3) var(--sp-4); }

/* ── LOADING ── */
.dy-loading-wrap { grid-column: 1/-1; display: flex; justify-content: center; padding: var(--sp-10); }
.dy-dot-loader { display: flex; gap: 6px; align-items: center; }
.dy-dot-loader span {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--clay);
  animation: dotPulse 1.4s ease-in-out infinite;
}
.dy-dot-loader span:nth-child(2) { animation-delay: 0.2s; }
.dy-dot-loader span:nth-child(3) { animation-delay: 0.4s; }
.dy-spinner {
  width: 22px; height: 22px;
  border: 2px solid var(--border); border-top-color: var(--clay);
  border-radius: 50%; animation: spin 0.75s linear infinite; margin: 0 auto;
}
.dy-loader { display: flex; justify-content: center; padding: var(--sp-8); }
.dy-feed-sentinel { padding: var(--sp-4); text-align: center; grid-column: 1/-1; }

/* Skeleton */
.dy-skeleton { background: linear-gradient(90deg, var(--warm) 25%, var(--parchment) 50%, var(--warm) 75%); background-size: 200% 100%; animation: shimmer 1.5s infinite; border-radius: var(--r-sm); }
.dy-skeleton-kaart { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-skeleton-foto { aspect-ratio: 4/5; background: linear-gradient(90deg, var(--warm) 25%, var(--parchment) 50%, var(--warm) 75%); background-size: 200% 100%; animation: shimmer 1.5s infinite; }
.dy-skeleton-tekst { padding: var(--sp-2) var(--sp-3); }
.dy-skeleton-regel { height: 9px; border-radius: var(--r-xs); margin-bottom: var(--sp-2); background: linear-gradient(90deg, var(--warm) 25%, var(--parchment) 50%, var(--warm) 75%); background-size: 200% 100%; animation: shimmer 1.5s infinite; }

/* ── FEED HEADER / PAGE TITLES ── */
.dy-feed-header { padding: var(--sp-4) var(--sp-3) var(--sp-2); background: var(--cream); }
.dy-feed-header-inner { display: flex; justify-content: space-between; align-items: flex-start; }
.dy-page-title { font-family: 'DM Sans', sans-serif; font-size: var(--t-xl); font-weight: 800; color: var(--ink); line-height: 1.15; }
.dy-page-title em { color: var(--clay); font-style: italic; font-weight: 300; font-family: 'Cormorant Garamond', serif; }
.dy-page-sub { font-size: var(--t-sm); color: var(--ink-muted); margin-top: var(--sp-1); line-height: 1.55; }
.dy-feed-intro { font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.65; margin-top: var(--sp-1); }
.dy-feed-nav-links { display: flex; align-items: center; gap: var(--sp-2); margin-top: var(--sp-3); flex-wrap: wrap; }
.dy-feed-nav-btn { background: none; border: none; color: var(--clay); font-family: inherit; font-size: var(--t-sm); font-weight: 600; cursor: pointer; padding: 0; display: flex; align-items: center; gap: var(--sp-1); transition: opacity var(--dur-fast); }
.dy-feed-nav-btn:hover { opacity: 0.7; }
.dy-feed-nav-icon { color: var(--clay); }
.dy-feed-nav-sep { color: var(--ink-muted); font-size: var(--t-sm); }

/* ── KNOPPEN ── */
.dy-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  width: 100%; padding: var(--sp-3) var(--sp-5);
  border: none; border-radius: var(--r-md);
  font-family: inherit; font-size: var(--t-base); font-weight: 700;
  cursor: pointer; transition: all var(--dur-fast) var(--ease-out);
  text-transform: uppercase; letter-spacing: 0.05em;
  min-height: 48px; text-decoration: none;
  -webkit-user-select: none; user-select: none;
}
.dy-btn:active { transform: scale(0.98); }
.dy-btn-primary { background: var(--clay); color: var(--white); }
.dy-btn-primary:hover { background: var(--clay-l); box-shadow: 0 4px 16px rgba(198,125,6,0.28); }
.dy-btn-primary:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }
.dy-btn-secondary { background: transparent; color: var(--ink-muted); border: 1.5px solid var(--border-m); }
.dy-btn-secondary:hover { border-color: var(--ink-muted); color: var(--ink); }
.dy-btn-ghost { background: transparent; color: var(--clay); border: 1.5px solid rgba(198,125,6,0.25); }
.dy-btn-ghost:hover { border-color: var(--clay); background: var(--clay-alpha); }
.dy-btn-uitloggen { color: var(--danger) !important; border-color: rgba(192,57,43,0.2) !important; }
.dy-btn-uitloggen:hover { background: rgba(192,57,43,0.05) !important; }
.dy-btn-link { background: none; border: none; color: var(--clay); font-family: inherit; font-size: var(--t-sm); font-weight: 600; cursor: pointer; padding: 0; text-decoration: underline; }
.dy-btn-media {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--warm); border: 1.5px solid var(--border); border-radius: var(--r-sm);
  font-family: inherit; font-size: var(--t-sm); font-weight: 500; color: var(--ink-muted);
  cursor: pointer; transition: all var(--dur-fast);
}
.dy-btn-media:hover { border-color: var(--clay); color: var(--clay); }
.dy-skip-btn { background: none; border: none; color: var(--ink-muted); font-family: inherit; font-size: var(--t-sm); cursor: pointer; padding: var(--sp-2) 0; text-align: center; width: 100%; }
.dy-back-btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  background: none; border: none; color: var(--clay);
  font-family: inherit; font-size: var(--t-sm); font-weight: 600;
  cursor: pointer; padding: var(--sp-2) 0; min-height: 44px;
  transition: opacity var(--dur-fast);
}
.dy-back-btn:hover { opacity: 0.7; }

/* ── FORMS ── */
.dy-form-wrap { padding: var(--sp-4) var(--sp-3) var(--sp-12); max-width: 600px; margin: 0 auto; }
.dy-field { margin-bottom: var(--sp-4); }
.dy-label {
  display: block; font-size: var(--t-xs); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--ink-soft); margin-bottom: var(--sp-2);
}
.dy-label-klein {
  display: block; font-size: var(--t-xs); font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(198,125,6,0.65); margin-bottom: var(--sp-1);
}
.dy-input {
  width: 100%; padding: var(--sp-3) var(--sp-4);
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: var(--r-md); color: var(--ink);
  font-size: var(--t-base); font-family: inherit;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
  min-height: 48px;
}
.dy-input:focus { outline: none; border-color: var(--clay); box-shadow: 0 0 0 3px rgba(198,125,6,0.10); }
.dy-input::placeholder { color: var(--ink-muted); }
.dy-input.error { border-color: var(--danger); box-shadow: 0 0 0 3px rgba(192,57,43,0.08); }
.dy-textarea {
  width: 100%; padding: var(--sp-3) var(--sp-4);
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: var(--r-md); color: var(--ink);
  font-size: var(--t-base); font-family: inherit; resize: vertical;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
  min-height: 120px; line-height: 1.6;
}
.dy-textarea:focus { outline: none; border-color: var(--clay); box-shadow: 0 0 0 3px rgba(198,125,6,0.10); }
.dy-form-err { color: var(--danger); font-size: var(--t-xs); margin-top: var(--sp-1); display: none; }
.dy-form-err.zichtbaar { display: block; }
.dy-ob-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.dy-maten-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }

/* ── TOAST ── */
.dy-toast {
  position: fixed;
  bottom: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px) + var(--sp-3));
  left: 50%; transform: translateX(-50%) translateY(10px);
  background: var(--ink); color: var(--white);
  padding: var(--sp-2) var(--sp-5); border-radius: var(--r-pill);
  font-size: var(--t-sm); font-weight: 500;
  box-shadow: var(--sh-lg); z-index: 500;
  opacity: 0; pointer-events: none; white-space: nowrap;
  transition: opacity var(--dur-mid), transform var(--dur-mid) var(--ease-out);
  max-width: 90vw;
}
.dy-toast.visible, .dy-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.dy-toast-dsp {
  position: fixed;
  bottom: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px) + var(--sp-3));
  left: 50%; transform: translateX(-50%);
  background: var(--clay); color: var(--white);
  padding: var(--sp-2) var(--sp-5); border-radius: var(--r-pill);
  font-size: var(--t-sm); font-weight: 700;
  box-shadow: 0 4px 20px rgba(198,125,6,0.3); z-index: 501;
  white-space: nowrap; animation: dspPop var(--dur-slow) var(--ease-out) both;
}

/* ── PROFIEL ── */
.dy-profiel-wrap { background: var(--cream); padding-bottom: var(--sp-8); }
.dy-profiel-hero { background: var(--ink); padding: var(--sp-8) var(--sp-4) var(--sp-5); text-align: center; }
.dy-profiel-avatar-container { position: relative; width: 88px; height: 88px; margin: 0 auto var(--sp-3); cursor: pointer; }
.dy-profiel-avatar-lg {
  width: 88px; height: 88px; border-radius: 50%;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
  display: flex; align-items: center; justify-content: center;
  font-size: var(--t-2xl); font-weight: 700; color: var(--white);
  overflow: hidden; border: 2px solid rgba(198,125,6,0.2);
  box-shadow: 0 0 24px rgba(198,125,6,0.2);
}
.dy-profiel-avatar-lg img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.dy-profiel-avatar-edit {
  position: absolute; bottom: 0; right: 0;
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--clay); display: flex; align-items: center; justify-content: center;
}
.dy-profiel-avatar-edit svg { width: 13px; height: 13px; fill: var(--white); stroke: none; }
.dy-profiel-foto-ring {
  position: absolute; inset: 0; border-radius: 50%;
  background: rgba(30,26,15,0.45);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity var(--dur-fast);
}
.dy-profiel-avatar-container:hover .dy-profiel-foto-ring { opacity: 1; }
.dy-profiel-foto-ring svg { width: 20px; height: 20px; stroke: var(--white); fill: none; }
.dy-profiel-naam-wrap { display: flex; align-items: center; justify-content: center; gap: var(--sp-2); margin-bottom: var(--sp-1); }
.dy-profiel-naam { font-family: 'DM Sans', sans-serif; font-size: var(--t-lg); font-weight: 800; color: var(--white); }
.dy-profiel-naam-edit-btn { background: none; border: none; cursor: pointer; color: rgba(254,252,245,0.35); padding: var(--sp-1); transition: color var(--dur-fast); }
.dy-profiel-naam-edit-btn:hover { color: var(--clay); }
.dy-profiel-naam-edit-btn svg { width: 14px; height: 14px; fill: currentColor; }
.dy-profiel-email { font-size: var(--t-xs); color: rgba(254,252,245,0.35); margin-top: var(--sp-1); }
.dy-profiel-identity {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  margin-top: var(--sp-3); padding: var(--sp-1) var(--sp-3);
  background: rgba(198,125,6,0.10); border: 1px solid rgba(198,125,6,0.18);
  border-radius: var(--r-pill); font-size: var(--t-xs); font-weight: 600; color: var(--clay);
}
.dy-profiel-niveau { display: flex; align-items: center; gap: var(--sp-2); justify-content: center; margin-top: var(--sp-2); }
.dy-niveau-naam { font-size: var(--t-sm); color: rgba(254,252,245,0.5); }
.dy-profiel-badge { position: absolute; bottom: 0; right: 0; font-size: 1.1rem; line-height: 1; }

/* Profiel stats */
.dy-profiel-stats { display: grid; grid-template-columns: repeat(3, 1fr); border-bottom: 1px solid var(--border); }
.dy-profiel-stat { padding: var(--sp-4) var(--sp-2); text-align: center; }
.dy-profiel-stat + .dy-profiel-stat { border-left: 1px solid var(--border); }
.dy-profiel-stat-val, .dy-profiel-stat-value { display: block; font-size: var(--t-2xl); font-weight: 800; color: var(--ink); line-height: 1; margin-bottom: var(--sp-1); font-family: 'DM Sans', sans-serif; }
.dy-profiel-stat-lbl, .dy-profiel-stat-label { font-size: var(--t-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.08em; }

/* Secties in profiel */
.dy-profiel-sectie {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--sp-4); margin: var(--sp-2) var(--sp-3);
}
.dy-profiel-sectie-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-3); }
.dy-profiel-sectie-titel { font-size: var(--t-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--clay); }
.dy-profiel-sectie-edit { font-size: var(--t-sm); color: var(--clay); background: none; border: none; cursor: pointer; font-family: inherit; font-weight: 600; }

/* DSP in profiel */
.dy-dsp-wrap { padding: 0 var(--sp-3) var(--sp-8); }
.dy-dsp-sectie { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-4); margin-bottom: var(--sp-2); }
.dy-dsp-sectie-titel { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--border); }
.dy-niveau-kaart { margin: var(--sp-2) var(--sp-3); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-4); }
.dy-niveau-kaart-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-3); font-size: var(--t-md); font-weight: 700; color: var(--ink); }
.dy-niveau-pct { font-size: var(--t-sm); color: var(--clay); font-weight: 600; }
.dy-progress-bar { height: 7px; background: var(--warm); border-radius: var(--r-xs); overflow: hidden; margin-bottom: var(--sp-3); }
.dy-progress-fill { height: 100%; background: linear-gradient(90deg, var(--clay-d), var(--clay)); border-radius: var(--r-xs); transition: width 1s var(--ease-out); }
.dy-niveau-voordelen { font-size: var(--t-sm); color: var(--ink-soft); margin-bottom: var(--sp-2); line-height: 1.6; }
.dy-niveau-next { font-size: var(--t-sm); color: var(--ink-muted); }
.dy-niveau-next strong { color: var(--clay); }

/* Seizoen kaart */
.dy-seizoen-kaart { margin: var(--sp-2) var(--sp-3); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-seizoen-kaart-header { display: flex; justify-content: space-between; align-items: flex-start; padding: var(--sp-4); border-bottom: 1px solid var(--border); }
.dy-seizoen-label { font-size: var(--t-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-muted); margin-bottom: 2px; }
.dy-seizoen-tier { font-size: var(--t-base); font-weight: 700; color: var(--ink); }
.dy-seizoen-pts { text-align: right; }
.dy-seizoen-pts strong { display: block; font-size: var(--t-2xl); font-weight: 900; color: var(--clay); line-height: 1; font-family: 'DM Sans', sans-serif; }
.dy-seizoen-pts span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-seizoen-voordelen { margin: 0; padding: var(--sp-3) var(--sp-4); font-size: var(--t-sm); color: var(--ink-soft); background: rgba(198,125,6,0.03); border-bottom: 1px solid var(--border); line-height: 1.6; }
.dy-seizoen-alle-tiers { padding: var(--sp-1) 0; }
.dy-seizoen-tier-rij { display: flex; align-items: flex-start; gap: var(--sp-3); padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); }
.dy-seizoen-tier-rij:last-child { border-bottom: none; }
.dy-seizoen-tier-rij.actief { background: rgba(198,125,6,0.03); }
.dy-seizoen-tier-dot { font-size: 0.85rem; color: var(--ink-muted); flex-shrink: 0; padding-top: 1px; }
.dy-seizoen-tier-rij.actief .dy-seizoen-tier-dot { color: var(--clay); }
.dy-seizoen-tier-rij.bereikt .dy-seizoen-tier-dot { color: var(--success); }
.dy-seizoen-tier-info { flex: 1; }
.dy-seizoen-tier-info strong { display: block; font-size: var(--t-sm); font-weight: 700; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-seizoen-tier-info span { display: block; font-size: var(--t-xs); color: var(--ink-muted); line-height: 1.5; margin-top: 1px; }
.dy-seizoen-tier-pts { font-size: var(--t-xs); font-weight: 700; color: var(--clay); white-space: nowrap; flex-shrink: 0; }

/* Stats grid */
.dy-stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); margin: var(--sp-2) var(--sp-3); }
.dy-stat { background: var(--white); padding: var(--sp-4) var(--sp-2); text-align: center; }
.dy-stat-waarde { display: block; font-size: var(--t-2xl); font-weight: 900; color: var(--ink); line-height: 1; margin-bottom: var(--sp-1); font-family: 'DM Sans', sans-serif; }
.dy-stat-label { display: block; font-size: var(--t-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-muted); }

/* DSP knoppen profiel */
.dy-dsp-reglement-btn {
  display: flex; align-items: center; justify-content: space-between;
  width: calc(100% - var(--sp-6)); margin: var(--sp-2) var(--sp-3);
  padding: var(--sp-4); background: var(--white);
  border: 1px solid var(--border); border-radius: var(--r-lg);
  cursor: pointer; transition: border-color var(--dur-fast); font-family: inherit;
}
.dy-dsp-reglement-btn:hover { border-color: var(--clay); }
.dy-dsp-reglement-links { display: flex; align-items: center; gap: var(--sp-3); }
.dy-dsp-reglement-icon { font-size: 1.2rem; color: var(--clay); flex-shrink: 0; }
.dy-dsp-reglement-links strong { display: block; font-size: var(--t-base); color: var(--ink); font-weight: 700; }
.dy-dsp-reglement-links span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-dsp-reglement-btn > svg { width: 18px; height: 18px; fill: var(--ink-muted); flex-shrink: 0; }

/* Push toggle */
.dy-push-toggle-kaart { display: flex; align-items: center; justify-content: space-between; margin: var(--sp-2) var(--sp-3); padding: var(--sp-4); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); }
.dy-push-toggle-links { display: flex; align-items: center; gap: var(--sp-3); }
.dy-push-toggle-icon { font-size: 1.25rem; flex-shrink: 0; }
.dy-push-toggle-links strong { display: block; font-size: var(--t-base); color: var(--ink); font-weight: 700; }
.dy-push-toggle-links span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-push-toggle-btn { padding: var(--sp-1) var(--sp-4); background: var(--warm); border: 1.5px solid var(--border); border-radius: var(--r-pill); font-family: inherit; font-size: var(--t-sm); font-weight: 600; color: var(--ink-muted); cursor: pointer; transition: all var(--dur-fast); }
.dy-push-toggle-btn.actief { background: var(--clay-alpha); border-color: rgba(198,125,6,0.3); color: var(--clay); }

/* Log sectie */
.dy-log-sectie { margin: var(--sp-2) var(--sp-3); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-log-titel { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); padding: var(--sp-3) var(--sp-4) var(--sp-2); border-bottom: 1px solid var(--border); }
.dy-log-item { display: flex; justify-content: space-between; align-items: center; padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); font-size: var(--t-sm); }
.dy-log-item:last-child { border-bottom: none; }
.dy-log-label { color: var(--ink-soft); }
.dy-log-pts { color: var(--clay); font-weight: 700; white-space: nowrap; margin-left: var(--sp-2); }
.dy-dsp-tip { display: flex; gap: var(--sp-3); align-items: flex-start; padding: var(--sp-3); background: var(--clay-alpha); border: 1px solid rgba(198,125,6,0.15); border-radius: var(--r-sm); margin-bottom: var(--sp-4); font-size: var(--t-sm); color: var(--ink-soft); line-height: 1.55; }
.dy-dsp-tip-icon { color: var(--clay); flex-shrink: 0; }
.dy-dsp-tabel { width: 100%; border-collapse: collapse; }
.dy-dsp-tabel td { padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid var(--border); font-size: var(--t-sm); color: var(--ink-soft); }
.dy-dsp-tabel td:last-child { text-align: right; color: var(--clay); font-weight: 700; }

/* Badges */
.dy-badges-sectie { margin: var(--sp-2) var(--sp-3); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-badges-grid { display: flex; flex-wrap: wrap; gap: var(--sp-2); padding: var(--sp-3) var(--sp-4); }
.dy-badge-item { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-1) var(--sp-3); background: var(--clay-alpha); border: 1px solid rgba(198,125,6,0.15); border-radius: var(--r-pill); font-size: var(--t-sm); color: var(--ink-soft); }
.dy-badge-emoji { font-size: 1rem; }
.dy-badge-naam { font-size: var(--t-sm); }
.dy-badge-naam { font-size: var(--t-xs); }

/* Fit identity */
.dy-fit-identity-grid { display: flex; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.dy-fit-stat { text-align: center; flex: 1; background: rgba(198,125,6,0.05); border-radius: var(--r-sm); padding: var(--sp-3) var(--sp-2); }
.dy-fit-stat-val { display: block; font-size: var(--t-xl); font-weight: 700; color: var(--clay); line-height: 1; font-family: 'DM Sans', sans-serif; }
.dy-fit-stat-lbl { display: block; font-size: var(--t-xs); color: var(--ink-muted); letter-spacing: 0.08em; text-transform: uppercase; margin-top: var(--sp-1); }
.dy-fit-tags { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.dy-fit-tag { font-size: var(--t-xs); background: var(--warm); color: var(--ink-muted); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 2px var(--sp-2); }
.dy-fit-identity-leeg { text-align: center; padding: var(--sp-4) 0; }
.dy-fit-identity-leeg p { font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.6; }

/* Profiel acties */
.dy-profiel-acties { display: flex; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3) var(--sp-5); }
.dy-profiel-acties .dy-btn { font-size: var(--t-sm); padding: var(--sp-3); text-transform: none; letter-spacing: 0; min-height: 44px; }

/* Body stat grid */
.dy-body-stats { padding: var(--sp-4); border-bottom: 1px solid var(--border); }
.dy-body-stat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-2); }
.dy-body-stat-item { background: var(--warm); padding: var(--sp-3); border-radius: var(--r-md); border: 1px solid var(--border); }
.dy-body-stat-val { font-size: var(--t-lg); font-weight: 700; color: var(--clay); font-family: 'DM Sans', sans-serif; }
.dy-body-stat-lbl { font-size: var(--t-xs); color: var(--ink-muted); margin-top: var(--sp-1); }

/* ── ALLE NIVEAUS ── */
.dy-alle-niveaus { margin: var(--sp-2) var(--sp-3); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-niveau-rij { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); transition: background var(--dur-fast); }
.dy-niveau-rij:last-child { border-bottom: none; }
.dy-niveau-rij.actief { background: rgba(198,125,6,0.03); }
.dy-niveau-rij-emoji { font-size: 1.3rem; flex-shrink: 0; width: 28px; text-align: center; }
.dy-niveau-rij-info { flex: 1; }
.dy-niveau-rij-info strong { display: block; font-size: var(--t-base); color: var(--ink); font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-niveau-rij-info span { font-size: var(--t-xs); color: var(--ink-muted); line-height: 1.5; }
.dy-niveau-rij-pts { font-size: var(--t-sm); font-weight: 700; color: var(--clay); white-space: nowrap; }

/* ── AUTH ── */
.dy-auth-wrap { min-height: calc(100vh - var(--topbar-h) - var(--nav-h)); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--sp-8) var(--sp-5); background: var(--cream); }
.dy-auth-card { width: 100%; max-width: 380px; }
.dy-auth-logo { text-align: center; margin-bottom: var(--sp-8); }
.dy-auth-w { font-family: 'Cormorant Garamond', serif; font-size: var(--t-3xl); font-weight: 700; color: var(--clay); line-height: 1; }
.dy-auth-brand { font-family: 'DM Sans', sans-serif; font-size: var(--t-lg); font-weight: 800; color: var(--ink); }
.dy-auth-sub { font-size: var(--t-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.1em; margin-top: var(--sp-1); }
.dy-auth-title { font-size: var(--t-xl); font-weight: 800; color: var(--ink); margin-bottom: var(--sp-2); font-family: 'DM Sans', sans-serif; }
.dy-auth-sub-small { font-size: var(--t-sm); color: var(--ink-muted); margin-bottom: var(--sp-5); line-height: 1.6; }
.dy-auth-err { color: var(--danger); font-size: var(--t-sm); margin-top: var(--sp-2); padding: var(--sp-2) var(--sp-3); background: rgba(192,57,43,0.06); border-radius: var(--r-sm); border: 1px solid rgba(192,57,43,0.15); display: none; }
.dy-auth-note { font-size: var(--t-sm); color: var(--ink-muted); text-align: center; margin-top: var(--sp-4); line-height: 1.6; }

/* ── REVIEWS ── */
.dy-reviews-wrap { padding-bottom: var(--sp-8); }
.dy-rv-sectie { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-4); margin-bottom: var(--sp-2); }
.dy-rv-sectie-titel { font-size: var(--t-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--clay); margin-bottom: var(--sp-3); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--border); }
.dy-rv-chips { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-2); }
.dy-rv-chip { padding: var(--sp-1) var(--sp-3); font-size: var(--t-sm); background: var(--warm); border: 1.5px solid var(--border); border-radius: var(--r-pill); cursor: pointer; color: var(--ink-muted); font-family: inherit; transition: all var(--dur-fast); white-space: nowrap; min-height: 36px; }
.dy-rv-chip:hover { border-color: var(--clay); color: var(--clay); }
.dy-rv-chip.actief { background: var(--clay); border-color: var(--clay); color: var(--white); font-weight: 500; }
.dy-rv-chip-sm { padding: 3px var(--sp-2); font-size: var(--t-xs); background: var(--warm); border: 1.5px solid var(--border); border-radius: var(--r-xs); cursor: pointer; color: var(--ink-muted); font-family: inherit; transition: all var(--dur-fast); }
.dy-rv-chip-sm.actief { background: var(--clay); border-color: var(--clay); color: var(--white); }
.dy-rv-onderdelen { display: flex; flex-direction: column; gap: var(--sp-2); margin-top: var(--sp-2); }
.dy-rv-onderdeel { display: flex; align-items: center; gap: var(--sp-3); }
.dy-rv-onderdeel-lbl { font-size: var(--t-sm); color: var(--ink-muted); width: 100px; flex-shrink: 0; }
.dy-rv-onderdeel-knoppen { display: flex; gap: var(--sp-1); }
.dy-rv-badges { display: flex; flex-wrap: wrap; gap: var(--sp-1); margin-bottom: var(--sp-2); }
.dy-rv-badge { font-size: var(--t-xs); font-weight: 600; letter-spacing: 0.04em; padding: 2px var(--sp-2); border-radius: var(--r-xs); white-space: nowrap; }
.dy-pasvorm-knoppen { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.dy-pasvorm-btn { flex: 1; padding: var(--sp-3) var(--sp-2); background: var(--warm); border: 1.5px solid var(--border); border-radius: var(--r-md); color: var(--ink-muted); font-family: inherit; font-size: var(--t-sm); font-weight: 500; cursor: pointer; transition: all var(--dur-fast); text-align: center; min-width: 80px; min-height: 44px; }
.dy-pasvorm-btn.actief { background: var(--clay); border-color: var(--clay); color: var(--white); font-weight: 700; }
.dy-ster-beoordeling { display: flex; gap: var(--sp-2); }
.dy-ster { background: none; border: none; color: var(--parchment); cursor: pointer; font-size: 2rem; transition: all var(--dur-fast); padding: var(--sp-1); min-height: 44px; }
.dy-ster.actief { color: var(--clay); }
.dy-ster:hover { transform: scale(1.15); }
.dy-review-footer { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-2) var(--sp-3); border-top: 1px solid var(--border); background: rgba(30,26,15,0.02); }
.dy-helpful-btn { font-size: var(--t-xs); color: var(--ink-muted); background: none; border: 1px solid var(--border); border-radius: var(--r-pill); padding: 4px var(--sp-3); cursor: pointer; font-family: inherit; transition: all var(--dur-fast); }
.dy-helpful-btn:hover { border-color: var(--clay); color: var(--clay); }
.dy-helpful-btn:disabled { opacity: 0.5; cursor: default; }
.dy-verified-badge { font-size: var(--t-xs); color: var(--success); font-weight: 600; }
.dy-rv-kaart { margin: 0 var(--sp-3) var(--sp-2); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-rv-kaart:hover { border-color: var(--clay); }
.dy-rv-kaart-header { padding: var(--sp-3) var(--sp-4); display: flex; align-items: center; gap: var(--sp-3); border-bottom: 1px solid var(--border); }
.dy-rv-kaart-meta { flex: 1; min-width: 0; }
.dy-rv-kaart-naam { font-size: var(--t-sm); font-weight: 700; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-rv-kaart-stats { font-size: var(--t-xs); color: var(--ink-muted); margin-top: 1px; }
.dy-rv-sterren { color: var(--clay); font-size: var(--t-sm); letter-spacing: 0.05em; }
.dy-rv-kaart-body { padding: var(--sp-3) var(--sp-4); }
.dy-rv-kaart-product { font-size: var(--t-xs); font-weight: 700; color: var(--clay); margin-bottom: var(--sp-2); text-transform: uppercase; letter-spacing: 0.05em; }
.dy-rv-kaart-tekst { font-size: var(--t-base); color: var(--ink-soft); line-height: 1.65; }
.dy-rv-kaart-footer { padding: var(--sp-2) var(--sp-4); border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; background: rgba(30,26,15,0.02); }
.dy-rv-match-badge { font-size: var(--t-xs); font-weight: 600; background: var(--clay-alpha); color: var(--clay); border: 1px solid var(--clay-glow); border-radius: var(--r-pill); padding: 2px var(--sp-2); }
.dy-rv-stat-blok { margin: 0 var(--sp-3) var(--sp-2); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-4); display: flex; align-items: center; gap: var(--sp-5); }
.dy-rv-stat-sterren { font-size: var(--t-2xl); font-weight: 900; color: var(--ink); font-family: 'DM Sans', sans-serif; }
.dy-rv-stat-bar-wrap { flex: 1; }
.dy-rv-stat-rij { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: 3px; }
.dy-rv-stat-ster-lbl { font-size: var(--t-xs); color: var(--ink-muted); width: 10px; text-align: right; flex-shrink: 0; }
.dy-rv-stat-bar { flex: 1; height: 5px; background: var(--warm); border-radius: var(--r-xs); overflow: hidden; }
.dy-rv-stat-bar-fill { height: 100%; background: var(--clay); border-radius: var(--r-xs); }
.dy-rv-stat-count { font-size: var(--t-xs); color: var(--ink-muted); width: 16px; flex-shrink: 0; }

/* ── LEADERBOARD ── */
.dy-leaderboard-wrap { padding-bottom: var(--sp-8); }
.dy-leaderboard-lijst { padding: var(--sp-2) var(--sp-3); }
.dy-leaderboard-periode { font-size: var(--t-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-muted); padding: var(--sp-2) var(--sp-1) var(--sp-3); text-align: center; }
.dy-leaderboard-rij { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-3) var(--sp-4); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: var(--sp-2); transition: border-color var(--dur-fast), box-shadow var(--dur-fast); cursor: pointer; }
.dy-leaderboard-rij:hover { border-color: var(--clay); box-shadow: var(--sh-sm); }
.dy-leaderboard-rij.jij { background: rgba(198,125,6,0.03); border-color: rgba(198,125,6,0.22); }
.dy-leaderboard-rang { font-size: 1.3rem; flex-shrink: 0; width: 36px; text-align: center; }
.dy-leaderboard-avatar { width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0; background: linear-gradient(135deg, var(--clay), var(--clay-d)); display: flex; align-items: center; justify-content: center; font-size: var(--t-sm); font-weight: 700; color: var(--white); overflow: hidden; }
.dy-leaderboard-info { flex: 1; min-width: 0; }
.dy-leaderboard-info strong { display: block; font-size: var(--t-base); font-weight: 700; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-leaderboard-info span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-leaderboard-pts { font-size: var(--t-sm); font-weight: 700; color: var(--clay); white-space: nowrap; flex-shrink: 0; }
.dy-leaderboard-optin { padding: var(--sp-4) var(--sp-1); text-align: center; }

/* ── CHALLENGES ── */
.dy-challenges-wrap { padding: var(--sp-2) var(--sp-3) var(--sp-8); }
.dy-challenge-kaart { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-4); margin-bottom: var(--sp-2); }
.dy-challenge-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--sp-2); }
.dy-challenge-titel { font-size: var(--t-base); font-weight: 700; color: var(--ink); }
.dy-challenge-dsp { font-size: var(--t-sm); font-weight: 700; color: var(--clay); white-space: nowrap; flex-shrink: 0; margin-left: var(--sp-2); }
.dy-challenge-sub { font-size: var(--t-sm); color: var(--ink-soft); line-height: 1.6; margin-bottom: var(--sp-3); }
.dy-challenge-voortgang { height: 6px; background: var(--warm); border-radius: var(--r-xs); overflow: hidden; margin-bottom: var(--sp-2); }
.dy-challenge-fill { height: 100%; background: linear-gradient(90deg, var(--clay-d), var(--clay)); border-radius: var(--r-xs); }
.dy-challenge-meta { display: flex; justify-content: space-between; font-size: var(--t-xs); color: var(--ink-muted); }
.dy-challenge-deelnemen { width: 100%; margin-top: var(--sp-3); padding: var(--sp-3); background: var(--clay); color: var(--white); border: none; border-radius: var(--r-md); font-family: inherit; font-size: var(--t-sm); font-weight: 700; cursor: pointer; transition: all var(--dur-fast); min-height: 44px; }
.dy-challenge-deelnemen:hover { background: var(--clay-l); }

/* ── MELDINGEN ── */
.dy-meldingen-wrap, .dy-meldingen-lijst { padding: var(--sp-2) var(--sp-3) var(--sp-8); }
.dy-melding-item { display: flex; align-items: flex-start; gap: var(--sp-3); padding: var(--sp-3) var(--sp-4); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: var(--sp-2); }
.dy-melding-item.ongelezen { border-left: 3px solid var(--clay); }
.dy-melding-avatar { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; background: var(--warm); display: flex; align-items: center; justify-content: center; font-size: var(--t-sm); font-weight: 700; color: var(--clay); }
.dy-melding-body { flex: 1; min-width: 0; }
.dy-melding-tekst { font-size: var(--t-base); color: var(--ink-soft); line-height: 1.55; }
.dy-melding-tekst strong { color: var(--ink); }
.dy-melding-tijd { font-size: var(--t-xs); color: var(--ink-muted); margin-top: var(--sp-1); }
.dy-melding-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--clay); flex-shrink: 0; margin-top: 5px; }

/* ── BERICHTEN ── */
.dy-berichten-wrap, .dy-berichten-lijst { padding-bottom: var(--sp-8); }
.dy-bericht-rij { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-4); border-bottom: 1px solid var(--border); cursor: pointer; transition: background var(--dur-fast); background: var(--white); }
.dy-bericht-rij:hover { background: var(--warm); }
.dy-bericht-item { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-4); border-bottom: 1px solid var(--border); cursor: pointer; transition: background var(--dur-fast); }
.dy-bericht-item:hover { background: var(--warm); }
.dy-bericht-rij-info { flex: 1; min-width: 0; }
.dy-bericht-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 2px; }
.dy-bericht-header-naam, .dy-bericht-naam { font-size: var(--t-base); font-weight: 700; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px; }
.dy-bericht-preview, .dy-bericht-tekst { font-size: var(--t-sm); color: var(--ink-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-bericht-tijd { font-size: var(--t-xs); color: var(--ink-muted); white-space: nowrap; }
.dy-bericht-badge { background: var(--clay); color: var(--white); border-radius: var(--r-pill); font-size: var(--t-xs); font-weight: 700; padding: 1px var(--sp-2); margin-left: var(--sp-2); }
.dy-bericht-ongelezen { width: 7px; height: 7px; border-radius: 50%; background: var(--clay); flex-shrink: 0; }
.dy-bericht-chat { display: flex; flex-direction: column; height: calc(100vh - var(--topbar-h) - var(--nav-h)); }
.dy-chat-berichten { flex: 1; overflow-y: auto; padding: var(--sp-3); background: var(--cream); }
.dy-chat-bericht { margin-bottom: var(--sp-3); display: flex; flex-direction: column; }
.dy-chat-bericht.eigen { align-items: flex-end; }
.dy-bericht-bubble { max-width: 72%; padding: var(--sp-2) var(--sp-3); border-radius: var(--r-lg); font-size: var(--t-base); line-height: 1.55; }
.dy-chat-bericht:not(.eigen) .dy-bericht-bubble { background: var(--white); color: var(--ink); border-radius: var(--r-xs) var(--r-lg) var(--r-lg) var(--r-lg); border: 1px solid var(--border); }
.dy-chat-bericht.eigen .dy-bericht-bubble { background: var(--clay); color: var(--white); border-radius: var(--r-lg) var(--r-xs) var(--r-lg) var(--r-lg); }
.dy-bericht-input-wrap { padding: var(--sp-2) var(--sp-3); border-top: 1px solid var(--border); display: flex; gap: var(--sp-2); background: var(--white); }
.dy-bericht-input, .dy-chat-input { flex: 1; padding: var(--sp-2) var(--sp-3); background: var(--warm); border: 1px solid var(--border); border-radius: var(--r-pill); color: var(--ink); font-family: inherit; font-size: var(--t-base); min-height: 44px; }
.dy-bericht-input:focus, .dy-chat-input:focus { outline: none; border-color: var(--clay); }
.dy-bericht-stuur-btn, .dy-chat-send { width: 40px; height: 40px; border-radius: 50%; background: var(--clay); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: transform var(--dur-fast); }
.dy-bericht-stuur-btn:hover, .dy-chat-send:hover { transform: scale(1.08); }
.dy-bericht-stuur-btn svg, .dy-chat-send svg { width: 16px; height: 16px; fill: var(--white); }
.dy-bericht-media-btn { background: var(--clay-alpha); border: 1px solid var(--clay-glow); border-radius: var(--r-pill); padding: var(--sp-1) var(--sp-3); font-size: var(--t-xs); color: var(--clay); cursor: pointer; font-family: inherit; font-weight: 600; min-height: 36px; }
.dy-bericht-vinkjes { font-size: var(--t-xs); color: var(--clay); margin-left: var(--sp-1); }
.dy-bericht-media { border-radius: var(--r-md); overflow: hidden; max-width: 200px; margin-top: var(--sp-2); }

/* ── WINKEL ── */
.dy-winkel-wrap { padding-bottom: var(--sp-8); }
.dy-winkel-fit-banner { background: rgba(198,125,6,0.06); border-bottom: 1px solid rgba(198,125,6,0.12); padding: var(--sp-3) var(--sp-4); }
.dy-winkel-fit-banner-inner { display: flex; align-items: center; gap: var(--sp-3); }
.dy-winkel-fit-icon { font-size: 1.1rem; color: var(--clay); flex-shrink: 0; }
.dy-winkel-fit-titel { font-size: var(--t-sm); font-weight: 700; color: var(--ink); }
.dy-winkel-fit-sub { font-size: var(--t-xs); color: var(--ink-muted); margin-top: 1px; }
.dy-winkel-acties { padding: 0 var(--sp-3) var(--sp-3); }
.dy-winkel-btn-primary { width: 100%; display: flex; align-items: center; justify-content: center; gap: var(--sp-3); padding: var(--sp-4); background: var(--clay); color: var(--white); border: none; border-radius: var(--r-lg); font-family: inherit; font-size: var(--t-base); font-weight: 700; cursor: pointer; transition: all var(--dur-fast); margin-bottom: var(--sp-2); min-height: 52px; }
.dy-winkel-btn-primary:hover { background: var(--clay-l); box-shadow: 0 4px 16px rgba(198,125,6,0.25); }
.dy-winkel-btn-secondary { width: 100%; padding: var(--sp-3); background: transparent; color: var(--clay); border: 1.5px solid rgba(198,125,6,0.25); border-radius: var(--r-lg); font-family: inherit; font-size: var(--t-sm); font-weight: 600; cursor: pointer; transition: all var(--dur-fast); min-height: 44px; }
.dy-winkel-btn-secondary:hover { border-color: var(--clay); background: var(--clay-alpha); }
.dy-winkel-cat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-2); }
@media (min-width: 480px) { .dy-winkel-cat-grid { grid-template-columns: repeat(4, 1fr); } }
.dy-winkel-cat-kaart { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-4); cursor: pointer; transition: all var(--dur-fast); display: flex; flex-direction: column; gap: var(--sp-1); }
.dy-winkel-cat-kaart:hover { border-color: var(--clay); background: rgba(198,125,6,0.02); }
.dy-winkel-cat-icon { font-size: 1.5rem; margin-bottom: var(--sp-1); }
.dy-winkel-cat-kaart strong { font-size: var(--t-base); font-weight: 700; color: var(--ink); }
.dy-winkel-cat-kaart span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-winkel-dsp-tabel { width: 100%; background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-winkel-dsp-rij { display: flex; justify-content: space-between; align-items: center; padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); font-size: var(--t-sm); }
.dy-winkel-dsp-rij:last-child { border-bottom: none; }
.dy-winkel-dsp-rij span:first-child { color: var(--ink-soft); }
.dy-winkel-dsp-pts { color: var(--clay); font-weight: 700; }
.dy-dsp-disclaimer { font-size: var(--t-xs); color: var(--ink-muted); margin-top: var(--sp-2); line-height: 1.6; padding: 0 var(--sp-1); }
.dy-tall-badge { display: inline-block; font-size: var(--t-xs); font-weight: 700; background: rgba(26,107,58,0.08); color: var(--success); border: 1px solid rgba(26,107,58,0.18); border-radius: var(--r-xs); padding: 1px var(--sp-2); margin-bottom: var(--sp-1); }

/* ── LOOKS ── */
.dy-look-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; padding: 10px var(--sp-3); }
@media (min-width: 480px) { .dy-look-grid { grid-template-columns: repeat(3, 1fr); } }
.dy-look-kaart { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; cursor: pointer; transition: border-color var(--dur-fast), box-shadow var(--dur-fast); }
.dy-look-kaart:hover { border-color: var(--clay); box-shadow: var(--sh-sm); }
.dy-look-foto-wrap { position: relative; aspect-ratio: 4/5; overflow: hidden; background: var(--warm); }
.dy-look-foto { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.5s var(--ease-out); }
.dy-look-kaart:hover .dy-look-foto { transform: scale(1.04); }
.dy-look-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: var(--sp-8) var(--sp-3) var(--sp-2); background: linear-gradient(transparent, rgba(30,26,15,0.85)); }
.dy-look-info-bottom { padding: var(--sp-3); }
.dy-look-naam { font-size: var(--t-sm); font-weight: 600; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-look-maten { font-size: var(--t-xs); color: var(--ink-muted); margin-top: 1px; }

/* ── PRODUCT KAART ── */
.dy-product-kaart { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; cursor: pointer; transition: border-color var(--dur-fast); }
.dy-product-kaart:hover { border-color: var(--clay); }
.dy-product-foto-wrap { position: relative; aspect-ratio: 3/4; overflow: hidden; background: var(--warm); display: flex; align-items: center; justify-content: center; }
.dy-product-foto { width: 100%; height: 100%; object-fit: cover; display: block; }
.dy-product-fit-badge { position: absolute; top: var(--sp-2); right: var(--sp-2); background: rgba(254,252,245,0.92); backdrop-filter: blur(6px); padding: var(--sp-2) var(--sp-3); border-radius: var(--r-md); text-align: center; }
.dy-product-fit-score-val { font-size: var(--t-xl); font-weight: 900; color: var(--clay); display: block; line-height: 1; font-family: 'DM Sans', sans-serif; }
.dy-product-fit-score-lbl { font-size: var(--t-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.08em; }
.dy-product-info { padding: var(--sp-3) var(--sp-4); }
.dy-product-merk { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-1); }
.dy-product-naam { font-weight: 700; font-size: var(--t-base); color: var(--ink); margin-bottom: var(--sp-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-product-prijs { font-family: 'DM Sans', sans-serif; font-size: var(--t-lg); font-weight: 800; color: var(--ink); }
.dy-product-meta { display: flex; align-items: center; gap: var(--sp-3); margin-top: var(--sp-2); font-size: var(--t-xs); color: var(--ink-muted); }
.dy-winkel-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-2); }
@media (min-width: 600px) { .dy-winkel-grid { grid-template-columns: repeat(3, 1fr); } }

/* ── CONFIGURATOR ── */
.dy-cfg-wrap { display: grid; grid-template-columns: 240px 1fr; min-height: calc(100vh - var(--topbar-h)); align-items: start; }
@media (max-width: 680px) { .dy-cfg-wrap { grid-template-columns: 1fr; } }
.dy-cfg-preview { background: var(--warm); padding: var(--sp-5); display: flex; flex-direction: column; align-items: center; position: sticky; top: var(--topbar-h); min-height: calc(100vh - var(--topbar-h)); overflow-y: auto; border-right: 1px solid var(--border); }
@media (max-width: 680px) { .dy-cfg-preview { position: static; min-height: auto; padding: var(--sp-4) var(--sp-3); border-right: none; border-bottom: 1px solid var(--border); } }
.dy-cfg-svg-wrap { width: 180px; height: 300px; margin: 0 auto var(--sp-4); background: rgba(198,125,6,0.03); border: 1px solid rgba(198,125,6,0.08); border-radius: var(--r-xs); display: flex; align-items: center; justify-content: center; padding: var(--sp-3); }
.dy-cfg-tabs-wrap { display: flex; border-bottom: 1px solid var(--border); overflow-x: auto; }
.dy-cfg-tab { padding: var(--sp-3) var(--sp-4); background: none; border: none; border-bottom: 2px solid transparent; color: var(--ink-muted); font-family: inherit; font-size: var(--t-sm); font-weight: 500; cursor: pointer; white-space: nowrap; transition: all var(--dur-fast); }
.dy-cfg-tab.active { color: var(--clay); border-bottom-color: var(--clay); }
.dy-cfg-panel { padding: var(--sp-4); display: none; }
.dy-cfg-panel.active { display: block; }
.dy-cfg-genereer-btn { width: 100%; padding: var(--sp-4); background: var(--clay); color: var(--white); border: none; border-radius: var(--r-md); font-family: inherit; font-size: var(--t-base); font-weight: 700; cursor: pointer; transition: all var(--dur-fast); text-transform: uppercase; letter-spacing: 0.05em; min-height: 52px; }
.dy-cfg-genereer-btn:hover { background: var(--clay-l); }
.dy-cfg-genereer-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.dy-cfg-maten-form { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.dy-cfg-maat-veld { display: flex; flex-direction: column; gap: var(--sp-1); }
.dy-cfg-maat-label { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-muted); }
.dy-cfg-maat-input { padding: var(--sp-2) var(--sp-3); background: var(--white); border: 1.5px solid var(--border); border-radius: var(--r-sm); color: var(--ink); font-family: inherit; font-size: var(--t-sm); min-height: 40px; }
.dy-cfg-maat-input:focus { outline: none; border-color: var(--clay); }
.dy-cfg-check { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-2); font-size: var(--t-sm); color: var(--ink-soft); cursor: pointer; }
.dy-cfg-check input { accent-color: var(--clay); }
.dy-cfg-kleuren { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.dy-cfg-kleur { width: 28px; height: 28px; border-radius: 50%; cursor: pointer; border: 2px solid transparent; transition: all var(--dur-fast); }
.dy-cfg-kleur.actief { border-color: var(--clay); transform: scale(1.15); }
.dy-cfg-patroon-svg { width: 100%; overflow: auto; background: white; border-radius: var(--r-xs); border: 1px solid var(--border); padding: var(--sp-2); margin-bottom: var(--sp-2); max-height: 70vh; min-height: 400px; }
.dy-cfg-community-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-2); }
@media (min-width: 480px) { .dy-cfg-community-grid { grid-template-columns: repeat(3, 1fr); } }

/* ── PASKAMER ── */
.dy-pk-wrap { padding-bottom: var(--sp-8); background: var(--cream); }
.dy-pk-sectie { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-4); margin: var(--sp-2) var(--sp-3); }
.dy-pk-sectie-titel { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--border); }
.dy-pk-maat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); margin-top: var(--sp-3); }
.dy-pk-maat-item { background: var(--warm); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-3) var(--sp-2); text-align: center; }
.dy-pk-maat-val { display: block; font-size: var(--t-lg); font-weight: 800; color: var(--clay); font-family: 'DM Sans', sans-serif; }
.dy-pk-maat-lbl { display: block; font-size: var(--t-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-top: var(--sp-1); }

/* ── GEBRUIKER PROFIEL ── */
.dy-gebruiker-wrap { padding-bottom: var(--sp-8); }
.dy-gebruiker-stats { padding: var(--sp-3); }
.dy-gebruiker-stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); }
.dy-gebruiker-stat { background: var(--white); padding: var(--sp-4) var(--sp-2); text-align: center; }
.dy-gebruiker-stat + .dy-gebruiker-stat { border-left: 1px solid var(--border); }
.dy-gebruiker-stat-waarde { display: block; font-size: var(--t-xl); font-weight: 800; color: var(--ink); line-height: 1; margin-bottom: var(--sp-1); font-family: 'DM Sans', sans-serif; }
.dy-gebruiker-stat-label { display: block; font-size: var(--t-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-muted); }
.dy-gebruiker-tier-badge { font-size: var(--t-xs); background: var(--clay-alpha); color: var(--clay); border: 1px solid var(--clay-glow); border-radius: var(--r-pill); padding: 2px var(--sp-2); margin-left: auto; }
.dy-gebruiker-sectie-titel { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--border); }

/* ── BESTELLINGEN ── */
.dy-bestellingen-wrap { padding: var(--sp-3) var(--sp-3) var(--sp-8); }
.dy-best-shopify-blok { padding: var(--sp-8) var(--sp-5); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); text-align: center; margin-bottom: var(--sp-3); }
.dy-best-shopify-titel { font-size: var(--t-lg); font-weight: 800; color: var(--ink); margin: var(--sp-3) 0 var(--sp-2); }
.dy-best-shopify-tekst { font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.7; margin-bottom: var(--sp-5); }
.dy-best-leeg { text-align: center; padding: var(--sp-8) var(--sp-4); }
.dy-best-leeg-icon { font-size: 3rem; display: block; margin-bottom: var(--sp-3); opacity: 0.4; }
.dy-best-dsp-overzicht { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: var(--sp-3); }
.dy-best-dsp-rij { display: flex; justify-content: space-between; align-items: center; padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); font-size: var(--t-sm); }
.dy-best-dsp-rij:last-child { border-bottom: none; }
.dy-best-dsp-rij-label { color: var(--ink-soft); }
.dy-best-dsp-totaal { font-size: var(--t-xs); font-weight: 700; color: var(--clay); padding: var(--sp-2) var(--sp-4); background: rgba(198,125,6,0.03); border-top: 1px solid var(--border); }

/* ── ZOEKBALK ── */
.dy-zoekbalk-wrap { background: var(--ink); padding: var(--sp-2) var(--sp-3); border-bottom: 1px solid rgba(198,125,6,0.12); margin-top: var(--topbar-h); }
.dy-zoekbalk-inner { display: flex; align-items: center; gap: var(--sp-2); }
.dy-zoek-input { flex: 1; background: none; border: none; color: var(--white); font-family: inherit; font-size: var(--t-base); min-height: 40px; }
.dy-zoek-input::placeholder { color: rgba(254,252,245,0.3); }
.dy-zoek-input:focus { outline: none; }
.dy-zoek-sluit { background: none; border: none; color: rgba(254,252,245,0.4); cursor: pointer; font-size: 1.1rem; padding: var(--sp-2); min-height: 44px; }

/* ── DETAIL PAGINA ── */
.dy-detail-wrap { padding: 0 0 var(--sp-8); max-width: var(--max-w); margin: 0 auto; background: var(--cream); }
.dy-artikel { padding: var(--sp-4); background: var(--white); margin: var(--sp-2) var(--sp-3); border-radius: var(--r-lg); border: 1px solid var(--border); }
.dy-artikel-titel { font-family: 'DM Sans', sans-serif; font-size: var(--t-xl); font-weight: 800; color: var(--ink); margin-bottom: var(--sp-3); line-height: 1.25; }
.dy-artikel-tekst { font-size: var(--t-base); color: var(--ink-soft); line-height: 1.8; }

.dy-artikel-acties { display: flex; gap: var(--sp-2); padding-top: var(--sp-3); border-top: 1px solid var(--border); margin-top: var(--sp-3); }
.dy-reacties-sectie { padding: var(--sp-3); }
.dy-reactie-header { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--border); }

/* ── ONBOARDING ── */
.dy-onboarding-wrap { min-height: 100vh; background: var(--ink); color: var(--white); position: relative; }
.dy-onboarding-bg { position: absolute; top: 0; left: 0; right: 0; height: 40%; background: linear-gradient(135deg, var(--clay), var(--clay-d)); opacity: 0.06; filter: blur(80px); pointer-events: none; }
.dy-onboarding-slide { display: flex; flex-direction: column; align-items: center; text-align: center; padding: var(--sp-8) var(--sp-5); min-height: 100vh; justify-content: center; position: relative; z-index: 1; }
.dy-onboarding-emoji { font-size: 3.5rem; margin-bottom: var(--sp-5); }
.dy-onboarding-titel { font-family: 'DM Sans', sans-serif; font-size: var(--t-2xl); font-weight: 900; line-height: 1.15; color: var(--white); margin-bottom: var(--sp-3); }
.dy-onboarding-tekst { font-size: var(--t-base); color: rgba(254,252,245,0.6); line-height: 1.75; max-width: 320px; margin: 0 auto var(--sp-8); }
.dy-onboarding-acties { display: flex; flex-direction: column; align-items: center; gap: var(--sp-3); width: 100%; max-width: 320px; }
.dy-onboarding-volgende { width: 100%; }
.dy-onboarding-dots { display: flex; gap: var(--sp-2); justify-content: center; margin-bottom: var(--sp-5); }
.dy-onboarding-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(254,252,245,0.2); }
.dy-onboarding-dot.actief { background: var(--clay); width: 20px; border-radius: var(--r-xs); }
.dy-onboarding-form { width: 100%; max-width: 360px; text-align: left; }
.dy-ob-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-3); margin-bottom: var(--sp-5); }
.dy-ob-btn { padding: var(--sp-4); background: rgba(254,252,245,0.06); border: 1.5px solid rgba(198,125,6,0.2); border-radius: var(--r-md); color: rgba(254,252,245,0.7); font-family: inherit; font-size: var(--t-sm); font-weight: 500; cursor: pointer; transition: all var(--dur-fast); text-align: center; }
.dy-ob-btn:hover { border-color: rgba(198,125,6,0.4); color: var(--white); }
.dy-ob-btn.selected, .dy-ob-btn.actief { background: rgba(198,125,6,0.15); border-color: var(--clay); color: var(--clay); }
.dy-ob-multi { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-3); margin-bottom: var(--sp-5); }
.dy-ob-multi-item { padding: var(--sp-3) var(--sp-4); background: rgba(254,252,245,0.06); border: 1.5px solid rgba(198,125,6,0.18); border-radius: var(--r-md); color: rgba(254,252,245,0.6); font-family: inherit; font-size: var(--t-sm); font-weight: 500; cursor: pointer; transition: all var(--dur-fast); display: flex; align-items: center; gap: var(--sp-3); }
.dy-ob-multi-item::before { content: ''; width: 18px; height: 18px; border: 2px solid rgba(254,252,245,0.2); border-radius: var(--r-xs); transition: all var(--dur-fast); flex-shrink: 0; }
.dy-ob-multi-item.selected, .dy-ob-multi-item.actief { background: rgba(198,125,6,0.12); border-color: var(--clay); color: var(--white); }
.dy-ob-multi-item.selected::before, .dy-ob-multi-item.actief::before { background: var(--clay); border-color: var(--clay); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231e1a0f' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E"); background-size: 12px; background-position: center; background-repeat: no-repeat; }
.dy-ob-slider { margin: var(--sp-5) 0; }
.dy-ob-slider-val { text-align: center; font-family: 'DM Sans', sans-serif; font-size: var(--t-3xl); font-weight: 900; color: var(--clay); margin-bottom: var(--sp-3); }
.dy-ob-slider-val span { font-size: var(--t-md); color: rgba(254,252,245,0.5); font-weight: 400; margin-left: var(--sp-1); }
.dy-ob-track { width: 100%; height: 6px; background: rgba(254,252,245,0.1); border-radius: var(--r-xs); position: relative; margin: var(--sp-3) 0; cursor: pointer; touch-action: none; }
.dy-ob-fill { height: 100%; background: linear-gradient(90deg, var(--clay-d), var(--clay)); border-radius: var(--r-xs); }
.dy-ob-thumb { width: 26px; height: 26px; background: var(--clay); border: 3px solid var(--ink); border-radius: 50%; position: absolute; top: 50%; transform: translate(-50%, -50%); box-shadow: 0 2px 10px rgba(198,125,6,0.35); cursor: grab; touch-action: none; }
.dy-ob-thumb:active { cursor: grabbing; transform: translate(-50%, -50%) scale(1.1); }
.dy-ob-range { display: flex; justify-content: space-between; font-size: var(--t-xs); color: rgba(254,252,245,0.35); margin-top: var(--sp-1); }
.dy-silhouette-row { display: flex; justify-content: center; align-items: flex-end; gap: var(--sp-4); margin: var(--sp-8) 0; height: 160px; }
.dy-sil { width: 50px; background: rgba(254,252,245,0.08); border-radius: 26px 26px 6px 6px; transition: all 0.6s var(--ease-out); position: relative; opacity: 0.4; }
.dy-sil.active { background: var(--clay); opacity: 1; box-shadow: 0 0 28px rgba(198,125,6,0.25); }
.dy-sil::before { content: ''; position: absolute; top: -20px; left: 50%; transform: translateX(-50%); width: 26px; height: 26px; background: inherit; border-radius: 50%; opacity: 0.85; }

/* ── FIT CONFIDENCE ── */
.dy-fit-confidence-blok { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-3); margin: var(--sp-2) 0; }
.dy-fit-conf-header { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-2); }
.dy-fit-conf-score { font-family: 'DM Sans', sans-serif; font-size: 2rem; font-weight: 900; line-height: 1; flex-shrink: 0; }
.dy-fit-conf-info strong { display: block; font-size: var(--t-base); font-weight: 700; color: var(--ink); }
.dy-fit-conf-info span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-fit-conf-badges { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.dy-fit-conf-badge { font-size: var(--t-xs); font-weight: 600; border-radius: var(--r-pill); padding: 2px var(--sp-2); white-space: nowrap; }

/* ── INSTALL BANNER ── */
.dy-install-banner { background: var(--warm); border-bottom: 1px solid var(--border); padding: var(--sp-3) var(--sp-4); display: flex; align-items: center; gap: var(--sp-3); }
.dy-install-banner-tekst { flex: 1; font-size: var(--t-sm); }
.dy-install-banner-tekst strong { display: block; color: var(--ink); font-size: var(--t-base); }
.dy-install-banner-tekst span { color: var(--ink-muted); }

/* ── STREAKS ── */
.dy-streak-indicator { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-3); background: var(--clay-alpha); border: 1px solid rgba(198,125,6,0.15); border-radius: var(--r-sm); margin-bottom: var(--sp-3); font-size: var(--t-sm); color: var(--ink-soft); }
.dy-streak-vuur { font-size: 1.1rem; }
.dy-streak-getal { font-weight: 800; color: var(--clay); font-family: 'DM Sans', sans-serif; }

/* ── MISC ── */
.dy-match-score { display: inline-flex; align-items: center; gap: var(--sp-1); font-size: var(--t-xs); font-weight: 700; color: var(--clay); background: var(--clay-alpha); border: 1px solid var(--clay-glow); border-radius: var(--r-pill); padding: 2px var(--sp-2); white-space: nowrap; flex-shrink: 0; }
.dy-login-prompt-wrap { padding: var(--sp-8) var(--sp-4); }
.dy-login-prompt-kaart { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-8) var(--sp-5); text-align: center; }
.dy-login-prompt-icon { font-size: 2rem; color: var(--clay); margin-bottom: var(--sp-3); }
.dy-login-prompt-titel { font-size: var(--t-lg); font-weight: 800; color: var(--ink); margin-bottom: var(--sp-2); }
.dy-login-prompt { font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.7; margin-bottom: var(--sp-5); }
.dy-gender-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); max-width: 860px; margin: 0 auto; }
@media (max-width: 600px) { .dy-gender-grid { grid-template-columns: 1fr; max-width: 320px; } }
.dy-gender-card { border: 1px solid var(--border); padding: var(--sp-6) var(--sp-5); text-align: center; cursor: pointer; transition: all var(--dur-fast); border-radius: var(--r-lg); }
.dy-gender-card.selected { border-color: var(--clay); background: rgba(198,125,6,0.04); }
.dy-gender-name { font-family: 'DM Sans', sans-serif; font-size: var(--t-xl); font-weight: 700; color: var(--ink); }
.dy-gender-icon { width: 64px; height: 64px; margin: 0 auto var(--sp-3); }
.dy-verwijder-btn { background: none; border: none; color: var(--danger); cursor: pointer; padding: var(--sp-1); opacity: 0.65; transition: opacity var(--dur-fast); }
.dy-verwijder-btn:hover { opacity: 1; }
.dy-verwijder-btn svg { width: 17px; height: 17px; fill: currentColor; }
.dy-outline-svg { width: 100%; height: auto; display: block; overflow: visible; }
.dy-op { fill: none; stroke: var(--clay); stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
.dy-profiel-foto-upload { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-4); background: var(--warm); border: 1.5px solid var(--border); border-radius: var(--r-lg); cursor: pointer; margin-bottom: var(--sp-4); transition: border-color var(--dur-fast); }
.dy-profiel-foto-upload:hover { border-color: var(--clay); }
.dy-profiel-foto-preview { width: 56px; height: 56px; border-radius: 50%; background: var(--white); display: flex; align-items: center; justify-content: center; overflow: hidden; flex-shrink: 0; border: 1px solid var(--border); }
.dy-profiel-foto-initialen { font-size: var(--t-md); font-weight: 700; color: var(--clay); }
.dy-profiel-foto-label { flex: 1; }
.dy-profiel-foto-label strong { display: block; font-size: var(--t-base); color: var(--ink); font-weight: 700; }
.dy-profiel-foto-label span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-avatar-foto { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.dy-cfg-patroon-info { background: var(--warm); border: 1px solid var(--border); border-radius: var(--r-sm); padding: var(--sp-3); margin-bottom: var(--sp-2); }
.dy-cfg-patroon-naam { display: block; font-size: var(--t-sm); font-weight: 600; color: var(--ink); }
.dy-cfg-patroon-maten { display: block; font-size: var(--t-xs); color: var(--ink-muted); margin-top: var(--sp-1); }
.dy-cfg-patroon-acties { display: flex; gap: var(--sp-2); }
.dy-cfg-patroon-fout { background: rgba(192,57,43,0.06); border: 1px solid rgba(192,57,43,0.15); border-radius: var(--r-md); padding: var(--sp-5); text-align: center; color: var(--danger); font-size: var(--t-sm); }
.dy-cfg-patroon-loading { display: flex; flex-direction: column; align-items: center; gap: var(--sp-3); padding: var(--sp-8); }
.dy-cfg-model-dots { display: flex; gap: var(--sp-2); }
.dy-cfg-model-dots span { width: 8px; height: 8px; border-radius: 50%; background: var(--clay); animation: dotPulse 1.4s ease-in-out infinite; }
.dy-cfg-model-dots span:nth-child(2) { animation-delay: 0.2s; }
.dy-cfg-model-dots span:nth-child(3) { animation-delay: 0.4s; }
.dy-cfg-community-kaart { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; cursor: pointer; }
.dy-cfg-community-foto-wrap { position: relative; aspect-ratio: 4/5; overflow: hidden; background: var(--warm); }
.dy-cfg-community-foto { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.dy-cfg-community-info { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(30,26,15,0.88)); padding: var(--sp-5) var(--sp-2) var(--sp-2); opacity: 0; transition: opacity var(--dur-fast); }
.dy-cfg-community-kaart:hover .dy-cfg-community-info { opacity: 1; }
.dy-cfg-community-naam { display: block; font-size: var(--t-xs); font-weight: 700; color: var(--white); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dy-cfg-community-maten { display: block; font-size: var(--t-xs); color: rgba(254,252,245,0.7); }
.dy-cfg-community-sectie, .dy-cfg-patroon-sectie { background: var(--cream); border-top: 1px solid var(--border); padding: var(--sp-5) var(--sp-4) var(--sp-8); }
.dy-cfg-community-header, .dy-cfg-patroon-header { margin-bottom: var(--sp-3); }
.dy-cfg-community-titel { font-family: 'DM Sans', sans-serif; font-size: var(--t-xl); font-weight: 800; color: var(--ink); margin-bottom: var(--sp-1); }
.dy-cfg-community-sub { font-size: var(--t-sm); color: var(--ink-muted); }
.dy-cfg-patroon-disclaimer { font-size: var(--t-xs); color: var(--ink-muted); margin-top: var(--sp-3); line-height: 1.6; }
.dy-cfg-admin-blok { background: rgba(192,57,43,0.05); border: 1px solid rgba(192,57,43,0.12); border-radius: var(--r-md); padding: var(--sp-4); margin-bottom: var(--sp-3); }
.dy-cfg-admin-titel { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--danger); margin-bottom: var(--sp-3); }
.dy-cfg-maten-form-titel { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); grid-column: 1/-1; }
.dy-cfg-maten-opmerking { font-size: var(--t-xs); color: var(--ink-muted); margin-top: var(--sp-3); line-height: 1.6; }
.dy-cfg-model-foto { width: 100%; border-radius: var(--r-md); max-height: 300px; object-fit: cover; }
.dy-cfg-model-download { display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2) var(--sp-4); background: var(--clay); color: var(--white); border: none; border-radius: var(--r-sm); font-size: var(--t-sm); font-weight: 600; cursor: pointer; font-family: inherit; min-height: 40px; }
.dy-cfg-model-acties { display: flex; gap: var(--sp-2); flex-wrap: wrap; margin-top: var(--sp-3); }
.dy-cfg-acties { padding: var(--sp-3); display: flex; gap: var(--sp-2); }
.dy-cfg-ai-sectie { padding: var(--sp-4); }
.dy-cfg-ai-label { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); padding: var(--sp-3) var(--sp-3) 0; }
.dy-cfg-ai-chat { display: flex; flex-direction: column; height: 280px; background: var(--warm); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; margin-bottom: var(--sp-2); }
.dy-cfg-ai-input-wrap { display: flex; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); border-top: 1px solid var(--border); background: var(--white); }
.dy-cfg-ai-input { flex: 1; padding: var(--sp-2) var(--sp-3); background: var(--warm); border: 1px solid var(--border); border-radius: var(--r-sm); font-family: inherit; font-size: var(--t-sm); color: var(--ink); }
.dy-cfg-ai-stuur { padding: var(--sp-2) var(--sp-3); background: var(--clay); color: var(--white); border: none; border-radius: var(--r-sm); font-size: var(--t-sm); font-weight: 700; cursor: pointer; font-family: inherit; min-height: 40px; }
.dy-cfg-ai-sluit { background: none; border: none; color: var(--ink-muted); cursor: pointer; font-size: 1rem; padding: var(--sp-1); min-height: 36px; }
.dy-cfg-brief { padding: var(--sp-4); }
.dy-cfg-brief-titel { font-size: var(--t-base); font-weight: 700; color: var(--ink); margin-bottom: var(--sp-3); }
.dy-cfg-brief-top { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); }
.dy-cfg-brief-rij { display: flex; justify-content: space-between; padding: var(--sp-2) 0; border-bottom: 1px solid var(--border); font-size: var(--t-sm); }
.dy-cfg-brief-label { color: var(--ink-muted); }
.dy-cfg-brief-datum { color: var(--ink-soft); font-size: var(--t-xs); }
.dy-cfg-brief-textarea { width: 100%; padding: var(--sp-3); background: var(--warm); border: 1.5px solid var(--border); border-radius: var(--r-md); color: var(--ink); font-family: inherit; font-size: var(--t-sm); resize: vertical; line-height: 1.6; }
.dy-cfg-brief-textarea:focus { outline: none; border-color: var(--clay); }
.dy-cfg-brief-acties { display: flex; gap: var(--sp-2); margin-top: var(--sp-3); }
.dy-cfg-brief-check { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--t-sm); color: var(--ink-muted); cursor: pointer; padding: var(--sp-2) 0; }
.dy-cfg-brief-overzicht { background: var(--warm); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-3); margin-top: var(--sp-3); }
.dy-cfg-ks-tab { padding: var(--sp-2) var(--sp-3); background: var(--warm); border: 1px solid var(--border); border-radius: var(--r-sm); font-family: inherit; font-size: var(--t-sm); cursor: pointer; color: var(--ink-muted); }
.dy-cfg-ks-tab.actief { background: var(--clay); border-color: var(--clay); color: var(--white); }
.dy-cfg-sectie { padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); }
.dy-cfg-sectie-titel { font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); margin-bottom: var(--sp-3); }
.dy-cfg-body { padding: var(--sp-3); }
.dy-cfg-briefing-container { display: block; }
.dy-cfg-feed-header { margin-bottom: var(--sp-4); }
.dy-cfg-admin-maten { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.dy-cfg-admin-patroon-preview { width: 100%; border-radius: var(--r-sm); margin-top: var(--sp-2); }
.dy-maat-badge { display: inline-block; font-size: var(--t-xs); font-weight: 700; background: var(--clay-alpha); color: var(--clay); border: 1px solid var(--clay-glow); border-radius: var(--r-pill); padding: 2px var(--sp-2); }

/* ── DSP PAGE ── */
.dy-dsp-niveaus { display: flex; flex-direction: column; gap: var(--sp-1); margin-bottom: var(--sp-4); }
.dy-dsp-niveau-rij { display: flex; align-items: flex-start; gap: var(--sp-3); padding: var(--sp-3); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-md); margin-bottom: var(--sp-1); }
.dy-dsp-niveau-emoji { font-size: 1.4rem; flex-shrink: 0; }
.dy-dsp-niveau-info { flex: 1; }
.dy-dsp-niveau-info strong { display: block; font-size: var(--t-base); color: var(--ink); font-weight: 700; }
.dy-dsp-niveau-voordelen { font-size: var(--t-xs); color: var(--ink-muted); margin-top: 2px; line-height: 1.5; }
.dy-dsp-level-name { font-family: 'DM Sans', sans-serif; font-size: var(--t-lg); font-weight: 800; color: var(--clay); }
.dy-dsp-punten { font-size: var(--t-sm); color: var(--ink-muted); }
.dy-dsp-bar { height: 7px; background: var(--warm); border-radius: var(--r-xs); overflow: hidden; margin-bottom: var(--sp-2); }
.dy-dsp-bar-fill { height: 100%; background: linear-gradient(90deg, var(--clay-d), var(--clay)); border-radius: var(--r-xs); transition: width 1s var(--ease-out); }
.dy-dsp-next { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-dsp-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-3); }

/* Responsive desktop */
@media (min-width: 640px) {
  .dy-verhalen-grid { grid-template-columns: repeat(3, 1fr); gap: 12px; padding: 12px; }
  .dy-look-grid { grid-template-columns: repeat(3, 1fr); }
  .dy-form-wrap { max-width: 560px; }
  .dy-profiel-wrap { max-width: 680px; margin: 0 auto; }
}
@media (min-width: 1024px) {
  .dy-verhalen-grid { grid-template-columns: repeat(4, 1fr); }
}

/* Interactie feedback */
button, [role="button"] { -webkit-user-select: none; user-select: none; }
.dy-kaart, .dy-story, .dy-look-kaart, .dy-product-kaart, .dy-winkel-cat-kaart, .dy-leaderboard-rij, .dy-bericht-rij, .dy-bericht-item, .dy-melding-item { cursor: pointer; -webkit-user-select: none; user-select: none; }

/* Overgang vloeiend */
.dy-main > * { animation: pageIn var(--dur-mid) var(--ease-out) both; }

/* ── RESTERENDE KLASSEN ── */
.dy-bericht-meta { display: flex; justify-content: space-between; align-items: center; }
.dy-bericht-vinkjes { font-size: var(--t-xs); color: var(--clay); margin-left: var(--sp-1); }
.dy-best-dsp { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-md); padding: var(--sp-3); text-align: center; margin-bottom: var(--sp-1); }
.dy-best-dsp-getal { font-size: var(--t-2xl); font-weight: 900; color: var(--clay); display: block; line-height: 1; font-family: 'DM Sans', sans-serif; }
.dy-best-dsp-label { font-size: var(--t-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.08em; }
.dy-btn-link-licht { background: none; border: none; color: rgba(254,252,245,0.5); font-family: inherit; font-size: var(--t-sm); cursor: pointer; padding: var(--sp-2) 0; text-align: center; }
.dy-cfg-admin-badge { display: inline-block; font-size: var(--t-xs); font-weight: 700; background: rgba(192,57,43,0.08); color: var(--danger); border: 1px solid rgba(192,57,43,0.2); border-radius: var(--r-xs); padding: 1px var(--sp-2); margin-left: var(--sp-2); }
.dy-cfg-ai-header { margin-bottom: var(--sp-3); }
.dy-cfg-community-leeg { text-align: center; padding: var(--sp-8); color: var(--ink-muted); font-size: var(--t-sm); }
.dy-cfg-maten-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.dy-cfg-model-fout { background: rgba(192,57,43,0.06); border: 1px solid rgba(192,57,43,0.15); border-radius: var(--r-md); padding: var(--sp-5); text-align: center; color: var(--danger); font-size: var(--t-sm); }
.dy-cfg-model-loading { display: flex; flex-direction: column; align-items: center; gap: var(--sp-3); padding: var(--sp-8); }
.dy-cfg-model-opnieuw { background: none; border: 1px solid var(--border); border-radius: var(--r-sm); padding: var(--sp-2) var(--sp-4); font-family: inherit; font-size: var(--t-sm); color: var(--ink-muted); cursor: pointer; margin-top: var(--sp-3); }
.dy-cfg-model-resultaat { margin-top: var(--sp-3); }
.dy-cfg-model-wrap-klein { max-width: 200px; margin: 0 auto; }
.dy-cfg-opties { display: flex; flex-direction: column; gap: var(--sp-2); }
.dy-cfg-panel-wrap { overflow: auto; background: var(--cream); }
.dy-cfg-patroon-resultaat { margin-top: var(--sp-2); }
.dy-gebruiker-badges-sectie, .dy-gebruiker-verhalen-sectie { padding: var(--sp-3); }
.dy-gebruiker-niveau { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-4); font-size: var(--t-sm); color: var(--ink-soft); margin: 0 var(--sp-3) var(--sp-2); border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--white); }
.dy-pk-fit-status { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-3); background: rgba(26,107,58,0.05); border: 1px solid rgba(26,107,58,0.15); border-radius: var(--r-sm); margin-top: var(--sp-3); font-size: var(--t-sm); color: var(--success); }
.dy-pk-maat-badge { display: inline-block; font-size: var(--t-sm); font-weight: 700; background: var(--clay-alpha); color: var(--clay); border: 1px solid var(--clay-glow); border-radius: var(--r-pill); padding: 3px var(--sp-3); margin: var(--sp-1); }
.dy-rv-filter-row { display: flex; gap: var(--sp-2); padding: 0 var(--sp-3) var(--sp-3); overflow-x: auto; }
.dy-rv-fit-summary { margin: 0 var(--sp-3) var(--sp-2); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.dy-rv-fit-summary-header { padding: var(--sp-2) var(--sp-4); background: rgba(198,125,6,0.03); border-bottom: 1px solid var(--border); font-size: var(--t-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--clay); }
.dy-rv-fit-bars { padding: var(--sp-3) var(--sp-4); }
.dy-rv-fit-bar-rij { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.dy-rv-fit-bar-lbl { font-size: var(--t-xs); color: var(--ink-muted); width: 88px; flex-shrink: 0; }
.dy-rv-fit-bar-track { flex: 1; height: 6px; background: var(--warm); border-radius: var(--r-xs); overflow: hidden; }
.dy-rv-fit-bar-fill { height: 100%; background: var(--clay); border-radius: var(--r-xs); transition: width 0.6s var(--ease-out); }
.dy-rv-fit-bar-pct { font-size: var(--t-xs); font-weight: 700; color: var(--clay); width: 32px; text-align: right; flex-shrink: 0; }
.dy-rv-mijn-bouw-chip { display: inline-flex; align-items: center; gap: var(--sp-1); font-size: var(--t-xs); font-weight: 600; color: var(--clay); background: var(--clay-alpha); border: 1px solid var(--clay-glow); border-radius: var(--r-pill); padding: 3px var(--sp-3); }
.dy-challenges-header-blok { margin: 0 var(--sp-3) var(--sp-3); background: rgba(198,125,6,0.04); border: 1px solid rgba(198,125,6,0.12); border-radius: var(--r-lg); padding: var(--sp-4); }
.dy-challenges-header-blok h3 { font-size: var(--t-base); font-weight: 700; color: var(--ink); margin-bottom: var(--sp-1); }
.dy-challenges-header-blok p { font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.6; }
.dy-leaderboard-jij-sectie { margin: var(--sp-2) var(--sp-3); background: rgba(198,125,6,0.04); border: 1px solid rgba(198,125,6,0.18); border-radius: var(--r-lg); padding: var(--sp-3) var(--sp-4); display: flex; align-items: center; gap: var(--sp-3); }
.dy-leaderboard-jij-pos { font-family: 'DM Sans', sans-serif; font-size: var(--t-2xl); font-weight: 900; color: var(--clay); line-height: 1; flex-shrink: 0; min-width: 40px; text-align: center; }
.dy-leaderboard-jij-info strong { display: block; font-size: var(--t-base); font-weight: 700; color: var(--ink); }
.dy-leaderboard-jij-info span { font-size: var(--t-xs); color: var(--ink-muted); }
.dy-leaderboard-jij-pts { margin-left: auto; font-size: var(--t-sm); font-weight: 700; color: var(--clay); white-space: nowrap; flex-shrink: 0; }
.dy-fit-prompt-text svg { width: 14px; height: 14px; }
.dy-paskamer-wrap, .dy-pk { background: var(--cream); padding-bottom: var(--sp-8); }
.dy-pk-stap { padding: var(--sp-3); }
.dy-cfg-model-download svg, .dy-bericht-stuur-btn svg, .dy-chat-send svg { width: 16px; height: 16px; fill: var(--white); }

/* ════════════════════════════════════════════════════════════════════
   TARGETED FIXES — Gebaseerd op screenshot analyse
   ════════════════════════════════════════════════════════════════════ */

/* ── FIX 1: Kaart header naam + badge niet afsnijden ── */
.dy-kaart-naam-row {
  display: flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
  overflow: hidden;
}
.dy-kaart-naam-row .dy-kaart-naam {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: none; /* verwijder de 120px limiet */
}
.dy-kaart-naam-row .dy-eigen-badge {
  flex-shrink: 0;
  font-size: 0.6rem;
  padding: 1px 5px;
  white-space: nowrap;
}

/* ── FIX 2: Look grid = zelfde als verhalen grid ── */
.dy-look-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  padding: 10px var(--sp-3);
}
@media (min-width: 480px) { .dy-look-grid { grid-template-columns: repeat(3, 1fr); } }

/* Look footer compact */
.dy-look-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-2) var(--sp-3);
  border-top: 1px solid var(--border);
  background: rgba(30,26,15,0.02);
}
.dy-look-auteur {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  min-width: 0;
  overflow: hidden;
}
.dy-look-auteur span {
  font-size: var(--t-sm);
  font-weight: 600;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dy-look-like {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  background: none;
  border: none;
  color: var(--ink-muted);
  cursor: pointer;
  font-size: var(--t-xs);
  padding: var(--sp-1);
  border-radius: var(--r-sm);
  transition: color var(--dur-fast);
  flex-shrink: 0;
}
.dy-look-like svg { width: 16px; height: 16px; fill: currentColor; }
.dy-look-like.liked { color: var(--danger); }
.dy-look-omschrijving {
  font-size: var(--t-sm);
  color: var(--ink-soft);
  padding: var(--sp-2) var(--sp-3);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── FIX 3: Lightbox — max size, niet schermvullend ── */
.dy-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(30,26,15,0.88);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 800;
  opacity: 0;
  transition: opacity var(--dur-mid);
  padding: var(--sp-6) var(--sp-4);
}
.dy-lightbox.actief { opacity: 1; }
.dy-lightbox-media {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: var(--r-lg);
  box-shadow: var(--sh-lg);
}
.dy-lightbox-sluit {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-4);
  width: 40px; height: 40px;
  background: rgba(254,252,245,0.12);
  border: none;
  color: var(--white);
  border-radius: 50%;
  cursor: pointer;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
  transition: background var(--dur-fast);
}
.dy-lightbox-sluit:hover { background: rgba(254,252,245,0.22); }

/* ── FIX 4: DSP pagina — nette kaarten, geen platte tekst ── */
.dy-dsp-uitleg-kaart {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  margin-bottom: var(--sp-3);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.dy-dsp-uitleg-item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
}
.dy-dsp-uitleg-icon { font-size: 1.3rem; flex-shrink: 0; margin-top: 1px; }
.dy-dsp-uitleg-item strong { display: block; font-size: var(--t-base); font-weight: 700; color: var(--ink); margin-bottom: 2px; }
.dy-dsp-uitleg-item p { font-size: var(--t-sm); color: var(--ink-muted); line-height: 1.5; }

/* DSP niveaus in kaart */
.dy-dsp-niveau-rij {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
  background: var(--white);
}
.dy-dsp-niveau-rij:last-child { border-bottom: none; }
.dy-dsp-niveau-emoji { font-size: 1.4rem; flex-shrink: 0; width: 28px; text-align: center; margin-top: 1px; }
.dy-dsp-niveau-info { flex: 1; min-width: 0; }
.dy-dsp-niveau-info strong { display: block; font-size: var(--t-base); font-weight: 700; color: var(--ink); margin-bottom: 2px; }
.dy-dsp-niveau-range { display: block; font-size: var(--t-xs); color: var(--clay); font-weight: 600; margin-bottom: 2px; }
.dy-dsp-niveau-voordeel-tekst {
  display: block;
  font-size: var(--t-xs);
  color: var(--ink-muted);
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* DSP actie tabel — nette twee-koloms layout */
.dy-dsp-cat {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: var(--sp-3);
}
.dy-dsp-cat-titel {
  font-size: var(--t-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clay);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
  background: rgba(198,125,6,0.03);
  margin: 0;
}
.dy-dsp-cat-tabel { display: flex; flex-direction: column; }
.dy-dsp-actie-rij {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--border);
  gap: var(--sp-3);
}
.dy-dsp-actie-rij:last-child { border-bottom: none; }
.dy-dsp-actie-label {
  font-size: var(--t-sm);
  color: var(--ink-soft);
  flex: 1;
  min-width: 0;
  /* Geen overflow hide — laat het wrappen */
  line-height: 1.4;
}
.dy-dsp-actie-rechts {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
  text-align: right;
}
.dy-dsp-pts {
  font-size: var(--t-sm);
  font-weight: 800;
  color: var(--clay);
  white-space: nowrap;
  font-family: 'DM Sans', sans-serif;
}
.dy-dsp-limit {
  font-size: var(--t-xs);
  color: var(--ink-muted);
  white-space: nowrap;
  background: var(--warm);
  padding: 1px var(--sp-2);
  border-radius: var(--r-pill);
}
.dy-page-dsp-sub {
  font-size: var(--t-xs);
  color: var(--clay);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: var(--sp-1);
  text-decoration: none !important;
}

/* ── FIX 5: Configurator — mobile-first, huisstijl tabs ── */
.dy-cfg-wrap-mobile {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - var(--topbar-h));
  background: var(--cream);
}
/* Preview bovenaan op mobile */
.dy-cfg-preview {
  background: var(--warm);
  padding: var(--sp-4);
  display: flex;
  flex-direction: column;
  align-items: center;
  border-bottom: 1px solid var(--border);
  position: static; /* niet sticky op mobile */
}
.dy-cfg-svg-wrap {
  width: 160px;
  height: 260px;
  margin: 0 auto var(--sp-3);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-3);
}
/* Samenvatting tekst onder preview */
.dy-cfg-samenvatting {
  font-size: var(--t-xs);
  color: var(--ink-muted);
  text-align: center;
  margin-bottom: var(--sp-3);
}
/* Genereer knop direct zichtbaar */
.dy-cfg-genereer-btn {
  width: 100%;
  padding: var(--sp-4);
  background: var(--clay);
  color: var(--white);
  border: none;
  border-radius: var(--r-lg);
  font-family: inherit;
  font-size: var(--t-base);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--dur-fast);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
}
.dy-cfg-genereer-btn:hover { background: var(--clay-l); }
.dy-cfg-genereer-btn:disabled { opacity: 0.45; cursor: not-allowed; }

/* Kleuren in cirkel grid */
.dy-cfg-kleuren {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
  justify-content: flex-start;
}
.dy-cfg-kleur {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--dur-fast);
  outline: 2px solid transparent;
  outline-offset: 2px;
}
.dy-cfg-kleur.actief {
  outline-color: var(--clay);
  transform: scale(1.1);
}

/* Tabs als filter pills */
.dy-cfg-tabs-premium {
  display: flex;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  overflow-x: auto;
  background: var(--cream);
  border-bottom: 1px solid var(--border);
}
.dy-cfg-tabs-premium::-webkit-scrollbar { display: none; }
/* De tabs gebruiken nu .dy-filter klasse */

/* Paneel body */
.dy-cfg-panel-wrap { background: var(--cream); flex: 1; }
.dy-cfg-panel { padding: var(--sp-4); display: none; }
.dy-cfg-panel.active { display: block; }

/* Cfg sectie titels */
.dy-cfg-sectie-titel {
  font-size: var(--t-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clay);
  margin-bottom: var(--sp-3);
}

/* Cfg opties */
.dy-cfg-opties {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.dy-cfg-optie {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: all var(--dur-fast);
  font-family: inherit;
  font-size: var(--t-sm);
  color: var(--ink-muted);
  text-align: left;
  min-height: 48px;
}
.dy-cfg-optie:hover { border-color: var(--clay); color: var(--ink); }
.dy-cfg-optie.actief { background: var(--clay-alpha); border-color: var(--clay); color: var(--clay); font-weight: 600; }

/* ── FIX 6: Niveau tiers in profiel/DSP — tekst niet afkappen ── */
.dy-seizoen-tier-info strong,
.dy-niveau-rij-info strong {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}
.dy-seizoen-tier-info span,
.dy-niveau-rij-info span {
  white-space: normal;
  overflow: visible;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* ── FIX 7: Verhaal kaart — auteur sectie nooit overflowt ── */
.dy-kaart-auteur {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex: 1;
  min-width: 0;
  overflow: hidden;
}
.dy-kaart-meta {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.dy-kaart-naam {
  font-size: var(--t-sm);
  font-weight: 700;
  color: var(--ink);
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── FIX 8: Img in detail pagina — max height zodat het niet fullscreen gaat ── */



/* ── FIX 9: DSP niveau rijen niet afkappen ── */
.dy-dsp-niveau-voordelen {
  display: block;
  font-size: var(--t-xs);
  color: var(--ink-muted);
  white-space: normal;
  overflow: visible;
  line-height: 1.5;
}

/* ── FIX 10: Configurator resultaat sectie ── */
.dy-cfg-patroon-resultaat {
  margin-top: var(--sp-3);
  background: var(--cream);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.dy-cfg-patroon-svg {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-3);
  margin-bottom: var(--sp-3);
  overflow: auto;
  max-height: 60vh;
}

/* ── Deel modal polish ── */
.dy-deel-modal {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.dy-deel-overlay {
  position: absolute;
  inset: 0;
  background: rgba(30,26,15,0.5);
  backdrop-filter: blur(4px);
}
.dy-deel-sheet {
  position: relative;
  background: var(--white);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  padding: var(--sp-5);
  width: 100%;
  max-width: var(--max-w);
  z-index: 1;
  animation: slideUp var(--dur-mid) var(--ease-out);
}
.dy-deel-handle {
  width: 36px;
  height: 4px;
  background: var(--parchment);
  border-radius: 2px;
  margin: 0 auto var(--sp-4);
}
.dy-deel-titel {
  font-size: var(--t-lg);
  font-weight: 800;
  color: var(--ink);
  margin-bottom: var(--sp-1);
  text-align: center;
}
.dy-deel-sub {
  font-size: var(--t-sm);
  color: var(--clay);
  font-weight: 600;
  text-align: center;
  margin-bottom: var(--sp-5);
}
.dy-deel-opties {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.dy-deel-opt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  text-decoration: none;
  font-size: var(--t-xs);
  color: var(--ink-muted);
  font-weight: 500;
  transition: opacity var(--dur-fast);
}
.dy-deel-opt:hover { opacity: 0.75; }
.dy-deel-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
}
.dy-deel-icon svg { width: 22px; height: 22px; fill: var(--white); }
.dy-deel-wa { background: #25D366; }
.dy-deel-fb { background: #1877F2; }
.dy-deel-ig { background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.dy-deel-tt { background: #000; }
.dy-deel-pin { background: #E60023; }
.dy-deel-copy { background: var(--ink-soft); }
.dy-deel-link-wrap {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  background: var(--warm);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-2) var(--sp-3);
}
.dy-deel-link {
  flex: 1;
  font-size: var(--t-xs);
  color: var(--ink-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dy-deel-kopieer {
  padding: var(--sp-1) var(--sp-3);
  background: var(--clay);
  color: var(--white);
  border: none;
  border-radius: var(--r-sm);
  font-family: inherit;
  font-size: var(--t-xs);
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Zoek overlay ── */
.dy-zoek-overlay {
  position: fixed;
  top: var(--topbar-h);
  left: 0;
  right: 0;
  background: var(--ink);
  z-index: 200;
  border-bottom: 1px solid rgba(198,125,6,0.15);
  animation: slideUp var(--dur-fast) var(--ease-out);
}

/* ── Kaart hover verwijder knop ── */
.dy-kaart-verwijder {
  background: none;
  border: none;
  color: var(--danger);
  cursor: pointer;
  padding: var(--sp-1);
  border-radius: var(--r-sm);
  margin-left: auto;
  opacity: 0.7;
  transition: opacity var(--dur-fast);
}
.dy-kaart-verwijder:hover { opacity: 1; }
.dy-kaart-verwijder svg { width: 16px; height: 16px; fill: currentColor; }


/* ════════════════════════════════════════════════════════════════════
   FEED PAGINA OPTIMALISATIES — Avatar, naam, lees meer, volgen
   ════════════════════════════════════════════════════════════════════ */

/* ── Kaart header compact & premium ── */
.dy-kaart-header {
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  min-height: 0;
}

/* Compact avatar met initialen fallback */
.dy-kaart-avatar-wrap {
  position: relative;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}
.dy-kaart-avatar-img {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}
.dy-kaart-avatar-initials {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 700;
}
/* Groen stipje voor eigen verhaal */
.dy-kaart-jij-dot {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 9px;
  height: 9px;
  background: var(--clay);
  border-radius: 50%;
  border: 1.5px solid var(--cream);
}

/* Meta tekst compact */
.dy-kaart-meta {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.dy-kaart-naam {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--ink);
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.2;
}
.dy-eigen-badge {
  display: inline-block;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--clay);
  color: var(--white);
  border-radius: var(--r-pill);
  padding: 1px 5px;
  margin-left: 4px;
  vertical-align: middle;
  flex-shrink: 0;
}
.dy-kaart-tijd {
  font-size: 0.65rem;
  color: var(--ink-muted);
  white-space: nowrap;
  line-height: 1.2;
}

/* Volg knop in kaart header */
.dy-kaart-volg-btn {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  background: var(--white);
  color: var(--ink-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all var(--dur-fast);
}
.dy-kaart-volg-btn:hover {
  border-color: var(--clay);
  color: var(--clay);
  background: var(--clay-alpha);
}
.dy-kaart-volg-btn.volgend {
  background: var(--clay);
  border-color: var(--clay);
  color: var(--white);
}

/* ── Kaart footer met zichtbare Lees meer ── */


/* Lees meer knop — altijd zichtbaar rechts */

.dy-lees-meer-btn:hover { opacity: 0.7; }
.dy-lees-meer-btn svg { flex-shrink: 0; }

/* Actie knoppen compacter */

.dy-kaart-actie:hover, .dy-like-btn:hover { background: var(--warm); color: var(--clay); }
.dy-kaart-actie.liked, .dy-like-btn.liked { color: var(--danger); }
.dy-kaart-actie.liked svg, .dy-like-btn.liked svg { fill: var(--danger); }
.dy-kaart-actie svg, .dy-like-btn svg, .dy-reactie-btn svg, .dy-deel-btn svg {
  width: 15px; height: 15px; fill: currentColor; flex-shrink: 0;
}

/* ── Zoekbalk — smooth slide down ── */
#dy-zoekbalk-wrap {
  position: sticky;
  top: var(--topbar-h);
  left: 0;
  right: 0;
  background: var(--ink);
  padding: 8px 14px;
  border-bottom: 1px solid rgba(198,125,6,0.15);
  z-index: 90;
  display: none;
  animation: slideDown 0.2s ease-out;
}
#dy-zoekbalk-wrap.actief { display: block; }
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Vrienden pagina ── */
.dy-vrienden-leeg {
  grid-column: 1/-1;
  text-align: center;
  padding: 3rem 1.5rem;
}
.dy-vrienden-leeg-icon { font-size: 3rem; display: block; margin-bottom: 14px; opacity: 0.5; }
.dy-vrienden-leeg-titel { font-size: 1.1rem; font-weight: 800; color: var(--ink); margin-bottom: 8px; }
.dy-vrienden-leeg-tekst { font-size: 0.85rem; color: var(--ink-muted); line-height: 1.7; max-width: 260px; margin: 0 auto 20px; }

/* Mensen vinden knop */
.dy-btn-vind-mensen {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--clay-alpha);
  border: 1.5px solid rgba(198,125,6,0.25);
  border-radius: var(--r-pill);
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--clay);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: all var(--dur-fast);
}
.dy-btn-vind-mensen:hover { background: var(--clay); color: var(--white); border-color: var(--clay); }

/* Vind mensen kaart */
.dy-vind-kaart {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 16px 12px;
  gap: 8px;
  transition: border-color var(--dur-fast);
  text-align: center;
}
.dy-vind-kaart:hover { border-color: var(--clay); }
.dy-vind-avatar-wrap {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  overflow: hidden;
  cursor: pointer;
  flex-shrink: 0;
}
.dy-vind-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.dy-vind-avatar-initials {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
  color: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 700;
}
.dy-vind-info { flex: 1; min-width: 0; width: 100%; }
.dy-vind-naam { display: block; font-size: 0.85rem; font-weight: 700; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-bottom: 2px; }
.dy-vind-stats { display: block; font-size: 0.72rem; color: var(--ink-muted); }
.dy-vind-volg-btn {
  width: 100%;
  padding: 7px;
  background: var(--clay-alpha);
  border: 1.5px solid rgba(198,125,6,0.25);
  border-radius: var(--r-pill);
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--clay);
  cursor: pointer;
  transition: all var(--dur-fast);
  min-height: 36px;
}
.dy-vind-volg-btn:hover { background: var(--clay); color: var(--white); border-color: var(--clay); }
.dy-vind-volg-btn.volgend {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--white);
}

/* ── Gebruiker profiel hero — volgknop ── */
.dy-gebruiker-volg-wrap { padding: 12px 12px 4px; }
.dy-gebruiker-volg-btn {
  width: 100%;
  padding: 12px;
  background: var(--clay);
  color: var(--white);
  border: none;
  border-radius: var(--r-lg);
  font-family: inherit;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--dur-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
}
.dy-gebruiker-volg-btn:hover { background: var(--clay-l); }
.dy-gebruiker-volg-btn.volgend { background: var(--warm); color: var(--ink); border: 1.5px solid var(--border); }
.dy-gebruiker-volg-btn.volgend:hover { background: rgba(192,57,43,0.06); color: var(--danger); border-color: rgba(192,57,43,0.2); }

/* ── Feed header voor vrienden ── */
.dy-feed-header-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}


/* ── Kaart footer — definitief, geen overflow ── */
.dy-kaart-footer {
  display: flex;
  align-items: center;
  padding: 4px 6px;
  border-top: 1px solid var(--border);
  background: rgba(30,26,15,0.02);
  flex-shrink: 0;
  gap: 0;
  overflow: visible;
  min-height: 36px;
}

/* ── Actie knoppen in footer — definitief ── */
.dy-kaart-actie, .dy-like-btn, .dy-reactie-btn, .dy-deel-btn {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  background: none;
  border: none;
  color: var(--ink-muted);
  font-family: inherit;
  font-size: 0.72rem;
  font-weight: 500;
  cursor: pointer;
  padding: 6px 7px;
  border-radius: var(--r-sm);
  min-height: 36px;
  flex-shrink: 0;
  white-space: nowrap;
  transition: color var(--dur-fast), background var(--dur-fast);
}
.dy-kaart-actie:hover, .dy-like-btn:hover, .dy-reactie-btn:hover, .dy-deel-btn:hover {
  background: var(--warm); color: var(--clay);
}
.dy-kaart-actie.liked, .dy-like-btn.liked { color: var(--danger); }
.dy-kaart-actie.liked svg, .dy-like-btn.liked svg { fill: var(--danger); }
.dy-kaart-actie svg, .dy-like-btn svg, .dy-reactie-btn svg, .dy-deel-btn svg {
  width: 15px; height: 15px; fill: currentColor; flex-shrink: 0;
}

/* Lees meer knop — rechts in footer, altijd zichtbaar */
.dy-lees-meer-btn {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  background: none;
  border: none;
  color: var(--clay);
  font-family: inherit;
  font-size: 0.72rem;
  font-weight: 700;
  cursor: pointer;
  padding: 6px 7px;
  border-radius: var(--r-sm);
  white-space: nowrap;
  flex-shrink: 0;
  margin-left: auto;
  min-height: 36px;
  transition: opacity var(--dur-fast);
}
.dy-lees-meer-btn:hover { opacity: 0.7; }
.dy-lees-meer-btn svg { flex-shrink: 0; }

/* ── Kaart footer: 2 rijen — acties + lees meer ── */
.dy-kaart-footer-wrap {
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}
.dy-kaart-acties-rij {
  display: flex;
  align-items: center;
  padding: 2px 6px;
  gap: 0;
  background: rgba(30,26,15,0.02);
}
.dy-kaart-lees-meer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 100%;
  padding: 8px;
  background: rgba(198,125,6,0.05);
  border: none;
  border-top: 1px solid rgba(198,125,6,0.12);
  color: var(--clay);
  font-family: inherit;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.dy-kaart-lees-meer:hover {
  background: var(--clay);
  color: var(--white);
}
.dy-kaart-lees-meer svg { flex-shrink: 0; transition: transform var(--dur-fast); }
.dy-kaart-lees-meer:hover svg { transform: translateX(2px); }

/* ── Detail pagina foto — volledig zichtbaar, juiste verhouding ── */
.dy-detail-foto {
  display: block;
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: contain;
  border-radius: var(--r-lg);
  margin: 0 0 var(--sp-3) 0;
  background: var(--warm);
}
video.dy-detail-foto {
  object-fit: contain;
  background: #000;
}

/* ════════════════════════════════════════════════════════════════════
   GEBRUIKERSPROFIEL — Premium hero layout
   ════════════════════════════════════════════════════════════════════ */

.dy-gp-wrap {
  background: var(--cream);
  min-height: calc(100vh - var(--topbar-h) - var(--nav-h));
  padding-bottom: 80px;
}

/* ── Hero sectie — donkere ink achtergrond zoals eigen profiel ── */
.dy-gp-hero {
  background: var(--ink);
  padding: var(--sp-4) var(--sp-4) var(--sp-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
}

/* Terug knop — linksboven, subtiel ── */
.dy-gp-terug {
  position: absolute;
  top: var(--sp-4);
  left: var(--sp-4);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: rgba(254,252,245,0.08);
  border: 1px solid rgba(254,252,245,0.12);
  border-radius: var(--r-pill);
  color: rgba(254,252,245,0.7);
  font-family: inherit;
  font-size: var(--t-sm);
  font-weight: 600;
  cursor: pointer;
  padding: 6px 12px;
  transition: all var(--dur-fast);
}
.dy-gp-terug:hover {
  background: rgba(254,252,245,0.14);
  color: var(--white);
}

/* Avatar ring — groot en premium ── */
.dy-gp-avatar-ring {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  margin: var(--sp-5) auto var(--sp-3);
  padding: 3px;
  background: linear-gradient(135deg, var(--clay), var(--clay-d));
  flex-shrink: 0;
  position: relative;
}
.dy-gp-avatar-initials {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: var(--ink-soft);
  border: 2.5px solid var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'DM Sans', sans-serif;
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--white);
  letter-spacing: -0.02em;
}
.dy-gp-avatar-img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  border: 2.5px solid var(--ink);
}

/* Naam ── */
.dy-gp-naam {
  font-family: 'DM Sans', sans-serif;
  font-size: var(--t-xl);
  font-weight: 800;
  color: var(--white);
  margin-bottom: var(--sp-2);
  letter-spacing: -0.01em;
}

/* Niveau pills ── */
.dy-gp-niveau {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-bottom: var(--sp-4);
}
.dy-gp-niveau-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--t-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--clay);
  background: rgba(198,125,6,0.12);
  border: 1px solid rgba(198,125,6,0.22);
  border-radius: var(--r-pill);
  padding: 4px 12px;
}
.dy-gp-seizoen-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--t-xs);
  font-weight: 600;
  color: rgba(254,252,245,0.55);
  background: rgba(254,252,245,0.07);
  border: 1px solid rgba(254,252,245,0.1);
  border-radius: var(--r-pill);
  padding: 4px 12px;
}

/* Volgknop — prominent in hero ── */
.dy-gp-volg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 11px 28px;
  background: var(--clay);
  color: var(--white);
  border: none;
  border-radius: var(--r-pill);
  font-family: inherit;
  font-size: var(--t-base);
  font-weight: 700;
  cursor: pointer;
  transition: all var(--dur-fast);
  min-height: 44px;
  letter-spacing: 0.01em;
}
.dy-gp-volg-btn:hover {
  background: var(--clay-l);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(198,125,6,0.3);
}
.dy-gp-volg-btn.volgend {
  background: rgba(254,252,245,0.08);
  color: rgba(254,252,245,0.6);
  border: 1px solid rgba(254,252,245,0.15);
}
.dy-gp-volg-btn.volgend:hover {
  background: rgba(192,57,43,0.15);
  border-color: rgba(192,57,43,0.25);
  color: #f87171;
}

/* ── Stats grid — 5 kolommen ── */
.dy-gp-stats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--sp-3);
}
@media (max-width: 480px) {
  .dy-gp-stats { grid-template-columns: repeat(3, 1fr); }
  /* Volgers en volgend op 2e rij */
}
.dy-gp-stat {
  background: var(--white);
  padding: var(--sp-4) var(--sp-2);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
}
.dy-gp-stat-val {
  font-family: 'DM Sans', sans-serif;
  font-size: 1.3rem;
  font-weight: 900;
  color: var(--ink);
  line-height: 1;
}
.dy-gp-stat-lbl {
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-muted);
}

/* ── Verhalen sectie ── */
.dy-gp-sectie {
  padding: 0 0 32px;
}
.dy-gp-sectie-titel {
  font-size: var(--t-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--clay);
  padding: var(--sp-3) var(--sp-3) var(--sp-2);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--sp-2);
}

/* Legacy aliases — verberg oude stijlen */
.dy-gebruiker-hero { display: none !important; }
.dy-gebruiker-terug { display: none !important; }

/* ── Nav: 4 tabs + center knop — perfect gebalanceerd ── */
.dy-nav {
  display: grid;
  grid-template-columns: 1fr 1fr 72px 1fr 1fr;
  align-items: stretch;
}
.dy-nav-center {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding-bottom: 6px;
}
.dy-nav-center-ring {
  position: absolute;
  top: -20px;
  width: 52px;
  height: 52px;
  background: var(--clay);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(198,125,6,0.4), 0 0 0 4px var(--ink);
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast);
}
.dy-nav-center-ring:hover { transform: scale(1.07); box-shadow: 0 6px 20px rgba(198,125,6,0.5), 0 0 0 4px var(--ink); }
.dy-nav-center-ring:active { transform: scale(0.95); }
.dy-nav-center-ring svg { stroke: var(--white); }
.dy-nav-center-lbl {
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(254,252,245,0.28);
  margin-top: 2px;
}
.dy-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding-bottom: 6px;
  gap: 3px;
  color: rgba(254,252,245,0.28);
  font-family: inherit;
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  background: none;
  min-height: var(--nav-h);
  transition: color var(--dur-fast);
  -webkit-user-select: none;
  user-select: none;
}
.dy-nav-item svg { margin-bottom: 1px; }
.dy-nav-item.active { color: var(--clay); }
.dy-nav-item:hover { color: rgba(198,125,6,0.65); }

/* ── Nav: 6 tabs + center — Feed|Vrienden|Looks|[+]|Winkel|Reviews|Profiel ── */
.dy-nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr) 60px repeat(3, 1fr);
  align-items: stretch;
  height: calc(var(--nav-h) + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
.dy-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding-bottom: 7px;
  gap: 2px;
  color: rgba(254,252,245,0.28);
  font-family: inherit;
  font-size: 0.52rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  background: none;
  min-height: 44px;
  transition: color var(--dur-fast);
  -webkit-user-select: none; user-select: none;
}
.dy-nav-item svg { flex-shrink: 0; }
.dy-nav-item.active { color: var(--clay); }
.dy-nav-item:hover { color: rgba(198,125,6,0.65); }
.dy-nav-center {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding-bottom: 5px;
}
.dy-nav-center-ring {
  position: absolute;
  top: -18px;
  width: 48px;
  height: 48px;
  background: var(--clay);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(198,125,6,0.4), 0 0 0 3px var(--ink);
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast);
}
.dy-nav-center-ring:hover { transform: scale(1.07); }
.dy-nav-center-ring:active { transform: scale(0.94); }
.dy-nav-center-ring svg { stroke: var(--white); }
.dy-nav-center-lbl {
  font-size: 0.52rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(254,252,245,0.28);
  margin-top: 2px;
}

/* ── Vind mensen grid — 2 kolommen ── */
.dy-vind-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  padding: 10px var(--sp-3) var(--sp-8);
}
@media (min-width: 480px) { .dy-vind-grid { grid-template-columns: repeat(3, 1fr); } }
