/* =========================================================================
   adcolor.ro v2 — PLP DE CATEGORIE „Tehnici decorative" (full-page design comp) · DIRECȚIA D2 „Var & salvie"
   MACHETĂ DE DESIGN — NU site live. Imagini TEMPORARE (placeholder din img-temp/).
   GLOBALE (header/footer/share/sprite/tokeni/CSS de bază/motion/JS-motion) = REUTILIZATE VERBATIM din pdp-v5.html
   (PM: „header și footer sunt globale" — trebuie BIT-IDENTICE pe tot site-ul).
   COMPONENTE (card produs „favourite", card categorie „Pick your finish" color-slide, filtre PLP cu
   swatch, paginație, badge-uri, paletar/swatch) = REUTILIZATE din components-v1.html (validate de PM).

   STRUCTURA PLP (de sus în jos, redată întocmai):
     HEADER GLOBAL (fundal solid #33382F = --color-text-primary, controale inversate, logo auriu)
     BREADCRUMB: Acasă › Produse › Tehnici decorative
     ANTET CATEGORIE: titlu „Tehnici decorative" + descriere SEO scurtă + „34 produse"
     RÂND CARDURI CATEGORIE: 7 familii (card-categorie 1:1 din components-v1, grilă 4 pe rând care se înfășoară), curenta = activă
     ZONĂ PRINCIPALĂ 2 COLOANE:
        STÂNGA = sidebar FILTRE STICKY (Brand, Nuanță-swatch, Ambalaj/Volum, Destinație, Preț-range)
                 → pe mobil = buton „Filtre" care deschide un DRAWER
        DREAPTA = bară de sus (count + sortare + toggle densitate grilă) + GRILĂ carduri PRODUS premium
                  (4 col widescreen → reflow), incl. variante: Nou, Reducere (preț tăiat), Stoc epuizat,
                  Preț la cerere (badge + „Cere ofertă"), bestseller.
     PAGINAȚIE
     BARĂ SHARE GLOBALĂ „Distribuie această pagină"
     FOOTER GLOBAL
     STRAT MOTION GLOBAL (buton „sus" cu inel de procent, scroll-reveal staggered, blob) — prefers-reduced-motion guard

   Date demo PLAUZIBILE (tehnici decorative, branduri reale Caparol/Valpaint/Cebos/Chreon).
   Randamentul m²/L de pe carduri NU apare (e detaliu PDP); prețurile „de la X lei/L" = DEMO [NEEDS-PM la import real].

   Stare livrabil: CONSTRUIT, NEconfirmat vizual (RULE 8 — fără render real). Randează PM/manager headless.
   ========================================================================= */

:root{
  --fs-display: clamp(2.5rem, 1.8rem + 3.5vw, 4.5rem);
  --fs-h2: clamp(1.75rem, 1.4rem + 1.8vw, 2.75rem);
  --fs-h3: clamp(1.25rem, 1.1rem + 0.8vw, 1.6rem);
  --fs-lead: clamp(1.05rem, 1rem + 0.4vw, 1.25rem);
  --fs-body: clamp(1rem, 0.97rem + 0.15vw, 1.0625rem);
  --fs-stat: clamp(2.5rem, 1.6rem + 3.5vw, 3.75rem);
  --fs-small: 0.875rem; --fs-eyebrow: 0.8125rem;
  --lh-tight: 1.1; --lh-heading: 1.25; --lh-body: 1.65;
  --ls-eyebrow: 0.12em; --ls-heading: -0.01em;
  --fw-regular:400; --fw-medium:500; --fw-semibold:600; --fw-bold:700;
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:24px;
  --space-6:32px; --space-7:48px; --space-8:64px; --space-9:96px;
  --radius-sm:4px; --radius-md:10px; --radius-lg:18px; --radius-swatch:6px; --radius-pill:999px;
  --container-max:1280px; --container-max-wide:1480px;
  --container-pad: clamp(1rem, 0.5rem + 2.5vw, 2.5rem);
  --touch-min:44px; --border-w:1px; --transition:180ms ease; --tr-flood:240ms ease;
  --tr-slide:320ms cubic-bezier(.4,0,.2,1); --tr-zoom:320ms cubic-bezier(.4,0,.2,1);
  --header-h:72px;
  --card-curve-w:150%; --card-curve-h:100%;
  --card-curve: radial-gradient(var(--card-curve-w) var(--card-curve-h) at 50% 0%, #000 99.5%, transparent 100%);
  --z-sticky:200; --z-overlay:300; --z-mega:250; --z-drawer:350; --z-totop:400;
  --tr-motion:560ms cubic-bezier(.4,0,.2,1);  /* easing premium pentru stratul de mișcare */
  --font-display:"Marcellus", serif; --font-body:"Mulish", sans-serif;
  --color-background:#F4F2EC; --color-surface:#FFFFFF; --color-surface-alt:#E7E6DC;
  --color-text-primary:#33382F; --color-text-secondary:#5E6357;
  --color-primary:#5E7355; --color-primary-hover:#4A5D44; --color-primary-active:#3C4D38;
  --color-secondary:#8A7E6A; --color-accent:#B8A66F;
  --color-success:#4F7A4E; --color-warning:#A87E2C; --color-danger:#9C463A;
  --color-danger-hover:#86392F; --color-danger-active:#6F2F26;
  --color-border:#D8D6C9; --color-on-primary:#F6F8F2;
  --color-info:#3E6A77;
  --color-success-soft:#E6EEE2; --color-warning-soft:#F3EAD3;
  --color-danger-soft:#F2E1DD; --color-info-soft:#E0EBEE;
  --color-selected-ring:#5E7355; --color-overlay:rgba(51,56,47,0.55);
  --color-tint:#ECEEE3;            /* tentă D2 deschisă pentru variația de fundal */
  --shadow-sm:0 1px 2px rgba(60,64,52,.08);
  --shadow-card:0 4px 14px rgba(60,64,52,.10);
  --shadow-card-hover:0 10px 28px rgba(60,64,52,.16);
  --shadow-swatch:0 2px 8px rgba(60,64,52,.14);
  --cat-sage:#CFE0B4; --cat-lime:#E0E8B2; --cat-mustard:#EDDA9C; --cat-clay:#F3D4BC;
  --cat-stone:#CDDCDF; --cat-forest:#CCDFC6; --cat-sand:#EEDAAE;
}

*{box-sizing:border-box;}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{ margin:0; font-family:var(--font-body); font-size:var(--fs-body); line-height:var(--lh-body);
  color:var(--color-text-primary); background:var(--color-background); }
img{ max-width:100%; }
a{ color:var(--color-primary); }
.wrap{ width:min(100% - 2*var(--container-pad), var(--container-max)); margin:0 auto; }
@media (min-width:1440px){ .wrap{ width:min(100% - 2*var(--container-pad), var(--container-max-wide)); } }
.skip{ position:absolute; left:-9999px; }
.skip:focus{ left:var(--space-3); top:var(--space-3); z-index:999; background:var(--color-surface);
  padding:var(--space-3) var(--space-4); border-radius:var(--radius-md); box-shadow:var(--shadow-card); }

/* ---- Banner notă (machetă) — DEZACTIVAT (display:none defensiv + comentat în HTML), ca pe pdp-v5. ---- */
.comp-banner{ display:none !important; }

/* ---- ICOANE SVG ---- */
.icon{ width:1.15em; height:1.15em; display:inline-block; vertical-align:-0.15em; flex:0 0 auto;
  stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; fill:none; }

/* ---- BUTOANE (VERBATIM din pdp-v5) ---- */
.btn{ font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-body);
  border-radius:var(--radius-md); padding:var(--space-3) var(--space-5); min-height:var(--touch-min);
  display:inline-flex; align-items:center; justify-content:center; gap:var(--space-2); cursor:pointer;
  text-decoration:none; border:1px solid transparent;
  transition:background var(--transition), box-shadow var(--transition), transform var(--transition); }
.btn-primary{ background:var(--color-primary); color:var(--color-on-primary); }
.btn-primary:hover{ background:var(--color-primary-hover); box-shadow:var(--shadow-sm); transform:translateY(-1px); }
.btn-primary:active{ background:var(--color-primary-active); transform:translateY(0); box-shadow:none; }
.btn-secondary{ background:transparent; border-color:var(--color-primary); color:var(--color-primary); }
.btn-secondary:hover{ background:var(--color-surface-alt); }
.btn-ghost{ background:transparent; color:var(--color-primary); }
.btn-ghost:hover{ background:var(--color-surface-alt); text-decoration:underline; }
.btn-onsage{ background:var(--color-on-primary); color:var(--color-primary); border-color:transparent; }
.btn-onsage:hover{ background:#fff; box-shadow:var(--shadow-sm); transform:translateY(-1px); }
.btn:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.btn-onsage:focus-visible{ outline-color:var(--color-on-primary); }
.btn-sm{ font-size:var(--fs-small); padding:var(--space-2) var(--space-4); min-height:38px; }
.btn-full{ width:100%; }
.btn .ic{ width:1.1em; height:1.1em; }
.link-arrow{ display:inline-flex; align-items:center; gap:var(--space-1); font-weight:600;
  color:var(--color-primary); text-decoration:none; }
.link-arrow:hover{ text-decoration:underline; }
.link-arrow .icon{ transition:transform var(--transition); }
.link-arrow:hover .icon{ transform:translateX(2px); }
@media (prefers-reduced-motion: reduce){
  .btn-primary:hover, .btn-onsage:hover{ transform:none; }
  .link-arrow:hover .icon{ transform:none; }
}

/* ---- SCROLL REVEAL (fade + slide-up subtil) — VERBATIM din pdp-v5 ---- */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .6s ease, transform .6s cubic-bezier(.4,0,.2,1); }
.reveal.is-in{ opacity:1; transform:none; }
.reveal--left{ transform:translateX(-34px); }
.reveal--right{ transform:translateX(34px); }
.reveal--left.is-in, .reveal--right.is-in{ transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal, .reveal--left, .reveal--right{ opacity:1 !important; transform:none !important; transition:none; }
}

