/* ==== FONTS (Ceresit) – adăugare, nu înlocuire ==== */
@font-face{
  font-family:"Futura Ceresit";
  src:url("/assets/fonts/Futura_Bold.woff") format("woff");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Futura Ceresit";
  src:url("/assets/fonts/Futura_Book_Regular.woff") format("woff");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Futura Ceresit Condensed";
  src:url("/assets/fonts/Futura_Condensed_Bold.woff") format("woff");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Futura Ceresit Condensed";
  src:url("/assets/fonts/Futura_Condensed_Regular.woff") format("woff");
  font-weight:400; font-style:normal; font-display:swap;
}
.font-condensed{ font-family:"Futura Ceresit Condensed","Helvetica","Arial",system-ui,-apple-system,sans-serif; }
/* Headline-uri mari – păstrăm fontul Condensed */
.h1,
h1,
.h2,
h2{
  font-weight:700;
  font-family:var(--font-head);
}

/* Titluri mici și carduri – folosesc fontul de body (cu diacritice corecte) */
.h3,
h3{
  font-weight:700;
  font-family:var(--font-body);
}
body{ font-family:var(--font-body); }
/* ============ Tokens ============ */
:root{
  --c-black:#000; --c-white:#fff;
  --c-tiling:#0085ca;     /* accent: Tiling/Grouts */
  --c-waterproof:#00843d; /* accent: Waterproofing */
  --c-interior:#ffd700;   /* accent: Interior Finishes */
  --c-orange:#fe5000; --c-red:#e04f39; --c-magenta:#ce0058; --c-violet:#24125f;

  --font-head: "Futura Ceresit Condensed","Futura Ceresit","Helvetica","Arial",system-ui,-apple-system,sans-serif;
  --font-body: "Futura Ceresit","Helvetica","Arial",system-ui,-apple-system,sans-serif;
  --ls-tight:-0.02em;
  --lh-head:1.1; --lh-body:1.5;

  --radius:0;
  --grid-gap:20px;
  --border:#000;
  --container:1180px;

  --shadow: 0 8px 24px rgba(0,0,0,.08);
}

/* ============ Base ============ */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  letter-spacing:var(--ls-tight);
  line-height:var(--lh-body);
  color:var(--c-black);
  background:var(--c-white);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.visually-hidden{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0;border:0;height:1px;width:1px;overflow:hidden;}

/* Layout helpers */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding:0 16px}
.h1{font-size:clamp(28px,4vw,44px);line-height:var(--lh-head);margin:0 0 12px}
.h2{font-size:clamp(22px,3vw,32px);line-height:var(--lh-head);margin:0 0 16px}
.lead{font-size:clamp(16px,2.4vw,18px);opacity:.85;margin:0 0 24px}
.caption{font-size:12px;opacity:.7}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  height:44px;padding:0 18px;border:1.5px solid #000;
  font-weight:600; text-transform:none; letter-spacing:0;
  border-radius:var(--radius); transition:transform .08s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:#000;color:#fff}
