@import url('./assets/fonts/fonts.css');

/* ============================================================
   DRECO NIERUCHOMOŚCI — styles.css
   Estetyka: elegancki redakcyjny minimal nieruchomości.
   Granat/grafit (#13233B / #1C2A3F) + ciepły mosiądz (#C39A52).
   Newsreader (display serif) + Public Sans (body grotesk).
   Mobile-first. WCAG AA. Wspólny chrome 1:1 na każdej podstronie.
   ============================================================ */

/* ---------- TOKENY ---------- */
:root{
  --navy:#13233B;        /* główne ciemne tło / nagłówki */
  --navy-2:#1C2A3F;      /* ciemne sekcje wariant */
  --ink:#1A2331;         /* tekst na jasnym (kontrast ~13:1) */
  --ink-soft:#41506A;    /* tekst drugorzędny na jasnym (~6.4:1) */
  --brass:#C39A52;       /* akcent mosiądz (dekoracja / ramki) */
  --brass-deep:#9A7430;  /* mosiądz ciemniejszy = tekst-akcent na jasnym (~4.7:1) */
  --brass-soft:#E7CF9E;  /* akcent jasny = tekst na ciemnym (~7:1 na navy) */
  --paper:#FBF9F5;       /* tło główne (ciepła biel) */
  --paper-2:#F3EFE7;     /* sekcja wariant kremowa */
  --card:#FFFFFF;        /* karty */
  --line:#E4DDD0;        /* delikatne linie na jasnym */
  --line-2:#D7CDBA;      /* mocniejsza linia */
  --on-dark:#F4F1EA;     /* tekst na ciemnym (~14:1 na navy) */
  --on-dark-soft:#C3CAD6;/* drugorzędny na ciemnym (~7:1) */
  --line-dark:rgba(231,222,203,.18);

  --radius:14px;
  --radius-sm:9px;
  --maxw:1160px;
  --gut:clamp(1.15rem,5vw,2.25rem);

  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Public Sans',system-ui,-apple-system,'Segoe UI',sans-serif;

  --shadow-sm:0 1px 2px rgba(19,35,59,.05),0 2px 8px rgba(19,35,59,.05);
  --shadow:0 6px 22px rgba(19,35,59,.09),0 2px 6px rgba(19,35,59,.05);
  --shadow-lg:0 22px 60px rgba(19,35,59,.16);

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.1;margin:0;color:var(--navy);letter-spacing:-.01em}
p{margin:0 0 1rem}
ul{margin:0;padding:0}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--brass-deep);outline-offset:2px;border-radius:3px}

/* baza ikon — siatka bezpieczeństwa (lekcja v5.2) */
.ico{width:1.25em;height:1.25em;flex:none;display:inline-block;vertical-align:middle}

