:root{
  --bg: #f6f8ff;
  --bg2:#eef3ff;
  --panel:#ffffff;
  --panel2:#f7f9ff;
  --text:#0b1220;
  --muted: rgba(11,18,32,.72);
  --muted2: rgba(11,18,32,.56);
  --line: rgba(11,18,32,.10);

  --accent:#0ea5e9;   /* sky */
  --accent2:#22c55e;  /* green */
  --accent3:#a78bfa;  /* violet */

  --shadow: 0 18px 55px rgba(11,18,32,.10);
  --shadow2: 0 10px 25px rgba(11,18,32,.08);

  --radius: 18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 480px at 10% 0%, rgba(14,165,233,.18), transparent 55%),
    radial-gradient(780px 520px at 90% 10%, rgba(34,197,94,.14), transparent 55%),
    radial-gradient(900px 700px at 55% 110%, rgba(167,139,250,.14), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}

/* delikatna “siatka” w tle */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(to right, rgba(11,18,32,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(11,18,32,.05) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity:.25;
  z-index:-2;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.92}

.container{width:min(1120px, 92vw); margin:0 auto}

/* ===== Topbar ===== */
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}

.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:800; letter-spacing:.2px;
}
.brand__mark{
  width:34px; height:34px; border-radius:12px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(14,165,233,.18), rgba(34,197,94,.16));
  border:1px solid rgba(11,18,32,.10);
  box-shadow: var(--shadow2);
}
.brand__text{font-size:15px}

.nav{display:flex; gap:18px; align-items:center}
.nav a{color:var(--muted); font-weight:700; font-size:13px}
.nav a:hover{color:var(--text)}

.navToggle{
  display:none;
  width:42px; height:42px; border-radius:12px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.65);
  box-shadow: var(--shadow2);
}
.navToggle span{
  display:block; height:2px; width:18px;
  background: rgba(11,18,32,.75);
  margin:4px auto; border-radius:99px;
}

/* mobile nav */
.navMobile{
  display:none;
  border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.92);
  padding:10px 0;
}
.navMobile a{
  display:block;
  padding:12px min(1120px, 92vw);
  color:var(--muted);
  font-weight:800;
}
.navMobile a:hover{color:var(--text)}
.navMobile.is-open{display:block}

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 16px; border-radius:14px;
  font-weight:900; font-size:13px;
  border:1px solid rgba(14,165,233,.25);
  background:
    linear-gradient(135deg, rgba(14,165,233,.18), rgba(34,197,94,.14));
  box-shadow: var(--shadow2);
  transition: transform .15s ease, filter .15s ease, box-shadow .15s ease;
}
.btn:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
  box-shadow: 0 16px 35px rgba(11,18,32,.12);
}
.btn:active{transform: translateY(0px) scale(.99)}

.btn--ghost{
  border:1px solid var(--line);
  background:rgba(255,255,255,.55);
}
.btn--small{padding:10px 12px; border-radius:12px}
.btn--full{width:100%}

/* ===== Hero ===== */
.hero{padding:44px 0 20px; position:relative}
.hero::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(11,18,32,.12), transparent);
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.35fr .95fr;
  gap:22px;
  align-items:stretch;
}

.pill{
  display:inline-flex; align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.65);
  color:var(--muted);
  font-weight:800;
  font-size:12px;
  box-shadow: var(--shadow2);
}

h1{
  margin:14px 0 10px;
  font-size:38px;
  line-height:1.06;
  letter-spacing:-.6px;
}
.lead{
  color:var(--muted);
  font-size:15px;
  line-height:1.65;
  margin:0 0 18px;
}

.cta{display:flex; gap:12px; flex-wrap:wrap; margin:18px 0 18px}

.hero__meta{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin-top:14px;
}
.metaCard{
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.70);
  border-radius:16px;
  padding:12px;
  box-shadow: var(--shadow2);
}
.metaCard__k{color:var(--muted2); font-weight:900; font-size:12px}
.metaCard__v{font-weight:950; font-size:13px; margin-top:4px}

/* ===== Hero “grafika” bez obrazków ===== */
.heroArt{
  border-radius: var(--radius);
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.75);
  box-shadow: var(--shadow);
  min-height: 360px;
  position:relative;
  overflow:hidden;
}
.heroArt::before{
  content:"";
  position:absolute;
  inset:-120px;
  background:
    radial-gradient(420px 260px at 25% 20%, rgba(14,165,233,.18), transparent 60%),
    radial-gradient(440px 280px at 75% 30%, rgba(34,197,94,.16), transparent 60%),
    radial-gradient(520px 340px at 55% 85%, rgba(167,139,250,.16), transparent 60%);
  filter: blur(10px);
  opacity:.95;
}
.heroArt__frame{
  position:absolute; inset:16px;
  border-radius: calc(var(--radius) - 6px);
  border:1px solid rgba(11,18,32,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(245,248,255,.70));
  overflow:hidden;
}

