@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700;800&display=swap');
:root{
  --bg:#ffffff;
  --bg-muted:#f6f6f6;
  --bg-dark:#1e1e1e;
  --text:#1e1e1e;
  --text-muted:#5a6472;
  --text-light:#9aa3ad;
  --accent:#5aacba;
  --accent-dark:#3f8d9a;
  --accent-light:#e8f3f6;
  --border:#e6e6e6;
  --border-strong:#cfcfcf;
  --maxw:1440px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
/* Block editor: when a block is selected from the list view (Widok listy)
   Gutenberg calls scrollIntoView with default options — block lands at the
   very top of the iframe canvas, often half-hidden under sticky tools.
   scroll-margin-top forces 100px breathing room. Frontend ignores this
   (only affects programmatic scrollIntoView calls). */
.wp-block{scroll-margin-top:100px;scroll-margin-bottom:100px}

/* Selected block highlight + brief pulse on selection change. Editor only
   (this stylesheet is injected into the iframe canvas via add_editor_style,
   but the .is-selected class is added by Gutenberg only there). Frontend
   pages never have .is-selected so the rule is a no-op outside the editor. */
/* Selected block highlight + pulse animation lives in
   mu-plugins/erb-admin-skin/assets/css/editor-enhance.css — that file is
   loaded after main.css in the editor iframe, so styling there wins. */
body{
  font-family:'Montserrat',system-ui,sans-serif;
  color:var(--text);background:var(--bg);
  font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.container{max-width:var(--maxw);margin:0 auto;padding:0 32px}
@media (max-width:768px){.container{padding:0 20px}}

/* Typography */
h1,h2,h3{font-family:'Montserrat',sans-serif;font-weight:700;letter-spacing:-0.025em;line-height:1.1;color:var(--text)}
h1{font-size:3rem;font-weight:700;letter-spacing:-0.035em}
h2{font-size:clamp(1.75rem,3.2vw,2.75rem);font-weight:700;letter-spacing:-0.025em;line-height:1.15}
h3{font-size:1.0625rem;font-weight:600;letter-spacing:-0.01em}
.eyebrow{font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);display:inline-block;margin-bottom:1.5rem}
.lead{font-size:1.125rem;color:var(--text-muted);line-height:1.65;max-width:62ch}
p{color:var(--text-muted);max-width:65ch}
p + p{margin-top:1rem}

/* Preview sidebar (development only — sitemap tree) */
:root{--preview-w:320px}
html.has-preview-sidebar body{padding-left:var(--preview-w)}
@media (max-width:900px){html.has-preview-sidebar body{padding-left:0}}
.preview-sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--preview-w);
  background:#1e1e1e;color:white;z-index:100;
  overflow-y:auto;
  border-right:1px solid rgba(255,255,255,0.06);
  font-size:0.8125rem;
}
@media (max-width:900px){.preview-sidebar{display:none}}
.preview-sidebar-inner{padding:24px 0;display:flex;flex-direction:column;min-height:100%}
.preview-sidebar-head{padding:4px 20px 24px;border-bottom:1px solid rgba(255,255,255,0.06);margin-bottom:16px}
.preview-sidebar-title{display:block;font-size:0.875rem;font-weight:700;letter-spacing:-0.01em;color:white}
.preview-sidebar-sub{display:block;font-size:0.7rem;color:rgba(255,255,255,0.4);letter-spacing:0.08em;text-transform:uppercase;font-weight:500;margin-top:4px}
.preview-sidebar-foot{margin-top:auto;padding:16px 20px;font-size:0.7rem;color:rgba(255,255,255,0.35);letter-spacing:0.04em;border-top:1px solid rgba(255,255,255,0.06)}
.preview-sidebar-foot strong{color:var(--accent);font-weight:600}

.tree{display:flex;flex-direction:column;padding:0 12px}
.tree-item{
  display:flex;align-items:center;gap:8px;
  padding:7px 10px;color:rgba(255,255,255,0.68);
  text-decoration:none;border-radius:3px;
  font-size:0.78rem;line-height:1.3;
  transition:all .15s;position:relative;
}
.tree-item:hover{background:rgba(255,255,255,0.06);color:white}
.tree-item.active{background:var(--accent);color:white}
.tree-item.active .tree-num{color:rgba(255,255,255,0.85)}
.tree-item.non-clickable{cursor:default}
.tree-item-top{font-weight:700;color:rgba(255,255,255,0.92);margin-top:4px}
.tree-item-top .tree-num{color:var(--accent)}
.tree-num{
  font-size:0.68rem;font-weight:600;
  color:rgba(255,255,255,0.4);
  min-width:34px;
  letter-spacing:0.02em;
  font-variant-numeric:tabular-nums;
}
.tree-label{flex:1;font-weight:inherit;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tree-children{
  display:flex;flex-direction:column;
  border-left:1px solid rgba(255,255,255,0.06);
  margin-left:18px;margin-bottom:4px;
  padding-left:8px;
}
.tree-children .tree-item{font-weight:400;font-size:0.75rem;padding:5px 8px}

/* Status badges */
.tree-badge{
  flex-shrink:0;font-size:0.58rem;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;
  padding:2px 6px;border-radius:2px;line-height:1.2;
}
.tree-badge.s-done{background:var(--accent);color:white}
.tree-badge.s-live{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.55)}
.tree-badge.s-feedback{background:rgba(245,180,100,0.18);color:#f5b464}
.tree-badge.s-todo{background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.3)}
.tree-item.active .tree-badge.s-done{background:rgba(255,255,255,0.25)}

/* Legend */
.tree-legend{
  display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;
  padding:16px 20px;margin-top:16px;
  border-top:1px solid rgba(255,255,255,0.06);
  font-size:0.68rem;color:rgba(255,255,255,0.5);
}
.tree-legend span{display:flex;align-items:center;gap:6px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.875rem 1.75rem;
  background:var(--text);color:white;
  text-decoration:none;font-weight:500;font-size:0.9rem;
  border:none;cursor:pointer;transition:all .2s;
  letter-spacing:0.01em;
}
.btn:hover{background:var(--accent)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border-strong)}
.btn-outline:hover{background:var(--text);color:white;border-color:var(--text)}
.btn-lg{padding:1.125rem 2.25rem;font-size:0.95rem}
.btn svg{width:16px;height:16px}

/* HERO */
.hero{
  position:relative;min-height:92vh;
  display:flex;align-items:center;
  background:linear-gradient(135deg,#f6f6f6 0%,#ededed 100%);
  overflow:hidden;
}
.hero-inner{padding:96px 32px 96px;width:100%;max-width:var(--maxw);margin:0 auto}
@media (max-width:960px){.hero-inner{padding:72px 20px}}
.hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:96px;align-items:center}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:48px}}
.hero-copy h1{margin-bottom:1.75rem}
.hero-copy .lead{margin-bottom:2.5rem;font-size:1.25rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero-visual{
  position:relative;aspect-ratio:4/5;
  background-size:cover;background-position:center;
  border-radius:2px;
}
.hero-visual::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(30,30,30,0.2) 100%);
}

/* Intro block */
.intro{padding:120px 0;background:white}
.intro-grid{display:grid;grid-template-columns:1fr 2fr;gap:80px}
.intro-grid.intro-grid--no-label{grid-template-columns:1fr}
@media (max-width:800px){.intro-grid{grid-template-columns:1fr;gap:32px}}
.intro-label{font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);font-weight:600;padding-top:0.5rem}
.intro-body p{font-size:1.125rem;color:var(--text);line-height:1.7;max-width:none}
.intro-body p + p{margin-top:1.5rem}
.intro-body ul{margin-top:1rem;padding-left:0;list-style:none}
.intro-body ul li{font-size:1.125rem;color:var(--text);line-height:1.7;padding-left:1.25rem;position:relative}
.intro-body ul li::before{content:'';position:absolute;left:0;top:0.65em;width:8px;height:1px;background:var(--accent)}

/* Section base */
section.std{padding:120px 0}
/* When a block has no section header (eyebrow/heading/lead), the first
 * grid/list inside the container would otherwise have a leading margin-top
 * intended to separate it from the header — wastes vertical space. Kill it. */
.std > .container > :first-child{margin-top:0}
section.gray{background:var(--bg-muted)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center}
@media (max-width:900px){.two-col{grid-template-columns:1fr;gap:48px}}
.col-text h2{margin-bottom:2rem}
.img-frame{
  aspect-ratio:4/5;background:var(--border);
  background-size:cover;background-position:center;
  border-radius:2px;position:relative;
}
.img-frame.wide{aspect-ratio:16/10}

/* 3-col grid */
.three-col{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:48px;margin-top:64px}
@media (max-width:800px){.three-col{grid-template-columns:1fr;gap:32px}}
.feature{padding-top:32px;border-top:2px solid var(--text)}
.feature .num{font-family:'Montserrat',sans-serif;font-size:1rem;color:var(--accent);font-weight:500;margin-bottom:1rem;display:block}
.feature h3{margin-bottom:0.875rem;font-size:1.25rem;line-height:1.3}
.feature p{font-size:0.95rem;color:var(--text-muted);max-width:none}

/* Tabs */
.tabs-wrap{margin-top:56px}
/* Desktop: minimal text-style tabs (close to original) with stronger hover
   so it's clear they're clickable. Active gets the turquoise underline. */
