/* ============================================================
   FLORSIMINTEX · components.css
   Layout-ul secțiunilor. Folosește tokenii din base.css / teme.
   ============================================================ */

/* ---------------- HERO ---------------- */
.hero{position:relative;min-height:clamp(560px,90vh,860px);display:flex;align-items:flex-end;
  padding-block:clamp(40px,8vh,90px);overflow:hidden;isolation:isolate}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.hero-overlay{position:absolute;inset:0;z-index:-1;background:var(--hero-grad)}
.hero-inner{position:relative;max-width:760px}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.16em;font-size:.78rem;color:#fff;background:color-mix(in srgb,var(--accent) 92%,#000);
  padding:.5em 1em;border-radius:999px;margin-bottom:1.4rem}
.ping{width:9px;height:9px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:ping 1.8s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 12px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.hero h1{font-family:var(--font-display);text-transform:uppercase;color:#fff;
  font-size:clamp(2.7rem,1.4rem + 7vw,6rem);letter-spacing:.01em;text-shadow:0 6px 30px rgba(0,0,0,.5)}
.hero h1 em{font-style:normal;color:var(--accent2);-webkit-text-stroke:0}
.hero .lead{color:#e7e9ec;font-size:clamp(1.05rem,1rem + .5vw,1.3rem);max-width:54ch;margin:1.3rem 0 2rem;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:1.8rem}
.hero-actions .btn{font-size:1.06rem;padding:1em 1.5em}
.hero-chips{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;color:#fff}
.hero-chips li{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.92rem;text-shadow:0 2px 10px rgba(0,0,0,.7)}
.hero-chips svg{width:18px;height:18px;fill:none;stroke:var(--accent2);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}

/* ---------------- TICKER ---------------- */
.ticker{background:var(--accent);color:var(--accent-ink);overflow:hidden;border-block:3px solid color-mix(in srgb,var(--accent) 60%,#000);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.ticker-track{display:flex;gap:0;width:max-content;animation:scroll 32s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track span{display:inline-flex;align-items:center;gap:.5rem;padding:.7em 1.6em;font-family:var(--font-display);
  font-size:1.15rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.ticker-track span svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.4;opacity:.7}
.ticker-track span::after{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.4;margin-left:1.4em}
@keyframes scroll{to{transform:translateX(-33.333%)}}

/* ---------------- STATS ---------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,28px);
  margin-top:clamp(48px,7vw,76px);margin-bottom:clamp(8px,2vw,20px)}
.stat{text-align:center;padding:18px 8px}
.stat b{display:block;font-family:var(--font-display);font-size:clamp(2.4rem,1.5rem + 3.6vw,4.4rem);
  line-height:1;color:var(--accent);letter-spacing:.01em}
.stat span{display:block;color:var(--muted);font-size:.86rem;margin-top:.5rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600}

/* ---------------- SERVICII ---------------- */
.services{display:grid;gap:clamp(16px,2vw,24px);grid-template-columns:repeat(auto-fit,minmax(290px,1fr))}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;position:relative}
.card:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--accent) 50%,var(--line));box-shadow:var(--shadow)}
.card-media{aspect-ratio:16/10;overflow:hidden;background:var(--surface2)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card-media img{transform:scale(1.06)}
.card-body{padding:24px;display:flex;flex-direction:column;flex:1;gap:.5rem}
.card-ico{display:grid;place-items:center;width:54px;height:54px;border-radius:13px;margin-bottom:.4rem;
  background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.card-ico svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.card-tag{font-size:.7rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--accent2)}
.card h3{font-family:var(--font-display);font-size:1.5rem;text-transform:uppercase;letter-spacing:.01em}
.card p{color:var(--muted);font-size:.96rem;flex:1}
.card-link{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--text);margin-top:.4rem;align-self:flex-start}
.card-link svg{width:18px;height:18px;fill:none;stroke:var(--accent);stroke-width:2.4;transition:transform .25s var(--ease)}
.card-link:hover{color:var(--accent)}
.card-link:hover svg{transform:translateX(5px)}