.heroArt__chip{
  position:absolute; top:14px; left:14px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.8);
  color:var(--muted);
  font-weight:950;
  font-size:12px;
  box-shadow: var(--shadow2);
}

.heroArt__ring{
  position:absolute;
  width:240px; height:240px;
  border-radius:999px;
  border:1px solid rgba(14,165,233,.22);
  top:78px; left:42px;
  box-shadow: inset 0 0 0 1px rgba(34,197,94,.12);
  animation: floaty 6s ease-in-out infinite;
}
.heroArt__ring--2{
  width:320px; height:320px;
  border-color: rgba(34,197,94,.20);
  top:44px; left:125px;
  animation-delay: .6s;
}

.heroArt__bars{
  position:absolute;
  right:18px; bottom:18px;
  display:grid;
  grid-template-columns: repeat(4, 10px);
  gap:10px;
  align-items:end;
}
.heroArt__bars span{
  display:block;
  width:10px;
  border-radius:10px;
  background:linear-gradient(180deg, rgba(14,165,233,.55), rgba(34,197,94,.35));
  border:1px solid rgba(11,18,32,.10);
  height: 26px;
  animation: bars 1.6s ease-in-out infinite;
}
.heroArt__bars span:nth-child(2){height:44px; animation-delay:.15s}
.heroArt__bars span:nth-child(3){height:34px; animation-delay:.30s}
.heroArt__bars span:nth-child(4){height:56px; animation-delay:.45s}

.heroArt__badge{
  position:absolute;
  left:14px; bottom:14px;
  padding:12px 12px;
  border-radius:16px;
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.78);
  box-shadow: var(--shadow2);
}
.heroArt__badgeK{color:var(--muted2); font-weight:950; font-size:12px}
.heroArt__badgeV{font-weight:950; margin-top:4px}

/* ===== Sections / grids ===== */
.section{padding:46px 0}
.section--alt{
  background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(245,248,255,.75), rgba(255,255,255,.55));
  border-top:1px solid rgba(11,18,32,.07);
  border-bottom:1px solid rgba(11,18,32,.07);
}

.sectionHead{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:20px; margin-bottom:16px;
}
.sectionHead h2{margin:0; font-size:24px; letter-spacing:-.3px}
.sectionHead p{margin:0}

.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:14px}
.mt{margin-top:14px}

/* ===== Cards ===== */
.card{
  position:relative;
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.82);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: var(--shadow2);
  overflow:hidden;
}
.card::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(14,165,233,.10), rgba(34,197,94,.08), rgba(167,139,250,.08));
  opacity:0;
  pointer-events:none;
  transition: opacity .25s ease;
}
.card:hover::after{opacity:1}

.card--soft{background:rgba(255,255,255,.72)}
.card--glow{
  box-shadow: 0 22px 70px rgba(11,18,32,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,249,255,.80));
}

.card h3{margin:0 0 10px; font-size:16px}
.card p{margin:0}

.list{
  margin:0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.65;
}
.muted{color:var(--muted)}
.tiny{font-size:12px; margin-top:10px}

/* ===== Form ===== */
.form{margin-top:12px}
label{
  display:block;
  font-weight:950;
  font-size:12px;
  color:var(--muted);
  margin-top:12px;
}
input, textarea, select{
  width:100%;
  margin-top:8px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(11,18,32,.12);
  background:rgba(255,255,255,.92);
  color:var(--text);
  outline:none;
  box-shadow: 0 6px 16px rgba(11,18,32,.05);
}
input:focus, textarea:focus, select:focus{
  border-color: rgba(14,165,233,.35);
  box-shadow: 0 10px 22px rgba(14,165,233,.10);
}
.form__row{display:grid; grid-template-columns:1fr 1fr; gap:10px}
.form__row--turnstile{grid-template-columns:1fr}

/* ===== Alerts ===== */
.alert{
  border-radius:14px;
  padding:10px 12px;
  border:1px solid rgba(11,18,32,.10);
  margin:10px 0 0;
  font-weight:900;
  font-size:13px;
  background: rgba(255,255,255,.85);
}
.alert--ok{
  border-color: rgba(34,197,94,.28);
  background: rgba(34,197,94,.10);
}
.alert--bad{
  border-color: rgba(239,68,68,.28);
  background: rgba(239,68,68,.10);
}

/* ===== Contact ===== */
.contactList{display:grid; gap:10px; margin-top:12px}
.contactItem{
  display:flex; justify-content:space-between; gap:12px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.85);
  box-shadow: var(--shadow2);
}
.contactItem .k{color:var(--muted2); font-weight:950; font-size:12px}
.contactItem .v{font-weight:950}

.note{
  border:1px dashed rgba(11,18,32,.14);
  background:rgba(255,255,255,.75);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: var(--shadow2);
}
.note h3{margin:0 0 8px; font-size:15px}