.tabs-nav{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:48px;flex-wrap:wrap}
.tab-btn{
  background:none;border:none;
  padding:1.1rem 1.5rem;margin:0;
  font-family:'Montserrat',sans-serif;font-size:0.95rem;font-weight:600;
  color:var(--text-muted,#5a6472);cursor:pointer;
  border-bottom:3px solid transparent;margin-bottom:-1px;
  transition:color .15s,background .15s,border-bottom-color .15s;
  letter-spacing:0;line-height:1.3;
}
.tab-btn:hover,.tab-btn:focus-visible{color:var(--text);background:rgba(90,172,186,0.06)}
.tab-btn.active{color:var(--text);border-bottom-color:var(--accent);background:transparent}
.tab-btn.active::after{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin-left:8px;vertical-align:middle}

/* Mobile: vertical stack — each tab full row with clear chevron + left
   accent border on active. Avoids both horizontal scroll AND wrapping. */
@media (max-width:700px){
  .tabs-nav{flex-direction:column;gap:0;border-bottom:none;border-top:1px solid var(--border);margin:0 -24px 32px;padding:0;flex-wrap:nowrap}
  .tab-btn{
    width:100%;text-align:left;padding:18px 24px;
    border:none;border-bottom:1px solid var(--border);
    border-left:3px solid transparent;margin:0;
    font-size:0.95rem;font-weight:600;
    display:flex;align-items:center;justify-content:space-between;gap:12px;
  }
  .tab-btn::before{
    content:'';width:8px;height:8px;border-radius:50%;
    background:var(--border);flex-shrink:0;transition:background .15s;
  }
  .tab-btn::after{
    content:'›';margin-left:auto;font-size:1.4rem;line-height:1;
    color:var(--text-muted);font-weight:400;transition:transform .15s,color .15s;
    background:none;width:auto;height:auto;border-radius:0;display:inline-block;vertical-align:baseline;
  }
  .tab-btn:hover,.tab-btn:focus-visible{background:var(--bg-muted,#f6f6f6);color:var(--text)}
  .tab-btn.active{
    background:rgba(90,172,186,0.08);color:var(--text);
    border-left-color:var(--accent);border-bottom-color:var(--border);
  }
  .tab-btn.active::before{background:var(--accent)}
  .tab-btn.active::after{transform:rotate(90deg);color:var(--accent)}
}
.tab-panel{display:none}
.tab-panel.active{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
@media (max-width:800px){.tab-panel.active{grid-template-columns:1fr;gap:32px}}
.tab-item h3{margin-bottom:0.75rem;font-size:1.125rem}
.tab-item p{font-size:0.95rem;max-width:none}
.tab-item .dot{width:8px;height:8px;background:var(--accent);display:inline-block;margin-bottom:1rem}

/* Full width image section */
.fullimg{
  position:relative;min-height:560px;
  background-size:cover;background-position:center;
  display:flex;align-items:center;color:white;
}
.fullimg::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(30,30,30,0.78) 0%,rgba(30,30,30,0.45) 100%);
}
.fullimg .container{position:relative}
.fullimg h2{color:white;max-width:28ch}
.fullimg p{color:rgba(255,255,255,0.85);font-size:1.05rem}
.fullimg .inner{max-width:1000px;padding-top:120px;padding-bottom:120px}
@media (max-width:800px){.fullimg{min-height:auto}.fullimg .inner{padding-top:72px;padding-bottom:72px}}
.fullimg .eyebrow{color:#8fd0db}

/* Role cards (4-col clickable) */
.role-grid{display:grid;grid-template-columns:repeat(var(--cols,4),1fr);gap:24px;margin-top:64px}
@media (max-width:1000px){.role-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.role-grid{grid-template-columns:1fr}}
.role-card{
  display:flex;flex-direction:column;
  background:white;padding:40px 32px;
  border:1px solid var(--border);
  text-decoration:none;color:var(--text);
  transition:all .25s;position:relative;
}
.role-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 32px -12px rgba(30,30,30,0.15)}
.role-card img{width:64px;height:64px;margin-bottom:28px}
.role-card .role-num{font-family:'Montserrat',sans-serif;font-size:2.25rem;font-weight:300;color:var(--accent);line-height:1;margin-bottom:24px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;display:block}
.role-card .role-label{font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);margin-bottom:0.875rem}
.role-card h3{font-size:1.25rem;line-height:1.25;margin-bottom:0.875rem;color:var(--text)}
.role-card p{font-size:0.925rem;color:var(--text-muted);max-width:none;flex:1}
.role-card .more{
  margin-top:24px;font-size:0.825rem;font-weight:600;
  color:var(--text);display:inline-flex;align-items:center;gap:6px;
  letter-spacing:0.02em;
}
.role-card .more svg{width:14px;height:14px;transition:transform .2s}
.role-card:hover .more{color:var(--accent)}
.role-card:hover .more svg{transform:translateX(3px)}

/* 4-col project types */
.four-col{display:grid;grid-template-columns:repeat(var(--cols,4),1fr);gap:32px;margin-top:64px}
@media (max-width:1000px){.four-col{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.four-col{grid-template-columns:1fr}}
.proj-card{
  background:white;padding:36px 28px;
  border:1px solid var(--border);
  transition:all .3s;
  position:relative;overflow:hidden;
}
.proj-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.proj-icon{width:56px;height:56px;margin-bottom:24px;display:block}
.proj-card h3{font-size:1.125rem;margin-bottom:0.625rem}
.proj-card p{font-size:0.9rem;max-width:none}

/* CTA — light gray (less heavy contrast against dark footer) */
.cta{background:var(--bg-muted);color:var(--text);padding:120px 0;position:relative;overflow:hidden;border-top:1px solid var(--border)}
.cta::before{content:'';position:absolute;top:0;right:0;width:50%;height:100%;background:linear-gradient(135deg,transparent,rgba(90,172,186,0.08));pointer-events:none}
.cta-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:end;position:relative}
.cta-action{text-align:right}
@media (max-width:800px){.cta-action{text-align:left}}
@media (max-width:800px){.cta-grid{grid-template-columns:1fr;gap:32px}}
.cta h2{color:var(--text);max-width:18ch;margin-bottom:1.5rem}
.cta p{color:var(--text-muted);font-size:1.125rem;max-width:none}
.cta .btn{background:var(--text);color:white;padding:1.25rem 2.5rem;font-size:1rem}
.cta .btn:hover{background:var(--accent);color:white}

/* Process flow */
.process-flow{display:flex;align-items:stretch;gap:0;margin-top:56px;flex-wrap:wrap;border:1px solid var(--border);background:white}
.process-step{flex:1;min-width:160px;text-align:center;padding:40px 20px;position:relative}
.process-step:not(:last-child){border-right:1px solid var(--border)}
.process-step .num{color:var(--accent);font-size:0.75rem;font-weight:700;letter-spacing:0.18em;margin-bottom:0.625rem;display:block}
.process-step h4{font-family:'Montserrat',sans-serif;font-size:1rem;font-weight:700;color:var(--text);letter-spacing:-0.005em}

/* Checkmark list */
.list-check{list-style:none;padding:0;margin-top:1.5rem}
.list-check li{padding:0.875rem 0 0.875rem 2rem;position:relative;border-bottom:1px solid var(--border);font-size:1.0625rem;color:var(--text);font-weight:500}
.list-check li:last-child{border-bottom:none}
.list-check li::before{content:'';position:absolute;left:0;top:1.4em;width:14px;height:2px;background:var(--accent)}

/* Auto-style raw <ul> in RichText body — same look as .list-check */
.text-section-block ul:not([class]),
.fullimg .inner ul:not([class]),
.content ul:not([class]),
.prose ul:not([class]){list-style:none;padding:0;margin-top:1.5rem}
.text-section-block ul:not([class]) li,
.fullimg .inner ul:not([class]) li,
.content ul:not([class]) li,
.prose ul:not([class]) li{padding:0.875rem 0 0.875rem 2rem;position:relative;border-bottom:1px solid var(--border);font-size:1.0625rem;color:var(--text);font-weight:500}
.text-section-block ul:not([class]) li:last-child,
.fullimg .inner ul:not([class]) li:last-child,
.content ul:not([class]) li:last-child,
.prose ul:not([class]) li:last-child{border-bottom:none}
.text-section-block ul:not([class]) li::before,
.fullimg .inner ul:not([class]) li::before,
.content ul:not([class]) li::before,
.prose ul:not([class]) li::before{content:'';position:absolute;left:0;top:1.4em;width:14px;height:2px;background:var(--accent)}
.fullimg .inner ul:not([class]) li{color:white;border-color:rgba(255,255,255,0.2)}

/* Job meta */
.job-meta{display:flex;gap:48px;flex-wrap:wrap;margin:2.25rem 0 2.5rem;padding:1.5rem 0;border-top:1px solid var(--border-strong);border-bottom:1px solid var(--border-strong)}
.job-meta > div{min-width:140px}
.job-meta .label{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);font-weight:600;margin-bottom:0.375rem}
.job-meta .value{font-size:1.0625rem;font-weight:600;color:var(--text)}

/* Path grid (2-col) */
.path-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:56px}
@media (max-width:800px){.path-grid{grid-template-columns:1fr}}
.path-card{display:flex;flex-direction:column;padding:48px;background:white;border:1px solid var(--border);transition:all .25s;text-decoration:none;color:var(--text)}
.path-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.path-card .icon{width:52px;height:52px;margin-bottom:28px}
.path-card .path-num{font-family:'Montserrat',sans-serif;font-size:2.5rem;font-weight:300;color:var(--accent);line-height:1;margin-bottom:24px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums}
.path-card h3{font-size:1.5rem;margin-bottom:0.875rem;line-height:1.2}
.path-card p{font-size:1rem;color:var(--text-muted);max-width:none;flex:1;margin-bottom:1.5rem}
.path-card .link{font-weight:600;color:var(--text);display:inline-flex;align-items:center;gap:8px;font-size:0.9rem}
.path-card:hover .link{color:var(--accent)}
.path-card .link svg{width:14px;height:14px;transition:transform .2s}
.path-card:hover .link svg{transform:translateX(3px)}

/* Recruitment steps */
.steps{display:grid;grid-template-columns:repeat(var(--cols,5),1fr);gap:0;margin-top:56px;background:white;border:1px solid var(--border)}
@media (max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.steps{grid-template-columns:1fr}}
.step{padding:36px 28px;position:relative}
.step:not(:last-child){border-right:1px solid var(--border)}
@media (max-width:900px){.step:nth-child(2n){border-right:none}.step:not(:last-child){border-bottom:1px solid var(--border)}}
.step .step-num{font-family:'Montserrat',sans-serif;font-size:2.5rem;font-weight:300;color:var(--accent);line-height:1;margin-bottom:1rem;display:block}
.step h3, .step h4{font-size:1rem;font-weight:600;margin-bottom:0.5rem;color:var(--text)}
.step p{font-size:0.9rem;max-width:none}
.step .step-text{font-size:0.9rem;color:var(--text-muted)}
.step .step-text p{font-size:0.9rem;margin:0 0 0.6rem}
.step .step-text p:last-child{margin-bottom:0}
.step .step-text ul, .step .step-text ol{font-size:0.9rem;margin:0 0 0.6rem;padding-left:1.2rem}
.step .step-text ul:last-child, .step .step-text ol:last-child{margin-bottom:0}
.step .step-text ul{list-style:none;padding-left:0}
.step .step-text ul li{position:relative;padding-left:1.1rem;margin-bottom:0.3rem}
.step .step-text ul li::before{content:'';position:absolute;left:0;top:0.7em;width:8px;height:2px;background:var(--accent)}
.step .step-text ol{padding-left:1.4rem}
.step .step-text ol li{margin-bottom:0.3rem}
.step .step-text strong{font-weight:600;color:var(--text)}
.step .step-text a{color:var(--accent);text-decoration:underline}

