/* =========================================================================
   adcolor.ro v2 — PDP / VARIANTA 5 „ATIPIC PE ETAJE" (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) = REUTILIZATE VERBATIM din home-v1.html
   (PM: „header și footer sunt globale"). Corpul PDP urmează STRUCTURA EXACTĂ cerută de PM în
   pdp-layout-variants.md §„V5 — varianta ATIPICĂ cerută de PM" + sistemele comune §1–§4.

   STRUCTURA V5 (redată întocmai, NU reinterpretată):
     Breadcrumb
     SECȚIUNEA 1 — 2 col 50/50 : galerie (stânga) | etichetă+H1+★+descriere scurtă(≤100 cuv.)+S1 preț+microinfo (dreapta)
     SECȚIUNEA 2 — FULL-WIDTH  : PALETAR (selecție de comandă) cu căutare + game + grilă densă + „Vezi toate" + „Mostră"
     SECȚIUNEA 3 — 2 col 40/60 : calculator + opționale/accesorii (stânga 40) | ambalaj+stepper+coș+♡+calc-result (dreapta 60)
     SECȚIUNEA 4 — 2 col 60/40 : DETALII produs/specs/aplicare/recenzii (stânga 60) | poză portret lucrare/reclamă (dreapta 40)
     Completează proiectul → Galerie proiecte → Produse similare → FAQ → Newsletter → bloc SEO/EEAT/GEO → SHARE (global)

   FEZABILITATE (pdp-woo-feasibility.md §2 varianta b): paletarul (Secțiunea 2 full-width) + zona de
   cumpărare (Secțiunea 3) sunt înfășurate de UN SINGUR <form class="pdp-buy"> întins vizual pe benzi.
   Aici e doar machetă, dar respectăm principiul în STRUCTURĂ: un form, mai multe benzi vizuale.
   Calculatorul (Secțiunea 3 stânga) și add-to-cart (Secțiunea 3 dreapta) sunt coloane diferite →
   stare PARTAJATĂ JS între ele (un singur IIFE care le leagă). Vezi blocul JS NOU (PDP V5) la final.

   Produs demo REAL: Caparol EasyMatt (products.json id 6099, type variable, Cantitate 9L=257 / 15L=422 lei,
   acoperire „cca 8 m²/L"). Randament 8 m²/L = PLACEHOLDER [NEEDS-PM].

   FIX-URI obligatorii față de v1: (1) panoul mega din header pornește ÎNCHIS (fără `is-open` pe .tmd-mm);
   (2) logica calculatorului corectă (combinația de galeți întregi cu COSTUL TOTAL minim + preț total corect).

   Stare livrabil: CONSTRUIT, NEconfirmat vizual (RULE 8 — fără render real). NU atinge pdp-v1.html sau alte pdp-v*.
   ========================================================================= */

: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-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 home-v1. ---- */
.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 ---- */
.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-onhero{ background:var(--color-surface); color:var(--color-text-primary); border-color:transparent; }
.btn-onhero:hover{ background:#fff; box-shadow:var(--shadow-card); transform:translateY(-1px); }
.btn-onhero-outline{ background:transparent; border-color:var(--color-on-primary); color:var(--color-on-primary); }
.btn-onhero-outline:hover{ background:rgba(255,255,255,.14); }
.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-onhero-outline:focus-visible, .btn-onhero:focus-visible, .btn-onsage:focus-visible{ outline-color:var(--color-on-primary); }
.btn-lg{ font-size:var(--fs-lead); padding:var(--space-4) var(--space-6); min-height:52px; }
.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-onhero:hover, .btn-onsage:hover{ transform:none; }
  .link-arrow:hover .icon{ transform:none; }
}

/* ---- BADGE ---- */
.badge{ font-family:var(--font-body); font-size:var(--fs-eyebrow); font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; border-radius:var(--radius-pill); padding:3px var(--space-3); display:inline-flex; }
.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); }

/* ---- SECȚIUNI ---- */
.section{ padding:var(--space-9) 0; }
.section--tint{ background:var(--color-tint); }
.section--alt{ background:var(--color-surface-alt); }
.section--surface{ background:var(--color-surface); }
.section-head{ text-align:center; max-width:64ch; margin:0 auto var(--space-7); }
.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); }
h2.sec-title{ font-family:var(--font-display); font-size:var(--fs-h2); line-height:var(--lh-heading);
  font-weight:var(--fw-regular); letter-spacing:var(--ls-heading); margin:0 0 var(--space-3); }
.sec-sub{ color:var(--color-text-secondary); font-size:var(--fs-lead); margin:0; }

/* ---- SCROLL REVEAL (fade + slide-up subtil) ---- */
.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 home-v1.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 folosit pe PDP: product-card, review) ---- */
.product-card, .review{ position:relative; }
.product-card::before, .review::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, .review:hover::before{
  transform:scale(1.18) rotate(8deg); border-radius:58% 42% 48% 52% / 44% 56% 48% 52%; opacity:.9; }
.product-card > *, .review > *{ 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, .review::before{ transition:none; }
  .product-card:hover::before, .review:hover::before{ transform:none; border-radius:46% 54% 58% 42% / 52% 44% 56% 48%; }
}

/* ============ HEADER STICKY (GLOBAL — reutilizat din home-v1.html) ============ */
.site-header{ position:sticky; top:0; z-index:var(--z-sticky);
  /* Fundal SOLID = cel mai închis token din paleta D2 (--color-text-primary #33382F).
     PREVIEW pe V5; propagarea pe celelalte comps se face separat. Controale inversate (deschise)
     + logo auriu rămân lizibile pe închis (vezi regulile .site-header de mai jos). */
  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 (H1/H2 din home-v1). */
.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) ---- */
.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 PDP — VARIANTA 5 „ATIPIC PE ETAJE". Componente specifice (pe tokeni D2).
   Multe primitive (galerie, paletar-chip, qty, calc, tabs, product-card, proj-card,
   review, share, footer) sunt reutilizate VERBATIM din pdp-v1.html / home-v1.html;
   NOU pentru V5 = etajele full-width, paletarul COMPACT cu căutare/game/scroll, și
   decuplarea fizică calc↔coș pe coloane cu stare partajată JS.
   ============================================================================ */