/* ---------------- FEATURE / DE CE NOI ---------------- */
.feature{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(30px,5vw,70px);align-items:center}
.feature-media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.feature-media img{width:100%;aspect-ratio:3/4;object-fit:cover}
.feature-badge{position:absolute;left:18px;bottom:18px;display:flex;align-items:center;gap:.7rem;
  background:var(--accent);color:var(--accent-ink);padding:.8rem 1.1rem;border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.4)}
.feature-badge svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2.2}
.feature-badge b{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.04em;display:block;line-height:1}
.feature-badge span{font-size:.74rem;opacity:.85}
.why{display:grid;gap:1.3rem;margin:2rem 0}
.why li{display:flex;gap:1rem}
.why-ico{flex:none;display:grid;place-items:center;width:48px;height:48px;border-radius:12px;
  background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.why-ico svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.why b{font-size:1.1rem;display:block;margin-bottom:.15rem}
.why p{color:var(--muted);font-size:.95rem}

/* ---------------- ACOPERIRE ---------------- */
.areas{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:2.4rem}
.area-pill{display:inline-flex;align-items:center;gap:.45rem;padding:.6em 1.1em;border-radius:999px;
  border:1px solid var(--line);background:var(--surface);font-weight:600;transition:.25s}
.area-pill:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.area-pill svg{width:16px;height:16px;fill:none;stroke:var(--accent);stroke-width:2}
.map-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:clamp(20px,3vw,30px)}
.map-cta b{font-size:1.15rem}
.map-cta span{display:block;color:var(--muted);font-size:.92rem}

/* ---------------- RECENZII ---------------- */
.rating-line{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem .6rem;margin-top:1rem;color:var(--muted)}
.rating-line b{color:var(--text)}
.stars{display:inline-flex;gap:2px}
.stars .star{width:18px;height:18px;fill:var(--accent2);stroke:none}
.stars .star.off{fill:color-mix(in srgb,var(--muted) 40%,transparent)}
.reviews{display:grid;gap:clamp(16px,2vw,22px);grid-template-columns:repeat(auto-fit,minmax(270px,1fr))}
.review{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:26px;display:flex;flex-direction:column;gap:1rem}
.review .stars .star{width:20px;height:20px}
.review blockquote{font-size:1.1rem;line-height:1.55;flex:1}
.review figcaption{display:flex;align-items:center;gap:.7rem}
.avatar{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:var(--accent);
  color:var(--accent-ink);font-weight:800;font-size:1.1rem;flex:none}
.review figcaption b{display:block}
.review figcaption i{font-style:normal;color:var(--muted);font-size:.85rem}

/* ---------------- CONTACT ---------------- */
.contact-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,60px);align-items:start}
.contact-actions{display:flex;flex-wrap:wrap;gap:14px;margin:1.8rem 0}
.contact-actions .btn{font-size:1.06rem;padding:1em 1.5em}
.contact-list{display:grid;gap:.9rem}
.contact-list li{display:flex;align-items:center;gap:.8rem;color:var(--muted)}
.contact-list svg{width:22px;height:22px;fill:none;stroke:var(--accent);stroke-width:2;flex:none}
.hours{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:clamp(22px,3vw,32px)}
.hours h3{font-family:var(--font-display);font-size:1.6rem;text-transform:uppercase;margin-bottom:1rem}
.hours table{width:100%;border-collapse:collapse}
.hours td{padding:.85rem 0;border-bottom:1px solid var(--line);font-size:.96rem;vertical-align:top}
.hours td:last-child{text-align:right;color:var(--muted);font-weight:600;white-space:nowrap;padding-left:14px}
.hours td.hl{color:var(--accent);font-family:var(--font-display);letter-spacing:.05em;font-size:1.05rem}
.hours tr:last-child td{border-bottom:0}
.hours-note{display:flex;align-items:center;gap:.6rem;margin-top:1.1rem;color:var(--muted);font-size:.88rem}
.hours-note svg{width:20px;height:20px;fill:none;stroke:var(--accent);stroke-width:2;flex:none}