/* Benefits list grid */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);margin-top:48px}
@media (max-width:800px){.benefits{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.benefits{grid-template-columns:1fr}}
.benefit{background:white;padding:32px;display:flex;align-items:center;gap:16px}
.benefit::before{content:'';width:14px;height:2px;background:var(--accent);flex-shrink:0}
.benefit span{font-size:1rem;font-weight:500;color:var(--text)}

/* Config cards (tech specs) */
.config-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
@media (max-width:900px){.config-grid{grid-template-columns:1fr}}
.config-col{background:white;padding:36px 32px;border:1px solid var(--border)}
.config-col .config-label{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:1.25rem;display:block}
.config-col h4{font-family:'Montserrat',sans-serif;font-size:1.125rem;font-weight:700;margin:0 0 1.5rem;color:var(--text);padding-bottom:1rem;border-bottom:2px solid var(--text)}
.config-item{padding:1rem 0;border-bottom:1px solid var(--border)}
.config-item:last-child{border-bottom:none}
.config-item h5{font-size:0.95rem;font-weight:600;margin-bottom:0.375rem;color:var(--text)}
.config-item p{font-size:0.875rem;max-width:none;color:var(--text-muted)}

/* Doc grid (Technical 6-card) */
.doc-grid{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:24px;margin-top:56px}
@media (max-width:900px){.doc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:500px){.doc-grid{grid-template-columns:1fr}}
.doc-card{display:flex;flex-direction:column;padding:40px 32px;background:white;border:1px solid var(--border);text-decoration:none;color:var(--text);transition:all .25s;min-height:200px}
.doc-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.doc-card .tag{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:1rem}
.doc-card h3{font-size:1.25rem;font-weight:700;margin-bottom:0.5rem;line-height:1.25;flex:1;color:var(--text)}
.doc-card .link{font-weight:600;font-size:0.875rem;display:inline-flex;align-items:center;gap:6px;margin-top:1.5rem;color:var(--text)}
.doc-card .link svg{width:14px;height:14px;transition:transform .2s}
.doc-card:hover .link{color:var(--accent)}
.doc-card:hover .link svg{transform:translateX(3px)}

/* Open position card (careers listing) */
.jobs-list{margin-top:40px;border-top:1px solid var(--border)}
.job-row{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:24px;padding:28px 0;border-bottom:1px solid var(--border);align-items:center;text-decoration:none;color:var(--text);transition:all .2s}
.job-row:hover{background:var(--bg-muted);padding-left:16px;padding-right:16px}
@media (max-width:700px){.job-row{grid-template-columns:1fr;gap:4px;padding:20px 0}}
.job-row h4{font-size:1.125rem;font-weight:600;color:var(--text)}
.job-row .meta{font-size:0.875rem;color:var(--text-muted)}
.job-row .arrow{font-size:0.875rem;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.job-row .arrow svg{width:14px;height:14px}

/* Value cards (why work here) */
.values-grid{display:grid;grid-template-columns:repeat(var(--cols,2),1fr);gap:32px;margin-top:56px}
@media (max-width:800px){.values-grid{grid-template-columns:1fr}}
.value-item{padding:36px;background:white;border:1px solid var(--border)}
.value-item h4{font-size:1.125rem;font-weight:700;margin-bottom:0.875rem;color:var(--text)}
.value-item p{font-size:0.95rem;max-width:none}

/* Preview nav — group style */
.preview-group{display:inline-flex;align-items:center;gap:2px;padding:0 14px;border-left:1px solid rgba(255,255,255,0.08)}
.preview-group:first-child{border-left:none;padding-left:0}
.preview-group-label{color:rgba(255,255,255,0.38);font-size:0.68rem;letter-spacing:0.08em;text-transform:uppercase;margin-right:6px;font-weight:500}

/* Full-width hero — light scrim + dark text */
.hero.hero-full{
  min-height:56vh;padding:0;
  background-size:cover;background-position:center;
  background-color:var(--bg-muted);
  align-items:flex-end;display:flex;
  color:var(--text);position:relative;
}
.hero.hero-full::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,
    rgba(246,246,246,0.97) 0%,
    rgba(246,246,246,0.94) 32%,
    rgba(246,246,246,0.5) 52%,
    rgba(246,246,246,0.1) 68%,
    transparent 82%);
  pointer-events:none;
}
.hero.hero-full .hero-inner{
  position:relative;z-index:2;padding:120px 32px 72px;
}
@media (max-width:960px){.hero.hero-full .hero-inner{padding:96px 20px 56px}}
.hero.hero-full h1{color:var(--text);max-width:22ch}
.hero.hero-full p{color:var(--text);opacity:0.78}
.hero.hero-full .lead{color:var(--text);opacity:0.9;max-width:52ch}
.hero.hero-full .eyebrow{color:var(--accent)}
.hero.hero-full strong{color:var(--text);opacity:1}
.hero.hero-full .btn{background:var(--text);color:white}
.hero.hero-full .btn:hover{background:var(--accent)}
.hero.hero-full .btn-outline{background:transparent;color:var(--text);border-color:rgba(30,30,30,0.25)}
.hero.hero-full .btn-outline:hover{background:var(--text);color:white;border-color:var(--text)}

/* Hotel project grid (6+ project tiles) */
.hotel-grid{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:24px;margin-top:56px}
@media (max-width:900px){.hotel-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.hotel-grid{grid-template-columns:1fr}}
.hotel-card{
  position:relative;aspect-ratio:4/3;
  background-size:cover;background-position:center;
  overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;
  color:white;text-decoration:none;
  transition:transform .25s;
}
.hotel-card--tall{aspect-ratio:4/5}

/* Portfolio grid CTA link below tiles ("View all projects →" / "Wszystkie projekty →" / "Alle Projekte →") */
.portfolio-grid-cta{margin-top:48px;text-align:center}
.portfolio-grid-cta .more-link{
  display:inline-block;font-weight:600;color:var(--text);text-decoration:none;
  border-bottom:2px solid var(--accent);padding-bottom:4px;font-size:1rem;
  transition:color .2s
}
.portfolio-grid-cta .more-link:hover{color:var(--accent)}
.hotel-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(30,30,30,0.85) 100%);pointer-events:none}
.hotel-card:hover{transform:translateY(-3px)}
.hotel-card .tag{position:relative;padding:18px 18px 6px;font-size:0.7rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:#8fd0db}
.hotel-card h3, .hotel-card h4{position:relative;padding:0 18px 4px;font-family:'Montserrat',sans-serif;font-size:1.125rem;font-weight:700;color:white;line-height:1.2}
.hotel-card .loc{position:relative;padding:0 18px 18px;font-size:0.8rem;color:rgba(255,255,255,0.8)}
.hotel-card .pods{position:absolute;top:16px;right:16px;background:rgba(30,30,30,0.75);backdrop-filter:blur(8px);color:white;font-size:0.75rem;font-weight:600;padding:6px 12px}

/* ───────── Site header (sticky top, full-width mega) ───────── */
.site-header{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,0.94);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--border);
}
.site-header-inner{
  display:flex;align-items:center;gap:24px;
  max-width:var(--maxw);margin:0 auto;padding:0 32px;height:80px;
  position:relative;
}
.site-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.site-logo img{height:42px;width:auto;display:block}
.site-nav{display:flex;gap:0;align-items:center;flex:1;justify-content:center;white-space:nowrap}
.nav-item{position:static}
.nav-link{
  color:var(--text);text-decoration:none;font-size:0.84rem;font-weight:500;
  padding:30px 12px;display:inline-flex;align-items:center;gap:5px;
  transition:color .15s;letter-spacing:-0.005em;
  position:relative;white-space:nowrap;
}
.nav-link::after{
  content:'';position:absolute;left:12px;right:12px;bottom:0;height:2px;
  background:var(--accent);transform:scaleX(0);transform-origin:center;transition:transform .2s;
}
.nav-link:hover{color:var(--text)}
.nav-link:hover::after,.nav-item:hover .nav-link::after{transform:scaleX(1)}
.nav-link .chev{width:11px;height:11px;opacity:0.5;transition:transform .2s;flex-shrink:0}
.nav-item:hover .nav-link .chev{transform:rotate(180deg);opacity:1}

/* Mega menu — width matching content container */
.mega{
  position:absolute;left:32px;right:32px;top:calc(100% + 4px);
  opacity:0;pointer-events:none;transform:translateY(-4px);
  background:white;border:1px solid var(--border);
  box-shadow:0 24px 56px -24px rgba(30,30,30,0.22);
  transition:opacity .2s,transform .2s;
}
.nav-item.has-mega:hover .mega{opacity:1;transform:translateY(0);pointer-events:auto}
.mega-inner{
  display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:48px;
  padding:40px;
}
.mega-col{min-width:0}
/* Single-column mega → render links as horizontal grid */
.mega-inner > .mega-col:only-child{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:8px 24px;
}
.mega-inner > .mega-col:only-child .mega-title{grid-column:1/-1}
.mega-title{
  font-size:0.68rem;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--text-muted);font-weight:700;margin-bottom:1.25rem;
  padding-bottom:0.875rem;border-bottom:1px solid var(--border);
}
/* Cards inside col — horizontal cards (number tile + text) */
.mega-link{
  display:flex;gap:16px;padding:14px 12px;text-decoration:none;color:var(--text);
  border-radius:0;transition:all .15s;align-items:flex-start;
  border-left:2px solid transparent;
  margin:0 -12px;
}
.mega-link:hover{background:var(--bg-muted);border-left-color:var(--accent)}
.mega-link:hover strong{color:var(--accent)}
.mega-num{
  flex-shrink:0;font-family:'Montserrat',sans-serif;font-size:1.5rem;font-weight:700;
  color:#5aacba;
  min-width:42px;line-height:1.1;letter-spacing:-0.02em;
  font-variant-numeric:tabular-nums;
  padding-top:2px;
}
.mega-body{flex:1;min-width:0}
.mega-link strong{display:block;font-size:0.95rem;font-weight:600;margin-bottom:0.25rem;line-height:1.25;transition:color .15s;color:var(--text)}
.mega-link span{display:block;font-size:0.8rem;color:var(--text-muted);line-height:1.4}
.mega-link:hover span{color:var(--text-muted)}