/* ---- BREADCRUMB ---- */
.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); }

/* ---- ETAJE (ritm comun al secțiunilor V5) ---- */
.floor{ padding:var(--space-8) 0; }
.floor--first{ padding:var(--space-6) 0 var(--space-8); }
.floor-head{ max-width:none; margin:0 0 var(--space-6); }
.floor-head .eyebrow{ margin:0 0 var(--space-2); }
.floor-head h2{ font-family:var(--font-display); font-size:var(--fs-h2); line-height:var(--lh-heading);
  font-weight:var(--fw-regular); letter-spacing:var(--ls-heading); margin:0; color:var(--color-text-primary); }
.floor-head p.sub{ color:var(--color-text-secondary); font-size:var(--fs-lead); margin:var(--space-2) 0 0; }

/* SECȚIUNEA 1 — 3 coloane (BATCH): sidebar (căutare + categorii) | galerie | sumar produs.
   Mobil = o coloană (sidebarul coboară sub conținut, NU sticky). Desktop ≥1024 = 3 coloane
   ~22% / ~40% / ~38%. Pe mobil ordinea: galerie → info → sidebar (categorii ca acordeon jos). */
.s1-grid{ display:grid; grid-template-columns:1fr; gap:var(--space-7); align-items:start; }
@media (min-width:1024px){ .s1-grid{ grid-template-columns:22fr 40fr 38fr; gap:var(--space-7); } }
/* ordine mobilă: galerie, info, apoi sidebar (categorii) ultimul */
.s1-gallery{ order:1; }
.s1-summary{ order:2; }
.s1-side{ order:3; }
@media (min-width:1024px){ .s1-side{ order:0; } .s1-gallery{ order:0; } .s1-summary{ order:0; } }

/* ---- SIDEBAR S1 (BATCH): căutare + arbore de categorii. STICKY BOUNDED:
   pe desktop devine sticky sub header; se „dezlipește" natural când Secțiunea 2 (paletarul)
   urcă și împinge wrapperul Secțiunii 1 (containing block = coloana din .s1-grid).
   Nu folosim JS de scroll — `position:sticky` bounded rezolvă singur. ---- */
.s1-side{ display:flex; flex-direction:column; gap:var(--space-5); }
@media (min-width:1024px){
  .s1-side{ position:sticky; top:calc(var(--header-h) + var(--space-4)); align-self:start; }
}
.side-box{ background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card); padding:var(--space-5); }
.side-title{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3);
  margin:0 0 var(--space-4); color:var(--color-text-primary); }
/* căutare sidebar */
.side-search{ display:flex; flex-direction:column; gap:var(--space-3); }
.side-search-field{ position:relative; }
.side-search-field .icon{ position:absolute; left:var(--space-3); top:50%; transform:translateY(-50%);
  color:var(--color-text-secondary); width:1.1em; height:1.1em; }
.side-search input{ width:100%; min-height:var(--touch-min); border:1px solid var(--color-border);
  border-radius:var(--radius-pill); background:var(--color-surface); font-family:var(--font-body);
  font-size:var(--fs-body); padding:0 var(--space-4) 0 calc(var(--space-4)*2); color:var(--color-text-primary); }
.side-search input:focus{ outline:2px solid var(--color-primary); outline-offset:1px; border-color:var(--color-primary); }
/* arbore categorii */
.cat-tree{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; }
.cat-tree > li + li{ border-top:1px solid var(--color-border); }
.cat-link{ display:flex; align-items:center; gap:var(--space-2); justify-content:space-between;
  min-height:var(--touch-min); padding:var(--space-2) var(--space-1); text-decoration:none;
  font-family:var(--font-body); font-size:var(--fs-small); color:var(--color-text-primary);
  border-radius:var(--radius-sm); transition:color var(--transition), background var(--transition); }
.cat-link:hover{ color:var(--color-primary); background:var(--color-tint); }
.cat-link:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
.cat-link .cat-name{ flex:1 1 auto; min-width:0; }
.cat-count{ flex:0 0 auto; 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); }
/* categoria curentă a produsului — evidențiată (accent salvie) */
.cat-link[aria-current="page"]{ color:var(--color-primary); font-weight:var(--fw-semibold); background:var(--color-tint); }
.cat-link[aria-current="page"] .cat-count{ background:var(--color-primary); color:var(--color-on-primary); }
/* sub-itemi (sub Tehnici decorative) — indentați */
.cat-sub{ list-style:none; margin:0; padding:0 0 var(--space-2) 0; }
.cat-sub .cat-link{ padding-left:var(--space-5); min-height:38px; color:var(--color-text-secondary); font-size:.8rem; }
.cat-sub .cat-link:hover{ color:var(--color-primary); }
.cat-sub .cat-count{ background:transparent; padding:0; }

/* SECȚIUNEA 3 — 2 coloane 40/60 (calculator+opționale | ambalaj+coș+rezultat) */
.s3-grid{ display:grid; grid-template-columns:1fr; gap:var(--space-6); align-items:start; }
@media (min-width:1024px){ .s3-grid{ grid-template-columns:40fr 60fr; gap:var(--space-7); } }

/* SECȚIUNEA 4 — 2 coloane 60/40 (detalii | poză portret).
   DECIS de PM: DETALII 60% / POZĂ 40%. Markup: detalii PRIMUL (stânga 60), poza al doilea (dreapta 40). */
.s4-grid{ display:grid; grid-template-columns:1fr; gap:var(--space-7); align-items:start; }
@media (min-width:1024px){ .s4-grid{ grid-template-columns:60fr 40fr; gap:var(--space-8); } }

/* ---- GALERIE no-stretch (S1 stânga) — reutilizat din pdp-v1.html ---- */
.gallery{ display:flex; flex-direction:column; gap:var(--space-4); }
.gallery-main{ position:relative; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--color-border);
  box-shadow:var(--shadow-card); background:var(--color-surface); }