.btn--primary:hover{filter:brightness(0.98)}
.btn--ghost{background:transparent;color:#000}
.btn--ghost:hover{background:#000;color:#fff}
.btn--secondary{background:#fff;color:#000}
.btn--secondary:hover{background:#000;color:#fff}

/* ============ Header ============ */
.site-header{
  position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid #0000;
  transition:box-shadow .2s ease;
}
.site-header.scrolled{box-shadow:var(--shadow)}
.header-inner{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;padding:12px 0}
.logo img{display:block;height:auto}
.header-cta{display:none}
.nav{display:none;gap:16px}
.nav__link{padding:8px 4px}
.burger{
  width:40px;height:40px;border:1.5px solid #000;background:#fff;border-radius:var(--radius);
  display:inline-flex;align-items:center;justify-content:center;gap:4px;
}
.burger span{display:block;width:18px;height:2px;background:#000}
.no-scroll{overflow:hidden}

/* Mobile nav open */
.nav.is-open{
  position:fixed;inset:64px 0 0 0;background:#fff;padding:24px 16px;display:flex;flex-direction:column;gap:12px;border-top:1px solid #000;
}

/* ============ Hero ============ */
.hero{padding:40px 0 16px;border-bottom:1px solid #0000}
.hero__grid{display:grid;grid-template-columns:1fr;gap:24px}
.hero__text .cta-group{display:flex;gap:12px;flex-wrap:wrap}
.tile-grid{position:relative;outline:2px solid #000;outline-offset:-2px}
.tile-grid::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(to right, #000 0 2px, transparent 2px calc(50% - 1px), #000 calc(50% - 1px) calc(50% + 1px), transparent calc(50% + 1px) calc(100% - 2px), #000 calc(100% - 2px) 100%),
    linear-gradient(to bottom, #000 0 2px, transparent 2px calc(50% - 1px), #000 calc(50% - 1px) calc(50% + 1px), transparent calc(50% + 1px) calc(100% - 2px), #000 calc(100% - 2px) 100%);
  opacity:.25;
}

/* ============ Benefits ============ */
.benefits{padding:60px 0}
.benefits__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px 32px}
.benefit{display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:flex-start}
.benefit .icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.benefit .icon svg{width:48px;height:48px}
.benefit .icon circle{fill:#000}
.benefit__content h3{margin:0 0 4px;font-size:18px}
.benefit__content p{margin:0;line-height:1.4}

/* ============ How it works ============ */
.howto{padding:16px 0 32px;border-top:1px solid #000;border-bottom:1px solid #0000}
.howto__grid{display:grid;grid-template-columns:1fr;gap:16px}
.step{border:1px solid #000;padding:16px;border-radius:var(--radius)}
.step__no{display:inline-block;font-weight:700;border-bottom:2px solid #000;margin-bottom:8px}

/* ============ Campaigns ============ */
.campaigns{padding:32px 0;border-top:1px solid #000}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cards-snap{
  display:grid;gap:16px;padding-bottom:8px
}
.cards-snap--grid-1{grid-template-columns:1fr}
.cards-snap--grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.cards-snap--grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cards-snap--grid-1 .card{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);
  align-items:stretch;
}
.cards-snap--grid-1 .card__media{
  min-height:280px;
  aspect-ratio:auto;
}
.cards-snap--grid-1 .card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.cards-snap--grid-1 .card__body{
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:280px;
}
.cards-snap--carousel{
  grid-auto-flow:column;
  grid-auto-columns:80%;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;
}
.cards-snap::-webkit-scrollbar{height:6px}
.cards-snap::-webkit-scrollbar-thumb{background:#0002}
.card{scroll-snap-align:start;border:1px solid #000;background:#fff}
.card__media{aspect-ratio:16/9;background:#f4f4f4}
.card__body{padding:12px}
.badge{
  display:inline-block;border:1px solid #000;padding:3px 6px;margin-bottom:8px;
  background:var(--badge, #fff); color:#000;
}
.campaigns-carousel{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}
.campaigns-carousel__btn{
  width:42px;
  height:42px;
  border:1px solid #000;
  border-radius:50%;
  background:#fff;
  color:#000;
  font:inherit;
  font-size:28px;
  line-height:1;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.campaigns-carousel__btn:disabled{opacity:.32;cursor:default}
.campaigns-carousel__hint{margin:4px 0 0 54px}

/* ============ Partners ============ */
.partners{padding:24px 0;border-top:1px solid #000}
.partners__row{display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.partners__head{display:flex;gap:16px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:14px}
.partners__label{font-weight:700}
.partners__logos{list-style:none;display:flex;gap:16px;margin:0;padding:0;align-items:center}
.partners__logos img{filter:grayscale(1);opacity:.9}
.partners__logos--grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:12px;
  align-items:stretch;
}
.partner-tile{min-width:0}
.partner-tile__link{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:110px;
  border:1px solid #000;
  padding:10px;
  background:#fff;
}
.partner-tile__logo-wrap{
  height:56px;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.partner-tile__logo-wrap img{
  max-height:56px;
  width:auto;
  object-fit:contain;
}
.partner-tile__link:hover{
  background:#000;
  color:#fff;
}
.partner-tile__link:hover img{
  filter:grayscale(0) invert(1);
  opacity:1;
}
.partner-tile__name{
  font-size:13px;
  text-align:center;
  line-height:1.25;
}
.partners__meta{
  margin-top:12px;
  font-size:12px;
  opacity:.7;
}

.partners-swiper{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
}
.partners-swiper__viewport{
  overflow-x:auto;
  scrollbar-width:thin;
  scroll-snap-type:x mandatory;
  padding-bottom:6px;
}
.partners-swiper__btn{
  width:42px;
  height:42px;
  border:1px solid #000;
  border-radius:999px;
  background:#fff;
  color:#000;
  font-size:26px;
  line-height:1;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 3px 10px rgba(0,0,0,.12);
  transition:background .15s ease,color .15s ease,transform .08s ease,box-shadow .15s ease;
}
.partners-swiper__btn:hover{
  background:#000;
  color:#fff;
  box-shadow:0 6px 14px rgba(0,0,0,.2);
}
.partners-swiper__btn:active{
  transform:translateY(1px);
}
.partners-swiper__btn:disabled{
  opacity:.28;
  cursor:default;
  box-shadow:none;
}
.partners__logos--swiper{
  display:flex;
  gap:12px;
  align-items:stretch;
  min-width:max-content;
}
.partner-tile--swiper{
  width:170px;
  flex:0 0 170px;
  scroll-snap-align:start;
}

@media (max-width:640px){
  .partners-swiper{
    grid-template-columns:1fr;
    gap:8px;
  }
  .partners-swiper__btn{
    display:none;
  }
  .partner-tile--swiper{
    width:150px;
    flex-basis:150px;
  }
}

/* ============ FAQ ============ */
.faq{padding:24px 0;border-top:1px solid #000}
.faq__item{border:1px solid #000;padding:12px;margin-bottom:12px}
.faq__item summary{cursor:pointer;font-weight:600}
.faq__content{margin-top:8px}

/* ============ Footer ============ */
.site-footer{border-top:1px solid #000;padding:24px 0}
.footer-inner{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-links{display:flex;gap:12px;flex-wrap:wrap}
.footer-links a{border-bottom:1px solid #0000}
.footer-links a:hover{border-color:#000}
.footer-links button{
  font:inherit;
  color:inherit;
  background:transparent;
  border:1px solid currentColor;
  padding:6px 10px;
  cursor:pointer;
}
.footer-links button:hover{opacity:1}

/* ============ Responsive (≥ 768px) ============ */
@media (min-width:768px){
  .header-inner{grid-template-columns:auto auto 1fr auto}
  .nav{display:flex}
  .header-cta{display:block}
  .burger{display:none}

  .hero{padding:64px 0 24px}
  .hero__grid{grid-template-columns:1.1fr 1fr;gap:24px;align-items:start}
  .howto__grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .cards-snap--carousel{grid-auto-columns:calc((100% - 32px) / 3)}
}

@media (max-width:767px){
  .benefits{padding:40px 0}
  .benefits__grid{gap:24px}
  .section-head{align-items:flex-start;gap:12px;flex-direction:column}
  .cards-snap--grid-1 .card{grid-template-columns:1fr}
  .cards-snap--grid-1 .card__media{min-height:0;aspect-ratio:16/9}
  .cards-snap--grid-1 .card__body{min-height:0}
  .cards-snap--grid-2,.cards-snap--grid-3{grid-template-columns:1fr}
  .campaigns-carousel{grid-template-columns:1fr}
  .campaigns-carousel__btn{display:none}
  .campaigns-carousel__hint{margin-left:0}
}

/* Header shadow on scroll */
@media (prefers-reduced-motion:no-preference){
  document:focus-within .site-header{box-shadow:var(--shadow)}
}
/* ====== Top bar pe negru, fără a schimba markup-ul existent ====== */
.site-header{
  background:#000; color:#fff; position:sticky; top:0; z-index:1000;
  border-bottom:1px solid #111; transition:box-shadow .2s ease;
}
.site-header.scrolled{ box-shadow: var(--shadow); }

.site-header .header-inner{ padding:10px 0; }
.site-header .logo img{
  height:auto; /* fallback: dacă ai doar logo negru pe fundal transparent */
 
}

/* navigație pe dark */
.site-header .nav{ display:flex; gap:16px; flex-wrap:wrap; }
.site-header .nav__link{
  color:#fff; opacity:.92; padding:10px 0; border-bottom:2px solid transparent;
}
.site-header .nav__link:hover{ opacity:1; border-color:#fff; }

/* butoanele din header – stil „pill” pentru contrast pe negru */
.site-header .btn{ height:36px; border-radius:999px; padding:0 14px; border-width:1px; }
.site-header .btn--ghost{ background:transparent; color:#fff; border-color:#fff; }
.site-header .btn--ghost:hover{ background:#fff; color:#000; }
.site-header .btn--primary{
  background: var(--c-red); border-color: var(--c-red); color:#fff;
}
.site-header .btn--primary:hover{ filter:brightness(.95); }

/* burger pe dark (mobil) – păstrează JS-ul tău existent */
.site-header .burger{
  border:1px solid #444; background:#111; border-radius:8px; width:40px; height:36px;
}
.site-header .burger span{ background:#fff; }
@media (max-width:960px){
  .nav.is-open{
    position:fixed; inset:56px 0 auto 0; background:#000;
    display:flex; flex-direction:column; gap:8px; padding:12px 16px; border-top:1px solid #111;
  }
  .nav.is-open .nav__link{ border:none; padding:8px 0; }
}

/* ====== Footer pe negru, păstrând structura ta .site-footer ====== */
.site-footer{ background:#000; color:#fff; border-top:1px solid #111; }
.site-footer .footer-inner{ padding:28px 0; }

.site-footer .footer-links a{
  color:#fff; opacity:.85; border-bottom:1px solid transparent;
}
.site-footer .footer-links a:hover{ opacity:1; border-color:#fff; }
.site-footer .footer-links button{
  color:#fff;
  opacity:.85;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.55);
}
.site-footer .footer-links button:hover{
  opacity:1;
  background:#fff;
  color:#000;
}
.site-footer .caption{ opacity:.8; }

.legal-page{
  padding:40px 0 56px;
  background:#f7f7f7;
  min-height:calc(100vh - 140px);
}
.legal-card{
  background:#fff;
  border:1px solid #000;
  padding:24px;
  box-shadow:var(--shadow);
}
.legal-card > * + *{ margin-top:16px; }
.legal-copy > * + *{ margin-top:14px; }
.legal-copy h2{
  margin:24px 0 0;
  font-size:clamp(1.2rem, 1.5vw + 1rem, 1.6rem);
}
.legal-copy h3{
  margin:18px 0 0;
  font-size:1.05rem;
}
.legal-copy ul{
  margin:0;
  padding-left:20px;
}
.legal-copy li + li{ margin-top:8px; }
.legal-signature{
  margin-top:28px;
  text-align:left;
}
.legal-signature p{
  margin:0;
}
.legal-signature p + p{
  margin-top:4px;
}
.legal-annex{
  margin-top:34px;
}
.legal-annex h2{
  margin-bottom:8px;
}
.legal-table-wrap{
  width:100%;
  overflow-x:auto;
  margin-top:14px;
  border:1px solid #111;
}
.legal-participants-table{
  width:100%;
  min-width:980px;
  border-collapse:collapse;
  font-size:.84rem;
  line-height:1.25;
}
.legal-participants-table th,
.legal-participants-table td{
  border:1px solid #111;
  padding:4px 6px;
  vertical-align:top;
}
.legal-participants-table th{
  background:#17476d;
  color:#fff;
  font-family:var(--font-heading);
  font-size:.82rem;
  text-align:center;
}
.legal-participants-table tbody tr:nth-child(odd){
  background:#f1f1f1;
}
.legal-participants-table td:first-child{
  width:54px;
  text-align:right;
  white-space:nowrap;
}
.legal-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.legal-note{
  padding:14px 16px;
  border-left:4px solid #da291c;
  background:#fff5f4;
}