.site-actions{display:flex;align-items:center;gap:14px;flex-shrink:0}
.lang-switch{display:inline-flex;align-items:center;gap:4px;font-size:0.78rem;font-weight:600;color:var(--text-muted);letter-spacing:0.05em}
.lang-switch button,.lang-switch a{text-decoration:none;
  background:transparent;border:none;
  padding:6px 4px;font-family:'Montserrat';font-size:0.78rem;font-weight:600;letter-spacing:0.05em;
  color:var(--text-light);cursor:pointer;transition:color .15s;
  border-bottom:2px solid transparent;
}
.lang-switch button:hover,.lang-switch a:hover{color:var(--text)}
.lang-switch button.active,.lang-switch a.active{color:var(--accent);text-decoration:none}
.lang-switch::before{content:'';display:inline-block;width:1px;height:20px;background:var(--border);margin-right:8px}
.btn-cta{
  background:var(--text);color:white !important;padding:13px 22px;
  font-size:0.78rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
  text-decoration:none;transition:all .2s;
  display:inline-flex;align-items:center;gap:10px;line-height:1;
}
.btn-cta svg{width:14px;height:14px;transition:transform .2s;flex-shrink:0}
.btn-cta:hover{background:var(--accent) !important}
.btn-cta:hover svg{transform:translateX(3px)}

@media (max-width:1340px){.site-nav .nav-link{padding:30px 9px;font-size:0.8rem}.site-header-inner{gap:16px}}
@media (max-width:1180px){.site-nav{display:none}}

/* ───────── Site footer ───────── */
.site-footer{background:var(--bg-dark);color:rgba(255,255,255,0.7);margin-top:0}
.site-footer-top{
  display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:40px;
  max-width:var(--maxw);margin:0 auto;padding:80px 32px 56px;
}
@media (max-width:1000px){.site-footer-top{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.site-footer-top{grid-template-columns:1fr}}
.footer-col h3, .footer-col h4{
  font-size:0.8rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  color:white;margin-bottom:1.25rem;
}
.footer-col a{
  display:block;padding:6px 0;color:rgba(255,255,255,0.6);font-size:0.875rem;
  text-decoration:none;transition:color .15s;
}
.footer-col a:hover{color:var(--accent)}
.footer-col.brand{padding-right:40px}
.footer-logo{margin-bottom:1.5rem}
.footer-logo img{height:54px;width:auto;display:block}
.footer-col.brand p{font-size:0.85rem;color:rgba(255,255,255,0.55);max-width:none;line-height:1.55;margin-bottom:1.5rem}
.footer-address{font-size:0.8rem;color:rgba(255,255,255,0.55);line-height:1.7}
.footer-address strong{color:white;font-weight:600}
.footer-address a{display:inline;padding:0;color:rgba(255,255,255,0.7)}
.footer-address a:hover{color:var(--accent)}

.site-footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding:24px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;max-width:var(--maxw);margin:0 auto;padding:0 32px;font-size:0.78rem;color:rgba(255,255,255,0.5)}
.footer-bottom-inner a{color:rgba(255,255,255,0.5);text-decoration:none;transition:color .15s}
.footer-bottom-inner a:hover{color:var(--accent)}
.legal-sep{margin:0 8px;opacity:0.4}
.social{display:flex;gap:12px;align-items:center}
.social a{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;color:rgba(255,255,255,0.65);transition:color .2s}
.social a:hover,.social a:focus-visible{color:#fff}
.social a svg{width:22px;height:22px;display:block}

/* Back to design system link in preview sidebar */
.preview-back-ds{
  display:flex;align-items:center;gap:6px;
  margin:0 12px 16px;padding:10px 14px;
  font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  color:rgba(255,255,255,0.6);text-decoration:none;
  background:rgba(255,255,255,0.04);border-left:2px solid var(--accent);
  transition:all .15s;
}
.preview-back-ds:hover{background:rgba(255,255,255,0.08);color:white}

/* === Home page specific === */
.home-hero{min-height:88vh;position:relative;overflow:hidden}
.home-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(1.05) saturate(0.65) contrast(0.95)}
.home-hero .hero-inner{position:relative;z-index:1}

/* Numbers strip (home page variant of stats) */
.numbers-strip{background:var(--bg-dark);color:white;padding:80px 0}
.numbers-strip .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;max-width:var(--maxw);margin:0 auto;padding:0 32px}
@media (max-width:800px){.numbers-strip .grid{grid-template-columns:1fr;gap:32px}}
.numbers-strip h3{font-family:'Montserrat',sans-serif;font-size:2.5rem;font-weight:300;color:var(--accent);line-height:1;margin-bottom:1rem}
.numbers-strip p{color:rgba(255,255,255,0.78);font-size:0.95rem;max-width:none}
.numbers-strip h4{font-size:1rem;color:white;font-weight:600;margin-bottom:0.5rem}
.num-item{padding-left:24px;border-left:2px solid var(--accent)}

/* Fullimg list-check on dark backgrounds */
.fullimg .list-check li{color:white;border-color:rgba(255,255,255,0.2)}

/* === Mobile navigation === */
.hamburger{display:none;background:transparent;border:none;cursor:pointer;padding:8px;width:40px;height:40px;flex-direction:column;justify-content:space-around;align-items:center;margin-left:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:1px;transition:all .3s}
body.nav-open .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .hamburger span:nth-child(2){opacity:0}
body.nav-open .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-overlay{display:none;position:fixed;top:80px;left:0;right:0;bottom:0;background:white;z-index:100;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-overlay-inner{padding:24px;max-width:var(--maxw);margin:0 auto;font-family:'Montserrat',sans-serif}
body.nav-open{overflow:hidden}
body.nav-open .mobile-overlay{display:block}

.mobile-menu-list{list-style:none;padding:0;margin:0}
.mobile-menu-list li{border-bottom:1px solid var(--border)}
.mobile-menu-toggle{width:100%;background:transparent;border:none;display:flex;justify-content:space-between;align-items:center;padding:20px 4px;font-family:'Montserrat',sans-serif;font-size:1.125rem;font-weight:600;color:var(--text);cursor:pointer;text-align:left}
.mobile-menu-toggle .mobile-menu-arrow{font-size:1.5rem;font-weight:300;color:var(--accent);transition:transform .3s}
.mobile-menu-item.is-open .mobile-menu-toggle .mobile-menu-arrow{transform:rotate(45deg)}
.mobile-menu-link-top{display:block;padding:20px 4px;font-family:'Montserrat',sans-serif;font-size:1.125rem;font-weight:600;color:var(--text);text-decoration:none}
.mobile-menu-item.has-children .mobile-menu-link-top{padding:0 0 16px 4px;font-size:0.85rem;color:var(--text-muted);font-weight:500;text-transform:none;letter-spacing:0;display:none}
.mobile-menu-item.has-children.is-open .mobile-menu-link-top{display:block}
.mobile-submenu{list-style:none;padding:0;margin:0}
.mobile-submenu-depth-0{max-height:0;overflow:hidden;transition:max-height .45s ease}
.mobile-menu-item.is-open > .mobile-submenu-depth-0{max-height:3000px}
.mobile-submenu-depth-1{padding-left:0}
.mobile-submenu-depth-1 > li{border-bottom:none}
.mobile-group-title{display:block;font-family:'Montserrat',sans-serif;font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);font-weight:700;margin:16px 0 8px 4px}
.mobile-menu-sublink{display:flex;gap:12px;align-items:baseline;padding:10px 4px;color:var(--text);text-decoration:none;font-size:0.95rem;font-family:'Montserrat',sans-serif;font-weight:500}
.mobile-menu-sublink .mobile-menu-num{color:var(--accent);font-weight:700;font-size:0.72rem;letter-spacing:0.1em;min-width:28px}

.mobile-lang-switch{margin-top:0;padding:24px 4px;display:flex;justify-content:space-between;align-items:center}
.mobile-lang-label{font-family:'Montserrat',sans-serif;font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);font-weight:700}
.mobile-lang-switch .lang-switch::before{display:none}
.mobile-lang-switch .lang-switch a{padding:8px 12px;font-size:1rem}

@media (max-width:1180px){
    .hamburger{display:flex}
    .lang-switch-desktop{display:none}
    .site-actions{gap:12px;margin-left:auto}
}
@media (max-width:600px){
    .btn-cta{font-size:0.72rem;padding:10px 14px}
    .btn-cta svg{display:none}
}


/* Safety: prevent horizontal scroll on any viewport */
html{overflow-x:clip}body{overflow-x:clip;max-width:100vw}

body.nav-open .site-header{position:fixed;top:0;left:0;right:0}

/* Pullquote (callout-list variant:quote) */
.erb-pullquote{padding:2rem 2.5rem;border-left:3px solid var(--accent);background:var(--bg-muted);font-family:"Montserrat",sans-serif;font-size:1.375rem;font-weight:500;color:var(--text);line-height:1.4;font-style:italic;max-width:720px;margin:3rem 0 0}
@media (max-width:600px){.erb-pullquote{padding:1.5rem 1.75rem;font-size:1.125rem}}

/* === Certificates List === */
.cert-group-title{margin-bottom:32px}
.cert-grid{display:grid;grid-template-columns:repeat(var(--cols,2),1fr);gap:24px;margin-top:40px}
@media(max-width:800px){.cert-grid{grid-template-columns:1fr}}
.cert-card{background:white;border:1px solid var(--border);border-radius:8px;padding:32px;display:flex;flex-direction:column;gap:16px;transition:box-shadow .2s}
.cert-card:hover{box-shadow:0 4px 20px rgba(0,0,0,0.08)}
.cert-card-head{display:flex;align-items:center;gap:16px}
.cert-logo{width:64px;height:64px;object-fit:contain;flex-shrink:0}
.cert-logo-placeholder{width:64px;height:64px;border-radius:8px;background:var(--bg-muted);display:flex;align-items:center;justify-content:center;font-size:0.65rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;flex-shrink:0;text-align:center}
.cert-card-head h4{font-size:1.1rem;font-weight:700;color:var(--text);margin:0}
.cert-card-head .cert-tag{font-size:0.68rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--accent);display:block;margin-top:2px}
.cert-card p{font-size:0.95rem;color:var(--text);opacity:0.8;line-height:1.6;margin:0}
.cert-card-body{display:flex;gap:24px;align-items:flex-start}
.cert-card-body>.cert-card-text{flex:1;min-width:0}
.cert-card-body>.cert-card-text>p{margin:0 0 0.875rem}
.cert-card-body>.cert-card-text>p:last-child{margin-bottom:0}
.cert-thumb{width:120px;flex-shrink:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#fafafa;cursor:pointer;transition:all .2s}
.cert-thumb:hover{box-shadow:0 4px 16px rgba(0,0,0,0.12);transform:scale(1.02)}
.cert-thumb img{width:100%;height:auto;display:block}
.cert-card-actions{margin-top:auto;padding-top:8px;display:flex;gap:12px;align-items:center}
.cert-download{display:inline-flex;align-items:center;gap:6px;font-size:0.78rem;font-weight:600;color:var(--accent);text-decoration:none;letter-spacing:0.03em;transition:color .15s}
.cert-download:hover{color:var(--text)}

/* Lightbox */
.cert-lightbox{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,0.85);align-items:center;justify-content:center;cursor:zoom-out}
.cert-lightbox.open{display:flex}
.cert-lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,0.4)}
.cert-lightbox-close{position:absolute;top:24px;right:32px;color:white;font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,0.1);transition:background .2s}
.cert-lightbox-close:hover{background:rgba(255,255,255,0.25)}