/* ============ STRATUL DE MIȘCARE (motion layer) — VERBATIM din pdp-v5.html ============ */
.stagger-group > .stg-child{ opacity:0; transition:opacity var(--tr-motion), transform var(--tr-motion); }
.stg-child.from-up{    transform:translateY(34px); }
.stg-child.from-down{  transform:translateY(-26px); }
.stg-child.from-left{  transform:translateX(-38px); }
.stg-child.from-right{ transform:translateX(38px); }
.stagger-group.is-in > .stg-child{ opacity:1; transform:none; }

/* ---- Buton „înapoi sus" cu inel de progres de scroll ---- */
.to-top{ position:fixed; right:clamp(16px,3vw,28px); bottom:clamp(16px,3vw,28px); z-index:var(--z-totop);
  width:56px; height:56px; padding:0; border:0; border-radius:var(--radius-pill);
  background:var(--color-surface); color:var(--color-primary); box-shadow:var(--shadow-card-hover); cursor:pointer;
  display:grid; place-items:center; opacity:0; transform:translateY(12px) scale(.85); pointer-events:none;
  transition:opacity var(--transition), transform var(--tr-slide), box-shadow var(--transition); }
.to-top.is-visible{ opacity:1; transform:translateY(0) scale(1); pointer-events:auto; }
.to-top:hover{ box-shadow:var(--shadow-card-hover), 0 0 0 3px var(--color-tint); }
.to-top:focus-visible{ outline:3px solid var(--color-primary); outline-offset:3px; }
.to-top .tt-ring{ position:absolute; inset:0; width:100%; height:100%; transform:rotate(-90deg); pointer-events:none; }
.to-top .tt-track{ fill:none; stroke:var(--color-border); stroke-width:3; }
.to-top .tt-bar{ fill:none; stroke:var(--color-primary); stroke-width:3; stroke-linecap:round;
  transition:stroke-dashoffset 90ms linear; }
.to-top:hover .tt-bar{ stroke:var(--color-accent); }
.to-top .tt-face{ position:relative; display:grid; place-items:center; line-height:1; }
.to-top .tt-pct{ font-family:var(--font-body); font-weight:var(--fw-bold); font-size:.82rem;
  color:var(--color-text-primary); letter-spacing:.01em;
  transition:opacity var(--transition), transform var(--transition); }
.to-top .tt-arrow{ position:absolute; inset:0; display:grid; place-items:center; color:var(--color-primary);
  opacity:0; transform:translateY(3px); transition:opacity var(--transition), transform var(--transition); }
.to-top .tt-arrow .icon{ width:1.5em; height:1.5em; }
.to-top:hover .tt-pct, .to-top:focus-visible .tt-pct{ opacity:0; transform:translateY(-3px); }
.to-top:hover .tt-arrow, .to-top:focus-visible .tt-arrow{ opacity:1; transform:translateY(0); }

/* ---- „Blob" decorativ pe carduri (subset: product-card) ---- */
.product-card{ position:relative; }
.product-card::before{
  content:""; position:absolute; z-index:0; top:-18%; right:-14%; width:46%; aspect-ratio:1/1; pointer-events:none;
  background:radial-gradient(circle at 35% 35%, rgba(94,115,85,.18), rgba(94,115,85,0) 70%);
  border-radius:46% 54% 58% 42% / 52% 44% 56% 48%; opacity:.7;
  transition:transform 1.4s cubic-bezier(.4,0,.2,1), border-radius 1.4s cubic-bezier(.4,0,.2,1), opacity var(--transition); }
.product-card:hover::before{
  transform:scale(1.18) rotate(8deg); border-radius:58% 42% 48% 52% / 44% 56% 48% 52%; opacity:.9; }
.product-card > *{ position:relative; z-index:1; }
@media (prefers-reduced-motion: reduce){
  .to-top{ transition:opacity .01ms; transform:none; } .to-top.is-visible{ transform:none; }
  .to-top .tt-bar{ transition:none; }
  .stagger-group > .stg-child{ opacity:1 !important; transform:none !important; transition:none; }
  .product-card::before{ transition:none; }
  .product-card:hover::before{ transform:none; border-radius:46% 54% 58% 42% / 52% 44% 56% 48%; }
}

/* ============ HEADER STICKY (GLOBAL — VERBATIM din pdp-v5.html) ============ */
.site-header{ position:sticky; top:0; z-index:var(--z-sticky);
  background:var(--color-text-primary);
  border-bottom:1px solid rgba(255,255,255,.14); }
.header-inner{ display:flex; align-items:center; gap:var(--space-4); min-height:var(--header-h);
  padding-top:var(--space-2); padding-bottom:var(--space-2); }
.header-search{ position:relative; flex:1 1 auto; max-width:360px; }
.header-search .icon{ position:absolute; left:var(--space-4); top:50%; transform:translateY(-50%);
  color:var(--color-text-secondary); width:1.1em; height:1.1em; }
.header-search input{ width:100%; min-height:var(--touch-min); border:1px solid var(--color-border);
  border-radius:var(--radius-pill); background:var(--color-background); font-family:var(--font-body);
  font-size:var(--fs-body); padding:0 var(--space-4) 0 calc(var(--space-4)*2 + 8px); color:var(--color-text-primary); }
.header-search input:focus{ outline:2px solid var(--color-primary); outline-offset:1px; border-color:var(--color-primary); }
.header-actions{ display:flex; align-items:center; gap:var(--space-1); margin-left:auto; flex:0 0 auto; }
.icon-btn{ position:relative; width:var(--touch-min); height:var(--touch-min); display:inline-flex;
  align-items:center; justify-content:center; border:0; background:transparent; color:var(--color-text-primary);
  border-radius:var(--radius-md); cursor:pointer; text-decoration:none; }
.icon-btn:hover{ background:var(--color-surface-alt); }
.icon-btn:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
.icon-btn .icon{ width:1.4em; height:1.4em; }
.cart-count{ position:absolute; top:4px; right:4px; min-width:18px; height:18px; padding:0 4px;
  background:var(--color-primary); color:var(--color-on-primary); border-radius:var(--radius-pill);
  font-size:.7rem; font-weight:700; display:flex; align-items:center; justify-content:center; font-family:var(--font-body); }