.gallery-main .gframe{ position:relative; aspect-ratio:4/3; overflow:hidden; }
.gallery-main img{ 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); }
.gallery-main:hover img, .gallery-main:focus-within img{ transform:scale(1.05); }
.gallery-main .pbadge{ position:absolute; top:var(--space-4); left:var(--space-4); z-index:2; }
.gallery-thumbs{ display:grid; grid-template-columns:repeat(5,1fr); gap:var(--space-3); }
.gthumb{ position:relative; aspect-ratio:1/1; border-radius:var(--radius-md); overflow:hidden; cursor:pointer;
  border:2px solid var(--color-border); background:var(--color-surface); padding:0;
  transition:border-color var(--transition), transform var(--transition); }
.gthumb img{ width:100%; height:100%; object-fit:cover; display:block; transform:scale(1); transition:transform var(--tr-zoom); }
.gthumb:hover img, .gthumb:focus-visible img{ transform:scale(1.08); }
.gthumb:hover{ border-color:var(--color-primary); }
.gthumb[aria-current="true"]{ border-color:var(--color-selected-ring); }
.gthumb:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){
  .gallery-main img, .gthumb img{ transition:none; }
  .gallery-main:hover img, .gallery-main:focus-within img, .gthumb:hover img, .gthumb:focus-visible img{ transform:none; }
}

/* ---- SUMAR PRODUS (S1 dreapta) — etichetă + H1 + ★ + descriere scurtă + S1 preț + microinfo ---- */
.psum{ display:flex; flex-direction:column; gap:var(--space-4); }
.psum-flags{ display:flex; flex-wrap:wrap; gap:var(--space-2); }
.psum-flag{ position:static; }
.psum-brand{ font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  letter-spacing:.08em; text-transform:uppercase; color:var(--color-text-secondary); margin:0; }
.psum-title{ 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:var(--space-1) 0 0; color:var(--color-text-primary); }
.psum-ratingline{ display:flex; align-items:center; gap:var(--space-2); flex-wrap:wrap; }
.psum-ratingline .stars{ display:inline-flex; gap:2px; color:var(--color-warning); }
.psum-ratingline .stars .icon{ width:16px; height:16px; }
.psum-ratingline .stars .icon.empty{ color:var(--color-border); }
.psum-ratingline a{ font-size:var(--fs-small); color:var(--color-text-secondary); }
/* DESCRIERE SCURTĂ (≤100 cuvinte) — NU dublează descrierea din Secțiunea 4 (detalii). */
.psum-short{ font-size:var(--fs-body); color:var(--color-text-primary); line-height:var(--lh-body); margin:0; max-width:54ch; }
/* BADGE DESTINAȚIE MATERIAL (BATCH) — la build = valoarea atributului `pa_destinatie`. */
.psum-dest{ align-self:flex-start; display:inline-flex; align-items:center; gap:var(--space-2);
  background:var(--color-info-soft); color:var(--color-info); 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); font-weight:var(--fw-semibold); }
.psum-dest .icon{ width:16px; height:16px; flex:0 0 auto; }

/* LISTĂ „Avantaje și certificări" (BATCH) — bifă + titlu + descriere, FĂRĂ imagini.
   La build = widget Elementor Icon List / repeater EDITABIL (bifă + titlu + descriere). */
.psum-benefits{ display:flex; flex-direction:column; gap:var(--space-3); margin:0; padding:0; list-style:none; }
.psum-benefits-title{ font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-small);
  text-transform:uppercase; letter-spacing:.06em; color:var(--color-text-secondary); margin:var(--space-1) 0 0; }
.benefit{ display:flex; align-items:flex-start; gap:var(--space-3); }
.benefit .bf-ico{ flex:0 0 auto; width:22px; height:22px; border-radius:50%; background:var(--color-success-soft);
  color:var(--color-success); display:inline-flex; align-items:center; justify-content:center; margin-top:1px; }
.benefit .bf-ico .icon{ width:14px; height:14px; }
.benefit .bf-body{ min-width:0; }
.benefit .bf-title{ font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-small);
  color:var(--color-text-primary); line-height:1.3; }
.benefit .bf-desc{ font-size:.8rem; color:var(--color-text-secondary); line-height:1.4; }

/* S1 PREȚ — preț PE LITRU + ~10% mai mare (BATCH).
   --fs-price-now derivat din 1.75rem × 1.1 = 1.925rem (NU magic number brut — scalare locală).
   Zonă aerisită: align-items:baseline pe „de la" (mic) + cifră (bold), gap pe tokeni, fără sub-linia /găleată. */
.psum-price{ --fs-price-base:1.75rem; --fs-price-now:calc(var(--fs-price-base) * 1.1);
  display:flex; align-items:baseline; flex-wrap:wrap; gap:var(--space-2) var(--space-4);
  margin:var(--space-2) 0; padding-top:var(--space-5); border-top:1px solid var(--color-border); }
/* „de la" = cuvinte mici, secundare (accentul rămâne pe cifră) */
.psum-price .price-from{ font-size:var(--fs-small); font-weight:var(--fw-regular); color:var(--color-text-secondary); }
/* prețul (cifră + unitate) = bold, dominant */
.psum-price .now{ font-family:var(--font-body); font-size:var(--fs-price-now); font-weight:var(--fw-bold); color:var(--color-text-primary); }
.psum-price .tva{ font-size:var(--fs-small); color:var(--color-text-secondary); }
/* notă cantitate minimă + meta produs (BATCH) */
.psum-minqty{ font-size:var(--fs-small); color:var(--color-text-secondary); margin:0; }
/* „Disponibil în:" (BATCH) — rând INFO sub „Cantitate minimă". Etichetă în stilul meta-ului din jur +
   chip-uri NEUTRE, doar informative (mărimile de ambalaj ale produsului). NU selector, NU interactive,
   FĂRĂ hover de selecție / name / radio — vizual DISTINCTE de pill-urile de ambalaj din Secțiunea 3. */
.psum-sizes{ display:flex; align-items:center; flex-wrap:wrap; gap:var(--space-2); margin:0;
  font-size:var(--fs-small); color:var(--color-text-secondary); }
.psum-sizes-label{ font-weight:var(--fw-semibold); }
.size-chip{ display:inline-flex; align-items:center; min-height:26px; padding:2px var(--space-3);
  background:var(--color-surface-alt); border:1px solid var(--color-border); border-radius:var(--radius-pill);
  font-family:var(--font-body); font-size:var(--fs-eyebrow); font-weight:var(--fw-semibold);
  color:var(--color-text-primary); cursor:default; }