/* === FAQ grid === */
.faq-layout{display:grid;grid-template-columns:1fr 1fr;gap:32px 48px;max-width:var(--maxw);margin:0 auto;padding:32px 32px 80px}
@media(max-width:900px){.faq-layout{grid-template-columns:1fr;padding:48px 20px}}
.faq-item{position:relative;padding:32px;background:white;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.faq-watermark{position:absolute;right:12px;top:12px;font-size:5rem;font-weight:800;color:rgba(90,172,186,0.07);font-family:"Montserrat",sans-serif;line-height:1;pointer-events:none;user-select:none}
.faq-label{font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:0.75rem;display:block}
.faq-item h3{font-size:1.3rem;font-weight:700;color:var(--text);line-height:1.3;margin:0 0 1rem}
.faq-item p{color:var(--text);opacity:0.8;line-height:1.75;font-size:1.0625rem;max-width:580px}
.faq-item .tag{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-top:1.25rem;display:inline-flex;align-items:center;gap:6px;background:rgba(90,172,186,0.07);padding:6px 14px;border-radius:4px}
.faq-item .tag::before{content:"\2192";font-size:0.8rem}

/* === Comparison === */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--border);margin-top:56px}
@media (max-width:800px){.compare{grid-template-columns:1fr}}
.compare-col{background:white;padding:40px 36px}
.compare-col h3{font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--text)}
.compare-col.tradi h3{border-color:rgba(30,30,30,0.3)}
.compare-col.pods h3{color:var(--accent);border-color:var(--accent)}
.compare-col ul{list-style:none;padding:0}
.compare-col li{padding:0.875rem 0;border-bottom:1px solid var(--border);font-size:0.95rem;color:var(--text)}
.compare-col li:last-child{border-bottom:none}

/* Contact / info-block — used by card-grid variant=info|contact */
.contact-grid{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:24px;margin-top:56px}
@media (max-width:800px){.contact-grid{grid-template-columns:1fr}}
.info-block{background:white;padding:40px 32px;border:1px solid var(--border)}
.info-block .label{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:0.875rem;display:block}
.info-block h4{font-size:1.125rem;font-weight:700;margin-bottom:0.75rem;line-height:1.35}
.info-block a{color:var(--text);text-decoration:none;font-weight:500}
.info-block a:hover{color:var(--accent)}
.info-block p{font-size:0.95rem;color:var(--text-muted);margin:0}

/* Newsroom — featured tiles (image-tile-grid variant=featured) */
.featured-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
@media (max-width:800px){.featured-row{grid-template-columns:1fr}}
.news-featured{position:relative;aspect-ratio:16/10;overflow:hidden;background-size:cover;background-position:center;background-color:var(--bg-muted);text-decoration:none;color:white;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .25s}
.news-featured::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(30,30,30,0.88) 100%);pointer-events:none}
.news-featured:hover{transform:translateY(-3px)}
.news-featured .tag{position:absolute;top:16px;left:16px;background:var(--accent);color:white;padding:6px 12px;font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;z-index:1}
.news-featured h4{position:relative;padding:24px 24px 6px;font-family:'Montserrat',sans-serif;font-size:1.375rem;font-weight:700;color:white;line-height:1.2;margin:0}
.news-featured .loc{position:relative;padding:0 24px 24px;font-size:0.8rem;color:rgba(255,255,255,0.85)}

/* Newsroom — article cards (image-tile-grid variant=news) */
.news-grid{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:24px;margin-top:48px}
@media (max-width:900px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.news-grid{grid-template-columns:1fr}}
.news-card{position:relative;aspect-ratio:4/3;overflow:hidden;background-size:cover;background-position:center;background-color:var(--bg-muted);text-decoration:none;color:white;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .25s}
.news-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(30,30,30,0.85) 100%);pointer-events:none}
.news-card:hover{transform:translateY(-3px)}
.news-card .tag{position:absolute;top:12px;left:12px;background:var(--accent);color:white;padding:4px 10px;font-size:0.65rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;z-index:1}
.news-card h4{position:relative;padding:16px 16px 4px;font-family:'Montserrat',sans-serif;font-size:1rem;font-weight:700;color:white;line-height:1.25;margin:0}
.news-card .loc{position:relative;padding:0 16px 16px;font-size:0.75rem;color:rgba(255,255,255,0.85)}

/* Projects — tile grid (image-tile-grid variant=project) */
.proj-grid{display:grid;grid-template-columns:repeat(var(--cols,3),1fr);gap:24px;margin-top:48px}
@media (max-width:900px){.proj-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.proj-grid{grid-template-columns:1fr}}
.proj-tile{position:relative;aspect-ratio:4/5;overflow:hidden;background-size:cover;background-position:center;background-color:var(--bg-muted);text-decoration:none;color:white;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .25s}
.proj-tile::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(30,30,30,0.88) 100%);pointer-events:none}
.proj-tile:hover{transform:translateY(-3px)}
.proj-tile .pods{position:absolute;top:16px;right:16px;background:rgba(30,30,30,0.75);backdrop-filter:blur(8px);color:white;font-size:0.75rem;font-weight:600;padding:6px 12px;z-index:1}
.proj-tile .tag{position:absolute;top:16px;left:16px;background:var(--accent);color:white;padding:6px 12px;font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;z-index:1}
.proj-tile h4{position:relative;padding:24px 24px 4px;font-family:'Montserrat',sans-serif;font-size:1.125rem;font-weight:700;color:white;line-height:1.2;margin:0}
.proj-tile .loc{position:relative;padding:0 24px 24px;font-size:0.8rem;color:rgba(255,255,255,0.85)}

/* Stats-strip mobile — override inline grid-template-columns */
@media (max-width:800px){
  .stats-strip > div{grid-template-columns:1fr !important;gap:28px !important;padding:0 24px !important}
  .stats-strip > div > div{padding-left:20px !important}
  .stats-strip h3{font-size:2.75rem !important}
}

/* === Newsroom — category filters === */
.news-filters{display:flex;gap:10px;flex-wrap:wrap;margin:48px 0 40px;align-items:center}
.news-filters .fl-label{font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);font-weight:700;margin-right:12px}
.news-filters a{background:white;border:1px solid var(--border);padding:9px 18px;font-family:'Montserrat',sans-serif;font-size:0.85rem;font-weight:500;color:var(--text);cursor:pointer;transition:all .15s;text-decoration:none}
.news-filters a:hover{border-color:var(--accent);color:var(--accent)}
.news-filters a.active{background:var(--accent);color:white;border-color:var(--accent)}

/* === Newsroom — pagination === */
.erb-pagination{margin-top:56px;display:flex;justify-content:center}
.erb-pagination ul.page-numbers{list-style:none;padding:0;display:flex;gap:6px;flex-wrap:wrap}
.erb-pagination .page-numbers{background:white;border:1px solid var(--border);padding:10px 16px;min-width:44px;text-align:center;font-weight:500;font-size:0.875rem;color:var(--text);text-decoration:none;transition:all .15s;display:inline-block}
.erb-pagination .page-numbers:hover{border-color:var(--accent);color:var(--accent)}
.erb-pagination .page-numbers.current{background:var(--accent);color:white;border-color:var(--accent)}
.erb-pagination .page-numbers.next,.erb-pagination .page-numbers.prev{background:var(--text);color:white;border-color:var(--text);padding:10px 20px}

/* === Single article — hero === */
.article-hero{position:relative;min-height:52vh;background-size:cover;background-position:center;background-color:var(--bg-muted);display:flex;align-items:flex-end;overflow:hidden}
.article-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,30,30,0.3) 0%,rgba(30,30,30,0.85) 100%);pointer-events:none;z-index:0}
.article-hero-inner{position:relative;z-index:1;width:100%;max-width:var(--maxw);margin:0 auto;padding:64px 32px 80px}
.article-hero-copy{max-width:820px;color:white}
.article-hero h1{color:white;font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.15;margin:0.5rem 0 1.25rem}
.article-hero-plain{background:var(--bg-muted);min-height:auto;padding:72px 0 48px;align-items:center}
.article-hero-plain::before{display:none}
.article-hero-plain h1{color:var(--text);font-size:clamp(2rem,4vw,3rem);line-height:1.15;margin:0.5rem 0 1rem}

/* Article category tag */
.article-cat-tag{display:inline-block;background:var(--accent);color:white;padding:6px 14px;font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;text-decoration:none;transition:transform .2s}
.article-cat-tag:hover{transform:translateY(-2px);color:white}
.article-cat-tag-plain{background:var(--accent);color:white}
.article-meta{color:rgba(255,255,255,0.8);font-size:0.9rem;font-weight:500}
.article-hero-plain .article-meta{color:var(--text-muted)}

/* === Breadcrumb === */
.article-breadcrumb{background:white;border-bottom:1px solid var(--border);padding:16px 0;font-size:0.85rem}
.article-breadcrumb a{color:var(--text-muted);text-decoration:none;font-weight:500}
.article-breadcrumb a:hover{color:var(--accent)}

/* === Article body (prose typography) === */
.article-body{padding:72px 0 56px}
.article-prose{font-size:1.0625rem;line-height:1.7;color:var(--text)}
.article-prose h1,.article-prose h2,.article-prose h3,.article-prose h4{font-family:'Montserrat',sans-serif;font-weight:700;color:var(--text);line-height:1.25;margin-top:2.5rem;margin-bottom:1rem}
.article-prose h1{font-size:1.875rem}
.article-prose h2{font-size:1.625rem}
.article-prose h3{font-size:1.375rem}
.article-prose h4{font-size:1.125rem}
.article-prose p{margin-bottom:1.5rem}
.article-prose ul,.article-prose ol{margin:0 0 1.5rem 1.5rem;padding:0}
.article-prose ul li,.article-prose ol li{margin-bottom:0.625rem}
.article-prose ul.wp-block-list,.article-prose ol.wp-block-list{list-style:none;margin-left:0}
.article-prose ul.wp-block-list li{position:relative;padding-left:24px}
.article-prose ul.wp-block-list li::before{content:'';position:absolute;left:0;top:0.65em;width:8px;height:8px;background:var(--accent);border-radius:50%}
.article-prose strong{color:var(--text);font-weight:700}
.article-prose em{font-style:italic}
.article-prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.article-prose a:hover{color:var(--text)}
.article-prose blockquote{border-left:4px solid var(--accent);padding:1rem 1.5rem;margin:2rem 0;font-size:1.2rem;font-style:italic;color:var(--text-muted)}

