:root{
  --bg: #faf7fb;
  --bg2:#ffffff;
  --text:#1f1b24;
  --muted:#6b6475;
  --primary:#6B4AA6;
  --primary2:#9A6BD6;
  --border: rgba(31,27,36,.12);
  --shadow: 0 18px 40px rgba(31,27,36,.12);
  --shadow2: 0 10px 24px rgba(31,27,36,.10);
  --radius: 18px;
  --radius2: 26px;
  --container: 1140px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background: radial-gradient(1200px 800px at 10% -10%, rgba(154,107,214,.20), transparent 50%),
              radial-gradient(900px 700px at 90% 0%, rgba(107,74,166,.18), transparent 55%),
              var(--bg);
  line-height:1.55;
}
a{color:inherit; text-decoration:none}
a:hover{opacity:.92}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size:.92em}

/* ✅ MNIEJSZY MARGINES, ŻEBY BRAND BYŁ BLIŻEJ LEWEJ KRAWĘDZI */
.container{
  width: min(var(--container), calc(100% - 28px)); /* było 40px */
  margin: 0 auto;
}

.skip{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip:focus{left:16px; top:16px; width:auto; height:auto; padding:10px 14px; background:#fff; border-radius:12px; box-shadow:var(--shadow2); z-index:9999}

/* (topbar możesz usunąć z HTML; w CSS może zostać, nie szkodzi) */
.topbar{
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.topbar__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 10px 0;
  gap: 14px;
  font-size: 14px;
}
.topbar__left{display:flex; align-items:center; gap: 12px; flex-wrap:wrap}
.topbar__item{display:flex; align-items:center; gap:8px; color: var(--muted)}
.topbar__item--btn{border:0; background:transparent; cursor:pointer; padding:0}
.topbar__item--btn:hover{color: var(--text)}
.topbar__sep{color: rgba(107,100,117,.6)}
.topbar__right{display:flex; align-items:center; gap: 10px}
.icon{font-size: 16px; line-height:1}
.social{
  width:36px; height:36px;
  display:inline-flex; align-items:center; justify-content:center;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255,255,255,.75);
}
.social svg{width:18px; height:18px; fill: var(--primary)}

.header{
  position: sticky; top:0;
  z-index: 50;
  background: rgba(250,247,251,.72);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 0;
  gap: 14px;
}

/* ✅ KLUCZ: brand po lewej + spycha menu w prawo */
.brand{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap: 12px;

  margin-right: auto;  /* spycha menu w prawo */
  min-width: 0;        /* ważne, żeby flex nie rozpychał */
}


/* ✅ NOWE LOGO: większe + ograniczone */
.logoText{
  width: 220px;   /* główny rozmiar logo */
  height: auto;
  display: block;
}



/* (stare elementy brandu zostawiam — jak ich nie ma w HTML, to nie wpływają) */
.brand__mark{
  width:44px; height:44px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.85), rgba(255,255,255,.0) 55%),
    linear-gradient(135deg, var(--primary), var(--primary2));
  box-shadow: 0 10px 20px rgba(107,74,166,.25);
  position: relative;
}
.brand__mark::after{
  content:"";
  position:absolute; inset:10px;
  border-radius: 12px;
  border: 1px dashed rgba(255,255,255,.55);
}
.brand__text{display:flex; flex-direction:column; line-height:1.2}
.brand__name{
  font-family: "Playfair Display", serif;
  font-size: 20px; font-weight: 700;
  letter-spacing: .2px;
}
.brand__sub{font-size: 12px; color: var(--muted)}

.nav{display:flex; align-items:center}
.nav__toggle{
  display:none;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.8);
  border-radius: 14px;
  padding: 10px 12px;
  cursor:pointer;
  align-items:center; gap:10px;
}
.nav__toggleBars{
  width:18px; height:12px; position:relative; display:inline-block;
}
.nav__toggleBars::before,
.nav__toggleBars::after{
  content:""; position:absolute; left:0; right:0; height:2px;
  background: var(--primary);
  border-radius: 2px;
}
.nav__toggleBars::before{top:1px}
.nav__toggleBars::after{bottom:1px}
.nav__toggleLabel{font-size: 14px; color: var(--muted)}
.nav__menu{
  display:flex; align-items:center; gap: 18px;
  font-weight: 500;
}
.nav__menu a{color: var(--muted)}
.nav__menu a:hover{color: var(--text)}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 18px;
  border-radius: 16px;
  border: 1px solid rgba(107,74,166,.18);
  background: linear-gradient(135deg, var(--primary), var(--primary2));

  color: #ffffff !important;   /* KLUCZOWE */
  font-weight: 700;            /* lekko mocniejszy tekst */
  letter-spacing: .2px;

  box-shadow: 0 12px 28px rgba(107,74,166,.22);
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}

.nav__menu .btn{
  color:#fff !important;
}

