/*
 Theme Name:   WOH.GROUP Child (Divi 5)
 Theme URI:    https://woh.group
 Description:  Child theme dla Divi 5 — delikatny, edytorialny szablon WOH.GROUP.
               Tokeny designu, typografia (Newsreader + Hanken Grotesk), komponenty.
 Author:       WOH.GROUP
 Template:     Divi
 Version:      2.9.8
 Text Domain:  woh-child
*/

/* ============================================================
   Jak używać:
   1. Spakuj folder "divi-child" do ZIP i wgraj jako motyw (Wygląd → Motywy → Dodaj nowy).
   2. Aktywuj "WOH.GROUP Child (Divi 5)". Motyw nadrzędny Divi musi być zainstalowany.
   3. Tokeny i klasy poniżej stosuj w polach "CSS Class" / "Custom CSS" modułów Divi.
   4. Fonty i skrypt motywu ładuje functions.php (nie edytuj kolejności).

   AKCENT (zablokowany): #7A5C3E (brąz)   ·   NAGŁÓWKI: Newsreader   ·   TŁO: Ivory
   ============================================================ */

/* ============================================================
   WOH.GROUP — refined editorial template
   Delicate · professional · airy. One light direction.
   ============================================================ */

:root{
  /* brand swirl colours (logo) — used sparingly */
  --woh-yellow:#F5D429;
  --woh-orange:#EE8431;
  --woh-red:#EB1D24;
  --woh-magenta:#EA018C;
  --brand-grad:linear-gradient(118deg,#F5D429 0%,#EE8431 30%,#EB1D24 62%,#EA018C 100%);

  /* tweakable */
  --accent:#7A5C3E;
  --display:'Newsreader';

  /* surfaces — warm ivory */
  --bg:#FCFBF8;
  --bg-2:#F4F1EA;
  --surface:#FFFFFF;

  /* ink */
  --ink:#1A1714;
  --ink-2:#6B645B;
  --ink-3:#A39B90;

  /* lines */
  --line:rgba(26,23,20,.11);
  --line-2:rgba(26,23,20,.06);

  --shadow:0 30px 70px -42px rgba(50,35,25,.30);
  --shadow-sm:0 12px 32px -20px rgba(50,35,25,.25);

  --maxw:1180px;
  --gut:clamp(22px,5vw,60px);
  --r:16px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  line-height:1.6;overflow-x:hidden;font-size:17px;
}
h1,h2,h3,h4{font-family:var(--display),Georgia,serif;font-weight:400;line-height:1.08;letter-spacing:-.012em;text-wrap:balance}
.serif-i{font-style:italic}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:var(--accent);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}

/* eyebrow */
.eyebrow{
  font-family:'Hanken Grotesk';font-weight:600;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-2);display:inline-flex;align-items:center;gap:11px;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--brand-grad)}

/* accent underline word */
.u-accent{position:relative;white-space:nowrap}
.u-accent::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:2px;background:var(--accent);opacity:.55;border-radius:2px}

/* ---------- buttons ---------- */
.btn{
  font-family:'Hanken Grotesk';font-weight:600;font-size:.98rem;letter-spacing:.005em;
  display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border-radius:999px;
  border:1px solid transparent;cursor:pointer;transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s,border-color .3s;
}
.btn .ar{transition:transform .35s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:#FCFBF8}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.link-arrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.98rem;color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:3px;transition:border-color .3s,color .3s}
.link-arrow .ar{transition:transform .35s var(--ease)}
.link-arrow:hover{border-color:var(--accent);color:var(--accent)}
.link-arrow:hover .ar{transform:translateX(4px)}

/* ============================================================
   Header
   ============================================================ */
header{position:fixed;inset:0 0 auto 0;z-index:100;transition:background .45s var(--ease),border-color .45s,backdrop-filter .45s}
header.scrolled{background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(18px) saturate(1.3);-webkit-backdrop-filter:blur(18px) saturate(1.3);border-bottom:1px solid var(--line-2)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:22px var(--gut);transition:padding .45s}
header.scrolled .nav{padding-block:14px}
.brand img{height:32px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:38px}
.nav-links a{font-weight:500;font-size:.96rem;color:var(--ink-2);position:relative;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--accent);transition:width .35s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:20px}

/* language switcher */
.lang{position:relative}
.lang-btn{display:flex;align-items:center;gap:7px;font-weight:600;font-size:.82rem;letter-spacing:.04em;padding:8px 6px;border:0;background:transparent;color:var(--ink-2);cursor:pointer;transition:color .25s}
.lang-btn:hover{color:var(--ink)}
.lang-btn .chev{transition:transform .3s}
.lang.open .lang-btn .chev{transform:rotate(180deg)}
.lang-menu{position:absolute;right:0;top:calc(100% + 12px);background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:7px;min-width:166px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .3s,transform .3s,visibility .3s}
.lang.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-menu button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:10px 12px;border:0;background:transparent;border-radius:9px;cursor:pointer;font-family:'Hanken Grotesk';font-weight:500;font-size:.92rem;color:var(--ink);transition:background .18s}
.lang-menu button:hover{background:var(--bg-2)}
.lang-menu button.active{color:var(--accent);font-weight:600}
.lang-menu .flag{font-size:1.05rem}
.btn-sm{padding:11px 22px;font-size:.92rem}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:23px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ============================================================
   Hero
   ============================================================ */
.hero{padding-top:clamp(140px,17vw,210px);padding-bottom:clamp(70px,10vw,130px);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-18%;right:-12%;width:60vw;height:60vw;max-width:760px;max-height:760px;
  background:radial-gradient(circle at 50% 50%, rgba(234,1,140,.10), rgba(245,166,35,.07) 42%, transparent 68%);
  filter:blur(10px);pointer-events:none;z-index:0}
.hero .wrap{position:relative;z-index:1}
.hero-eyebrow{margin-bottom:30px}
.hero h1{font-size:clamp(2.5rem,6.6vw,5.3rem);font-weight:300;letter-spacing:-.02em;max-width:14ch}
.hero h1 em{font-style:italic;color:var(--ink)}
.hero-sub{margin-top:34px;max-width:540px;font-size:clamp(1.05rem,1.5vw,1.24rem);color:var(--ink-2);font-weight:400;line-height:1.62}
.hero-cta{display:flex;flex-wrap:wrap;align-items:center;gap:18px 26px;margin-top:44px}
.hero-meta{margin-top:64px;padding-top:30px;border-top:1px solid var(--line-2);display:flex;flex-wrap:wrap;gap:10px 30px;align-items:center}
.hero-meta span{font-size:.9rem;color:var(--ink-3);font-weight:500;letter-spacing:.02em}
.hero-meta .sep{width:4px;height:4px;border-radius:50%;background:var(--ink-3);opacity:.6}

/* ============================================================
   Stats band
   ============================================================ */
.stats{border-block:1px solid var(--line-2)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(38px,5vw,58px) clamp(20px,2.6vw,38px);border-left:1px solid var(--line-2)}
.stat:first-child{border-left:0;padding-left:0}
.stat .num{font-family:var(--display);font-weight:300;font-size:clamp(2.5rem,4.4vw,3.6rem);line-height:1;letter-spacing:-.02em}
.stat .lbl{margin-top:12px;color:var(--ink-2);font-weight:500;font-size:.94rem;line-height:1.4}

