/* ═══════════════════════════════════════════
   STEFI ART — Premium Design System
   ═══════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --negru:      #0d0d0d;
  --negru2:     #1a1a1a;
  --gri:        #6b7280;
  --gri2:       #9ca3af;
  --linie:      #e5e7eb;
  --light:      #f7f6f3;
  --alb:        #ffffff;
  --portocaliu: #f37c26;
  --portocaliu2:#d96b1a;
  --font:       'Outfit', system-ui, sans-serif;
}

html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family: var(--font); background: var(--alb); color: var(--negru); line-height: 1.6; overflow-x: hidden; max-width: 100%; }
img  { display: block; width: 100%; height: 100%; object-fit: cover; }
a    { text-decoration: none; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 32px; }

/* ─── HEADER ─── */
.site-header  { position: sticky; top: 0; z-index: 200; }
.header-top   { background: #141414; padding: 9px 0; font-size: 13px; color: rgba(255,255,255,.45); }
.header-top .container { display: flex; align-items: center; justify-content: space-between; }
.ht-left      { display: flex; gap: 20px; }
.ht-phone     { display: flex; align-items: center; gap: 6px; color: #fff !important; font-weight: 700; font-size: 14px; }
.ht-phone svg { width: 13px; height: 13px; fill: currentColor; }
.header-main  { background: #111; border-bottom: 1px solid rgba(255,255,255,.06); }
.header-main .container { display: flex; align-items: center; height: 60px; gap: 20px; }

.logo         { font-size: 20px; font-weight: 800; letter-spacing: .05em; color: #fff; flex-shrink: 0; }
.logo span    { opacity: .3; }

.main-nav     { display: flex; align-items: center; gap: 0; margin-left: auto; }
.main-nav a   { font-size: 13.5px; font-weight: 500; color: rgba(255,255,255,.5); padding: 6px 12px; border-radius: 6px; transition: color .2s, background .2s; white-space: nowrap; }
.main-nav a:hover { color: #fff; background: rgba(255,255,255,.07); }
.main-nav a.activ { color: #fff; background: var(--portocaliu); }

.header-social { display: flex; align-items: center; gap: 8px; margin-right: auto; }
.header-social a { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 6px; background: rgba(255,255,255,.08); transition: background .2s; }
.header-social a:hover { background: rgba(255,255,255,.18); }
.header-social svg { fill: #fff; transition: fill .2s; }
.header-social a:hover svg { fill: #fff; }

.header-cta   { display: flex; align-items: center; gap: 7px; padding: 8px 16px; background: #fff; color: #111 !important; font-weight: 700; font-size: 13px; border-radius: 6px; flex-shrink: 0; transition: background .2s; }
.header-cta:hover { background: #eee; }
.header-cta svg { fill: #111; }

.menu-toggle  { display: none; background: none; border: none; cursor: pointer; padding: 4px; margin-left: auto; }
.menu-toggle span { display: block; width: 22px; height: 2px; background: #fff; margin: 5px 0; border-radius: 2px; transition: transform .25s, opacity .25s; }

/* ─── WHATSAPP ─── */
.wa-float { position: fixed; bottom: 24px; right: 24px; z-index: 999; width: 56px; height: 56px; background: #25D366; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(37,211,102,.4); transition: transform .2s; }
.wa-float:hover { transform: scale(1.1); }
.wa-float svg { width: 30px; height: 30px; fill: #fff; }

/* ─── BUTTONS ─── */
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 13px 26px; border-radius: 6px; font-weight: 600; font-size: 15px; font-family: var(--font); white-space: nowrap; transition: all .2s; border: 2px solid transparent; cursor: pointer; }
.btn-primar   { background: var(--portocaliu); color: #fff; border-color: var(--portocaliu); }
.btn-primar:hover { background: var(--portocaliu2); border-color: var(--portocaliu2); }
.btn-alb      { background: #fff; color: var(--negru); }
.btn-alb:hover { background: #f0f0f0; }
.btn-contur   { background: transparent; color: rgba(255,255,255,.7); border-color: rgba(255,255,255,.25); }
.btn-contur:hover { color: #fff; border-color: rgba(255,255,255,.6); }
.btn-tel      { background: #25D366; color: #fff; font-size: 16px; padding: 14px 28px; }
.btn-tel:hover { background: #1fbd5a; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(37,211,102,.35); }
.btn-portocaliu-solid { display: inline-flex; align-items: center; gap: 8px; padding: 13px 26px; border-radius: 6px; font-weight: 700; font-size: 15px; font-family: var(--font); background: var(--portocaliu); color: #fff; border: none; cursor: pointer; transition: background .2s; }
.btn-portocaliu-solid:hover { background: var(--portocaliu2); }

/* ─── HERO V2 ─── */
.hero-v2 { position: relative; height: 100vh; height: 100svh; min-height: 600px; display: flex; align-items: flex-end; padding-bottom: 88px; overflow: hidden; }
.hero-v2-bg { position: absolute; inset: 0; width: 100%; height: 100%; background-color: #111; }
.hero-video { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); min-width: 100%; min-height: 100%; width: auto; height: auto; object-fit: cover; pointer-events: none; }
.hero-v2-overlay { position: absolute; inset: 0; width: 100%; height: 100%; background: linear-gradient(135deg, rgba(0,0,0,.88) 0%, rgba(0,0,0,.6) 50%, rgba(0,0,0,.25) 100%); }
.hero-v2-inner { position: relative; z-index: 1; display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; width: 100%; }
.hero-v2-content { max-width: 680px; }
.hero-v2-eyebrow { font-size: 12px; font-weight: 700; color: var(--portocaliu); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 20px; }
.hero-v2-h1 { font-size: clamp(52px, 8.5vw, 96px); font-weight: 800; color: #fff; letter-spacing: -.04em; line-height: .93; margin-bottom: 36px; }
.hero-v2-h1 span { color: rgba(255,255,255,.3); }
.btn-hero-tel  { display: inline-flex; align-items: center; gap: 10px; padding: 15px 30px; background: var(--portocaliu); color: #fff; font-weight: 700; font-size: 18px; font-family: var(--font); border-radius: 6px; border: none; cursor: pointer; transition: background .2s; margin-right: 14px; }
.btn-hero-tel:hover { background: var(--portocaliu2); }
.btn-hero-ghost { display: inline-flex; align-items: center; font-weight: 600; font-size: 15px; color: rgba(255,255,255,.6); font-family: var(--font); transition: color .2s; }
.btn-hero-ghost:hover { color: #fff; }
/* Stat card flotant */
.hero-v2-stat { background: rgba(255,255,255,.08); backdrop-filter: blur(12px); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; padding: 24px 32px; display: flex; flex-direction: column; gap: 20px; flex-shrink: 0; }
.hvs-item strong { display: block; font-size: 28px; font-weight: 800; color: #fff; letter-spacing: -.03em; line-height: 1; }
.hvs-item strong sup { font-size: 16px; vertical-align: super; }
.hvs-item span { font-size: 12px; color: rgba(255,255,255,.4); font-weight: 500; text-transform: uppercase; letter-spacing: .08em; }

/* ─── CIFRE STRIP ─── */
.cifre-strip { background: #111; border-bottom: 1px solid rgba(255,255,255,.05); }
.cifre-strip-inner { display: grid; grid-template-columns: repeat(4, 1fr); }
.cifra-item { padding: 36px 40px; }
.cifra-item strong { display: block; font-size: clamp(34px, 4vw, 52px); font-weight: 800; color: #fff; letter-spacing: -.04em; line-height: 1; margin-bottom: 8px; }
.cifra-item strong sup { font-size: 60%; vertical-align: super; color: var(--portocaliu); }
.cifra-item span { font-size: 13px; color: rgba(255,255,255,.35); line-height: 1.5; max-width: 180px; display: block; }
.cifra-sep { width: 1px; background: rgba(255,255,255,.07); align-self: stretch; margin: 24px 0; }

/* ─── SECTIUNE HELPERS ─── */
.sectiune-label { font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--portocaliu); margin-bottom: 12px; }
.sectiune-label--alb { color: rgba(255,255,255,.4); }
.sectiune-h2 { font-size: clamp(28px, 4vw, 48px); font-weight: 800; letter-spacing: -.03em; line-height: 1.05; }
.sp-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 48px; gap: 24px; }

/* ─── PRODUSE V2 ─── */
.sectiune-produse { padding: 100px 0; }
.prod-cards-v2 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; }
.prod-card-v2 { display: flex; flex-direction: column; overflow: hidden; background: #fff; border: 1px solid var(--linie); color: inherit; transition: box-shadow .3s, transform .3s; border-radius: 4px; }
.prod-card-v2:hover { box-shadow: 0 20px 60px rgba(0,0,0,.13); transform: translateY(-6px); }
.pcv2-img { height: 300px; background-size: cover; background-position: center; position: relative; background-color: #ddd; overflow: hidden; flex-shrink: 0; }
.pcv2-img-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.25) 0%, transparent 50%); }
.pcv2-body { padding: 28px; display: flex; flex-direction: column; flex: 1; }
.pcv2-top { flex: 1; margin-bottom: 24px; }
.pcv2-top h3 { font-size: clamp(19px, 2vw, 23px); font-weight: 800; letter-spacing: -.02em; line-height: 1.2; margin-bottom: 10px; }
.pcv2-top p  { font-size: 14px; color: var(--gri); line-height: 1.65; }
.pcv2-bottom { display: flex; align-items: center; justify-content: space-between; padding-top: 20px; border-top: 1px solid var(--linie); }
.pcv2-pret   { font-size: 13px; color: var(--gri); }
.pcv2-pret strong { color: var(--negru); font-size: 17px; font-weight: 800; }
.pcv2-link   { font-size: 13px; font-weight: 700; color: var(--portocaliu); letter-spacing: .02em; }

/* ─── AVANTAJE PREMIUM (split) ─── */
.avantaje-premium { background: #111; padding: 100px 0; }
.avantaje-premium-inner { display: grid; grid-template-columns: 5fr 7fr; gap: 80px; align-items: start; }
.ap-left h2 { font-size: clamp(32px, 4.5vw, 54px); font-weight: 800; color: #fff; letter-spacing: -.04em; line-height: 1.05; margin-bottom: 20px; }
.ap-left > p { font-size: 16px; color: rgba(255,255,255,.45); line-height: 1.75; max-width: 340px; }
.ap-right { display: flex; flex-direction: column; }
.ap-row { display: grid; grid-template-columns: 40px 1fr; gap: 20px; align-items: start; padding: 24px 0; border-top: 1px solid rgba(255,255,255,.07); }
.ap-row:last-child { border-bottom: 1px solid rgba(255,255,255,.07); }
.ap-nr { font-size: 12px; font-weight: 700; color: var(--portocaliu); letter-spacing: .05em; padding-top: 3px; }
.ap-row h4 { font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 6px; }
.ap-row p  { font-size: 14px; color: rgba(255,255,255,.4); line-height: 1.7; }

/* ─── GALERIE PREMIUM ─── */
.galerie-premium { display: grid; grid-template-columns: 1.4fr 1fr 1fr; grid-template-rows: 280px 200px; gap: 4px; border-radius: 8px; overflow: hidden; }
.gp-mare  { grid-row: span 2; position: relative; overflow: hidden; display: block; }
.gp-coloana { display: contents; }
.gp-mic   { position: relative; overflow: hidden; display: block; }
.gp-lat   { position: relative; overflow: hidden; display: block; }
.gp-mare img, .gp-mic img, .gp-lat img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.gp-mare:hover img, .gp-mic:hover img, .gp-lat:hover img { transform: scale(1.05); }
.gp-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 14px 16px; background: linear-gradient(to top, rgba(0,0,0,.65), transparent); opacity: 0; transition: opacity .25s; }
.gp-mare:hover .gp-overlay, .gp-mic:hover .gp-overlay, .gp-lat:hover .gp-overlay { opacity: 1; }
.gp-overlay span { font-size: 13px; font-weight: 600; color: #fff; }

/* ─── CULORI ─── */
.sectiune { padding: 88px 0; }
.bg-light-sectiune { background: var(--light); }
.culori-row { display: flex; justify-content: flex-start; gap: 20px; flex-wrap: wrap; }
.culoare-item { display: flex; flex-direction: column; align-items: center; gap: 8px; cursor: default; }
.culoare-cerc { width: 60px; height: 60px; border-radius: 50%; box-shadow: 0 4px 16px rgba(0,0,0,.15); transition: transform .2s; }
.culoare-item:hover .culoare-cerc { transform: scale(1.12) translateY(-4px); }
.culoare-item span { font-size: 12px; font-weight: 500; color: var(--gri); }

/* ─── RECENZIE FEATURED ─── */
.recenzie-featured-wrap { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: start; }
.rf-stele { color: var(--portocaliu); font-size: 20px; letter-spacing: 3px; margin-bottom: 24px; }
.rf-citat { font-size: clamp(18px, 2.2vw, 26px); font-weight: 500; color: var(--negru); line-height: 1.5; letter-spacing: -.01em; font-style: normal; margin-bottom: 24px; }
.rf-autor { font-size: 14px; font-weight: 700; color: var(--gri); }
.rf-mici  { display: flex; flex-direction: column; gap: 16px; }
.recenzie-mica { background: var(--light); border-radius: 10px; padding: 24px; border: 1px solid var(--linie); }
.rm-stele { color: var(--portocaliu); font-size: 14px; letter-spacing: 2px; margin-bottom: 10px; }
.recenzie-mica p { font-size: 15px; color: #333; line-height: 1.7; margin-bottom: 12px; }
.recenzie-mica span { font-size: 13px; color: var(--gri); font-weight: 600; }

/* ─── CTA TELEFON ─── */
.cta-telefon { background: #111; padding: 112px 0; text-align: center; }
.cta-telefon-inner { display: flex; flex-direction: column; align-items: center; }
.ct-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: rgba(255,255,255,.3); margin-bottom: 20px; }
.ct-numar { font-size: clamp(44px, 8.5vw, 96px); font-weight: 800; color: #fff; letter-spacing: -.04em; line-height: 1; margin-bottom: 16px; transition: color .2s; }
.ct-numar:hover { color: var(--portocaliu); }
.ct-sub { font-size: 15px; color: rgba(255,255,255,.3); }

/* ─── FOOTER ─── */
.site-footer { background: #0a0a0a; }
.footer-top { padding: 64px 0; display: grid; grid-template-columns: 1.7fr 1fr 1fr 1fr; gap: 48px; }
.footer-brand .logo { display: inline-block; margin-bottom: 16px; font-size: 20px; }
.footer-brand p { font-size: 14px; color: rgba(255,255,255,.3); line-height: 1.75; max-width: 260px; }
.footer-tel { margin-top: 20px; font-size: 18px; font-weight: 700; color: #fff; display: flex; align-items: center; gap: 8px; }
.footer-tel svg { width: 16px; height: 16px; fill: currentColor; }
.footer-col h5 { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.2); margin-bottom: 18px; }
.footer-col a { display: block; font-size: 14px; color: rgba(255,255,255,.4); padding: 4px 0; transition: color .2s; }
.footer-col a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.05); padding: 20px 0; display: flex; justify-content: space-between; align-items: center; font-size: 13px; color: rgba(255,255,255,.18); }
.footer-social { display: flex; gap: 12px; }
.footer-social a { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 8px; background: rgba(255,255,255,.07); transition: background .2s; }
.footer-social a:hover { background: rgba(255,255,255,.15); }
.footer-social svg { fill: #fff; transition: fill .2s; }
.footer-social a:hover svg { fill: #fff; }

/* ─── BREADCRUMB ─── */
.breadcrumb { padding: 12px 0; border-bottom: 1px solid var(--linie); font-size: 13px; color: var(--gri); }
.breadcrumb a { color: var(--gri); }
.breadcrumb a:hover { color: #111; }
.breadcrumb .sep { margin: 0 6px; }

/* ─── PAGINI PRODUS ─── */
.prod-hero { background: #111; padding: 80px 0; }
.prod-hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.prod-hero h1 { font-size: clamp(30px, 4.5vw, 52px); font-weight: 800; color: #fff; letter-spacing: -.03em; margin-bottom: 18px; line-height: 1.05; }
.prod-hero p  { font-size: 17px; color: rgba(255,255,255,.5); line-height: 1.75; margin-bottom: 32px; }
.prod-hero-img { aspect-ratio: 4/3; border-radius: 10px; overflow: hidden; background: #2a2a2a; }
.prod-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.pret-badge { display: inline-flex; align-items: center; gap: 8px; background: var(--portocaliu); color: #fff; font-size: 20px; font-weight: 800; padding: 10px 22px; border-radius: 6px; margin-bottom: 28px; }
.pret-badge small { font-size: 13px; font-weight: 400; opacity: .75; }

.specs-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 3px; background: var(--linie); border: 1px solid var(--linie); border-radius: 10px; overflow: hidden; margin-bottom: 56px; }
.spec-row { background: #fff; padding: 16px 22px; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.spec-label { font-size: 13px; color: var(--gri); font-weight: 500; }
.spec-val   { font-size: 14px; font-weight: 700; text-align: right; }

.galerie-produs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; border-radius: 10px; overflow: hidden; }
.galerie-produs-item { aspect-ratio: 4/3; overflow: hidden; background: #ddd; }
.galerie-produs-item img { transition: transform .4s; }
.galerie-produs-item:hover img { transform: scale(1.04); }

/* ─── CTA FINAL (pagini produse) ─── */
.cta-final { background: #111; padding: 80px 0; }
.cta-final-inner { display: flex; align-items: center; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.cta-final h2 { font-size: clamp(22px, 3.5vw, 36px); font-weight: 800; color: #fff; margin-bottom: 8px; letter-spacing: -.02em; }
.cta-final p  { font-size: 15px; color: rgba(255,255,255,.4); }
.cta-final-btns { display: flex; gap: 14px; flex-wrap: wrap; flex-shrink: 0; }
.btn-alb { background: #fff; color: var(--negru); display: inline-flex; align-items: center; gap: 8px; padding: 13px 26px; border-radius: 6px; font-weight: 700; font-size: 15px; font-family: var(--font); border: 2px solid transparent; transition: background .2s; }
.btn-alb:hover { background: #eee; }

/* ─── SECTIUNE TITLU (alte pagini) ─── */
.sectiune-titlu { text-align: center; margin-bottom: 52px; }
.sectiune-titlu h2 { font-size: clamp(26px, 4vw, 40px); font-weight: 800; letter-spacing: -.02em; margin-bottom: 12px; }
.sectiune-titlu p  { font-size: 17px; color: var(--gri); max-width: 540px; margin: 0 auto; line-height: 1.7; }

/* ─── GALERIE PAGE ─── */
.galerie-grid-full { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.galerie-grid-full .gal-item { aspect-ratio: 3/4; overflow: hidden; position: relative; border-radius: 6px; cursor: pointer; background: #ddd; }
.galerie-grid-full .gal-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s; }
.galerie-grid-full .gal-item:hover img { transform: scale(1.05); }
.galerie-grid-full .gal-item .gal-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 16px; background: linear-gradient(to top, rgba(0,0,0,.7), transparent); opacity: 0; transition: opacity .25s; }
.galerie-grid-full .gal-item:hover .gal-overlay { opacity: 1; }
.galerie-grid-full .gal-item .gal-overlay p { font-size: 14px; font-weight: 600; color: #fff; }
.galerie-grid-full .gal-item .gal-overlay span { font-size: 12px; color: rgba(255,255,255,.65); }
.gf-btn.activ { background: var(--portocaliu) !important; color: #fff !important; border-color: var(--portocaliu) !important; }

/* ─── CONTACT PAGE ─── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 72px; align-items: start; }
.contact-info-bloc h2 { font-size: clamp(26px, 3.5vw, 38px); font-weight: 800; letter-spacing: -.02em; margin-bottom: 14px; }
.contact-info-bloc > p { font-size: 16px; color: var(--gri); line-height: 1.75; margin-bottom: 36px; }
.contact-links { display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px; }
.contact-link { display: flex; align-items: center; gap: 14px; padding: 16px 18px; border: 1px solid var(--linie); border-radius: 8px; color: inherit; transition: border-color .2s, background .2s; }
.contact-link:hover { border-color: #111; background: var(--light); }
.contact-link svg { width: 20px; height: 20px; fill: var(--gri); flex-shrink: 0; }
.contact-link span  { font-size: 12px; color: var(--gri); display: block; text-transform: uppercase; letter-spacing: .07em; font-weight: 600; margin-bottom: 2px; }
.contact-link strong { font-size: 16px; }
.form-card { background: var(--light); border: 1px solid var(--linie); border-radius: 12px; padding: 40px; display: flex; flex-direction: column; gap: 16px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 5px; }
.form-group label { font-size: 13px; font-weight: 600; }
.form-group input, .form-group select, .form-group textarea { padding: 12px 14px; border: 1.5px solid var(--linie); border-radius: 6px; font-family: var(--font); font-size: 15px; color: var(--negru); background: #fff; outline: none; width: 100%; resize: vertical; transition: border-color .2s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--portocaliu); }
.form-group input::placeholder, .form-group textarea::placeholder { color: #bbb; }
.form-success { display: none; align-items: center; gap: 10px; padding: 14px 16px; background: #fff; border: 1px solid var(--linie); border-radius: 6px; font-size: 14px; font-weight: 600; }
.form-success.show { display: flex; }
.btn.btn-primar[style*="width:100%"] { justify-content: center; }

/* ─── CONFIGURATOR ─── */
.config-promo { background: var(--portocaliu); border-radius: 12px; padding: 40px 48px; display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.config-promo h3 { font-size: 22px; font-weight: 800; color: #fff; margin-bottom: 6px; }
.config-promo p  { font-size: 15px; color: rgba(255,255,255,.8); }

/* ─── VIDEO / TIKTOK GRID ─── */
.tt-grid {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: nowrap;
}
.tt-card {
  flex: 0 0 auto;
  width: 260px;
  height: 462px; /* 9:16 */
  border-radius: 16px;
  overflow: hidden;
  background: #161823;
  box-shadow: 0 12px 40px rgba(0,0,0,.7);
  position: relative;
}
.tt-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media (max-width: 900px) {
  .tt-card { width: 210px; height: 373px; }
}
@media (max-width: 640px) {
  .tt-grid {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  .tt-card {
    width: min(320px, calc(100vw - 40px));
    height: calc(min(320px, calc(100vw - 40px)) * 16 / 9);
    border-radius: 12px;
  }
}

/* ─── RESPONSIVE ─── */

/* Tablet landscape / small desktop */
@media (max-width: 960px) {
  .main-nav, .header-cta { display: none; }
  .header-social a { width: 34px; height: 34px; }
  .main-nav.deschis { display: flex; flex-direction: column; position: fixed; inset: 0; top: 105px; background: #111; padding: 24px; gap: 2px; z-index: 199; overflow-y: auto; }
  .main-nav.deschis a { font-size: 17px; padding: 13px 16px; border-bottom: 1px solid rgba(255,255,255,.07); }
  .menu-toggle { display: block; }
  .hero-v2-stat { display: none; }
  .cifre-strip-inner { grid-template-columns: 1fr 1fr; }
  .cifra-sep { display: none; }
  .prod-cards-v2 { grid-template-columns: repeat(2, 1fr); max-width: 100%; margin: 0; }
  .avantaje-premium-inner { grid-template-columns: 1fr; gap: 40px; }
  .ap-left > p, .ap-left .btn-portocaliu-solid { display: none; }
  .galerie-premium { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .gp-mare { grid-column: span 2; height: 280px; }
  .gp-lat, .gp-mic { height: 200px; }
  .recenzie-featured-wrap { grid-template-columns: 1fr; }
  .ct-numar { font-size: clamp(36px, 8vw, 64px); }
  .cta-final-inner { flex-direction: column; text-align: center; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-brand { grid-column: span 2; }
  .prod-hero-inner { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .sp-header { flex-direction: column; }
}

/* Tablet portrait */
@media (max-width: 768px) {
  .prod-cards-v2 { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
  .galerie-grid-full { grid-template-columns: 1fr 1fr; }
  .galerie-produs { grid-template-columns: 1fr 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .hero-v2-actions { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
  .btn-hero-tel { margin-right: 0; }
}

/* Mobile */
@media (max-width: 600px) {
  .container { padding: 0 16px; max-width: 100%; }
  .sectiune { padding: 56px 0; }
  .sectiune-produse { padding: 56px 0; }
  .avantaje-premium { padding: 64px 0; }
  .cifre-strip-inner { grid-template-columns: 1fr 1fr; }
  .cifra-item { padding: 20px 16px; }
  .cifra-item strong { font-size: clamp(28px, 8vw, 42px); }
  .specs-grid { grid-template-columns: 1fr; }
  .galerie-produs { grid-template-columns: 1fr 1fr; }
  .galerie-grid-full { grid-template-columns: 1fr 1fr; }
  .footer-top { grid-template-columns: 1fr; }
  .footer-brand { grid-column: span 1; }
  .footer-bottom { flex-direction: column; gap: 6px; text-align: center; }
  .form-row { grid-template-columns: 1fr; }
  .cta-final-btns { flex-direction: column; width: 100%; }
  .cta-final-btns .btn, .cta-final-btns .btn-alb { justify-content: center; }
  .ht-left { display: none; }
  .galerie-premium { grid-template-columns: 1fr; }
  .gp-mare { grid-column: span 1; height: 240px; }
  .gp-lat, .gp-mic { height: 180px; }
  .config-promo { padding: 28px 20px; }
  .hero-v2 { height: 100vh; height: 100svh; min-height: 560px; padding-bottom: 60px; align-items: flex-end; }
  .hero-video { width: 100%; height: 100%; min-width: unset; min-height: unset; top: 0; left: 0; transform: none; object-fit: cover; }
  .hero-v2-h1 { font-size: clamp(36px, 11vw, 56px); line-height: 1; }
  .hero-v2-eyebrow { font-size: 11px; }
  .culoare-cerc { width: 48px; height: 48px; }
  .culori-row { gap: 12px; }
  .prod-cards-v2 { max-width: 100%; }
  .masuratori-grid { grid-template-columns: 1fr !important; }
  /* Collapse inline 2-col grids in product pages */
  section .container > div[style*="grid-template-columns:1fr 1fr"],
  section .container > div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  section .container > div[style*="grid-template-columns:1fr 1fr"] img,
  section .container > div[style*="grid-template-columns: 1fr 1fr"] img {
    height: auto !important;
  }
}

@media (max-width: 420px) {
  .cifre-strip-inner { grid-template-columns: 1fr; }
  .galerie-grid-full { grid-template-columns: 1fr; }
  .galerie-produs { grid-template-columns: 1fr; }
  .recenzie-featured-wrap { gap: 24px; }
}