.burger{ display:none; }
/* Inversiune controale pe fundalul header-ului închis. */
.site-header .tmd-mm__logo .logo-mark{ color:var(--color-accent); }
.site-header .tmd-mm__logo .logo-mark b{ color:var(--color-accent); }
.site-header .tmd-mm__navlink, .site-header .tmd-mm__trigger{ color:var(--color-on-primary); }
.site-header .tmd-mm__navlink:hover, .site-header .tmd-mm__trigger:hover{ color:#fff; }
.site-header .tmd-mm__navlink.is-current{ color:var(--color-accent); }
.site-header .tmd-mm__trigger::after{ background:var(--color-accent); }
.site-header .tmd-mm__trigger-underline{ background:var(--color-accent); }
.site-header .tmd-mm__indicator{ color:var(--color-on-primary); }
.site-header .tmd-mm__navlink:focus-visible, .site-header .tmd-mm__trigger:focus-visible,
.site-header .tmd-mm__toggle:focus-visible{ outline:2px solid var(--color-accent); outline-offset:2px; }
.site-header .tmd-mm__toggle{ color:var(--color-on-primary); }
.site-header .header-search .icon{ color:rgba(246,248,242,.85); }
.site-header .header-search input{ background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.45); color:#fff; }
.site-header .header-search input::placeholder{ color:rgba(246,248,242,.78); }
.site-header .header-search input:focus{ outline:2px solid var(--color-accent); outline-offset:1px;
  border-color:var(--color-accent); background:rgba(255,255,255,.18); }
.site-header .icon-btn{ color:var(--color-on-primary); }
.site-header .icon-btn:hover{ background:rgba(255,255,255,.14); color:#fff; }
.site-header .icon-btn:focus-visible{ outline:2px solid var(--color-accent); outline-offset:-2px; }
.site-header .cart-count{ background:var(--color-accent); color:#2B2F27; }

/* ---- TMD MEGA MENU (preview static fidel; mapat pe tokeni D2 — VERBATIM din pdp-v5) ---- */
.tmd-mm{
  --mm-accent:var(--color-primary); --mm-accent-ink:var(--color-on-primary);
  --mm-eyebrow-accent:var(--color-accent); --mm-bar-bg:var(--color-surface); --mm-bar-ink:var(--color-text-primary);
  --mm-panel-bg:var(--color-surface); --mm-panel-ink:var(--color-text-primary); --mm-muted:var(--color-text-secondary);
  --mm-card-bg:var(--color-surface); --mm-card-bg-hover:var(--color-tint); --mm-border:var(--color-border);
  --mm-font-heading:var(--font-display); --mm-font-body:var(--font-body); --mm-font-label:var(--font-body);
  --mm-weight-heading:var(--fw-regular); --mm-weight-label:var(--fw-semibold); --mm-tracking-label:0.06em;
  --mm-fz-nav:var(--fs-small); --mm-fz-eyebrow:var(--fs-eyebrow); --mm-fz-title:var(--fs-h3);
  --mm-fz-card-title:1.05rem; --mm-fz-desc:var(--fs-small); --mm-fz-feature:var(--fs-h3);
  --mm-maxw:var(--container-max); --mm-bar-h:calc(var(--header-h) - 16px); --mm-bar-pad-x:0px;
  --mm-panel-pad-y:var(--space-6); --mm-panel-pad-x:var(--space-6); --mm-gap:var(--space-4);
  --mm-radius:var(--radius-lg); --mm-radius-card:var(--radius-md); --mm-cols:4;
  --mm-ease:cubic-bezier(.4,0,.2,1); --mm-dur:240ms;
  position:relative; flex:1 1 auto; min-width:0; font-family:var(--mm-font-body); color:var(--mm-panel-ink); }
.tmd-mm *,.tmd-mm *::before,.tmd-mm *::after{ box-sizing:border-box; }
.tmd-mm a{ text-decoration:none; color:inherit; }
.tmd-mm__bar{ background:transparent; }
.tmd-mm__bar-inner{ max-width:none; margin:0; padding:0; height:var(--mm-bar-h); display:flex; align-items:center; gap:var(--space-5); }
.tmd-mm__logo{ display:flex; align-items:center; height:40px; color:var(--mm-bar-ink); flex:0 0 auto; }
.tmd-mm__logo a{ display:flex; align-items:center; }
.tmd-mm__logo img{ height:100%; width:auto; display:block; }
.tmd-mm__logo .logo-mark{ font-family:var(--font-display); font-size:1.5rem; color:var(--color-text-primary); letter-spacing:.02em; line-height:1; }
.tmd-mm__logo .logo-mark b{ color:var(--color-primary); font-weight:var(--fw-regular); }
.tmd-mm__nav{ display:flex; align-items:center; gap:var(--space-4); flex:1 1 auto; min-width:0;
  flex-wrap:var(--mm-nav-wrap, wrap); overflow-x:var(--mm-nav-overflow, visible); }
.tmd-mm__navlink,.tmd-mm__trigger{ font-family:var(--mm-font-label); font-size:var(--mm-fz-nav);
  font-weight:var(--mm-weight-label); letter-spacing:var(--mm-tracking-label); color:var(--mm-bar-ink);
  background:none; border:0; padding:0; cursor:pointer; line-height:1; min-height:var(--touch-min); display:inline-flex; align-items:center; }
.tmd-mm__navlink{ color:var(--color-text-primary); padding:0 var(--space-2); border-radius:var(--radius-md); }
.tmd-mm__navlink:hover{ color:var(--color-primary); }
.tmd-mm__navlink:focus-visible,.tmd-mm__trigger:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; border-radius:var(--radius-md); }
.tmd-mm__navlink.is-current{ color:var(--mm-accent); }
.tmd-mm__triggerwrap{ position:relative; order:-1; }
.tmd-mm__trigger{ position:relative; gap:7px; padding:0 var(--space-2); }
.tmd-mm__trigger::after{ content:""; width:7px; height:7px; border-radius:50%; background:var(--mm-accent);
  opacity:0; transform:scale(.4); transition:opacity .2s ease, transform .2s ease; }
.tmd-mm.is-open .tmd-mm__trigger::after{ opacity:1; transform:scale(1); }
.tmd-mm__trigger-underline{ position:absolute; left:var(--space-2); right:var(--space-4); bottom:6px; height:2px;
  background:var(--mm-accent); transform:scaleX(0); transform-origin:left; transition:transform var(--mm-dur) var(--mm-ease); }
.tmd-mm.is-open .tmd-mm__trigger-underline,.tmd-mm__trigger:hover .tmd-mm__trigger-underline{ transform:scaleX(1); }
.tmd-mm__indicator{ display:inline-flex; align-items:center; line-height:0; transition:transform var(--mm-dur) var(--mm-ease); }
.tmd-mm__indicator .icon{ width:1em; height:1em; }
.tmd-mm__indicator-open{ display:none; }
.tmd-mm.is-open .tmd-mm__indicator-closed{ display:none; }
.tmd-mm.is-open .tmd-mm__indicator-open{ display:inline-flex; }
.tmd-mm__panel{ position:absolute; left:0; right:0; transform:translateY(-8px); top:100%; width:auto;
  background:var(--mm-panel-bg); border-top:1px solid var(--mm-border); border-bottom:1px solid var(--mm-border);
  box-shadow:var(--shadow-card-hover); opacity:0; visibility:hidden; z-index:var(--z-mega);
  transition:opacity var(--mm-dur) var(--mm-ease), transform var(--mm-dur) var(--mm-ease), visibility 0s linear var(--mm-dur); }
.tmd-mm.is-open .tmd-mm__panel{ opacity:1; visibility:visible; transform:translateY(0);
  transition:opacity var(--mm-dur) var(--mm-ease), transform var(--mm-dur) var(--mm-ease); }
.tmd-mm__panel-inner{ max-width:var(--mm-maxw); margin:0 auto; padding:var(--mm-panel-pad-y) var(--container-pad); }
.tmd-mm__eyebrow,.tmd-mm__intro-eyebrow{ font-family:var(--mm-font-label); font-size:var(--mm-fz-eyebrow);
  letter-spacing:var(--ls-eyebrow); text-transform:uppercase; font-weight:var(--fw-bold); color:var(--color-primary); }
.tmd-mm__intro-title{ font-family:var(--mm-font-heading); font-weight:var(--mm-weight-heading); font-size:var(--mm-fz-title);
  line-height:var(--lh-heading); letter-spacing:var(--ls-heading); margin:var(--space-2) 0 0; color:var(--color-text-primary); }
.tmd-mm--images .tmd-mm__panel-inner{ display:grid; grid-template-columns:200px 1fr; gap:var(--space-6); align-items:start; }
.tmd-mm__grid{ display:grid; grid-template-columns:repeat(var(--mm-cols), 1fr); gap:var(--mm-gap); }
.tmd-mm__card{ position:relative; display:block; border:1px solid var(--mm-border); border-radius:var(--mm-radius-card);
  overflow:hidden; background:var(--mm-card-bg); box-shadow:var(--shadow-card);
  transition:border-color .2s ease, transform .2s ease, box-shadow .2s ease; }
.tmd-mm__card:hover{ border-color:var(--mm-accent); transform:translateY(-3px); box-shadow:var(--shadow-card-hover); }
.tmd-mm__card:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.tmd-mm__thumb{ --card-curve-h:135%; position:relative; aspect-ratio:16/10; background:var(--mm-card-bg-hover);
  overflow:hidden; -webkit-mask:var(--card-curve); mask:var(--card-curve); }
.tmd-mm__thumb img{ position:relative; z-index:0; width:100%; height:100%; object-fit:cover; display:block;
  transform:scale(1); transform-origin:center; will-change:transform; transition:transform var(--tr-zoom); }
.tmd-mm__card:hover .tmd-mm__thumb img, .tmd-mm__card:focus-visible .tmd-mm__thumb img{ transform:scale(1.06); }
.tmd-mm__thumb::before{ content:""; position:absolute; left:0; right:0; top:0; height:55%; z-index:1; pointer-events:none;
  background:linear-gradient(to bottom, var(--mm-accent) 0%, rgba(94,115,85,0) 100%);
  opacity:0; transform:translateY(-100%); transition:transform var(--tr-slide), opacity var(--tr-flood); }
.tmd-mm__card:hover .tmd-mm__thumb::before, .tmd-mm__card:focus-visible .tmd-mm__thumb::before{ opacity:.55; transform:translateY(0); }
.tmd-mm__card-body{ padding:var(--space-3) var(--space-4) var(--space-4); }
.tmd-mm__card-title{ font-family:var(--mm-font-heading); font-weight:var(--mm-weight-heading); font-size:var(--mm-fz-card-title);
  line-height:1.25; color:var(--color-text-primary); transition:color .2s ease; }
.tmd-mm__card:hover .tmd-mm__card-title{ color:var(--mm-accent); }
.tmd-mm__card-desc{ font-family:var(--mm-font-body); font-size:var(--mm-fz-desc); line-height:1.45; color:var(--mm-muted); margin-top:4px; }
.tmd-mm__feature{ display:flex; flex-direction:column; justify-content:space-between; gap:var(--space-3);
  background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-active) 100%);
  color:var(--color-on-primary); border-radius:var(--mm-radius); padding:var(--space-5); }
.tmd-mm__feature--compact{ grid-column:auto; }
.tmd-mm__feature-eyebrow{ font-family:var(--mm-font-label); font-size:var(--mm-fz-eyebrow); letter-spacing:var(--ls-eyebrow);
  text-transform:uppercase; font-weight:var(--fw-bold); color:var(--mm-eyebrow-accent); }