/* ---------- UKŁAD ---------- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.section{padding-block:clamp(3.2rem,8vw,5.5rem)}
.section--paper2{background:var(--paper-2)}
.section--navy{background:var(--navy);color:var(--on-dark)}
.section--navy h1,.section--navy h2,.section--navy h3,.section--navy h4{color:var(--on-dark)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:.7rem 1.1rem;z-index:200;border-radius:0 0 8px 0}
.skip-link:focus{left:0}

.eyebrow{
  font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brass-deep);margin:0 0 .85rem;display:flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--brass);display:inline-block}
.section--navy .eyebrow{color:var(--brass-soft)}
.section--navy .eyebrow::before{background:var(--brass-soft)}
.section-head{max-width:42rem;margin-bottom:clamp(1.8rem,4vw,2.8rem)}
.section-head h2{font-size:clamp(1.9rem,5.2vw,2.85rem)}
.section-head p{margin-top:1rem;color:var(--ink-soft);font-size:1.05rem}
.section--navy .section-head p{color:var(--on-dark-soft)}
.lead{font-size:1.18rem;color:var(--ink-soft);line-height:1.6}

/* ---------- PRZYCISKI ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--sans);font-weight:600;font-size:1rem;line-height:1;
  padding:.95rem 1.5rem;border-radius:999px;border:1.5px solid transparent;
  white-space:nowrap;transition:transform .18s var(--ease),background .18s var(--ease),box-shadow .18s var(--ease),color .18s var(--ease);
  min-height:48px;
}
.btn .ico{width:1.15em;height:1.15em}
.btn--primary{background:var(--brass);color:#23170a;border-color:var(--brass)}
.btn--primary:hover{background:#cfa862;box-shadow:0 8px 22px rgba(195,154,82,.34);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--navy);background:rgba(19,35,59,.04);transform:translateY(-2px)}
.section--navy .btn--ghost,.on-dark .btn--ghost{color:var(--on-dark);border-color:rgba(231,222,203,.4)}
.section--navy .btn--ghost:hover,.on-dark .btn--ghost:hover{border-color:var(--brass-soft);background:rgba(231,222,203,.08)}
.btn--block{width:100%}

/* ---------- HEADER / NAV ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(251,249,245,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:70px}
.brand{display:flex;align-items:center;gap:.7rem;padding:.4rem 0}
.brand__mark{width:38px;height:38px;flex:none}
.brand__name{font-family:var(--serif);font-weight:600;font-size:1.32rem;color:var(--navy);line-height:1;letter-spacing:-.01em}
.brand__tag{display:block;font-family:var(--sans);font-weight:600;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-deep);margin-top:.18rem}

.nav__links{display:none;list-style:none;align-items:center;gap:.35rem}
.nav__links a{
  font-weight:500;font-size:.97rem;color:var(--ink);padding:.55rem .8rem;border-radius:8px;
  white-space:nowrap;transition:color .15s,background .15s;position:relative;
}
.nav__links a:hover{color:var(--navy);background:rgba(19,35,59,.05)}
.nav__links a[aria-current="page"]{color:var(--brass-deep)}
.nav__links a[aria-current="page"]::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.28rem;height:2px;background:var(--brass)}

.nav__cta{display:none;align-items:center;gap:.6rem}
.nav__tel{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--navy);font-size:.95rem;white-space:nowrap;padding:.4rem .2rem}
.nav__tel:hover{color:var(--brass-deep)}
.nav__tel .ico{color:var(--brass-deep)}

.nav-toggle{
  display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:46px;padding:11px;background:transparent;border:1px solid var(--line-2);border-radius:10px;
}
.nav-toggle span{height:2px;width:100%;background:var(--navy);border-radius:2px;transition:transform .25s var(--ease),opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav panel */
.mobile-nav{position:fixed;inset:70px 0 0;background:var(--navy);color:var(--on-dark);z-index:99;
  transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform .3s var(--ease),opacity .25s,visibility .3s;
  overflow-y:auto;padding:1.4rem var(--gut) 2.4rem}
.mobile-nav[data-open="true"]{transform:translateY(0);opacity:1;visibility:visible}
.mobile-nav ul{list-style:none}
.mobile-nav a{display:flex;align-items:center;justify-content:space-between;padding:1.05rem .2rem;font-family:var(--serif);font-size:1.5rem;color:var(--on-dark);border-bottom:1px solid var(--line-dark)}
.mobile-nav a[aria-current="page"]{color:var(--brass-soft)}
.mobile-nav a .ico{color:var(--brass-soft);opacity:.7}
.mobile-nav__cta{margin-top:1.7rem;display:grid;gap:.8rem}
.mobile-nav__meta{margin-top:1.7rem;color:var(--on-dark-soft);font-size:.95rem;line-height:1.7}
.mobile-nav__meta a{display:inline;font-family:var(--sans);font-size:.95rem;padding:0;border:0;color:var(--brass-soft)}

@media (min-width:1024px){
  .nav__links{display:flex}
  .nav__cta{display:flex}
  .nav-toggle{display:none}
  .mobile-nav{display:none}
}