/* ============================================================
   Section scaffolding
   ============================================================ */
.sec{padding-block:clamp(80px,11vw,150px)}
.sec-head{margin-bottom:clamp(48px,6vw,80px);max-width:760px}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.4rem);font-weight:300;margin-top:20px}
.sec-head .lead{margin-top:22px;color:var(--ink-2);font-size:1.1rem;max-width:560px;font-weight:400}

/* ============================================================
   Services — refined list with hairlines
   ============================================================ */
.services{display:grid;grid-template-columns:repeat(2,1fr);column-gap:clamp(40px,5vw,84px)}
.svc{display:grid;grid-template-columns:auto 1fr;gap:0 30px;padding:36px 0;border-top:1px solid var(--line);position:relative}
.svc:hover .svc-ic{color:var(--accent);border-color:var(--accent)}
.svc:hover h3{color:var(--accent)}
.svc-no{font-family:var(--display);font-style:italic;font-size:1.1rem;color:var(--ink-3);padding-top:4px}
.svc-ic{width:46px;height:46px;border-radius:12px;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);transition:color .35s,border-color .35s;margin-bottom:20px}
.svc-ic svg{width:22px;height:22px}
.svc h3{font-size:1.5rem;font-weight:400;margin-bottom:9px;transition:color .35s}
.svc p{color:var(--ink-2);font-weight:400;font-size:1.02rem;line-height:1.58;max-width:42ch}
.svc-tags{margin-top:14px;display:flex;flex-wrap:wrap;gap:7px}
.svc-tags span{font-size:.78rem;color:var(--ink-3);font-weight:500;padding:4px 11px;border:1px solid var(--line-2);border-radius:999px}

/* ============================================================
   Process — elegant numbered row
   ============================================================ */
.process{background:var(--bg-2)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.step{padding:0 clamp(18px,2vw,30px);border-left:1px solid var(--line);position:relative}
.step:first-child{border-left:0;padding-left:0}
.step .n{font-family:var(--display);font-style:italic;font-size:1.5rem;color:var(--accent);font-weight:400}
.step h4{font-size:1.34rem;font-weight:400;margin:18px 0 11px}
.step p{color:var(--ink-2);font-weight:400;font-size:.98rem;line-height:1.55}

/* ============================================================
   Work — refined gallery
   ============================================================ */
.port-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,2vw,26px)}
.port{position:relative;overflow:hidden;border-radius:var(--r);background:var(--bg-2);border:1px solid var(--line-2);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.port:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.port.a{grid-column:span 7;aspect-ratio:16/11}
.port.b{grid-column:span 5;aspect-ratio:16/12}
.port.c{grid-column:span 4;aspect-ratio:4/4.2}
.port.d{grid-column:span 4;aspect-ratio:4/4.2}
.port.e{grid-column:span 4;aspect-ratio:4/4.2}
.port image-slot{width:100%;height:100%}
.port .meta{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;z-index:3;background:linear-gradient(transparent,rgba(20,14,10,.66));color:#fff;opacity:0;transform:translateY(8px);transition:opacity .45s,transform .45s;pointer-events:none}
.port:hover .meta{opacity:1;transform:none}
.port .meta .cat{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;opacity:.85}
.port .meta .t{font-family:var(--display);font-weight:400;font-size:1.32rem;margin-top:3px}

/* ============================================================
   Quote / contact
   ============================================================ */
.quote{background:var(--bg-2)}
.quote-inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(44px,6vw,96px);align-items:start}
.quote-left h2{font-size:clamp(2rem,4.2vw,3.2rem);font-weight:300;margin:20px 0 24px}
.quote-left p{color:var(--ink-2);font-size:1.08rem;max-width:400px;margin-bottom:38px;font-weight:400}
.quote-contacts{display:flex;flex-direction:column;gap:8px}
.qc{display:flex;align-items:center;gap:14px;padding:15px 0;border-top:1px solid var(--line);font-weight:500}
.qc .ic{width:38px;height:38px;display:grid;place-items:center;color:var(--accent)}
.qc a,.qc span{font-size:1rem}

.form{background:var(--surface);border:1px solid var(--line-2);border-radius:calc(var(--r) + 6px);padding:clamp(28px,3.4vw,44px);box-shadow:var(--shadow)}
.field{margin-bottom:22px}
.field label{display:block;font-weight:600;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);margin-bottom:10px}
.field input,.field select,.field textarea{width:100%;font-family:'Hanken Grotesk';font-size:1rem;font-weight:400;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:14px 16px;transition:border-color .25s,box-shadow .25s}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 14%,transparent)}
.field textarea{resize:vertical;min-height:112px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{font-family:'Hanken Grotesk';font-weight:500;font-size:.92rem;padding:10px 16px;border-radius:999px;border:1px solid var(--line);cursor:pointer;user-select:none;background:transparent;color:var(--ink-2);transition:.22s}
.chip:hover{border-color:var(--ink-3);color:var(--ink)}
.chip.on{background:var(--ink);color:#FCFBF8;border-color:var(--ink)}
.form .btn-primary{width:100%;justify-content:center;margin-top:4px}
.form .btn-primary:hover{box-shadow:0 16px 36px -18px rgba(214,1,127,.5)}
.form-ok{text-align:center;padding:44px 12px}
.form-ok .check{width:64px;height:64px;border-radius:50%;border:1px solid var(--accent);color:var(--accent);display:grid;place-items:center;margin:0 auto 22px}
.form-ok h3{font-size:1.7rem;font-weight:400;margin-bottom:10px}
.form-ok p{color:var(--ink-2);font-weight:400}
.hidden{display:none!important}

/* ============================================================
   Footer
   ============================================================ */
footer{padding-block:clamp(64px,8vw,100px) 38px}
.foot-cta{text-align:center;padding-bottom:clamp(60px,7vw,90px);margin-bottom:clamp(56px,6vw,80px);border-bottom:1px solid var(--line)}
.foot-cta h2{font-size:clamp(2.2rem,5.5vw,4.4rem);font-weight:300;max-width:16ch;margin:0 auto 30px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:56px}
.foot-brand img{height:36px;width:auto}
.foot-brand p{color:var(--ink-2);font-weight:400;margin-top:20px;max-width:290px;font-size:.98rem}
.foot-col h5{font-family:'Hanken Grotesk';font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:18px;font-weight:600}
.foot-col a{display:block;color:var(--ink);font-weight:500;padding:6px 0;font-size:.98rem;transition:color .25s}
.foot-col a:hover{color:var(--accent)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:30px;border-top:1px solid var(--line-2);color:var(--ink-3);font-size:.88rem;font-weight:500;flex-wrap:wrap}
.socials{display:flex;gap:9px}
.socials a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-2);transition:.28s}
.socials a:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-2px)}

/* ============================================================
   Reveal
   ============================================================ */
