/* ========================================
   CONSUMER SITE CSS
   Scoped under .consumer-layout to avoid
   conflicts with existing shop.css
   ======================================== */

/* ========================================
   DESIGN TOKENS
   ======================================== */
.consumer-layout {
  --clr-primary: #A31B34;
  --clr-primary-dark: #7C1428;
  --clr-primary-light: #C92A47;
  --clr-cta: #00843D;
  --clr-cta-hover: #006B31;
  --clr-gold: #F5C518;
  --clr-gold-dark: #D4A90E;
  --clr-bg: #FAFAF8;
  --clr-bg-warm: #F5F0EB;
  --clr-surface: #FFFFFF;
  --clr-text: #1A1A1A;
  --clr-text-secondary: #6D6D6D;
  --clr-text-muted: #999999;
  --clr-border: #E8E2DC;
  --clr-border-light: #F0ECE7;
  --clr-wine-red: #722F37;
  --clr-wine-white: #F0E68C;
  --clr-wine-rose: #E8A0BF;
  --ff-heading: 'Playfair Display', Georgia, serif;
  --ff-body: 'Inter', -apple-system, sans-serif;
  --fs-xs: 0.75rem;
  --fs-sm: 0.875rem;
  --fs-base: 1rem;
  --fs-md: 1.125rem;
  --fs-lg: 1.25rem;
  --fs-xl: 1.5rem;
  --fs-2xl: 2rem;
  --fs-3xl: 2.5rem;
  --fs-4xl: 3.5rem;
  --fs-5xl: 4.5rem;
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-8: 2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.1);
  --shadow-xl: 0 24px 64px rgba(0,0,0,0.12);
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --duration-fast: 150ms;
  --duration-normal: 250ms;
  --duration-slow: 400ms;
}

/* ========================================
   RESET (scoped)
   ======================================== */
.consumer-layout *,
.consumer-layout *::before,
.consumer-layout *::after { box-sizing: border-box; margin: 0; padding: 0; }
.consumer-layout { font-family: var(--ff-body); font-size: var(--fs-base); line-height: 1.6; color: var(--clr-text); background: var(--clr-bg); overflow-x: hidden; -webkit-font-smoothing: antialiased; }
.consumer-layout img,
.consumer-layout svg { display: block; max-width: 100%; }
.consumer-layout a { color: inherit; text-decoration: none; }
.consumer-layout button { font-family: inherit; border: none; cursor: pointer; background: none; }
.consumer-layout ul { list-style: none; }
.consumer-layout h1,
.consumer-layout h2,
.consumer-layout h3,
.consumer-layout h4,
.consumer-layout h5 { font-family: var(--ff-heading); font-weight: 600; line-height: 1.2; }

/* ========================================
   LAYOUT
   ======================================== */
.consumer-layout .c-container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 var(--sp-6); }
.consumer-layout .c-section { padding: var(--sp-20) 0; }
.consumer-layout .c-section-header { text-align: center; margin-bottom: var(--sp-12); }
.consumer-layout .c-section-header h2 { font-size: var(--fs-3xl); margin-bottom: var(--sp-3); }
.consumer-layout .c-section-line { width: 60px; height: 3px; background: var(--clr-primary); margin: var(--sp-4) auto; border-radius: 2px; }
.consumer-layout .c-section-header p { font-size: var(--fs-md); color: var(--clr-text-secondary); max-width: 600px; margin: 0 auto; line-height: 1.7; }

/* ========================================
   ANIMATIONS
   ======================================== */
.consumer-layout .c-fade-up { opacity: 0; transform: translateY(32px); transition: opacity var(--duration-slow) var(--ease-out), transform var(--duration-slow) var(--ease-out); }
.consumer-layout .c-fade-up.visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .consumer-layout .c-fade-up { opacity: 1; transform: none; transition: none; } }
@keyframes c-fadeInUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes c-float { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-20px) rotate(3deg); } }

/* ========================================
   HEADER
   ======================================== */