.btn:hover{transform: translateY(-1px); box-shadow: 0 16px 34px rgba(107,74,166,.25)}
.btn--ghost{
  background: rgba(255,255,255,.75);
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: var(--shadow2);
}
.btn--ghost:hover{box-shadow: 0 14px 28px rgba(31,27,36,.14)}
.btn--small{padding: 10px 12px; border-radius: 14px; font-size: 14px}

.badge{
  display:inline-flex; gap:8px; align-items:center;
  background: rgba(255,255,255,.70);
  border: 1px solid var(--border);
  padding: 8px 12px;
  border-radius: 999px;
  color: var(--muted);
  box-shadow: 0 10px 22px rgba(31,27,36,.08);
}

.hero{
  position:relative;
  padding: 56px 0 26px;
  overflow:hidden;
}
.hero__bg{
  position:absolute; inset:0;
  background-size: cover;
  background-position:center;
  filter: saturate(1.05) contrast(1.02);
  opacity:.16;
  transform: scale(1.05);
}
.hero__bg::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(250,247,251,.40), rgba(250,247,251,.92));
}
.hero__inner{
  display:grid;
  grid-template-columns: 1.25fr .85fr;
  gap: 32px;
  align-items: center;
  position:relative;
}
.hero h1{
  font-family:"Playfair Display", serif;
  font-size: clamp(34px, 4.2vw, 54px);
  line-height:1.05;
  margin: 14px 0 14px;
}
.accent{color: var(--primary)}
.lead{font-size: 16px; color: rgba(31,27,36,.85); margin: 0 0 18px}
.hero__cta{display:flex; gap: 12px; flex-wrap:wrap; margin: 18px 0 18px}

.hero__meta{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 18px;
}
.metaCard{
  background: rgba(255,255,255,.72);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 12px 14px;
  box-shadow: 0 12px 26px rgba(31,27,36,.08);
}
.metaCard__kicker{font-size: 12px; color: var(--muted); display:block}
.metaCard__val{font-weight: 700}

.hero__portrait{display:flex; justify-content:flex-end}
.portraitCard{
  width:min(380px, 100%);
  background: rgba(255,255,255,.75);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.portraitCard img{width:100%; height:auto; display:block}
.portraitCard__label{
  padding: 14px 16px;
  display:flex; flex-direction:column; gap: 2px;
}
.portraitCard__name{font-weight: 700}
.portraitCard__desc{color: var(--muted); font-size: 13px}

.section{padding: 56px 0}
.section--alt{
  background: rgba(255,255,255,.55);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.section__head{
  max-width: 720px;
  margin-bottom: 26px;
}
.section__head h2{
  font-family:"Playfair Display", serif;
  font-size: clamp(26px, 3vw, 36px);
  margin: 0 0 10px;
}
.section__head p{margin:0; color: var(--muted)}

.grid{display:grid}
.cards{
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}
.card{
  background: rgba(255,255,255,.75);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 18px 16px;
  box-shadow: 0 12px 26px rgba(31,27,36,.08);
  min-height: 160px;
}
.card h3{margin: 0 0 10px; font-size: 18px}
.card p{margin: 0 0 12px; color: var(--muted)}
.card__link{color: var(--primary); font-weight: 700}
.card--highlight{
  border-color: rgba(107,74,166,.28);
  background: linear-gradient(180deg, rgba(154,107,214,.16), rgba(255,255,255,.72));
}
.card--highlight p{color: rgba(31,27,36,.82)}

.split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: center;
}
.ticks{
  list-style:none; padding:0; margin: 18px 0 18px;
  display:grid; gap: 8px;
}
.ticks li{
  position:relative; padding-left: 28px;
  color: rgba(31,27,36,.86);
}
.ticks li::before{
  content:"✓";
  position:absolute; left:0; top:0;
  width:20px; height:20px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius: 8px;
  background: rgba(107,74,166,.14);
  color: var(--primary);
  font-weight: 900;
}
.actions{display:flex; gap: 12px; flex-wrap:wrap; align-items:center}

.stack{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.stack__img{
  width:100%;
  height: 180px;
  object-fit: cover;
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  box-shadow: var(--shadow2);
}

.gallery{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}
.gallery__placeholder{
  grid-column: 1 / -1;
  background: rgba(255,255,255,.72);
  border: 1px dashed rgba(107,74,166,.35);
  border-radius: var(--radius2);
  padding: 18px;
  box-shadow: 0 12px 26px rgba(31,27,36,.06);
  margin-bottom: 6px;
}
.ph__title{font-weight: 800}
.ph__desc{color: var(--muted); font-size: 14px; margin-top: 6px}
.tile{
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  background:
    linear-gradient(135deg, rgba(107,74,166,.10), rgba(154,107,214,.10)),
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.75), rgba(255,255,255,0) 55%),
    rgba(255,255,255,.6);
  height: 210px;
  cursor:pointer;
  position:relative;
  overflow:hidden;
  box-shadow: 0 10px 22px rgba(31,27,36,.08);
}
.tile::after{
  content:"Dodaj zdjęcie";
  position:absolute; inset:auto 14px 14px 14px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.78);
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: 14px;
}
.tile[data-src]:not([data-src=""]) { background-size:cover; background-position:center; }
.tile[data-src]:not([data-src=""])::after { content:"Kliknij, aby powiększyć"; }

