:root{
  --bg: radial-gradient(circle at center, #3a6b8e 0%, #1c3d5a 100%);
  --ink:#fff;
  --muted: rgba(255,255,255,.78);
  --glass: rgba(255,255,255,.08);
  --glass2: rgba(255,255,255,.12);
  --stroke: rgba(255,255,255,.15);
  --shadow: 0 18px 50px rgba(0,0,0,0.35);
  --max: 1320px;
  --pad: clamp(18px, 4vw, 52px);
  --showhome-optical-shift: 48px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  background-attachment:fixed;
  color:var(--ink);
  line-height:1.7;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:-30vh -20vw;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.10), transparent 35%),
    radial-gradient(circle at 80% 30%, rgba(255,255,255,.08), transparent 40%),
    radial-gradient(circle at 55% 75%, rgba(255,255,255,.06), transparent 42%);
  filter: blur(18px);
  opacity:.55;
  pointer-events:none;
  z-index:-1;
}
h1,h2,h3{font-family:'Cinzel',serif;font-weight:400;letter-spacing:3px}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{padding:110px 0}
.section-title{text-align:center;margin-bottom:58px}
.section-title h2{font-size:2.2rem}
.section-title p{margin-top:14px;color:var(--muted);font-weight:200;letter-spacing:.06em;font-size:.95rem}

nav{
  padding:18px var(--pad);
  display:flex;
  justify-content:space-between;
  align-items:center;
  position:fixed;
  width:100%;
  top:0;
  z-index:1000;
  background: rgba(28, 61, 90, 0.42);
  backdrop-filter: blur(15px);
  border-bottom:1px solid var(--stroke);
  gap:18px;
}
.brand{display:flex;align-items:center;gap:12px;min-width:160px}
.brand .wordmark{font-family:'Cinzel',serif;font-size:1.25rem;letter-spacing:8px;opacity:.92;text-transform:uppercase;line-height:1}

.links{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.links a{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:2px;
  opacity:.92;
  transition:.25s;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid transparent;
}
.links a:hover{opacity:1;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.links a[aria-current="page"]{opacity:1;background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18)}

.hero{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  padding: 120px var(--pad) 0;
}
.hero h1{
  font-size:clamp(2.6rem,8vw,5.6rem);
  margin-bottom:18px;
  text-shadow:0 10px 30px rgba(0,0,0,0.2);
  letter-spacing:10px;
}
.hero-tagline{
  font-size:.86rem;
  letter-spacing:6px;
  text-transform:uppercase;
  border-top:1px solid rgba(255,255,255,0.45);
  border-bottom:1px solid rgba(255,255,255,0.45);
  padding:14px 38px;
  font-weight:300;
}
.hero-sub{
  margin-top:26px;
  max-width: 980px;
  color:rgba(255,255,255,.86);
  font-weight:200;
  font-size:1.0rem;
  line-height:1.9;
}

.glass{
  background:var(--glass);
  border:1px solid var(--stroke);
  backdrop-filter:blur(7px);
  padding:52px;
  transition:.35s;
  box-shadow:var(--shadow);
}
.glass:hover{background:var(--glass2);transform:translateY(-6px)}
.glass p{font-weight:200;font-size:.95rem;margin-top:14px;color:rgba(255,255,255,.86)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px}

.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border:1px solid rgba(255,255,255,.75);
  color:white;text-transform:uppercase;letter-spacing:2px;font-size:.72rem;
  transition:.35s;background:rgba(255,255,255,0.06);white-space:nowrap;
  cursor:pointer;
}
.btn:hover{background:white;color:#1c3d5a}
.btn.subtle{border-color:rgba(255,255,255,.35);background:rgba(255,255,255,0.04);opacity:.92}
.btn.subtle:hover{opacity:1}

/* SHOWHOME */
.showhome-wrap{padding:0; position:relative}
.showhome-full{position:relative;width:100%;min-height:min(78vh,760px);margin-top:76px}
.showhome-media{position:absolute;inset:0;left:50%;transform:translateX(-50%);width:100vw;height:100%;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);
  background:radial-gradient(1200px 700px at 30% 20%, rgba(255,255,255,.14), transparent 50%),
             radial-gradient(900px 520px at 70% 55%, rgba(255,255,255,.10), transparent 55%),
             linear-gradient(135deg, rgba(0,0,0,.18), rgba(0,0,0,.05));
  box-shadow: var(--shadow);
}
.showhome-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.06);
  transition:opacity 1.0s ease;will-change:transform,opacity;filter:saturate(1.04) contrast(1.03)}
