/*
Theme Name: ASPEKT Len
Theme URI: https://nowa.pracaaspekt.pl
Author: ASPEKT
Description: Autorski motyw agencji pracy ASPEKT z Zyrardowa. Design system "Atrament i len".
Version: 1.0.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: aspekt-len
*/


:root{
  --as-ink:#1F2C4D;
  --as-indigo:#33477E;
  --as-steel:#5A6680;
  --as-mistblue:#C8D0E0;
  --as-linen:#F3EEE3;
  --as-flax:#E4DAC4;
  --as-paper:#FAF8F3;
  --as-go:#23834F;
  --as-go-deep:#1F7448;
  --as-sun:#F5BE85;
  --as-sun-ink:#5C4100;
  --as-grad-ink:linear-gradient(150deg,#1F2C4D,#33477E);
  --as-grad-linen:linear-gradient(180deg,#FAF8F3,#F3EEE3);
  --f-head:'Onest',system-ui,sans-serif;
  --f-body:'Golos Text',system-ui,sans-serif;
  --f-mono:'Spline Sans Mono',ui-monospace,monospace;
  --ease-org:cubic-bezier(0.22,1,0.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
body{
  margin:0;
  font-family:var(--f-body);
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--as-ink);
  background:var(--as-paper);
}
h1,h2,h3,h4{font-family:var(--f-head);line-height:1.15;margin:0 0 .5em}
h1{font-weight:800;font-size:clamp(2rem,4.6vw,3.4rem);letter-spacing:-.015em}
h2{font-weight:700;font-size:clamp(1.6rem,3.2vw,2.4rem);letter-spacing:-.01em}
h3{font-weight:600;font-size:clamp(1.15rem,2vw,1.4rem)}
p{margin:0 0 1em}
a{color:var(--as-indigo)}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:74rem;margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem)}

/* --- sciag: motyw sygnaturowy (krotkie kreski) --- */
.stitch{--stitch-color:var(--as-indigo);height:2px;border:0;margin:0;
  background:repeating-linear-gradient(90deg,var(--stitch-color) 0 10px,transparent 10px 18px)}
.stitch--light{--stitch-color:rgba(250,248,243,.55)}
.stitch--go{--stitch-color:var(--as-go)}

/* tekstura splotu lnu (opacity < 4%) */
.weave{position:relative}
.weave::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14'%3E%3Cpath d='M0 3.5h14M0 10.5h14' stroke='%231F2C4D' stroke-width='1'/%3E%3Cpath d='M3.5 0v14M10.5 0v14' stroke='%231F2C4D' stroke-width='1'/%3E%3C/svg%3E")}

/* --- przyciski --- */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-head);font-weight:600;
  font-size:1rem;text-decoration:none;padding:.85rem 1.5rem;border-radius:.4rem;border:2px solid transparent;
  transition:background .2s var(--ease-org),transform .2s var(--ease-org),box-shadow .2s var(--ease-org)}