.lightbox{
  position: fixed; inset:0;
  background: rgba(0,0,0,.68);
  display:none;
  align-items:center; justify-content:center;
  padding: 20px;
  z-index: 999;
}
.lightbox[aria-hidden="false"]{display:flex}
.lightbox img{
  max-width: min(980px, 100%);
  max-height: 82vh;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 24px 70px rgba(0,0,0,.35);
}
.lightbox__close{
  position:absolute; top: 14px; right: 14px;
  width: 42px; height: 42px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.12);
  color:#fff;
  font-size: 28px;
  cursor:pointer;
}

.contactGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items:start;
}
.contactCard{
  background: rgba(255,255,255,.75);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  padding: 18px;
  box-shadow: 0 12px 26px rgba(31,27,36,.08);
}
.contactCard--map{grid-column: 1 / -1}
.contactItem{display:grid; grid-template-columns: 120px 1fr; gap: 10px; padding: 10px 0; border-bottom: 1px solid rgba(31,27,36,.06)}
.contactItem:last-of-type{border-bottom:0}
.contactItem__k{color: var(--muted); font-size: 14px}
.contactItem__v{font-weight: 600}

.form{display:grid; gap: 12px}
.form__row{display:grid; grid-template-columns: 1fr 1fr; gap: 12px}
label{display:grid; gap: 6px; font-weight: 600; font-size: 14px}
input, textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(31,27,36,.12);
  background: rgba(255,255,255,.85);
  font: inherit;
  outline: none;
}
input:focus, textarea:focus{border-color: rgba(107,74,166,.50); box-shadow: 0 0 0 4px rgba(107,74,166,.12)}
.form__actions{display:flex; align-items:center; gap: 12px; flex-wrap:wrap}
.form__status{color: var(--muted); font-size: 14px}
.hint{color: var(--muted); font-size: 13px; margin-top: 10px}

.mapWrap{
  height: 500px;
}

.mapWrap{ height: 520px; background:#fff; overflow:hidden; border-radius: var(--radius2); border: 1px solid rgba(31,27,36,.10); }

@media (max-width: 680px){
  .mapWrap{ height: 320px; }
   .cards{grid-template-columns: 1fr !important;}
}


.mapWrap iframe{
  width:100%;
  height:100%;
  border:0;
  filter: none;
}

.footer{
  padding: 34px 0;
}
.footer__inner{
  display:grid;
  grid-template-columns: 1.2fr .9fr .4fr;
  gap: 16px;
  align-items:center;
}
.footer__note{color: var(--muted); margin: 10px 0 0}
.footer__links{display:flex; gap: 14px; flex-wrap:wrap; justify-content:center}
.footer__links a{color: var(--muted); font-weight: 600}
.footer__copy{color: var(--muted); text-align:right}
.brand--footer .brand__mark{width:40px; height:40px}

@media (max-width: 980px){
  .hero__inner{grid-template-columns: 1fr}
  .hero__portrait{justify-content:flex-start}
  .cards{grid-template-columns: repeat(2, minmax(0,1fr))}
  .split{grid-template-columns: 1fr}
  .contactGrid{grid-template-columns: 1fr}
  .footer__inner{grid-template-columns: 1fr; text-align:center}
  .footer__copy{text-align:center}
}

@media (max-width: 680px){
  .topbar__inner{flex-direction:column; align-items:flex-start}
  .nav__toggle{display:inline-flex}
  .nav__menu{
    position:absolute;
    right: 20px;
    top: 72px;
    width: min(320px, calc(100vw - 40px));
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap: 10px;
    padding: 12px;
    border-radius: var(--radius2);
    border: 1px solid var(--border);
    background: rgba(255,255,255,.92);
    box-shadow: var(--shadow);
  }
  .nav__menu a{padding: 10px 12px; border-radius: 14px}
  .nav__menu a:hover{background: rgba(107,74,166,.08)}
  .nav__menu.isOpen{display:flex}
  .hero{padding-top: 40px}
  .hero__meta{grid-template-columns: 1fr; }
  .form__row{grid-template-columns: 1fr}
  .gallery{grid-template-columns: 1fr}
  .tile{height: 180px}

  /* ✅ na mobile logo nie może być za szerokie */
  .logoText{
    height: 100px;
    max-width: 220px;
  }
}



/* Hide-on-scroll header */
.header{
  transition: transform .22s ease, box-shadow .22s ease, background-color .22s ease;
  will-change: transform;
}

.header.is-hidden{
  transform: translateY(-110%);
}

/* opcjonalnie: lekki cień gdy header wraca */
.header.is-scrolling{
  box-shadow: 0 10px 24px rgba(31,27,36,.10);
}