.psum-meta{ display:flex; flex-direction:column; gap:2px; margin:0; padding:0; list-style:none; }
.psum-meta li{ font-size:.8rem; color:var(--color-text-secondary); list-style:none; }
.psum-meta b{ color:var(--color-text-primary); font-weight:var(--fw-semibold); }
/* LINK INTERN SEO (Categorie / Etichetă) — stil link D2: subliniere discretă, hover primary,
   focus-visible, touch ≥44px pe mobil (la build = link real către arhiva categoriei/etichetei). */
.meta-link{ color:var(--color-primary); font-weight:var(--fw-semibold);
  text-decoration:underline; text-decoration-thickness:1px; text-underline-offset:2px;
  text-decoration-color:var(--color-border); transition:color var(--transition), text-decoration-color var(--transition); }
.meta-link:hover{ color:var(--color-primary-hover); text-decoration-color:var(--color-primary); }
.meta-link:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; border-radius:var(--radius-sm); }
@media (max-width:1023px){
  .meta-link{ display:inline-flex; align-items:center; min-height:var(--touch-min); }
}
.psum-microinfo{ display:flex; flex-direction:column; gap:var(--space-2); padding:0; margin:var(--space-1) 0 0; }
.psum-microinfo li{ display:flex; align-items:center; gap:var(--space-2); font-size:var(--fs-small); color:var(--color-text-secondary); list-style:none; }
.psum-microinfo .icon{ width:18px; height:18px; color:var(--color-primary); flex:0 0 auto; }
.psum-stock-ok{ color:var(--color-success); font-weight:var(--fw-semibold); }

/* ============================================================================
   PALETAR COMPACT & SCALABIL (SECȚIUNEA 2 — bandă FULL-WIDTH proprie).
   Sistemul comun §1: căutare cod/nume + filtre game + grilă densă swatch mici +
   scroll intern plafonat + „Vezi toate" (inline) + „Comandă mostră". Culoarea =
   SELECȚIE DE COMANDĂ (eticheta nuanței selectate mereu vizibilă; la build apare în
   comandă/coș/factură ca variație Woo). Aici primește cel mai mult spațiu → grilă pe
   toată lățimea, foarte densă, ca să respire la „foarte multe" culori/texturi.
   ============================================================================ */
.palbar{ background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card); padding:var(--space-6); }
.palbar-top{ display:flex; flex-wrap:wrap; align-items:baseline; justify-content:space-between; gap:var(--space-3) var(--space-5); margin-bottom:var(--space-4); }
.palbar-titlewrap{ display:flex; align-items:baseline; gap:var(--space-3); flex-wrap:wrap; }
.palbar-title{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3); margin:0; color:var(--color-text-primary); }
/* Eticheta nuanței selectate — MEREU VIZIBILĂ (selecție de comandă). */
.pal-selected{ display:inline-flex; align-items:center; gap:var(--space-2); background:var(--color-tint);
  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); color:var(--color-text-primary); }
.pal-selected .sw-dot{ width:18px; height:18px; border-radius:50%; box-shadow:var(--shadow-swatch); flex:0 0 auto; overflow:hidden; }
.pal-selected b{ font-weight:var(--fw-semibold); }
.pal-selected .sel-code{ color:var(--color-text-secondary); }
.palbar-note{ font-size:.78rem; color:var(--color-text-secondary); margin:var(--space-1) 0 0; width:100%; }

/* Rând controale: căutare + filtre game */
.pal-controls{ display:flex; flex-wrap:wrap; gap:var(--space-3) var(--space-4); align-items:center; margin-bottom:var(--space-4); }
.pal-search{ position:relative; flex:1 1 260px; min-width:200px; }
.pal-search .icon{ position:absolute; left:var(--space-3); top:50%; transform:translateY(-50%); color:var(--color-text-secondary); width:1.1em; height:1.1em; }
.pal-search input{ width:100%; min-height:var(--touch-min); border:1px solid var(--color-border); border-radius:var(--radius-pill);
  background:var(--color-surface); font-family:var(--font-body); font-size:var(--fs-body);
  padding:0 var(--space-4) 0 calc(var(--space-4)*2); color:var(--color-text-primary); }
.pal-search input:focus{ outline:2px solid var(--color-primary); outline-offset:1px; border-color:var(--color-primary); }
.pal-games{ display:flex; flex-wrap:wrap; gap:var(--space-2); align-items:center; }
.pal-games .games-lbl{ font-size:var(--fs-small); color:var(--color-text-secondary); }
.game-chip{ font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  min-height:36px; padding:var(--space-1) var(--space-3); border-radius:var(--radius-pill);
  border:1px solid var(--color-border); background:var(--color-surface); color:var(--color-text-primary); cursor:pointer;
  transition:border-color var(--transition), background var(--transition), color var(--transition); }
.game-chip:hover{ background:var(--color-surface-alt); }
.game-chip[aria-pressed="true"]{ background:var(--color-primary); border-color:var(--color-primary); color:var(--color-on-primary); }
.game-chip:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }

/* Zonă derulabilă plafonată — grila densă de swatch-uri MICI pe toată lățimea */
.pal-scroll{ max-height:248px; overflow-y:auto; padding:var(--space-1) var(--space-1) var(--space-1) 0;
  border:1px solid var(--color-border); border-radius:var(--radius-md); background:var(--color-tint); }
.pal-scroll.is-expanded{ max-height:none; }
.pal-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(46px, 1fr)); gap:var(--space-3);
  padding:var(--space-4); }
.swatch{ display:flex; flex-direction:column; align-items:center; gap:4px; background:transparent; border:0; padding:0;
  cursor:pointer; text-align:center; }
.swatch .sw{ position:relative; width:100%; aspect-ratio:1/1; border-radius:var(--radius-swatch); box-shadow:var(--shadow-swatch);
  transform:translateY(0) scale(1); transition:transform var(--tr-zoom), box-shadow var(--tr-zoom); will-change:transform; overflow:hidden; }