/* ---------------- DOCK (butoane flotante mobil) ---------------- */
.dock{position:fixed;right:16px;bottom:16px;z-index:90;display:flex;flex-direction:column;gap:12px}
.dock-btn{display:grid;place-items:center;width:58px;height:58px;border-radius:50%;box-shadow:0 10px 30px rgba(0,0,0,.45);
  transition:transform .2s var(--ease)}
.dock-btn svg{width:30px;height:30px;fill:currentColor}
.dock-btn:hover{transform:scale(1.08)}
.dock-call{background:var(--accent);color:var(--accent-ink)}
.dock-call svg{width:26px;height:26px}
.dock-wa{background:var(--wa);color:#fff;animation:bob 2.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.dock-wa::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 var(--wa);animation:ping2 2.4s infinite}
.dock-wa{position:relative}
@keyframes ping2{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--wa) 70%,transparent)}70%{box-shadow:0 0 0 16px transparent}100%{box-shadow:0 0 0 0 transparent}}
@media (min-width:881px){.dock{right:24px;bottom:24px}}

/* ---------------- RESPONSIVE ---------------- */
@media (max-width:880px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .feature{grid-template-columns:1fr}
  .feature-media{max-width:440px;margin-inline:auto;order:-1}
  .contact-inner{grid-template-columns:1fr}
}
@media (max-width:480px){
  .hero-actions .btn{width:100%;justify-content:center}
}

/* ============================================================
   UPGRADE UI — hero cinematic, semnătură, carduri, hartă,
   carusel recenzii, bară de apel mobil
   ============================================================ */

/* ---------------- HERO: far care mătură (o singură dată) ---------------- */
.hero-sweep{position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(74deg,transparent 32%,color-mix(in srgb,var(--accent2) 60%,transparent) 46%,rgba(255,255,255,.10) 50%,transparent 64%);
  transform:translateX(-130%);animation:heroSweep 2.3s var(--ease) .35s 1 both}
@keyframes heroSweep{to{transform:translateX(130%)}}

/* ---------------- SEMNĂTURĂ: banda hazard = progres de citire ---------------- */
.chevron-bar{position:relative;overflow:hidden}
.chevron-bar__fill{position:absolute;inset:0 100% 0 0;display:block;
  background:repeating-linear-gradient(-45deg,var(--accent) 0 16px,#f3f3f0 16px 32px);
  background-size:45px 100%;will-change:right,background-position;transition:right .12s linear}

/* ---------------- CARD: spotlight care urmărește cursorul + placeholder ---------------- */
.card{transform-style:preserve-3d;will-change:transform}
.card-glow{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0;transition:opacity .35s var(--ease);
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),color-mix(in srgb,var(--accent) 22%,transparent),transparent 62%)}
.card:hover .card-glow{opacity:1}
.card-body{position:relative;z-index:2}
.card-media--ph{display:grid;place-items:center;position:relative;
  background:radial-gradient(120% 120% at 70% 10%,color-mix(in srgb,var(--accent) 12%,var(--surface2)),var(--surface2))}
.card-media--ph .ph-ico{display:grid;place-items:center;opacity:.9}
.card-media--ph .ph-ico svg{width:88px;height:88px;fill:none;stroke:var(--accent);stroke-width:1.6;
  stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 8px 18px rgba(0,0,0,.4))}