.tmd-mm__feature-title{ font-family:var(--mm-font-heading); font-weight:var(--mm-weight-heading); font-size:var(--mm-fz-feature);
  line-height:var(--lh-heading); color:#fff; }
.tmd-mm__feature-text{ font-family:var(--mm-font-body); font-size:var(--fs-small); line-height:1.5; color:#ECEFE6; margin:0; }
.tmd-mm__feature-btn{ align-self:flex-start; display:inline-flex; align-items:center; gap:8px; min-height:var(--touch-min);
  font-family:var(--mm-font-body); font-weight:var(--fw-semibold); font-size:var(--fs-small); background:var(--color-on-primary);
  border:1px solid transparent; padding:var(--space-2) var(--space-4); border-radius:var(--radius-md); transition:background var(--transition); }
.tmd-mm a.tmd-mm__feature-btn{ color:var(--color-primary); }
.tmd-mm__feature-btn .icon{ color:var(--color-primary); flex:0 0 auto; }
.tmd-mm a.tmd-mm__feature-btn:hover{ background:#fff; color:var(--color-primary-hover); }
.tmd-mm__feature-btn:hover .icon{ color:var(--color-primary-hover); }
.tmd-mm a.tmd-mm__feature-btn:focus-visible{ outline:2px solid var(--color-on-primary); outline-offset:2px; color:var(--color-primary); }
.tmd-mm__intro{ display:flex; flex-direction:column; gap:var(--space-4); }
.tmd-mm__viewall{ font-family:var(--mm-font-label); font-size:var(--mm-fz-nav); font-weight:var(--fw-semibold);
  letter-spacing:var(--mm-tracking-label); color:var(--color-primary); align-self:flex-start; min-height:var(--touch-min);
  display:inline-flex; align-items:center; gap:6px; }
.tmd-mm__viewall:hover{ text-decoration:underline; }
.tmd-mm__viewall:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; border-radius:var(--radius-sm); }
@media (prefers-reduced-motion: reduce){
  .tmd-mm__card{ transition:border-color .01ms, box-shadow .01ms; } .tmd-mm__card:hover{ transform:none; }
  .tmd-mm__thumb img{ transition:none; } .tmd-mm__card:hover .tmd-mm__thumb img, .tmd-mm__card:focus-visible .tmd-mm__thumb img{ transform:none; }
  .tmd-mm__thumb::before{ transition:none; }
  .tmd-mm__card:hover .tmd-mm__thumb::before, .tmd-mm__card:focus-visible .tmd-mm__thumb::before{ opacity:0; transform:translateY(-100%); }
}
@media (min-width:1025px){
  .tmd-mm__toggle{ display:none; }
  .tmd-mm{ position:static; }
}
@media (max-width:1024px){
  .header-inner{ flex-wrap:wrap; row-gap:0; align-items:flex-start; position:relative; }
  .header-search{ display:none; }
  .tmd-mm{ flex:1 1 auto; display:flex; flex-wrap:wrap; align-items:center; min-width:0; }
  .tmd-mm__bar{ flex:1 1 auto; min-width:0; order:0; }
  /* FIX mobil: cele 3 acțiuni (favorite+cont+COȘ cu badge) trebuie să încapă pe 360–412px.
     gap:0 + icon-btn 40px lat (=120px total) → coșul + badge-ul rămân complet vizibile; rezervarea
     din .tmd-mm__bar-inner = exact lățimea reală a actions (3×40 + un mic respiro). Touch: înălțimea
     icon-btn rămâne 44px (vertical), lățimea 40px = control secundar dens (design-system §6.bis.1). */
  .tmd-mm__bar-inner{ height:auto; min-height:var(--mm-bar-h); gap:var(--space-3); flex-wrap:wrap; row-gap:0;
    padding-right:calc(3 * 40px + var(--space-2)); }
  .header-actions{ position:absolute; top:0; right:0; height:var(--mm-bar-h); display:flex; align-items:center;
    gap:0; margin-left:0; flex:0 0 auto; z-index:calc(var(--z-sticky) + 1); }
  .header-actions .icon-btn{ width:40px; }
  .tmd-mm.is-open ~ .header-actions, .site-header .header-actions{ position:absolute; top:0; right:0; height:var(--mm-bar-h);
    display:flex; align-items:center; gap:0; margin-left:0; z-index:calc(var(--z-sticky) + 1); }
  .tmd-mm__logo{ order:0; flex:0 0 auto; }
  .tmd-mm__nav{ order:2; flex:1 1 100%; display:none; flex-direction:column; align-items:stretch;
    gap:var(--space-2); width:100%; padding:var(--space-3) 0; }
  .tmd-mm--mobile-accordion .tmd-mm__panel{ order:3; flex:1 1 100%; }
  .tmd-mm.is-open .tmd-mm__nav{ display:flex; flex-direction:column; align-items:stretch; width:100%; flex:1 1 100%; order:2; }
  .tmd-mm.is-open .tmd-mm__nav .tmd-mm__triggerwrap{ width:100%; }
  .tmd-mm.is-open .tmd-mm__nav .tmd-mm__navlink, .tmd-mm.is-open .tmd-mm__nav .tmd-mm__trigger{ width:100%; min-height:var(--touch-min); display:flex; align-items:center; }
  .tmd-mm__toggle{ display:inline-flex; align-items:center; justify-content:center; margin-left:0;
    width:var(--touch-min); height:var(--touch-min); background:transparent; border:0; cursor:pointer;
    color:var(--color-text-primary); border-radius:var(--radius-md); flex:0 0 auto; order:1; }
  .tmd-mm__toggle:hover{ background:var(--color-surface-alt); }
  .tmd-mm__toggle:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
  .tmd-mm__toggle .icon{ width:1.5em; height:1.5em; }
  .tmd-mm__toggle-close{ display:none; }
  .tmd-mm.is-open .tmd-mm__toggle-open{ display:none; }
  .tmd-mm.is-open .tmd-mm__toggle-close{ display:inline-flex; }
  .tmd-mm__navlink{ min-height:var(--touch-min); padding:0 var(--space-3); }
  .tmd-mm--mobile-accordion .tmd-mm__panel, .tmd-mm--mobile-accordion.is-open .tmd-mm__panel{ position:static; left:auto; right:auto; top:auto;
    transform:none; width:100%; max-width:100%; margin:0; box-shadow:none; border:0; border-top:1px solid var(--mm-border); opacity:1; visibility:visible; }
  .tmd-mm--mobile-accordion .tmd-mm__panel{ display:none; }
  .tmd-mm--mobile-accordion.is-open .tmd-mm__panel{ display:block; }
  .tmd-mm__panel-inner{ max-width:100%; width:100%; margin:0; padding:var(--space-4) 0; }
  .tmd-mm--images .tmd-mm__panel-inner{ grid-template-columns:1fr; gap:var(--space-4); }
  .tmd-mm__grid{ grid-template-columns:1fr; width:100%; margin:0; }
}

/* ============================================================================
   CORP PLP — componente specifice (pe tokeni D2). Card produs / card categorie /
   filtre / paginație / badge / paletar = REUTILIZATE din components-v1.html (validate PM).
   ============================================================================ */

/* ---- BREADCRUMB (VERBATIM din pdp-v5) ---- */
.breadcrumb{ padding:var(--space-5) 0 0; }
.breadcrumb ol{ list-style:none; display:flex; flex-wrap:wrap; gap:var(--space-2); padding:0; margin:0;
  font-family:var(--font-body); font-size:var(--fs-small); }
.breadcrumb a{ color:var(--color-primary); text-decoration:none; }
.breadcrumb a:hover{ text-decoration:underline; }
.breadcrumb .sep{ color:var(--color-text-secondary); }
.breadcrumb [aria-current="page"]{ color:var(--color-text-secondary); }

/* ---- ANTET CATEGORIE ---- */
.cat-hero{ padding:var(--space-6) 0 var(--space-5); }
.cat-hero .eyebrow{ font-family:var(--font-body); text-transform:uppercase; letter-spacing:var(--ls-eyebrow);
  font-size:var(--fs-eyebrow); font-weight:700; color:var(--color-primary); margin:0 0 var(--space-2); }
.cat-hero h1{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-display);
  line-height:var(--lh-tight); letter-spacing:var(--ls-heading); margin:0; color:var(--color-text-primary); }
.cat-hero .cat-lead{ color:var(--color-text-secondary); font-size:var(--fs-lead); line-height:var(--lh-body);
  max-width:70ch; margin:var(--space-4) 0 0; }
.cat-hero .cat-count-line{ display:inline-flex; align-items:center; gap:var(--space-2); margin:var(--space-4) 0 0;
  font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold); color:var(--color-text-secondary); }
.cat-hero .cat-count-line .num{ color:var(--color-text-primary); }

/* ========================================================================
   ZONĂ DE FILTRARE ORIZONTALĂ stil eMAG (R1 + R2 din page-section-standard.md §3.2).
   Categoriile = SELECȚIE (taburi text cu count), NU carduri. Bară de dropdown-uri.
   Chips filtre active. Toolbar cu sortare + comutator listă/grilă. FĂRĂ sidebar/scrollbar.
   ======================================================================== */

/* ---- (a) TABURI CATEGORII ca FILTRU (cele 7 oficiale; „Tehnici decorative" = activ) ---- */
.cat-tabs-section{ padding:var(--space-5) 0 var(--space-2); }
.cat-tabs{ display:flex; gap:var(--space-2); overflow-x:auto; padding-bottom:var(--space-2);
  scrollbar-width:thin; -webkit-overflow-scrolling:touch; }
.cat-tab{ flex:0 0 auto; display:inline-flex; align-items:center; gap:var(--space-2); min-height:var(--touch-min);
  padding:var(--space-2) var(--space-4); border:1px solid var(--color-border); border-radius:var(--radius-pill);
  background:var(--color-surface); color:var(--color-text-primary); text-decoration:none;
  font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold); white-space:nowrap;
  transition:background var(--transition), border-color var(--transition), color var(--transition); }
.cat-tab:hover{ border-color:var(--color-primary); color:var(--color-primary); }
.cat-tab:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.cat-tab .tab-count{ font-size:.72rem; font-weight:var(--fw-bold); color:var(--color-text-secondary);
  background:var(--color-surface-alt); border-radius:var(--radius-pill); padding:1px var(--space-2); }
.cat-tab[aria-current="page"]{ background:var(--color-primary); color:var(--color-on-primary); border-color:var(--color-primary); }
.cat-tab[aria-current="page"] .tab-count{ background:rgba(255,255,255,.22); color:var(--color-on-primary); }