/* Native Gutenberg blocks at top level of <main> — when Karolina pastes a
 * paragraph / heading / image / list / etc. directly into a page (outside any
 * erb/* block wrapper) they end up as direct children of <main> with no width
 * constraint and span the full viewport. Constrain them to our container
 * width and centre, matching the .std .container behaviour used elsewhere.
 *
 * Excludes: <section> (our erb/* blocks), .alignfull / .alignwide (deliberate
 * full-bleed). */
main > p,
main > h1, main > h2, main > h3, main > h4, main > h5, main > h6,
main > ul, main > ol, main > blockquote, main > pre, main > table, main > hr,
main > figure,
main > .wp-block-heading,
main > .wp-block-paragraph,
main > .wp-block-list,
main > .wp-block-quote,
main > .wp-block-image,
main > .wp-block-gallery,
main > .wp-block-table,
main > .wp-block-separator,
main > .wp-block-columns,
main > .wp-block-group,
main > .wp-block-embed,
main > .wp-block-html,
main > .wp-block-buttons,
main > .wp-block-cover,
main > .wp-block-media-text,
main > .wp-block-video,
main > .wp-block-audio {
  max-width: var(--maxw, 1280px);
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 32px;
  padding-right: 32px;
  box-sizing: border-box;
}
/* Vertical breathing room — Gutenberg blocks default to zero margin */
main > p, main > .wp-block-paragraph,
main > h1, main > h2, main > h3, main > h4,
main > .wp-block-heading,
main > ul, main > ol, main > .wp-block-list,
main > figure, main > .wp-block-image, main > .wp-block-gallery,
main > .wp-block-quote, main > blockquote,
main > .wp-block-columns, main > .wp-block-group,
main > .wp-block-embed, main > .wp-block-html, main > .wp-block-video,
main > .wp-block-cover, main > .wp-block-buttons,
main > table, main > .wp-block-table,
main > .wp-block-media-text, main > .wp-block-audio { margin-top: 1.5rem; margin-bottom: 1.5rem; }

/* Center alignment for explicitly aligncenter blocks */
main > .aligncenter,
main > .wp-block-image.aligncenter,
main > figure.aligncenter { text-align: center; }
main > .aligncenter img,
main > .wp-block-image.aligncenter img,
main > figure.aligncenter img { display: inline-block; max-width: 100%; height: auto; margin-left: auto; margin-right: auto; }

/* Full / wide alignment escape-hatch — let blocks bleed full viewport when
 * Karolina explicitly chooses "Full width" / "Wide" in editor */
main > .alignfull { max-width: none !important; padding-left: 0; padding-right: 0; }
main > .alignwide { max-width: 1600px; }

@media (max-width: 768px) {
  main > p,
  main > h1, main > h2, main > h3, main > h4, main > h5, main > h6,
  main > ul, main > ol, main > blockquote, main > pre, main > table, main > hr,
  main > figure,
  main > [class*="wp-block-"]:not(.alignfull) { padding-left: 20px; padding-right: 20px; }
}

/* Embedded video / iframe — default to text column width with 16:9 aspect.
 * Karolina pastes raw YouTube embed code (560×315 fixed) into wp:html block;
 * without this it sticks at 560px instead of filling the 820px text column.
 * Also handles native <video> tags and Gutenberg /embed blocks. */
.article-prose iframe,
.article-prose video,
.article-prose .wp-block-embed iframe,
.article-prose .wp-block-embed__wrapper iframe {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border: 0;
  margin: 2rem 0;
  background: #000;
}
.article-prose .wp-block-embed,
.article-prose .wp-block-embed__wrapper { max-width: 100%; margin: 2rem 0; }
.article-prose .wp-block-embed iframe,
.article-prose .wp-block-embed__wrapper iframe { margin: 0; }

/* Gutenberg image blocks */
.article-prose figure.wp-block-image{margin:2rem 0}
.article-prose figure.wp-block-image img{width:100%;height:auto;border:1px solid var(--border)}
.article-prose figure.wp-block-image figcaption{font-size:0.875rem;color:var(--text-muted);text-align:center;margin-top:0.75rem;font-style:italic}
.article-prose .wp-block-image.size-large img,.article-prose .wp-block-image.size-full img{width:100%}
.article-prose .wp-block-image.size-medium img{max-width:420px}

/* Gutenberg gallery */
.article-prose .wp-block-gallery{margin:2.5rem 0}
.article-prose .wp-block-gallery.has-nested-images{display:grid;gap:16px}
.article-prose .wp-block-gallery.columns-2{grid-template-columns:repeat(2,1fr)}
.article-prose .wp-block-gallery.columns-3{grid-template-columns:repeat(3,1fr)}
.article-prose .wp-block-gallery.columns-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:700px){.article-prose .wp-block-gallery{grid-template-columns:1fr !important}}
.article-prose .wp-block-gallery figure{margin:0}

/* Gutenberg separator */
.article-prose hr.wp-block-separator{border:none;border-top:1px solid var(--border);margin:3rem 0}

/* Gutenberg columns */
.article-prose .wp-block-columns{display:grid;gap:32px;margin:2rem 0}
.article-prose .wp-block-columns.has-2-columns{grid-template-columns:1fr 1fr}
.article-prose .wp-block-columns.has-3-columns{grid-template-columns:1fr 1fr 1fr}
@media (max-width:700px){.article-prose .wp-block-columns{grid-template-columns:1fr !important}}

/* Mobile article hero */
@media (max-width:700px){
  .article-hero{min-height:auto;padding:48px 0 40px}
  .article-hero-inner{padding:40px 24px 48px}
  .article-body{padding:48px 0}
  .article-prose{font-size:1rem}
}

/* ═══════════════════════════════════════════════════════════════════════════
 * PROJECTS + CUSTOMERS styling
 * Matches /przewodnik/project-single(-360).html and projects.html
 * ═══════════════════════════════════════════════════════════════════════════ */

/* ───── Projects archive filters ───── */
.proj-filters{display:flex;gap:10px;flex-wrap:wrap;margin:40px 0 24px;align-items:center}
.proj-filters .fl-label{font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);font-weight:700;margin-right:12px}
.proj-filters select{
  background:white;border:1px solid var(--border);
  padding:10px 36px 10px 16px;font-family:'Montserrat',sans-serif;font-size:0.85rem;font-weight:500;
  color:var(--text);cursor:pointer;transition:all .15s;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%23666' stroke-width='1.5' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
  min-width:170px
}
.proj-filters select:hover,.proj-filters select:focus{border-color:var(--accent);color:var(--accent);outline:none}
.proj-filters .btn-reset{background:transparent;border:0;padding:10px 8px;font-family:'Montserrat',sans-serif;font-size:0.85rem;color:var(--text-muted);text-decoration:none;font-weight:500}
.proj-filters .btn-reset:hover{color:var(--accent)}
.proj-filters .btn-submit{background:var(--text);color:white;border:0;padding:10px 18px;font-weight:600;cursor:pointer}

/* ───── Leaflet map on archive ───── */
#erb-projects-map{position:relative}
/* HQ map on /contact/ — inline aspect-ratio:21/9 makes it 161px tall on 375px
   mobile (panoramic ratio). Override on small screens to a usable square. */
@media (max-width:700px){
  #erb-hq-map{aspect-ratio:1/1!important;min-height:320px!important}
}

/* ─── Mobile section padding reset ───
   Desktop uses 120px / 80px vertical paddings on .std, .intro, .cta etc.
   Stacked on mobile that means 240px+ of empty space between sections.
   Reduce globally on small screens for a denser, more readable mobile flow. */
@media (max-width:700px){
  .intro,
  section.std,
  .cta{padding-top:60px;padding-bottom:60px}
  .numbers-strip{padding:48px 0}
  .related-projects{padding:48px 24px}
  .pano-card{padding:32px 20px}
}
@media (max-width:480px){
  .intro,
  section.std,
  .cta{padding-top:48px;padding-bottom:48px}
}
.leaflet-popup-content-wrapper{border-radius:4px;padding:4px 2px}
.leaflet-popup-content{margin:8px 12px;font-family:'Montserrat',sans-serif;font-size:0.85rem;line-height:1.45}
.leaflet-popup-content a{color:var(--accent)}

/* ───── Project single — back link ───── */
.project-back{padding:20px 32px;max-width:var(--maxw);margin:0 auto;font-size:0.875rem}
.project-back a{color:var(--text-muted);text-decoration:none;font-weight:500}
.project-back a:hover{color:var(--accent)}
.project-main{padding-top:0}

/* ───── Project hero ───── */
.project-hero{
  position:relative;aspect-ratio:21/9;max-height:620px;
  background-size:cover;background-position:center;background-color:var(--bg-muted);
  margin:0 32px;overflow:hidden
}
.project-hero::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(30,30,30,0.15) 0%,rgba(30,30,30,0.78) 100%);
}
.project-hero .info{
  position:absolute;left:48px;bottom:48px;right:48px;z-index:2;color:white;max-width:760px
}
@media (max-width:800px){
  .project-hero{margin:0;aspect-ratio:4/3;max-height:none}
  .project-hero .info{left:24px;right:24px;bottom:32px}
}
.project-hero .typ{display:inline-block;background:var(--accent);color:white;padding:6px 14px;font-size:0.7rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:16px}
.project-hero h1{color:white;font-size:clamp(1.8rem,4vw,3rem);line-height:1.15;margin:0 0 12px}
.project-hero .loc{font-size:1rem;color:rgba(255,255,255,0.88);font-weight:500}