/* ---------- HERO ---------- */
.hero{position:relative;background:linear-gradient(165deg,#13233B 0%,#172A45 55%,#1C3050 100%);color:var(--on-dark);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 55% at 82% 8%,rgba(195,154,82,.16),transparent 60%),
  radial-gradient(50% 50% at 12% 92%,rgba(195,154,82,.08),transparent 60%);pointer-events:none}
.hero__inner{position:relative;padding-block:clamp(3rem,9vw,5.5rem)}
.hero__grid{display:grid;gap:clamp(2rem,5vw,3rem)}
.hero h1{color:var(--on-dark);font-weight:500;font-size:clamp(2.3rem,8.5vw,4.1rem);line-height:1.04;letter-spacing:-.02em}
.hero h1 em{font-style:italic;color:var(--brass-soft)}
.hero__lead{color:var(--on-dark-soft);font-size:clamp(1.05rem,2.6vw,1.22rem);max-width:34rem;margin:1.3rem 0 0}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2.2rem;list-style:none}
.hero__trust li{display:inline-flex;align-items:center;gap:.5rem;font-size:.86rem;font-weight:500;
  padding:.5rem .9rem;border-radius:999px;border:1px solid var(--line-dark);background:rgba(231,222,203,.05);color:var(--on-dark)}
.hero__trust .ico{width:1.05em;height:1.05em;color:var(--brass-soft)}

/* karta-statystyka w hero (prawa kolumna) */
.hero__panel{background:rgba(231,222,203,.06);border:1px solid var(--line-dark);border-radius:var(--radius);padding:clamp(1.4rem,4vw,2rem);backdrop-filter:blur(4px)}
.hero__panel h2{color:var(--on-dark);font-size:1.15rem;font-weight:600;margin-bottom:1.2rem}
.hero__stats{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem 1rem;list-style:none}
.hero__stats strong{display:block;font-family:var(--serif);font-weight:600;font-size:1.9rem;color:var(--brass-soft);line-height:1;font-variant-numeric:tabular-nums}
.hero__stats span{display:block;margin-top:.4rem;font-size:.85rem;color:var(--on-dark-soft);line-height:1.4}

@media (min-width:880px){
  .hero__grid{grid-template-columns:1.25fr .85fr;align-items:center}
}

/* ---------- PASEK ZAUFANIA (logo-strip / fakty) ---------- */
.factbar{background:var(--navy-2);color:var(--on-dark);border-top:1px solid var(--line-dark)}
.factbar__grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem 1rem;padding-block:2.2rem;list-style:none}
.factbar__grid li{text-align:center}
.factbar strong{display:block;font-family:var(--serif);font-size:1.7rem;font-weight:600;color:var(--brass-soft);line-height:1;font-variant-numeric:tabular-nums}
.factbar span{display:block;margin-top:.45rem;font-size:.82rem;color:var(--on-dark-soft)}
@media (min-width:760px){.factbar__grid{grid-template-columns:repeat(4,1fr)}}

