*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    /* Skip link — WCAG 2.4.1 (Bypass Blocks). Ukryty, focusowalny → widoczny po Tab */
    .skip-link {
      position: absolute;
      left: -9999px;
      top: 0;
      z-index: 10000;
      background: #8B6914;
      color: #fff;
      padding: 12px 20px;
      text-decoration: none;
      font-weight: 700;
      border-radius: 0 0 8px 0;
      font-family: 'Raleway', system-ui, sans-serif;
    }
    .skip-link:focus { left: 0; outline: 3px solid #fff; outline-offset: -3px; }

    :root {
      --gold: #8B6914;
      --gold-light: #D4A84C;
      --gold-pale: #FDF6E3;
      --dark: #FAF9F6;
      --dark2: #F0EFE9;
      --dark3: #FAF9F6;
      --dark4: #E8E7E1;
      --text: #1A1A1A;
      --text-dim: #5C5650;
      --red: #C0392B;
      --yellow: #D4A017;
      --green: #1A7A4A;
      --shadow-gold: rgba(184,137,42,0.10);
      --shadow-gold-sm: rgba(184,137,42,0.06);
    }

    html { scroll-behavior: smooth; }

    /* Grain texture overlay */
    body::after {
      content: '';
      position: fixed;
      inset: 0;
      pointer-events: none;
      z-index: 9999;
      opacity: 0.025;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
      background-repeat: repeat;
      background-size: 128px 128px;
    }

    body {
      background: var(--dark);
      color: var(--text);
      font-family: 'Raleway', sans-serif;
      font-weight: 400;
      line-height: 1.7;
      min-height: 100vh;
    }

    /* ── HEADER ── */
    @keyframes fadeDown { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:translateY(0)} }
    header {
      position: fixed;
      top: 0; left: 0; right: 0;
      z-index: 1000;
      padding: 0 32px;
      height: 68px;
      display: grid;
      /* 4 kolumny: logo | nav (centrowany) | credits | auth — wszystko w jednej linii */
      grid-template-columns: auto 1fr auto auto;
      align-items: center;
      column-gap: 16px;
      white-space: nowrap;
      background: rgba(8,14,7,.75);
      backdrop-filter: blur(20px);
      border-bottom: 1px solid rgba(255,255,255,.06);
      opacity: 0;
      animation: fadeDown .6s .2s ease both;
      transition: background .3s;
    }
    header.scrolled { background: rgba(8,14,7,.92); }
    /* nav w środkowej kolumnie z 1fr — centruj go */
    header > nav { justify-self: center; min-width: 0; }
    /* gdy credits-badge ma display:none, nav-auth wjeżdża w pustą kolumnę 3
       — to OK, grid traktuje to jako pustą celę, layout się nie rozjeżdża */

    .logo {
      font-family: 'Playfair Display', serif;
      font-size: 1.4rem;
      font-weight: 900;
      color: #fff;
      text-decoration: none;
      letter-spacing: 1px;
      text-transform: uppercase;
      transition: font-size .3s ease;
    }
    header.scrolled .logo { font-size: 1.1rem; }
    .logo span { color: #C9A84C; text-transform: none; letter-spacing: 0; }

    nav { display: flex; gap: 32px; align-items: center; flex-wrap: nowrap; }
    #nav-auth { justify-self: end; display: flex; align-items: center; gap: 6px; flex-wrap: nowrap; }
    #credits-badge { white-space: nowrap; }

    /* Hamburger menu button — default hidden on desktop, shown on <768px */
    #mobileMenuBtn { display: none; background: none; border: none; color: #C9A84C; font-size: 1.6rem; padding: 8px 10px; cursor: pointer; line-height: 1; }
    #mobileMenuBtn:hover { color: #e0bc5e; }

    /* Responsive 2-col grid — collapses to 1-col on mobile */
    .form-2col-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 0; }
    @media (max-width: 600px) { .form-2col-grid { grid-template-columns: 1fr; } }

    /* === Kompresja headera dla węższych desktopów (≤1280px) ===
       żeby logo + 4 menu items + credits + admin + history + avatar
       nie wracały na drugą linię */
    @media (min-width: 769px) and (max-width: 1280px) {
      header { padding: 0 20px; column-gap: 12px; }
      nav { gap: 22px; }
      nav a { font-size: .62rem; letter-spacing: .18em; }
      .nav-cta-btn { padding: 8px 16px; font-size: .76rem; }
      #credits-badge { font-size: 0.72rem !important; padding: 4px 9px !important; margin-right: 4px !important; }
      #nav-hist-btn { padding: 5px 10px !important; font-size: .78rem !important; margin-right: 4px !important; }
    }
    @media (min-width: 769px) and (max-width: 1100px) {
      header { padding: 0 14px; column-gap: 8px; }
      nav { gap: 16px; }
      nav a { font-size: .58rem; letter-spacing: .14em; }
      .logo { font-size: 1.15rem; letter-spacing: .5px; }
    }
    nav a {
      color: rgba(255,255,255,.5);
      text-decoration: none;
      font-size: .68rem;
      font-weight: 500;
      letter-spacing: .22em;
      text-transform: uppercase;
      transition: color .2s;
    }
    nav a:hover { color: rgba(201,168,76,.9); }
    .nav-cta-btn {
      background: linear-gradient(135deg,#C9A84C,#e0bc5e);
      color: #1a1400 !important;
      padding: 9px 22px;
      border-radius: 7px;
      font-size: .82rem;
      font-weight: 700 !important;
      letter-spacing: .04em;
      text-transform: none;
      transition: opacity .2s;
    }
    .nav-cta-btn:hover { opacity: .88; color: #1a1400 !important; }
    .pricing-btn { width:100%;background:#8B6914;color:#fff;border:none;border-radius:8px;padding:11px 16px;font-weight:700;font-size:.88rem;cursor:pointer;font-family:inherit;transition:opacity .15s; }
    .pricing-btn:hover { opacity:.85; }

    /* ── HERO ── */
    .hero {
      position: relative;
      min-height: 100dvh;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: flex-start;
      text-align: center;
      overflow: hidden;
      background: radial-gradient(ellipse 120% 80% at 50% -10%, #193318 0%, #0d1a0c 35%, #080e07 70%);
    }

    /* ── GLOBE CANVAS ── */
    #gc {
      position: absolute; bottom: -360px; left: 50%; transform: translateX(-50%);
      width: 820px; height: 820px; border-radius: 50%; z-index: 2;
      animation: rise 3.5s cubic-bezier(.05,.85,.15,1) 0.5s both;
    }
    @keyframes rise {
      0%   { transform: translateX(-50%) translateY(520px) scale(.80); opacity: 0; filter: blur(30px); }
      12%  { opacity: 1; }
      100% { transform: translateX(-50%) translateY(0) scale(1); filter: blur(0); }
    }
    .aura {
      position: absolute; bottom: calc(-360px - 60px); left: 50%; transform: translateX(-50%);
      width: 940px; height: 940px; border-radius: 50%; z-index: 1; pointer-events: none;
      background: radial-gradient(ellipse at 50% 50%, transparent 42%, rgba(40,110,30,.18) 54%, rgba(20,60,16,.10) 66%, transparent 76%);
      box-shadow: 0 0 60px 20px rgba(201,168,76,.07), 0 0 160px 70px rgba(20,60,16,.40), 0 0 320px 110px rgba(14,30,12,.55);
    }
    #lsvg { position: absolute; inset: 0; z-index: 8; width: 100%; height: 100%; pointer-events: none; }

    /* ── PHOTO CARDS ── */
    .pcard { position: absolute; z-index: 30; opacity: 0; transform: scale(.72) translateY(8px); transition: opacity .5s, transform .5s cubic-bezier(.2,.8,.3,1); pointer-events: none; }
    .pcard.show { opacity: 1; transform: scale(1) translateY(0); pointer-events: auto; cursor: pointer; }
    .pcard img { width: 120px; height: 80px; object-fit: cover; border-radius: 12px; display: block; box-shadow: 0 6px 28px rgba(0,0,0,.5), 0 0 0 2.5px rgba(201,168,76,.5); }
    .pcard:hover img { box-shadow: 0 8px 32px rgba(0,0,0,.7), 0 0 0 2.5px #C9A84C; transform: scale(1.04); }
    .pcard img { transition: transform .2s, box-shadow .2s; }

    /* ── CHAT BUBBLES ── */
    .umsg { position: absolute; z-index: 22; pointer-events: none; background: rgba(255,255,255,.95); backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,.6); border-radius: 14px 14px 14px 4px; padding: 10px 14px; max-width: 210px; min-width: 140px; box-shadow: 0 4px 22px rgba(0,0,0,.18); opacity: 0; transform: translateY(10px) scale(.92); transition: opacity .45s, transform .45s cubic-bezier(.2,.9,.3,1); }
    .umsg.vis { opacity: 1; transform: translateY(0) scale(1); }
    .umsg .un { display: block; font-size: .62rem; font-weight: 700; color: #C9A84C; margin-bottom: 4px; }
    .umsg .ut { font-size: .76rem; color: #333; line-height: 1.45; font-weight: 500; }

    .hero-content {
      position: relative;
      z-index: 10;
      max-width: 700px;
      padding: 108px 32px 0;
    }

    @keyframes heroFadeUp {
      from { opacity: 0; transform: translateY(28px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    .hero-badge {
      display: inline-block;
      background: rgba(184,137,42,0.15);
      border: 1px solid rgba(184,137,42,0.45);
      color: var(--gold);
      font-size: 0.68rem;
      font-weight: 600;
      letter-spacing: 3px;
      text-transform: uppercase;
      padding: 7px 18px;
      border-radius: 100px;
      margin-bottom: 36px;
      animation: heroFadeUp 0.8s cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    .hero h1 {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2.2rem, 4vw, 3.8rem);
      font-weight: 700;
      line-height: 1.2;
      margin-bottom: 28px;
      color: #FFFFFF;
      animation: heroFadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.15s both;
    }

    .hero h1 em {
      font-style: italic;
      color: var(--gold);
      -webkit-text-fill-color: var(--gold);
      background: none;
    }

    .hero h1 .hero-h1-dim {
      color: rgba(255,255,255,0.45);
    }

    .hero p {
      font-size: 1.05rem;
      color: rgba(255,255,255,0.72);
      max-width: 520px;
      margin: 0 auto 48px;
      font-weight: 300;
      line-height: 1.85;
      animation: heroFadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.28s both;
    }

    .hero-cta {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      background: linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 100%);
      color: #000;
      font-family: 'Raleway', sans-serif;
      font-weight: 700;
      font-size: 0.8rem;
      letter-spacing: 2px;
      text-transform: uppercase;
      padding: 18px 40px;
      border-radius: 50px;
      border: none;
      cursor: pointer;
      text-decoration: none;
      transition: opacity .3s, transform .3s, box-shadow .3s;
      animation: heroFadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.42s both;
    }
    .hero-cta:hover { opacity: 0.88; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(184,137,42,0.4); }
    .hero-cta:active { transform: scale(0.98); }
    .hero-cta:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; }

    .hero-scroll {
      position: absolute;
      bottom: 48px;
      left: 8vw;
      z-index: 4;
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 8px;
      color: rgba(80,60,20,0.7);
      font-size: 0.65rem;
      letter-spacing: 2px;
      text-transform: uppercase;
      text-shadow: 0 1px 8px rgba(255,255,255,0.95), 0 0 3px rgba(255,255,255,0.7);
    }
    .scroll-line {
      width: 1px;
      height: 40px;
      background: linear-gradient(to bottom, var(--gold), transparent);
      animation: scrollLine 1.5s ease-in-out infinite;
    }
    @keyframes scrollLine {
      0%, 100% { opacity: 0.3; }
      50% { opacity: 1; }
    }

    @media (max-width: 768px) {
      .hero { padding: 120px 24px 140px; }
      .hero-scroll { left: 24px; }

      /* ── MOBILE: ukryj elementy które wylatują poza ekran ── */
      .loader-side-panel { display: none !important; }
      .pcard { display: none !important; }
      #lsvg { display: none !important; }


      /* ── MOBILE: header ── */
      header {
        padding: 0 16px;
        height: 56px;
        top: 34px;
        /* 4 widoczne kolumny: logo | hamburger | credits | auth (nav ukryty domyślnie, rozwija się jako overlay) */
        grid-template-columns: 1fr auto auto auto;
        column-gap: 8px;
      }
      header nav { display: none; }
      /* Hamburger pokazuje overlay nav po kliknięciu */
      #mobileMenuBtn { display: block; }
      header nav.is-open {
        display: flex;
        position: fixed;
        top: 90px; /* pod headerem (56px) + BETA bar (~34px) */
        left: 0; right: 0;
        background: rgba(8,14,7,.97);
        backdrop-filter: blur(20px);
        flex-direction: column;
        padding: 18px 24px;
        z-index: 998;
        gap: 0;
        border-bottom: 1px solid rgba(201,168,76,.25);
      }
      header nav.is-open a {
        padding: 14px 4px;
        font-size: 1rem;
        letter-spacing: .12em;
        border-bottom: 1px solid rgba(255,255,255,.08);
        color: rgba(255,255,255,.85);
      }
      header nav.is-open a:last-child { border-bottom: none; }
      #nav-auth { justify-self: end; display: flex; align-items: center; gap: 6px; }
      #credits-badge { font-size: 0.7rem !important; padding: 3px 8px !important; margin-right: 0 !important; }
      .logo { font-size: 1.05rem; letter-spacing: .5px; }

      /* przyciski nav — tylko ikona na mobile */
      #nav-hist-btn .nav-hist-label { display: none; }
      #nav-hist-btn .nav-hist-icon { display: inline !important; }
      #nav-hist-btn { padding: 10px 12px; font-size: .9rem; margin-right: 4px; min-height: 44px; min-width: 44px; display: inline-flex; align-items: center; justify-content: center; }
      #nav-login-btn .nav-login-label { display: none; }
      #nav-login-btn .nav-login-icon { display: inline !important; }
      #nav-login-btn { padding: 10px 12px; font-size: .9rem; min-height: 44px; min-width: 44px; display: inline-flex; align-items: center; justify-content: center; }
      /* Touch targets — Apple/Google guidelines 44×44 (WCAG 2.5.5 Target Size) */
      #mobileMenuBtn { min-height: 44px; min-width: 44px; padding: 10px 12px; display: inline-flex; align-items: center; justify-content: center; }
      header nav.is-open a { min-height: 44px; }
    }

    @media (max-width: 480px) {
      header { top: 0; }
    }

    /* ── SCROLL REVEAL ── */
    .reveal {
      opacity: 0;
      transform: translateY(32px);
      transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
                  transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
    }
    .reveal.visible {
      opacity: 1;
      transform: translateY(0);
    }

    /* ── STATS ── */
    .stats {
      display: flex;
      justify-content: center;
      gap: 0;
      border-bottom: 1px solid rgba(184,137,42,0.12);
      background: #F7F6F2;
    }
    .stat {
      flex: 1;
      max-width: 260px;
      padding: 48px 32px;
      text-align: center;
      border-right: 1px solid rgba(184,137,42,0.1);
      cursor: default;
      transition: background .35s, box-shadow .3s;
    }
    .stat:last-child { border-right: none; }
    .stat:hover {
      background: #2A1F0D;
      box-shadow: 0 8px 32px rgba(184,137,42,0.18);
      z-index: 2;
    }
    .stat:hover .stat-number { color: var(--gold-light); }
    .stat:hover .stat-label { color: rgba(255,255,255,0.55); }
    .stat:hover .stat-tooltip { max-height: 120px; opacity: 1; margin-top: 14px; padding-top: 12px; }
    .stat-number {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2.4rem,4.5vw,3.8rem);
      color: var(--gold);
      display: block;
      margin-bottom: 8px;
      transition: color .3s;
    }
    .stat-label {
      font-size: 0.75rem;
      color: #6B6560;
      letter-spacing: 2px;
      text-transform: uppercase;
      transition: color .3s;
    }
    .stat-tooltip {
      max-height: 0;
      overflow: hidden;
      opacity: 0;
      margin-top: 0;
      padding-top: 0;
      border-top: 1px solid rgba(184,137,42,0.3);
      font-size: 0.8rem;
      color: rgba(255,255,255,0.78);
      line-height: 1.6;
      transition: max-height .4s ease, opacity .35s, margin-top .35s, padding-top .35s;
    }

    /* ── SECTION ── */
    section { padding: 100px 24px; }

    .section-label {
      font-size: 0.7rem;
      color: var(--gold);
      letter-spacing: 4px;
      text-transform: uppercase;
      margin-bottom: 16px;
      display: block;
    }
    .section-title {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2rem, 4vw, 3rem);
      font-weight: 700;
      color: #111111;
      line-height: 1.2;
      margin-bottom: 16px;
    }
    .section-sub {
      font-size: 1rem;
      color: var(--text-dim);
      max-width: 480px;
      font-weight: 300;
    }

    /* ── FORM SECTION ── */
    #analiza {
      background: #FFFFFF;
    }

    .form-wrapper {
      max-width: 860px;
      margin: 60px auto 0;
    }

    .form-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      margin-bottom: 24px;
    }

    .form-group {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .form-group.full { grid-column: 1 / -1; }

    .form-group label {
      font-size: 0.7rem;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: var(--gold);
      font-weight: 600;
      color: #333 !important;
    }

    .form-group input,
    .form-group select,
    .form-group textarea {
      background: #F7F6F2;
      border: 1px solid rgba(184,137,42,0.25);
      color: #1A1A1A;
      font-family: 'Raleway', sans-serif;
      font-size: 1rem;
      font-weight: 400;
      padding: 16px 20px;
      outline: none;
      transition: border-color .3s, background .3s;
      -webkit-appearance: none;
    }
    .form-group input::placeholder,
    .form-group textarea::placeholder { color: #AAA; }
    .form-group input:focus,
    .form-group select:focus,
    .form-group textarea:focus {
      border-color: var(--gold);
      background: rgba(184,137,42,0.04);
    }

    .form-group select option { background: #FFFFFF; }
    .form-group textarea { resize: vertical; min-height: 80px; }

    .form-hint {
      font-size: 0.75rem;
      color: var(--text-dim);
      margin-top: 4px;
    }

    /* ── UPLOAD DOKUMENTÓW ── */
    .docs-buttons-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 10px;
    }
    .docs-upload-area {
      border: 2px dashed rgba(201,168,76,0.3);
      border-radius: 12px;
      padding: 16px 12px;
      text-align: center;
      cursor: pointer;
      transition: border-color 0.2s, background 0.2s;
      background: rgba(201,168,76,0.03);
    }
    .docs-camera-area {
      border-color: rgba(46,204,113,0.3);
      background: rgba(46,204,113,0.03);
    }
    .docs-upload-area:hover, .docs-upload-area.drag-over {
      border-color: var(--gold);
      background: rgba(201,168,76,0.07);
    }
    .docs-camera-area:hover {
      border-color: #2ECC71;
      background: rgba(46,204,113,0.07);
    }
    .docs-upload-icon { font-size: 1.6rem; margin-bottom: 5px; }
    .docs-upload-text { font-size: 0.85rem; font-weight: 600; color: var(--gold); margin-bottom: 3px; }
    .docs-camera-area .docs-upload-text { color: #2ECC71; }
    .docs-upload-hint { font-size: 0.72rem; color: var(--text-dim); line-height: 1.5; }
    .docs-upload-limit-info {
      font-size: 0.72rem;
      color: var(--text-dim);
      margin-top: 7px;
      text-align: center;
    }
    .doc-file-item {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 8px 12px;
      background: rgba(201,168,76,0.06);
      border: 1px solid rgba(201,168,76,0.2);
      border-radius: 8px;
      font-size: 0.82rem;
      color: var(--text);
    }
    .doc-file-item.loading { opacity: 0.6; }
    .doc-file-item.error { border-color: rgba(231,76,60,0.4); background: rgba(231,76,60,0.05); color: #E74C3C; }
    .doc-file-item.ok { border-color: rgba(46,204,113,0.3); }
    .doc-file-remove {
      margin-left: auto;
      cursor: pointer;
      color: var(--text-dim);
      font-size: 0.9rem;
      padding: 0 4px;
    }
    .doc-file-remove:hover { color: #E74C3C; }

    .submit-btn {
      width: 100%;
      padding: 22px;
      background: linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 100%);
      border: none;
      color: #000;
      font-family: 'Raleway', sans-serif;
      font-size: 0.85rem;
      font-weight: 700;
      letter-spacing: 3px;
      text-transform: uppercase;
      cursor: pointer;
      transition: opacity .3s, transform .3s;
      position: relative;
      overflow: hidden;
      margin-top: 8px;
    }
    .submit-btn:hover:not(:disabled) { opacity: 0.88; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(184,137,42,0.25); }
    .submit-btn:active:not(:disabled) { transform: scale(0.98) translateY(0); opacity: 1; }
    .submit-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

    /* ── LOADER ── */
    #loader {
      display: none;
      text-align: center;
      padding: 80px 0;
      position: relative;
      overflow: hidden;
      min-height: 520px;
    }
    /* ── SLIDESHOW BOCZNY ── */
    .loader-side-panel {
      position: fixed;
      top: 0; bottom: 0;
      width: 28vw;
      overflow: hidden;
      pointer-events: none;
      z-index: 9999;
      display: none;
    }
    .loader-side-panel.active { display: block; }
    #loader-panel-left  { left: 0; }
    #loader-panel-right { right: 0; }
    .lslide {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center;
      filter: sepia(0.3) brightness(0.5) saturate(0.75);
      opacity: 0;
      transition: opacity 0.9s ease;
    }
    .lslide.active { opacity: 1; }
    /* gradient w stronę środka — płynne przejście do białego tła */
    #loader-panel-left::after {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(to right, transparent 40%, #ffffff 100%);
    }
    #loader-panel-right::after {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(to left, transparent 40%, #ffffff 100%);
    }
    /* treść loadera zawsze na wierzchu */
    #loader > *:not(#loader-slideshow) { position: relative; z-index: 2; }
    .loader-ring {
      width: 64px;
      height: 64px;
      border: 2px solid rgba(201,168,76,0.15);
      border-top-color: var(--gold);
      border-radius: 50%;
      animation: spin 1s linear infinite;
      margin: 0 auto 32px;
    }
    @keyframes spin { to { transform: rotate(360deg); } }
    /* ══ TRYB WYNIKÓW — czysta strona tylko z analizą ══ */
    .wyniki-mode .hero,
    .wyniki-mode .stats,
    .wyniki-mode .how-section,
    .wyniki-mode .check-section,
    .wyniki-mode .for-section,
    .wyniki-mode .why-section,
    .wyniki-mode .compare-section,
    .wyniki-mode .maps-section,
    .wyniki-mode .faq-section,
    .wyniki-mode #wspolpraca-section,
    .wyniki-mode #trust-section,
    .wyniki-mode #co-dostane,
    .wyniki-mode .info-bar { display: none !important; }
    /* 2026-05-06: footer-new BYŁ ukryty w wyniku — klient nie widział regulaminu/RODO/kontaktu.
       Zachowuję widoczność w trybie wyniku (kompaktowa wersja). */
    .wyniki-mode .footer-new { padding: 16px !important; }
    .wyniki-mode .footer-new .footer-cols { display: none !important; }
    .wyniki-mode .footer-new .footer-bottom { display: block !important; }

    /* Ukryj wszystko w sekcji analiza oprócz form-wrapper (w nim są wyniki) */
    .wyniki-mode section#analiza > div > *:not(.form-wrapper) { display: none !important; }
    /* Wewnątrz form-wrapper ukryj wszystko oprócz wyniki-nav i wyniki */
    .wyniki-mode .form-wrapper > *:not(#wyniki-nav):not(#wyniki):not(#toc-sidebar) { display: none !important; }
    .wyniki-mode .form-wrapper { padding: 0 !important; margin: 0 !important; }

    .wyniki-mode #analiza { padding: 0; background: var(--dark2); }
    .wyniki-mode section#analiza > div { max-width: 100%; padding: 0; }

    /* Pasek nawigacji wyników */
    #wyniki-nav {
      display: none;
      position: relative;
      z-index: 1;
      background: #1c1508;
      border-bottom: 2px solid rgba(184,137,42,0.35);
      padding: 12px 32px;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      box-shadow: 0 2px 16px rgba(0,0,0,0.3);
    }
    .wyniki-mode #wyniki-nav { display: flex; }
    #wyniki-nav-title {
      font-family: 'Playfair Display', serif;
      font-size: 1.05rem;
      color: var(--gold);
      font-weight: 700;
    }
    #wyniki-nav-sub {
      font-size: 0.78rem;
      color: rgba(255,255,255,0.5);
      margin-top: 2px;
    }
    #plot-banner {
      display: none;
      background: linear-gradient(90deg, #1c1508 0%, #2a1f0d 100%);
      border-bottom: 1px solid rgba(184,137,42,0.25);
      padding: 10px 32px;
      font-size: 0.82rem;
      color: rgba(255,255,255,0.65);
      letter-spacing: 0.3px;
    }
    #plot-banner strong { color: var(--gold); font-weight: 700; font-size: 0.88rem; }
    #plot-banner span { margin: 0 10px; opacity: 0.35; }
    .wyniki-mode #plot-banner { display: block; }
    #wyniki-back-btn {
      display: flex;
      align-items: center;
      gap: 8px;
      background: rgba(184,137,42,0.15);
      border: 1px solid rgba(184,137,42,0.4);
      color: var(--gold);
      font-family: 'Raleway', sans-serif;
      font-size: 0.85rem;
      font-weight: 700;
      padding: 8px 18px;
      border-radius: 8px;
      cursor: pointer;
      letter-spacing: 0.5px;
      transition: background .2s, transform .2s;
      flex-shrink: 0;
    }
    #wyniki-back-btn:hover { background: rgba(184,137,42,0.28); transform: translateX(-2px); }

    @keyframes extras-pulse {
      0%,100% { border-color: rgba(184,137,42,0.25); box-shadow: none; }
      50% { border-color: rgba(184,137,42,0.65); box-shadow: 0 0 0 4px rgba(184,137,42,0.08); }
    }
    @keyframes extras-shake {
      0%,100% { transform: translateX(0); }
      20% { transform: translateX(-6px); }
      40% { transform: translateX(6px); }
      60% { transform: translateX(-4px); }
      80% { transform: translateX(4px); }
    }
    @keyframes arrow-nudge { 0%,100%{transform:translateX(0)} 50%{transform:translateX(5px)} }
    .extras-details {
      margin-top: 14px;
      margin-bottom: 24px;
      border: 2px solid rgba(184,137,42,0.45);
      border-radius: 14px;
      background: rgba(184,137,42,0.06);
      animation: extras-pulse 2.4s ease-in-out infinite;
      transition: border-color .3s, background .3s, box-shadow .3s;
      box-shadow: 0 2px 10px rgba(184,137,42,0.1);
    }
    .extras-details[open] {
      animation: none;
      border-color: var(--gold);
      background: rgba(184,137,42,0.07);
      box-shadow: 0 0 0 3px rgba(184,137,42,0.1);
    }
    .extras-details.shake { animation: extras-shake 0.5s ease; }
    .extras-summary {
      cursor: pointer;
      list-style: none;
      padding: 14px 18px;
      display: flex;
      align-items: center;
      gap: 10px;
      user-select: none;
    }
    .extras-summary::-webkit-details-marker { display: none; }
    .extras-arrow {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 26px; height: 26px;
      border-radius: 50%;
      background: var(--gold);
      color: #fff;
      font-size: 0.85rem;
      font-weight: 700;
      flex-shrink: 0;
      transition: transform .3s;
      animation: arrow-nudge 1.8s ease-in-out infinite;
    }
    .extras-details[open] .extras-arrow {
      transform: rotate(90deg);
      animation: none;
    }
    .extras-label {
      font-weight: 800;
      font-size: 1rem;
      color: #8B6914;
      text-shadow: 0 0 20px rgba(184,137,42,0.2);
    }
    .extras-hint {
      font-size: 0.8rem;
      color: var(--text-dim);
      margin-left: auto;
    }
    .extras-body {
      padding: 0 18px 18px;
      overflow: hidden;
      transition: max-height .4s ease, opacity .35s ease;
      max-height: 0;
      opacity: 0;
    }
    @keyframes slideInRight { from { transform: translateX(120%); opacity:0; } to { transform: translateX(0); opacity:1; } }
    .loader-text {
      font-size: 0.8rem;
      color: var(--text-dim);
      letter-spacing: 2px;
      text-transform: uppercase;
    }
    .loader-progress-wrap {
      max-width: 320px;
      margin: 20px auto 6px;
    }
    .loader-progress-bar {
      height: 2px;
      background: rgba(201,168,76,0.12);
      border-radius: 2px;
      overflow: hidden;
    }
    .loader-progress-fill {
      height: 100%;
      background: linear-gradient(90deg, var(--gold), #e8c86a);
      border-radius: 2px;
      width: 0%;
      transition: width 0.8s linear;
    }
    .loader-timer {
      font-size: 0.7rem;
      color: var(--text-dim);
      text-align: center;
      margin: 6px 0 18px;
      letter-spacing: 1px;
      opacity: 0.7;
    }
    .loader-chips {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 6px;
      max-width: 420px;
      margin: 0 auto;
    }
    .loader-chip {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 0.76rem;
      padding: 7px 11px;
      border-radius: 7px;
      background: rgba(255,255,255,0.02);
      border: 1px solid rgba(255,255,255,0.05);
      color: var(--text-dim);
      transition: color 0.4s, border-color 0.4s, background 0.4s;
    }
    .loader-chip.loading {
      color: var(--gold);
      border-color: rgba(201,168,76,0.25);
      background: rgba(201,168,76,0.05);
    }
    .loader-chip.done {
      color: #1E9458;
      border-color: rgba(30,148,88,0.25);
      background: rgba(30,148,88,0.05);
    }
    .chip-status {
      width: 10px;
      height: 10px;
      flex-shrink: 0;
      position: relative;
    }
    .chip-spinner {
      width: 10px;
      height: 10px;
      border: 1.5px solid rgba(201,168,76,0.2);
      border-top-color: var(--gold);
      border-radius: 50%;
      animation: spin 0.8s linear infinite;
      position: absolute;
      top: 0; left: 0;
    }
    .loader-chip.done .chip-spinner { display: none; }
    .chip-check {
      display: none;
      width: 10px;
      height: 10px;
      background: #1E9458;
      border-radius: 50%;
      position: absolute;
      top: 0; left: 0;
    }
    .loader-chip.done .chip-check { display: block; }
    .loader-chip.idle .chip-spinner { border-top-color: rgba(255,255,255,0.15); animation: none; }

    /* ── RESULTS ── */
    #wyniki { display: none; }

    .verdict-banner {
      padding: 40px 48px;
      margin-bottom: 40px;
      display: flex;
      align-items: center;
      gap: 32px;
      position: relative;
      overflow: hidden;
    }
    .verdict-banner::before {
      content: '';
      position: absolute;
      inset: 0;
      opacity: 0.07;
      background: currentColor;
    }
    .verdict-banner.danger {
      border: 1px solid rgba(192,57,43,0.4);
      color: #E74C3C;
    }
    .verdict-banner.warn {
      border: 1px solid rgba(212,160,23,0.4);
      color: #F39C12;
    }
    .verdict-banner.ok {
      border: 1px solid rgba(26,122,74,0.4);
      color: #2ECC71;
    }

    .verdict-icon {
      font-size: 3rem;
      flex-shrink: 0;
    }
    .verdict-content { flex: 1; }
    .verdict-label {
      font-size: 0.7rem;
      letter-spacing: 3px;
      text-transform: uppercase;
      opacity: 0.7;
      margin-bottom: 8px;
    }
    .verdict-summary {
      font-family: 'Playfair Display', serif;
      font-size: 1.6rem;
      font-weight: 600;
      color: var(--text);
      line-height: 1.3;
      margin-bottom: 12px;
    }
    .verdict-counts {
      display: flex;
      gap: 24px;
      font-size: 0.8rem;
      font-weight: 600;
      letter-spacing: 1px;
    }
    .count-red { color: #E74C3C; }
    .count-yellow { color: #F39C12; }

    .results-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      margin-bottom: 40px;
    }

    .info-card {
      background: var(--dark3);
      border: 1px solid rgba(201,168,76,0.1);
      padding: 32px;
    }

    /* 2026-05-06: kafelki NMT (Klimat, Kubatura, Ekspozycja, Profile) wyciągnięte
       z info-card "Dane działki" (lewa kolumna była długa, prawa pusta) do osobnego
       2-kolumnowego grida POD info-cards. Hover: lekkie podnoszenie + cień + złota ramka. */
    .nmt-tiles-grid .nmt-tile {
      transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
      cursor: default;
    }
    .nmt-tiles-grid .nmt-tile:hover {
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(184, 137, 42, 0.18);
      border-color: rgba(184, 137, 42, 0.45);
    }
    @media (max-width: 768px) {
      .nmt-tiles-grid { grid-template-columns: 1fr !important; }
    }
    .info-card-title {
      font-size: 0.7rem;
      color: var(--gold);
      letter-spacing: 3px;
      text-transform: uppercase;
      font-weight: 600;
      margin-bottom: 20px;
      padding-bottom: 16px;
      border-bottom: 1px solid rgba(201,168,76,0.1);
    }
    .info-row {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      padding: 8px 0;
      border-bottom: 1px solid rgba(255,255,255,0.03);
      gap: 16px;
      flex-wrap: wrap; /* 2026-05-04: zawijanie label/val na wąskich kartach (GZWP "Zbiornik Gliwice | głębokość 20-200m") */
    }
    .info-row:last-child { border-bottom: none; }
    .info-key {
      font-size: 0.75rem;
      color: var(--text-dim);
      font-weight: 500;
      flex-shrink: 0;
      max-width: 50%;
    }
    .info-val {
      font-size: 0.85rem;
      color: var(--text);
      text-align: right;
      font-weight: 500;
      min-width: 0; /* 2026-05-04: pozwala flex child zawinąć tekst */
      word-break: break-word;
      overflow-wrap: break-word;
      flex: 1;
    }

    /* ── SECTION HEADERS IN RESULTS ── */
    .results-section-header {
      font-family: 'Playfair Display', serif;
      font-size: 1.2rem;
      color: var(--text);
      margin: 32px 0 16px;
      padding-bottom: 12px;
      border-bottom: 1px solid rgba(201,168,76,0.15);
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .results-section-header .rsh-num {
      font-family: 'DM Sans', sans-serif;
      font-size: 0.68rem;
      font-weight: 700;
      letter-spacing: .12em;
      color: var(--gold);
      opacity: 0.7;
      text-transform: uppercase;
    }

    /* ── ISSUES ── */
    .issues-section-title {
      font-family: 'Playfair Display', serif;
      font-size: 1.4rem;
      color: var(--text);
      margin-bottom: 20px;
      padding-bottom: 16px;
      border-bottom: 1px solid rgba(201,168,76,0.12);
    }

    .issue-card {
      background: var(--dark3);
      border: 1px solid var(--dark4);
      border-left: 5px solid transparent;
      border-radius: 10px;
      margin-bottom: 14px;
      overflow: hidden;
      box-shadow: 0 1px 6px rgba(0,0,0,0.06);
      transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
      animation: issueEnter 0.4s cubic-bezier(.22,.68,0,1.1) backwards;
    }
    .issue-card:hover {
      transform: translateX(4px);
      box-shadow: 0 4px 20px rgba(0,0,0,0.12);
    }
    .issue-card.red  { border-left-color: rgba(192,57,43,0.85); background: rgba(231,76,60,0.07); }
    .issue-card.yellow { border-left-color: rgba(212,160,23,0.9); background: rgba(243,156,18,0.07); }
    .issue-card.green  { border-left-color: rgba(26,122,74,0.7);  background: rgba(46,204,113,0.07); }
    @keyframes issueEnter {
      from { opacity: 0; transform: translateX(-8px); }
      to   { opacity: 1; transform: translateX(0); }
    }
    .issue-card:nth-child(1) { animation-delay: 0.05s; }
    .issue-card:nth-child(2) { animation-delay: 0.10s; }
    .issue-card:nth-child(3) { animation-delay: 0.15s; }
    .issue-card:nth-child(4) { animation-delay: 0.20s; }
    .issue-card:nth-child(5) { animation-delay: 0.25s; }
    .issue-card:nth-child(6) { animation-delay: 0.30s; }
    .issue-card:nth-child(7) { animation-delay: 0.35s; }
    .issue-card:nth-child(8) { animation-delay: 0.40s; }

    .issue-top {
      padding: 20px 28px 16px;
      display: flex;
      align-items: flex-start;
      gap: 16px;
    }
    .issue-icon {
      font-size: 1.5rem;
      flex-shrink: 0;
      margin-top: 2px;
    }
    .issue-badge {
      display: inline-block;
      font-size: 0.6rem;
      font-weight: 700;
      letter-spacing: 2px;
      text-transform: uppercase;
      padding: 3px 10px;
      margin-bottom: 6px;
    }
    .issue-badge.red    { background: rgba(231,76,60,0.15);   color: #E74C3C; }
    .issue-badge.yellow { background: rgba(243,156,18,0.15);  color: #F39C12; }
    .issue-badge.green  { background: rgba(46,204,113,0.12);  color: #2ECC71; }

    .issue-title {
      font-family: 'Playfair Display', serif;
      font-size: 1.15rem;
      color: var(--text);
      font-weight: 600;
      line-height: 1.3;
      margin-bottom: 6px;
    }
    .issue-detail {
      font-size: 0.88rem;
      color: var(--text-dim);
      line-height: 1.75;
    }
    .issue-steps-toggle {
      display: flex;
      align-items: center;
      gap: 8px;
      cursor: pointer;
      border-top: 1px solid rgba(184,137,42,0.12);
      padding: 10px 28px;
      font-size: 0.78rem;
      color: var(--gold);
      font-weight: 600;
      letter-spacing: 0.5px;
      user-select: none;
      background: none;
      transition: background 0.15s;
    }
    .issue-steps-toggle:hover { background: rgba(184,137,42,0.06); }
    .issue-steps-toggle .toggle-arrow {
      font-size: 0.65rem;
      transition: transform 0.2s;
    }
    .issue-steps-toggle.open .toggle-arrow { transform: rotate(180deg); }
    .issue-steps {
      background: rgba(184,137,42,0.05);
      border-top: 1px solid rgba(184,137,42,0.08);
      padding: 14px 28px 16px 28px;
      display: none;
    }
    .issue-steps.visible { display: block; }
    .issue-steps-label {
      font-size: 0.65rem;
      color: var(--gold);
      letter-spacing: 2px;
      text-transform: uppercase;
      font-weight: 700;
      margin-bottom: 10px;
    }
    .issue-step {
      display: flex;
      gap: 12px;
      margin-bottom: 8px;
      font-size: 0.85rem;
      color: var(--text);
      line-height: 1.6;
      align-items: flex-start;
    }
    .issue-step:last-child { margin-bottom: 0; }
    .issue-step .step-num {
      background: rgba(201,168,76,0.15);
      color: var(--gold);
      font-size: 0.65rem;
      font-weight: 700;
      min-width: 20px;
      width: 20px;
      height: 20px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      margin-top: 2px;
    }

    .uldk-manual-note {
      background: rgba(26,122,74,0.08);
      border: 1px solid rgba(46,204,113,0.2);
      padding: 16px 24px;
      margin-bottom: 32px;
      font-size: 0.85rem;
      color: #2ECC71;
      display: flex;
      gap: 12px;
      align-items: center;
    }

    /* ── REKOMENDACJA ── */
    .rekomendacja-card {
      background: linear-gradient(135deg, rgba(201,168,76,0.08) 0%, rgba(201,168,76,0.02) 100%);
      border: 1px solid rgba(201,168,76,0.25);
      padding: 40px 48px;
      margin-bottom: 40px;
      position: relative;
    }
    .rekomendacja-card::before {
      content: '"';
      font-family: 'Playfair Display', serif;
      font-size: 8rem;
      color: var(--gold);
      opacity: 0.12;
      position: absolute;
      top: -20px;
      left: 24px;
      line-height: 1;
    }
    .rekomendacja-label {
      font-size: 0.7rem;
      color: var(--gold);
      letter-spacing: 3px;
      text-transform: uppercase;
      font-weight: 600;
      margin-bottom: 16px;
    }
    .rekomendacja-text {
      font-family: 'Playfair Display', serif;
      font-size: 1.15rem;
      color: var(--text);
      line-height: 1.8;
      font-style: italic;
    }

    .ocena-ceny {
      background: linear-gradient(135deg, #1e1506 0%, #2a1c08 100%);
      border: 2px solid rgba(201,168,76,0.35);
      border-radius: 14px;
      padding: 28px 32px;
      margin-bottom: 40px;
      display: flex;
      align-items: flex-start;
      gap: 20px;
      box-shadow: 0 4px 24px rgba(184,137,42,0.1);
    }
    .ocena-icon { font-size: 2rem; flex-shrink: 0; margin-top: 2px; }
    .ocena-label {
      font-size: 0.68rem;
      color: var(--gold);
      letter-spacing: 2px;
      text-transform: uppercase;
      margin-bottom: 6px;
      opacity: 0.8;
    }
    .ocena-ceny .ocena-value-highlight {
      font-size: 1.55rem;
      font-weight: 800;
      color: var(--gold);
      font-family: 'Playfair Display', serif;
      line-height: 1.2;
      margin-bottom: 6px;
    }
    .ocena-ceny .ocena-value-note {
      font-size: 0.7rem;
      color: rgba(255,255,255,0.4);
      margin-bottom: 10px;
      letter-spacing: 0.3px;
    }
    .ocena-text { font-size: 0.95rem; color: var(--text-dim); line-height: 1.6; }

    .new-search-btn {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      border: 1px solid rgba(201,168,76,0.4);
      color: var(--gold);
      background: transparent;
      font-family: 'Raleway', sans-serif;
      font-size: 0.8rem;
      font-weight: 600;
      letter-spacing: 2px;
      text-transform: uppercase;
      padding: 16px 32px;
      cursor: pointer;
      transition: background .3s, color .3s;
    }
    /* ── CHECKLIST "CO JEST PRZY DZIAŁCE" ── */
    .checklist-section {
      background: var(--dark3);
      border: 1px solid rgba(201,168,76,0.12);
      border-radius: 12px;
      padding: 24px 28px;
      margin-bottom: 24px;
    }
    .checklist-section-title {
      font-family: 'Playfair Display', serif;
      font-size: 1rem;
      color: var(--gold);
      margin-bottom: 20px;
      letter-spacing: 0.5px;
    }
    /* Wiersze 40-punktowej checklisty */
    .cl-row { padding:8px 12px; border-bottom:1px dotted rgba(0,0,0,0.06); transition: background 0.15s; cursor: default; }
    .cl-row:hover { background: rgba(184,137,42,0.07) !important; }
    .cl-row:last-child { border-bottom: none; }
    .cl-row-desc { font-size:0.78rem; color:#555; margin-top:4px; line-height:1.5; display:none; }
    .cl-row:hover .cl-row-desc { display:block; }

    /* Kategorie — grupy w checkliście */
    .cl-group { margin-bottom: 20px; }
    .cl-group:last-child { margin-bottom: 0; }
    .cl-group-hdr {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 0.65rem;
      font-weight: 700;
      letter-spacing: 1.8px;
      text-transform: uppercase;
      color: var(--text-dim);
      padding-bottom: 8px;
      border-bottom: 1px solid rgba(255,255,255,0.06);
      margin-bottom: 10px;
    }
    .cl-group-hdr span { opacity: 0.5; }
    .checklist-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 8px;
    }
    .checklist-item {
      display: flex;
      align-items: flex-start;
      gap: 9px;
      padding: 10px 12px;
      border-radius: 8px;
      border: 1px solid rgba(255,255,255,0.07);
      background: rgba(255,255,255,0.025);
      transition: box-shadow .2s;
    }
    .checklist-item:hover { box-shadow: 0 2px 10px rgba(0,0,0,0.15); }
    .checklist-item.cl-ok     { background: rgba(46,204,113,0.07);  border-color: rgba(46,204,113,0.22); }
    .checklist-item.cl-warn   { background: rgba(243,156,18,0.07);  border-color: rgba(243,156,18,0.22); }
    .checklist-item.cl-danger { background: rgba(231,76,60,0.09);   border-color: rgba(231,76,60,0.28); }
    .checklist-item.cl-unknown{ background: rgba(255,255,255,0.02); border-color: rgba(255,255,255,0.07); }
    .checklist-ico { font-size: 1rem; flex-shrink: 0; margin-top: 1px; line-height: 1; }
    .checklist-lbl {
      font-size: 0.78rem;
      font-weight: 700;
      color: var(--text);
      margin-bottom: 3px;
      line-height: 1.2;
    }
    .checklist-item.cl-ok     .checklist-lbl { color: #27AE60; }
    .checklist-item.cl-warn   .checklist-lbl { color: #D68910; }
    .checklist-item.cl-danger .checklist-lbl { color: #C0392B; }
    .checklist-item.cl-unknown .checklist-lbl{ color: var(--text-dim); }
    .checklist-val {
      font-size: 0.75rem;
      color: var(--text-dim);
      line-height: 1.45;
    }
    .permit-difficulty {
      padding: 14px 16px;
      background: var(--dark4);
      border-radius: 8px;
      display: flex;
      align-items: center;
      gap: 16px;
      margin-top: 16px;
    }
    .permit-difficulty-label { font-size: 0.65rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.8px; margin-bottom: 5px; }
    .permit-difficulty-text  { font-weight: 700; font-size: 0.9rem; margin-bottom: 6px; }
    .permit-bar-track  { height: 5px; background: rgba(255,255,255,0.07); border-radius: 3px; overflow: hidden; }
    .permit-bar-fill   { height: 100%; border-radius: 3px; transition: width 1.2s ease; }
    @media(max-width:768px){ .checklist-grid { grid-template-columns: 1fr 1fr; } }
    @media(max-width:480px){ .checklist-grid { grid-template-columns: 1fr; } }

    /* ── WZ SZANSE ── */
    .wz-szanse-wrap { margin-top:14px; padding:14px 16px; background:#1a1a1a; border:1px solid rgba(255,255,255,.08); border-radius:10px; }
    .wz-szanse-hdr  { display:flex; align-items:center; gap:8px; margin-bottom:12px; }
    .wz-szanse-title { font-size:.82rem; color:#ccc; font-weight:700; flex:1; }
    .wz-src-badge   { font-size:.68rem; padding:2px 7px; border-radius:4px; font-weight:700; flex-shrink:0; }
    .mpzp-badge     { background:#C9A84C; color:#1a1400; }
    .wz-badge       { background:#3A6BC4; color:#fff; }
    .wz-info-icon   { width:18px; height:18px; background:rgba(201,168,76,.12); border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:.65rem; color:#C9A84C; cursor:pointer; border:1px solid rgba(201,168,76,.25); flex-shrink:0; position:relative; user-select:none; }
    .wz-tip-popup   { display:none; position:absolute; bottom:calc(100% + 8px); right:-4px; background:#222; border:1px solid rgba(201,168,76,.25); border-radius:8px; padding:10px 12px; font-size:.74rem; color:#bbb; white-space:pre-wrap; width:260px; z-index:300; line-height:1.6; box-shadow:0 4px 24px rgba(0,0,0,.6); pointer-events:none; }
    .wz-info-icon.tip-open .wz-tip-popup { display:block; }
    .wz-bar-row     { margin-bottom:10px; }
    .wz-bar-labels  { display:flex; justify-content:space-between; align-items:center; margin-bottom:4px; }
    .wz-bar-lbl     { font-size:.8rem; color:#ccc; }
    .wz-bar-pct     { font-size:.76rem; font-weight:700; }
    .wz-bar-track   { height:6px; background:rgba(255,255,255,.07); border-radius:3px; overflow:hidden; }
    .wz-bar-fill    { height:100%; border-radius:3px; transition:width 1.3s ease; width:0%; }
    .wz-szanse-foot { font-size:.7rem; color:#666; margin-top:10px; line-height:1.5; }
    .wz-mpzp-row    { display:flex; align-items:center; gap:10px; padding:5px 0; border-bottom:1px solid rgba(255,255,255,.05); }
    .wz-mpzp-row:last-child { border-bottom:none; }

    /* ── ULDK RETRY SCREEN ── */
    .uldk-retry-screen {
      text-align: center;
      padding: 48px 32px;
      background: var(--dark3);
      border: 1px solid rgba(201,168,76,0.15);
      border-radius: 12px;
      max-width: 560px;
      margin: 0 auto;
    }
    .uldk-retry-icon { font-size: 2.8rem; margin-bottom: 16px; }
    .uldk-retry-screen h3 { font-family: 'Playfair Display', serif; font-size: 1.2rem; color: var(--gold); margin-bottom: 12px; }
    .uldk-retry-screen p { font-size: 0.88rem; color: var(--text-dim); line-height: 1.7; margin-bottom: 18px; }
    .uldk-retry-status { font-size: 0.82rem; color: var(--text-dim); margin-bottom: 10px; min-height: 1.4em; }
    .uldk-retry-progress { height: 4px; background: rgba(255,255,255,0.07); border-radius: 2px; overflow: hidden; margin-bottom: 20px; }
    .uldk-retry-bar { height: 100%; background: var(--gold); border-radius: 2px; transition: width 1s linear; width: 0%; }
    .uldk-retry-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
    .uldk-retry-btn-manual { padding: 10px 20px; border: 1px solid var(--gold); background: transparent; color: var(--gold); border-radius: 6px; cursor: pointer; font-size: 0.88rem; transition: background .2s; }
    .uldk-retry-btn-manual:hover { background: rgba(201,168,76,0.15); }
    .uldk-retry-btn-gps { padding: 10px 20px; background: var(--gold); color: #000; border: none; border-radius: 6px; cursor: pointer; font-size: 0.88rem; font-weight: 700; }

    .new-search-btn:hover {
      background: var(--gold);
      color: #000;
    }

    /* ── CZAT ── */
    .chat-widget {
      margin-top: 40px;
      border: 1px solid rgba(201,168,76,0.3);
      border-radius: 16px;
      overflow: hidden;
      background: rgba(201,168,76,0.04);
    }
    .chat-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 16px 20px;
      border-bottom: 1px solid rgba(201,168,76,0.15);
      background: rgba(201,168,76,0.07);
    }
    .chat-title { font-weight: 700; font-size: 1rem; color: var(--gold); }
    .chat-limit-badge {
      font-size: 0.75rem;
      background: rgba(201,168,76,0.15);
      color: var(--gold);
      border-radius: 20px;
      padding: 3px 10px;
      border: 1px solid rgba(201,168,76,0.3);
    }
    .chat-info {
      padding: 12px 20px;
      font-size: 0.82rem;
      color: var(--text-dim);
      border-bottom: 1px solid rgba(201,168,76,0.08);
    }
    .chat-messages {
      padding: 16px 20px;
      min-height: 40px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
    .chat-msg { display: flex; flex-direction: column; gap: 4px; }
    .chat-msg-user { align-items: flex-end; }
    .chat-msg-ai { align-items: flex-start; }
    .chat-bubble {
      max-width: 85%;
      padding: 10px 14px;
      border-radius: 12px;
      font-size: 0.88rem;
      line-height: 1.55;
      white-space: pre-wrap;
    }
    .chat-bubble-user {
      background: rgba(201,168,76,0.18);
      color: var(--text);
      border-radius: 12px 12px 2px 12px;
    }
    .chat-bubble-ai {
      background: rgba(255,255,255,0.06);
      color: var(--text);
      border: 1px solid rgba(201,168,76,0.1);
      border-radius: 12px 12px 12px 2px;
    }
    .chat-role { font-size: 0.72rem; color: var(--text-dim); margin-bottom: 2px; }
    .chat-input-row {
      display: flex;
      gap: 10px;
      padding: 14px 20px;
      border-top: 1px solid rgba(201,168,76,0.1);
      align-items: flex-end;
    }
    .chat-input {
      flex: 1;
      background: rgba(255,255,255,0.06);
      border: 1px solid rgba(201,168,76,0.25);
      border-radius: 10px;
      color: var(--text);
      padding: 10px 14px;
      font-size: 0.88rem;
      resize: none;
      font-family: inherit;
      line-height: 1.5;
    }
    .chat-input:focus { outline: none; border-color: var(--gold); }
    .chat-input::placeholder { color: #6B6560; }
    .chat-send-btn {
      background: var(--gold);
      color: #000;
      border: none;
      border-radius: 10px;
      padding: 10px 20px;
      font-weight: 700;
      cursor: pointer;
      font-size: 0.88rem;
      white-space: nowrap;
    }
    .chat-send-btn:disabled { opacity: 0.4; cursor: default; }
    .chat-counter {
      text-align: center;
      padding: 8px;
      font-size: 0.78rem;
      color: var(--text-dim);
      border-top: 1px solid rgba(201,168,76,0.08);
    }
    .chat-done {
      text-align: center;
      padding: 16px 20px;
      font-size: 0.85rem;
      color: var(--text-dim);
      border-top: 1px solid rgba(201,168,76,0.1);
    }
    .chat-thinking { color: var(--gold); font-size: 0.82rem; animation: pulse 1.2s infinite; }

    /* ── ODMOWA WZ ── */
    .odmowa-widget {
      margin-top: 24px;
      border: 1px solid rgba(231,76,60,0.3);
      border-radius: 16px;
      overflow: hidden;
      background: rgba(231,76,60,0.03);
    }
    .odmowa-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 14px 20px;
      cursor: pointer;
      font-weight: 600;
      font-size: 0.92rem;
      color: #E74C3C;
      background: rgba(231,76,60,0.07);
      user-select: none;
      transition: background 0.15s;
    }
    .odmowa-header:hover { background: rgba(231,76,60,0.12); }
    .odmowa-toggle-arrow { font-size: 0.7rem; transition: transform 0.2s; }
    .odmowa-body { padding: 16px 20px 20px; }
    .odmowa-info {
      font-size: 0.82rem;
      color: var(--text-dim);
      margin-bottom: 12px;
      line-height: 1.6;
    }
    .odmowa-textarea {
      width: 100%;
      min-height: 120px;
      background: rgba(255,255,255,0.05);
      border: 1px solid rgba(231,76,60,0.25);
      border-radius: 10px;
      color: var(--text);
      padding: 12px 14px;
      font-size: 0.85rem;
      resize: vertical;
      font-family: inherit;
      line-height: 1.5;
      box-sizing: border-box;
    }
    .odmowa-textarea:focus { outline: none; border-color: #E74C3C; }
    .odmowa-btn {
      margin-top: 10px;
      background: #E74C3C;
      color: #fff;
      border: none;
      border-radius: 10px;
      padding: 10px 22px;
      font-weight: 700;
      cursor: pointer;
      font-size: 0.88rem;
    }
    .odmowa-btn:disabled { opacity: 0.45; cursor: default; }
    .odmowa-result {
      margin-top: 18px;
      border-top: 1px solid rgba(231,76,60,0.15);
      padding-top: 16px;
    }
    .odmowa-section-title {
      font-size: 0.65rem;
      text-transform: uppercase;
      letter-spacing: 2px;
      color: #E74C3C;
      font-weight: 700;
      margin: 14px 0 6px;
    }
    .odmowa-szanse-badge {
      display: inline-block;
      padding: 3px 12px;
      border-radius: 20px;
      font-size: 0.78rem;
      font-weight: 700;
    }
    .odmowa-szanse-wysokie { background: rgba(46,204,113,0.15); color: #2ECC71; border: 1px solid rgba(46,204,113,0.3); }
    .odmowa-szanse-srednie { background: rgba(241,196,15,0.12); color: #F1C40F; border: 1px solid rgba(241,196,15,0.25); }
    .odmowa-szanse-niskie  { background: rgba(231,76,60,0.12); color: #E74C3C; border: 1px solid rgba(231,76,60,0.25); }
    .odmowa-krok {
      display: flex;
      gap: 12px;
      margin-bottom: 8px;
      font-size: 0.85rem;
      color: var(--text);
      line-height: 1.6;
      align-items: flex-start;
    }
    .odmowa-krok-num {
      background: rgba(231,76,60,0.15);
      color: #E74C3C;
      font-size: 0.65rem;
      font-weight: 700;
      min-width: 20px;
      height: 20px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 4px;
      flex-shrink: 0;
      margin-top: 2px;
    }
    @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }

    /* ── TARGOWANIE ── */
    .targowanie-section {
      background: linear-gradient(135deg, rgba(27,94,32,0.06) 0%, rgba(27,94,32,0.02) 100%);
      border: 1.5px solid rgba(46,125,50,0.25);
      border-radius: 16px;
      padding: 22px 24px;
      margin-bottom: 18px;
    }
    .targowanie-header {
      display: flex;
      align-items: center;
      gap: 12px;
      margin-bottom: 16px;
    }
    .targowanie-title {
      font-size: 0.82rem;
      text-transform: uppercase;
      letter-spacing: .08em;
      font-weight: 700;
      color: #2e7d32;
    }
    .targowanie-subtitle {
      font-size: 0.78rem;
      color: #6B6560;
      margin-top: 2px;
    }
    .targowanie-card {
      background: rgba(255,255,255,0.7);
      border: 1px solid rgba(46,125,50,0.18);
      border-radius: 10px;
      padding: 12px 16px;
      margin-bottom: 10px;
      display: flex;
      gap: 14px;
      align-items: flex-start;
    }
    .targowanie-waga-dot {
      width: 10px; height: 10px;
      border-radius: 50%;
      margin-top: 5px;
      flex-shrink: 0;
    }
    .targ-waga-wysoka { background: #E74C3C; }
    .targ-waga-srednia { background: #F39C12; }
    .targ-waga-niska { background: #95a5a6; }
    .targowanie-problem {
      font-size: 0.72rem;
      text-transform: uppercase;
      letter-spacing: .05em;
      color: #6B6560;
      margin-bottom: 3px;
    }
    .targowanie-argument {
      font-size: 0.88rem;
      color: #1A1A1A;
      line-height: 1.5;
      font-style: italic;
    }
    .targowanie-koszt {
      font-size: 0.78rem;
      color: #E74C3C;
      font-weight: 600;
      margin-top: 4px;
    }
    .targowanie-suma {
      margin-top: 14px;
      padding: 12px 16px;
      background: rgba(46,125,50,0.08);
      border: 1px solid rgba(46,125,50,0.2);
      border-radius: 8px;
      font-size: 0.88rem;
      color: #2e7d32;
      font-weight: 700;
    }

    /* ── HOW IT WORKS ── */
    #jak-to-dziala { background: var(--dark); }

    .steps-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 40px;
      margin-top: 64px;
      max-width: 1000px;
      margin-left: auto;
      margin-right: auto;
    }
    .step-card {
      padding: 40px 32px;
      background: var(--dark3);
      border: 1px solid rgba(201,168,76,0.08);
      position: relative;
      transition: border-color .3s;
    }
    .step-card:hover { border-color: rgba(201,168,76,0.3); }
    .step-card .step-num {
      font-family: 'Playfair Display', serif;
      font-size: 4rem;
      color: rgba(201,168,76,0.1);
      line-height: 1;
      margin-bottom: 24px;
      font-weight: 700;
    }
    .step-title {
      font-family: 'Playfair Display', serif;
      font-size: 1.2rem;
      color: var(--text);
      font-weight: 600;
      margin-bottom: 12px;
    }
    .step-desc {
      font-size: 0.875rem;
      color: var(--text-dim);
      line-height: 1.8;
    }

    /* ── FOOTER ── */
    footer {
      background: var(--dark2);
      border-top: 1px solid rgba(201,168,76,0.1);
      padding: 48px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .footer-logo {
      font-family: 'Playfair Display', serif;
      font-size: 1.2rem;
      color: var(--gold);
      letter-spacing: 2px;
      text-transform: uppercase;
    }
    .footer-copy {
      font-size: 0.75rem;
      color: var(--text-dim);
    }
    .footer-line {
      width: 60px;
      height: 1px;
      background: linear-gradient(to right, var(--gold), transparent);
    }

    /* ── DIVIDER ── */
    .gold-divider {
      width: 48px;
      height: 2px;
      background: linear-gradient(to right, var(--gold), var(--gold-light));
      margin: 24px 0;
    }

    /* ── MODAL ── */
    .modal-overlay {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.75);
      z-index: 999;
      align-items: center;
      justify-content: center;
      padding: 24px;
    }
    .modal-overlay.open { display: flex; }
    .modal-box {
      background: var(--dark3);
      border: 1px solid rgba(201,168,76,0.25);
      max-width: 480px;
      width: 100%;
      padding: 40px;
      position: relative;
      animation: modalIn .25s ease;
    }
    @keyframes modalIn { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:none; } }
    @keyframes histOverlayIn  { from { opacity:0; } to { opacity:1; } }
    @keyframes histOverlayOut { from { opacity:1; } to { opacity:0; } }
    @keyframes histPanelIn    { from { opacity:0; transform:translateY(-28px) scale(.97); } to { opacity:1; transform:translateY(0) scale(1); } }
    @keyframes histPanelOut   { from { opacity:1; transform:translateY(0) scale(1); } to { opacity:0; transform:translateY(-20px) scale(.97); } }
    #historyModal.hist-open   { animation: histOverlayIn  .25s ease forwards; }
    #historyModal.hist-close  { animation: histOverlayOut .2s  ease forwards; }
    #historyModal.hist-open  > div { animation: histPanelIn  .28s cubic-bezier(.22,.9,.36,1) forwards; }
    #historyModal.hist-close > div { animation: histPanelOut .18s ease          forwards; }
    .modal-close {
      position: absolute;
      top: 16px; right: 20px;
      background: none;
      border: none;
      color: var(--text-dim);
      font-size: 1.4rem;
      cursor: pointer;
      line-height: 1;
    }
    .modal-close:hover { color: var(--gold); }
    .modal-ring-header {
      display: flex;
      align-items: center;
      gap: 20px;
      margin-bottom: 24px;
      padding-bottom: 20px;
      border-bottom: 1px solid rgba(201,168,76,0.12);
    }
    .modal-ring-mini {
      width: 64px; height: 64px; flex-shrink: 0; position: relative;
    }
    .modal-ring-mini svg { transform: rotate(-90deg); }
    .modal-ring-mini .mini-val {
      position: absolute; inset: 0;
      display: flex; align-items: center; justify-content: center;
      font-family: 'Playfair Display', serif;
      font-size: 1rem; font-weight: 700;
    }
    .modal-title {
      font-family: 'Playfair Display', serif;
      font-size: 1.2rem; color: #fff; font-weight: 600;
    }
    .modal-subtitle { font-size: 0.75rem; color: var(--text-dim); margin-top: 4px; }
    .modal-body { font-size: 0.9rem; color: var(--text-dim); line-height: 1.8; }
    .modal-body p { margin-bottom: 12px; }
    .modal-body strong { color: var(--text); }
    .modal-action {
      margin-top: 20px;
      padding: 14px 20px;
      background: rgba(201,168,76,0.08);
      border-left: 2px solid var(--gold);
      font-size: 0.85rem;
      color: var(--text-dim);
      line-height: 1.6;
    }
    .modal-action strong { color: var(--gold); display: block; margin-bottom: 4px; font-size: 0.75rem; letter-spacing: 1px; text-transform: uppercase; }
    .risk-circle { cursor: pointer; }
    .risk-circle:hover .ring-label { color: var(--gold); }

    /* ── ERROR ── */
    .error-box {
      background: rgba(192,57,43,0.1);
      border: 1px solid rgba(192,57,43,0.3);
      padding: 24px 32px;
      color: #E74C3C;
      font-size: 0.9rem;
    }

    /* ── RISK RINGS ── */
    .risk-circles-section { margin: 40px 0 48px; }
    .risk-circles-title {
      font-size: 0.7rem;
      color: var(--gold);
      letter-spacing: 3px;
      text-transform: uppercase;
      font-weight: 600;
      margin-bottom: 32px;
      text-align: center;
    }
    .risk-circles {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 16px;
    }
    .risk-circle {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 10px;
      padding: 24px 12px;
      background: var(--dark3);
      border: 1px solid rgba(201,168,76,0.08);
      transition: border-color .3s;
    }
    .risk-circle:hover { border-color: rgba(201,168,76,0.25); }
    .ring-wrap {
      position: relative;
      width: 88px;
      height: 88px;
    }
    .ring-svg {
      width: 88px;
      height: 88px;
      transform: rotate(-90deg);
    }
    .ring-bg { fill: none; stroke: rgba(255,255,255,0.06); stroke-width: 7; }
    .ring-fill {
      fill: none;
      stroke-width: 7;
      stroke-linecap: round;
      transition: stroke-dashoffset 1.4s cubic-bezier(0.4,0,0.2,1);
    }
    .ring-value {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: 'Playfair Display', serif;
      font-size: 1.2rem;
      font-weight: 700;
      color: #fff;
    }
    .ring-label {
      font-size: 0.68rem;
      color: var(--text);
      letter-spacing: 1px;
      text-transform: uppercase;
      text-align: center;
      font-weight: 600;
      line-height: 1.4;
    }
    .ring-desc {
      font-size: 0.7rem;
      color: var(--text-dim);
      text-align: center;
      line-height: 1.5;
    }
    .ring-source {
      font-size: 0.58rem;
      font-weight: 700;
      letter-spacing: 0.8px;
      text-transform: uppercase;
      padding: 2px 7px;
      text-align: center;
      margin-top: 2px;
    }
    .ring-source.verified { color: #2ECC71; }
    .ring-source.partial  { color: #F39C12; }
    .ring-source.estimate { color: var(--text-dim); }

    .data-legend {
      display: flex;
      justify-content: center;
      gap: 20px;
      margin-top: 20px;
      flex-wrap: wrap;
    }
    .legend-item {
      display: flex;
      align-items: center;
      gap: 6px;
      font-size: 0.68rem;
      color: var(--text-dim);
      letter-spacing: 0.5px;
    }
    .legend-dot {
      width: 7px; height: 7px;
      border-radius: 50%;
      flex-shrink: 0;
    }

    .info-source-tag {
      display: inline-block;
      font-size: 0.58rem;
      font-weight: 700;
      letter-spacing: 0.8px;
      text-transform: uppercase;
      padding: 1px 5px;
      margin-left: 6px;
      vertical-align: middle;
      border-radius: 2px;
    }
    .info-source-tag.verified { color: #2ECC71; background: rgba(46,204,113,0.1); }
    .info-source-tag.estimate { color: #8A8070; background: rgba(138,128,112,0.1); }
    .info-source-tag.partial  { color: #F39C12; background: rgba(243,156,18,0.08); }

    /* ── MAPA ── */
    /* Leaflet controls domyślnie mają z-index:1000 — obniżamy poniżej fixeda headera */
    .leaflet-top, .leaflet-bottom { z-index: 900 !important; }
    .leaflet-control { z-index: 900 !important; }

    /* Przełącznik warstw — styl Gruntownie (złota paleta) */
    .leaflet-control-layers {
      border: 1px solid #E2C060 !important;
      border-radius: 8px !important;
      background: rgba(255,255,255,.96) !important;
      box-shadow: 0 4px 14px rgba(184,137,42,.18) !important;
      font-size: 12.5px !important;
      font-weight: 500 !important;
    }
    .leaflet-control-layers-expanded {
      padding: 8px 12px !important;
      color: #3a3a3a !important;
    }
    .leaflet-control-layers-base label {
      display: flex !important;
      align-items: center !important;
      gap: 6px !important;
      padding: 4px 0 !important;
      cursor: pointer;
      transition: color .15s ease;
    }
    .leaflet-control-layers-base label:hover {
      color: #8B6914 !important;
    }
    .leaflet-control-layers-base input[type="radio"] {
      accent-color: #8B6914;
      margin: 0 !important;
    }

    /* ── PANEL DETEKCJI (żółte/szare sekcje pod mapą) ── */
    .detection-panel {
      margin-top: 14px;
      background: #FAF9F6;
      border: 1px solid rgba(184,137,42,0.18);
      border-radius: 12px;
      padding: 16px 18px 14px;
    }
    .detection-panel-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 10px;
      flex-wrap: wrap;
    }
    .detection-panel-title {
      font-size: 0.86rem;
      font-weight: 700;
      color: #1A1A1A;
      letter-spacing: 0.01em;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .detection-panel-title::before {
      content: '';
      width: 4px;
      height: 16px;
      background: #8B6914;
      border-radius: 2px;
    }
    .detection-panel-sub {
      font-size: 0.72rem;
      color: #6B6560;
      font-weight: 500;
    }
    .detection-single {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .detection-col-head {
      font-size: 0.74rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      margin-bottom: 4px;
      display: flex;
      align-items: center;
      gap: 6px;
      color: #8B6914;
    }
    /* Sekcje kategorii — nagłówek + chipy */
    .detection-section {
      margin-top: 8px;
      padding-top: 6px;
      border-top: 1px dashed rgba(184,137,42,0.12);
    }
    .detection-section:first-of-type {
      margin-top: 2px;
      padding-top: 0;
      border-top: none;
    }
    .detection-section-head {
      font-size: 0.68rem;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: #8a6a1a;
      margin-bottom: 5px;
      padding-left: 2px;
      opacity: 0.85;
    }
    /* Legenda chipów pod kontenerem */
    .detection-legend {
      display: flex;
      flex-wrap: wrap;
      gap: 10px 18px;
      margin-top: 12px;
      padding: 10px 14px;
      background: rgba(184,137,42,0.04);
      border: 1px dashed rgba(184,137,42,0.2);
      border-radius: 8px;
      font-size: 0.74rem;
      color: #6b5014;
      align-items: flex-start;
      line-height: 1.4;
    }
    .detection-legend-item {
      display: inline-flex;
      align-items: flex-start;
      gap: 7px;
      max-width: 320px;
    }
    .detection-legend-chip {
      display: inline-flex;
      align-items: center;
      gap: 3px;
      padding: 3px 9px;
      border-radius: 14px;
      font-size: 0.72rem;
      font-weight: 600;
      white-space: nowrap;
      flex-shrink: 0;
      margin-top: 1px;
    }
    .legend-found {
      background: rgba(46,204,113,0.10);
      border: 1px solid rgba(46,204,113,0.42);
      color: #1d6d3d;
    }
    .legend-found::before { content: '✓'; color: #27ae60; font-weight: 800; margin-right: 3px; }
    .legend-yellow {
      background: rgba(216,169,46,0.08);
      border: 1px solid rgba(216,169,46,0.40);
      color: #8a6a1e;
    }
    .legend-yellow::before { content: '○'; color: #8B6914; font-weight: 800; margin-right: 3px; }
    .legend-miss {
      background: #F2F2EF;
      border: 1px dashed #C5C5C2;
      color: #9A9A95;
      opacity: 0.7;
    }
    .legend-miss::before { content: '✕'; color: #B5B5B0; font-weight: 700; margin-right: 3px; }
    .detection-legend-text { font-size: 0.72rem; color: #6b5014; }
    .detection-legend-text strong { color: #1d6d3d; }
    .detection-legend-text em { font-style: normal; color: #6B6560; }
    .detection-chips {
      display: flex;
      flex-wrap: wrap;
      gap: 5px;
    }
    .detection-chip {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: 0.74rem;
      padding: 4px 10px;
      border-radius: 16px;
      line-height: 1.25;
      cursor: default;
      transition: transform .12s ease, box-shadow .12s ease;
      white-space: nowrap;
    }
    /* Domyślny stan chipu = ŻÓŁTY z ○ (sprawdzimy w pełnej analizie — jeszcze nie potwierdzono dla tej działki) */
    .detection-chip-yellow {
      background: rgba(216,169,46,0.08);
      border: 1px solid rgba(216,169,46,0.40);
      color: #8a6a1e;
      font-weight: 600;
    }
    .detection-chip-yellow::before {
      content: '○';
      color: #8B6914;
      font-weight: 800;
      font-size: 0.82rem;
    }
    /* Stan ZIELONY z ✓ (potwierdzone dla tej działki — dane dostępne) */
    .detection-chip.detection-chip-found,
    .detection-chip.detection-chip-warn {
      background: rgba(46,204,113,0.10);
      border: 1px solid rgba(46,204,113,0.42);
      color: #1d6d3d;
      font-weight: 600;
    }
    .detection-chip.detection-chip-found::before,
    .detection-chip.detection-chip-warn::before {
      content: '✓';
      color: #27ae60;
      font-weight: 800;
      font-size: 0.82rem;
    }
    .detection-chip:hover {
      transform: translateY(-1px);
      box-shadow: 0 2px 6px rgba(0,0,0,0.07);
    }
    .detection-chip[title] { cursor: help; }
    .detection-panel-foot {
      margin-top: 10px;
      padding-top: 10px;
      border-top: 1px dashed rgba(184,137,42,0.15);
      font-size: 0.7rem;
      color: #6B6560;
      line-height: 1.45;
    }
    .detection-panel-foot strong { color: #8B6914; font-weight: 700; }

    /* ── Chip w trybie "wykryto dla tej działki" (konkretna wartość) ── */
    .detection-chip-detail {
      display: inline-flex;
      align-items: center;
      margin-left: 4px;
      padding: 1px 7px;
      border-radius: 10px;
      font-size: 0.68rem;
      font-weight: 700;
      background: #fff;
      border: 1px solid rgba(184,137,42,0.35);
      color: #8B6914;
      letter-spacing: 0.01em;
    }
    /* Detail badge w zielonym chipie */
    .detection-chip-yellow .detection-chip-detail,
    .detection-chip.detection-chip-found .detection-chip-detail,
    .detection-chip.detection-chip-warn .detection-chip-detail {
      background: rgba(46,204,113,0.14);
      border-color: rgba(46,204,113,0.5);
      color: #1d6d3d;
    }
    .detection-chip.detection-chip-miss {
      background: #F2F2EF;
      border: 1px dashed #C5C5C2;
      color: #9A9A95;
      opacity: 0.7;
      text-decoration: line-through;
      text-decoration-color: rgba(150,150,150,0.5);
    }
    .detection-chip.detection-chip-miss::before { content: '✕'; color: #B5B5B0; font-weight: 700; font-size: 0.78rem; text-decoration: none; }
    .detection-chip.detection-chip-miss .detection-chip-detail {
      background: #fff;
      border-color: rgba(150,150,150,0.3);
      color: #6B6560;
    }

    /* ── MODAL: lista warstw analizy ── */
    .apm-item {
      display: flex;
      align-items: center;
      gap: 7px;
      padding: 5px 0;
      font-size: 0.82rem;
      color: #2C2C2A;
      border-bottom: 1px solid #F0EDE8;
    }
    .apm-item::before {
      content: '✓';
      color: #27ae60;
      font-weight: 700;
      font-size: 0.78rem;
      flex-shrink: 0;
    }
    @media (max-width: 560px) {
      #apm-list { grid-template-columns: 1fr !important; }
    }

    /* ── CUSTOM CHIP TOOLTIP ── */
    #chip-tip {
      position: fixed;
      display: none;
      z-index: 9999;
      max-width: 260px;
      padding: 10px 13px;
      background: #1C1C1B;
      color: #F0EFE9;
      border-radius: 10px;
      box-shadow: 0 4px 20px rgba(0,0,0,0.30);
      pointer-events: none;
      font-size: 12.5px;
      line-height: 1.55;
    }
    #chip-tip strong {
      display: block;
      font-size: 11px;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: #8B6914;
      margin-bottom: 4px;
    }

    /* Granice działek (WMS GUGiK) — drop-shadow dla czytelności na satelicie/ortofoto */
    .parcel-wms-layer {
      filter: drop-shadow(0 0 1px rgba(255,255,255,0.9)) drop-shadow(0 0 1px rgba(0,0,0,0.6));
    }

    /* ── CUSTOM LAYER SWITCHER (OnGeo-style, kompaktowy) ── */
    .custom-layer-switcher {
      position: relative;
      font-family: inherit;
    }
    .custom-layer-switcher .cls-toggle {
      display: flex;
      align-items: center;
      gap: 5px;
      padding: 6px 10px;
      background: #fff;
      border: 1px solid rgba(0,0,0,0.12);
      border-radius: 6px;
      box-shadow: 0 1px 4px rgba(0,0,0,0.16);
      cursor: pointer;
      font-size: 0.74rem;
      font-weight: 600;
      color: #333;
      font-family: inherit;
      line-height: 1;
      transition: background .12s, border-color .12s;
    }
    .custom-layer-switcher .cls-toggle:hover { background: #f7f7f7; }
    .custom-layer-switcher .cls-toggle.cls-active { background: #f3efe6; border-color: rgba(184,137,42,0.4); }
    .custom-layer-switcher .cls-toggle .cls-icon { font-size: 0.95rem; line-height: 1; }
    .custom-layer-switcher .cls-menu {
      display: none;
      position: absolute;
      top: 100%;
      right: 0;
      margin-top: 5px;
      background: #fff;
      border: 1px solid rgba(0,0,0,0.1);
      border-radius: 6px;
      box-shadow: 0 4px 14px rgba(0,0,0,0.18);
      padding: 4px 0;
      min-width: 150px;
      z-index: 1000;
    }
    .custom-layer-switcher .cls-menu.cls-open { display: block; }
    .custom-layer-switcher .cls-menu label {
      display: flex;
      align-items: center;
      gap: 7px;
      padding: 7px 12px;
      cursor: pointer;
      font-size: 0.76rem;
      color: #333;
      font-weight: 500;
    }
    .custom-layer-switcher .cls-menu label:hover { background: #f5f1e8; }
    .custom-layer-switcher .cls-menu input {
      margin: 0;
      accent-color: #8B6914;
      cursor: pointer;
    }

    /* ── MINI-MAPA inwestycji (tooltip hover) ── */
    #inwest-mmap {
      display:none; position:fixed; z-index:9999;
      width:280px; height:190px;
      border-radius:12px; overflow:hidden;
      box-shadow:0 8px 32px rgba(0,0,0,.28), 0 2px 8px rgba(0,0,0,.16);
      border:1px solid rgba(255,255,255,.18);
      pointer-events:none;
      background:#e8e0d8;
      transition:opacity .15s;
    }
    #inwest-mmap-label {
      position:absolute; bottom:0; left:0; right:0;
      background:rgba(0,0,0,.62); color:#fff;
      font-size:.72rem; font-weight:600;
      padding:5px 10px; z-index:10;
      white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
    }
    .inwest-card { cursor:pointer; transition:box-shadow .15s, transform .15s; }
    .inwest-card:hover { box-shadow:0 0 0 2px rgba(255,255,255,.25); transform:translateX(2px); }
    @media (max-width: 768px) {
      #mapContainer { height: 300px !important; }
    }

    /* ── CO SPRAWDZAMY ── */
    .check-section { padding: 100px 48px; background: #F7F6F2; }
    .check-section-inner { max-width: 1120px; margin: 0 auto; }
    .check-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 56px; }
    .check-card {
      position: relative;
      background: #FFFFFF;
      border: 1px solid rgba(184,137,42,0.12);
      border-radius: 16px;
      padding: 28px 22px;
      transition: background .35s 0s, border-color .3s 0s, transform .3s 0s, box-shadow .3s 0s, color .3s 0s;
      cursor: default;
      box-shadow: 0 2px 12px var(--shadow-gold-sm);
      will-change: background, transform;
      overflow: visible;
    }
    .check-card:hover {
      background: #2A1F0D;
      border-color: rgba(184,137,42,0.55);
      transform: translateY(-6px);
      box-shadow: 0 14px 40px rgba(184,137,42,0.22);
      z-index: 20;
    }
    /* ── TOOLTIP CHMURKA ── */
    .check-grid { overflow: visible; }
    .check-card-tooltip {
      position: absolute; top: 0; left: calc(100% + 20px);
      width: 220px;
      background: #1C1810; border: 1px solid rgba(201,168,76,.38); border-radius: 14px;
      padding: 14px 16px; font-size: .82rem; color: rgba(255,255,255,.82); line-height: 1.65;
      pointer-events: none; z-index: 30;
      box-shadow: 0 10px 36px rgba(0,0,0,.38);
      opacity: 0; transform: translateY(8px) scale(.97); transform-origin: left center;
      transition: opacity .22s ease, transform .22s ease;
    }
    .check-card-tooltip::before {
      content: ''; position: absolute; top: 22px; left: -20px;
      width: 20px; height: 1px;
      background: linear-gradient(to right, transparent, rgba(201,168,76,.55));
      transform: scaleX(0); transform-origin: left;
      transition: transform .15s ease;
    }
    .check-card-tooltip::after {
      content: ''; position: absolute; top: 18px; left: -23px;
      width: 5px; height: 5px; border-radius: 50%;
      background: rgba(201,168,76,.75);
      opacity: 0; transition: opacity .1s .12s;
    }
    .check-card:hover .check-card-tooltip { opacity: 1; transform: translateY(0) scale(1); }
    .check-card:hover .check-card-tooltip::before { transform: scaleX(1); }
    .check-card:hover .check-card-tooltip::after  { opacity: 1; }
    /* cols 3 & 4 → tooltip po lewej */
    .check-card:nth-child(4n)   .check-card-tooltip,
    .check-card:nth-child(4n-1) .check-card-tooltip {
      left: auto; right: calc(100% + 20px); transform-origin: right center;
    }
    .check-card:nth-child(4n)   .check-card-tooltip::before,
    .check-card:nth-child(4n-1) .check-card-tooltip::before {
      left: auto; right: -20px;
      background: linear-gradient(to left, transparent, rgba(201,168,76,.55));
      transform-origin: right;
    }
    .check-card:nth-child(4n)   .check-card-tooltip::after,
    .check-card:nth-child(4n-1) .check-card-tooltip::after { left: auto; right: -23px; }
    .check-card:hover .check-card-num { color: rgba(184,137,42,0.55); }
    .check-card:hover .check-card-title { color: var(--gold-light); }
    .check-card:hover .check-card-desc { color: rgba(255,255,255,0.75); }
    .check-card:hover .check-card-source { color: rgba(184,137,42,0.5); }
    .check-card-num { display: none; }
    .check-card-icon { font-size: 2.2rem; margin-bottom: 14px; display: block; line-height: 1; transition: transform .35s; }
    .check-card:hover .check-card-icon { transform: translateY(-4px) scale(1.1); }
    .check-card-title { font-size: 1.05rem; font-weight: 700; color: #111; margin-bottom: 10px; transition: color .3s; }
    .check-card-desc { font-size: 0.88rem; color: #444; line-height: 1.75; transition: color .3s; }
    .check-card-source { display: none; }

    /* ── TABELA PORÓWNAWCZA ── */
    .compare-section { padding:100px 48px; background:#F7F6F2; }
    .compare-section-inner { max-width:960px; margin:0 auto; }
    .compare-table { width:100%; border-collapse:collapse; font-size:.86rem; margin-top:56px; border-radius:12px; overflow:hidden; box-shadow:0 4px 24px rgba(0,0,0,.07); }
    .compare-table thead tr { background:#1A1A1A; color:#fff; }
    .compare-table th { padding:14px 18px; font-weight:600; }
    .compare-table th:first-child { text-align:left; border-radius:12px 0 0 0; }
    .compare-table th:last-child { border-radius:0 12px 0 0; }
    .compare-table th.hl { background:#8B6914; font-weight:700; }
    .compare-table td { padding:12px 18px; text-align:center; border-bottom:1px solid #eee; }
    .compare-table td:first-child { text-align:left; color:#444; }
    .compare-table tbody tr:nth-child(odd) { background:#fafafa; }
    .compare-table tbody tr:nth-child(even) { background:#fff; }
    .compare-table tbody tr:last-child td { border-bottom:none; }
    .compare-table .yes { color:#1A7A4A; font-weight:700; }
    .compare-table .no { color:#C0392B; }
    .compare-table .mid { color:#555; }

    /* ── MAPY SHOWCASE ── */
    .maps-section { padding:100px 48px; background:#fff; }
    .maps-section-inner { max-width:1120px; margin:0 auto; }
    .maps-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:56px; }
    .map-chip { background:#FAF9F6; border:1px solid rgba(184,137,42,.14); border-radius:12px; padding:18px 14px 16px; text-align:center; transition:background .3s,transform .25s,box-shadow .25s; cursor:default; }
    .map-chip:hover { background:#2A1F0D; transform:translateY(-4px); box-shadow:0 10px 28px rgba(184,137,42,.2); }
    .map-chip-icon { font-size:1.9rem; line-height:1; margin-bottom:10px; display:block; }
    .map-chip-name { font-size:.75rem; font-weight:600; color:#333; line-height:1.3; transition:color .3s; }
    .map-chip:hover .map-chip-name { color:rgba(201,168,76,.9); }
    .map-chip-src { font-size:.62rem; color:#aaa; margin-top:5px; transition:color .3s; }
    .map-chip:hover .map-chip-src { color:rgba(201,168,76,.45); }
    @media(max-width:900px) { .maps-grid{grid-template-columns:repeat(3,1fr);} }
    @media(max-width:600px) { .maps-grid{grid-template-columns:repeat(2,1fr);} }

    /* ── JAK TO DZIAŁA (nowy) ── */
    .how-section { padding: 100px 48px; background: #FFFFFF; }
    .how-section-inner { max-width: 1000px; margin: 0 auto; text-align: center; }
    .how-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px; margin-top: 64px; position: relative; }
    .how-steps::before {
      content: '';
      position: absolute;
      top: 52px; left: calc(100% / 6); right: calc(100% / 6);
      height: 1px;
      background: linear-gradient(to right, transparent, rgba(184,137,42,0.3), rgba(184,137,42,0.3), transparent);
    }
    .how-step { display: flex; flex-direction: column; align-items: center; }
    .how-step-num-bg {
      width: 80px; height: 80px;
      border-radius: 50%;
      border: 2px solid rgba(184,137,42,0.3);
      background: #FDF6E3;
      display: flex; align-items: center; justify-content: center;
      font-family: 'Playfair Display', serif;
      font-size: 1.6rem; font-weight: 700;
      color: var(--gold);
      margin-bottom: 24px;
      position: relative; z-index: 1;
    }
    .how-step-title { font-size: 1.15rem; font-weight: 700; color: #111; margin-bottom: 14px; }
    .how-step-desc { font-size: 0.92rem; color: #444; line-height: 1.85; max-width: 260px; }

    /* ── DLA KOGO ── */
    .for-section { padding: 100px 48px; background: #F7F6F2; }
    .for-section-inner { max-width: 1000px; margin: 0 auto; }
    .for-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; margin-top: 56px; }
    .for-card {
      background: #FFFFFF;
      border: 1px solid rgba(184,137,42,0.1);
      border-radius: 16px;
      padding: 32px 28px;
      transition: background .35s 0s, border-color .3s 0s, transform .3s 0s, box-shadow .3s 0s;
      box-shadow: 0 2px 12px var(--shadow-gold-sm);
      will-change: background, transform;
    }
    .for-card:hover {
      background: #2A1F0D;
      border-color: rgba(184,137,42,0.55);
      transform: translateY(-6px);
      box-shadow: 0 14px 40px rgba(184,137,42,0.22);
    }
    .for-card:hover .for-title { color: var(--gold-light); }
    .for-card:hover .for-list li { color: rgba(255,255,255,0.75); border-bottom-color: rgba(255,255,255,0.08); }
    .for-card:hover .for-icon { transform: translateY(-4px) scale(1.1); }
    .for-icon { font-size: 2.4rem; margin-bottom: 18px; display: block; line-height: 1; transition: transform .35s; }
    .for-title { font-size: 1.1rem; font-weight: 700; color: var(--gold); margin-bottom: 18px; transition: color .3s; }
    .for-list { list-style: none; }
    .for-list li { font-size: 0.88rem; color: #444; padding: 8px 0; border-bottom: 1px solid rgba(0,0,0,0.06); display: flex; gap: 8px; transition: color .3s, border-bottom-color .3s; }
    .for-list li::before { content: '→'; color: var(--gold); flex-shrink: 0; }

    /* ── DLACZEGO MY ── */
    .why-section { padding: 100px 48px; background: #FFFFFF; }
    .why-section-inner { max-width: 960px; margin: 0 auto; }
    .why-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 56px; }
    .why-card { display: flex; gap: 22px; padding: 32px; background: var(--dark3); border: 1px solid rgba(184,137,42,0.1); border-radius: 16px; align-items: flex-start; box-shadow: 0 2px 12px var(--shadow-gold-sm); transition: background .35s, transform .3s, box-shadow .3s; }
    .why-card:hover { background: #2A1F0D; transform: translateY(-5px); box-shadow: 0 12px 36px rgba(184,137,42,0.2); }
    .why-card:hover .why-card-icon { transform: translateY(-3px) scale(1.12); }
    .why-card:hover .why-card-title { color: var(--gold-light); }
    .why-card:hover .why-card-desc { color: rgba(255,255,255,0.73); }
    .why-card-icon { font-size: 2rem; flex-shrink: 0; padding-top: 2px; transition: transform .35s; line-height: 1; }
    .why-card-title { font-size: 1.05rem; font-weight: 700; color: #111; margin-bottom: 10px; transition: color .3s; }
    .why-card-desc { font-size: 0.88rem; color: #444; line-height: 1.8; transition: color .3s; }
    .why-badge { display:inline-block; background:rgba(201,168,76,.12); border:1px solid rgba(201,168,76,.3); color:var(--gold); font-size:.65rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; padding:3px 10px; border-radius:4px; margin-top:8px; }
    .why-card:hover .why-card-desc { color: rgba(255,255,255,0.73); }
    .why-badge { display: inline-block; background: rgba(201,168,76,0.12); border: 1px solid rgba(201,168,76,0.3); color: var(--gold); font-size: 0.65rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 3px 10px; border-radius: 4px; margin-top: 8px; }

    /* ── FAQ TEASER ── */
    .faq-section { padding: 100px 48px; background: #F7F6F2; }
    .faq-section-inner { max-width: 820px; margin: 0 auto; }
    .faq-list { margin-top: 56px; }
    .faq-item { border-bottom: 1px solid rgba(0,0,0,0.08); }
    .faq-q {
      padding: 22px 0;
      cursor: pointer;
      display: flex;
      justify-content: space-between;
      align-items: center;
      font-size: 0.95rem;
      font-weight: 500;
      color: #111;
      transition: color .2s;
      user-select: none;
    }
    .faq-q:hover { color: var(--gold); }
    .faq-arrow { color: var(--gold); font-size: 1.3rem; transition: transform .3s; flex-shrink: 0; margin-left: 16px; }
    .faq-a {
      max-height: 0;
      overflow: hidden;
      transition: max-height .4s ease, padding .3s;
      font-size: 0.85rem;
      color: #555;
      line-height: 1.85;
    }
    .faq-item.open .faq-arrow { transform: rotate(45deg); }
    .faq-item.open .faq-a { max-height: 300px; padding-bottom: 22px; }
    .faq-more-link { display: block; text-align: center; margin-top: 48px; color: var(--gold); font-size: 0.85rem; letter-spacing: 1px; text-decoration: none; }
    .faq-more-link:hover { opacity: 0.8; }

    /* ── FOOTER (improved) ── */
    .footer-new {
      padding: 64px 48px 40px;
      background: #1A1A1A;
      border-top: none;
    }
    .footer-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 40px; max-width: 1100px; margin: 0 auto 48px; flex-wrap: wrap; }
    .footer-brand .logo { font-size: 1.6rem; }
    .footer-brand p { font-size: 0.8rem; color: #6B6560; margin-top: 12px; max-width: 280px; line-height: 1.7; }
    .footer-col h4 { font-size: 0.7rem; letter-spacing: 2px; text-transform: uppercase; color: var(--gold-light); margin-bottom: 16px; }
    .footer-col a { display: block; font-size: 0.82rem; color: #6B6560; text-decoration: none; margin-bottom: 10px; transition: color .2s; }
    .footer-col a:hover { color: #fff; }
    .footer-bottom { max-width: 1100px; margin: 0 auto; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.07); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
    .footer-bottom-copy { font-size: 0.74rem; color: #6B6560; }
    .footer-bottom-data { font-size: 0.72rem; color: #BDBDBD; }

    /* ── PRE-FOOTER INFO BAR ── */
    .info-bar {
      background: #F7F6F2;
      padding: 80px 48px;
      border-top: 1px solid rgba(184,137,42,0.12);
    }
    .info-bar-inner {
      max-width: 1100px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 48px;
    }
    .info-bar-block h3 {
      font-family: 'Playfair Display', serif;
      font-size: 1rem;
      color: #1a1a1a;
      margin-bottom: 14px;
      letter-spacing: 0.5px;
    }
    .info-bar-block p, .info-bar-block li {
      font-size: 0.8rem;
      color: #555;
      line-height: 1.8;
    }
    .info-bar-block ul { padding-left: 16px; }
    .info-bar-block li { margin-bottom: 4px; }
    .info-bar-block .info-tag {
      display: inline-block;
      background: rgba(184,137,42,0.1);
      border: 1px solid rgba(184,137,42,0.25);
      color: #8a6520;
      font-size: 0.68rem;
      font-weight: 600;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      padding: 4px 10px;
      border-radius: 3px;
      margin-bottom: 14px;
    }
    .pay-logos {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      margin-top: 14px;
    }
    .pay-logo {
      background: #fff;
      border: 1px solid rgba(0,0,0,0.1);
      border-radius: 6px;
      padding: 6px 12px;
      font-size: 0.72rem;
      font-weight: 700;
      color: #222;
      letter-spacing: 0.5px;
    }
    @media (max-width: 900px) {
      .info-bar { padding: 56px 24px; }
      .info-bar-inner { grid-template-columns: 1fr; gap: 36px; }
    }

    /* ── AUTOCOMPLETE ── */
    .autocomplete-wrap { position: relative; flex: 1; }
    .autocomplete-dropdown {
      position: absolute;
      top: 100%; left: 0; right: 0;
      background: #fff;
      border: 1px solid rgba(184,137,42,0.3);
      border-top: none;
      border-radius: 0 0 8px 8px;
      z-index: 9999;
      max-height: 220px;
      overflow-y: auto;
      box-shadow: 0 8px 24px rgba(184,137,42,0.15);
    }
    .autocomplete-item {
      padding: 10px 14px;
      font-size: 0.84rem;
      color: #1A1A1A;
      cursor: pointer;
      border-bottom: 1px solid rgba(0,0,0,0.05);
      transition: background .15s;
    }
    .autocomplete-item:hover { background: rgba(184,137,42,0.08); }
    .autocomplete-item strong { color: var(--gold); }

    .form-group input, .form-group select {
      background: #F7F6F2 !important;
      border-color: rgba(184,137,42,0.25) !important;
      color: #1A1A1A !important;
    }
    .form-group input::placeholder { color: #AAA !important; }
    .form-group label { color: #333 !important; }
    .form-hint { color: #6B6560 !important; }

    /* ── RESPONSIVE ── */
    @media (max-width: 768px) {
      header { padding: 16px 24px; }
      nav { display: none; }
      .stats { flex-direction: column; }
      .stat { max-width: 100%; border-right: none; border-bottom: 1px solid rgba(201,168,76,0.1); }
      .form-grid { grid-template-columns: 1fr; }
      .results-grid { grid-template-columns: 1fr; }
      .steps-grid { grid-template-columns: 1fr; }
      .risk-circles { grid-template-columns: repeat(3, 1fr); }
      .verdict-banner { flex-direction: column; text-align: center; padding: 32px 24px; }
      .rekomendacja-card { padding: 32px 24px; }
      footer { flex-direction: column; gap: 16px; text-align: center; }
      .check-grid { grid-template-columns: repeat(2, 1fr); }
      .for-grid { grid-template-columns: 1fr; }
      .why-grid { grid-template-columns: 1fr; }
      .how-steps { grid-template-columns: 1fr; }
      .how-steps::before { display: none; }
      .check-section, .how-section, .for-section, .why-section, .faq-section { padding: 64px 24px; }
      .footer-top { flex-direction: column; }
    }

    /* === PRZYCISKI PDF / EMAIL === */
    .export-bar {
      display: flex;
      gap: 12px;
      justify-content: center;
      margin: 28px 0 8px;
      flex-wrap: wrap;
    }
    .export-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 12px 24px;
      border-radius: 8px;
      font-size: 0.9rem;
      font-weight: 600;
      cursor: pointer;
      border: 2px solid var(--gold);
      transition: background .2s, color .2s;
      letter-spacing: 0.5px;
    }
    .export-btn-pdf, .export-btn-email, .export-btn-share {
      background: transparent;
      color: var(--gold);
    }
    .export-btn-pdf:hover, .export-btn-email:hover, .export-btn-share:hover {
      background: var(--gold);
      color: #fff;
    }
    .export-btn-blad {
      background: rgba(231,76,60,0.08);
      color: #E74C3C;
      border-color: rgba(231,76,60,0.45);
      font-size: 0.8rem;
      font-weight: 600;
    }
    .export-btn-blad:hover { background: #E74C3C; color: #fff; border-color: #E74C3C; }
    .urz-link-btn {
      display: flex;
      align-items: center;
      gap: 6px;
      padding: 10px 14px;
      border-radius: 8px;
      border: 1px solid rgba(201,168,76,0.25);
      background: rgba(201,168,76,0.05);
      color: var(--text-dim);
      text-decoration: none;
      font-size: 0.82rem;
      font-weight: 500;
      transition: background .2s, border-color .2s, color .2s;
    }
    .urz-link-btn:hover { background: rgba(201,168,76,0.12); border-color: rgba(201,168,76,0.5); color: var(--gold); }
    .aerial-link-btn {
      display: inline-block;
      padding: 5px 12px;
      border-radius: 5px;
      border: 1px solid #444;
      color: #bbb;
      text-decoration: none;
      font-size: 0.78rem;
      transition: border-color .2s, color .2s;
    }
    .aerial-link-btn:hover { border-color: var(--gold); color: var(--gold); }

    /* === MODAL EMAIL === */
    .email-modal-overlay {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,.55);
      z-index: 1000;
      align-items: center;
      justify-content: center;
    }
    .email-modal-overlay.open { display: flex; }
    .email-modal-box {
      background: var(--dark, #FAF9F6);
      border: 1px solid var(--dark4, #E8E7E1);
      border-radius: 16px;
      padding: 36px 32px 28px;
      width: 100%;
      max-width: 440px;
      position: relative;
      animation: modalIn .25s ease;
    }
    .email-modal-title {
      font-family: 'Playfair Display', serif;
      font-size: 1.3rem;
      font-weight: 700;
      margin-bottom: 8px;
    }
    .email-modal-desc {
      font-size: 0.85rem;
      color: var(--text-dim);
      margin-bottom: 20px;
      line-height: 1.6;
    }
    .email-modal-input {
      width: 100%;
      padding: 12px 16px;
      border-radius: 8px;
      border: 1px solid var(--border);
      background: var(--bg);
      color: var(--text);
      font-size: 0.95rem;
      margin-bottom: 16px;
      box-sizing: border-box;
    }
    .email-modal-input:focus { outline: none; border-color: var(--gold); }
    .email-modal-send {
      width: 100%;
      padding: 13px;
      background: var(--gold);
      color: #fff;
      border: none;
      border-radius: 8px;
      font-size: 0.95rem;
      font-weight: 700;
      cursor: pointer;
      transition: background .2s;
    }
    .email-modal-send:hover { background: var(--gold-light); }
    .email-modal-send:disabled { opacity: .5; cursor: not-allowed; }
    .email-modal-close {
      position: absolute;
      top: 16px; right: 20px;
      background: none; border: none;
      font-size: 1.2rem;
      color: var(--text-dim);
      cursor: pointer;
    }
    .email-modal-close:hover { color: var(--gold); }
    .email-modal-status {
      margin-top: 12px;
      font-size: 0.85rem;
      text-align: center;
      min-height: 20px;
    }

    /* === MAPA WYNIKÓW === */
    .results-map-section {
      margin: 28px 0;
    }
    .results-map-tabs {
      display: flex;
      gap: 6px;
      margin-bottom: 8px;
      flex-wrap: wrap;
    }
    .rmap-tab {
      padding: 6px 14px;
      font-size: 0.75rem;
      font-weight: 600;
      letter-spacing: 0.5px;
      border: 1px solid rgba(201,168,76,0.25);
      background: transparent;
      color: var(--text-dim);
      cursor: pointer;
      border-radius: 3px;
      transition: all .2s;
    }
    .rmap-tab:hover { border-color: var(--gold); color: var(--gold); }
    .rmap-tab.active { background: var(--gold); color: #fff; border-color: var(--gold); }
    /* Pogrupowane zakładki mapy wyników */
    .results-map-tabs-grouped {
      display: flex;
      flex-direction: column;
      gap: 10px;
      margin-bottom: 12px;
    }
    .rmap-group {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 6px 8px;
      padding: 6px 10px;
      background: rgba(201,168,76,0.04);
      border-left: 3px solid rgba(201,168,76,0.4);
      border-radius: 0 6px 6px 0;
    }
    .rmap-group-label {
      font-size: 0.65rem;
      font-weight: 700;
      letter-spacing: 1.2px;
      text-transform: uppercase;
      color: var(--gold);
      opacity: 0.75;
      margin-right: 4px;
      min-width: 130px;
    }
    @media (max-width: 720px) {
      .rmap-group-label { min-width: auto; width: 100%; margin-bottom: 2px; }
    }
    #resultsMap {
      height: 380px;
      border-radius: 10px;
      border: 1px solid rgba(201,168,76,0.2);
      overflow: hidden;
    }
    @media (max-width: 600px) { #resultsMap { height: 280px; } }
    @media print { .results-map-section { display: none; } }

    .elev-legend {
      display: none;
      margin-top: 6px;
      padding: 6px 12px;
      background: rgba(255,255,255,0.92);
      border-radius: 8px;
      border: 1px solid rgba(184,137,42,0.18);
      font-size: 11px;
      color: var(--text);
      gap: 6px;
      flex-wrap: wrap;
      align-items: center;
    }
    .elev-legend.visible { display: flex; }
    .elev-item {
      display: flex;
      align-items: center;
      gap: 4px;
      white-space: nowrap;
    }
    .elev-swatch {
      width: 14px; height: 14px;
      border-radius: 3px;
      border: 1px solid rgba(0,0,0,0.15);
      flex-shrink: 0;
    }

    #mapDesc {
      margin-top: 6px;
      padding: 6px 10px;
      background: rgba(184,137,42,0.07);
      border-left: 3px solid var(--gold);
      border-radius: 0 6px 6px 0;
      font-size: 12px;
      color: var(--text-dim);
      line-height: 1.5;
      min-height: 28px;
    }

    /* Tooltips */
    .tip {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 14px; height: 14px;
      background: var(--gold);
      color: #fff;
      border-radius: 50%;
      font-size: 9px;
      font-weight: 700;
      cursor: pointer;
      position: relative;
      vertical-align: middle;
      margin-left: 3px;
      flex-shrink: 0;
    }
    .tip::after {
      content: attr(data-tip);
      position: absolute;
      bottom: 130%;
      left: 50%;
      transform: translateX(-50%);
      background: #1a1a1a;
      color: #fff;
      padding: 7px 10px;
      border-radius: 7px;
      font-size: 11px;
      width: 220px;
      text-align: center;
      pointer-events: none;
      opacity: 0;
      transition: opacity .2s;
      z-index: 9000;
      font-weight: 400;
      line-height: 1.4;
      white-space: normal;
      box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    }
    .tip:hover::after, .tip:focus::after { opacity: 1; }

    /* === SUROWE DANE === */
    .raw-data-section {
      margin-top: 40px;
      border-top: 2px solid var(--gold);
      padding-top: 28px;
    }
    .raw-data-title {
      font-family: 'Playfair Display', serif;
      font-size: 1.1rem;
      color: var(--text);
      margin-bottom: 6px;
      letter-spacing: 0.5px;
    }
    .raw-data-subtitle {
      font-size: 0.78rem;
      color: var(--text-dim);
      margin-bottom: 20px;
    }
    .raw-data-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
      gap: 16px;
    }
    .raw-data-group {
      background: var(--dark3);
      border: 1px solid rgba(201,168,76,0.1);
      padding: 16px 18px;
      break-inside: avoid;
    }
    .raw-data-group-title {
      font-size: 0.7rem;
      font-weight: 700;
      letter-spacing: 1.5px;
      text-transform: uppercase;
      color: var(--gold);
      margin-bottom: 10px;
      padding-bottom: 6px;
      border-bottom: 1px solid rgba(201,168,76,0.15);
    }
    .raw-row {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 8px;
      padding: 4px 0;
      border-bottom: 1px solid rgba(0,0,0,0.04);
      font-size: 0.78rem;
      line-height: 1.4;
    }
    .raw-row:last-child { border-bottom: none; }
    .raw-label { color: var(--text-dim); flex: 0 0 auto; max-width: 50%; }
    .raw-value { color: var(--text); text-align: right; word-break: break-word; }
    .raw-source {
      font-size: 0.68rem;
      color: var(--text-dim);
      margin-top: 8px;
      text-align: right;
      font-style: italic;
    }
    @media (max-width: 600px) {
      .raw-data-grid { grid-template-columns: 1fr; }
    }

    /* === WYNIKI — sticky zakładki grupujące sekcje === */
    .results-tabs-sticky {
      position: sticky;
      top: 0;
      z-index: 100;
      background: linear-gradient(to bottom, rgba(240,239,233,0.98) 0%, rgba(240,239,233,0.96) 100%);
      backdrop-filter: blur(8px);
      border-bottom: 1px solid rgba(184,137,42,0.22);
      margin: 0 -8px 16px;
      padding: 8px 8px 8px;
      box-shadow: 0 4px 12px -8px rgba(0,0,0,0.15);
    }
    .results-tabs-inner {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      align-items: center;
      max-width: 100%;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: thin;
    }
    .rtab {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 14px;
      font-size: 0.82rem;
      font-weight: 600;
      color: rgba(40,30,15,0.62);
      background: rgba(255,255,255,0.45);
      border: 1px solid rgba(184,137,42,0.18);
      border-radius: 22px;
      cursor: pointer;
      white-space: nowrap;
      transition: all .18s ease;
      font-family: inherit;
    }
    .rtab:hover {
      background: rgba(201,168,76,0.12);
      color: rgba(40,30,15,0.85);
      border-color: rgba(184,137,42,0.35);
    }
    .rtab.active {
      background: var(--gold, #C9A84C);
      color: #fff;
      border-color: var(--gold, #C9A84C);
      box-shadow: 0 2px 8px rgba(201,168,76,0.35);
    }
    .rtab-count {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 18px;
      height: 18px;
      padding: 0 5px;
      font-size: 0.66rem;
      font-weight: 700;
      background: rgba(0,0,0,0.08);
      color: inherit;
      border-radius: 10px;
    }
    .rtab.active .rtab-count {
      background: rgba(255,255,255,0.28);
      color: #fff;
    }
    .rtab-warn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 18px;
      height: 18px;
      padding: 0 5px;
      margin-left: 2px;
      font-size: 0.66rem;
      font-weight: 700;
      background: #DC2626;
      color: #fff;
      border-radius: 10px;
    }
    .rtab.active .rtab-warn { background: #fff; color: #DC2626; }
    [data-rtab-hidden="1"] { display: none !important; }
    @media (max-width: 720px) {
      .rtab { padding: 7px 11px; font-size: 0.78rem; }
    }

    /* === SPIS TREŚCI (TOC) sidebar === */
    #toc-sidebar {
      display: none;
      position: fixed;
      left: 14px;
      top: 50%;
      transform: translateY(-50%);
      z-index: 200;
      width: 250px;
      padding: 18px 4px;
      background: rgba(240,239,233,0.92);
      border-radius: 12px;
      backdrop-filter: blur(6px);
      box-shadow: 0 4px 18px rgba(0,0,0,0.10);
    }
    .wyniki-mode #toc-sidebar { display: block !important; }
    @media (max-width: 1180px) { #toc-sidebar, .wyniki-mode #toc-sidebar { display: none !important; } }
    #toc-sidebar .toc-group {
      margin-bottom: 10px;
    }
    #toc-sidebar .toc-group-label {
      font-size: 0.74rem;
      font-weight: 700;
      letter-spacing: 1.2px;
      text-transform: uppercase;
      color: rgba(140,105,30,0.65);
      padding: 4px 14px 6px;
      transition: color .3s;
    }
    #toc-sidebar .toc-group.active .toc-group-label {
      color: var(--gold);
    }
    #toc-sidebar .toc-item {
      display: block;
      position: relative;
      font-size: 0.88rem;
      color: rgba(40,30,15,0.55);
      padding: 6px 14px 6px 18px;
      border-left: 2px solid transparent;
      cursor: pointer;
      transition: color .25s, border-color .25s, padding-left .2s, background-color .2s, transform .2s;
      line-height: 1.4;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      text-decoration: none;
    }
    #toc-sidebar .toc-item:hover {
      color: rgba(40,30,15,0.95);
      background-color: rgba(201,168,76,0.10);
      padding-left: 22px;
      border-left-color: rgba(201,168,76,0.45);
    }
    #toc-sidebar .toc-item:hover::before {
      content: '›';
      position: absolute;
      left: 8px;
      color: var(--gold);
      font-weight: 700;
      animation: toc-arrow-in .25s ease;
    }
    @keyframes toc-arrow-in { from { opacity: 0; transform: translateX(-3px); } to { opacity: 1; transform: translateX(0); } }
    #toc-sidebar .toc-item.active {
      color: var(--gold);
      border-left-color: var(--gold);
      padding-left: 16px;
      font-weight: 600;
    }
    @keyframes toc-pulse { 0%,100% { opacity:1; } 50% { opacity:.6; } }
    #toc-sidebar .toc-group.active .toc-group-label { animation: none; }

    /* Sticky header (.results-tabs-sticky) zasłania target przy scrollIntoView.
       scroll-margin-top dodaje "wirtualny offset" tak że scroll zatrzyma się
       80px wyżej (wystarczająco żeby header sekcji był widoczny pod sticky bar). */
    .results-section-header,
    .verdict-block,
    .ocena-ceny,
    .summary-section { scroll-margin-top: 90px; }

    /* Target highlight po kliknięciu w TOC — subtle gold ring na 1.5s */
    @keyframes toc-target-flash {
      0%   { box-shadow: 0 0 0 0 rgba(201,168,76,0); background-color: transparent; }
      15%  { box-shadow: 0 0 0 6px rgba(201,168,76,0.35); background-color: rgba(201,168,76,0.08); }
      100% { box-shadow: 0 0 0 0 rgba(201,168,76,0); background-color: transparent; }
    }
    .toc-target-highlight {
      animation: toc-target-flash 1.5s ease-out;
      border-radius: 4px;
    }

    /* === PRINT / PDF === */
    @media print {
      #toc-sidebar { display: none !important; }
      /* Nadpisz wszystkie CSS zmienne koloru — ciemny motyw na białym papierze = niewidoczny */
      :root {
        --bg: #ffffff !important;
        --dark2: #ffffff !important;
        --dark3: #f8f8f6 !important;
        --dark4: #f0efea !important;
        --text: #111111 !important;
        --text-dim: #444444 !important;
        --gold: #8B6914 !important;
      }
      body { background: #fff !important; color: #111 !important; }

      /* Ukryj wszystko poza wynikami */
      header, footer, .faq-section, .how-section, .for-section,
      .why-section, .check-section, .export-bar, .new-search-btn,
      #chatPanel, .scroll-hint, .hero, .stats,
      .results-map-section { display: none !important; }
      /* Struktura: #analiza > div(anonimowy) > .form-wrapper > #wyniki */
      #analiza > div > *:not(.form-wrapper) { display: none !important; }
      #analiza > div { padding: 0 !important; margin: 0 auto !important; }
      .form-wrapper > *:not(#wyniki) { display: none !important; }
      #analiza { padding: 0 !important; }
      .form-wrapper { padding: 0 !important; margin: 0 !important; }
      #wyniki { display: block !important; padding: 0 !important; }

      /* Karty i elementy */
      .verdict-banner { print-color-adjust: exact; -webkit-print-color-adjust: exact; }
      .issue-card, .info-card, .rekomendacja-card, .raw-data-group { break-inside: avoid; }
      .issue-card { background: #f8f8f8 !important; border: 1px solid #ddd !important; }
      .issue-steps { background: #f0f0ee !important; }
      .info-card { background: #f8f8f8 !important; border: 1px solid #ddd !important; }
      a { color: #111 !important; }

      /* Surowe dane */
      .raw-data-section { margin-top: 24px; border-top: 1.5px solid #8B6914; }
      .raw-data-group { background: #f8f8f8 !important; border: 1px solid #ddd !important; }
      .raw-data-grid { grid-template-columns: repeat(2, 1fr); }
    }

    /* 2026-05-04: MPZP badge — pokazuje symbol planu nad działką gdy KIMPZP WMS nie ma overlay */
    .mpzp-badge-wrap { background: transparent !important; border: none !important; }
    .mpzp-badge { background: #fff; border: 2px solid #8B6914; border-radius: 8px; padding: 8px 12px; box-shadow: 0 4px 12px rgba(0,0,0,0.25); min-width: 180px; max-width: 240px; text-align: center; position: relative; transform: translateY(-12px); }
    .mpzp-badge-sym { font-weight: 800; color: #5a4520; font-size: 1.05rem; letter-spacing: 0.5px; }
    .mpzp-badge-fn { font-size: 0.78rem; color: #555; margin-top: 4px; line-height: 1.3; }
    .mpzp-badge-link { display: inline-block; margin-top: 6px; font-size: 0.82rem; color: #8B6914; font-weight: 600; text-decoration: none; }
    .mpzp-badge-link:hover { text-decoration: underline; }
    .mpzp-badge-arrow { position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%); width: 0; height: 0; border-left: 8px solid transparent; border-right: 8px solid transparent; border-top: 8px solid #8B6914; }
    .mpzp-badge-arrow::after { content: ''; position: absolute; top: -10px; left: -7px; width: 0; height: 0; border-left: 7px solid transparent; border-right: 7px solid transparent; border-top: 7px solid #fff; }