.showhome-slide.is-active{opacity:1;animation:showhomeKenBurns 7s ease-in-out forwards}
@keyframes showhomeKenBurns{0%{transform:scale(1.06) translate3d(-1%,-1%,0)}100%{transform:scale(1.14) translate3d(1%,1%,0)}}
.showhome-grad{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.14),rgba(0,0,0,.44));pointer-events:none;z-index:3}
.showhome-dots{position:absolute;left:18px;bottom:16px;display:flex;gap:8px;z-index:4}
.showhome-dot{width:8px;height:8px;border-radius:999px;border:1px solid rgba(255,255,255,.55);background:rgba(0,0,0,.18);cursor:pointer;opacity:.85;padding:0}
.showhome-dot.is-active{background:rgba(255,255,255,.80);opacity:1}

.showhome-copy{position:relative;z-index:5;height:100%;display:flex;align-items:center;justify-content:flex-end;pointer-events:none}
.showhome-copy .panel{pointer-events:auto;width:min(580px,92vw);margin-right:var(--pad);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px);
  box-shadow:0 20px 40px rgba(0,0,0,0.25);padding:52px;text-align:left;
  transform: translateY(var(--showhome-optical-shift));}
.showhome-copy h2{font-size:1.9rem;margin-bottom:10px}
.showhome-copy p{color:rgba(255,255,255,.86);font-weight:200}
.showhome-kicker{margin-top:14px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;opacity:.88;border-top:1px solid rgba(255,255,255,.22);padding-top:14px}
.showhome-kicker a{border-bottom:2px solid rgba(255,255,255,.85);padding-bottom:4px;font-weight:600}

/* Accordion + galleries */
.real-accordion{display:flex;flex-direction:column;gap:14px}
.real-item{border:1px solid var(--stroke);background:var(--glass);box-shadow:var(--shadow)}
.real-head{
  width:100%;
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:18px;
  align-items:center;
  padding:22px 22px;
  background:transparent;
  border:0;
  color:var(--ink);
  cursor:pointer;
  text-align:left;
}
.real-title{font-family:'Cinzel',serif;letter-spacing:3px;font-size:1.05rem}
.real-meta{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;opacity:.78;white-space:nowrap}
.real-icon{width:34px;height:34px;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;font-size:1.1rem;line-height:1;opacity:.85;transition:transform .25s ease, background .25s ease, opacity .25s ease}
.real-item.open .real-icon{transform:rotate(45deg);opacity:1;background:rgba(255,255,255,.06)}
.real-head:hover{background:rgba(255,255,255,.06)}
.real-body{border-top:1px solid rgba(255,255,255,.12);max-height:0;overflow:hidden;transition:max-height .45s ease}
.real-item.open .real-body{max-height:900px}
.real-body-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;padding:22px}
.real-text p{color:rgba(255,255,255,.86);font-weight:200}

.real-media{position:relative;min-height:260px;border:1px solid rgba(255,255,255,.14);overflow:hidden;background:rgba(0,0,0,.10)}
.real-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s ease}
.real-media img.is-active{opacity:1}
.real-media .dots{position:absolute;left:14px;bottom:12px;display:flex;gap:8px;z-index:3}
.real-media .dot{width:8px;height:8px;border-radius:999px;border:1px solid rgba(255,255,255,.55);background:rgba(0,0,0,.18);cursor:pointer;opacity:.85}
.real-media .dot.is-active{background:rgba(255,255,255,.80);opacity:1}

/* Contact */
.contact-box{max-width:var(--max);margin:0 auto;padding:54px}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:stretch;text-align:left}
.contact-left{display:flex;flex-direction:column;justify-content:center}
.contact-line{margin-top:18px;font-weight:200;color:rgba(255,255,255,.86);font-size:.98rem}
#kontakt .contact-left a{border-bottom:2px solid rgba(255,255,255,.85);padding-bottom:6px;font-weight:600}
.map-wrap{position:relative;width:100%;min-height:360px;overflow:hidden;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);backdrop-filter:blur(10px);box-shadow:0 18px 50px rgba(0,0,0,0.25)}
.map-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

footer{text-align:center;padding:60px 18px;font-size:.72rem;letter-spacing:2px;opacity:.65;border-top:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.12)}