/* ---------- KARTY USŁUG ---------- */
.cards{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media (min-width:600px){.cards{grid-template-columns:1fr 1fr}}
@media (min-width:980px){.cards--3{grid-template-columns:repeat(3,1fr)}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.4rem,3.5vw,1.9rem);box-shadow:var(--shadow-sm);transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card__ico{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;background:rgba(195,154,82,.14);color:var(--brass-deep);margin-bottom:1.1rem}
.card__ico .ico{width:24px;height:24px}
.card h3{font-size:1.32rem;margin-bottom:.5rem}
.card p{color:var(--ink-soft);font-size:.98rem;margin:0}
.card__list{list-style:none;margin-top:1rem;display:grid;gap:.5rem}
.card__list li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.card__list .ico{width:1.1em;height:1.1em;color:var(--brass-deep);margin-top:.28em;flex:none}

/* ---------- KARTY OFERT (nieruchomości) ---------- */
.listings{display:grid;gap:1.3rem;grid-template-columns:1fr}
@media (min-width:640px){.listings{grid-template-columns:1fr 1fr}}
@media (min-width:980px){.listings{grid-template-columns:repeat(3,1fr)}}
.listing{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
.listing:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.listing__media{position:relative;aspect-ratio:4/3;background:linear-gradient(150deg,#1C2A3F,#2A3E5C);overflow:hidden}
.listing__media svg{position:absolute;inset:0;width:100%;height:100%}
.listing__badge{position:absolute;top:.85rem;left:.85rem;z-index:2;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:.34rem .7rem;border-radius:999px;background:var(--brass);color:#23170a}
.listing__badge--muted{background:rgba(244,241,234,.92);color:var(--navy)}
.listing__body{padding:1.2rem 1.25rem 1.4rem}
.listing__type{font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brass-deep);margin-bottom:.4rem}
.listing__body h3{font-size:1.28rem;margin-bottom:.35rem}
.listing__loc{display:flex;align-items:center;gap:.4rem;font-size:.92rem;color:var(--ink-soft);margin-bottom:.9rem}
.listing__loc .ico{width:1em;height:1em;color:var(--brass-deep)}
.listing__meta{display:flex;flex-wrap:wrap;gap:.4rem .9rem;padding-top:.9rem;border-top:1px solid var(--line);font-size:.88rem;color:var(--ink-soft)}
.listing__meta span{display:inline-flex;align-items:center;gap:.35rem}
.listing__meta .ico{width:1.05em;height:1.05em;color:var(--brass-deep)}
.listing__price{font-family:var(--serif);font-weight:600;font-size:1.35rem;color:var(--navy);font-variant-numeric:tabular-nums;margin-top:1rem}
.listing__price small{font-family:var(--sans);font-size:.78rem;font-weight:600;color:var(--ink-soft);display:block;margin-top:.15rem}

/* ---------- SEKCJA KREDYTY (split na ciemnym) ---------- */
.split{display:grid;gap:clamp(1.8rem,5vw,3rem);align-items:center}
@media (min-width:900px){.split{grid-template-columns:1fr 1fr}.split--rev .split__media{order:-1}}
.split__media{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-dark);aspect-ratio:5/4;position:relative;background:linear-gradient(150deg,#1C2A3F,#2A3E5C)}
.split__media svg{position:absolute;inset:0;width:100%;height:100%}
.steps{list-style:none;display:grid;gap:1.05rem;counter-reset:step}
.steps li{display:grid;grid-template-columns:auto 1fr;gap:.95rem;align-items:start}
.steps li::before{counter-increment:step;content:counter(step);font-family:var(--serif);font-weight:600;font-size:1rem;
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(195,154,82,.16);color:var(--brass-soft);border:1px solid var(--brass);flex:none}
.steps h3{font-size:1.1rem;margin-bottom:.2rem}
.steps p{margin:0;color:var(--on-dark-soft);font-size:.96rem}
.section:not(.section--navy) .steps li::before{background:rgba(195,154,82,.14);color:var(--brass-deep)}
.section:not(.section--navy) .steps p{color:var(--ink-soft)}

/* ---------- "DLACZEGO MY" / cechy ---------- */
.feats{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media (min-width:640px){.feats{grid-template-columns:1fr 1fr}}
.feat{display:grid;grid-template-columns:auto 1fr;gap:1rem;padding:1.3rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);align-items:start}
.feat__ico{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:var(--navy);color:var(--brass-soft);flex:none}
.feat__ico .ico{width:22px;height:22px}
.feat h3{font-size:1.12rem;margin-bottom:.3rem}
.feat p{margin:0;color:var(--ink-soft);font-size:.95rem}

/* ---------- O NAS / agent ---------- */
.profile{display:grid;gap:clamp(1.6rem,4vw,2.6rem);align-items:center}
@media (min-width:820px){.profile{grid-template-columns:.8fr 1.2fr}}
.profile__card{background:var(--navy);color:var(--on-dark);border-radius:var(--radius);padding:clamp(1.6rem,4vw,2.2rem);text-align:center}
.profile__avatar{width:120px;height:120px;margin:0 auto 1.2rem;border-radius:50%;background:rgba(231,222,203,.08);border:2px solid var(--brass);display:grid;place-items:center;color:var(--brass-soft)}
.profile__avatar .ico{width:54px;height:54px}
.profile__card h3{color:var(--on-dark);font-size:1.35rem}
.profile__role{color:var(--brass-soft);font-size:.92rem;font-weight:600;letter-spacing:.04em;margin-top:.3rem}
.profile__chips{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1.2rem}
.profile__chips li{font-size:.8rem;padding:.4rem .8rem;border-radius:999px;border:1px solid var(--line-dark);color:var(--on-dark-soft)}

/* ---------- OPINIE / slider (mobile) → siatka (desktop) ---------- */
.reviews{display:grid;gap:1.1rem}
.review{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm)}
.review__stars{display:inline-flex;gap:2px;color:var(--brass);margin-bottom:.8rem}
.review__stars .ico{width:18px;height:18px}
.review p{font-size:1.02rem;color:var(--ink);line-height:1.6;margin:0 0 1rem}
.review__who{display:flex;align-items:center;gap:.7rem}
.review__ava{width:40px;height:40px;border-radius:50%;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--serif);font-weight:600;color:var(--brass-deep);flex:none}
.review__name{font-weight:600;font-size:.95rem;color:var(--navy)}
.review__src{font-size:.8rem;color:var(--ink-soft)}

.slider{position:relative}
.slider__track{display:grid;grid-auto-flow:column;grid-auto-columns:88%;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:.4rem}
.slider__track::-webkit-scrollbar{display:none}
.slider__track>*{scroll-snap-align:start}
.slider__dots{display:flex;justify-content:center;gap:.4rem;margin-top:1.2rem}
.slider__dots button{width:24px;height:24px;padding:0;border:0;background:transparent;display:grid;place-items:center;cursor:pointer}
.slider__dots button::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--line-2);transition:background .2s,transform .2s}
.slider__dots button[aria-current="true"]::before{background:var(--brass-deep);transform:scale(1.25)}

@media (min-width:760px){
  .reviews--grid{grid-template-columns:repeat(3,1fr)}
  .slider .slider__track{grid-auto-flow:row;grid-auto-columns:auto;grid-template-columns:repeat(3,1fr);overflow:visible}
  .slider__dots{display:none}
}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem;max-width:48rem}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:1.15rem 1.3rem;font-weight:600;font-size:1.05rem;color:var(--navy);
  display:flex;align-items:center;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ico{width:1.2em;height:1.2em;color:var(--brass-deep);transition:transform .25s var(--ease);flex:none}