.woh-js .reveal{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.woh-js .reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:980px){
  .services{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr;gap:36px 0}
  .step{padding-block:0}
  .step:nth-child(3){border-left:0;padding-left:0}
  .stats .grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(3){border-left:0;padding-left:0}
  .quote-inner{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr;gap:34px}
  .port.a,.port.b{grid-column:span 12}
  .port.c,.port.d,.port.e{grid-column:span 4}
}
@media (max-width:680px){
  body{font-size:16px}
  .nav-links{display:none}
  .burger{display:flex}
  .steps{grid-template-columns:1fr}
  .step{border-left:0;padding-left:0}
  .stats .grid{grid-template-columns:1fr 1fr}
  .two{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .port.c,.port.d,.port.e{grid-column:span 12;aspect-ratio:16/11}
  .svc{grid-template-columns:1fr;gap:0}
  .svc-no{display:none}
  .svc-ic{grid-column:1}
  .svc-body{grid-column:1}
}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:99;background:var(--bg);display:flex;flex-direction:column;justify-content:center;gap:6px;padding:var(--gut);transform:translateY(-100%);transition:transform .55s var(--ease)}
.mobile-menu.open{transform:none}
.mobile-menu a{font-family:var(--display);font-weight:400;font-size:2.1rem;color:var(--ink);padding:11px 0}

/* ============================================================
   SUBPAGES
   ============================================================ */
/* page header */
.page-head{padding-top:clamp(140px,16vw,205px);padding-bottom:clamp(36px,4.5vw,64px);position:relative;overflow:hidden}
.page-head::before{content:"";position:absolute;top:-30%;right:-10%;width:50vw;height:50vw;max-width:640px;max-height:640px;background:radial-gradient(circle at 50% 50%, rgba(234,1,140,.09), rgba(245,166,35,.06) 44%, transparent 68%);filter:blur(10px);pointer-events:none;z-index:0}
.page-head .wrap{position:relative;z-index:1}
.page-head .eyebrow{margin-bottom:26px}
.page-head h1{font-size:clamp(2.4rem,5.8vw,4.6rem);font-weight:300;letter-spacing:-.02em;max-width:17ch}
.page-head h1 em{font-style:italic}
.page-head .lead{margin-top:26px;max-width:600px;color:var(--ink-2);font-size:1.16rem;font-weight:400;line-height:1.6}

/* service detail blocks */
.svc-detail{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(28px,5vw,84px);padding-block:clamp(46px,5.5vw,76px);border-top:1px solid var(--line);align-items:start}
.services-detail .svc-detail:last-child{border-bottom:1px solid var(--line)}
.sd-head{display:flex;gap:22px;align-items:flex-start}
.sd-no{font-family:var(--display);font-style:italic;font-size:1.35rem;color:var(--ink-3);padding-top:6px;flex:none}
.sd-ic{width:52px;height:52px;border-radius:13px;border:1px solid var(--line);display:grid;place-items:center;color:var(--accent);flex:none;margin-bottom:16px}
.sd-ic svg{width:24px;height:24px}
.sd-head h3{font-size:clamp(1.55rem,2.6vw,2.25rem);font-weight:300;line-height:1.1}
.sd-right>p{color:var(--ink-2);font-size:1.08rem;line-height:1.62;font-weight:400;margin-bottom:26px;max-width:46ch}
.incl-label{font-family:'Hanken Grotesk';font-weight:600;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.incl-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0 30px}
.incl-list li{display:flex;gap:12px;align-items:flex-start;padding:13px 0;border-top:1px solid var(--line-2);font-size:.98rem;color:var(--ink);font-weight:400}
.incl-list li svg{width:17px;height:17px;color:var(--accent);flex:none;margin-top:3px}