.page-hero{padding:140px var(--pad) 40px;text-align:center;}
.page-hero h1{font-size:clamp(2.0rem,5vw,3.4rem);letter-spacing:8px}
.page-hero p{margin-top:18px;color:rgba(255,255,255,.86);font-weight:200;max-width:980px;margin-left:auto;margin-right:auto;line-height:1.9}
.breadcrumbs{opacity:.8;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin-top:16px}
.breadcrumbs a{border-bottom:1px solid rgba(255,255,255,.5)}
.faq{display:grid;grid-template-columns:1fr;gap:14px}
.faq details{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);padding:16px 18px}
.faq summary{cursor:pointer;letter-spacing:.06em}
.faq p{margin-top:10px;color:rgba(255,255,255,.86);font-weight:200}
/* ===== Wiedza / Artykuły (premium, szerzej) ===== */
.article-premium{max-width:1180px;margin:0 auto}
.article-premium h1{font-size:clamp(1.55rem,2.2vw,1.9rem);letter-spacing:3px;line-height:1.25;margin-bottom:18px;text-align:center}
.article-premium h2{font-size:clamp(1.4rem,2.2vw,1.85rem);letter-spacing:3px;line-height:1.3;max-width:980px;margin:0 auto 12px;text-align:center}
.article-premium p{max-width:none}
.article-divider{border:0;height:1px;background:rgba(255,255,255,.18);margin:44px auto;max-width:100%}
@media (max-width: 900px){
  .article-divider{margin:32px auto}
}

@media (max-width: 900px){
  :root{ --showhome-optical-shift: 0px; }
  .links{display:none}
  .real-head{grid-template-columns:1fr;gap:10px}
  .real-meta{white-space:normal}
  .real-icon{justify-self:start}
  .real-body-inner{grid-template-columns:1fr}
  .real-media{min-height:220px}
  .contact-grid{grid-template-columns:1fr;text-align:center}
  .contact-left{text-align:center}
  .map-wrap{min-height:320px}
  .glass{padding:40px}
  .section{padding:92px 0}
}


/* --- Oferta dropdown (nav) --- */
.topnav{display:flex;align-items:center;justify-content:space-between;gap:18px}
.topnav .links{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.nav-dd{position:relative;display:inline-flex;align-items:center}
.nav-dd-btn{
  font: inherit;
  color: inherit;
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  padding:10px 12px;
  border-radius:999px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-size:.78rem;
  opacity:.92;
  transition:.25s;
}
.nav-dd-btn:hover{opacity:1;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14)}
.nav-dd-menu{
  position:absolute;
  top: calc(100% + 10px);
  left: 0;
  min-width: 220px;
  padding: 10px;
  background: rgba(28, 61, 90, 0.55);
  backdrop-filter: blur(14px);
  border:1px solid rgba(255,255,255,.16);
  border-radius:16px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.35);
  display:none;
  z-index:1200;
}
.nav-dd.open .nav-dd-menu{display:block}
.nav-dd-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  letter-spacing:.10em;
  text-transform:uppercase;
  font-size:.75rem;
  opacity:.92;
}
.nav-dd-menu a:hover{background:rgba(255,255,255,.08);opacity:1}
.nav-dd-caret{opacity:.75;margin-left:6px}
@media (max-width: 820px){
  .nav-dd-menu{position:static;display:block;background:transparent;border:0;box-shadow:none;padding:0}
  .nav-dd.open .nav-dd-menu{display:block}
}


html{font-size:16px;}
nav.topnav{font-size:16px;}
nav.topnav .links a,
nav.topnav .nav-dd-btn{font-size:12px;} /* was .78rem */
nav.topnav .brand .wordmark{font-size:20px;} /* was 1.25rem */


}