/* ---------------- STATS: panou tip bord de mașină ---------------- */
.stats{position:relative}
.stat b{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* ---------------- HARTĂ încorporată ---------------- */
.map-embed{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  margin-bottom:18px;box-shadow:var(--shadow);background:var(--surface)}
.map-embed iframe{display:block;width:100%;height:clamp(260px,38vw,400px);border:0;
  filter:grayscale(.35) contrast(1.05) brightness(.92)}
.map-embed .map-pin{position:absolute;left:50%;top:46%;transform:translate(-50%,-100%);pointer-events:none;
  color:var(--accent);filter:drop-shadow(0 6px 10px rgba(0,0,0,.5))}
.map-embed .map-pin svg{width:34px;height:34px;fill:var(--accent);stroke:#fff;stroke-width:1.4}

/* ---------------- RECENZII: carusel mobil + dots + link Google ---------------- */
.rating-link{color:var(--accent);font-weight:700;white-space:nowrap;border-bottom:1px solid color-mix(in srgb,var(--accent) 50%,transparent)}
.rating-link:hover{color:var(--text);border-color:currentColor}
.review-dots{display:none}
.reviews-all{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.6rem;font-weight:700;color:var(--text);
  border:1px solid var(--line);padding:.7em 1.2em;border-radius:999px;transition:.25s}
.reviews-all svg{width:18px;height:18px;fill:var(--accent2);stroke:none}
.reviews-all:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

@media (max-width:720px){
  .reviews{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;
    gap:14px;scroll-padding-inline:var(--pad);
    margin-inline:calc(var(--pad) * -1);padding-inline:var(--pad);padding-bottom:6px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .reviews::-webkit-scrollbar{display:none}
  .review{flex:0 0 84%;scroll-snap-align:center}
  .review-dots{display:flex;gap:8px;justify-content:center;margin-top:18px}
  .review-dots .dot{width:8px;height:8px;padding:0;border-radius:50%;
    background:color-mix(in srgb,var(--muted) 45%,transparent);transition:width .25s var(--ease),background .25s}
  .review-dots .dot[aria-current="true"]{background:var(--accent);width:24px;border-radius:5px}
}

/* ---------------- BARĂ FIXĂ DE APEL (mobil) ---------------- */
.callbar{display:none}
@media (max-width:880px){
  .callbar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;
    box-shadow:0 -8px 28px rgba(0,0,0,.45);padding-bottom:env(safe-area-inset-bottom)}
  .callbar-call{flex:1;display:flex;align-items:center;justify-content:center;gap:.55rem;
    background:var(--accent);color:#fff;font-family:var(--font-display);letter-spacing:.04em;
    text-transform:uppercase;font-size:1.12rem;padding:1.05em 1em}
  .callbar-call svg{width:22px;height:22px;fill:currentColor}
  .callbar-wa{flex:none;display:grid;place-items:center;width:66px;background:var(--wa);color:#fff}
  .callbar-wa svg{width:30px;height:30px;fill:currentColor}
  .dock{display:none}
  body{padding-bottom:62px}
}

/* ============================================================
   UPGRADE v2 — picture, GPS, facade hartă, pași, despre, galerie, FAQ
   ============================================================ */

/* <picture> umple containerele media exact ca <img> înainte */
.hero-media picture,.card-media picture,.feature-media picture,.shot picture{display:block;width:100%;height:100%}
.hero-media picture img{width:100%;height:100%;object-fit:cover;object-position:center 38%}
.card-media picture img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.feature-media picture img{width:100%;aspect-ratio:3/4;object-fit:cover}

/* buton „Sunt blocat aici" (GPS) */
.btn-loc{color:#fff;border-color:color-mix(in srgb,#fff 35%,transparent);background:color-mix(in srgb,#000 25%,transparent)}
.btn-loc svg{fill:none;stroke:var(--accent2);stroke-width:2}
.btn-loc:hover{border-color:var(--accent2);color:var(--accent2)}
.contact .btn-loc{color:var(--text);background:transparent;border-color:var(--line)}
.btn-loc.loc-loading{opacity:.7;pointer-events:none}
.btn-loc.loc-loading span{visibility:hidden}
.btn-loc.loc-loading::after{content:"";position:absolute;width:18px;height:18px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}
.btn-loc{position:relative}
@keyframes spin{to{transform:rotate(360deg)}}

/* facade hartă (înlocuiește iframe-ul până la click) */
.map-facade{cursor:pointer;display:flex;align-items:center;gap:1rem;min-height:clamp(180px,26vw,260px);
  padding:clamp(20px,4vw,34px);position:relative;overflow:hidden;background:var(--surface)}
.map-facade-grid{position:absolute;inset:0;opacity:.5;
  background:
    linear-gradient(0deg,transparent 95%,color-mix(in srgb,var(--accent) 25%,transparent) 95%) 0 0/100% 28px,
    linear-gradient(90deg,transparent 95%,color-mix(in srgb,var(--accent) 12%,transparent) 95%) 0 0/28px 100%}
.map-facade-pin{position:relative;display:grid;place-items:center;width:60px;height:60px;flex:none;border-radius:50%;
  background:var(--accent);color:#fff;box-shadow:0 10px 24px -8px var(--accent)}
.map-facade-pin svg{width:32px;height:32px;fill:#fff;stroke:#fff}
.map-facade-txt{position:relative}
.map-facade-txt b{font-family:var(--font-display);font-size:1.4rem;text-transform:uppercase;letter-spacing:.02em;display:block}
.map-facade-txt span{color:var(--muted);font-size:.92rem}
.map-facade:hover .map-facade-pin{transform:scale(1.06)}
.map-facade:focus-visible{outline:3px solid var(--accent);outline-offset:3px}

/* CUM FUNCȚIONEAZĂ — 3 pași */
.steps{display:grid;gap:clamp(16px,2.5vw,26px);grid-template-columns:repeat(3,1fr);counter-reset:none;list-style:none}
.step{position:relative;display:flex;gap:1rem;align-items:flex-start;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:clamp(20px,3vw,28px)}
.step-no{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,3.4rem);line-height:.8;color:var(--accent);flex:none;
  -webkit-text-stroke:0;letter-spacing:.01em}
.step h3{font-family:var(--font-display);font-size:1.3rem;text-transform:uppercase;margin-bottom:.3rem}
.step p{color:var(--muted);font-size:.96rem}
@media (max-width:780px){.steps{grid-template-columns:1fr}}

/* DESPRE — feature inversat (text stânga, media dreapta) */
.feature-rev .feature-media{order:0}
.about-p{color:var(--muted);font-size:1.05rem;margin-bottom:1.1rem;max-width:54ch}
.about-p:first-of-type{color:var(--text)}

/* GALERIE */
.gallery{display:grid;gap:clamp(12px,1.6vw,18px);grid-template-columns:repeat(3,1fr)}
.shot{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:var(--surface2)}
.shot picture img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.shot:hover picture img{transform:scale(1.07)}
.shot figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem .9rem .7rem;font-size:.85rem;font-weight:600;color:#fff;
  background:linear-gradient(0deg,rgba(0,0,0,.82),transparent);transform:translateY(0);transition:.3s}
@media (max-width:1000px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.gallery{grid-template-columns:1fr}}

/* FAQ */
.faq{display:grid;gap:12px;max-width:820px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:clamp(16px,2.4vw,22px);font-weight:700;font-size:1.06rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-ico{position:relative;flex:none;width:20px;height:20px}
.faq-ico::before,.faq-ico::after{content:"";position:absolute;background:var(--accent);border-radius:2px;transition:transform .25s var(--ease)}
.faq-ico::before{left:0;right:0;top:9px;height:2px}
.faq-ico::after{top:0;bottom:0;left:9px;width:2px}
.faq-item[open] .faq-ico::after{transform:scaleY(0)}
.faq-item[open] summary{color:var(--accent)}
.faq-a{padding:0 clamp(16px,2.4vw,22px) clamp(16px,2.4vw,22px)}
.faq-a p{color:var(--muted)}

/* perf: sari rendering-ul secțiunilor lungi de jos până aproape de viewport */
#galerie,#faq{content-visibility:auto;contain-intrinsic-size:auto 760px}

/* ============================================================
   FOOTER LEGAL · BANNER COOKIE · PAGINI LEGALE
   ============================================================ */

/* linkuri legale în footer */
.foot-links{display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;margin-top:1rem;width:100%}
.foot-links a{color:var(--muted);font-size:.86rem;text-decoration:none;border-bottom:1px solid transparent;transition:.2s}
.foot-links a:hover{color:var(--text);border-bottom-color:var(--accent)}

/* banner cookie — jos, discret, peste callbar pe mobil */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:80;
  background:color-mix(in srgb,var(--surface) 96%,#000);border-top:1px solid var(--line);
  box-shadow:0 -10px 40px rgba(0,0,0,.45);
  transform:translateY(110%);transition:transform .35s var(--ease);
  padding:max(14px,env(safe-area-inset-bottom)) 16px 14px}
.cookie-banner.show{transform:translateY(0)}
.cookie-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cookie-txt{flex:1 1 380px;margin:0;color:var(--muted);font-size:.9rem;line-height:1.5}
.cookie-txt strong{color:var(--text)}
.cookie-txt a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.cookie-btns{display:flex;gap:10px;flex:none}
.cookie-btns .btn{padding:.6em 1.2em;font-size:.9rem}
@media (max-width:760px){
  .cookie-banner{bottom:64px}            /* deasupra barei „Sun.A cum" de pe mobil */
  .cookie-btns{flex:1 1 100%}
  .cookie-btns .btn{flex:1}
}
@media (prefers-reduced-motion:reduce){.cookie-banner{transition:none}}

/* pagini legale — proză lizibilă pe fundal închis */
.legal-page{padding-bottom:0}
.legal-wrap{padding:clamp(90px,12vh,130px) 0 70px}
.legal-back a{display:inline-flex;align-items:center;gap:.45rem;color:var(--muted);text-decoration:none;font-weight:600;font-size:.92rem}
.legal-back a:hover{color:var(--text)}
.legal-back svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2.4;transform:scaleX(-1)}
.legal-wrap h1{font-family:var(--font-display);font-size:clamp(2.1rem,6vw,3.4rem);line-height:1;letter-spacing:.012em;margin:1.2rem 0 .6rem}
.legal-lead{color:var(--text);font-size:1.1rem;max-width:62ch;margin:0 0 .4rem}
.legal-updated{color:var(--muted);font-size:.85rem;margin:0 0 2.4rem}
.legal-body{max-width:74ch}
.legal-body h2{font-size:1.25rem;margin:2.2rem 0 .7rem;letter-spacing:.01em}
.legal-body p,.legal-body li{color:var(--muted);line-height:1.7}
.legal-body p{margin:0 0 1rem}
.legal-body ul{margin:0 0 1.2rem;padding-left:1.2rem;display:grid;gap:.5rem}
.legal-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.legal-body strong{color:var(--text)}
.legal-body code{background:var(--surface2);border:1px solid var(--line);border-radius:5px;padding:.08em .4em;font-size:.88em}
.legal-table{width:100%;border-collapse:collapse;margin:0 0 1.4rem;font-size:.92rem}
.legal-table th,.legal-table td{text-align:left;padding:.7em .8em;border:1px solid var(--line);vertical-align:top}
.legal-table th{background:var(--surface2);color:var(--text);font-weight:700}
.legal-table td{color:var(--muted)}
@media (max-width:600px){.legal-table,.legal-table tbody,.legal-table tr,.legal-table td,.legal-table th{display:block}
  .legal-table thead{display:none}
  .legal-table tr{margin-bottom:.8rem;border:1px solid var(--line);border-radius:8px;overflow:hidden}
  .legal-table td{border:0;border-bottom:1px solid var(--line)}
  .legal-table td:last-child{border-bottom:0}}

/* bannere ANPC (SAL + SOL/ODR) — protecția consumatorului */
.foot-anpc{display:flex;flex-wrap:wrap;gap:10px;margin-top:1rem;width:100%}
.anpc-badge{display:inline-flex;align-items:stretch;border:1px solid var(--line);border-radius:8px;overflow:hidden;
  text-decoration:none;background:var(--surface);transition:.2s;max-width:340px}
.anpc-badge:hover{border-color:var(--accent);transform:translateY(-2px)}
.anpc-k{display:grid;place-items:center;padding:.45em .7em;background:var(--accent);color:#fff;font-family:var(--font-display);font-size:.85rem;letter-spacing:.04em}
.anpc-v{display:grid;align-items:center;padding:.45em .75em;color:var(--muted);font-size:.78rem;line-height:1.2}