/* ===== Footer ===== */
.footer{
  border-top:1px solid rgba(11,18,32,.10);
  padding:26px 0 16px;
  background:rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
}
.footer__inner{display:flex; justify-content:space-between; gap:20px; align-items:flex-start}
.footer__cols{display:flex; gap:40px}
.footer__cols h4{margin:0 0 10px; font-size:13px}
.footer__cols a{display:block; color:var(--muted); margin:6px 0; font-weight:900; font-size:13px}
.footer__bottom{
  display:flex; justify-content:space-between;
  margin-top:16px;
  color:var(--muted2);
  font-weight:900;
  font-size:12px;
}
.brand--footer{margin-bottom:8px}

/* ===== Animations ===== */
@keyframes floaty{
  0%,100%{transform: translateY(0px)}
  50%{transform: translateY(-10px)}
}
@keyframes bars{
  0%,100%{transform: scaleY(1)}
  50%{transform: scaleY(1.15)}
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .hero__grid{grid-template-columns:1fr;}
  h1{font-size:34px}
  .grid3{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .sectionHead{flex-direction:column; align-items:flex-start}
  .nav{display:none}
  .navToggle{display:inline-grid; place-items:center}
  .hero__meta{grid-template-columns:1fr;}
  .form__row{grid-template-columns:1fr}
}

/* ===== Vertical layout + image section ===== */

.section--tight{padding: 18px 0 42px}

/* Hero teraz pionowo */
.hero__grid{
  grid-template-columns: 1fr; /* było 2 kolumny */
}

/* Media card (grafika) */
.mediaCard{
  position:relative;
  border-radius: 22px;
  overflow:hidden;
  border:1px solid rgba(11,18,32,.10);
  box-shadow: var(--shadow);
  background: rgba(255,255,255,.85);
}

.mediaCard__img{
  position:relative;
  aspect-ratio: 16/7;         /* panoramicznie */
  background: linear-gradient(135deg, rgba(14,165,233,.10), rgba(34,197,94,.08));
}

.mediaCard__img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter: saturate(1.05) contrast(1.02);
  transform: scale(1.01);
}

/* overlay na grafice */
.mediaCard__overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding: 16px 16px 14px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.55), rgba(255,255,255,.88));
  border-top:1px solid rgba(11,18,32,.08);
  backdrop-filter: blur(8px);
}

.mediaBadge{
  display:inline-flex;
  padding:8px 10px;
  border-radius:999px;
  font-weight:950;
  font-size:12px;
  border:1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.85);
  box-shadow: var(--shadow2);
}

.mediaTitle{
  margin-top:10px;
  font-weight: 950;
  letter-spacing: -.3px;
  font-size: 16px;
}

.mediaSub{
  margin-top:6px;
  color: var(--muted);
  font-weight: 800;
  font-size: 13px;
}

/* Trochę bardziej pionowo: większe odstępy między sekcjami */
.section{padding: 52px 0}

/* Na mobile bardziej “portrait” */
@media (max-width: 980px){
  .mediaCard__img{aspect-ratio: 4/3;}
  .mediaTitle{font-size: 15px;}
}


/* ===== CTA STRIP ===== */

.ctaStrip{
  margin: 40px 0 20px;
}

.ctaStrip__inner{
  display:grid;
  grid-template-columns: 1.4fr .8fr;
  gap: 20px;
  align-items:center;

  padding: 28px 30px;

  border-radius: 24px;
  border:1px solid rgba(11,18,32,.10);

  background:
    linear-gradient(135deg,
      rgba(14,165,233,.12),
      rgba(34,197,94,.10),
      rgba(167,139,250,.10)
    ),
    rgba(255,255,255,.85);

  box-shadow: 0 25px 60px rgba(11,18,32,.12);
  position:relative;
  overflow:hidden;
}

/* delikatne glow */
.ctaStrip__inner::before{
  content:"";
  position:absolute;
  inset:-80px;
  background:
    radial-gradient(400px 240px at 20% 20%, rgba(14,165,233,.25), transparent 60%),
    radial-gradient(420px 260px at 80% 40%, rgba(34,197,94,.20), transparent 60%);
  opacity:.35;
  pointer-events:none;
}

.ctaStrip__left h2{
  margin:10px 0 8px;
  font-size:22px;
  letter-spacing:-.4px;
}

.ctaStrip__left p{
  margin:0;
  color: var(--muted);
  font-weight:600;
}

.ctaStrip__badge{
  display:inline-flex;
  padding:7px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  border:1px solid rgba(11,18,32,.10);
  background: rgba(255,255,255,.85);
  box-shadow: var(--shadow2);
}

.ctaStrip__right{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  flex-wrap:wrap;
}

.btn--cta{
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color:#fff;
  border:none;
  box-shadow: 0 18px 40px rgba(14,165,233,.25);
}

.btn--cta:hover{
  filter: brightness(1.05);
  box-shadow: 0 22px 50px rgba(14,165,233,.35);
}

/* Responsive */
@media (max-width: 980px){
  .ctaStrip__inner{
    grid-template-columns:1fr;
    text-align:center;
  }

  .ctaStrip__right{
    justify-content:center;
  }
}