/*
Theme Name: Deweloper Starter
Theme URI: https://example.com/
Author: ChatGPT
Author URI: https://example.com/
Description: Lekki motyw startowy dla dewelopera (Inwestycja + Lokale) z placeholderami i szablonami: Home, Aktualne, Zrealizowane, O nas, Kontakt.
Version: 1.2.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: deweloper-starter
*/

:root { --brand:#0b6; --brand-alt:#0a4; --text:#1b1b1b; --muted:#6b6b6b; --bg:#fff; --ph:#e6e6e6; }
body { font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color:var(--text); margin:0; background:#fff; }
h1,h2,h3 { line-height:1.2; margin:0 0 .5em; }
main { max-width:1200px; margin:0 auto; padding:24px; }
.site-header { background:#fff; border-bottom:1px solid #eee; }
.site-header .wrap { max-width:1200px; margin:0 auto; padding:12px 24px; display:flex; gap:16px; align-items:center; justify-content:space-between; }
.brand { font-weight:700; font-size:18px; letter-spacing:.2px; }
nav.primary a { text-decoration:none; color:#222; margin:0 10px; }
nav.primary a:hover { color:var(--brand); }

.hero, .inv-hero { display:grid; grid-template-columns: 2fr 1fr; gap:24px; align-items:center; }
.hero .hero-media img, .inv-hero .media img { width:100%; height:auto; border-radius:16px; }
.ph { border-radius:16px; overflow:hidden; }
.hero-ph, .map-ph { width:100%; height:100%; min-height:300px; }
.hero-copy .btn { margin-top:12px; }
.features .grid, .inv-features .grid { display:grid; grid-template-columns: repeat(4,1fr); gap:16px; }
.feature { border:1px solid #eee; border-radius:12px; padding:16px; background:#fff; }
.feature .icon { width:40px; height:40px; background:var(--ph); border-radius:999px; margin-bottom:8px; }
.cta { margin:40px 0; }
.cta-box { background:linear-gradient(180deg,#f7f7f7,#fff); border:1px solid #eee; border-radius:16px; padding:24px; display:flex; justify-content:space-between; align-items:center; }
.btn { display:inline-block; background:var(--brand); color:#fff; text-decoration:none; border:none; padding:10px 16px; border-radius:10px; cursor:pointer; font-weight:600; }
.btn:hover { filter:brightness(.95); }
.btn-alt { background:#f0f0f0; color:#000; }
.btn-alt.disabled { opacity:.5; pointer-events:none; }
.btn-sm { padding:6px 10px; font-size:14px; }
.badge { padding:4px 8px; border-radius:999px; font-size:12px; }
.badge-dostepny { background:#e9f9ef; color:#1b7a3f; }
.badge-rezerwacja { background:#fff5e6; color:#a86400; }
.badge-sprzedany { background:#f5e9ec; color:#8a1d2a; }
.inv-files .btn { margin-right:8px; margin-bottom:8px; }
.filters { display:flex; flex-wrap:wrap; gap:12px; align-items:end; margin-bottom:12px; }
.filters label { display:flex; flex-direction:column; font-size:14px; color:var(--muted); }
.units { width:100%; border-collapse:collapse; background:#fff; border-radius:12px; overflow:hidden; }
.units th, .units td { padding:12px; border-bottom:1px solid #eee; text-align:left; }
.units thead th { background:#fafafa; font-size:14px; color:#444; }
.inv-map .map-wrap { border:1px solid #eee; border-radius:16px; overflow:hidden; }
.site-footer { border-top:1px solid #eee; margin-top:40px; }
.site-footer .wrap { max-width:1200px; margin:0 auto; padding:16px 24px; color:#666; font-size:14px; }
@media (max-width: 980px) {
  .hero, .inv-hero { grid-template-columns: 1fr; }
  .features .grid, .inv-features .grid { grid-template-columns: repeat(2,1fr); }
}

/* === Page templates === */
.sub-hero { max-width:1200px; margin:0 auto 20px; padding:24px; }
.sub-hero h1 { font-size:36px; margin-bottom:6px; }
.sub-hero p { color:var(--muted); }

.grid-cards { display:grid; grid-template-columns: repeat(3, 1fr); gap:20px; }
@media (max-width: 980px){ .grid-cards { grid-template-columns: 1fr 1fr; } }
@media (max-width: 680px){ .grid-cards { grid-template-columns: 1fr; } }

.card { border:1px solid #eee; border-radius:16px; overflow:hidden; background:#fff; display:flex; flex-direction:column; }
.card-media img, .card .ph-rect { width:100%; display:block; }
.card-body { padding:16px; display:flex; flex-direction:column; gap:10px; }
.card-title { font-size:20px; margin:0; }
.card-excerpt { color:#444; }
.card-meta { display:flex; gap:12px; flex-wrap:wrap; color:#666; font-size:14px; }
.inv-card.done { opacity:.95; }
.pagination { display:flex; gap:8px; justify-content:center; margin:24px 0; }

.section { max-width:1200px; margin:24px auto; padding:0 24px; }
.two-col { display:grid; grid-template-columns: 1fr 1fr; gap:24px; align-items:center; }
@media (max-width: 980px){ .two-col { grid-template-columns: 1fr; } }
.grid-3 { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.grid-4 { display:grid; grid-template-columns: repeat(4,1fr); gap:16px; }
.value-box { border:1px solid #eee; border-radius:12px; padding:16px; background:#fff; }
.counters .num { font-size:32px; font-weight:700; }
.counters .lab { color:#666; }
.steps { counter-reset: step; list-style:none; padding-left:0; }
.steps li { margin:10px 0; padding-left:0; }
.checklist { padding-left:18px; }
.checklist li { margin:6px 0; }

.contact-box { border:1px solid #eee; border-radius:12px; padding:16px; background:#fff; margin-bottom:16px; }
.contact-form { border:1px solid #eee; border-radius:12px; padding:16px; background:#fff; display:grid; gap:12px; }
.contact-form label { display:flex; flex-direction:column; gap:6px; font-size:14px; color:#555; }
.contact-form input, .contact-form textarea { border:1px solid #ddd; border-radius:8px; padding:10px 12px; font: inherit; }
.contact-form .agree { flex-direction:row; align-items:center; gap:8px; }
.form-note { font-size:12px; color:#666; margin:0; }
.map { border:1px solid #eee; border-radius:16px; overflow:hidden; }

/* === Modern sticky header & navigation === */
.site-header-modern {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.9);
  backdrop-filter: saturate(1.2) blur(6px);
  border-bottom: 1px solid rgba(0,0,0,0.05);
  transition: background .25s ease, box-shadow .25s ease, transform .25s ease;
}
.is-scrolled .site-header-modern {
  box-shadow: 0 6px 24px rgba(0,0,0,0.06);
  background: rgba(255,255,255,0.98);
}
.site-header-modern .wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px 24px;
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 16px;
  align-items: center;
}
.brand-wrap { display:flex; align-items:center; gap:10px; }
.brand { display:flex; align-items:center; gap:10px; text-decoration:none; color:#111; font-weight:700; }
.logo-ph { width:40px; height:40px; border-radius:12px; background:var(--ph); display:flex; align-items:center; justify-content:center; font-size:12px; color:#666; }
.brand-name { letter-spacing:.3px; }

.menu-toggle { display:none; width:42px; height:42px; border-radius:10px; border:1px solid #e6e6e6; background:#fff; align-items:center; justify-content:center; }
.menu-toggle .bar { width:20px; height:2px; background:#111; display:block; margin:3px auto; border-radius:2px; }

.site-nav { display:flex; align-items:center; gap:20px; }
.site-nav .menu { display:flex; list-style:none; margin:0; padding:0; gap:14px; }
.site-nav .menu > li { position:relative; }
.site-nav .menu a { display:inline-block; padding:10px 10px; text-decoration:none; color:#222; border-radius:10px; }
.site-nav .menu a:hover { background:#f4f6f5; color:#000; }
.site-nav .menu > li.menu-item-has-children:hover > .sub-menu { opacity:1; visibility:visible; transform: translateY(0); }

/* Dropdown (desktop) */
.sub-menu { position:absolute; left:0; top:100%; min-width:220px; background:#fff; border:1px solid #eee; border-radius:12px; padding:8px; list-style:none; margin:6px 0 0; box-shadow:0 12px 30px rgba(0,0,0,0.08); opacity:0; visibility:hidden; transform: translateY(6px); transition: .2s ease; z-index: 10; }
.sub-menu li a { display:block; padding:10px 12px; border-radius:8px; }
.sub-menu li a:hover { background:#f7f7f7; }

/* CTA on the right */
.nav-cta { display:flex; align-items:center; gap:10px; margin-left:10px; }
.nav-cta .tel { text-decoration:none; color:#111; font-weight:600; padding:8px 10px; border-radius:8px; background:#f4f6f5; }
.btn-cta { background: var(--brand); color:#fff !important; padding:10px 14px; border-radius:12px; text-decoration:none; font-weight:700; border:0; }
.btn-cta:hover { filter:brightness(.95); }

/* Mobile */
@media (max-width: 980px){
  .menu-toggle { display:flex; }
  .site-header-modern .wrap { grid-template-columns: auto auto auto; }
  .site-nav { position: fixed; inset: 70px 0 0 0; background:#fff; display:block; transform: translateY(-8px); opacity:0; visibility:hidden; transition: .25s ease; overflow:auto; border-top:1px solid #eee; padding:12px 16px 24px; }
  .site-nav.is-open { transform: translateY(0); opacity:1; visibility:visible; }
  .site-nav .menu { display:block; }
  .site-nav .menu > li { border-bottom:1px solid #f2f2f2; }
  .site-nav .menu a { display:block; padding:14px 6px; }
  .site-nav .menu > li.menu-item-has-children > .sub-menu { position:static; transform:none; opacity:1; visibility:visible; border:0; box-shadow:none; padding:0 0 8px 8px; display:none; }
  .site-nav .menu > li.open > .sub-menu { display:block; }
  .nav-cta { padding:12px 6px; gap:8px; }
}