.swatch .sw img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.swatch:hover .sw, .swatch:focus-visible .sw{ transform:translateY(-3px) scale(1.08); box-shadow:var(--shadow-card-hover); }
.swatch:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; border-radius:var(--radius-sm); }
.swatch[aria-checked="true"] .sw{ outline:3px solid var(--color-selected-ring); outline-offset:2px; }
.swatch .sw .tick{ position:absolute; right:2px; bottom:2px; width:13px; height:13px; color:#fff;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.5)); display:none; z-index:2; }
.swatch[aria-checked="true"] .sw .tick{ display:block; }
/* Eticheta text (cod+nume) apare la hover/selecție — NU sub fiecare swatch (densitate fără zgomot). */
.swatch .sw-tip{ font-size:.66rem; line-height:1.15; color:var(--color-text-secondary); max-width:100%; overflow:hidden;
  text-overflow:ellipsis; white-space:nowrap; opacity:0; height:0; transition:opacity var(--transition); }
.swatch:hover .sw-tip, .swatch:focus-visible .sw-tip, .swatch[aria-checked="true"] .sw-tip{ opacity:1; height:auto; }
/* element ascuns de filtrare (search/game) */
.swatch[hidden]{ display:none; }
.pal-empty{ display:none; padding:var(--space-5); text-align:center; color:var(--color-text-secondary); font-size:var(--fs-small); }
.pal-empty.is-on{ display:block; }
/* acțiuni paletar: „Vezi toate" (inline) + „Comandă mostră" */
.pal-actions{ display:flex; flex-wrap:wrap; gap:var(--space-3); align-items:center; margin-top:var(--space-4); }
.pal-actions .pal-count{ margin-left:auto; font-size:var(--fs-small); color:var(--color-text-secondary); }
@media (prefers-reduced-motion: reduce){
  .swatch .sw{ transition:box-shadow var(--transition); }
  .swatch:hover .sw, .swatch:focus-visible .sw{ transform:none; }
}

/* ============================================================================
   SECȚIUNEA 3 — CALCULATOR + OPȚIONALE (stânga 40) | AMBALAJ + COȘ + REZULTAT (dreapta 60).
   Calculatorul (stânga) și add-to-cart (dreapta) sunt FIZIC DECUPLATE (coloane diferite),
   dar LOGIC CUPLATE prin stare partajată JS (un singur IIFE). Ambele trăiesc în ACELAȘI
   <form class="pdp-buy"> care înfășoară și paletarul din Secțiunea 2 (principiul „un form
   întins pe benzi" — pdp-woo-feasibility.md §2 varianta b).
   ============================================================================ */
.panel-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); }
.panel-head{ display:flex; align-items:center; gap:var(--space-3); margin-bottom:var(--space-2); }
.panel-head .panel-ico{ flex:0 0 auto; width:44px; height:44px; border-radius:var(--radius-md);
  background:var(--color-primary); color:var(--color-on-primary); display:flex; align-items:center; justify-content:center; }
.panel-head .panel-ico .icon{ width:1.4em; height:1.4em; }
.panel-head h3{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3); margin:0; }
.panel-lead{ color:var(--color-text-secondary); font-size:var(--fs-small); margin:0 0 var(--space-5); }

/* CALCULATOR (S3 stânga) — câmpuri m² + straturi */
.calc-fields{ display:flex; flex-direction:column; gap:var(--space-4); }
.calc-field label{ display:block; font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold);
  color:var(--color-text-primary); margin-bottom:var(--space-2); }
.calc-field input{ width:100%; min-height:var(--touch-min); padding:var(--space-3) var(--space-4); border-radius:var(--radius-sm);
  border:1px solid var(--color-border); background:var(--color-surface); color:var(--color-text-primary);
  font-family:var(--font-body); font-size:var(--fs-body); }
.calc-field input:focus{ outline:2px solid var(--color-primary); outline-offset:1px; border-color:var(--color-primary); }
.calc-field input[aria-invalid="true"]{ border-color:var(--color-danger); }
.calc-err{ display:none; font-size:var(--fs-small); color:var(--color-danger); margin-top:var(--space-1); align-items:center; gap:var(--space-1); }
.calc-err.is-on{ display:flex; }
.calc-pack-info{ font-size:var(--fs-small); color:var(--color-text-secondary); margin:0; }

/* OPȚIONALE / accesorii necesare (S3 stânga, sub calculator): S3 grund/amorsă/aditiv (obligatorii,
   pre-bifate, încadrate) + S4 sclipici (opțional, toggle). */
.opt-group{ display:flex; flex-direction:column; gap:var(--space-2); margin-top:var(--space-5);
  border-top:1px solid var(--color-border); padding-top:var(--space-4); }
.opt-title{ font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-small); color:var(--color-text-primary); }
.opt-title .opt-req{ font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
  color:var(--color-primary); margin-left:var(--space-2); }
/* obligatorii = încadrate cu accent salvie; opțional = simplu */
.opt-required{ background:var(--color-success-soft); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:var(--space-3) var(--space-4); }
.opt-optional{ background:var(--color-surface); }
.opt-choice{ display:flex; align-items:center; gap:var(--space-3); min-height:var(--touch-min); cursor:pointer;
  font-family:var(--font-body); font-size:var(--fs-small); color:var(--color-text-primary); }
.opt-choice input{ width:20px; height:20px; accent-color:var(--color-primary); flex:0 0 auto; }
.opt-choice .opt-price{ margin-left:auto; color:var(--color-text-secondary); }

/* AMBALAJ + COȘ + REZULTAT (S3 dreapta) */
.buy-block{ display:flex; flex-direction:column; gap:var(--space-3); }
.buy-block + .buy-block{ padding-top:var(--space-4); margin-top:var(--space-1); border-top:1px solid var(--color-border); }
.buy-block-head{ display:flex; align-items:baseline; justify-content:space-between; gap:var(--space-3); }
.buy-label{ font-family:var(--font-body); font-weight:var(--fw-semibold); color:var(--color-text-primary); }
.buy-selected{ font-size:var(--fs-small); color:var(--color-text-secondary); }
/* selector AMBALAJ (pills) */
.pack-pills{ display:flex; flex-wrap:wrap; gap:var(--space-2); }
.pack-pill{ font-family:var(--font-body); font-size:var(--fs-body); font-weight:var(--fw-semibold); min-height:var(--touch-min);
  padding:var(--space-2) var(--space-4); border-radius:var(--radius-md); border:1px solid var(--color-border);
  background:var(--color-surface); color:var(--color-text-primary); cursor:pointer; display:inline-flex; align-items:center; gap:var(--space-2);
  transition:border-color var(--transition), background var(--transition); }