/* ---- Categorii pe MOBIL: dropdown nativ în loc de taburi cu scroll (FIX fricțiune scroll orizontal).
   Breakpoint CONSECVENT cu butonul „Filtre" / colapsarea filtrelor: 1024px.
   DESKTOP (≥1024px): taburile rămân, select-ul ascuns. MOBIL (<1024px): invers. ---- */
.cat-select-mobile{ display:none; }
@media (max-width:1023px){
  .cat-tabs{ display:none; }
  .cat-select-mobile{ display:flex; align-items:center; gap:var(--space-3); }
}
.cat-select-label{ font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  color:var(--color-text-secondary); flex:0 0 auto; }
.cat-select{ flex:1 1 auto; min-height:var(--touch-min); border:1px solid var(--color-border); border-radius:var(--radius-md);
  background:var(--color-surface); font-family:var(--font-body); font-size:var(--fs-body); font-weight:var(--fw-semibold);
  color:var(--color-text-primary); padding:0 var(--space-7) 0 var(--space-4); cursor:pointer;
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235E7355' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right var(--space-4) center; background-size:18px; }
.cat-select:focus{ outline:2px solid var(--color-primary); outline-offset:1px; border-color:var(--color-primary); }

/* ---- (b) BARĂ DE FILTRE cu dropdown-uri orizontale ---- */
.filters-top{ padding:var(--space-3) 0 var(--space-2); }
.filters-bar{ display:flex; flex-wrap:wrap; gap:var(--space-3); align-items:center; }
.filter-dd{ position:relative; }
.filter-dd-btn{ display:inline-flex; align-items:center; gap:var(--space-2); min-height:var(--touch-min);
  padding:var(--space-2) var(--space-4); border:1px solid var(--color-border); border-radius:var(--radius-md);
  background:var(--color-surface); color:var(--color-text-primary); cursor:pointer;
  font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  transition:background var(--transition), border-color var(--transition); }
.filter-dd-btn:hover{ border-color:var(--color-primary); }
.filter-dd-btn:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.filter-dd-btn .chev{ width:1em; height:1em; transition:transform var(--transition); color:var(--color-text-secondary); }
.filter-dd-btn[aria-expanded="true"]{ border-color:var(--color-primary); color:var(--color-primary); }
.filter-dd-btn[aria-expanded="true"] .chev{ transform:rotate(180deg); }
.filter-dd-btn .dd-badge{ font-size:.7rem; font-weight:var(--fw-bold); color:var(--color-on-primary);
  background:var(--color-primary); border-radius:var(--radius-pill); padding:0 6px; min-width:18px; text-align:center; }
/* panoul dropdown */
.filter-dd-panel{ position:absolute; top:calc(100% + var(--space-2)); left:0; z-index:var(--z-dropdown,100);
  min-width:240px; max-width:320px; background:var(--color-surface); border:1px solid var(--color-border);
  border-radius:var(--radius-md); box-shadow:var(--shadow-card-hover); padding:var(--space-4);
  display:none; }
.filter-dd.is-open .filter-dd-panel{ display:block; }
.filter-dd-panel .dd-choice{ display:flex; align-items:center; gap:var(--space-3); min-height:var(--touch-min); cursor:pointer; }
.filter-dd-panel .dd-choice input{ width:18px; height:18px; accent-color:var(--color-primary); flex:0 0 auto; }
.filter-dd-panel .dd-choice .lbl{ font-size:var(--fs-small); color:var(--color-text-primary); }
.filter-dd-panel .dd-choice .cnt{ margin-left:auto; font-size:var(--fs-small); color:var(--color-text-secondary); }
.filter-dd-panel .dd-choice:focus-within{ outline:2px solid var(--color-primary); outline-offset:2px; border-radius:var(--radius-sm); }
/* grilă swatch nuanță în dropdown */
.dd-color-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(40px,1fr)); gap:var(--space-2); }
.dd-color-sw{ aspect-ratio:1/1; border-radius:var(--radius-swatch); box-shadow:var(--shadow-swatch);
  border:1px solid var(--color-border); cursor:pointer; position:relative; padding:0;
  transition:transform var(--tr-zoom); }
.dd-color-sw:hover, .dd-color-sw:focus-visible{ transform:scale(1.08); }
.dd-color-sw:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.dd-color-sw[aria-pressed="true"]{ outline:3px solid var(--color-selected-ring); outline-offset:2px; }
.dd-color-sw .tick{ position:absolute; right:2px; bottom:2px; width:14px; height:14px; color:#fff;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.55)); display:none; }
.dd-color-sw[aria-pressed="true"] .tick{ display:block; }
/* range preț în dropdown */
.dd-price{ display:flex; gap:var(--space-3); align-items:flex-end; }
.dd-price .field{ flex:1; }
.dd-price label{ display:block; font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  color:var(--color-text-secondary); margin-bottom:var(--space-1); }
.dd-price input{ width:100%; min-height:var(--touch-min); border:1px solid var(--color-border);
  border-radius:var(--radius-sm); padding:0 var(--space-3); font-family:var(--font-body); font-size:var(--fs-body);
  color:var(--color-text-primary); background:var(--color-surface); }
.dd-price input:focus{ outline:2px solid var(--color-primary); outline-offset:1px; border-color:var(--color-primary); }
.dd-apply{ margin-top:var(--space-3); }
/* toggle „La ofertă" = chip-buton on/off (fără panou) */
.filter-toggle{ display:inline-flex; align-items:center; gap:var(--space-2); min-height:var(--touch-min);
  padding:var(--space-2) var(--space-4); border:1px solid var(--color-border); border-radius:var(--radius-md);
  background:var(--color-surface); color:var(--color-text-primary); cursor:pointer;
  font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  transition:background var(--transition), border-color var(--transition), color var(--transition); }
.filter-toggle:hover{ border-color:var(--color-primary); }
.filter-toggle:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.filter-toggle[aria-pressed="true"]{ background:var(--color-danger); border-color:var(--color-danger); color:var(--color-on-primary); }

/* ---- (b.2) CHIPS FILTRE ACTIVE + „Șterge tot" ---- */
.active-row{ display:flex; flex-wrap:wrap; align-items:center; gap:var(--space-2); margin-top:var(--space-3); }
.active-row .ar-label{ font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  color:var(--color-text-secondary); }
.chip{ display:inline-flex; align-items:center; gap:var(--space-2); background:var(--color-surface-alt);
  color:var(--color-text-primary); border:1px solid var(--color-border); border-radius:var(--radius-pill);
  padding:var(--space-1) var(--space-3); font-family:var(--font-body); font-size:var(--fs-small); }
.chip button{ width:24px; height:24px; min-width:24px; border:0; border-radius:var(--radius-pill);
  background:transparent; color:var(--color-text-secondary); cursor:pointer; line-height:1;
  display:inline-flex; align-items:center; justify-content:center; padding:0; }
.chip button .icon{ width:14px; height:14px; }
.chip button:hover{ background:var(--color-border); color:var(--color-text-primary); }
.chip button:focus-visible{ outline:2px solid var(--color-primary); outline-offset:1px; }
.clear-all{ background:transparent; border:0; color:var(--color-primary); cursor:pointer;
  font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-small);
  display:inline-flex; align-items:center; gap:4px; min-height:var(--touch-min); padding:var(--space-2); }
.clear-all:hover{ text-decoration:underline; }
.clear-all:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }

/* ---- BUTON „Filtre" (doar mobil) + overlay drawer ---- */
.filters-mobile-btn{ display:none; }
@media (max-width:1023px){
  .filters-bar{ display:none; }
  .filters-mobile-btn{ display:inline-flex; }
  .filters-drawer{ position:fixed; top:0; left:0; bottom:0; width:min(90vw,360px); overflow-y:auto;
    background:var(--color-surface); z-index:var(--z-drawer); padding:var(--space-5);
    box-shadow:6px 0 24px rgba(60,64,52,.18); transform:translateX(-105%); transition:transform var(--tr-slide); }
  .filters-drawer.is-open{ transform:translateX(0); }
  .filters-drawer-head{ display:flex; align-items:center; justify-content:space-between; gap:var(--space-3); margin-bottom:var(--space-4); }
  .filters-drawer-head h2{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3); margin:0; }
  .filters-close{ width:var(--touch-min); height:var(--touch-min); border:0; background:transparent;
    color:var(--color-text-primary); border-radius:var(--radius-md); cursor:pointer; display:inline-flex;
    align-items:center; justify-content:center; }
  .filters-close:hover{ background:var(--color-surface-alt); }
  .filters-close:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
  .filters-close .icon{ width:1.4em; height:1.4em; }
  /* în drawer, fiecare grup de filtre = fieldset stivuit (nu dropdown) */
  .drawer-group{ border:0; border-top:1px solid var(--color-border); padding:var(--space-4) 0 0; margin:0 0 var(--space-4); }
  .drawer-group legend{ font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-small);
    color:var(--color-text-primary); padding:0; margin-bottom:var(--space-2); }
}
@media (min-width:1024px){
  .filters-drawer{ display:none; }
}
.drawer-overlay{ position:fixed; inset:0; background:var(--color-overlay); z-index:var(--z-overlay);
  opacity:0; visibility:hidden; transition:opacity var(--transition), visibility 0s linear var(--transition); }
.drawer-overlay.is-open{ opacity:1; visibility:visible; transition:opacity var(--transition); }
@media (prefers-reduced-motion: reduce){ .filters-drawer{ transition:none; } }

/* ---- (c) TOOLBAR: count + sortare + comutator listă/grilă ---- */
.toolbar{ display:flex; align-items:center; gap:var(--space-4); flex-wrap:wrap; justify-content:space-between;
  padding:var(--space-3) var(--space-4); background:var(--color-surface); border:1px solid var(--color-border);
  border-radius:var(--radius-md); margin:var(--space-4) 0 var(--space-5); }