/* ───── Meta bar ───── */
.meta-bar{background:white;border-bottom:1px solid var(--border)}
.meta-bar .container{max-width:var(--maxw);padding:0 32px}
.meta-grid{display:grid;grid-template-columns:repeat(var(--cols,5),1fr);gap:0;padding:32px 0}
@media (max-width:900px){.meta-grid{grid-template-columns:repeat(2,1fr);gap:20px;padding:24px 0}}
@media (max-width:500px){.meta-grid{grid-template-columns:1fr}}
.meta-item{padding:0 24px;border-right:1px solid var(--border)}
.meta-item:last-child{border-right:0}
@media (max-width:900px){.meta-item{border-right:0;padding:0 16px}}
.meta-label{font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted);font-weight:700;margin-bottom:8px}
.meta-value{font-size:1.5rem;font-weight:700;line-height:1.1;color:var(--text);font-family:'Montserrat',sans-serif}
.meta-value.meta-accent{color:var(--accent)}
.meta-value small{display:block;font-size:0.72rem;font-weight:400;color:var(--text-muted);margin-top:6px;letter-spacing:0;text-transform:none;line-height:1.35}

/* ───── Project body content ───── */
.project-content{padding:64px 32px 48px;max-width:820px;margin:0 auto}
.project-content h2{font-size:1.75rem;font-weight:700;margin:2.5rem 0 1rem;line-height:1.2}
.project-content p{font-size:1.0625rem;line-height:1.7;color:var(--text);margin-bottom:1.5rem}
.project-content p strong{font-weight:700}

/* Scope list */
.scope-list{background:var(--bg-muted);padding:32px 36px;margin:2.5rem 0;border-left:3px solid var(--accent)}
.scope-list h4{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:1rem}
.scope-list ul{list-style:none;padding:0;margin:0}
.scope-list li{position:relative;padding:8px 0 8px 24px;font-size:0.975rem;line-height:1.55;color:var(--text);border-bottom:1px solid rgba(30,30,30,0.06)}
.scope-list li:last-child{border-bottom:0}
.scope-list li::before{content:'';position:absolute;left:0;top:16px;width:8px;height:8px;background:var(--accent);border-radius:50%}

/* Gallery grid (inside project content) */
.project-content .gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:2.5rem 0}
@media (max-width:700px){.project-content .gallery{grid-template-columns:1fr}}
.project-content .gallery-item{aspect-ratio:4/3;background-size:cover;background-position:center;background-color:var(--bg-muted);display:block;transition:transform .25s}
.project-content .gallery-item:hover{transform:scale(1.01)}

/* ───── Panorama section (360 tours) ───── */
.pano-section{padding:0 32px 80px;max-width:820px;margin:0 auto}
@media (max-width:900px){.pano-section{max-width:none;padding:0 24px 60px}}
.pano-card{background:var(--bg-dark);padding:48px 40px;color:white}
.pano-card .eyebrow{color:#8fd0db}
.pano-card h2{color:white;max-width:22ch;margin:0.5rem 0 0.875rem}
.pano-card .lead{color:rgba(255,255,255,0.85);max-width:62ch;margin-top:1rem;font-size:1.0625rem}
.pano-frame{margin-top:32px;border:1px solid rgba(255,255,255,0.12);background:#0f1419;position:relative;aspect-ratio:16/9;overflow:hidden}
.pano-frame iframe{width:100%;height:100%;border:0;display:block}
@media (max-width:700px){.pano-frame{aspect-ratio:3/4}}
@media (max-width:700px){.pano-card{padding:32px 20px}}
@media (max-width:700px){.pano-fullscreen-btn{font-size:0.72rem;padding:10px 14px}}
.pano-frame:fullscreen{aspect-ratio:auto;width:100vw;height:100vh}
.pano-frame:fullscreen iframe{width:100%;height:100%}
/* JS-driven full-viewport overlay (more reliable on iOS than Fullscreen API).
   z-index above WP admin bar (32600) so logged-in viewers also see clean overlay. */
.pano-frame.is-fullscreen{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100vw!important;height:100vh!important;height:100dvh!important;z-index:999999!important;aspect-ratio:auto!important;border:0!important;margin:0!important}
.pano-frame.is-fullscreen iframe{width:100%;height:100%}
/* In fullscreen — both buttons flush against the very corners (no offset)
   so they fully cover kuula's own logo + UI buttons. */
.pano-frame.is-fullscreen .pano-badge,
.pano-frame.is-fullscreen .pano-fullscreen-btn{
  top:0!important;font-size:0.85rem;padding:12px 20px;height:auto;min-height:44px;letter-spacing:0.08em;
}
.pano-frame.is-fullscreen .pano-badge{left:0!important}
.pano-frame.is-fullscreen .pano-fullscreen-btn{right:0!important}
body.pano-locked{overflow:hidden;position:relative}
body.pano-locked #wpadminbar{display:none!important}
/* Override html overflow:clip (which would otherwise turn html into a
   containing block for fixed descendants → fixed:top:0 lands wherever html's
   top edge is, not the viewport). visible = viewport stays the containing
   block, so position:fixed truly fills the screen. */
html.pano-locked,html.pano-locked.wp-toolbar{margin-top:0!important;padding-top:0!important;overflow:visible!important}
.pano-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:white;padding:8px 14px;font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;z-index:1;line-height:1;display:inline-flex;align-items:center;height:34px;box-sizing:border-box}
.pano-fullscreen-btn{position:absolute;top:12px;right:12px;background:rgba(0,0,0,0.7);color:white;border:1px solid rgba(255,255,255,0.25);padding:8px 14px;font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:6px;z-index:2;backdrop-filter:blur(8px);transition:background .15s,border-color .15s;line-height:1;height:34px;box-sizing:border-box}
.pano-fullscreen-btn:hover,.pano-fullscreen-btn:focus{background:var(--accent);border-color:var(--accent)}
.pano-fullscreen-btn svg{width:14px;height:14px}
.pano-cta{margin-top:14px;display:flex;gap:16px;flex-wrap:wrap;align-items:center;font-size:0.85rem;color:rgba(255,255,255,0.6)}
.pano-cta a{color:#8fd0db;font-weight:600;text-decoration:none}
.pano-cta a:hover{color:white}

/* ───── Related projects ───── */
.related-projects{padding:80px 32px;background:var(--bg-muted)}
.related-projects .container{max-width:var(--maxw);margin:0 auto}
.related-projects .related-projects-back{margin-top:48px}
.related-projects-back-link{display:inline-flex;align-items:center;gap:8px;font-size:0.7rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--text);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color .15s,color .15s}
.related-projects-back-link:hover,.related-projects-back-link:focus{color:var(--accent);border-bottom-color:currentColor}

/* ───── Customers list + single ───── */
.customer-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px
}
@media (max-width:1000px){.customer-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:700px){.customer-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.customer-grid{grid-template-columns:1fr}}
.customer-card{
  background:white;border:1px solid var(--border);padding:32px 24px;
  text-decoration:none;color:var(--text);transition:all .2s;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  min-height:200px
}
.customer-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 32px -12px rgba(30,30,30,0.15)}
.customer-logo{min-height:80px;display:flex;align-items:center;justify-content:center;width:100%}
.logo-placeholder{width:72px;height:72px;border-radius:50%;background:var(--bg-muted);display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:1.875rem;font-weight:700;color:var(--accent)}
.customer-meta{text-align:center;margin-top:auto}
.customer-meta h4{font-size:1rem;font-weight:700;line-height:1.2;margin:0 0 6px}
.project-count{font-size:0.75rem;color:var(--text-muted);letter-spacing:0.08em}

.customer-chip{display:inline-flex;align-items:center;padding:16px 20px;background:white;border:1px solid var(--border);text-decoration:none;color:var(--text);transition:all .15s;min-height:80px}
.customer-chip:hover{border-color:var(--accent);transform:translateY(-2px)}

/* ═══════════════════════════════════════════════════════════════════════════
 * PROJECTS v2 fixes — full-width hero, new filter toolbar, map-bar, gallery slider
 * (Supersedes earlier rules via later cascade position.)
 * ═══════════════════════════════════════════════════════════════════════════ */

/* ───── #1 Filter toolbar — match mockup grid style ───── */
.filter-toolbar{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr auto;
  gap:16px;
  margin-top:40px;
  align-items:end;
}
@media (max-width:1100px){.filter-toolbar{grid-template-columns:1fr 1fr auto;gap:14px}}
@media (max-width:700px){.filter-toolbar{grid-template-columns:1fr;gap:12px;align-items:stretch}}
.filter-toolbar .field{display:flex;flex-direction:column;gap:6px}
.filter-toolbar .field-label{font-size:0.68rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-muted);font-weight:700}
.filter-toolbar input,
.filter-toolbar select{
  height:44px;padding:0 14px;font-family:'Montserrat',sans-serif;font-size:0.875rem;font-weight:500;
  border:1px solid var(--border);background:white;color:var(--text);
  transition:border-color .15s;appearance:none;
  border-radius:0;
  min-width:0;
  box-sizing:border-box;
  width:100%;
}
.filter-toolbar select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='none' stroke='%23666' stroke-width='1.5' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;
}
.filter-toolbar input:focus,
.filter-toolbar select:focus{outline:none;border-color:var(--accent)}
.filter-toolbar .search{position:relative}
.filter-toolbar .search .input-wrap{position:relative}
.filter-toolbar .search input{padding-left:42px}
.filter-toolbar .search .icn{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted);pointer-events:none}
.filter-toolbar .clear-btn{
  background:transparent;border:1px solid var(--border);
  height:44px;padding:0 18px;font-family:'Montserrat',sans-serif;font-size:0.78rem;font-weight:600;
  color:var(--text-muted);letter-spacing:0.05em;text-transform:uppercase;
  cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px;
  white-space:nowrap;
}
.filter-toolbar .clear-btn:hover{border-color:var(--accent);color:var(--accent)}
.filter-toolbar .clear-btn svg{width:14px;height:14px}

/* ───── Active chips + result counter row ───── */
.filter-meta-row{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin:24px 0 16px;min-height:32px}
.active-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;flex:1}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--accent);color:white;
  padding:6px 6px 6px 14px;font-size:0.78rem;font-weight:500;
  border-radius:0;
}
.chip button{
  background:transparent;border:0;color:white;cursor:pointer;
  width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;
  font-size:1rem;line-height:1;padding:0;border-radius:0;
}
.chip button:hover{background:rgba(0,0,0,0.2)}
.result-count{font-size:0.85rem;color:var(--text-muted);font-weight:500;white-space:nowrap}