/* ===== SINNOVA NAV (single source of truth) ===== */
nav.topnav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; gap:18px;
  padding:18px var(--pad);
  background: rgba(28, 61, 90, 0.42);
  backdrop-filter: blur(15px);
  border-bottom:1px solid rgba(255,255,255,.15);
}
nav.topnav .brand{display:flex;align-items:center;gap:12px;min-width:160px}
nav.topnav .wordmark{font-family:'Cinzel',serif;font-size:1.15rem;letter-spacing:8px;opacity:.92;text-transform:uppercase;line-height:1}
nav.topnav .links{
  flex:1;
  display:flex;
  align-items:stretch;
  justify-content:space-between;
  gap:10px;
}
nav.topnav .links > a,
nav.topnav .nav-dd-btn{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:2px;
  opacity:.92;
  transition:.25s;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid transparent;
  background:transparent;
  cursor:pointer;
  white-space:nowrap;
}
nav.topnav .links > a:hover,
nav.topnav .nav-dd-btn:hover{
  opacity:1;
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.14);
}
nav.topnav .nav-dd{position:relative;display:flex;flex:1}
nav.topnav .nav-dd-menu{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  width:100%;
  min-width:220px;
  padding:10px;
  display:none;
  background:rgba(28, 61, 90, 0.78);
  border:1px solid rgba(255,255,255,.15);
  border-radius:18px;
  box-shadow:0 18px 50px rgba(0,0,0,.35);
  backdrop-filter: blur(15px);
}
nav.topnav .nav-dd.open .nav-dd-menu{display:block}
nav.topnav .nav-dd-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  font-size:.78rem;
  letter-spacing:1.6px;
  text-transform:uppercase;
  opacity:.92;
  border:1px solid transparent;
}
nav.topnav .nav-dd-menu a:hover{opacity:1;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);}

@media (max-width: 920px){
  nav.topnav .links{gap:6px}
  nav.topnav .links > a, nav.topnav .nav-dd-btn{font-size:.72rem;letter-spacing:1.6px;padding:9px 10px}
}
@media (max-width: 820px){
  nav.topnav .links{display:none}
}