.toolbar .result-count{ font-family:var(--font-body); font-size:var(--fs-small); color:var(--color-text-secondary); }
.toolbar .result-count b{ color:var(--color-text-primary); font-weight:var(--fw-semibold); }
.toolbar-right{ display:flex; align-items:center; gap:var(--space-4); flex-wrap:wrap; }
.sort-field{ display:inline-flex; align-items:center; gap:var(--space-2); }
.sort-field label{ font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  color:var(--color-text-secondary); }
.sort-field select{ min-height:var(--touch-min); border:1px solid var(--color-border); border-radius:var(--radius-sm);
  background:var(--color-surface); font-family:var(--font-body); font-size:var(--fs-small); color:var(--color-text-primary);
  padding:0 var(--space-7) 0 var(--space-3); cursor:pointer;
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235E6357' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right var(--space-3) center; background-size:16px; }
.sort-field select:focus{ outline:2px solid var(--color-primary); outline-offset:1px; border-color:var(--color-primary); }
/* comutator listă / grilă (2 moduri) */
.view-toggle{ display:inline-flex; align-items:center; gap:var(--space-1); border:1px solid var(--color-border);
  border-radius:var(--radius-md); padding:2px; }
.view-toggle button{ width:44px; height:44px; border:0; background:transparent; color:var(--color-text-secondary);
  border-radius:var(--radius-sm); cursor:pointer; display:inline-flex; align-items:center; justify-content:center; }
.view-toggle button .icon{ width:1.25em; height:1.25em; }
.view-toggle button[aria-pressed="true"]{ background:var(--color-primary); color:var(--color-on-primary); }
.view-toggle button:hover:not([aria-pressed="true"]){ background:var(--color-surface-alt); color:var(--color-text-primary); }
.view-toggle button:focus-visible{ outline:2px solid var(--color-primary); outline-offset:1px; }

/* ---- MOD LISTĂ (rând-detaliat) — comutabil din toolbar (.cards.is-list) ---- */
.plp-main{ padding:0 0 var(--space-9); }
.cards.is-list{ display:flex; flex-direction:column; gap:var(--space-4); }
.cards.is-list .product-card{ flex-direction:row; align-items:stretch; }
.cards.is-list .pmedia{ flex:0 0 220px; aspect-ratio:4/3; }
.cards.is-list .pbody{ text-align:left; align-items:flex-start; flex:1; justify-content:center;
  padding:var(--space-4) var(--space-5); }
.cards.is-list .pswatches{ justify-content:flex-start; }
.cards.is-list .price{ justify-content:flex-start; }
.cards.is-list .list-desc{ display:block; font-size:var(--fs-small); color:var(--color-text-secondary);
  line-height:var(--lh-body); margin:var(--space-1) 0 var(--space-2); max-width:60ch; }
.cards.is-list .cart-cta{ width:auto; min-width:200px; margin-top:var(--space-2); }
/* descrierea-listă e ascunsă în modul grilă (apare DOAR pe listă) */
.list-desc{ display:none; }
@media (max-width:600px){
  .cards.is-list .product-card{ flex-direction:column; }
  .cards.is-list .pmedia{ flex:0 0 auto; aspect-ratio:5/4; }
  .cards.is-list .pbody{ text-align:center; align-items:center; }
  .cards.is-list .pswatches, .cards.is-list .price{ justify-content:center; }
  .cards.is-list .cart-cta{ width:100%; }
}

/* ========================================================================
   SECȚIUNI STANDARD §3.2 (după paginație): rails recomandări, SEO/EEAT/GEO/CITE,
   FAQ categorie, newsletter, blog legat. Reutilizează arhetipuri design-system.
   ======================================================================== */

/* ---- titlu de secțiune comun ---- */
.sec{ padding:var(--space-8) 0; }
.sec--tint{ background:var(--color-tint); }
.sec--surface{ background:var(--color-surface); }
.sec-head{ margin:0 0 var(--space-6); }
.sec-head .eyebrow{ font-family:var(--font-body); text-transform:uppercase; letter-spacing:var(--ls-eyebrow);
  font-size:var(--fs-eyebrow); font-weight:700; color:var(--color-primary); margin:0 0 var(--space-2); }
.sec-head h2{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h2);
  line-height:var(--lh-heading); letter-spacing:var(--ls-heading); margin:0; color:var(--color-text-primary); }
.sec-head.center{ text-align:center; max-width:64ch; margin-left:auto; margin-right:auto; }

/* ---- RAIL produse (vizitate recent / recomandări) = carduri mici pe rând orizontal ---- */
.rail{ display:grid; grid-auto-flow:column; grid-auto-columns:minmax(200px,1fr); gap:var(--space-4);
  overflow-x:auto; padding-bottom:var(--space-3); scrollbar-width:thin; }
@media (min-width:1024px){ .rail{ grid-auto-flow:row; grid-template-columns:repeat(5,1fr); grid-auto-columns:auto; overflow:visible; } }
.mini-card{ background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-md);
  box-shadow:var(--shadow-card); overflow:hidden; text-decoration:none; color:inherit; display:flex; flex-direction:column;
  transition:box-shadow var(--transition), transform var(--transition); }
.mini-card:hover{ box-shadow:var(--shadow-card-hover); transform:translateY(-3px); }
.mini-card:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.mini-card .mini-media{ aspect-ratio:1/1; overflow:hidden; }
.mini-card .mini-media img{ width:100%; height:100%; object-fit:cover; display:block;
  transform:scale(1); transition:transform var(--tr-zoom); }
.mini-card:hover .mini-media img{ transform:scale(1.05); }
.mini-card .mini-body{ padding:var(--space-3); display:flex; flex-direction:column; gap:2px; }
.mini-card .mini-brand{ font-family:var(--font-body); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--color-text-secondary); }
.mini-card .mini-name{ font-family:var(--font-display); font-size:1rem; font-weight:var(--fw-regular);
  line-height:1.25; color:var(--color-text-primary); }
.mini-card .mini-price{ font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-bold);
  color:var(--color-text-primary); margin-top:var(--space-1); }
.mini-card .mini-price .from{ font-weight:var(--fw-regular); color:var(--color-text-secondary); }
@media (prefers-reduced-motion: reduce){ .mini-card:hover{ transform:none; } .mini-card:hover .mini-media img{ transform:none; } }

/* ---- BLOC SEO (text descriptiv categorie) ---- */
.seo-block{ max-width:none; }
.seo-block p{ font-size:var(--fs-body); line-height:var(--lh-body); color:var(--color-text-primary); margin:0 0 var(--space-4); }
.seo-block p:last-child{ margin-bottom:0; }
.seo-block h3{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3);
  margin:var(--space-5) 0 var(--space-2); color:var(--color-text-primary); }

/* ---- EEAT + GEO (2 coloane, model pdp-v5) ---- */
.eeat-grid{ display:grid; grid-template-columns:1fr; gap:var(--space-6); }
@media (min-width:900px){ .eeat-grid{ grid-template-columns:1.1fr .9fr; } }
.expert-card, .geo-card{ background:var(--color-surface); border:1px solid var(--color-border);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-card); padding:var(--space-6); }
.expert-byline{ display:flex; align-items:center; gap:var(--space-3); margin-bottom:var(--space-4); }
.ex-ava{ width:44px; height:44px; border-radius:var(--radius-pill); background:var(--color-tint);
  color:var(--color-primary); display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; }
.ex-ava .icon{ width:1.4em; height:1.4em; }
.ex-meta{ display:flex; flex-direction:column; }
.ex-meta b{ font-family:var(--font-body); font-weight:var(--fw-semibold); color:var(--color-text-primary); }
.ex-meta span{ font-size:var(--fs-small); color:var(--color-text-secondary); }
.expert-card h3, .geo-card h3{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3);
  margin:0 0 var(--space-3); color:var(--color-text-primary); }
.expert-card p{ font-size:var(--fs-body); line-height:var(--lh-body); color:var(--color-text-primary); margin:0; }
.geo-card dl{ display:grid; grid-template-columns:auto 1fr; gap:var(--space-2) var(--space-4); margin:0 0 var(--space-4); }
.geo-card dt{ font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-small); color:var(--color-text-secondary); }
.geo-card dd{ margin:0; font-size:var(--fs-small); color:var(--color-text-primary); }
.geo-card .trust-row{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:var(--space-2); }
.geo-card .trust-row li{ display:flex; align-items:center; gap:var(--space-2); font-size:var(--fs-small); color:var(--color-text-primary); }
.geo-card .trust-row .icon{ width:18px; height:18px; color:var(--color-success); flex:0 0 auto; }
.geo-card .bb-note{ margin-top:var(--space-3); font-size:.78rem; color:var(--color-text-secondary); }

/* ---- BLOC CITE (citări de autoritate — SCHELET, conținut real = placeholder marcat) ---- */
.cite-block{ background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card); padding:var(--space-6); }
.cite-list{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:1fr; gap:var(--space-3); }
@media (min-width:768px){ .cite-list{ grid-template-columns:repeat(3,1fr); } }
.cite-item{ display:flex; gap:var(--space-3); align-items:flex-start; padding:var(--space-4);
  border:1px dashed var(--color-border); border-radius:var(--radius-md); background:var(--color-tint); }
.cite-item .cite-ico{ width:36px; height:36px; border-radius:var(--radius-md); background:var(--color-surface);
  color:var(--color-text-secondary); display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto;
  border:1px solid var(--color-border); }
.cite-item .cite-ico .icon{ width:1.2em; height:1.2em; }
.cite-item .cite-body b{ display:block; font-family:var(--font-body); font-weight:var(--fw-semibold);
  font-size:var(--fs-small); color:var(--color-text-primary); }