/* ───── #2 Map section header bar ───── */
.map-bar{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:40px}
.map-counter{font-size:0.85rem;color:var(--text-muted);font-weight:500}
#erb-projects-map{aspect-ratio:21/9;width:100%;max-height:560px;border:1px solid var(--border);background:var(--bg-muted);z-index:0}
@media (max-width:700px){#erb-projects-map{aspect-ratio:4/3}}

/* ───── #5 Project-hero FULL WIDTH (edge-to-edge, no side margins) ───── */
.project-hero{
  position:relative;aspect-ratio:21/9;max-height:620px;min-height:380px;
  background-size:cover;background-position:center center;background-repeat:no-repeat;
  background-color:var(--bg-muted);
  margin:0;           /* was: margin:0 32px — now full width */
  width:100%;
  overflow:hidden;
}
.project-hero::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(30,30,30,0.15) 0%,rgba(30,30,30,0.78) 100%);
  pointer-events:none;
}
.project-hero .info{
  position:absolute;left:48px;bottom:48px;right:48px;z-index:2;color:white;max-width:820px;
}
@media (max-width:900px){.project-hero{aspect-ratio:4/3;max-height:none;min-height:380px}}
@media (max-width:700px){.project-hero .info{left:24px;right:24px;bottom:32px}}
/* Cap hero on very wide viewports (>= 1920px) so image isn't stretched beyond natural quality */
@media (min-width:1921px){.project-hero{max-height:720px}}

/* ───── #7 Gallery: featured hero (first 2 side-by-side) + slider (rest) ───── */
.erb-gallery-featured{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  gap:16px;
  margin:2.5rem 0 0;
}
.erb-gallery-featured[data-count="1"]{grid-template-columns:minmax(0, 1fr)}
.erb-gallery-featured-item{
  display:block;aspect-ratio:3/4;min-width:0;
  background-size:cover;background-position:center;background-color:var(--bg-muted);
  cursor:zoom-in;transition:transform .25s;position:relative;
}
.erb-gallery-featured-item:hover{transform:scale(1.005)}
.erb-gallery-featured-item::after{
  content:'';position:absolute;top:14px;right:14px;width:36px;height:36px;
  background:rgba(30,30,30,0.7) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3M11 8v6M8 11h6'/%3E%3C/svg%3E") center/20px no-repeat;
  border-radius:50%;opacity:0;transition:opacity .2s;
}
.erb-gallery-featured-item:hover::after{opacity:1}
@media (max-width:700px){
  .erb-gallery-featured{grid-template-columns:1fr}
}
.erb-gallery--rest{margin-top:16px !important}

/* ───── #7 Gallery slider (horizontal scroll-snap) ───── */
.erb-gallery{position:relative;margin:2.5rem 0}
.erb-gallery-track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(140px, 1fr);
  gap:14px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:var(--accent) var(--bg-muted);
  padding-bottom:12px;
}
.erb-gallery-track::-webkit-scrollbar{height:8px}
.erb-gallery-track::-webkit-scrollbar-track{background:var(--bg-muted)}
.erb-gallery-track::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}
/* When ≤5 images in the slider, show all in a single 5-col row (no scroll). Beyond that → horizontal scroll */
.erb-gallery[data-count="1"] .erb-gallery-track,
.erb-gallery[data-count="2"] .erb-gallery-track,
.erb-gallery[data-count="3"] .erb-gallery-track,
.erb-gallery[data-count="4"] .erb-gallery-track,
.erb-gallery[data-count="5"] .erb-gallery-track{
  grid-auto-flow:row;
  grid-template-columns:repeat(5,1fr);
  grid-auto-columns:auto;
  overflow:visible;
}
@media (max-width:900px){
  .erb-gallery[data-count="1"] .erb-gallery-track,
  .erb-gallery[data-count="2"] .erb-gallery-track,
  .erb-gallery[data-count="3"] .erb-gallery-track,
  .erb-gallery[data-count="4"] .erb-gallery-track,
  .erb-gallery[data-count="5"] .erb-gallery-track{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:600px){
  .erb-gallery[data-count="1"] .erb-gallery-track,
  .erb-gallery[data-count="2"] .erb-gallery-track,
  .erb-gallery[data-count="3"] .erb-gallery-track,
  .erb-gallery[data-count="4"] .erb-gallery-track,
  .erb-gallery[data-count="5"] .erb-gallery-track{grid-template-columns:repeat(2,1fr)}
  .erb-gallery-track{grid-auto-columns:minmax(160px,1fr)}
}
.erb-gallery-item{
  display:block;aspect-ratio:3/4;background-size:cover;background-position:center;background-color:var(--bg-muted);
  scroll-snap-align:start;cursor:zoom-in;transition:transform .25s;position:relative;min-width:0;
}
.erb-gallery-item:hover{transform:scale(1.015)}
.erb-gallery-item::after{
  content:'';position:absolute;top:12px;right:12px;width:32px;height:32px;
  background:rgba(30,30,30,0.7) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3M11 8v6M8 11h6'/%3E%3C/svg%3E") center/18px no-repeat;
  border-radius:50%;opacity:0;transition:opacity .2s;
}
.erb-gallery-item:hover::after{opacity:1}

.erb-gallery-controls{position:absolute;top:-56px;right:0;display:flex;gap:8px;z-index:2}
.erb-gallery-nav{
  background:white;border:1px solid var(--border);
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .15s;color:var(--text);
}
.erb-gallery-nav:hover{border-color:var(--accent);color:var(--accent)}
.erb-gallery-nav svg{width:18px;height:18px}

/* ───── Legacy cleanup: old .gallery-item from first version (still used elsewhere?) ───── */
.project-content .gallery{display:none}  /* supersede with .erb-gallery */

/* ───── Hero info aligned to content container (1440px max, 32px padding) ───── */
.project-hero .info{
  position:absolute;
  left:0;right:0;bottom:48px;
  z-index:2;color:white;
  /* supersede previous rules: remove left:48px fixed position */
}
.project-hero .info .container{
  max-width:var(--maxw);margin:0 auto;padding:0 32px;
}
.project-hero .info .container > *{max-width:820px}
@media (max-width:700px){.project-hero .info{bottom:32px}.project-hero .info .container{padding:0 24px}}

/* ───── Hero info aligned to content container (1440px max, 32px padding) ───── */
/* !important because earlier rules in the file set left:48px + max-width:820px */
.project-hero .info{
  position:absolute !important;
  left:0 !important;right:0 !important;bottom:48px !important;
  z-index:2;color:white;
  max-width:none !important;   /* override prior 820px */
  padding:0 !important;
}
.project-hero .info .container{
  max-width:var(--maxw);margin:0 auto;padding:0 32px;
}
.project-hero .info .container > *{max-width:820px}
@media (max-width:700px){
  .project-hero .info{bottom:32px !important}
  .project-hero .info .container{padding:0 24px}
}

/* Meta-bar first/last item — align first column's label with container edge + padding */
.meta-grid > .meta-item:first-child{padding-left:0}
.meta-grid > .meta-item:last-child{padding-right:0;border-right:0}

/* ═══════════════════════════════════════════════════════════════════════════
 * WP Gutenberg — Gallery with nested images (WP 6.x pattern).
 * Fallback in case block-library CSS doesn't reach the frontend.
 * Matches ERB typography (compact, 16px gap, cropped square images).
 * ═══════════════════════════════════════════════════════════════════════════ */
.wp-block-gallery.has-nested-images {
    display: flex !important;
    flex-wrap: wrap;
    gap: 16px;
    margin: 1.5rem 0 !important;
    grid-template-columns: unset !important;  /* kill WP broken layout */
}
.wp-block-gallery.has-nested-images > figure.wp-block-image {
    flex: 1 1 calc((100% - 48px) / 4);
    min-width: 180px;
    max-width: 100%;
    margin: 0 !important;
    position: relative;
    display: block;
}
.wp-block-gallery.has-nested-images.columns-1 > figure.wp-block-image { flex-basis: 100%; }
.wp-block-gallery.has-nested-images.columns-2 > figure.wp-block-image { flex-basis: calc((100% - 16px) / 2); }
.wp-block-gallery.has-nested-images.columns-3 > figure.wp-block-image { flex-basis: calc((100% - 32px) / 3); }
.wp-block-gallery.has-nested-images.columns-4 > figure.wp-block-image { flex-basis: calc((100% - 48px) / 4); }
.wp-block-gallery.has-nested-images.columns-5 > figure.wp-block-image { flex-basis: calc((100% - 64px) / 5); min-width: 140px; }
.wp-block-gallery.has-nested-images.columns-6 > figure.wp-block-image { flex-basis: calc((100% - 80px) / 6); min-width: 120px; }
.wp-block-gallery.has-nested-images > figure.wp-block-image > img,
.wp-block-gallery.has-nested-images > figure.wp-block-image > a > img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 2px;
}
.wp-block-gallery.has-nested-images.is-cropped > figure.wp-block-image > img,
.wp-block-gallery.has-nested-images.is-cropped > figure.wp-block-image > a > img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    height: 100%;
}
.wp-block-gallery.has-nested-images > figure.wp-block-image figcaption {
    font-size: 12px;
    color: var(--text-muted, #5a6472);
    margin-top: 6px;
    text-align: left;
}

/* Responsive collapse */
@media (max-width: 800px) {
    .wp-block-gallery.has-nested-images > figure.wp-block-image {
        flex-basis: calc((100% - 16px) / 2) !important;
    }
}
@media (max-width: 480px) {
    .wp-block-gallery.has-nested-images > figure.wp-block-image {
        flex-basis: 100% !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
 * Mega menu item — PHP walker uses <div class="mega-label"> + <div class="mega-desc">
 * (przewodnik/site-chrome.js używa <strong>+<span> — obsługiwane wyżej w pliku).
 * Title gets bold 700 so nadrzędne linki odróżniają się wizualnie od opisu.
 * Future mega-menu manager GUI can write these same classes.
 * ═══════════════════════════════════════════════════════════════════════════ */
.mega-link .mega-label {
    display: block;
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 0.25rem;
    color: var(--text);
    transition: color .15s;
    white-space: normal;
    word-break: break-word;
    overflow-wrap: anywhere;
    hyphens: auto;
}
.mega-link .mega-desc,
.mega-link span,
.mega-link strong {
    white-space: normal;
    word-break: break-word;
    overflow-wrap: anywhere;
}
.mega-link:hover .mega-label,
.mega-link:focus .mega-label {
    color: var(--accent);
}
.mega-link .mega-desc {
    display: block;
    font-size: 0.8rem;
    font-weight: 400;
    line-height: 1.4;
    color: var(--text-muted);
}
.mega-link:hover .mega-desc,
.mega-link:focus .mega-desc {
    color: var(--text-muted);
}

/* Text-section blocks: bullets visually flow with body paragraphs (same muted color, weight, size) — keep brand teal dash + bottom border */
.text-section-block .list-check li {
    color: var(--text-muted);
    font-weight: 400;
    font-size: 1rem;
    line-height: 1.7;
}