/* --- Developer packages (premium tiles) --- */
.dev-packages{
  margin-top: 22px;
}
.package-card{
  position: relative;
}
.package-head{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}
.package-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
}
.package-note{
  opacity:.8;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.package-includes{
  margin: 0 0 10px;
  opacity:.9;
}
.package-list{
  margin: 0;
  padding-left: 18px;
}
.package-list li{
  margin: 8px 0;
  opacity:.95;
}
.package-badge.bronze{ background: rgba(205,127,50,.14); }
.package-badge.silver{ background: rgba(192,192,192,.12); }
.package-badge.gold{ background: rgba(212,175,55,.14); }


/* ===== MOBILE OPTIMIZATION ===== */
@media (max-width: 900px){

  .container{
    padding:0 22px;
  }

  .section{
    padding:70px 0;
  }

  h1{
    font-size:1.8rem;
    letter-spacing:2px;
  }

  h2{
    font-size:1.4rem;
    letter-spacing:2px;
  }

  h3{
    letter-spacing:1.5px;
  }

  nav{
    padding:14px 20px;
    flex-wrap:wrap;
    gap:10px;
  }

  .brand{
    min-width:auto;
  }

  .brand .wordmark{
    font-size:1rem;
    letter-spacing:5px;
  }

  .links{
    width:100%;
    justify-content:center;
    margin-top:6px;
    gap:4px;
  }

  .links a,
  .nav-dd-btn{
    font-size:.8rem;
    padding:6px 8px;
  }

  .hero,
  .hero-inner{
    min-height:auto !important;
    padding-top:110px !important;
    padding-bottom:40px !important;
  }

  .section-title{
    margin-bottom:34px;
  }

  .section-title h2{
    font-size:1.45rem;
  }

  .grid,
  .cards,
  .offer-grid,
  .wiedza-grid,
  .systemy-grid,
  .dev-packages-grid,
  .dev-why-grid,
  .prefab-grid,
  .prefab-combined{
    grid-template-columns:1fr !important;
    gap:18px !important;
  }

  .glass,
  .panel,
  .article-card,
  .wiedza-card,
  .systemy-card,
  .dev-pack,
  .dev-why-item{
    padding:24px 20px !important;
    border-radius:14px !important;
  }

  .real-body-inner{
    flex-direction:column !important;
  }

  .real-text,
  .real-media{
    width:100% !important;
  }

  .real-media{
    margin-top:18px;
    min-height:220px !important;
  }

  .prefab-right,
  .prefab-left{
    width:100% !important;
  }

  .prefab-frame,
  .prefab-slide{
    height:auto !important;
    min-height:220px !important;
  }

  img{
    max-width:100%;
    height:auto;
  }

  .btn{
    width:100%;
    justify-content:center;
  }
}


/* ===== MOBILE HOTFIX: narrow cards / process sections ===== */
@media (max-width: 900px){
  body{
    overflow-x:hidden !important;
  }

  .container,
  .article-card,
  .panel,
  .glass{
    max-width:100% !important;
  }

  /* steps / process cards */
  .steps,
  .process-grid,
  .timeline-grid,
  .roadmap-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .step,
  .process-card,
  .timeline-card,
  .roadmap-card{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    grid-column:auto !important;
    margin:0 !important;
    padding:22px 20px !important;
  }

  /* fix any horizontal sliders/cards still forced in row */
  .cards-row,
  .horizontal-cards,
  .slider-track,
  .dev-packages-grid,
  .wiedza-grid,
  .systemy-grid,
  .prefab-grid,
  .prefab-combined,
  .dev-why-grid{
    width:100% !important;
    max-width:100% !important;
  }

  /* headings in cards */
  .step h3,
  .step h2,
  .process-card h3,
  .panel h3{
    font-size:1.15rem !important;
    line-height:1.45 !important;
    letter-spacing:1px !important;
  }

  .step p,
  .process-card p,
  .panel p,
  .glass p{
    font-size:1rem !important;
    line-height:1.65 !important;
    word-break:normal !important;
    overflow-wrap:break-word !important;
  }
}


/* ===== MOBILE TITLE FIX FOR PROCESS CARDS ===== */
@media (max-width:900px){

/* reduce spacing that breaks titles */
.step h1,
.step h2,
.step h3,
.process-card h1,
.process-card h2,
.process-card h3{

  font-size:1.1rem !important;
  letter-spacing:0.5px !important;
  line-height:1.35 !important;
  word-break:normal !important;
  overflow-wrap:break-word !important;

}

/* ensure cards use full width */
.step,
.process-card,
.panel,
.glass{

  width:100% !important;
  max-width:100% !important;
  padding:22px 20px !important;

}

/* stack cards vertically */
.steps,
.process-grid{

  display:grid !important;
  grid-template-columns:1fr !important;
  gap:18px !important;

}

}


/* ===== MOBILE UX V4 ===== */
.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:12px;
  background:rgba(255,255,255,.05);
  color:#fff;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.nav-toggle span,
.nav-toggle span::before,
.nav-toggle span::after{
  content:"";
  display:block;
  width:18px;
  height:1.5px;
  background:#fff;
  border-radius:2px;
  position:relative;
  transition:.28s ease;
}
.nav-toggle span::before{position:absolute; top:-6px; left:0;}
.nav-toggle span::after{position:absolute; top:6px; left:0;}

.mobile-sticky-contact{
  display:none;
  position:fixed;
  left:16px;
  right:16px;
  bottom:14px;
  z-index:1200;
  gap:10px;
}
.mobile-sticky-contact a{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(28,61,90,.88);
  backdrop-filter:blur(10px);
  box-shadow:0 10px 30px rgba(0,0,0,.24);
  color:#fff;
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}

@media (max-width:900px){
  body{padding-bottom:78px;}
  nav{align-items:center;}
  .nav-toggle{display:flex; margin-left:auto;}
  .links{
    display:none !important;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:8px !important;
    margin-top:10px;
    padding:10px 0 4px;
  }
  nav.nav-open .links{display:flex !important;}
  .links a,
  .nav-dd-btn{
    width:100%;
    justify-content:flex-start;
    text-align:left;
    padding:12px 14px !important;
    border:1px solid rgba(255,255,255,.10);
    border-radius:12px;
    background:rgba(255,255,255,.04);
  }
  .nav-dd{width:100%;}
  .nav-dd-menu{
    position:static !important;
    display:none;
    width:100%;
    margin-top:6px;
    border-radius:12px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.04);
    box-shadow:none !important;
  }
  .nav-dd.open .nav-dd-menu{display:block;}
  .nav-dd-menu a{padding:12px 14px !important;}

  .mobile-sticky-contact{display:flex;}

  /* realizacje cards mobile polish */
  .real-item{
    border-radius:16px !important;
    overflow:hidden;
  }
  .real-head{
    padding:18px 18px !important;
    align-items:flex-start !important;
    gap:10px !important;
  }
  .real-title{
    font-size:1.05rem !important;
    line-height:1.35 !important;
    letter-spacing:1px !important;
  }
  .real-meta{
    display:block !important;
    margin-top:6px;
    font-size:.86rem !important;
    line-height:1.6 !important;
    opacity:.82;
  }
  .real-body{
    padding:0 !important;
  }
  .real-body-inner{
    padding:18px !important;
    gap:16px !important;
  }
  .real-media img{
    border-radius:14px !important;
  }
  .dots{
    bottom:10px !important;
  }
}