.cite-item .cite-body .cite-todo{ font-size:.78rem; color:var(--color-warning); font-weight:var(--fw-semibold); }

/* ---- FAQ (acordeon single-open) ---- */
.faq{ border:1px solid var(--color-border); border-radius:var(--radius-md); overflow:hidden; background:var(--color-surface); }
.faq-item + .faq-item{ border-top:1px solid var(--color-border); }
.faq-head{ width:100%; display:flex; align-items:center; gap:var(--space-3); justify-content:space-between;
  background:transparent; border:0; cursor:pointer; text-align:left;
  font-family:var(--font-display); font-size:var(--fs-h3); font-weight:var(--fw-regular);
  color:var(--color-text-primary); padding:var(--space-4) var(--space-5); min-height:var(--touch-min); }
.faq-head:hover{ background:var(--color-surface-alt); }
.faq-head:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
.faq-head .chev{ transition:transform var(--transition); color:var(--color-primary); flex:0 0 auto; }
.faq-head[aria-expanded="true"] .chev{ transform:rotate(90deg); }
.faq-panel{ padding:0 var(--space-5) var(--space-5); color:var(--color-text-secondary); line-height:var(--lh-body); }
.faq-panel[hidden]{ display:none; }
@media (prefers-reduced-motion: reduce){ .faq-head .chev{ transition:none; } }

/* ---- BLOG cards „frosted" (din design-system §6.bis.10) ---- */
.blog-cards{ display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:var(--space-5); }
.blog-card{ position:relative; display:block; text-decoration:none; color:inherit; overflow:hidden;
  border-radius:var(--radius-lg); box-shadow:var(--shadow-card); aspect-ratio:4/3;
  transition:box-shadow var(--transition), transform var(--transition); }
.blog-card:hover, .blog-card:focus-visible{ box-shadow:var(--shadow-card-hover); transform:translateY(-4px); outline:none; }
.blog-card:focus-visible{ outline:3px solid var(--color-primary); outline-offset:3px; }
.blog-card .bc-media{ position:absolute; inset:0; overflow:hidden; }
.blog-card .bc-media img{ width:100%; height:100%; object-fit:cover; display:block;
  transform:scale(1); transition:transform var(--tr-zoom); }
.blog-card:hover .bc-media img{ transform:scale(1.06); }
.blog-card .bc-scrim{ position:absolute; left:0; right:0; bottom:0; z-index:1; padding:var(--space-5);
  background:linear-gradient(to top, rgba(51,56,47,.92) 0%, rgba(51,56,47,.82) 55%, rgba(51,56,47,0) 100%); }
.blog-card .bc-tag{ display:inline-flex; align-items:center; gap:4px; font-family:var(--font-body); font-size:.72rem;
  font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--color-text-primary);
  background:var(--color-accent); border-radius:var(--radius-pill); padding:2px var(--space-3); margin-bottom:var(--space-2); }
.blog-card .bc-tag .icon{ width:1em; height:1em; }
.blog-card h3{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3);
  line-height:var(--lh-heading); margin:0 0 var(--space-1); color:var(--color-on-primary); }
.blog-card .bc-meta{ font-size:var(--fs-small); color:rgba(246,248,242,.82); }
@media (prefers-reduced-motion: reduce){ .blog-card:hover{ transform:none; } .blog-card:hover .bc-media img{ transform:none; } }

/* ---- NEWSLETTER (panou editorial salvie, global) ---- */
.newsletter{ padding:var(--space-8) 0; }
.nl-inner{ background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-active) 100%);
  color:var(--color-on-primary); border-radius:var(--radius-lg); padding:var(--space-7);
  display:grid; grid-template-columns:1fr; gap:var(--space-5); align-items:center; }
@media (min-width:768px){ .nl-inner{ grid-template-columns:1.2fr .8fr; } }
.nl-inner .nl-eyebrow{ font-family:var(--font-body); text-transform:uppercase; letter-spacing:var(--ls-eyebrow);
  font-size:var(--fs-eyebrow); font-weight:700; color:var(--color-on-primary); margin:0 0 var(--space-2); }
.nl-inner h2{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h2);
  line-height:var(--lh-heading); margin:0 0 var(--space-2); color:#fff; }
.nl-inner p{ margin:0; font-size:var(--fs-body); line-height:var(--lh-body); color:#ECEFE6; }
.nl-form{ display:flex; gap:var(--space-2); flex-wrap:wrap; }
.nl-form input{ flex:1 1 200px; min-height:var(--touch-min); border:1px solid rgba(255,255,255,.4);
  border-radius:var(--radius-md); padding:0 var(--space-4); font-family:var(--font-body); font-size:var(--fs-body);
  background:rgba(255,255,255,.14); color:#fff; }
.nl-form input::placeholder{ color:rgba(246,248,242,.78); }
.nl-form input:focus{ outline:2px solid var(--color-accent); outline-offset:1px; background:rgba(255,255,255,.2); }

/* ---- GRILĂ CARDURI PRODUS (din components-v1 §2) ---- */
.cards{ display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:var(--space-5); }
@media (min-width:1140px){ .cards{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1440px){ .cards{ grid-template-columns:repeat(4,1fr); } }
/* densitate compactă: forțează încă o coloană pe ecrane mari + gap mai mic */
.cards.is-compact{ gap:var(--space-4); }
@media (min-width:1140px){ .cards.is-compact{ grid-template-columns:repeat(4,1fr); } }
@media (min-width:1440px){ .cards.is-compact{ grid-template-columns:repeat(5,1fr); } }

.product-card{
  background:var(--color-surface); border-radius:var(--radius-lg); box-shadow:var(--shadow-card);
  display:flex; flex-direction:column; border:1px solid var(--color-border); overflow:hidden;
  transition:box-shadow var(--transition), transform var(--transition);
}
.product-card:hover{ box-shadow:var(--shadow-card-hover); transform:translateY(-4px); }
.product-card .pmedia{
  --card-curve-h:135%;
  aspect-ratio:5/4; position:relative;
  display:flex; align-items:flex-end; padding:var(--space-3);
}
.product-card .pmedia .pmedia-frame{
  position:absolute; inset:0; z-index:0; overflow:hidden;
  -webkit-mask:var(--card-curve); mask:var(--card-curve);
}
.product-card .pmedia .pmedia-bg{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
  transform:scale(1); transform-origin:center; will-change:transform;
  transition:transform var(--tr-zoom);
}
.product-card:hover .pmedia-bg, .product-card:focus-within .pmedia-bg{ transform:scale(1.06); }
.product-card.oos .pmedia-bg{ opacity:.72; }
/* buton favorite ♡ — colț dreapta-sus, frate al ramei (NU în mască) → nu e tăiat de curbă */
.fav-btn{ position:absolute; top:var(--space-3); right:var(--space-3); z-index:3;
  width:44px; height:44px; border:0; border-radius:var(--radius-pill);
  background:rgba(255,255,255,.9); color:var(--color-text-secondary); cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; box-shadow:var(--shadow-sm);
  transition:background var(--transition), color var(--transition), transform var(--transition); }
.fav-btn .icon{ width:1.1em; height:1.1em; }
.fav-btn:hover{ background:#fff; color:var(--color-danger); transform:scale(1.08); }
.fav-btn:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.fav-btn[aria-pressed="true"]{ color:var(--color-danger); }
.fav-btn[aria-pressed="true"] .icon{ fill:var(--color-danger); stroke:var(--color-danger); }
@media (prefers-reduced-motion: reduce){ .fav-btn:hover{ transform:none; } }
.product-card .pbody{ padding:var(--space-3) var(--space-4) var(--space-4); display:flex; flex-direction:column; flex:1;
  text-align:center; align-items:center; }
.product-card .eyebrow{ font-family:var(--font-body); font-size:.72rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--color-text-secondary); margin-top:0; }
.product-card .pname{ font-family:var(--font-display); font-size:1.12rem; font-weight:var(--fw-regular);
  line-height:1.3; margin:var(--space-1) 0 0; color:var(--color-text-primary); }
/* mini-rând nuanțe disponibile (swatch-uri informative sub titlu) */
.pswatches{ display:inline-flex; align-items:center; gap:var(--space-1); margin:var(--space-2) 0 0; flex-wrap:wrap; justify-content:center; }
.pswatches .ps-sw{ width:16px; height:16px; border-radius:var(--radius-swatch); box-shadow:var(--shadow-swatch);
  border:1px solid var(--color-border); }
.pswatches .ps-more{ font-family:var(--font-body); font-size:.72rem; color:var(--color-text-secondary); font-weight:var(--fw-semibold); }
.product-card .price{ font-family:var(--font-body); margin:var(--space-3) 0; display:flex; align-items:baseline; gap:var(--space-1) var(--space-2); flex-wrap:wrap; justify-content:center; }
.product-card .price .from{ font-size:var(--fs-small); font-weight:var(--fw-regular); color:var(--color-text-secondary); }
.product-card .price .now{ font-size:1.15rem; font-weight:var(--fw-bold); color:var(--color-text-primary); }
.product-card .price .unit{ font-size:var(--fs-small); color:var(--color-text-secondary); }
.product-card .price .old{ font-size:var(--fs-small); color:var(--color-text-secondary); text-decoration:line-through; }
.product-card .price.ask{ font-size:1.02rem; font-weight:var(--fw-semibold); color:var(--color-text-secondary); }
.product-card .price.ask .now{ font-size:1.02rem; font-weight:var(--fw-semibold); color:var(--color-text-secondary); }
.product-card .cart-cta{ margin-top:auto; width:100%; }
/* Pastilă-badge plină (text + culoare, WCAG 1.4.1) */
.pbadge{ position:absolute; top:var(--space-3); left:var(--space-3); z-index:2;
  font-family:var(--font-body); font-size:var(--fs-eyebrow); font-weight:700; letter-spacing:.04em;
  border-radius:var(--radius-pill); padding:3px var(--space-3); display:inline-flex; align-items:center; gap:4px; }
.pbadge-new{ background:var(--color-primary); color:var(--color-on-primary); }
.pbadge-best{ background:var(--color-text-primary); color:var(--color-on-primary); }
.pbadge-sale{ background:var(--color-danger); color:var(--color-on-primary); }
.pbadge-oos{ background:var(--color-surface-alt); color:var(--color-text-secondary); border:1px solid var(--color-border); }
.pbadge-ask{ background:var(--color-info-soft); color:var(--color-info); border:1px solid var(--color-info); }

/* ---- PAGINAȚIE (din components-v1 §8) ---- */
.plp-pagination{ margin-top:var(--space-7); display:flex; justify-content:center; }
.pagination{ display:flex; gap:var(--space-2); flex-wrap:wrap; align-items:center; }
.pagination a, .pagination span{ min-width:40px; min-height:40px; display:inline-flex; align-items:center;
  justify-content:center; border-radius:var(--radius-md); border:1px solid var(--color-border);
  font-family:var(--font-body); font-size:var(--fs-body); color:var(--color-text-primary); text-decoration:none;
  background:var(--color-surface); padding:0 var(--space-3); }
.pagination a:hover{ background:var(--color-surface-alt); }
.pagination a:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.pagination [aria-current="page"]{ background:var(--color-primary); color:var(--color-on-primary); border-color:var(--color-primary); }
.pagination .disabled{ opacity:.4; pointer-events:none; }
.pagination .gap{ border:0; background:transparent; min-width:auto; padding:0 var(--space-1); color:var(--color-text-secondary); }
.pagination .icon{ width:1.1em; height:1.1em; }

/* ============ BARĂ SHARE (GLOBAL — VERBATIM din pdp-v5.html) ============ */
.share-bar{ padding:var(--space-6) 0; background:var(--color-tint); border-top:1px solid var(--color-border); border-bottom:1px solid var(--color-border); }
.share-inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:var(--space-4) var(--space-5); }
.share-label{ display:inline-flex; align-items:center; gap:var(--space-2); margin:0;
  font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-body); color:var(--color-text-primary); }
.share-label .icon{ width:1.2em; height:1.2em; color:var(--color-primary); flex:0 0 auto; }
.share-list{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:var(--space-2); }
.share-list a{ width:var(--touch-min); height:var(--touch-min); display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--color-border); border-radius:var(--radius-md); background:var(--color-surface); color:var(--color-text-primary);
  transition:background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition); }
