/* fixwoodsystem — Front page (Industrial Premium, scoped .fwsm)
   Port z fixwoodsystem.html. Ładowane tylko na stronie głównej. */

/* reset kontenera Astry na froncie + ukryj tytuł strony — pełna szerokość */
.home .entry-title,
.home .ast-single-entry-banner{ display:none !important; }
.home #content .ast-container,
.home #primary,
.home #main,
.home .site-content,
.home .ast-container,
.home .entry-content,
.home .ast-article-single,
.home article.post{
  max-width:100% !important; width:100% !important;
  margin:0 !important; padding:0 !important;
  border:0 !important; box-shadow:none !important; background:transparent !important;
  display:block !important;   /* ast-container bywa flexem → main kurczył się do dziecka */
}
.home #content{ overflow-x:clip; }

.fwsm{ font-family:var(--body); color:var(--ink); width:100%; display:block; }
.fwsm *{ box-sizing:border-box; }
.fwsm-wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }

/* full-bleed sekcje — rodzic jest pełnej szerokości (reset .home wyżej),
   więc wystarczy width:100% (zero trików z 100vw, zero rozjazdu centrowania) */
.fwsm-hero,.fwsm-trust,.fwsm-thread,.fwsm-sortiment,.fwsm-band{ width:100%; }

.fwsm-eyebrow{ font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:var(--signal); }

/* thread divider */
.fwsm-thread{ height:14px; background-image:repeating-linear-gradient(66deg,var(--steel-line) 0 2px,transparent 2px 11px); opacity:.5; }

/* buttony */
.fwsm-btn{ display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:700; font-size:14px; letter-spacing:.01em; background:var(--signal); color:#fff; padding:11px 18px; border-radius:var(--r); border:none; cursor:pointer; transition:background .18s,transform .12s; }
.fwsm-btn:hover{ background:var(--signal-deep); color:#fff; }
.fwsm-btn:active{ transform:translateY(1px); }
.fwsm-btn .arr{ transition:transform .18s; }
.fwsm-btn:hover .arr{ transform:translateX(3px); }
.fwsm-btn-ghost{ background:transparent; color:var(--bone); border:1px solid var(--steel-line); }
.fwsm-btn-ghost:hover{ background:var(--steel); border-color:var(--zinc); color:var(--bone); }

/* HERO */
.fwsm-hero{ background:var(--graphite); color:var(--bone); position:relative; overflow:hidden; }
/* tekstura gwintu (spójna z hero o-nas + login) — wkręt zostaje gwiazdą */
.fwsm-hero::before{ content:""; position:absolute; inset:0; background-image:repeating-linear-gradient(66deg,var(--steel-line) 0 2px,transparent 2px 13px); opacity:.13; pointer-events:none; }
.fwsm-hero .fwsm-wrap{ position:relative; z-index:1; }
.fwsm-hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; align-content:center; padding-block:clamp(48px,6vw,88px); min-height:56vh; }
/* hero okazalszy na większych monitorach (nie full 100vh — premium) */
@media(min-width:1280px){ .fwsm-hero-grid{ min-height:60vh; } }
@media(min-width:1700px){ .fwsm-hero-grid{ min-height:64vh; } }
@media(min-width:2300px){ .fwsm-hero-grid{ min-height:68vh; } }
.fwsm-hero h1{ font-family:var(--display); font-weight:900; font-size:clamp(40px,6.4vw,82px); line-height:.96; letter-spacing:-.02em; margin:18px 0 22px; color:var(--bone); text-wrap:balance; }
.fwsm-hero h1 .em{ color:var(--signal); }
.fwsm-lead{ font-size:clamp(16px,1.4vw,18.5px); color:var(--zinc); max-width:46ch; margin-bottom:30px; }
.fwsm-hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }

/* figura inżynieryjna */
.fwsm-figure{ position:relative; display:flex; justify-content:center; }
.fwsm-figure svg{ width:100%; max-width:560px; height:auto; overflow:visible; }
.fwsm .callout-line{ stroke:var(--zinc); stroke-width:1; stroke-dasharray:2 3; }
.fwsm .callout-dot{ fill:var(--signal); }
.fwsm .callout-txt{ font-family:var(--mono); font-size:13px; fill:var(--bone); }
.fwsm .callout-sub{ font-family:var(--mono); font-size:10.5px; fill:var(--zinc); letter-spacing:.05em; }
.fwsm .screw-body{ fill:var(--zinc); }
.fwsm .screw-shade{ fill:#7c838a; }
.fwsm .screw-line{ stroke:var(--graphite); stroke-width:1.4; }
.fwsm .torx{ fill:var(--signal); }

/* trust strip */
.fwsm-trust{ background:var(--steel); border-top:1px solid var(--steel-line); color:var(--bone); }
.fwsm-trust ul{ list-style:none; display:flex; flex-wrap:wrap; gap:8px 36px; padding-block:18px; font-family:var(--mono); font-size:13px; color:var(--zinc); margin:0; }
.fwsm-trust li{ display:flex; align-items:center; gap:10px; }
.fwsm-trust li::before{ content:""; width:7px; height:7px; background:var(--signal); border-radius:50%; }

/* sekcje */
.fwsm-sec{ padding-block:clamp(56px,7vw,104px); }
.fwsm-sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:44px; flex-wrap:wrap; }
.fwsm-sec-head h2{ font-family:var(--display); font-weight:800; font-size:clamp(28px,3.8vw,46px); line-height:1.02; letter-spacing:-.015em; max-width:18ch; color:var(--ink); }
/* nagłówek z wordmarkiem pokolorowanym jak logo, jedna linia */
.fwsm-warum-h{ white-space:nowrap; max-width:none !important; }
.fwsm-brand-inline b{ color:var(--ink); font-weight:inherit; }
.fwsm-brand-inline i{ color:var(--signal); font-style:normal; }
.fwsm-sec-head p{ color:#55585d; max-width:40ch; font-size:15.5px; }

/* warum cards */
.fwsm-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:#dcd8cf; border:1px solid #dcd8cf; border-radius:var(--r); overflow:hidden; }
.fwsm-card{ background:var(--paper); padding:34px 30px 32px; transition:background .2s; }
.fwsm-card:hover{ background:var(--bone); }
.fwsm-card .idx{ font-family:var(--mono); font-size:12px; color:var(--timber); letter-spacing:.1em; }
.fwsm-card .ico{ margin:18px 0 18px; color:var(--signal); }
.fwsm-card .ico svg{ width:46px; height:46px; }
.fwsm-card h3{ font-family:var(--display); font-weight:700; font-size:21px; letter-spacing:-.01em; margin-bottom:10px; color:var(--ink); }
.fwsm-card p{ font-size:14.8px; color:#4a4d52; }

/* sortiment */
.fwsm-sortiment{ background:var(--bone); }
.fwsm-sort-cta{ text-align:center; margin-top:36px; }
.fwsm-btn-outline{ background:transparent; color:var(--signal); border:1px solid var(--signal); }
.fwsm-btn-outline:hover{ background:var(--signal); color:#fff; border-color:var(--signal); }
.fwsm-prods{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.fwsm-prod{ background:var(--paper); border:1px solid #e2ddd3; border-radius:var(--r); display:flex; flex-direction:column; overflow:hidden; transition:transform .16s,box-shadow .16s,border-color .16s; }
.fwsm-prod:hover{ transform:translateY(-4px); box-shadow:0 14px 30px -18px rgba(20,22,26,.45); border-color:var(--steel-line); }
.fwsm-prod .top{ position:relative; background:#fff; padding:14px 16px 18px; border-bottom:1px solid #efeae1; display:block; }
.fwsm-prod .eta{ position:absolute; top:12px; right:12px; font-family:var(--mono); font-size:10px; font-weight:600; letter-spacing:.08em; background:var(--signal); color:#fff; padding:3px 7px; border-radius:3px; z-index:2; }
.fwsm-prod .art{ display:block; font-family:var(--mono); font-size:10px; color:#9a9388; letter-spacing:.04em; margin-bottom:6px; max-width:78%; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fwsm-prod .pic{ display:flex; align-items:center; justify-content:center; }
.fwsm-prod .pic img{ width:100%; height:215px; object-fit:contain; }
.fwsm-prod .pbody{ padding:18px 20px 22px; display:flex; flex-direction:column; flex:1; }
.fwsm-prod h4{ font-family:var(--display); font-weight:700; font-size:17px; letter-spacing:-.01em; margin-bottom:4px; color:var(--ink); }
.fwsm-prod .desc{ font-size:13.5px; color:#54585d; margin-bottom:14px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.fwsm-prod .chips{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:18px; }
.fwsm-prod .chip{ font-family:var(--mono); font-size:11px; color:#3b3e43; background:#efeae1; border:1px solid #e0dacf; border-radius:3px; padding:3px 7px; }
.fwsm-prod .pfoot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.fwsm-prod .price{ font-family:var(--display); font-weight:700; font-size:15px; color:var(--ink); }
.fwsm-prod .price span{ font-family:var(--mono); font-weight:400; font-size:11px; color:#7a7e83; }
.fwsm-prod .price .amount{ font-family:var(--display); }
.fwsm-prod .lnk{ font-family:var(--display); font-weight:700; font-size:13.5px; color:var(--signal); display:inline-flex; gap:6px; align-items:center; white-space:nowrap; }
.fwsm-prod .lnk .arr{ transition:transform .18s; }
.fwsm-prod:hover .lnk .arr{ transform:translateX(3px); }

/* CTA band */
.fwsm-band{ background:var(--signal); color:#fff; }
.fwsm-band .fwsm-wrap{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding-block:46px; flex-wrap:wrap; }
.fwsm-band h2{ font-family:var(--display); font-weight:900; font-size:clamp(26px,3.4vw,40px); letter-spacing:-.02em; max-width:20ch; line-height:1.02; color:#fff; }
.fwsm-band p{ color:rgba(255,255,255,.85); font-size:15.5px; margin-top:8px; max-width:48ch; }
.fwsm-band .fwsm-btn{ background:var(--graphite); }
.fwsm-band .fwsm-btn:hover{ background:#000; }

/* responsive */
@media(max-width:1080px){ .fwsm-prods{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:880px){
  .fwsm-hero-grid{ grid-template-columns:1fr; gap:36px; }
  .fwsm-figure{ order:-1; max-width:340px; margin-inline:auto; }
  .fwsm-cards{ grid-template-columns:1fr; }
}
@media(max-width:560px){
  .fwsm-prods{ grid-template-columns:1fr; }
  .fwsm-band .fwsm-wrap{ flex-direction:column; align-items:flex-start; }

  /* HERO mobilny wg makiety: zwarty, h1 38px/.98, bez przepełnienia */
  .fwsm-hero-grid{ padding-block:26px 30px; gap:22px; min-height:0; }
  .fwsm-hero h1{ font-size:clamp(26px,7.2vw,38px); line-height:1.0; margin:12px 0 14px; overflow-wrap:break-word; hyphens:auto; }
  .fwsm-lead{ font-size:14px; line-height:1.5; margin-bottom:20px; }
  .fwsm-hero-cta{ gap:10px; }
  /* równe, obok siebie, ZAWSZE w jednej linii (DE „Datenblätter ansehen" zawijał) — nowrap + ciaśniejszy font/padding mieszczą najdłuższą etykietę we wszystkich językach */
  .fwsm-hero-cta .fwsm-btn{ flex:1 1 0; min-width:0; justify-content:center; white-space:nowrap; font-size:13px; padding-inline:13px; }
  /* wkręt duży, Z OPISAMI (callouty + animacja) jak na desktopie — figura na pełną szerokość,
     opisy przyciągnięte do wkręta (krótsze linie w SVG) → nic nie wychodzi poza ekran */
  .fwsm-figure{ max-width:360px; margin-inline:auto; }
  .fwsm-figure svg{ width:100%; max-width:360px; height:auto; }

  /* TRUST: chipy zawijają się (wszystkie widoczne, nic nie ucięte) */
  .fwsm-trust ul{ flex-wrap:wrap; gap:8px; padding-block:14px; }
  .fwsm-trust li{ white-space:nowrap; font-size:11px; border:1px solid var(--steel-line); border-radius:20px; padding:6px 12px; }

  /* sekcje: ciaśniejszy rytm pionowy na mobile */
  .fwsm-sec{ padding-block:40px; }
  .fwsm-sec-head{ margin-bottom:24px; }
  /* „Dlaczego FixWoodSystem?" — zwija się na mobile (było nowrap → ucinało) */
  .fwsm-warum-h{ white-space:normal !important; font-size:clamp(24px,6.4vw,32px); }
}

/* skalowanie na 2K / 4K — typografia i figura rosną z kontenerem */
@media(min-width:2300px){
  .fwsm-hero h1{ font-size:104px; }
  .fwsm-lead{ font-size:21px; max-width:50ch; }
  .fwsm-figure svg{ max-width:660px; }
  .fwsm-sec-head h2{ font-size:56px; }
  .fwsm-sec-head p{ font-size:17px; }
  .fwsm-prod h4{ font-size:19px; }
  .fwsm-band h2{ font-size:48px; }
}
@media(min-width:3300px){
  .fwsm-hero h1{ font-size:140px; }
  .fwsm-lead{ font-size:25px; }
  .fwsm-figure svg{ max-width:780px; }
  .fwsm-hero-grid{ gap:80px; }
  .fwsm-sec-head h2{ font-size:74px; }
  .fwsm-trust ul{ font-size:16px; }
}

/* animacje figury */
@keyframes fwsm-draw{ to{ stroke-dashoffset:0; } }
@keyframes fwsm-fade{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }
.fwsm .anim-line{ stroke-dasharray:120; stroke-dashoffset:120; animation:fwsm-draw .9s ease forwards; }
.fwsm .anim-fade{ opacity:0; animation:fwsm-fade .6s ease forwards; }
@media(prefers-reduced-motion:reduce){ .fwsm *{ animation:none!important; } }