.btn:hover{transform:translateY(-2px)}
.btn-go{background:var(--as-go);color:#fff}
.btn-go:hover{background:var(--as-go-deep)}
.btn-ink{background:var(--as-indigo);color:#fff}
.btn-ink:hover{background:var(--as-ink)}
.btn-outline-light{border-color:rgba(255,255,255,.65);color:#fff;background:transparent}
.btn-outline-light:hover{background:rgba(255,255,255,.12)}
.btn-outline-ink{border-color:var(--as-indigo);color:var(--as-indigo);background:transparent}
.btn-outline-ink:hover{background:var(--as-indigo);color:#fff}

/* --- header --- */
.site-header{position:sticky;top:0;z-index:60;border-bottom:1px solid var(--as-mistblue)}
.site-header::before{content:"";position:absolute;inset:0;background:rgba(250,248,243,.92);backdrop-filter:blur(8px);z-index:-1}
.site-header .wrap{display:flex;align-items:center;gap:1.5rem;min-height:4.5rem}
.brand{display:flex;align-items:center;gap:.95rem;text-decoration:none;color:var(--as-ink);margin-right:auto;min-width:0}
.brand-mark{width:3.35rem;height:3.35rem;object-fit:contain;flex:0 0 auto}
.brand-copy{display:grid;gap:.12rem;min-width:0}
.brand b{font-family:var(--f-head);font-weight:800;font-size:clamp(1.15rem,2.2vw,1.5rem);line-height:1;letter-spacing:.14em}
.brand small{display:flex;align-items:center;gap:.7rem;font-size:.78rem;font-weight:500;color:var(--as-indigo);letter-spacing:0;white-space:nowrap}
.brand small span{display:block;width:2.2rem;height:2px;background:var(--as-mistblue)}
.main-nav ul{display:flex;gap:1.4rem;list-style:none;margin:0;padding:0}
.main-nav a{font-family:var(--f-head);font-weight:600;font-size:.97rem;color:var(--as-ink);text-decoration:none;
  padding:.4rem 0;position:relative}
.main-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;
  background:repeating-linear-gradient(90deg,var(--as-go) 0 7px,transparent 7px 12px);transition:right .3s var(--ease-org)}
.main-nav a:hover::after,.main-nav a[aria-current="page"]::after{right:0}
.header-phone{white-space:nowrap}
.nav-toggle{display:none}

/* hamburger / drawer (mobile) */
@media (max-width:64rem){
  .brand{gap:.65rem}
  .brand-mark{width:2.6rem;height:2.6rem}
  .brand b{font-size:1.2rem;letter-spacing:.1em}
  .brand small{display:none}

  /* --- slide-in drawer --- */
  .main-nav{
    position:fixed;top:0;right:0;bottom:0;
    width:min(20rem,88vw);
    z-index:65;
    background:var(--as-ink);
    display:flex;flex-direction:column;
    overflow-y:auto;overflow-x:hidden;
    opacity:1;
    transform:translateX(110%);
    visibility:hidden;
    transition:transform .38s var(--ease-org),visibility 0s .38s;
    box-shadow:-8px 0 56px rgba(31,44,77,.6);
  }
  .main-nav.is-open{
    transform:translateX(0);
    visibility:visible;
    transition:transform .38s var(--ease-org),visibility 0s;
  }
  .main-nav::before{
    content:"ASPEKT";
    display:block;
    font-family:var(--f-head);
    font-weight:800;
    font-size:1.55rem;
    letter-spacing:.15em;
    color:#fff;
    padding:1.4rem 1.8rem 1.15rem;
    border-bottom:1px solid rgba(200,208,224,.14);
    background:rgba(255,255,255,.04);
    flex-shrink:0;
  }
  .main-nav ul{
    flex-direction:column;
    text-align:left;
    gap:0;
    padding:.4rem 0;
    flex:1;
  }
  .main-nav a{
    display:flex;align-items:center;
    color:rgba(255,255,255,.82);
    font-size:1.05rem;
    padding:.9rem 1.8rem;
    opacity:0;
    transform:translateX(14px);
    transition:opacity .4s var(--ease-org),transform .5s var(--ease-org),color .2s,background .2s,border-color .2s;
    border-left:3px solid transparent;
  }
  .main-nav a::after{
    content:"";
    position:static;
    left:auto;right:auto;bottom:auto;
    display:block;
    width:.42rem;height:.42rem;
    background:none;
    border:0;
    border-right:2px solid rgba(200,208,224,.35);
    border-top:2px solid rgba(200,208,224,.35);
    transform:rotate(45deg);
    margin-left:auto;
    flex-shrink:0;
    transition:border-color .2s;
  }
  .main-nav a:hover{color:#fff;background:rgba(255,255,255,.06);border-left-color:var(--as-sun)}
  .main-nav a:hover::after,.main-nav a[aria-current="page"]::after{right:auto;border-color:var(--as-sun)}
  .main-nav a[aria-current="page"]{color:#fff;border-left-color:var(--as-go)}
  .main-nav.is-open a{opacity:1;transform:none}
  .main-nav.is-open li:nth-child(1) a{transition-delay:.06s}
  .main-nav.is-open li:nth-child(2) a{transition-delay:.12s}
  .main-nav.is-open li:nth-child(3) a{transition-delay:.18s}
  .main-nav.is-open li:nth-child(4) a{transition-delay:.24s}
  .main-nav.is-open li:nth-child(5) a{transition-delay:.30s}

  .header-phone{display:none}
  .nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:2.8rem;height:2.8rem;
    padding:.6rem;background:none;border:0;cursor:pointer;z-index:70;position:relative}
  .nav-toggle span{display:block;height:2px;background:var(--as-ink);border-radius:2px;transition:transform .35s var(--ease-org),opacity .25s,background .25s}
  .nav-toggle[aria-expanded="true"] span{background:#fff}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* backdrop overlay */
.nav-backdrop{
  display:none;
  position:fixed;inset:0;
  z-index:64;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(2px);
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
.nav-backdrop.is-active{display:block}

/* drawer footer (phone number) */
.nav-drawer-foot{
  display:none;
  padding:1.4rem 1.8rem 2rem;
  border-top:1px solid rgba(200,208,224,.14);
  background:rgba(0,0,0,.15);
  flex-shrink:0;
}
@media (max-width:64rem){.nav-drawer-foot{display:block}}
.nav-drawer-foot .label{font-size:.78rem;color:rgba(255,255,255,.5);letter-spacing:.06em;text-transform:uppercase;font-family:var(--f-head);margin-bottom:.45rem}
.nav-drawer-phone{
  font-family:var(--f-mono);
  font-weight:700;
  font-size:1.25rem;
  color:var(--as-sun);
  text-decoration:none;
  display:inline-block;
}
.nav-drawer-phone:hover{color:#fff}

/* --- hero slider --- */
.hero{position:relative;overflow:hidden;background:var(--as-ink)}
.hero-track{display:flex;transition:transform .6s var(--ease-org)}
.hero-slide{position:relative;flex:0 0 100%;min-height:clamp(26rem,62vh,38rem);display:flex;align-items:center}
.hero-slide img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-slide .inner{position:relative;z-index:2;width:100%;color:#fff}
.hero-slide .inner .box{max-width:34rem;padding:2rem 0}
.hero-slide.comp-right .inner .box{margin-left:auto;text-align:right}
.hero-slide.comp-low .inner .box{align-self:flex-end;margin-bottom:3rem;max-width:40rem}
.hero-slide .kicker{font-family:var(--f-mono);font-weight:500;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--as-sun);margin-bottom:.7rem}
.hero-slide h1,.hero-slide h2{color:#fff;text-shadow:0 2px 18px rgba(31,44,77,.45)}
.hero-slide p{font-size:1.1rem;color:rgba(255,255,255,.88);max-width:30rem}
.hero-slide.comp-right p{margin-left:auto}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:2.9rem;height:2.9rem;border-radius:50%;
  border:1px solid rgba(255,255,255,.5);background:rgba(31,44,77,.35);color:#fff;font-size:1.2rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .2s}
.hero-arrow:hover{background:rgba(31,44,77,.7)}
.hero-arrow.prev{left:1rem}.hero-arrow.next{right:1rem}
.hero-dots{position:absolute;bottom:1.1rem;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:.6rem}
.hero-dots button{width:.85rem;height:.85rem;padding:0;border-radius:50%;border:1px solid #fff;background:transparent;cursor:pointer}
.hero-dots button[aria-current="true"]{background:var(--as-sun);border-color:var(--as-sun)}

/* --- rozwidlenie sciezek (60/40) --- */
.fork{display:grid;grid-template-columns:3fr 2fr;gap:1.2rem;margin-top:-3.2rem;position:relative;z-index:10;padding-bottom:1rem}
.fork-card{border-radius:.7rem;overflow:hidden;display:grid;grid-template-columns:1.2fr 1fr;min-height:19rem;
  box-shadow:0 18px 40px -18px rgba(31,44,77,.35);text-decoration:none;position:relative;
  transition:transform .25s var(--ease-org),box-shadow .25s var(--ease-org)}
.fork-card:hover{transform:translateY(-4px);box-shadow:0 26px 50px -20px rgba(31,44,77,.45)}
.fork-card .txt{padding:clamp(1.3rem,2.6vw,2.2rem);display:flex;flex-direction:column;gap:.4rem}
.fork-card .txt .btn{margin-top:auto;align-self:flex-start}
.fork-card img{width:100%;height:100%;object-fit:cover}
.fork-worker{background:var(--as-linen);color:var(--as-ink)}
.fork-worker h2{font-size:clamp(1.4rem,2.4vw,1.9rem)}
.fork-worker .lead{color:var(--as-steel)}
.fork-employer{background:var(--as-ink);color:#fff;grid-template-columns:1fr}
.fork-employer h2{color:#fff;font-size:clamp(1.3rem,2.2vw,1.7rem)}
.fork-employer .lead{color:rgba(255,255,255,.78)}
.fork-employer img{position:absolute;inset:0;opacity:.28}
.fork-employer .txt{position:relative;z-index:2}

/* --- pasek liczb --- */
.numbers{background:var(--as-grad-ink);color:#fff;padding:clamp(2.5rem,6vw,4.5rem) 0;position:relative}
.numbers .grid{display:grid;grid-template-columns:1.4fr 1fr 1.1fr;gap:2rem;align-items:end}
.numbers .num{font-family:var(--f-mono);font-weight:700;font-size:clamp(2.6rem,6.5vw,5rem);line-height:1;display:block}
.numbers .cell:nth-child(2) .num{font-size:clamp(2.2rem,5vw,3.8rem);color:var(--as-sun)}
.numbers .cell:nth-child(3){text-align:right}
.numbers .label{font-family:var(--f-head);font-weight:500;color:rgba(255,255,255,.82);letter-spacing:.02em}
.numbers .stitch{margin:1rem 0 0;max-width:7rem}
.numbers .cell:nth-child(3) .stitch{margin-left:auto}

/* --- sekcje --- */
.section{padding:clamp(2.8rem,7vw,5.2rem) 0}
.section--linen{background:var(--as-grad-linen)}
.section--ink{background:var(--as-ink);color:#fff}
.section--ink h2{color:#fff}
.section-head{max-width:42rem;margin-bottom:clamp(1.6rem,3.5vw,2.6rem)}
.section-head .pre{font-family:var(--f-mono);font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;color:var(--as-go);margin-bottom:.4rem}
.section--ink .section-head .pre{color:var(--as-sun)}
.section-head.right{margin-left:auto;text-align:right}

/* --- bento uslug --- */
.bento{display:grid;gap:1.1rem;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(8.5rem,auto)}
.bento .cell{border-radius:.6rem;padding:1.4rem 1.5rem;position:relative;overflow:hidden;display:flex;flex-direction:column}
.bento .cell h3{margin-bottom:.35rem}
.bento .cell p{font-size:.97rem;color:var(--as-steel);margin:0}
.bento .c1{grid-column:span 4;grid-row:span 2;background:var(--as-ink);color:#fff;justify-content:flex-end}
.bento .c1 h3{color:#fff;font-size:1.5rem}
.bento .c1 p{color:rgba(255,255,255,.8);max-width:30rem}
.bento .c1 img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.3}
.bento .c1 .txt{position:relative;z-index:2}
.bento .c2{grid-column:span 2;background:var(--as-linen)}
.bento .c3{grid-column:span 2;background:var(--as-flax)}
.bento .c4{grid-column:span 2;background:#fff;border:1px solid var(--as-mistblue)}
.bento .c5{grid-column:span 2;background:#fff;border:2px solid var(--as-sun)}
.bento .c5 h3{color:var(--as-ink)}
.bento .c5 p{color:var(--as-steel)}
.bento .c5 .stitch{--stitch-color:var(--as-sun)}
.bento .c6{grid-column:span 2;background:var(--as-linen)}
.bento .cell .stitch{margin-top:auto;max-width:4.5rem;margin-top:.9rem}

/* --- proces (linia sciegu) --- */
.process{position:relative}
.process ol{list-style:none;margin:2.2rem 0 0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;position:relative}
.process ol::before{content:"";position:absolute;top:1.05rem;left:3%;right:3%;height:2px;
  background:repeating-linear-gradient(90deg,var(--as-go) 0 10px,transparent 10px 18px)}
.process li{position:relative;padding-top:3rem}
.process li::before{content:counter(step);counter-increment:step;position:absolute;top:0;left:0;width:2.2rem;height:2.2rem;
  border-radius:50%;background:var(--as-go);color:#fff;font-family:var(--f-mono);font-weight:700;
  display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 5px var(--as-paper)}
.process ol{counter-reset:step}
.process h3{font-size:1.08rem;margin-bottom:.2rem}
.process p{font-size:.95rem;color:var(--as-steel);margin:0}
.section--linen .process li::before{box-shadow:0 0 0 5px var(--as-linen)}

/* --- dlaczego ASPEKT --- */
.why{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.why figure{margin:0;border-radius:.7rem;overflow:hidden;box-shadow:0 18px 40px -18px rgba(31,44,77,.4)}
.why ul{list-style:none;margin:1rem 0 1.4rem;padding:0}
.why li{padding:.45rem 0 .45rem 1.9rem;position:relative}
.why li::before{content:"";position:absolute;left:0;top:1.05rem;width:1.1rem;height:2px;
  background:repeating-linear-gradient(90deg,var(--as-go) 0 5px,transparent 5px 8px)}

/* --- karty ofert --- */
.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(17rem,1fr));gap:1.2rem}
.job-card{background:#fff;border:1px solid var(--as-mistblue);border-radius:.6rem;padding:1.3rem 1.4rem;position:relative;
  overflow:hidden;transition:transform .25s var(--ease-org),box-shadow .25s var(--ease-org);display:flex;flex-direction:column;gap:.3rem}
.job-card::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:repeating-linear-gradient(90deg,var(--as-go) 0 10px,transparent 10px 18px) 0 0/0% 100% no-repeat;
  transition:background-size .5s var(--ease-org)}
.job-card:hover{transform:translateY(-4px);box-shadow:0 16px 32px -16px rgba(31,44,77,.3)}
.job-card:hover::after{background-size:100% 100%}
.job-card .meta{font-size:.88rem;color:var(--as-steel);display:flex;flex-wrap:wrap;gap:.4rem .9rem}
.job-card .pay{font-family:var(--f-mono);font-weight:600;color:var(--as-go-deep)}
.job-card .tag{display:inline-block;font-size:.78rem;font-weight:600;background:var(--as-linen);border-radius:.3rem;
  padding:.15rem .55rem;color:var(--as-ink)}
.job-card .tag--tlumacz{background:var(--as-sun);color:var(--as-sun-ink)}
.jobs-empty{background:var(--as-linen);border-radius:.7rem;padding:2.2rem;text-align:center}

/* --- kontakt --- */
.contact-band{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(1.5rem,4vw,3rem)}
.contact-card{background:rgba(255,255,255,.06);border:1px solid rgba(200,208,224,.25);border-radius:.6rem;padding:1.3rem 1.5rem;margin-bottom:1rem}
.contact-card b{font-family:var(--f-head);font-size:1.05rem}
.contact-card .role{color:var(--as-mistblue);font-size:.9rem}
.contact-card a.tel{font-family:var(--f-mono);font-size:1.3rem;font-weight:600;color:var(--as-sun);text-decoration:none}

/* --- formularz --- */
.form{display:grid;gap: .9rem}
.form label{font-family:var(--f-head);font-weight:600;font-size:.92rem;display:block;margin-bottom:.25rem}
.form input[type=text],.form input[type=tel],.form input[type=email],.form select,.form textarea{
  width:100%;padding:.75rem .9rem;border:1px solid var(--as-mistblue);border-radius:.4rem;background:#fff;
  font:inherit;color:var(--as-ink)}
.form input:focus,.form textarea:focus,.form select:focus{outline:2px solid var(--as-indigo);outline-offset:1px}
.form .consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--as-steel)}
.form .consent input{margin-top:.25rem}

/* --- stopka --- */
.site-footer{background:var(--as-ink);color:rgba(255,255,255,.85);padding:clamp(2.5rem,6vw,4rem) 0 5.5rem}
.site-footer .cols{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:2rem}
.site-footer .foot-head{color:#fff;font-size:1rem;margin-bottom:.7rem}
.site-footer a{color:rgba(255,255,255,.85)}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
.site-footer .legal{margin-top:2rem;padding-top:1.2rem;border-top:1px solid rgba(200,208,224,.2);
  font-size:.85rem;color:rgba(255,255,255,.6);display:flex;flex-wrap:wrap;gap:.5rem 2rem}
.site-footer .brand-foot img{height:3.4rem;margin-bottom:.8rem}

/* --- sticky bottom bar (mobile) --- */
.sticky-bar{display:none}
@media (max-width:48rem){
  .sticky-bar{display:grid;grid-template-columns:1fr 1fr;position:fixed;bottom:0;left:0;right:0;z-index:55;
    box-shadow:0 -6px 20px rgba(31,44,77,.18)}
  .sticky-bar a{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem .5rem;
    font-family:var(--f-head);font-weight:700;font-size:.98rem;text-decoration:none}
  .sticky-bar .call{background:var(--as-ink);color:#fff}
  .sticky-bar .apply{background:var(--as-go);color:#fff}
}

/* --- scroll reveal --- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease-org),transform .7s var(--ease-org)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* --- responsywnosc --- */
@media (max-width:64rem){
  .fork{grid-template-columns:1fr;margin-top:-2rem}
  .numbers .grid{grid-template-columns:1fr 1fr;align-items:start}
  .numbers .cell:nth-child(3){text-align:left}
  .numbers .cell:nth-child(3) .stitch{margin-left:0}
  .bento .c1{grid-column:span 6}
  .bento .c2,.bento .c3,.bento .c4,.bento .c5,.bento .c6{grid-column:span 3}
  .why{grid-template-columns:1fr}
  .contact-band{grid-template-columns:1fr}
}
@media (max-width:48rem){
  .hero-arrow{display:none}
  .fork-card{grid-template-columns:1fr;min-height:auto}
  .fork-card img{max-height:13rem}
  .fork-worker{display:flex;flex-direction:column-reverse}
  .process ol{grid-template-columns:1fr;gap:1.6rem}
  .process ol::before{left:1.05rem;right:auto;top:3%;bottom:3%;width:2px;height:auto;
    background:repeating-linear-gradient(180deg,var(--as-go) 0 10px,transparent 10px 18px)}
  .process li{padding-top:0;padding-left:3.2rem}
  .bento .c2,.bento .c3,.bento .c4,.bento .c5,.bento .c6{grid-column:span 6}
  .site-footer .cols{grid-template-columns:1fr}
  .numbers .grid{grid-template-columns:1fr}
}

/* ===== PODSTRONY ===== */
.page-hero{position:relative;background:var(--as-ink);overflow:hidden}
.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.page-hero .wrap{position:relative;z-index:2;padding-top:clamp(3.5rem,9vw,6.5rem);padding-bottom:clamp(2.2rem,6vw,4rem);color:#fff}
.page-hero h1{color:#fff;margin-bottom:.2em}
.page-hero .kicker{font-family:var(--f-mono);font-size:.88rem;letter-spacing:.13em;text-transform:uppercase;color:var(--as-sun)}
.page-hero .stitch{max-width:8rem;margin-top:1.2rem}
.prose{max-width:46rem}
.prose h2{margin-top:1.8em}
.prose h3{margin-top:1.4em}
.prose ul{padding-left:1.2rem}
.prose li{margin:.35rem 0}
.layout-page{padding:clamp(2.2rem,6vw,4rem) 0}
.layout-page .wrap{display:grid;grid-template-columns:minmax(0,1fr);gap:2.5rem}
.layout-page.has-aside .wrap{grid-template-columns:minmax(0,1.7fr) minmax(0,1fr)}
.aside-card{background:var(--as-linen);border-radius:.7rem;padding:1.6rem;position:sticky;top:6rem}
.aside-card--ink{background:var(--as-ink);color:#fff}
.aside-card--ink h3{color:#fff}
.aside-card .tel{font-family:var(--f-mono);font-size:1.25rem;font-weight:600;color:var(--as-go-deep);text-decoration:none;display:inline-block;margin:.2rem 0}
.aside-card--ink .tel{color:var(--as-sun)}
.aside-card .stitch{margin:1rem 0}
@media (max-width:64rem){.layout-page.has-aside .wrap{grid-template-columns:1fr}.aside-card{position:static}}

/* archiwum ofert */
.jobs-filter{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.6rem}
.jobs-filter a{font-family:var(--f-head);font-weight:600;font-size:.92rem;text-decoration:none;color:var(--as-ink);
  background:var(--as-linen);border:1px solid transparent;border-radius:2rem;padding:.4rem 1rem;transition:background .2s}
.jobs-filter a:hover{background:var(--as-flax)}
.jobs-filter a.is-active{background:var(--as-ink);color:#fff}
.job-status-closed{opacity:.55}
.job-status-closed h3::after{content:" (zamknięta)";font-size:.8em;color:var(--as-steel)}
.single-job .meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(11rem,1fr));gap:1rem;margin:1.6rem 0;padding:1.4rem;background:var(--as-linen);border-radius:.7rem}
.single-job .meta-grid b{display:block;font-family:var(--f-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--as-steel);font-weight:500}
.single-job .meta-grid span{font-family:var(--f-head);font-weight:600}

/* CF7 */
.wpcf7 .form{display:grid;gap:.9rem}
.wpcf7 p{margin:0 0 .9rem}
.wpcf7 label{font-family:var(--f-head);font-weight:600;font-size:.92rem;display:block;margin-bottom:.25rem}
.wpcf7 input[type=text],.wpcf7 input[type=tel],.wpcf7 input[type=email],.wpcf7 select,.wpcf7 textarea{
  width:100%;padding:.75rem .9rem;border:1px solid var(--as-mistblue);border-radius:.4rem;background:#fff;font:inherit;color:var(--as-ink)}
.wpcf7 input:focus,.wpcf7 textarea:focus,.wpcf7 select:focus{outline:2px solid var(--as-indigo);outline-offset:1px}
.wpcf7 .wpcf7-acceptance .wpcf7-list-item{margin:0}
.wpcf7 .wpcf7-acceptance label{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--as-steel);font-weight:400;font-family:var(--f-body)}
.wpcf7 .wpcf7-submit{display:inline-flex;font-family:var(--f-head);font-weight:600;font-size:1rem;padding:.85rem 1.5rem;
  border-radius:.4rem;border:0;background:var(--as-go);color:#fff;cursor:pointer;transition:background .2s}
.wpcf7 .wpcf7-submit:hover{background:var(--as-go-deep)}
.wpcf7 .as-extra-wrap{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
.wpcf7-response-output{border-radius:.4rem;padding:.8rem 1rem;font-size:.95rem}
.section--ink .wpcf7 label{color:#fff}
.section--ink .wpcf7 .wpcf7-acceptance label{color:var(--as-mistblue)}
.section--ink .wpcf7 .wpcf7-acceptance a{color:var(--as-mistblue)}

/* 404 */
.error-404{min-height:55vh;display:flex;align-items:center;text-align:left}
.error-404 .code{font-family:var(--f-mono);font-weight:700;font-size:clamp(4rem,12vw,8rem);color:var(--as-mistblue);line-height:1}

/* breadcrumb-lite */
.backlink{font-size:.92rem}

/* Cookie Notice: kolory zgodne z kontraktem (kontrast AA) */
#cookie-notice .cn-button{background:var(--as-go)!important;color:#fff!important;border-radius:.35rem}
#cookie-notice .cn-button:hover{background:var(--as-go-deep)!important}

/* Karta oferty: klikalna w calosci (stretched link) */
.job-card h3 a{color:inherit;text-decoration:none}
.job-card h3 a::after{content:"";position:absolute;inset:0;z-index:1}
.job-card{cursor:pointer}
.job-card:hover h3 a{color:var(--as-indigo)}