.faq details[open] summary .ico{transform:rotate(45deg)}
.faq details>div{padding:0 1.3rem 1.25rem;color:var(--ink-soft)}
.faq details>div p{margin:0}

/* ---------- FORMULARZ ---------- */
.contact-grid{display:grid;gap:clamp(1.8rem,5vw,3rem)}
@media (min-width:920px){.contact-grid{grid-template-columns:1.05fr .95fr}}
.form{display:grid;gap:1.05rem}
.field{display:grid;gap:.4rem}
.field label{font-weight:600;font-size:.9rem;color:var(--navy)}
.field label .req{color:var(--brass-deep)}
.field input,.field textarea,.field select{
  font-family:inherit;font-size:1rem;color:var(--ink);background:var(--card);
  border:1.5px solid var(--line-2);border-radius:10px;padding:.85rem .95rem;width:100%;min-height:48px;transition:border-color .15s,box-shadow .15s}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brass-deep);box-shadow:0 0 0 3px rgba(154,116,48,.18)}
.field--error input,.field--error textarea,.field--error select{border-color:#B42318;box-shadow:0 0 0 3px rgba(180,35,24,.14)}
.field__err{display:none;font-size:.82rem;color:#B42318;font-weight:600}
.field--error .field__err{display:flex;align-items:center;gap:.35rem}
.field__err .ico{width:1em;height:1em}
.form__row{display:grid;gap:1.05rem}
@media (min-width:560px){.form__row{grid-template-columns:1fr 1fr}}
.form__consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--ink-soft)}
.form__consent input{width:20px;height:20px;min-height:0;margin-top:.15rem;flex:none}
.form__status{display:none;padding:.95rem 1.1rem;border-radius:10px;font-size:.95rem;font-weight:500}
.form__status--ok{display:block;background:#E9F4EC;color:#1B5E32;border:1px solid #BFE3C9}

/* karta kontaktowa + mapa */
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,4vw,2rem);box-shadow:var(--shadow-sm)}
.contact-list{list-style:none;display:grid;gap:1.15rem;margin:0 0 1.4rem}
.contact-list li{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:start}
.contact-list .ico-wrap{width:42px;height:42px;border-radius:10px;background:rgba(195,154,82,.14);color:var(--brass-deep);display:grid;place-items:center;flex:none}
.contact-list .ico-wrap .ico{width:21px;height:21px}
.contact-list dt{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-weight:700;margin-bottom:.15rem}
.contact-list dd{margin:0;font-weight:600;color:var(--navy);font-size:1.05rem;line-height:1.4}
.contact-list dd a:hover{color:var(--brass-deep)}
.contact-list dd small{display:block;font-weight:400;font-size:.85rem;color:var(--ink-soft);margin-top:.15rem}