/* filters */
.filters{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:clamp(34px,4vw,52px)}
.filter{font-family:'Hanken Grotesk';font-weight:500;font-size:.95rem;padding:10px 19px;border-radius:999px;border:1px solid var(--line);cursor:pointer;color:var(--ink-2);background:transparent;transition:.22s}
.filter:hover{border-color:var(--ink-3);color:var(--ink)}
.filter.active{background:var(--ink);color:#FCFBF8;border-color:var(--ink)}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.gal .port{aspect-ratio:4/3.3;grid-column:auto}
.gal .port.hide{display:none}
@media (max-width:900px){.gal{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.gal{grid-template-columns:1fr}.gal .port{aspect-ratio:16/11}}

/* CTA band */
.cta-band{text-align:center;padding-block:clamp(74px,9vw,124px);border-top:1px solid var(--line)}
.cta-band .eyebrow{justify-content:center;margin-bottom:22px}
.cta-band h2{font-size:clamp(2rem,4.6vw,3.6rem);font-weight:300;max-width:18ch;margin:0 auto 30px}

/* contact page tweaks */
.contact-sec .quote-inner{align-items:start}
.qc .ic{flex:none}
.qc .qc-txt .l{display:block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin-bottom:2px}
.qc .qc-txt .v{font-weight:500;font-size:1rem}

@media (max-width:980px){
  .svc-detail{grid-template-columns:1fr;gap:24px}
}
@media (max-width:560px){
  .incl-list{grid-template-columns:1fr}
}

/* ============================================================
   1:1 makieta wrapper — gdy strona jest wstawiona modułem Code
   ============================================================ */
.woh-page{background:var(--bg);color:var(--ink);font-family:'Hanken Grotesk',system-ui,sans-serif;line-height:1.6;font-size:17px}
.woh-page main{display:block}
/* Divi: zniweluj domyślne paddingi sekcji/wierszy wokół modułu Code */
.et_pb_module.et_pb_code.woh-code,.et_pb_code.woh-code .et_pb_code_inner{padding:0;margin:0}
.woh-bleed.et_pb_section{padding:0!important}
.woh-bleed .et_pb_row{padding:0!important;margin:0!important;width:100%!important;max-width:100%!important}
.woh-bleed .et_pb_column{padding:0!important;margin:0!important}
/* placeholder kafelka realizacji (zanim wstawisz własny obraz) */
.port-ph{width:100%;height:100%;min-height:230px;background:var(--bg-2);display:block}
.gal .port-ph{aspect-ratio:4/3.3}

/* ============================================================
   DIVI — wzbogacenie modułów: hover, kafelki, formularz, menu
   (działa na klasach modułów: svc / port / stat / form / woh-menu)
   ============================================================ */

/* --- USŁUGI: ikona + hover --- */
.et_pb_column.svc{transition:transform .4s var(--ease)}
.woh-svc{height:100%}
.woh-svc-ic{width:46px;height:46px;border-radius:12px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);margin-bottom:18px;transition:color .35s var(--ease),border-color .35s,transform .35s var(--ease),background .35s}
.woh-svc-ic svg{width:22px;height:22px}
.svc:hover .woh-svc-ic{color:#fff;border-color:transparent;background:var(--accent);transform:translateY(-4px)}
.woh-svc-h{transition:color .35s}
.svc:hover .woh-svc-h{color:var(--accent)!important}

/* --- LICZBY: subtelny hover --- */
.stat{transition:transform .4s var(--ease)}
.stat:hover{transform:translateY(-4px)}

/* --- PROCES: kreska akcentu --- */
.step{position:relative}

/* --- REALIZACJE: kafelek z notką (hover-reveal jak w makiecie) --- */
.woh-port{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line-2);background:var(--bg-2);transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.port:hover .woh-port{transform:translateY(-6px);box-shadow:var(--shadow)}
.woh-port-img{aspect-ratio:4/3.2;background:var(--bg-2);background-size:cover;background-position:center;transition:transform .7s var(--ease)}
.port:hover .woh-port-img{transform:scale(1.05)}
.woh-port-meta{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;z-index:2;background:linear-gradient(transparent,rgba(20,14,10,.72));color:#fff;opacity:0;transform:translateY(10px);transition:opacity .45s var(--ease),transform .45s var(--ease);pointer-events:none}
.port:hover .woh-port-meta{opacity:1;transform:none}
.woh-port-meta .cat{display:block;font-family:'Hanken Grotesk';font-weight:600;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--woh-yellow,#F5D429);margin-bottom:3px}
.woh-port-meta .t{font-family:'Newsreader',serif;font-weight:400;font-size:1.32rem}
.woh-worklink a{transition:border-color .3s,color .3s}
.woh-worklink a:hover{color:var(--accent);border-color:var(--accent)!important}

/* --- PRZYCISKI Divi: lekki lift --- */
.woh-page .et_pb_button,.woh-header .et_pb_button,.woh-footer .et_pb_button{transition:transform .3s var(--ease),box-shadow .3s var(--ease)!important}
.woh-page .et_pb_button:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(122,92,62,.5)}

/* --- FORMULARZ wyceny (moduł Contact Form z klasą .form) --- */
.form.et_pb_contact_form_container,.form .et_pb_contact{margin:0}
.form .et_pb_contact_form_title{display:none}
.form p{margin:0 0 16px;padding:0}
.form .et_pb_contact_field{padding:0 0 16px!important}
.form .input,.form textarea,.form select,.form .et_pb_contact_message{
  width:100%;font-family:'Hanken Grotesk',sans-serif;font-size:1rem;color:var(--ink);
  background:var(--bg)!important;border:1px solid var(--line)!important;border-radius:11px!important;
  padding:14px 16px!important;transition:border-color .25s,box-shadow .25s;box-shadow:none!important}
.form .input::placeholder,.form textarea::placeholder{color:var(--ink-3)}
.form .input:focus,.form textarea:focus,.form select:focus{outline:0;border-color:var(--accent)!important;box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 14%,transparent)!important}
.form .et_pb_contact_field_options_title{font-family:'Hanken Grotesk';font-weight:600;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2)}
.form .et_pb_button,.form .et_contact_bottom_container .et_pb_button{width:100%;text-align:center;margin-top:4px}
.form .et_pb_contact_field:last-of-type{padding-bottom:0!important}

/* --- MENU mobilne Divi (nagłówek) — pełna szerokość, animowane --- */
.woh-header .et_pb_menu .et_mobile_nav_menu .mobile_menu_bar:before,
.woh-header .mobile_menu_bar:before{color:var(--accent)!important;font-size:30px!important;line-height:1!important}
/* Divi 5 (alpha) — hamburger + tła rozwijanego/mobilnego menu na pewno nieprzezroczyste */
.woh-header .et_pb_menu__icon:before,
.woh-header [class*="mobile_menu_bar"]:before{color:var(--accent)!important}
.woh-header .et_pb_menu__mobile-menu,
.woh-header ul.et_pb_menu__mobile-menu,
.woh-header .et_pb_menu .et_mobile_menu{background:var(--bg)!important;border-top:2px solid var(--accent)!important}
.woh-header .et_pb_menu ul.sub-menu,
.woh-header .et_pb_menu__sub-menu{background:#fff!important}
/* desktop: rozwijane menu (dropdown) — linia/obwódka w kolorze akcentu, nie niebieska */
@media(min-width:981px){
  .woh-header .et_pb_menu .nav li ul,
  .woh-header .et_pb_menu .nav li ul.sub-menu,
  .woh-header .et_pb_menu__sub-menu,
  .woh-header nav ul ul,
  .woh-header [class*="sub-menu"]{
    border:0!important;border-top:2px solid var(--accent)!important;background:#fff!important;
    box-shadow:0 18px 40px -16px rgba(40,20,30,.28)!important;border-radius:0 0 12px 12px!important}
  /* kasuj domyślny niebieski border-top koloru akcentu motywu Divi */
  .woh-header .et_pb_menu .nav li ul{border-top-color:var(--accent)!important}
}
.woh-header .et_pb_menu .et_mobile_nav_menu{position:static}
.woh-menu .et_mobile_menu,
.woh-header .et_pb_menu .et_mobile_menu{
  position:fixed!important;left:0!important;right:0!important;top:60px!important;width:100%!important;
  margin:0!important;max-height:calc(100dvh - 60px)!important;overflow:auto!important;
  background:var(--bg)!important;border:0!important;border-top:2px solid var(--accent)!important;
  border-radius:0!important;box-shadow:0 26px 50px -24px rgba(40,20,30,.45)!important;padding:14px 7vw 26px!important;z-index:1000!important;
  animation:wohMenuIn .35s cubic-bezier(.22,1,.36,1)}
@keyframes wohMenuIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.woh-menu .et_mobile_menu li a,
.woh-header .et_pb_menu .et_mobile_menu li a{
  color:var(--ink)!important;font-family:'Hanken Grotesk',sans-serif!important;font-weight:500!important;font-size:1.25rem!important;
  padding:16px 8px!important;border:0!important;border-bottom:1px solid var(--line-2)!important;border-radius:0!important;
  transition:color .2s,padding-left .2s}
.woh-menu .et_mobile_menu li:last-child a,
.woh-header .et_pb_menu .et_mobile_menu li:last-child a{border-bottom:0!important}
.woh-menu .et_mobile_menu li a:hover,
.woh-menu .et_mobile_menu li a:active,
.woh-header .et_pb_menu .et_mobile_menu li a:hover{background:transparent!important;color:var(--accent)!important;padding-left:16px!important}
.woh-header .et_pb_menu__logo-wrap+.et_pb_menu__menu .et_mobile_nav_menu{margin-top:0}
/* mobilne podmenu: zamknięte do czasu tapnięcia + przycisk +/- w akcencie */
@media(max-width:980px){
  .et_pb_menu li>ul,
  [class*="et_pb_menu"] li>ul,
  .et_mobile_menu li>ul,
  .et_mobile_menu .menu-item-has-children>ul{display:none!important}
  .et_pb_menu li.woh-open>ul,
  [class*="et_pb_menu"] li.woh-open>ul,
  .et_mobile_menu li.woh-open>ul{display:block!important}
  .et_pb_menu li.menu-item-has-children,
  .et_mobile_menu li.menu-item-has-children{position:relative}
  .woh-header .menu-item-has-children{position:relative}
  .woh-subtoggle{position:absolute;right:6px;top:10px;width:34px;height:34px;border:0;background:transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;z-index:5}
  .woh-subtoggle span{position:absolute;width:14px;height:2px;border-radius:2px;background:var(--accent);transition:transform .25s ease}
  .woh-subtoggle span:last-child{transform:rotate(90deg)}
  .woh-open>.woh-subtoggle span:last-child{transform:rotate(0)}
}
/* desktop: menu w jednej linii (z mozliwoscia zawijania, bez przepelnienia) */
@media(min-width:981px){
  .woh-menu .et_pb_menu__menu>nav>ul,
  .woh-header .et_pb_menu nav>ul{display:flex!important;flex-wrap:wrap!important;gap:clamp(14px,1.6vw,30px);max-width:100%}
}

/* nagłówek: wyrównanie w pionie kolumn nav */
.woh-nav.et_pb_row{align-items:center;display:flex}
/* NAGŁÓWEK na mobile — CTA w jednej linii z hamburgerem */
@media (max-width:980px){
  .woh-nav.et_pb_row{display:flex!important;flex-wrap:nowrap!important;align-items:center!important;justify-content:flex-start!important;gap:10px}
  .woh-nav.et_pb_row>.et_pb_column{width:auto!important;margin:0!important;padding:0!important}
  .woh-nav.et_pb_row>.et_pb_column:nth-child(1){margin-right:auto!important}
  .woh-nav.et_pb_row>.et_pb_column:nth-child(2){order:3}
  .woh-nav.et_pb_row>.et_pb_column:nth-child(3){order:2}
  .woh-nav .et_pb_menu{background:transparent!important}
  .woh-nav .et_pb_menu .et_mobile_nav_menu{float:none;margin:0}
}
@media (max-width:560px){
  .woh-header .et_pb_image img{height:30px;width:auto}
  .woh-nav.et_pb_row>.et_pb_column:nth-child(3) a{padding:10px 16px!important;font-size:13px!important}
}

/* ============================================================
   USŁUGI — animowane bloki + link do podstrony
   ============================================================ */
.services-detail .svc-detail{position:relative;transition:transform .5s var(--ease),background .5s var(--ease);border-radius:18px}
.services-detail .svc-detail::before{content:"";position:absolute;top:-1px;left:0;height:2px;width:0;background:var(--accent);transition:width .55s var(--ease)}
.services-detail .svc-detail:hover::before{width:84px}
.services-detail .svc-detail:hover{background:color-mix(in srgb,var(--bg-2) 55%,transparent);transform:translateX(6px)}
.woh-sd-ic{width:54px;height:54px;border-radius:14px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--accent);margin:0 0 18px;transition:background .45s var(--ease),color .45s,border-color .45s,transform .45s var(--ease),box-shadow .45s}
.woh-sd-ic svg{width:25px;height:25px}
.svc-detail:hover .woh-sd-ic{background:var(--accent);color:#fff;border-color:transparent;transform:translateY(-5px) rotate(-4deg);box-shadow:0 14px 26px -12px rgba(122,92,62,.6)}
.svc-detail:hover .woh-sd-h{color:var(--accent)}
.woh-sd-h{transition:color .4s var(--ease)}
.woh-sd-no{transition:color .4s}
.svc-detail:hover .woh-sd-no{color:var(--accent)}
.woh-more{display:inline-flex;align-items:center;gap:9px;font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:.98rem;color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:3px;margin-top:22px;text-decoration:none;transition:color .3s,border-color .3s}
.woh-more .ar{transition:transform .35s var(--ease)}
.woh-more:hover{color:var(--accent);border-color:var(--accent)}
.woh-more:hover .ar{transform:translateX(5px)}
.svc-detail:hover .woh-more{border-color:var(--accent)}
.incl-anim li{transition:transform .3s var(--ease),border-color .3s}
.svc-detail:hover .incl-anim li{transform:translateX(3px)}

/* ============================================================
   PODSTRONA USŁUGI (single service)
   ============================================================ */
.breadcrumb{font-family:'Hanken Grotesk',sans-serif;font-size:.86rem;color:var(--ink-3);font-weight:500;margin-bottom:20px;display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.breadcrumb a{color:var(--ink-2);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb .sep{opacity:.5}
.intro-2{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(30px,5vw,80px);align-items:start}
.intro-2 .ih{font-family:'Newsreader',serif;font-weight:300;font-size:clamp(1.5rem,2.4vw,2.1rem);line-height:1.12;color:var(--ink);position:sticky;top:110px;margin:0}
.intro-2 .ip{font-family:'Hanken Grotesk',sans-serif;color:var(--ink-2);font-size:1.12rem;line-height:1.68;margin:0}
.intro-2 .ip strong{color:var(--ink);font-weight:600}
@media(max-width:880px){.intro-2{grid-template-columns:1fr;gap:18px}.intro-2 .ih{position:static}}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
@media(max-width:880px){.feat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.feat-grid{grid-template-columns:1fr}}
.feat{background:var(--surface);border:1px solid var(--line-2);border-radius:16px;padding:30px 28px;height:100%;transition:transform .45s var(--ease),box-shadow .45s,border-color .45s}
.feat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.feat-ic{width:46px;height:46px;border-radius:12px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:18px;transition:background .4s,color .4s,border-color .4s}
.feat:hover .feat-ic{background:var(--accent);color:#fff;border-color:transparent}
.feat-ic svg{width:22px;height:22px}
.feat h4{font-family:'Newsreader',serif;font-weight:400;font-size:1.3rem;color:var(--ink);margin:0 0 9px}
.feat p{font-family:'Hanken Grotesk',sans-serif;color:var(--ink-2);font-size:.98rem;line-height:1.55;margin:0}

/* ============================================================
   FORMULARZ na mobile — elegancko
   ============================================================ */
@media (max-width:680px){
  .form.et_pb_contact_form_container,.et_pb_column .form{padding:26px 20px!important;border-radius:20px!important}
  .form .input,.form textarea,.form select{padding:15px 16px!important;font-size:16px!important;border-radius:12px!important}
  .form .et_pb_contact_field{padding-bottom:14px!important}
  .form .et_pb_button{padding:16px!important;font-size:16px!important}
  .quote .quote-form-row.et_pb_row{padding-left:0!important;padding-right:0!important;width:92%!important}
  .quote-head.et_pb_row .et_pb_column{margin-bottom:24px!important}
}

/* --- PROCES: pionowe kreski-dzielniki między krokami (jak w makiecie) --- */
.process .et_pb_column.step{border-left:1px solid var(--line);padding-left:clamp(20px,2.4vw,34px);transition:transform .4s var(--ease)}
.process .et_pb_row .et_pb_column.step:first-child,
.process .et_pb_row .et_pb_column.step:nth-child(4n+1){border-left:0;padding-left:0}
.process .et_pb_column.step:hover{transform:translateY(-4px)}
@media (max-width:980px){
  .process .et_pb_column.step{border-left:0!important;padding-left:0!important}
}

/* --- REALIZACJE: aspect ratio kafelków zależnie od rozmiaru --- */
.woh-port.lg .woh-port-img{aspect-ratio:16/11}
.woh-port.md .woh-port-img{aspect-ratio:16/12}
.woh-port.sq .woh-port-img{aspect-ratio:4/4.1}

/* --- DARMOWA WYCENA: lista kontaktów z ikonami (jak w makiecie) --- */
.woh-qc{display:flex;align-items:center;gap:14px;padding:15px 0;border-top:1px solid var(--line)}
.woh-qc .ic{width:42px;height:42px;flex:none;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--line-2);color:var(--accent)}
.woh-qc .ic svg{width:18px;height:18px}
.woh-qc .v{font-family:'Hanken Grotesk';font-weight:600;color:var(--ink);font-size:1rem;text-decoration:none}
.woh-qc a.v:hover{color:var(--accent)}

/* --- USŁUGI/PROCES (Divi svc-detail): ładne łamanie tytułu w lewej kolumnie --- */
.svc-detail .woh-sd-no{font-family:'Newsreader',serif;font-style:italic;color:var(--ink-3);font-size:1.3rem;margin:0 0 6px}
.svc-detail .woh-sd-h{
  font-family:'Newsreader',serif;font-weight:300;color:var(--ink);
  font-size:clamp(1.45rem,1.9vw,1.8rem);line-height:1.16;letter-spacing:-.01em;
  margin:0;text-wrap:pretty;hyphens:none;overflow-wrap:normal;word-break:keep-all;
}
.svc-detail .woh-sd-lead{max-width:none}
/* na desktopie trzymaj lewą kolumnę węziej, by tytuł nie był rozjechany */
@media (min-width:981px){
  .services-detail .svc-detail.et_pb_row .et_pb_column:first-child{padding-right:clamp(10px,2vw,40px)}
}
@media (max-width:980px){
  .svc-detail .woh-sd-h{font-size:clamp(1.6rem,5vw,2rem)}
  .svc-detail .woh-sd-no{margin-bottom:2px}
}

/* ============================================================
   OPINIE KLIENTÓW (testimonials) + ZESPÓŁ + WARTOŚCI
   ============================================================ */
.tcard{background:var(--surface);border:1px solid var(--line-2);border-radius:18px;padding:34px 32px;height:100%;display:flex;flex-direction:column;transition:transform .45s var(--ease),box-shadow .45s,border-color .45s}
.tcard:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.tcard .q{font-family:'Newsreader',serif;font-style:italic;font-size:3.2rem;line-height:.6;color:var(--accent);opacity:.5;height:26px}
.tcard p.tq{font-family:'Newsreader',serif;font-weight:300;font-size:1.22rem;line-height:1.5;color:var(--ink);margin:14px 0 22px;flex:1}
.tcard .who{display:flex;align-items:center;gap:13px;margin-top:auto}
.tcard .ava{width:46px;height:46px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:1rem;color:#fff;background:var(--brand-grad)}
.tcard .nm{font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:.98rem;color:var(--ink);line-height:1.2}
.tcard .co{font-family:'Hanken Grotesk',sans-serif;font-size:.86rem;color:var(--ink-2)}
.tcard .stars{color:var(--accent);font-size:.9rem;letter-spacing:2px;margin-bottom:2px}

/* zespół */
.member{text-align:left}
.member-ph{width:100%;aspect-ratio:1/1.12;border-radius:16px;background:var(--bg-2);border:1px solid var(--line-2);overflow:hidden;margin-bottom:16px;transition:transform .45s var(--ease)}
.member:hover .member-ph{transform:translateY(-5px)}
.member-ph img{width:100%;height:100%;object-fit:cover;display:block}
.member .nm{font-family:'Newsreader',serif;font-weight:400;font-size:1.3rem;color:var(--ink);margin:0}
.member .role{font-family:'Hanken Grotesk',sans-serif;font-size:.92rem;color:var(--accent);font-weight:500;margin:2px 0 0}

/* wartości (reużywa feat, ale numerowane) */
.value-no{font-family:'Newsreader',serif;font-style:italic;font-size:1.4rem;color:var(--accent);margin:0 0 10px}

/* ============================================================
   MAPA (mapy.uk) — elegancka karta + animowany znacznik
   ============================================================ */
.woh-map{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:0 40px 80px -50px rgba(40,20,30,.5);background:var(--bg-2)}
.woh-map iframe{display:block;width:100%;height:520px;border:0;filter:saturate(.94) contrast(1.02)}
.woh-map .pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-100%);z-index:3;pointer-events:none}
.woh-map .pin .drop{position:relative;width:30px;height:30px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:linear-gradient(135deg,#EE8431,#EA018C);box-shadow:0 10px 22px -6px rgba(122,92,62,.7);border:2.5px solid #fff}
.woh-map .pin .drop::after{content:"";position:absolute;inset:0;margin:auto;width:9px;height:9px;background:#fff;border-radius:50%}
.woh-map .pin .ring{position:absolute;left:50%;top:50%;width:30px;height:30px;border-radius:50%;transform:translate(-50%,-50%);background:rgba(234,1,140,.28);animation:wohPulse 2.4s var(--ease) infinite}
@keyframes wohPulse{0%{width:18px;height:18px;opacity:.7}100%{width:90px;height:90px;opacity:0}}
.woh-map .addr{position:absolute;left:22px;bottom:22px;z-index:4;background:var(--surface);border:1px solid var(--line-2);border-radius:16px;padding:22px 24px;max-width:320px;box-shadow:0 24px 50px -28px rgba(40,20,30,.45)}
.woh-map .addr .lbl{font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin:0 0 8px}
.woh-map .addr .co{font-family:'Newsreader',serif;font-weight:400;font-size:1.3rem;color:var(--ink);margin:0 0 6px}
.woh-map .addr p{font-family:'Hanken Grotesk',sans-serif;font-size:.96rem;line-height:1.5;color:var(--ink-2);margin:0}
.woh-map .addr a.maplink{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:.92rem;color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:3px;text-decoration:none;transition:color .25s,border-color .25s}
.woh-map .addr a.maplink:hover{color:var(--accent);border-color:var(--accent)}
@media(max-width:600px){.woh-map iframe{height:420px}.woh-map .addr{left:14px;right:14px;bottom:14px;max-width:none;padding:18px 20px}}

/* ============================================================
   WAŻNE: wiersze Divi mają własne kolumny — wyłącz gridy z makiety,
   które kolidują z natywnym układem Divi (psuły kolumny stopki itd.)
   ============================================================ */
.et_pb_row.foot-top,
.et_pb_row.quote-inner,
.et_pb_row.gal,
.et_pb_row.services,
.et_pb_row.steps,
.et_pb_row.port-grid,
.et_pb_row.feat-grid,
.et_pb_row.stats{display:flex!important;grid-template-columns:none!important}
.woh-footer .foot-top .et_pb_column,
.woh-footer .et_pb_column{word-break:normal!important;overflow-wrap:normal!important}
.woh-footer .foot-col a,
.woh-footer .et_pb_text a{white-space:normal!important}




/* ============================================================
   REALIZACJE — natywny Divi Filterable Portfolio jako "notki"
   Selektory natywne (bez polegania na module_class)
   ============================================================ */
.et_pb_filterable_portfolio{max-width:1180px;margin:0 auto!important;padding:0 4%;float:none!important;width:auto!important}
.et_pb_filterable_portfolio .et_pb_portfolio_filters{margin:0 0 34px!important;text-align:left;float:none}
.et_pb_filterable_portfolio .et_pb_portfolio_filters ul{display:flex!important;flex-wrap:wrap;gap:9px;list-style:none;margin:0;padding:0;float:none}
.et_pb_filterable_portfolio .et_pb_portfolio_filters li{margin:0!important;padding:0!important;border:0!important}
.et_pb_filterable_portfolio .et_pb_portfolio_filters li a{display:inline-block;font-family:'Hanken Grotesk',sans-serif!important;font-weight:500!important;font-size:14px!important;padding:10px 18px!important;border-radius:999px;border:1px solid rgba(26,23,20,.14);color:#6B645B!important;opacity:1!important;text-decoration:none;transition:all .2s}
.et_pb_filterable_portfolio .et_pb_portfolio_filters li a:hover{border-color:#A39B90;color:#1A1714!important}
.et_pb_filterable_portfolio .et_pb_portfolio_filters li a.active{background:#1A1714;color:#FCFBF8!important;border-color:#1A1714}
.et_pb_filterable_portfolio .et_pb_portfolio_items,
.et_pb_filterable_portfolio .et_pb_ajax_pagination_container{display:grid!important;grid-template-columns:repeat(3,1fr);gap:22px;margin:0!important}
.et_pb_filterable_portfolio .et_pb_portfolio_item{width:auto!important;margin:0!important;padding:0!important;float:none!important;background:#fff;border:1px solid rgba(26,23,20,.08);border-radius:18px;overflow:hidden;transition:transform .45s cubic-bezier(.22,1,.36,1),box-shadow .45s,border-color .45s;display:flex;flex-direction:column}
.et_pb_filterable_portfolio .et_pb_portfolio_item:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(40,20,30,.4);border-color:transparent}

/* wspólne stylowanie kart portfolio (Realizacje + slider) */
.et_pb_portfolio_image{margin:0!important;border-radius:0;overflow:hidden;aspect-ratio:16/10;background:#F4F1EA}
.et_pb_portfolio_image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.22,1,.36,1)}
.et_pb_portfolio_item:hover .et_pb_portfolio_image img{transform:scale(1.05)}
.et_pb_portfolio_image .et_overlay{background:rgba(122,92,62,.18)!important;border:0!important;border-radius:0!important}
.et_pb_portfolio_item .et_pb_module_header{font-family:'Newsreader',Georgia,serif!important;font-weight:400!important;font-size:1.45rem!important;line-height:1.15!important;color:#1A1714!important;margin:0!important;padding:22px 26px 0!important}
.et_pb_portfolio_item:hover .et_pb_module_header,
.et_pb_portfolio_item .et_pb_module_header a:hover{color:#7A5C3E!important}
.et_pb_portfolio_item .et_pb_module_header a{color:inherit!important}
.et_pb_portfolio_item .post-meta{order:-1;padding:22px 26px 0!important;margin:0!important;font-family:'Hanken Grotesk',sans-serif!important;font-weight:600!important;font-size:11px!important;letter-spacing:1.8px!important;text-transform:uppercase!important;color:#7A5C3E!important}
.et_pb_portfolio_item .post-meta a{color:#7A5C3E!important;font-weight:600;text-decoration:none}
.et_pb_portfolio_item .et_pb_module_header:after{content:"Zobacz projekt →";display:block;margin:14px 0 26px;padding:0 26px;font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:14px;color:#1A1714;transition:color .3s,transform .3s}
.et_pb_portfolio_item:hover .et_pb_module_header:after{color:#7A5C3E;transform:translateX(4px)}
@media(max-width:900px){.et_pb_filterable_portfolio .et_pb_portfolio_items,.et_pb_filterable_portfolio .et_pb_ajax_pagination_container{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.et_pb_filterable_portfolio .et_pb_portfolio_items,.et_pb_filterable_portfolio .et_pb_ajax_pagination_container{grid-template-columns:1fr}}

/* ============================================================
   POJEDYNCZY PROJEKT — przycisk powrotu + slider (regularny portfolio)
   ============================================================ */
.woh-proj-back{display:inline-flex;align-items:center;gap:9px;font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:15px;color:#1A1714!important;text-decoration:none!important;border:1px solid rgba(26,23,20,.14);border-radius:999px;padding:12px 22px;transition:all .25s;-webkit-tap-highlight-color:transparent}
.woh-proj-back:link,.woh-proj-back:visited{color:#1A1714!important}
.woh-proj-back:hover,.woh-proj-back:active,.woh-proj-back:focus{border-color:#7A5C3E!important;color:#7A5C3E!important;transform:translateX(-3px)}
.woh-proj-back svg{stroke:currentColor}
.woh-proj-back .ar{transition:transform .3s;display:inline-flex}
.woh-proj-back:hover .ar{transform:translateX(-4px)}
.woh-proj-head{max-width:980px;margin:0 auto;padding:0 4%}
/* slider = regularny moduł portfolio (NIE filterable) */
.et_pb_portfolio:not(.et_pb_filterable_portfolio){max-width:1180px;margin:0 auto!important;padding:0 4%;float:none!important;width:auto!important}
.et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_items{display:flex!important;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:10px;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:0!important}
.et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_items::-webkit-scrollbar{display:none}
.et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_item{scroll-snap-align:start;flex:0 0 330px;width:330px!important;margin:0!important;padding:0!important;float:none!important;background:#fff;border:1px solid rgba(26,23,20,.08);border-radius:18px;overflow:hidden;transition:transform .45s,box-shadow .45s,border-color .45s;display:flex;flex-direction:column}
.et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_item:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(40,20,30,.4);border-color:transparent}
.woh-slider-nav{display:flex;gap:10px;justify-content:flex-end;margin:0 auto 18px;max-width:1180px;padding:0 4%}
.woh-slider-nav button{width:46px;height:46px;border-radius:50%;border:1px solid rgba(26,23,20,.16);background:#fff;color:#1A1714;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s}
.woh-slider-nav button:hover{background:#7A5C3E;color:#fff;border-color:transparent}
.woh-slider-nav svg{width:20px;height:20px}


/* === KOREKTA 2.8.3: szerokosc menu desktop + mobilne podmenu (Divi 5 .et-l--header) === */
@media(min-width:981px){
  .et-l--header .et_pb_row>.et_pb_column,.woh-header .et_pb_row>.et_pb_column{min-width:0}
  .et-l--header .et_pb_row>.et_pb_column:nth-child(1),.woh-header .et_pb_row>.et_pb_column:nth-child(1){flex:0 1 16%!important;max-width:16%!important}
  .et-l--header .et_pb_row>.et_pb_column:nth-child(2),.woh-header .et_pb_row>.et_pb_column:nth-child(2){flex:1 1 60%!important;max-width:62%!important}
  .et-l--header .et_pb_row>.et_pb_column:nth-child(3),.woh-header .et_pb_row>.et_pb_column:nth-child(3){flex:0 1 22%!important;max-width:24%!important}
  .et-l--header .et_pb_menu nav>ul,.woh-header .et_pb_menu nav>ul{flex-wrap:nowrap!important;justify-content:center}
}
@media(max-width:980px){
  .et-l--header ul ul,.et_pb_menu ul ul,[class*="et_pb_menu"] ul ul{display:none!important}
  .et-l--header li.woh-open>ul,.et_pb_menu li.woh-open>ul,[class*="et_pb_menu"] li.woh-open>ul{display:block!important}
  .et-l--header li.menu-item-has-children,.et_pb_menu li.menu-item-has-children{position:relative}
}


/* === KOREKTA 2.8.4: menu desktop (nowrap + center) + mobilne podmenu (szeroki selektor) === */
@media(min-width:981px){
  .et-l--header .et_pb_row,.woh-header .et_pb_row{align-items:center!important}
  .et-l--header .et_pb_menu,.woh-header .et_pb_menu{display:flex!important;align-items:center!important;justify-content:center!important;flex-wrap:nowrap!important}
  .et-l--header .et_pb_menu nav>ul,.woh-header .et_pb_menu nav>ul{display:flex!important;flex-wrap:nowrap!important;justify-content:center!important;align-items:center;column-gap:clamp(12px,1.5vw,28px)}
  .et-l--header .et_pb_menu nav>ul>li,.woh-header .et_pb_menu nav>ul>li{white-space:nowrap!important}
  .et-l--header .et_pb_menu nav>ul>li>a,.woh-header .et_pb_menu nav>ul>li>a{white-space:nowrap!important;display:inline-block}
}
@media(max-width:980px){
  .et-l--header li ul,.et_pb_menu li ul,[class*="et_pb_menu"] li ul,#main-header li ul,.et_mobile_menu li ul{display:none!important}
  .et-l--header li.woh-open>ul,.et_pb_menu li.woh-open>ul,[class*="et_pb_menu"] li.woh-open>ul,.et_mobile_menu li.woh-open>ul{display:block!important}
}


/* === 2.8.6: mobilne podmenu — natywne klasy Divi z inspect (.et_mobile_menu .menu-item-has-children) === */
@media(max-width:980px){
  .et_mobile_menu .menu-item-has-children>ul,
  .et_pb_menu .et_mobile_menu .menu-item-has-children>ul,
  .et_pb_menu_0_tb_header .et_mobile_menu .menu-item-has-children>ul{display:none!important}
  .et_mobile_menu .menu-item-has-children.woh-open>ul,
  .et_pb_menu .et_mobile_menu .menu-item-has-children.woh-open>ul,
  .et_pb_menu_0_tb_header .et_mobile_menu .menu-item-has-children.woh-open>ul{display:block!important}
  .et_mobile_menu .menu-item-has-children{position:relative}
  .et_mobile_menu .menu-item-has-children>.woh-subtoggle{position:absolute;right:8px;top:9px;width:38px;height:38px;border:0;background:transparent;cursor:pointer;display:inline-flex!important;align-items:center;justify-content:center;z-index:9}
  .et_mobile_menu .menu-item-has-children>.woh-subtoggle span{position:absolute;width:15px;height:2px;border-radius:2px;background:var(--accent,#7A5C3E);transition:transform .25s}
  .et_mobile_menu .menu-item-has-children>.woh-subtoggle span:last-child{transform:rotate(90deg)}
  .et_mobile_menu .menu-item-has-children.woh-open>.woh-subtoggle span:last-child{transform:rotate(0)}
}


/* === 2.8.7: ladniejsze karty Realizacji (caly kafelek klikalny) + dopieszczenie projektu === */
body .et_pb_filterable_portfolio .et_pb_portfolio_item,
body .et_pb_portfolio .et_pb_portfolio_item{position:relative!important;border-radius:20px;border:1px solid rgba(26,23,20,.08)!important}
body .et_pb_portfolio_item .et_pb_portfolio_image{position:relative!important;border-radius:0!important}
body .et_pb_portfolio_item .et_pb_portfolio_image:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(26,19,17,.22),transparent 48%);opacity:0;transition:opacity .45s;z-index:1;pointer-events:none}
body .et_pb_portfolio_item:hover .et_pb_portfolio_image:after{opacity:1}
/* caly kafelek klikalny (rozciagniety link tytulu) */
body .et_pb_portfolio_item .et_pb_module_header a{position:static!important}
body .et_pb_portfolio_item .et_pb_module_header a:after{content:"";position:absolute;inset:0;z-index:4}
/* widoczny link "Zobacz projekt" z akcentem + strzalka */
body .et_pb_filterable_portfolio .et_pb_portfolio_item .et_pb_module_header:after{content:"Zobacz projekt →"!important;display:inline-flex!important;align-items:center;margin:14px 26px 26px!important;padding:0!important;color:#7A5C3E!important;font-family:'Hanken Grotesk',sans-serif!important;font-weight:600!important;font-size:14px!important;letter-spacing:.2px;transition:transform .35s,gap .35s}
body .et_pb_filterable_portfolio .et_pb_portfolio_item:hover .et_pb_module_header:after{transform:translateX(5px)}
/* filtry: ladniejszy odstep + aktywny w akcencie */
body .et_pb_filterable_portfolio .et_pb_portfolio_filters{margin-bottom:40px!important}
body .et_pb_filterable_portfolio .et_pb_portfolio_filters li a.active{background:#7A5C3E!important;border-color:#7A5C3E!important}

/* pojedynczy projekt — bardziej estetycznie */
body .woh-proj-title .entry-title,body .woh-proj-title h1{position:relative;padding-bottom:22px!important}
body .woh-proj-title .entry-title:after,body .woh-proj-title h1:after{content:"";position:absolute;left:0;bottom:0;width:56px;height:3px;border-radius:3px;background:#7A5C3E}
body .woh-proj-desc .et_pb_post_content>p:first-child{font-family:'Newsreader',Georgia,serif!important;font-weight:300!important;font-size:clamp(1.3rem,2vw,1.6rem)!important;line-height:1.45!important;color:#2A241F!important;margin-bottom:26px!important}
body .woh-proj-media .et_pb_title_featured_container img{border:1px solid rgba(26,23,20,.06)}
body .woh-proj-media .woh-proj-media-cap,body .woh-proj-cat{font-family:'Hanken Grotesk',sans-serif;font-weight:600;font-size:11px;letter-spacing:1.8px;text-transform:uppercase;color:#7A5C3E;margin:16px 0 0}


/* === 2.8.8: desktop dropdown — podstrony jedna pod druga (pionowo) === */
@media(min-width:981px){
  .et-l--header .et_pb_menu .sub-menu,
  .et_pb_menu .sub-menu,
  .et_pb_menu nav>ul>li>ul,
  .et_pb_menu nav ul li>ul{display:block!important;flex-direction:column!important;flex-wrap:nowrap!important;min-width:230px}
  .et-l--header .et_pb_menu .sub-menu>li,
  .et_pb_menu .sub-menu>li,
  .et_pb_menu nav>ul>li>ul>li{display:block!important;float:none!important;width:100%!important;white-space:nowrap}
  .et_pb_menu .sub-menu>li>a{display:block!important;width:100%!important}
}


/* === SLIDER "Inne realizacje" — FLEX, zwykle % (desktop 3 kol / mobile 1) === */
body .et_pb_portfolio:not(.et_pb_filterable_portfolio){max-width:1180px;margin:0 auto!important;padding:0 4%;overflow:visible!important}
body .et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_items,
body .et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_ajax_pagination_container{
  display:flex!important;flex-wrap:nowrap!important;gap:20px!important;overflow-x:auto!important;overflow-y:visible!important;
  width:100%!important;margin:0!important;align-items:stretch;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
body .et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_items::-webkit-scrollbar,
body .et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_ajax_pagination_container::-webkit-scrollbar{display:none}
body .et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_item{
  flex:0 0 31.5%!important;width:31.5%!important;max-width:31.5%!important;
  float:none!important;margin:0!important;scroll-snap-align:start;white-space:normal!important;
  display:flex!important;flex-direction:column;
  border:1px solid rgba(26,23,20,.08)!important;border-radius:20px!important}
@media(max-width:980px){
  body .et_pb_portfolio:not(.et_pb_filterable_portfolio) .et_pb_portfolio_item{flex:0 0 84%!important;width:84%!important;max-width:84%!important}
}