.pack-pill .pk-price{ font-size:var(--fs-small); color:var(--color-text-secondary); font-weight:var(--fw-regular); }
.pack-pill:hover{ background:var(--color-surface-alt); }
.pack-pill[aria-checked="true"]{ border-color:var(--color-selected-ring); box-shadow:inset 0 0 0 1px var(--color-selected-ring); }
.pack-pill[aria-checked="true"] .pk-price{ color:var(--color-text-primary); }
.pack-pill:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
/* stepper qty */
.qty{ display:inline-flex; align-items:stretch; border:1px solid var(--color-border); border-radius:var(--radius-sm); overflow:hidden; flex:0 0 auto; }
.qty button{ width:44px; height:44px; border:0; background:var(--color-surface-alt); color:var(--color-text-primary);
  font-size:1.25rem; cursor:pointer; line-height:1; display:inline-flex; align-items:center; justify-content:center; }
.qty button:hover{ background:var(--color-border); }
.qty button:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
.qty button .icon{ width:1em; height:1em; }
.qty input{ width:56px; border:0; text-align:center; font-family:var(--font-body); font-size:var(--fs-body);
  background:var(--color-surface); color:var(--color-text-primary); }
.qty input:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
.buy-actions{ display:flex; flex-wrap:wrap; gap:var(--space-3); align-items:stretch; }
.buy-actions .btn-primary{ flex:1 1 200px; }
/* CALC-RESULT (S3 dreapta) — litri / recipiente / preț estimat; pulse subtil la update */
.calc-result{ background:var(--color-tint); border:1px solid var(--color-border); border-radius:var(--radius-md);
  padding:var(--space-5); display:flex; flex-direction:column; gap:var(--space-4); }
.calc-result.is-pulse{ animation:calcPulse 420ms ease; }
@keyframes calcPulse{ 0%{ box-shadow:0 0 0 0 rgba(94,115,85,.0); } 35%{ box-shadow:0 0 0 4px rgba(94,115,85,.18); } 100%{ box-shadow:0 0 0 0 rgba(94,115,85,0); } }
@media (prefers-reduced-motion: reduce){ .calc-result.is-pulse{ animation:none; } }
.calc-out{ display:grid; grid-template-columns:1fr; gap:var(--space-3); }
.calc-out .out-row{ display:flex; align-items:baseline; justify-content:space-between; gap:var(--space-3); }
.calc-out .out-row span{ font-size:var(--fs-small); color:var(--color-text-secondary); }
.calc-out .out-row b{ font-family:var(--font-body); font-weight:var(--fw-bold); font-size:1.1rem; color:var(--color-text-primary); }
.calc-out .out-total b{ font-size:1.4rem; color:var(--color-primary); }
.calc-note{ font-size:.78rem; color:var(--color-text-secondary); margin:0; line-height:1.5; }
.calc-note strong{ color:var(--color-warning); font-weight:var(--fw-semibold); }

/* ---- TEASER „Adaugă servicii colaborator (0 lei)" (S3 dreapta, sub „Adaugă în coș") ----
   Variantă COMPACTĂ a blocului din collaborator-services-flow.md §Wireframe → intrarea în flux +
   promisiunea „gratuit". Detaliul complet (zonă / proiect / consimțământ GDPR) stă pe Coș/Checkout,
   NU pe PDP. Aici = teaser + reveal inline cu cele 2 opțiuni (aplicator / designer) + notă „A&D doar
   transmite". FĂRĂ dropdown de colaboratori (doar recomandare după zonă — decizie PM 2026-06-26).
   Reutilizează tokeni D2 + primitivele existente (.opt-choice pentru bife, .badge pentru „0 lei"). */
.svc-teaser{ background:var(--color-success-soft); border:1px solid var(--color-border);
  border-radius:var(--radius-md); padding:var(--space-4); display:flex; flex-direction:column; gap:var(--space-3); }
.svc-teaser-top{ display:flex; align-items:flex-start; gap:var(--space-3); }
.svc-teaser-ico{ flex:0 0 auto; width:36px; height:36px; border-radius:50%; background:var(--color-surface);
  color:var(--color-success); display:inline-flex; align-items:center; justify-content:center; box-shadow:var(--shadow-sm); }
.svc-teaser-ico .icon{ width:18px; height:18px; }
.svc-teaser-copy{ min-width:0; flex:1 1 auto; }
.svc-teaser-line{ display:flex; align-items:center; flex-wrap:wrap; gap:var(--space-2); }
.svc-teaser-title{ font-family:var(--font-body); font-weight:var(--fw-semibold); font-size:var(--fs-body);
  color:var(--color-text-primary); line-height:1.3; }
/* badge „0 lei” — reutilizează .badge; tentă success ca să citească „gratuit” fără cost */
.badge-free{ background:var(--color-success); color:var(--color-on-primary); }
.svc-teaser-sub{ font-size:var(--fs-small); color:var(--color-text-secondary); margin:var(--space-1) 0 0; line-height:1.45; }
/* CTA discret = ghost text-only; comută panoul inline */
.svc-teaser-cta{ align-self:flex-start; }
.svc-teaser-cta .ic-chev{ transition:transform var(--transition); }
.svc-teaser-cta[aria-expanded="true"] .ic-chev{ transform:rotate(180deg); }
@media (prefers-reduced-motion: reduce){ .svc-teaser-cta .ic-chev{ transition:none; } }
/* panoul inline (închis = [hidden]; AT nu îl vede, JS comută hidden + aria-expanded) */
.svc-panel{ border-top:1px solid var(--color-border); padding-top:var(--space-3);
  display:flex; flex-direction:column; gap:var(--space-2); }
.svc-panel[hidden]{ display:none; }
.svc-panel .opt-choice{ font-size:var(--fs-small); }
.svc-note{ display:flex; align-items:flex-start; gap:var(--space-2); font-size:.78rem;
  color:var(--color-text-secondary); line-height:1.5; margin:var(--space-1) 0 0; }
.svc-note .icon{ flex:0 0 auto; width:15px; height:15px; margin-top:2px; color:var(--color-info); }

