*{box-sizing:border-box;}
body{margin:0;background:#F8FAFF;color:#0F172A;font-family:'Outfit', system-ui, sans-serif;line-height:1.6;}
img{max-width:100%;display:block;}
.ctr{max-width:1600px;margin:0 auto;padding:0 32px;}

/* header */
.site-header{background:#FFFFFF;box-shadow:0 1px 0 #0F172A15;position:sticky;top:0;z-index:100;}
.header-inner{max-width:1600px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:72px;}
.logo{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.65rem;font-weight:700;letter-spacing:-.02em;line-height:1;text-decoration:none;}
.tagline{color:#64748B;font-size:.72rem;margin-top:3px;}

/* nav */
.site-nav{background:#0F172A;}
.nav-inner{max-width:1600px;margin:0 auto;padding:0 32px;display:flex;min-height:44px;flex-wrap:wrap;overflow-x:hidden;}
.nav-link{color:rgba(255,255,255,.75);font-size:.76rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;padding:0 16px;height:44px;display:flex;align-items:center;text-decoration:none;border-right:1px solid rgba(255,255,255,.1);white-space:nowrap;flex-shrink:0;}
.nav-link:hover{color:#fff;background:rgba(255,255,255,.08);}

/* hamburger (mobile) — ukryty na desktopie */
.hamburger{display:none;border:none;background:none;cursor:pointer;padding:8px;flex-direction:column;align-items:center;justify-content:center;gap:5px;-webkit-tap-highlight-color:transparent;}
.hamburger .bar{display:block;width:22px;height:2px;background:#0F172A;border-radius:1px;transition:transform .25s,opacity .2s;}
.hamburger.open .bar1{transform:translateY(7px) rotate(45deg);}
.hamburger.open .bar2{opacity:0;}
.hamburger.open .bar3{transform:translateY(-7px) rotate(-45deg);}

/* wspólne */
.badge{background:#3B82F6;color:#fff;font-size:.68rem;font-weight:700;padding:4px 12px;letter-spacing:.1em;text-transform:uppercase;display:inline-block;text-decoration:none;}
.section-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.35rem;font-weight:700;margin:0;}
.accent-line{width:40px;height:3px;background:#3B82F6;margin:10px 0 28px;}

/* karta */
.card{background:#FFFFFF;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;text-decoration:none;color:inherit;}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #0F172A20;}
.card-img{width:100%;height:200px;background-size:cover;background-position:center center;}
.card-body{padding:20px;display:flex;flex-direction:column;flex:1;}
.card-cat{color:#3B82F6;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;}
.card-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.05rem;font-weight:600;line-height:1.3;margin:0 0 10px;}
.card-exc{color:#64748B;font-size:.875rem;line-height:1.55;margin:0 0 14px;flex:1;}
.card-foot{display:flex;align-items:center;justify-content:space-between;}
.card-meta{color:#64748B;font-size:.775rem;}
.card-read{color:#3B82F6;font-size:.8rem;font-weight:600;}

/* layout A: hero + siatka */
.hero{position:relative;height:560px;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center center;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0F172A08 0%,#0F172ABB 62%,#0F172AEE 100%);}
.hero-content{position:absolute;bottom:0;left:0;right:0;padding:48px 64px;}
.hero-title{font-family:'Outfit', Georgia, serif;color:#fff;font-size:2.25rem;font-weight:700;line-height:1.15;margin:12px 0 14px;max-width:780px;text-shadow:0 2px 12px rgba(0,0,0,.2);}
.hero-title a{color:#fff;text-decoration:none;}
.hero-exc{color:rgba(255,255,255,.85);font-size:1rem;line-height:1.6;margin:0;max-width:660px;}
.hero-meta{color:rgba(255,255,255,.58);font-size:.8rem;margin-top:14px;}
.grid-sect{padding:56px 0 64px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}

/* layout B: magazyn */
.mag-sect{padding:40px 0 64px;}
.mag-feat{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;background:#FFFFFF;border:1px solid #0F172A12;}
.mag-feat-img{width:100%;height:100%;min-height:340px;background-size:cover;background-position:center center;}
.mag-feat-content{padding:44px 40px;display:flex;flex-direction:column;justify-content:center;border-left:4px solid #3B82F6;}
.mag-feat-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.85rem;font-weight:700;line-height:1.15;margin:12px 0 16px;}
.mag-feat-title a{color:inherit;text-decoration:none;}
.mag-feat-exc{color:#64748B;font-size:.95rem;line-height:1.6;}
.mag-row{display:grid;grid-template-columns:1fr 260px;gap:24px;margin-top:24px;}
.mag-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.mag-card-body{padding:14px;}
.mag-sidebar{background:#FFFFFF;padding:20px 22px;border:1px solid #0F172A12;height:max-content;}
.mag-side-hdr{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid #3B82F6;}
.mag-side-link{color:#64748B;font-size:.875rem;display:block;padding:8px 0;border-bottom:1px solid #0F172A10;text-decoration:none;}
.mag-side-link:hover{color:#3B82F6;}

/* layout C: edytorial */
.edit-hero{background:#FFFFFF;padding:72px 0 56px;border-bottom:1px solid #0F172A12;}
.edit-label{color:#3B82F6;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;}
.edit-hero-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:3rem;font-weight:700;line-height:1.1;margin:16px 0 0;max-width:700px;}
.edit-hero-sub{color:#64748B;font-size:1.05rem;margin-top:16px;max-width:580px;line-height:1.65;}
.edit-list{padding:4px 0 64px;}
.edit-item,.edit-item-rev{display:grid;overflow:hidden;background:#FFFFFF;margin-bottom:2px;cursor:pointer;transition:box-shadow .2s;text-decoration:none;color:inherit;}
.edit-item{grid-template-columns:1fr 420px;}
.edit-item-rev{grid-template-columns:420px 1fr;}
.edit-item:hover,.edit-item-rev:hover{box-shadow:0 12px 32px #0F172A15;}
.edit-img{width:100%;height:300px;background-size:cover;background-position:center center;}
.edit-content{padding:48px 44px;display:flex;flex-direction:column;justify-content:center;}
.edit-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.5rem;font-weight:700;line-height:1.2;margin:10px 0 14px;}
.edit-exc{color:#64748B;font-size:.95rem;line-height:1.65;margin:0 0 16px;}

/* nagłówek strony (kategoria/kontakt) */
.page-hdr{background:#0F172A;padding:56px 0 48px;}
.page-hdr .bread{color:rgba(255,255,255,.48);font-size:.8rem;margin-bottom:20px;}
.page-hdr .bread a{color:rgba(255,255,255,.7);text-decoration:none;}
.page-hdr h1{font-family:'Outfit', Georgia, serif;color:#fff;font-size:2.5rem;font-weight:700;line-height:1.1;margin:0;max-width:840px;}
.page-hdr .desc{color:rgba(255,255,255,.72);font-size:1rem;margin-top:14px;max-width:560px;line-height:1.6;}
.page-hdr .count{display:inline-block;background:rgba(255,255,255,.12);color:#fff;font-size:.78rem;font-weight:600;padding:4px 14px;margin-top:18px;}

/* kategoria */
.cat-body{padding:40px 0 64px;}
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:#0F172A12;}
.cat-card{background:#FFFFFF;display:grid;grid-template-columns:220px 1fr;cursor:pointer;overflow:hidden;transition:transform .2s,box-shadow .2s;text-decoration:none;color:inherit;}
.cat-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #0F172A20;}
.cat-card-img{height:100%;min-height:200px;background-size:cover;background-position:center center;}
.cat-card-body{padding:24px 28px;display:flex;flex-direction:column;}
.cat-card-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.1rem;font-weight:600;line-height:1.3;margin:6px 0 12px;}
.cat-card-exc{color:#64748B;font-size:.875rem;line-height:1.55;flex:1;}
.cat-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;}

/* artykuł */
.art-hdr{background:#FFFFFF;padding:48px 0 40px;border-bottom:1px solid #0F172A12;}
.art-bread{color:#64748B;font-size:.8rem;margin-bottom:20px;}
.art-bread a{color:#3B82F6;font-weight:600;text-decoration:none;}
.art-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:2.5rem;font-weight:700;line-height:1.15;margin:14px 0 0;max-width:840px;}
.art-meta-row{display:flex;gap:8px;align-items:center;margin-top:24px;flex-wrap:wrap;color:#64748B;font-size:.875rem;}
.art-meta-row .dot{opacity:.4;}
.art-feat-img{width:100%;height:480px;background-size:cover;background-position:center center;}
.art-body-wrap{background:#F8FAFF;}
.art-body{max-width:740px;margin:0 auto;padding:48px 32px 64px;}
.art-body p{color:#0F172A;font-size:1rem;line-height:1.8;margin:0 0 22px;}
.art-body p:first-of-type{font-size:1.15rem;line-height:1.75;margin-bottom:28px;padding-left:20px;border-left:3px solid #3B82F6;}
.art-body h2{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.5rem;font-weight:700;margin:44px 0 16px;padding-bottom:10px;border-bottom:1px solid #0F172A15;}
.art-body h3{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.2rem;font-weight:700;margin:32px 0 12px;}
.art-body strong{color:#0F172A;font-weight:700;}
.art-body a{color:#3B82F6;font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.art-body ul,.art-body ol{margin:0 0 22px;padding-left:24px;line-height:1.8;}
.art-body li{margin-bottom:8px;}
.art-body img{margin:24px 0;}

/* powiązane */
.related{padding:56px 0 64px;border-top:1px solid #0F172A10;}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px;}

/* prev/next */
.post-nav{max-width:740px;margin:0 auto;padding:0 32px 56px;display:flex;justify-content:space-between;gap:16px;}
.post-nav a{flex:1;background:#FFFFFF;padding:18px 20px;text-decoration:none;border:1px solid #0F172A12;transition:box-shadow .2s;}
.post-nav a:hover{box-shadow:0 8px 24px #0F172A15;}
.post-nav .lbl{color:#64748B;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;}
.post-nav .ttl{font-family:'Outfit', Georgia, serif;color:#0F172A;font-weight:600;margin-top:6px;font-size:.95rem;}
.post-nav .next{text-align:right;}

/* kontakt */
.ct-body{padding:64px 32px;}
.ct-grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 360px;gap:80px;}
.ct-form-title{font-family:'Outfit', Georgia, serif;color:#0F172A;font-size:1.35rem;font-weight:700;margin-bottom:28px;}
.fg{margin-bottom:20px;}
.lbl{color:#0F172A;font-size:.875rem;font-weight:600;display:block;margin-bottom:6px;}
.inp,.txa{width:100%;padding:10px 14px;border:1px solid #0F172A28;font-size:.95rem;color:#0F172A;background:#FFFFFF;outline:none;border-radius:0;font-family:inherit;}
.inp:focus,.txa:focus{border-color:#3B82F6;}
.txa{resize:vertical;min-height:150px;}
.btn{background:#3B82F6;color:#fff;padding:12px 32px;border:none;cursor:pointer;font-size:.95rem;font-weight:700;margin-top:8px;font-family:inherit;}
.btn:hover{filter:brightness(.94);}
.btn:disabled{opacity:.6;cursor:default;}
.ct-info{padding-top:60px;}
.ct-info-item{margin-bottom:24px;}
.ct-info-lbl{color:#64748B;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px;}
.ct-info-val{color:#0F172A;font-size:.95rem;}
.ct-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}
.ct-tag{background:#0F172A12;color:#0F172A;font-size:.75rem;padding:3px 10px;}
.ct-status{margin-top:16px;font-size:.9rem;line-height:1.5;}
.ct-status.ok{color:#3B82F6;font-weight:600;}
.ct-status.err{color:#c0392b;font-weight:600;}

/* footer */
.site-footer{background:#0F172A;padding:56px 32px 24px;}
.ft-inner{max-width:1600px;margin:0 auto;}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:40px;}
.ft-logo{font-family:'Outfit', Georgia, serif;color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:8px;}
.ft-tag{color:rgba(255,255,255,.58);font-size:.875rem;line-height:1.5;}
.ft-domain{color:rgba(255,255,255,.33);font-size:.75rem;margin-top:6px;}
.ft-col-title{font-family:'Outfit', Georgia, serif;color:#fff;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:16px;}
.ft-link{color:rgba(255,255,255,.58);font-size:.85rem;display:block;margin-bottom:8px;text-decoration:none;}
.ft-link:hover{color:#fff;}
.ft-copy{color:rgba(255,255,255,.28);font-size:.75rem;border-top:1px solid rgba(255,255,255,.12);padding-top:20px;}

/* === RESPONSYWNOŚĆ (breakpointy 1024/480, menu hamburger) === */
@media(max-width:1024px){
  .hamburger{display:flex;}
  .site-nav{display:none;position:fixed;top:72px;left:0;right:0;z-index:300;max-height:calc(100vh - 72px);overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.22);}
  .site-nav.open{display:block;}
  .nav-inner{flex-direction:column;min-height:0;padding:0;}
  .nav-link{width:100%;border-right:none;border-bottom:1px solid rgba(255,255,255,.1);height:52px;padding:0 28px;font-size:.9rem;letter-spacing:.04em;}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .mag-feat{grid-template-columns:1fr;}
  .mag-row{grid-template-columns:1fr;}
  .mag-sidebar{display:none;}
  .mag-grid{grid-template-columns:repeat(2,1fr);}
  .edit-item,.edit-item-rev{grid-template-columns:1fr;}
  .cat-grid{grid-template-columns:1fr;}
  .cat-card{grid-template-columns:160px 1fr;}
  .ct-grid{grid-template-columns:1fr;gap:40px;}
  .ct-info{padding-top:0;}
  .rel-grid{grid-template-columns:repeat(2,1fr);}
  .ft-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .hero-content{padding:32px;}
  .art-title{font-size:1.9rem;}
  .edit-hero-title{font-size:2.2rem;}
  .ctr{padding:0 24px;}
  .mag-feat-img{height:320px;min-height:0;}
}
@media(max-width:480px){
  .site-nav{top:72px;max-height:calc(100vh - 72px);}
  .grid-3{grid-template-columns:1fr;}
  .mag-grid{grid-template-columns:1fr;}
  .rel-grid{grid-template-columns:1fr;}
  .ft-grid{grid-template-columns:1fr;gap:24px;}
  .cat-card{grid-template-columns:1fr;}
  .cat-card-img{min-height:180px;height:180px;}
  .ct-grid{gap:24px;}
  .ct-body{padding:32px 16px;}
  .hero-content{padding:20px;}
  .hero-title{font-size:1.35rem;}
  .edit-hero-title{font-size:1.5rem;}
  .art-title{font-size:1.3rem;}
  .ctr{padding:0 16px;}
  .mag-feat-img{height:220px;}
  .art-feat-img{height:240px;}
  .logo-tagline{display:none;}
}