.share-list a:hover{ background:var(--color-primary); border-color:var(--color-primary); color:var(--color-on-primary); transform:translateY(-2px); }
.share-list a:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
.share-list .icon{ width:20px; height:20px; }
@media (prefers-reduced-motion: reduce){ .share-list a:hover{ transform:none; } }

/* ============ FOOTER (GLOBAL — VERBATIM din pdp-v5.html) ============ */
.site-footer{ background:#2B2F27; color:#D6DACF; }
.footer-cols{ display:grid; grid-template-columns:1fr; gap:var(--space-6) var(--space-5); padding:var(--space-9) 0 var(--space-7); }
@media (min-width:480px){ .footer-cols{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .footer-cols{ grid-template-columns:1.4fr repeat(4,1fr); } }
.footer-cols h2{ font-family:var(--font-body); font-size:var(--fs-eyebrow); text-transform:uppercase;
  letter-spacing:.1em; color:var(--color-accent); margin:0 0 var(--space-4); font-weight:700; }
.footer-cols ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:var(--space-1); }
.footer-cols a{ color:#D6DACF; text-decoration:none; font-size:var(--fs-small); display:inline-flex; align-items:center; }
.footer-cols a:hover{ color:#fff; text-decoration:underline; }
@media (max-width:767px){ .footer-cols li a{ min-height:var(--touch-min); } }
.footer-brand{ display:flex; flex-direction:column; gap:var(--space-3); }
.footer-logo{ display:inline-flex; align-items:center; width:fit-content; text-decoration:none; }
.footer-logo .logo-mark{ font-family:var(--font-display); font-size:1.6rem; color:#fff; line-height:1; }
.footer-logo .logo-mark b{ color:var(--color-accent); font-weight:var(--fw-regular); }
.footer-pitch{ margin:0; font-size:var(--fs-small); line-height:1.55; color:#C6CBBC; max-width:34ch; }
.footer-pitch strong{ color:#E9ECE3; font-weight:600; }
.footer-cols .footer-brand .footer-social{ list-style:none; margin:var(--space-1) 0 0; padding:0; display:flex; flex-direction:row; flex-wrap:wrap; gap:var(--space-2); }
.footer-social a{ width:var(--touch-min); height:var(--touch-min); display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(255,255,255,.18); border-radius:var(--radius-md); color:#D6DACF;
  transition:background var(--transition), color var(--transition), border-color var(--transition); }
.footer-social a:hover{ background:var(--color-accent); border-color:var(--color-accent); color:#2B2F27; }
.footer-social .icon{ width:20px; height:20px; }
.footer-trust{ border-top:1px solid rgba(255,255,255,.12); }
.footer-trust-inner{ display:flex; flex-wrap:wrap; gap:var(--space-4) var(--space-6); align-items:center; justify-content:space-between; padding:var(--space-4) 0; }
.trust-auth{ margin:0; font-size:var(--fs-small); color:#C6CBBC; }
.trust-auth .trust-label{ color:#9DA294; }
.trust-auth strong{ color:#E9ECE3; font-weight:600; }
.trust-signals{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:var(--space-4); }
.trust-signals li{ display:inline-flex; align-items:center; gap:var(--space-2); font-size:var(--fs-small); color:#C6CBBC; }
.trust-signals .icon{ width:18px; height:18px; color:var(--color-accent); flex:0 0 auto; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding:var(--space-5) 0; display:flex; flex-wrap:wrap;
  gap:var(--space-4); justify-content:space-between; align-items:flex-start; font-size:var(--fs-small); color:#AEB3A6; }
.footer-org{ min-width:0; }
.footer-org .org-name{ margin:0 0 var(--space-1); color:#E9ECE3; font-size:var(--fs-body); }
.footer-org .org-data{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:2px; color:#C6CBBC; }
.footer-org a{ color:#D6DACF; text-decoration:none; }
.footer-org a:hover{ color:#fff; text-decoration:underline; }
.footer-pay{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:var(--space-2); align-items:center; }
.pay-card{ display:inline-flex; align-items:center; justify-content:center; gap:3px; width:46px; height:30px;
  background:#fff; border-radius:var(--radius-sm); color:#1A1D17; font-size:.62rem; font-weight:800; letter-spacing:.04em;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08); }
.pay-visa{ color:#1A1F71; font-style:italic; font-size:.72rem; }
.pay-mc i, .pay-maestro i{ width:15px; height:15px; border-radius:50%; display:block; margin:0 -4px; }
.pay-mc i:first-child{ background:#EB001B; }
.pay-mc i:last-child{ background:#F79E1B; mix-blend-mode:multiply; }
.pay-maestro i:first-child{ background:#0099DF; }
.pay-maestro i:last-child{ background:#ED0006; mix-blend-mode:multiply; }
.footer-compliance{ border-top:1px solid rgba(255,255,255,.12); }
.footer-compliance-inner{ display:flex; flex-wrap:wrap; align-items:center; gap:var(--space-4); padding:var(--space-5) 0; }
.comp-box{ display:inline-flex; align-items:center; justify-content:center; flex:0 0 auto; padding:var(--space-2);
  text-decoration:none; border-radius:var(--radius-md); transition:background var(--transition); }
.comp-box:hover{ background:rgba(255,255,255,.08); }
.comp-img{ display:inline-flex; align-items:center; justify-content:center; max-height:50px; height:auto; width:auto; max-width:100%; object-fit:contain;
  min-height:34px; padding:0 var(--space-3); background:rgba(255,255,255,.05); border:1px dashed rgba(255,255,255,.28);
  border-radius:var(--radius-sm); font-size:var(--fs-small); font-weight:700; color:#E9ECE3; text-align:center; white-space:nowrap; }
.footer-credit{ border-top:1px solid rgba(255,255,255,.12); padding:var(--space-4) 0; display:flex; flex-wrap:wrap;
  gap:var(--space-3); justify-content:space-between; align-items:center; font-size:.72rem; color:#9DA294; }
.dev-credit a{ color:#C6CBBC; text-decoration:none; }
.dev-credit a:hover{ color:#fff; text-decoration:underline; }
.dev-logo{ display:inline-block; padding:2px 8px; border:1px dashed rgba(255,255,255,.28); border-radius:var(--radius-sm); }
.site-footer a:focus-visible, .comp-box:focus-visible{ outline:2px solid var(--color-accent); outline-offset:2px; border-radius:var(--radius-sm); }
@media (max-width:767px){
  .footer-trust-inner{ flex-direction:column; align-items:flex-start; }
  .footer-bottom{ justify-content:center; text-align:center; }
  .footer-org{ flex:1 1 100%; text-align:center; } .footer-org .org-data{ align-items:center; }
  .footer-pay{ justify-content:center; flex:1 1 100%; }
  .footer-social{ justify-content:center; }
  .footer-credit{ flex-direction:column; text-align:center; gap:var(--space-2); }
}