/* ---- SECȚIUNEA 4 — TAB-URI DETALII (stânga 60) + POZĂ PORTRET (dreapta 40) ---- */
.tabs [role="tablist"]{ display:flex; gap:var(--space-2); border-bottom:1px solid var(--color-border); flex-wrap:wrap; }
.tabs [role="tab"]{ font-family:var(--font-body); font-size:var(--fs-body); font-weight:var(--fw-semibold);
  background:transparent; border:0; border-bottom:2px solid transparent; color:var(--color-text-secondary);
  padding:var(--space-3) var(--space-4); min-height:var(--touch-min); cursor:pointer; }
.tabs [role="tab"][aria-selected="true"]{ color:var(--color-text-primary); border-bottom-color:var(--color-primary); }
.tabs [role="tab"]:hover{ color:var(--color-text-primary); }
.tabs [role="tab"]:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
.tabs [role="tabpanel"]{ padding:var(--space-6) 0; max-width:72ch; }
.tabs [role="tabpanel"][hidden]{ display:none; }
.tabs [role="tabpanel"] h3{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3); margin:var(--space-5) 0 var(--space-2); }
.tabs [role="tabpanel"] h3:first-child{ margin-top:0; }
.tabs [role="tabpanel"] ul{ line-height:var(--lh-body); }
.spec-list{ list-style:none; padding:0; margin:0; max-width:560px; }
.spec-list li{ display:flex; justify-content:space-between; gap:var(--space-4); padding:var(--space-3) 0; border-bottom:1px solid var(--color-border); }
.spec-list b{ font-weight:var(--fw-semibold); }
.bb-note{ font-size:var(--fs-small); color:var(--color-text-secondary); margin:0; }
/* POZĂ PORTRET (S4 dreapta) — lucrare reală/reclamă, zoom-în-ramă la hover */
.portrait-ad{ position:relative; overflow:hidden; border-radius:var(--radius-lg); box-shadow:var(--shadow-card);
  border:1px solid var(--color-border); }
@media (min-width:1024px){ .portrait-ad{ position:sticky; top:calc(var(--header-h) + var(--space-4)); } }
.portrait-ad .pf{ position:relative; aspect-ratio:3/4; overflow:hidden; }
.portrait-ad img{ 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); }
.portrait-ad:hover img, .portrait-ad:focus-within img{ transform:scale(1.05); }
.portrait-ad .pf-ad{ position:absolute; left:0; right:0; bottom:0; padding:var(--space-5);
  background:linear-gradient(to top, rgba(51,56,47,.92) 0%, rgba(51,56,47,.55) 60%, rgba(51,56,47,0) 100%); color:var(--color-on-primary); }
.portrait-ad .pf-ad .eyebrow{ color:var(--color-accent); margin:0 0 var(--space-1); }
.portrait-ad .pf-ad 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-3); color:#fff; }
.portrait-ad .pf-ad .btn{ width:100%; }
@media (prefers-reduced-motion: reduce){
  .portrait-ad img{ transition:none; } .portrait-ad:hover img, .portrait-ad:focus-within img{ transform:none; }
}

/* recenzii (refolosit din home — card .review) */
.reviews{ display:grid; grid-template-columns:1fr; gap:var(--space-5); }
@media (min-width:768px){ .reviews{ grid-template-columns:repeat(2,1fr); } }
.review{ background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card); padding:var(--space-6); display:flex; flex-direction:column; gap:var(--space-3); }
.review .stars{ display:inline-flex; gap:2px; color:var(--color-warning); }
.review .stars .icon{ width:18px; height:18px; }
.review .stars .icon.empty{ color:var(--color-border); }
.review blockquote{ font-family:var(--font-display); font-size:var(--fs-lead); line-height:1.4; margin:0; color:var(--color-text-primary); }
.review .who{ font-family:var(--font-body); font-size:var(--fs-small); color:var(--color-text-secondary); margin-top:auto; }

/* ---- GRILĂ CARDURI PRODUS (cross-sell & similare) — reutilizat ---- */
.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(4,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; }
.product-card .pmedia .shade{ position:absolute; left:var(--space-3); bottom:32%; z-index:2;
  font-family:var(--font-body); font-size:.75rem; font-weight:600;
  background:rgba(255,255,255,.85); color:#33382F; padding:2px var(--space-2); border-radius:var(--radius-sm); }
.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); }
.product-card .price{ font-family:var(--font-body); margin:var(--space-3) 0; }
.product-card .price .now{ font-size:1.1rem; font-weight:var(--fw-semibold); color:var(--color-text-primary); }
.product-card .price .old{ font-size:var(--fs-small); color:var(--color-text-secondary); text-decoration:line-through; margin-left:var(--space-2); }
.product-card .pview{ margin-top:auto; font-family:var(--font-body); font-weight:600; font-size:var(--fs-small);
  color:var(--color-primary); text-decoration:none; display:inline-flex; align-items:center; gap:4px; padding:var(--space-2) var(--space-1); }
.product-card .pview:hover{ text-decoration:underline; }
.product-card .pview .icon{ width:1em; height:1em; transition:transform var(--transition); }
.product-card .pview:hover .icon{ transform:translateX(2px); }
.product-card .pview:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; border-radius:var(--radius-sm); }
.product-card .btn{ margin-top:auto; width:100%; }
.pbadge-best{ background:var(--color-text-primary); color:var(--color-on-primary); }
@media (prefers-reduced-motion: reduce){
  .product-card:hover{ transform:none; }
  .product-card .pmedia-bg{ transition:none; } .product-card:hover .pmedia-bg{ transform:none; }
}

/* ---- GALERIE PROIECTE COLABORATORI ---- */
.proj-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-4); }
@media (min-width:768px){ .proj-grid{ grid-template-columns:repeat(4,1fr); } }
.proj-card{ display:block; position:relative; border-radius:var(--radius-lg); overflow:hidden; text-decoration:none;
  border:1px solid var(--color-border); box-shadow:var(--shadow-card); aspect-ratio:4/5;
  transition:box-shadow var(--transition), transform var(--transition); }