.consumer-layout .c-header { position: sticky; top: 0; left: 0; right: 0; z-index: 1000; padding: 0; background: #2D2226; box-shadow: 0 2px 12px rgba(0,0,0,0.15); }
.consumer-layout .c-header .c-container { min-height: 64px; }
.consumer-layout .c-header .c-container { display: flex; align-items: center; justify-content: space-between; }
.consumer-layout .c-logo { display: flex; align-items: center; gap: var(--sp-3); cursor: pointer; text-decoration: none; }
.consumer-layout .c-logo-icon { width: 44px; height: 44px; }
.consumer-layout .c-logo-img { max-height: 40px; width: auto; }
.consumer-layout .c-logo-text { display: flex; flex-direction: column; }
.consumer-layout .c-logo-name { font-family: var(--ff-heading); font-size: var(--fs-lg); font-weight: 700; color: #fff; letter-spacing: 2px; line-height: 1.1; }
.consumer-layout .c-logo-tagline { font-size: var(--fs-xs); color: rgba(255,255,255,0.6); letter-spacing: 3px; text-transform: uppercase; font-weight: 500; }
.consumer-layout .c-nav-links { display: flex; align-items: center; gap: var(--sp-8); }
.consumer-layout .c-nav-links a { color: rgba(255,255,255,0.8); font-size: var(--fs-sm); font-weight: 500; letter-spacing: 0.5px; transition: color var(--duration-fast); position: relative; cursor: pointer; }
.consumer-layout .c-nav-links a::after { content: ''; position: absolute; bottom: -4px; left: 0; width: 0; height: 2px; background: var(--clr-gold); transition: width var(--duration-normal) var(--ease-out); }
.consumer-layout .c-nav-links a:hover { color: #fff; }
.consumer-layout .c-nav-links a:hover::after { width: 100%; }
.consumer-layout .c-nav-cart { display: flex; align-items: center; gap: var(--sp-2); color: #fff; font-size: var(--fs-sm); font-weight: 600; background: rgba(255,255,255,0.1); padding: var(--sp-2) var(--sp-4); border-radius: var(--radius-sm); transition: background var(--duration-fast); cursor: pointer; }
.consumer-layout .c-nav-cart:hover { background: rgba(255,255,255,0.2); }
.consumer-layout .c-nav-cart svg { width: 20px; height: 20px; }
.consumer-layout .c-mobile-menu-btn { display: none; color: #fff; padding: var(--sp-2); }
.consumer-layout .c-mobile-menu-btn svg { width: 28px; height: 28px; }

/* ========================================
   BUTTONS
   ======================================== */
.consumer-layout .c-btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); padding: var(--sp-4) var(--sp-8); border-radius: var(--radius-sm); font-weight: 600; font-size: var(--fs-base); letter-spacing: 0.3px; transition: all var(--duration-normal) var(--ease-out); min-height: 48px; cursor: pointer; }
.consumer-layout .c-btn svg { width: 20px; height: 20px; }
.consumer-layout .c-btn-primary { background: var(--clr-cta); color: #fff; }
.consumer-layout .c-btn-primary:hover { background: var(--clr-cta-hover); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,132,61,0.3); }
.consumer-layout .c-btn-primary:active { transform: translateY(0); }
.consumer-layout .c-btn-outline { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,0.3); }
.consumer-layout .c-btn-outline:hover { border-color: rgba(255,255,255,0.6); background: rgba(255,255,255,0.06); }
.consumer-layout .c-btn-outline-dark { background: transparent; color: var(--clr-text); border: 1.5px solid var(--clr-border); }
.consumer-layout .c-btn-outline-dark:hover { border-color: var(--clr-primary); color: var(--clr-primary); }
.consumer-layout .c-btn-sm { padding: var(--sp-2) var(--sp-5); font-size: var(--fs-sm); min-height: 40px; }

/* ========================================
   FLAGS
   ======================================== */
.consumer-layout .c-flag { display: inline-block; border-radius: 4px; overflow: hidden; box-shadow: var(--shadow-sm); vertical-align: middle; }
.consumer-layout .c-flag--sm { width: 18px; height: 13px; }
.consumer-layout .c-flag--md { width: 48px; height: 36px; }
.consumer-layout .c-flag--lg { width: 72px; height: 54px; }
.consumer-layout .c-flag-fr { background: linear-gradient(90deg, #002395 33%, #fff 33% 66%, #ED2939 66%); }
.consumer-layout .c-flag-it { background: linear-gradient(90deg, #008C45 33%, #F4F5F0 33% 66%, #CD212A 66%); }
.consumer-layout .c-flag-es { background: linear-gradient(180deg, #AA151B 25%, #F1BF00 25% 75%, #AA151B 75%); }
.consumer-layout .c-flag-pt { background: linear-gradient(90deg, #006600 40%, #FF0000 40%); }
.consumer-layout .c-flag-de { background: linear-gradient(180deg, #000 33%, #DD0000 33% 66%, #FFCC00 66%); }
.consumer-layout .c-flag-cl { background: linear-gradient(180deg, #fff 50%, #D52B1E 50%); }
.consumer-layout .c-flag-ar { background: linear-gradient(180deg, #74ACDF 33%, #fff 33% 66%, #74ACDF 66%); }
.consumer-layout .c-flag-za { background: linear-gradient(180deg, #DE3831 17%, #fff 17% 22%, #007A4D 22% 50%, #fff 50% 55%, #002395 55% 78%, #FFB612 78%); }
.consumer-layout .c-flag-au { background: #00008B; }
.consumer-layout .c-flag-nz { background: #00247D; }
.consumer-layout .c-flag-at { background: linear-gradient(180deg, #ED2939 33%, #fff 33% 66%, #ED2939 66%); }
.consumer-layout .c-flag-hu { background: linear-gradient(180deg, #CE2939 33%, #fff 33% 66%, #477050 66%); }
.consumer-layout .c-flag-lu { background: linear-gradient(180deg, #ED2939 33%, #fff 33% 66%, #00A1DE 66%); }
.consumer-layout .c-flag-md { background: linear-gradient(90deg, #003DA5 33%, #FFD200 33% 66%, #CC092F 66%); }

/* ========================================
   HERO SECTION
   ======================================== */
.consumer-layout .c-hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; }
.consumer-layout .c-hero-bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 20% 80%, rgba(163,27,52,0.3) 0%, transparent 60%), radial-gradient(ellipse at 80% 20%, rgba(114,47,55,0.2) 0%, transparent 50%), radial-gradient(ellipse at 50% 50%, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.7) 100%), linear-gradient(160deg, #2D1B1E 0%, #1A0F11 30%, #0D0809 70%, #1A1210 100%); z-index: 0; }
.consumer-layout .c-hero-bg::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 200px; background: linear-gradient(to top, var(--clr-bg), transparent); z-index: 1; }
.consumer-layout .c-hero-decorative { position: absolute; z-index: 0; }
.consumer-layout .c-hero-grape-left { left: 5%; top: 20%; opacity: 0.06; animation: c-float 8s ease-in-out infinite; }
.consumer-layout .c-hero .c-container { position: relative; z-index: 2; padding-top: var(--sp-24); padding-bottom: var(--sp-24); }
.consumer-layout .c-hero-content { max-width: 750px; }
.consumer-layout .c-hero-badge { display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2) var(--sp-4); background: rgba(245,197,24,0.12); border: 1px solid rgba(245,197,24,0.25); border-radius: 100px; margin-bottom: var(--sp-8); animation: c-fadeInUp 0.8s var(--ease-out) 0.2s both; }
.consumer-layout .c-hero-badge span { color: var(--clr-gold); font-size: var(--fs-sm); font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }
.consumer-layout .c-hero h1 { font-size: var(--fs-5xl); color: #fff; margin-bottom: var(--sp-6); line-height: 1.08; letter-spacing: -1px; animation: c-fadeInUp 0.8s var(--ease-out) 0.4s both; }
.consumer-layout .c-hero h1 em { font-style: italic; color: var(--clr-gold); }
.consumer-layout .c-hero-subtitle { font-size: var(--fs-lg); color: rgba(255,255,255,0.65); line-height: 1.7; margin-bottom: var(--sp-10); max-width: 560px; animation: c-fadeInUp 0.8s var(--ease-out) 0.6s both; }
.consumer-layout .c-hero-actions { display: flex; align-items: center; gap: var(--sp-4); animation: c-fadeInUp 0.8s var(--ease-out) 0.8s both; }

/* ========================================
   COUNTRIES
   ======================================== */
.consumer-layout .c-countries { background: var(--clr-bg); }
.consumer-layout .c-countries-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--sp-4); }
.consumer-layout .c-country-card { position: relative; padding: var(--sp-6) var(--sp-4); background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); text-align: center; transition: all var(--duration-normal) var(--ease-out); cursor: pointer; overflow: hidden; }
.consumer-layout .c-country-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--clr-primary); transform: scaleX(0); transition: transform var(--duration-normal) var(--ease-out); }
.consumer-layout .c-country-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--clr-primary); }
.consumer-layout .c-country-card:hover::before { transform: scaleX(1); }
.consumer-layout .c-country-card .c-flag { margin: 0 auto var(--sp-3); }
.consumer-layout .c-country-card h3 { font-family: var(--ff-heading); font-size: var(--fs-md); font-weight: 600; margin-bottom: var(--sp-1); }
.consumer-layout .c-country-card .c-wine-count { font-size: var(--fs-sm); color: var(--clr-primary); font-weight: 600; margin-bottom: var(--sp-2); }
.consumer-layout .c-country-card .c-country-desc { font-size: var(--fs-xs); color: var(--clr-text-secondary); line-height: 1.5; }

/* ========================================
   REGIONS
   ======================================== */
.consumer-layout .c-regions { background: var(--clr-bg-warm); }
.consumer-layout .c-regions-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); }
.consumer-layout .c-region-card { position: relative; border-radius: var(--radius-lg); overflow: hidden; min-height: 320px; display: flex; flex-direction: column; justify-content: flex-end; padding: var(--sp-8); cursor: pointer; transition: transform var(--duration-normal) var(--ease-out); }
.consumer-layout .c-region-card:hover { transform: scale(1.02); }
.consumer-layout .c-region-card-bg { position: absolute; inset: 0; z-index: 0; transition: transform var(--duration-slow) var(--ease-out); }
.consumer-layout .c-region-card:hover .c-region-card-bg { transform: scale(1.06); }
.consumer-layout .c-region-card::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.3) 50%, rgba(0,0,0,0.1) 100%); z-index: 1; }
.consumer-layout .c-region-card-content { position: relative; z-index: 2; }
.consumer-layout .c-region-card .c-region-country { font-size: var(--fs-xs); color: var(--clr-gold); font-weight: 600; letter-spacing: 2px; text-transform: uppercase; margin-bottom: var(--sp-2); }
.consumer-layout .c-region-card h3 { font-family: var(--ff-heading); font-size: var(--fs-2xl); color: #fff; margin-bottom: var(--sp-3); }
.consumer-layout .c-region-grape-tag { padding: var(--sp-1) var(--sp-3); background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2); border-radius: 100px; font-size: var(--fs-xs); color: rgba(255,255,255,0.85); font-weight: 500; display: inline-block; margin: 2px; }

/* Region BG gradients */
.consumer-layout .c-region-bordeaux .c-region-card-bg { background: linear-gradient(135deg, #3D1C24 0%, #6B2D3A 40%, #2D1B1E 100%); }
.consumer-layout .c-region-bourgogne .c-region-card-bg { background: linear-gradient(135deg, #4A2040 0%, #7B3F5E 40%, #2D1525 100%); }
.consumer-layout .c-region-toscane .c-region-card-bg { background: linear-gradient(135deg, #5C4033 0%, #8B6F47 40%, #3D2B1F 100%); }
.consumer-layout .c-region-rioja .c-region-card-bg { background: linear-gradient(135deg, #6B1B1B 0%, #9B3B3B 40%, #4A1212 100%); }
.consumer-layout .c-region-douro .c-region-card-bg { background: linear-gradient(135deg, #2D3B4E 0%, #4A6B82 40%, #1B2533 100%); }
.consumer-layout .c-region-mosel .c-region-card-bg { background: linear-gradient(135deg, #2B4A3E 0%, #4A7A68 40%, #1B3028 100%); }

/* ========================================
   WINE CARDS
   ======================================== */
.consumer-layout .c-filter-bar { display: flex; align-items: center; gap: var(--sp-4); margin-bottom: var(--sp-8); padding: var(--sp-4) var(--sp-6); background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); flex-wrap: wrap; }
.consumer-layout .c-filter-group { display: flex; align-items: center; gap: var(--sp-2); }
.consumer-layout .c-filter-label { font-size: var(--fs-sm); font-weight: 600; color: var(--clr-text-secondary); white-space: nowrap; }
.consumer-layout .c-filter-btn { padding: var(--sp-2) var(--sp-4); border-radius: 100px; font-size: var(--fs-sm); font-weight: 500; color: var(--clr-text-secondary); background: var(--clr-bg); border: 1px solid var(--clr-border); transition: all var(--duration-fast); cursor: pointer; display: inline-flex; align-items: center; gap: var(--sp-2); min-height: 36px; }
.consumer-layout .c-filter-btn:hover,
.consumer-layout .c-filter-btn.active { background: var(--clr-primary); color: #fff; border-color: var(--clr-primary); }
.consumer-layout .c-filter-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; border: 1px solid rgba(0,0,0,0.1); }
.consumer-layout .c-filter-dot-red { background: var(--clr-wine-red); }
.consumer-layout .c-filter-dot-white { background: var(--clr-wine-white); }
.consumer-layout .c-filter-dot-rose { background: var(--clr-wine-rose); }
.consumer-layout .c-filter-separator { width: 1px; height: 24px; background: var(--clr-border); }
.consumer-layout .c-filter-select { padding: var(--sp-2) var(--sp-4); border-radius: var(--radius-sm); font-size: var(--fs-sm); font-family: var(--ff-body); border: 1px solid var(--clr-border); background: var(--clr-bg); color: var(--clr-text); cursor: pointer; min-height: 36px; }

.consumer-layout .c-wines-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-6); }
.consumer-layout .c-wine-card { background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); overflow: hidden; transition: all var(--duration-normal) var(--ease-out); cursor: pointer; }
.consumer-layout .c-wine-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-xl); border-color: transparent; }
.consumer-layout .c-wine-card-image { position: relative; height: 240px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.consumer-layout .c-wine-card-image-bg { position: absolute; inset: 0; }
.consumer-layout .c-wine-card-image .bottle-svg { position: relative; z-index: 1; filter: drop-shadow(0 8px 24px rgba(0,0,0,0.15)); transition: transform var(--duration-normal) var(--ease-out); }
.consumer-layout .c-wine-card:hover .bottle-svg { transform: translateY(-8px) scale(1.03); }
.consumer-layout .c-wine-badge { position: absolute; top: var(--sp-3); left: var(--sp-3); z-index: 2; padding: var(--sp-1) var(--sp-3); border-radius: 100px; font-size: var(--fs-xs); font-weight: 700; letter-spacing: 0.5px; }
.consumer-layout .c-wine-badge-sale { background: var(--clr-primary); color: #fff; }
.consumer-layout .c-wine-badge-new { background: var(--clr-cta); color: #fff; }
.consumer-layout .c-wine-badge-custom { background: var(--clr-gold); color: #1A1A1A; }
.consumer-layout .c-wine-color-dot { position: absolute; top: var(--sp-3); right: var(--sp-3); z-index: 2; width: 16px; height: 16px; border-radius: 50%; border: 2px solid #fff; box-shadow: var(--shadow-sm); }
.consumer-layout .c-wine-card-body { padding: var(--sp-5); }
.consumer-layout .c-wine-card-origin { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.consumer-layout .c-wine-card-origin span { font-size: var(--fs-xs); color: var(--clr-text-secondary); font-weight: 500; }
.consumer-layout .c-wine-card h3 { font-family: var(--ff-heading); font-size: var(--fs-md); font-weight: 600; margin-bottom: var(--sp-1); line-height: 1.3; }
.consumer-layout .c-wine-card .c-winery { font-size: var(--fs-sm); color: var(--clr-text-secondary); margin-bottom: var(--sp-3); display: block; }
.consumer-layout .c-wine-card .c-vintage { font-size: var(--fs-xs); color: var(--clr-text-muted); font-weight: 500; }
.consumer-layout .c-wine-card-rating { display: flex; align-items: center; gap: var(--sp-1); margin: var(--sp-3) 0; }
.consumer-layout .c-star { width: 16px; height: 16px; color: var(--clr-gold); }
.consumer-layout .c-star-empty { color: var(--clr-border); }
.consumer-layout .c-rating-score { font-size: var(--fs-sm); font-weight: 600; color: var(--clr-text); margin-left: var(--sp-1); }
.consumer-layout .c-wine-card-footer { display: flex; align-items: center; justify-content: space-between; padding-top: var(--sp-3); border-top: 1px solid var(--clr-border-light); }
.consumer-layout .c-wine-price .c-price-current { font-size: var(--fs-xl); font-weight: 700; color: var(--clr-text); }
.consumer-layout .c-wine-price .c-price-old { font-size: var(--fs-sm); color: var(--clr-text-muted); text-decoration: line-through; }
.consumer-layout .c-btn-cart { width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; background: var(--clr-cta); color: #fff; border-radius: var(--radius-sm); transition: all var(--duration-fast); cursor: pointer; }
.consumer-layout .c-btn-cart:hover { background: var(--clr-cta-hover); transform: scale(1.08); }
.consumer-layout .c-btn-cart svg { width: 20px; height: 20px; }

/* ========================================
   COLLECTION PAGE
   ======================================== */
.consumer-layout .c-collection-layout { display: grid; grid-template-columns: 1fr 260px; gap: var(--sp-8); align-items: start; }
.consumer-layout .c-collection-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
.consumer-layout .c-collection-grid .c-wine-card-image { height: 200px; }
.consumer-layout .c-collection-grid .c-wine-card h3 { font-size: var(--fs-sm); }
.consumer-layout .c-collection-filters { position: sticky; top: 80px; background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); padding: var(--sp-5); }
.consumer-layout .c-filter-section { margin-bottom: var(--sp-5); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--clr-border-light); }
.consumer-layout .c-filter-section:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.consumer-layout .c-filter-section h4 { font-size: var(--fs-sm); font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--clr-text-secondary); margin-bottom: var(--sp-3); }
.consumer-layout .c-filter-input { width: 100%; padding: var(--sp-2) var(--sp-3); border: 1px solid var(--clr-border); border-radius: var(--radius-sm); font-size: var(--fs-sm); background: var(--clr-bg); }
.consumer-layout .c-filter-input:focus { outline: none; border-color: var(--clr-primary); }
.consumer-layout .c-filter-option { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-1) 0; cursor: pointer; font-size: var(--fs-sm); color: var(--clr-text); }
.consumer-layout .c-filter-option input[type="radio"] { accent-color: var(--clr-primary); margin: 0; }
.consumer-layout .c-filter-clear { background: none; border: none; font-size: var(--fs-xs); color: var(--clr-primary); cursor: pointer; padding: var(--sp-1) 0; font-weight: 500; }
.consumer-layout .c-filter-clear:hover { text-decoration: underline; }
@media (max-width: 1024px) {
  .consumer-layout .c-collection-layout { grid-template-columns: 1fr 220px; }
  .consumer-layout .c-collection-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .consumer-layout .c-collection-layout { grid-template-columns: 1fr; }
  .consumer-layout .c-collection-filters { position: static; order: -1; }
  .consumer-layout .c-collection-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ========================================
   USP
   ======================================== */
.consumer-layout .c-usp { background: var(--clr-bg-warm); position: relative; overflow: hidden; }
.consumer-layout .c-usp::before { content: ''; position: absolute; top: -50%; right: -15%; width: 500px; height: 500px; border-radius: 50%; background: radial-gradient(circle, rgba(163,27,52,0.04) 0%, transparent 70%); }
.consumer-layout .c-usp-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-6); }
.consumer-layout .c-usp-card { text-align: center; padding: var(--sp-8) var(--sp-6); background: var(--clr-surface); border-radius: var(--radius-md); border: 1px solid var(--clr-border-light); transition: all var(--duration-normal) var(--ease-out); }
.consumer-layout .c-usp-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.consumer-layout .c-usp-icon { width: 56px; height: 56px; margin: 0 auto var(--sp-5); display: flex; align-items: center; justify-content: center; background: rgba(163,27,52,0.08); border-radius: var(--radius-md); color: var(--clr-primary); }
.consumer-layout .c-usp-icon svg { width: 28px; height: 28px; }
.consumer-layout .c-usp-card h3 { font-family: var(--ff-heading); font-size: var(--fs-lg); margin-bottom: var(--sp-3); }
.consumer-layout .c-usp-card p { font-size: var(--fs-sm); color: var(--clr-text-secondary); line-height: 1.6; }

/* ========================================
   NEWSLETTER
   ======================================== */
.consumer-layout .c-newsletter { background: linear-gradient(135deg, var(--clr-primary-dark) 0%, var(--clr-primary) 50%, #8B1A2B 100%); position: relative; overflow: hidden; padding: var(--sp-20) 0; }
.consumer-layout .c-newsletter::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 20% 50%, rgba(245,197,24,0.08) 0%, transparent 50%), radial-gradient(circle at 80% 50%, rgba(255,255,255,0.04) 0%, transparent 40%); }
.consumer-layout .c-newsletter .c-container { position: relative; z-index: 1; text-align: center; }
.consumer-layout .c-newsletter h2 { font-family: var(--ff-heading); font-size: var(--fs-3xl); color: #fff; margin-bottom: var(--sp-3); }
.consumer-layout .c-newsletter p { font-size: var(--fs-md); color: rgba(255,255,255,0.7); margin-bottom: var(--sp-8); max-width: 500px; margin-left: auto; margin-right: auto; }
.consumer-layout .c-newsletter-form { display: flex; max-width: 480px; margin: 0 auto; gap: var(--sp-3); }
.consumer-layout .c-newsletter-input { flex: 1; padding: var(--sp-4) var(--sp-5); border-radius: var(--radius-sm); border: 1px solid rgba(255,255,255,0.2); background: rgba(255,255,255,0.1); color: #fff; font-family: var(--ff-body); font-size: var(--fs-base); min-height: 48px; transition: all var(--duration-fast); }
.consumer-layout .c-newsletter-input::placeholder { color: rgba(255,255,255,0.5); }
.consumer-layout .c-newsletter-input:focus { outline: none; border-color: var(--clr-gold); background: rgba(255,255,255,0.15); }
.consumer-layout .c-newsletter-btn { padding: var(--sp-4) var(--sp-6); background: var(--clr-gold); color: var(--clr-text); font-weight: 700; border-radius: var(--radius-sm); font-size: var(--fs-base); white-space: nowrap; transition: all var(--duration-fast); min-height: 48px; cursor: pointer; }
.consumer-layout .c-newsletter-btn:hover { background: var(--clr-gold-dark); transform: translateY(-1px); }
.consumer-layout .c-newsletter-disclaimer { margin-top: var(--sp-4); font-size: var(--fs-xs); color: rgba(255,255,255,0.4); }

/* ========================================
   FOOTER
   ======================================== */
.consumer-layout .c-footer { background: #1A1210; color: rgba(255,255,255,0.7); padding: var(--sp-16) 0 var(--sp-8); }
.consumer-layout .c-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--sp-10); margin-bottom: var(--sp-12); }
.consumer-layout .c-footer-brand p { font-size: var(--fs-sm); line-height: 1.7; max-width: 300px; margin: var(--sp-4) 0 var(--sp-5); }
.consumer-layout .c-footer-social { display: flex; gap: var(--sp-3); }
.consumer-layout .c-footer-social a { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-sm); background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.6); transition: all var(--duration-fast); }
.consumer-layout .c-footer-social a:hover { background: var(--clr-primary); color: #fff; }
.consumer-layout .c-footer-social svg { width: 18px; height: 18px; }
.consumer-layout .c-footer-col h4 { font-family: var(--ff-heading); font-size: var(--fs-base); color: #fff; margin-bottom: var(--sp-5); font-weight: 600; }
.consumer-layout .c-footer-col ul li { margin-bottom: var(--sp-3); }
.consumer-layout .c-footer-col a { font-size: var(--fs-sm); color: rgba(255,255,255,0.55); transition: color var(--duration-fast); }
.consumer-layout .c-footer-col a:hover { color: var(--clr-gold); }
.consumer-layout .c-footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding-top: var(--sp-8); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--sp-4); }
.consumer-layout .c-footer-bottom p { font-size: var(--fs-xs); color: rgba(255,255,255,0.4); }
.consumer-layout .c-footer-payment { display: flex; align-items: center; gap: var(--sp-3); }
.consumer-layout .c-payment-icon { width: 40px; height: 28px; background: rgba(255,255,255,0.08); border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 10px; color: rgba(255,255,255,0.5); font-weight: 700; }
.consumer-layout .c-age-notice { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-4); background: rgba(163,27,52,0.15); border: 1px solid rgba(163,27,52,0.25); border-radius: var(--radius-sm); font-size: var(--fs-xs); color: rgba(255,255,255,0.6); font-weight: 500; }
.consumer-layout .c-age-badge { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; background: var(--clr-primary); border-radius: 50%; font-size: 11px; font-weight: 800; color: #fff; flex-shrink: 0; }

/* ========================================
   DETAIL PAGE (Country & Region)
   ======================================== */
.consumer-layout .c-detail-hero { position: relative; min-height: 420px; display: flex; align-items: flex-end; padding-bottom: var(--sp-12); overflow: hidden; }
.consumer-layout .c-detail-hero-bg { position: absolute; inset: 0; z-index: 0; }
.consumer-layout .c-detail-hero::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.4) 40%, rgba(0,0,0,0.2) 100%); z-index: 1; }
.consumer-layout .c-detail-hero .c-container { position: relative; z-index: 2; padding-top: 120px; }

/* Breadcrumb */
.consumer-layout .c-breadcrumb { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-4) 0; }
.consumer-layout .c-breadcrumb a,
.consumer-layout .c-breadcrumb span { font-size: var(--fs-sm); color: var(--clr-text-secondary); font-weight: 500; }
.consumer-layout .c-breadcrumb a { cursor: pointer; transition: color var(--duration-fast); }
.consumer-layout .c-breadcrumb a:hover { color: var(--clr-primary); }
.consumer-layout .c-breadcrumb svg { width: 14px; height: 14px; color: var(--clr-border); flex-shrink: 0; }
/* Dark variant for hero sections */
.consumer-layout .c-detail-hero .c-breadcrumb a,
.consumer-layout .c-detail-hero .c-breadcrumb span { color: rgba(255,255,255,0.6); }
.consumer-layout .c-detail-hero .c-breadcrumb a:hover { color: var(--clr-gold); }
.consumer-layout .c-detail-hero .c-breadcrumb svg { color: rgba(255,255,255,0.3); }

.consumer-layout .c-detail-hero-content { display: flex; align-items: flex-end; gap: var(--sp-8); }
.consumer-layout .c-detail-hero-flag { flex-shrink: 0; }
.consumer-layout .c-detail-hero h1 { font-size: var(--fs-4xl); color: #fff; margin-bottom: var(--sp-3); }
.consumer-layout .c-detail-hero .c-subtitle { font-size: var(--fs-lg); color: rgba(255,255,255,0.7); max-width: 600px; line-height: 1.6; }

/* Detail Stats */
.consumer-layout .c-detail-stats { display: flex; gap: var(--sp-8); margin-top: var(--sp-6); }
.consumer-layout .c-detail-stat { text-align: center; }
.consumer-layout .c-detail-stat .c-stat-value { font-family: var(--ff-heading); font-size: var(--fs-2xl); font-weight: 700; color: var(--clr-gold); }
.consumer-layout .c-detail-stat .c-stat-label { font-size: var(--fs-xs); color: rgba(255,255,255,0.5); text-transform: uppercase; letter-spacing: 1px; margin-top: var(--sp-1); }

/* Detail Info Section */
.consumer-layout .c-detail-info { background: var(--clr-bg); }
.consumer-layout .c-detail-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-10); align-items: start; }
.consumer-layout .c-detail-info-text h2 { font-size: var(--fs-2xl); margin-bottom: var(--sp-5); }
.consumer-layout .c-detail-info-text p { font-size: var(--fs-base); color: var(--clr-text-secondary); line-height: 1.8; margin-bottom: var(--sp-4); }

/* Photo Gallery */
.consumer-layout .c-detail-gallery { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 200px 200px; gap: var(--sp-4); }
.consumer-layout .c-gallery-img { border-radius: var(--radius-md); overflow: hidden; position: relative; }
.consumer-layout .c-gallery-img:first-child { grid-row: 1 / 3; }
.consumer-layout .c-gallery-img-inner { width: 100%; height: 100%; transition: transform var(--duration-slow) var(--ease-out); }
.consumer-layout .c-gallery-img:hover .c-gallery-img-inner { transform: scale(1.06); }
.consumer-layout .c-gallery-label { position: absolute; bottom: var(--sp-3); left: var(--sp-3); font-size: var(--fs-xs); font-weight: 600; color: #fff; background: rgba(0,0,0,0.5); backdrop-filter: blur(8px); padding: var(--sp-1) var(--sp-3); border-radius: 100px; z-index: 1; }

/* Key Facts */
.consumer-layout .c-detail-facts { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); margin-top: var(--sp-8); }
.consumer-layout .c-fact-card { background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); padding: var(--sp-5); }
.consumer-layout .c-fact-card h4 { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 1px; color: var(--clr-primary); font-weight: 700; margin-bottom: var(--sp-2); font-family: var(--ff-body); }
.consumer-layout .c-fact-card p { font-size: var(--fs-sm); color: var(--clr-text); font-weight: 500; }

/* Regions in country detail */
.consumer-layout .c-detail-regions { background: var(--clr-bg-warm); }

/* Detail wines */
.consumer-layout .c-detail-wines { background: var(--clr-bg); }

/* ========================================
   WINE DETAIL HERO
   ======================================== */
.consumer-layout .c-wine-hero { padding-top: 0; background: var(--clr-bg-warm); position: relative; overflow: hidden; }
.consumer-layout .c-wine-hero::before { content: ''; position: absolute; top: -30%; right: -10%; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle, rgba(163,27,52,0.06) 0%, transparent 70%); }
.consumer-layout .c-wine-hero-grid { display: grid; grid-template-columns: 400px 1fr; gap: var(--sp-12); padding: var(--sp-12) 0 var(--sp-16); align-items: start; }
.consumer-layout .c-wine-hero-image { position: relative; display: flex; align-items: center; justify-content: center; min-height: 480px; background: linear-gradient(180deg, #F0EBE5, #DDD5CA); border-radius: var(--radius-lg); overflow: hidden; }
.consumer-layout .c-wine-hero-image .bottle-svg { filter: drop-shadow(0 16px 48px rgba(0,0,0,0.2)); transition: transform 0.6s var(--ease-out); }
.consumer-layout .c-wine-hero-image:hover .bottle-svg { transform: translateY(-12px) scale(1.02); }
.consumer-layout .c-wine-color-indicator { position: absolute; top: var(--sp-4); right: var(--sp-4); width: 20px; height: 20px; border-radius: 50%; border: 2px solid #fff; box-shadow: var(--shadow-sm); background: var(--clr-wine-red); }
.consumer-layout .c-wine-hero-info { padding-top: var(--sp-4); }
.consumer-layout .c-wine-hero-info .c-wine-origin { display: flex; align-items: center; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.consumer-layout .c-wine-hero-info .c-wine-origin span { font-size: var(--fs-sm); color: var(--clr-text-secondary); font-weight: 500; }
.consumer-layout .c-wine-hero-info h1 { font-size: var(--fs-4xl); margin-bottom: var(--sp-2); line-height: 1.1; }
.consumer-layout .c-wine-winery { font-size: var(--fs-lg); color: var(--clr-text-secondary); margin-bottom: var(--sp-6); }
.consumer-layout .c-wine-meta-row { display: flex; flex-wrap: wrap; gap: var(--sp-6); margin-bottom: var(--sp-8); padding-bottom: var(--sp-6); border-bottom: 1px solid var(--clr-border-light); }
.consumer-layout .c-wine-meta-item { display: flex; flex-direction: column; gap: var(--sp-1); }
.consumer-layout .c-wine-meta-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 1px; color: var(--clr-text-muted); font-weight: 600; }
.consumer-layout .c-wine-meta-value { font-size: var(--fs-base); font-weight: 600; color: var(--clr-text); }
.consumer-layout .c-wine-price-section { display: flex; align-items: center; gap: var(--sp-6); margin-bottom: var(--sp-8); }
.consumer-layout .c-wine-price-current { font-family: var(--ff-heading); font-size: var(--fs-3xl); font-weight: 700; color: var(--clr-text); }
.consumer-layout .c-wine-price-btns { display: flex; gap: var(--sp-3); }
.consumer-layout .c-wine-description-intro { font-size: var(--fs-md); color: var(--clr-text-secondary); line-height: 1.8; max-width: 560px; }

/* ========================================
   TASTING PROFILE SECTION
   ======================================== */
.consumer-layout .c-tasting-section { background: var(--clr-bg); position: relative; }
.consumer-layout .c-tasting-section .c-section-header { text-align: center; margin-bottom: var(--sp-12); }
.consumer-layout .c-tasting-section .c-section-header h2 { font-size: var(--fs-3xl); margin-bottom: var(--sp-3); }
.consumer-layout .c-tasting-section .c-section-header p { font-size: var(--fs-md); color: var(--clr-text-secondary); max-width: 600px; margin: 0 auto; line-height: 1.7; }

/* Three tasting cards */
.consumer-layout .c-tasting-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); margin-bottom: var(--sp-16); }
.consumer-layout .c-tasting-card { background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); padding: var(--sp-8); transition: all var(--duration-normal) var(--ease-out); position: relative; overflow: hidden; }
.consumer-layout .c-tasting-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--clr-primary); transform: scaleX(0); transition: transform var(--duration-normal) var(--ease-out); }
.consumer-layout .c-tasting-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--clr-primary); }
.consumer-layout .c-tasting-card:hover::before { transform: scaleX(1); }
.consumer-layout .c-tasting-card-icon { width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; background: rgba(163,27,52,0.08); border-radius: var(--radius-md); color: var(--clr-primary); margin-bottom: var(--sp-5); }
.consumer-layout .c-tasting-card-icon svg { width: 28px; height: 28px; }
.consumer-layout .c-tasting-card h3 { font-family: var(--ff-heading); font-size: var(--fs-xl); margin-bottom: var(--sp-4); }
.consumer-layout .c-tasting-card p { font-size: var(--fs-base); color: var(--clr-text-secondary); line-height: 1.7; margin-bottom: var(--sp-5); }

/* Aroma tags */
.consumer-layout .c-aroma-tags { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.consumer-layout .c-aroma-tag { display: inline-flex; align-items: center; gap: var(--sp-1); padding: var(--sp-1) var(--sp-3); background: rgba(163,27,52,0.06); border: 1px solid rgba(163,27,52,0.12); border-radius: 100px; font-size: var(--fs-xs); color: var(--clr-wine-red); font-weight: 600; transition: all var(--duration-fast); }
.consumer-layout .c-aroma-tag:hover { background: rgba(163,27,52,0.12); border-color: rgba(163,27,52,0.25); }
.consumer-layout .c-aroma-tag svg { width: 14px; height: 14px; flex-shrink: 0; }

/* ========================================
   TASTE BARS (smaakbalkjes)
   ======================================== */
.consumer-layout .c-taste-bars { display: flex; flex-direction: column; gap: var(--sp-4); }
.consumer-layout .c-taste-bar-item { display: grid; grid-template-columns: 100px 1fr auto; align-items: center; gap: var(--sp-4); }
.consumer-layout .c-taste-bar-label { font-size: var(--fs-sm); font-weight: 600; color: var(--clr-text); }
.consumer-layout .c-taste-bar-track { height: 8px; background: var(--clr-border-light); border-radius: 4px; overflow: hidden; position: relative; }
.consumer-layout .c-taste-bar-fill { height: 100%; border-radius: 4px; transition: width 1s var(--ease-out); width: 0; }
.consumer-layout .c-taste-bar-fill-low { background: linear-gradient(90deg, #E8D4A0, #D4A90E); }
.consumer-layout .c-taste-bar-fill-medium { background: linear-gradient(90deg, #C67B5C, #A31B34); }
.consumer-layout .c-taste-bar-fill-high { background: linear-gradient(90deg, #A31B34, #722F37); }
.consumer-layout .c-taste-bar-value { font-size: var(--fs-xs); font-weight: 700; color: var(--clr-text-secondary); width: 24px; text-align: right; }

/* ========================================
   KARAKTER QUOTE
   ======================================== */
.consumer-layout .c-karakter-quote { text-align: center; padding: var(--sp-10) var(--sp-8); background: linear-gradient(135deg, rgba(163,27,52,0.04) 0%, rgba(114,47,55,0.06) 100%); border-radius: var(--radius-lg); margin-bottom: var(--sp-16); position: relative; }
.consumer-layout .c-karakter-quote::before { content: '\201C'; font-family: var(--ff-heading); font-size: 6rem; color: rgba(163,27,52,0.1); position: absolute; top: -0.1em; left: 50%; transform: translateX(-50%); line-height: 1; }
.consumer-layout .c-karakter-quote blockquote { font-family: var(--ff-heading); font-size: var(--fs-2xl); font-style: italic; color: var(--clr-wine-red); line-height: 1.5; max-width: 700px; margin: 0 auto var(--sp-4); position: relative; }
.consumer-layout .c-karakter-label { font-size: var(--fs-sm); font-weight: 600; color: var(--clr-text-muted); text-transform: uppercase; letter-spacing: 2px; }

/* ========================================
   RADAR CHART
   ======================================== */
.consumer-layout .c-radar-section { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-12); align-items: center; margin-bottom: var(--sp-16); }
.consumer-layout .c-radar-chart-wrapper { display: flex; align-items: center; justify-content: center; }
.consumer-layout .c-radar-chart-wrapper svg { max-width: 420px; width: 100%; }
.consumer-layout .c-radar-info h3 { font-size: var(--fs-2xl); margin-bottom: var(--sp-4); }
.consumer-layout .c-radar-info p { font-size: var(--fs-base); color: var(--clr-text-secondary); line-height: 1.8; margin-bottom: var(--sp-6); }
.consumer-layout .c-radar-legend { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.consumer-layout .c-radar-legend-item { display: flex; align-items: center; gap: var(--sp-2); }
.consumer-layout .c-radar-legend-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--clr-primary); flex-shrink: 0; }
.consumer-layout .c-radar-legend-text { font-size: var(--fs-sm); color: var(--clr-text-secondary); }
.consumer-layout .c-radar-legend-value { font-weight: 700; color: var(--clr-text); margin-left: auto; font-size: var(--fs-sm); }

/* ========================================
   FOOD PAIRING
   ======================================== */
.consumer-layout .c-pairing-section { background: var(--clr-bg-warm); }
.consumer-layout .c-pairing-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-6); }
.consumer-layout .c-pairing-card { background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); padding: var(--sp-6); text-align: center; transition: all var(--duration-normal) var(--ease-out); }
.consumer-layout .c-pairing-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.consumer-layout .c-pairing-icon { width: 64px; height: 64px; margin: 0 auto var(--sp-4); display: flex; align-items: center; justify-content: center; background: rgba(163,27,52,0.06); border-radius: 50%; color: var(--clr-primary); }
.consumer-layout .c-pairing-icon svg { width: 32px; height: 32px; }
.consumer-layout .c-pairing-card h4 { font-family: var(--ff-heading); font-size: var(--fs-md); margin-bottom: var(--sp-2); }
.consumer-layout .c-pairing-card p { font-size: var(--fs-sm); color: var(--clr-text-secondary); line-height: 1.5; }

/* ========================================
   SERVEER TIPS
   ======================================== */
.consumer-layout .c-serve-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); margin-top: var(--sp-12); }
.consumer-layout .c-serve-item { display: flex; align-items: center; gap: var(--sp-4); padding: var(--sp-5) var(--sp-6); background: var(--clr-surface); border: 1px solid var(--clr-border-light); border-radius: var(--radius-md); }
.consumer-layout .c-serve-item-icon { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; background: rgba(163,27,52,0.08); border-radius: var(--radius-sm); color: var(--clr-primary); flex-shrink: 0; }
.consumer-layout .c-serve-item-icon svg { width: 24px; height: 24px; }
.consumer-layout .c-serve-item-text h4 { font-family: var(--ff-body); font-size: var(--fs-sm); font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--clr-primary); margin-bottom: var(--sp-1); }
.consumer-layout .c-serve-item-text p { font-size: var(--fs-base); font-weight: 600; color: var(--clr-text); }

/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 1024px) {
  .consumer-layout .c-countries-grid { grid-template-columns: repeat(3, 1fr); }
  .consumer-layout .c-wines-grid { grid-template-columns: repeat(3, 1fr); }
  .consumer-layout .c-regions-grid { grid-template-columns: repeat(2, 1fr); }
  .consumer-layout .c-footer-grid { grid-template-columns: repeat(2, 1fr); }
  .consumer-layout .c-detail-info-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-hero h1 { font-size: var(--fs-4xl); }
  .consumer-layout .c-wine-hero-grid { grid-template-columns: 320px 1fr; gap: var(--sp-8); }
  .consumer-layout .c-radar-section { grid-template-columns: 1fr; }
  .consumer-layout .c-radar-chart-wrapper { order: -1; }
  .consumer-layout .c-pairing-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .consumer-layout .c-nav-links { display: none; }
  .consumer-layout .c-mobile-menu-btn { display: block; }
  .consumer-layout .c-hero h1 { font-size: var(--fs-3xl); }
  .consumer-layout .c-hero-subtitle { font-size: var(--fs-base); }
  .consumer-layout .c-hero-actions { flex-direction: column; align-items: flex-start; }
  .consumer-layout .c-section { padding: var(--sp-12) 0; }
  .consumer-layout .c-section-header h2 { font-size: var(--fs-2xl); }
  .consumer-layout .c-countries-grid { grid-template-columns: repeat(2, 1fr); }
  .consumer-layout .c-wines-grid { grid-template-columns: repeat(2, 1fr); }
  .consumer-layout .c-regions-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-usp-grid { grid-template-columns: repeat(2, 1fr); }
  .consumer-layout .c-footer-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-filter-bar { flex-direction: column; align-items: flex-start; }
  .consumer-layout .c-filter-separator { display: none; }
  .consumer-layout .c-newsletter-form { flex-direction: column; }
  .consumer-layout .c-footer-bottom { flex-direction: column; text-align: center; }
  .consumer-layout .c-detail-hero h1 { font-size: var(--fs-3xl); }
  .consumer-layout .c-detail-hero-content { flex-direction: column; align-items: flex-start; }
  .consumer-layout .c-detail-stats { flex-wrap: wrap; gap: var(--sp-4); }
  .consumer-layout .c-detail-gallery { grid-template-columns: 1fr; grid-template-rows: auto; }
  .consumer-layout .c-gallery-img:first-child { grid-row: auto; }
  .consumer-layout .c-detail-facts { grid-template-columns: 1fr; }
  .consumer-layout .c-wine-hero-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-wine-hero-image { min-height: 360px; max-width: 320px; margin: 0 auto; }
  .consumer-layout .c-wine-hero-info h1 { font-size: var(--fs-3xl); }
  .consumer-layout .c-tasting-cards { grid-template-columns: 1fr; }
  .consumer-layout .c-serve-strip { grid-template-columns: 1fr; }
  .consumer-layout .c-karakter-quote blockquote { font-size: var(--fs-xl); }
  .consumer-layout .c-radar-legend { grid-template-columns: 1fr; }
  .consumer-layout .c-pairing-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-taste-bar-item { grid-template-columns: 80px 1fr auto; }
}

@media (max-width: 480px) {
  .consumer-layout .c-countries-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-wines-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-usp-grid { grid-template-columns: 1fr; }
  .consumer-layout .c-hero h1 { font-size: var(--fs-2xl); }
  .consumer-layout .c-wine-meta-row { gap: var(--sp-4); }
  .consumer-layout .c-wine-price-btns { flex-direction: column; width: 100%; }
  .consumer-layout .c-wine-price-section { flex-direction: column; align-items: flex-start; }
}