/* ===== MOBILE V5 HOTFIX ===== */
@media (max-width:900px){
  /* topnav specific open state */
  .topnav.nav-open .links{display:flex !important;}

  /* sections built with inline 12-col grid on desktop */
  .glass > div[style*="grid-template-columns:repeat(12,1fr)"]{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
  .glass > div[style*="grid-template-columns: repeat(12,1fr)"]{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
  .glass [style*="grid-column:span 6"]{
    grid-column:span 12 !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }
  .glass [style*="grid-column: span 6"]{
    grid-column:span 12 !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }

  /* title wrapping in inline-built cards */
  .glass h3{
    font-size:1.02rem !important;
    letter-spacing:.5px !important;
    line-height:1.45 !important;
    white-space:normal !important;
    word-break:normal !important;
    overflow-wrap:anywhere !important;
  }

  .glass p{
    font-size:1rem !important;
    line-height:1.65 !important;
  }
}


/* ===== MOBILE / CONTACT / PREFAB V6 ===== */
.contact-socials{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.contact-socials a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  min-width:130px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:#fff;
  text-decoration:none;
  font-size:.82rem;
  letter-spacing:.10em;
  text-transform:uppercase;
}
.contact-socials a:hover{
  background:rgba(255,255,255,.08);
}

.prefab-benefits{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:22px;
}
.prefab-benefit{
  padding:20px 20px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:rgba(255,255,255,.05);
}
.prefab-benefit h3{
  margin:0 0 8px;
  font-size:1rem;
  letter-spacing:1.2px;
}
.prefab-benefit p{
  margin:0;
  font-size:.95rem;
  line-height:1.7;
}
.faq-list{
  display:grid !important;
  grid-template-columns:repeat(2,1fr);
  gap:16px !important;
}
.faq-item{
  padding:18px 18px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  background:rgba(255,255,255,.04);
}

@media (max-width:900px){
  .mobile-sticky-contact{
    display:flex;
    bottom:10px;
    left:12px;
    right:12px;
  }
  .mobile-sticky-contact a{
    min-height:46px;
    font-size:.8rem;
    letter-spacing:.06em;
  }
  .contact-socials{
    flex-direction:column;
  }
  .contact-socials a{
    width:100%;
  }
  .prefab-benefits{
    grid-template-columns:1fr;
  }
  .faq-list{
    grid-template-columns:1fr !important;
  }
  /* inline desktop grids hidden issue */
  [style*="grid-template-columns:repeat(12,1fr)"],
  [style*="grid-template-columns: repeat(12,1fr)"]{
    grid-template-columns:1fr !important;
  }
  [style*="grid-column:span 6"],
  [style*="grid-column: span 6"]{
    grid-column:span 12 !important;
  }
  [style*="grid-column:span 4"],
  [style*="grid-column: span 4"]{
    grid-column:span 12 !important;
  }
  .glass h3,
  .panel h3,
  .step h3,
  .process-card h3{
    font-size:1rem !important;
    letter-spacing:.4px !important;
    line-height:1.4 !important;
    overflow-wrap:anywhere !important;
    white-space:normal !important;
  }
}


/* ===== HAMBURGER HARD FIX ===== */
@media (max-width:900px){
  .topnav{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    flex-wrap:wrap !important;
  }

  .topnav .nav-toggle{
    display:flex !important;
    margin-left:auto !important;
    z-index:1300;
  }

  .topnav .links{
    display:none !important;
    width:100% !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
    margin-top:12px !important;
    padding:8px 0 0 !important;
  }

  .topnav.nav-open .links{
    display:flex !important;
  }

  .topnav .links a,
  .topnav .nav-dd-btn{
    display:flex !important;
    width:100% !important;
    text-align:left !important;
    justify-content:flex-start !important;
    padding:12px 14px !important;
  }

  .topnav .nav-dd{
    width:100% !important;
  }

  .topnav .nav-dd-menu{
    position:static !important;
    display:none !important;
    width:100% !important;
    margin-top:6px !important;
  }

  .topnav .nav-dd.open .nav-dd-menu{
    display:block !important;
  }
}