.proj-card:hover{ box-shadow:var(--shadow-card-hover); transform:translateY(-3px); }
.proj-card .pf{ position:absolute; inset:0; overflow:hidden; }
.proj-card img{ width:100%; height:100%; object-fit:cover; display:block;
  transform:scale(1); transform-origin:center; will-change:transform; transition:transform var(--tr-zoom); }
.proj-card:hover img, .proj-card:focus-visible img{ transform:scale(1.07); }
.proj-card .pf-scrim{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(to top, rgba(51,56,47,.85) 0%, rgba(51,56,47,.20) 45%, rgba(51,56,47,0) 70%);
  opacity:.9; transition:opacity var(--transition); }
.proj-card:hover .pf-scrim, .proj-card:focus-visible .pf-scrim{ opacity:1; }
.proj-card .pf-meta{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:var(--space-4); color:var(--color-on-primary); }
.proj-card .pf-tag{ display:inline-flex; align-items:center; gap:4px; font-family:var(--font-body); font-size:.72rem;
  font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--color-accent); margin-bottom:var(--space-1); }
.proj-card .pf-title{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:1.05rem; line-height:1.25; color:#fff; display:block; }
.proj-card .pf-cta{ display:inline-flex; align-items:center; gap:4px; margin-top:var(--space-2);
  font-family:var(--font-body); font-size:var(--fs-small); font-weight:var(--fw-semibold); color:var(--color-on-primary);
  opacity:0; transform:translateY(6px); transition:opacity var(--transition), transform var(--transition); }
.proj-card:hover .pf-cta, .proj-card:focus-visible .pf-cta{ opacity:1; transform:none; }
.proj-card .pf-cta .icon{ width:1em; height:1em; }
.proj-card:focus-visible{ outline:2px solid var(--color-primary); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){
  .proj-card{ transition:box-shadow var(--transition); } .proj-card:hover{ transform:none; }
  .proj-card img{ transition:none; } .proj-card:hover img, .proj-card:focus-visible img{ transform:none; }
  .proj-card .pf-cta{ opacity:1; transform:none; transition:none; }
}

/* ---- FAQ (acordeon single-open; FAQPage schema la build) — reutilizat din home-v1 ---- */
.faq{ max-width:840px; margin:0 auto; border:1px solid var(--color-border); border-radius:var(--radius-lg);
  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; justify-content:space-between; gap:var(--space-4);
  text-align:left; background:transparent; border:0; cursor:pointer; padding:var(--space-4) var(--space-5);
  min-height:var(--touch-min); font-family:var(--font-body); font-size:var(--fs-lead); font-weight:var(--fw-semibold);
  color:var(--color-text-primary); transition:background var(--transition); }
.faq-head:hover{ background:var(--color-tint); }
.faq-head:focus-visible{ outline:2px solid var(--color-primary); outline-offset:-2px; }
.faq-head .chev{ color:var(--color-primary); transition:transform var(--transition); 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); }
.faq-panel[hidden]{ display:none; }
@media (prefers-reduced-motion: reduce){ .faq-head .chev{ transition:none; } }

/* ---- NEWSLETTER (panou editorial salvie) — reutilizat din home-v1 ---- */
.newsletter{ background:var(--color-primary); color:var(--color-on-primary); }
.nl-inner{ display:grid; grid-template-columns:1fr; gap:var(--space-6); align-items:center; padding:var(--space-9) 0; }
@media (min-width:768px){ .nl-inner{ grid-template-columns:1.1fr 1fr; } }
.nl-inner h2{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h2); margin:0 0 var(--space-3); color:#fff; }
.nl-inner p{ margin:0; color:var(--color-on-primary); max-width:46ch; }
.nl-form{ display:flex; gap:var(--space-3); flex-wrap:wrap; }
.nl-form input{ flex:1 1 220px; min-height:var(--touch-min); padding:var(--space-3) var(--space-4);
  border-radius:var(--radius-md); border:1px solid transparent; font-family:var(--font-body); font-size:var(--fs-body);
  background:var(--color-surface); color:var(--color-text-primary); }
.nl-form input:focus{ outline:2px solid var(--color-on-primary); outline-offset:2px; }

/* ---- BLOC SEO / EEAT / GEO (autor/expert + semnale locale + trust) ---- */
.eeat-grid{ display:grid; grid-template-columns:1fr; gap:var(--space-6); align-items:start; }
@media (min-width:900px){ .eeat-grid{ grid-template-columns:1.2fr 1fr; gap:var(--space-7); } }
.expert-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); display:flex; flex-direction:column; gap:var(--space-3); }
.expert-byline{ display:flex; align-items:center; gap:var(--space-3); }
.expert-byline .ex-ava{ width:48px; height:48px; border-radius:50%; background:var(--color-primary); color:var(--color-on-primary);
  display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.expert-byline .ex-ava .icon{ width:1.5em; height:1.5em; }
.expert-byline .ex-meta b{ display:block; font-family:var(--font-body); font-weight:var(--fw-semibold); color:var(--color-text-primary); }
.expert-byline .ex-meta span{ font-size:var(--fs-small); color:var(--color-text-secondary); }
.expert-card h3{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3); margin:var(--space-2) 0 0; }
.expert-card p{ margin:0; color:var(--color-text-secondary); font-size:var(--fs-body); line-height:var(--lh-body); }
.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); display:flex; flex-direction:column; gap:var(--space-3); }
.geo-card h3{ font-family:var(--font-display); font-weight:var(--fw-regular); font-size:var(--fs-h3); margin:0; }
.geo-card dl{ margin:0; display:grid; grid-template-columns:auto 1fr; gap:var(--space-2) var(--space-3); }
.geo-card dt{ color:var(--color-text-secondary); font-size:var(--fs-small); }
.geo-card dd{ margin:0; color:var(--color-text-primary); font-size:var(--fs-small); }
.trust-row{ list-style:none; margin:var(--space-2) 0 0; padding:0; display:flex; flex-direction:column; gap:var(--space-2); }
.trust-row li{ display:flex; align-items:center; gap:var(--space-2); font-size:var(--fs-small); color:var(--color-text-primary); }
.trust-row .icon{ width:18px; height:18px; color:var(--color-success); flex:0 0 auto; }

/* ============ BARĂ SHARE (GLOBAL — VERBATIM din home-v1.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 home-v1.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); }
}