/* mapa — własny kontener z ustaloną wysokością (lekcja: mapa-w-kontenerze) */
.map-frame{margin-top:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-2);box-shadow:var(--shadow-sm)}
.map-frame iframe{display:block;width:100%;height:340px;border:0}

/* ---------- CTA pas ---------- */
.cta-band{background:linear-gradient(150deg,#13233B,#1C3050);color:var(--on-dark);border-radius:var(--radius);padding:clamp(2rem,6vw,3.2rem);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(50% 70% at 50% 0%,rgba(195,154,82,.18),transparent 70%);pointer-events:none}
.cta-band h2{color:var(--on-dark);font-size:clamp(1.7rem,4.6vw,2.5rem);position:relative}
.cta-band p{color:var(--on-dark-soft);max-width:38rem;margin:1rem auto 0;position:relative}
.cta-band .hero__cta{justify-content:center;position:relative}

/* ---------- BREADCRUMB ---------- */
.breadcrumb{padding-top:1.4rem}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.3rem;align-items:center;font-size:.85rem;color:var(--ink-soft)}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--brass-deep)}
.breadcrumb li[aria-current]{color:var(--navy);font-weight:600}
.breadcrumb li+li::before{content:"/";margin-right:.3rem;color:var(--line-2)}

/* nagłówek podstrony (page hero) */
.page-hero{background:linear-gradient(165deg,#13233B,#1C3050);color:var(--on-dark);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(55% 60% at 85% 10%,rgba(195,154,82,.15),transparent 60%);pointer-events:none}
.page-hero .wrap{position:relative;padding-block:clamp(2.4rem,6vw,3.8rem)}
.page-hero .breadcrumb a,.page-hero .breadcrumb{color:var(--on-dark-soft)}
.page-hero .breadcrumb a:hover{color:var(--brass-soft)}
.page-hero .breadcrumb li[aria-current]{color:var(--on-dark);font-weight:600}
.page-hero .breadcrumb li+li::before{color:rgba(231,222,203,.35)}
.page-hero h1{color:var(--on-dark);font-size:clamp(2rem,6vw,3.1rem);margin-top:1rem;font-weight:500}
.page-hero p{color:var(--on-dark-soft);max-width:40rem;margin-top:1rem;font-size:1.1rem}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--navy);color:var(--on-dark-soft);padding-top:clamp(2.8rem,7vw,4rem)}
.footer__grid{display:grid;gap:2.2rem;grid-template-columns:1fr}
@media (min-width:680px){.footer__grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer__brand .brand__name{color:var(--on-dark)}
.footer__about{margin-top:1rem;font-size:.95rem;line-height:1.7;max-width:30rem}
.footer h4{color:var(--on-dark);font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem}
.footer__links{list-style:none;display:grid;gap:.65rem}
.footer__links a{font-size:.96rem;color:var(--on-dark-soft)}
.footer__links a:hover{color:var(--brass-soft)}
.footer__contact{list-style:none;display:grid;gap:.85rem;font-size:.96rem}
.footer__contact li{display:grid;grid-template-columns:auto 1fr;gap:.7rem;align-items:start}
.footer__contact .ico{width:1.15em;height:1.15em;color:var(--brass-soft);margin-top:.2em}
.footer__contact a:hover{color:var(--brass-soft)}
.footer__bottom{margin-top:2.6rem;border-top:1px solid var(--line-dark);padding-block:1.5rem;
  display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;justify-content:space-between;align-items:center;font-size:.84rem}
.footer__bottom p{margin:0}
.footer__bottom a{color:var(--on-dark-soft)}
.footer__bottom a:hover{color:var(--brass-soft)}

/* ---------- REVEAL (animacje wejścia, z safety) ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.is-visible,.reveal-instant .reveal{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.card:hover,.listing:hover{transform:none}
}

/* utility */
.center{text-align:center}
.mt-2{margin-top:2rem}
.muted-link{color:var(--brass-deep);font-weight:600;display:inline-flex;align-items:center;gap:.4rem}
.muted-link:hover{gap:.6rem}
.muted-link .ico{width:1.05em;height:1.05em;transition:transform .2s}
.section--navy .muted-link{color:var(--brass-soft)}
