/* ============================================================
   KRESKI — Strona główna v2.0
   /wp-content/themes/flatsome-child/css/homepage.css
   ============================================================ */

/* ── Wspólne elementy sekcji ─────────────────────────────── */
.kr-wrap { max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.kr-section { padding: 72px 0; }
.kr-section-header { text-align: left; max-width: 100%; margin: 0 0 32px; }
.kr-section-header--center { text-align: center; max-width: 760px; margin: 0 auto 48px; }
.kr-section-header--flex { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 40px; gap: 24px; }
.kr-section-overtitle { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .14em; color: var(--red); margin: 0 0 8px; }
.kr-section-title { font-size: clamp(22px, 2.8vw, 34px); font-weight: 800; color: var(--black); margin: 0 0 14px; line-height: 1.15; text-transform: uppercase; }
.kr-section-title--light { color: var(--white); }
.kr-section-desc { font-size: 15px; color: var(--gray-m); line-height: 1.7; margin: 0; max-width: 560px; }
.kr-section-footer { text-align: center; margin-top: 40px; }

/* ── Przyciski ───────────────────────────────────────────── */
.kr-btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font); font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; cursor: pointer; transition: background .2s, color .2s; text-decoration: none; white-space: nowrap; border: none; }
.kr-btn-red { background: var(--red); color: var(--white); padding: 14px 32px; border-radius: 3px; }
.kr-btn-red:hover { background: var(--red-d); color: var(--white); }
.kr-btn-red svg { transition: transform .2s; }
.kr-btn-red:hover svg { transform: translateX(4px); }
.kr-btn-outline-white { background: transparent; color: var(--white); padding: 12px 26px; border-radius: 3px; border: 2px solid rgba(255,255,255,.5); }
.kr-btn-outline-white:hover { border-color: var(--white); background: rgba(255,255,255,.08); }
.kr-btn-ghost { background: transparent; color: var(--red); padding: 0; font-size: 13px; text-transform: none; letter-spacing: 0; }
.kr-btn-ghost:hover { color: var(--red-d); }


/* ══════════════════════════════════════════════════════════
   1. HERO
   ══════════════════════════════════════════════════════════ */
#kr-homepage .kr-hero { position: relative !important; min-height: 480px !important; display: flex !important; align-items: center !important; overflow: hidden !important; background: #060e18 !important; }
#kr-homepage .kr-hero-bg { position: absolute !important; inset: -15% 0 !important; z-index: 0 !important; will-change: transform !important; }
#kr-homepage .kr-hero-bg img { width: 100% !important; height: 115% !important; object-fit: cover !important; opacity: 1 !important; filter: saturate(.85) brightness(1) !important; display: block !important; }
#kr-homepage .kr-hero-bg::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    to right,
    rgba(4, 10, 20, 0.95) 0%,
    rgba(4, 10, 20, 0.4) 20%,
    rgba(4, 10, 20, 0) 35%,
    transparent 100%
  ) !important;
  z-index: 1 !important;
}
#kr-homepage .kr-hero-inner { position: relative !important; z-index: 2 !important; padding: 60px 32px 60px !important; margin-left: max(32px, calc(50vw - 580px)) !important; max-width: 700px !important; width: 100% !important; }
#kr-homepage .kr-hero-badge { display: inline-flex !important; align-items: center !important; gap: 8px !important; background: rgba(34,197,94,.15) !important; border: 1px solid rgba(34,197,94,.5) !important; color: #4ade80 !important; font-size: 11px !important; font-weight: 800 !important; text-transform: uppercase !important; letter-spacing: .14em !important; padding: 6px 16px !important; border-radius: 2px !important; margin-bottom: 28px !important; }
#kr-homepage .kr-hero-badge span { width: 7px !important; height: 7px !important; background: #22c55e !important; border-radius: 50% !important; flex-shrink: 0 !important; animation: badge-pulse 2s ease-in-out infinite !important; }
@keyframes badge-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.5)} }
#kr-homepage .kr-hero-h1 { font-size: clamp(26px, 3.6vw, 48px) !important; font-weight: 900 !important; color: #ffffff !important; line-height: 1.1 !important; margin: 0 !important; letter-spacing: -.01em !important; text-transform: uppercase !important; }
#kr-homepage .kr-hero-h1-accent { color: var(--red) !important; display: block !important; }
#kr-homepage .kr-hero-h1-accent-inline { color: var(--red) !important; }
#kr-homepage .kr-hero-typewriter { font-size: clamp(26px, 3.6vw, 48px) !important; font-weight: 900 !important; color: var(--red) !important; line-height: 1.1 !important; margin: 0 0 36px !important; text-transform: uppercase !important; letter-spacing: -.01em !important; display: block !important; height: 1.2em !important; overflow: visible !important; white-space: nowrap !important; }
#kr-homepage .kr-hero-typewriter-prefix { display: none !important; }
#kr-homepage .kr-hero-typewriter-text { color: var(--red) !important; border-right: 3px solid var(--red) !important; padding-right: 4px !important; font-weight: 900 !important; }
#kr-homepage .kr-hero-typewriter-text.blinking { animation: tw-blink .75s step-end infinite !important; }
@keyframes tw-blink { 0%,100%{border-color:var(--red)} 50%{border-color:transparent} }
#kr-homepage .kr-hero-sub { display: none !important; }
#kr-homepage .kr-hero-btns { display: flex !important; gap: 14px !important; flex-wrap: wrap !important; margin-top: 0 !important; }
#kr-homepage .kr-btn-red { background: var(--red) !important; color: #fff !important; padding: 16px 32px !important; border-radius: 4px !important; font-size: 13px !important; font-weight: 800 !important; letter-spacing: .1em !important; border: none !important; }
#kr-homepage .kr-btn-red:hover { background: var(--red-d) !important; }
#kr-homepage .kr-btn-outline-white { border: 2px solid rgba(255,255,255,.5) !important; color: #fff !important; background: transparent !important; padding: 14px 30px !important; border-radius: 0 !important; font-size: 13px !important; font-weight: 800 !important; letter-spacing: .1em !important; }
#kr-homepage .kr-btn-outline-white:hover { border-color: #fff !important; background: rgba(255,255,255,.08) !important; }


/* ══════════════════════════════════════════════════════════
   2. OFERTA
   ══════════════════════════════════════════════════════════ */
#kr-homepage .kr-offer { background: #f4f4f4 !important; padding: 64px 0 !important; }
#kr-homepage .kr-offer-header { display: block !important; width: 100% !important; margin-bottom: 36px !important; text-align: left !important; }
#kr-homepage .kr-offer-header .kr-section-overtitle { color: var(--red) !important; }
#kr-homepage .kr-offer-title { font-size: clamp(20px, 2.6vw, 32px) !important; margin: 0 0 16px !important; text-transform: uppercase !important; max-width: 100% !important; }
#kr-homepage .kr-offer-desc { font-size: 14px !important; color: #6b6b6b !important; line-height: 1.7 !important; margin: 0 !important; max-width: 680px !important; }
#kr-homepage .kr-offer-filters { display: flex !important; gap: 8px !important; width: auto !important; margin-bottom: 36px !important; margin-top: 24px !important; border: none !important; background: transparent !important; flex-wrap: nowrap !important; overflow-x: auto !important; }
#kr-homepage .kr-filter-btn { padding: 9px 22px !important; background: #fff !important; border: 1.5px solid #e2e2e2 !important; color: #2d2d2d !important; font-family: var(--font) !important; font-size: 11px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .1em !important; cursor: pointer !important; transition: all .18s !important; border-radius: 2px !important; white-space: nowrap !important; }
#kr-homepage .kr-filter-btn:hover { color: var(--red) !important; border-color: var(--red) !important; background: #fff8f8 !important; }
#kr-homepage .kr-filter-btn.active { background: var(--red) !important; color: #fff !important; border-color: var(--red) !important; }
#kr-homepage .kr-offer-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; background: #fff !important; border: 1.5px solid #e2e2e2 !important; gap: 0 !important; }
#kr-homepage .kr-offer-card { padding: 28px 24px !important; border-right: 1.5px solid #e2e2e2 !important; border-bottom: 1.5px solid #e2e2e2 !important; display: flex !important; flex-direction: column !important; position: relative !important; background: #fff !important; margin: 0 !important; box-shadow: none !important; transition: background .22s ease, border-color .22s ease !important; cursor: pointer !important; }
#kr-homepage .kr-offer-card:nth-child(3n) { border-right: none !important; }
#kr-homepage .kr-offer-card:nth-last-child(-n+3) { border-bottom: none !important; }
#kr-homepage .kr-offer-card:hover { background: var(--red) !important; border-color: var(--red) !important; }
#kr-homepage .kr-offer-card:hover .kr-offer-icon { background: rgba(255,255,255,.18) !important; color: #fff !important; }
#kr-homepage .kr-offer-card:hover .kr-offer-name { color: #fff !important; }
#kr-homepage .kr-offer-card:hover .kr-offer-desc { color: rgba(255,255,255,.88) !important; }
#kr-homepage .kr-offer-card:hover .kr-offer-link { color: #fff !important; }
#kr-homepage .kr-offer-icon { width: 44px !important; height: 44px !important; background: rgba(227,6,19,.1) !important; border-radius: 6px !important; display: flex !important; align-items: center !important; justify-content: center !important; margin-bottom: 16px !important; flex-shrink: 0 !important; color: var(--red) !important; padding: 10px !important; transition: background .22s, color .22s !important; }
#kr-homepage .kr-offer-icon svg { width: 100% !important; height: 100% !important; }
#kr-homepage .kr-offer-name { font-size: 15px !important; font-weight: 700 !important; color: #1a1a1a !important; margin: 0 0 10px !important; line-height: 1.3 !important; transition: color .22s !important; }
#kr-homepage .kr-offer-desc { font-size: 13px !important; color: #6b6b6b !important; line-height: 1.65 !important; margin: 0 0 16px !important; flex: 1 !important; transition: color .22s !important; }
#kr-homepage .kr-offer-link { display: inline-flex !important; align-items: center !important; gap: 6px !important; font-size: 12px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .04em !important; color: var(--red) !important; transition: gap .2s, color .22s !important; margin-top: auto !important; text-decoration: none !important; }
#kr-homepage .kr-offer-link:hover { gap: 10px !important; }
#kr-homepage .kr-offer-card-link { position: absolute !important; inset: 0 !important; z-index: 1 !important; }
#kr-homepage .kr-offer-card .kr-offer-link { position: relative !important; z-index: 2 !important; }
#kr-homepage .kr-offer-card.kr-hidden { opacity: 0 !important; pointer-events: none !important; display: none !important; }
#kr-homepage .kr-offer .kr-section-footer { text-align: center !important; margin-top: 36px !important; }
#kr-homepage .kr-offer .kr-btn-red { padding: 14px 40px !important; letter-spacing: .1em !important; }


/* ══════════════════════════════════════════════════════════
   3. BANERY
   ══════════════════════════════════════════════════════════ */
#kr-homepage .kr-banners { background: var(--white); padding: 48px 0; }
#kr-homepage .kr-banners-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
#kr-homepage .kr-banner { position: relative !important; display: block !important; min-height: 300px !important; overflow: hidden !important; text-decoration: none !important; }
#kr-homepage .kr-banner-img { position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; object-fit: cover !important; transition: transform .5s cubic-bezier(.4,0,.2,1) !important; display: block !important; }
#kr-homepage .kr-banner:hover .kr-banner-img { transform: scale(1.04) !important; }
#kr-homepage .kr-banner-overlay { position: absolute !important; inset: 0 !important; background: linear-gradient(to top, rgba(0,0,0,.80) 0%, rgba(0,0,0,.40) 50%, rgba(0,0,0,.10) 100%) !important; z-index: 1 !important; }
#kr-homepage .kr-banner-body { position: absolute !important; bottom: 0 !important; left: 0 !important; right: 0 !important; padding: 32px 36px !important; z-index: 2 !important; }
#kr-homepage .kr-banner-sub { font-size: 11px !important; font-weight: 800 !important; text-transform: uppercase !important; letter-spacing: .14em !important; color: var(--red) !important; margin: 0 0 10px !important; display: block !important; }
#kr-homepage .kr-banner-title { font-size: clamp(18px, 2vw, 26px) !important; font-weight: 900 !important; color: #fff !important; margin: 0 0 16px !important; text-transform: uppercase !important; line-height: 1.15 !important; }
#kr-homepage .kr-banner-desc { font-size: 13px !important; color: rgba(255,255,255,.88) !important; line-height: 1.6 !important; margin: 0 0 20px !important; display: none !important; }
#kr-homepage .kr-banner:hover .kr-banner-desc { display: block !important; }
#kr-homepage .kr-banner-btn { display: inline-flex !important; align-items: center !important; gap: 8px !important; font-size: 12px !important; font-weight: 800 !important; text-transform: uppercase !important; letter-spacing: .1em !important; color: #000 !important; background: #fff !important; border: none !important; padding: 13px 28px !important; border-radius: 6px !important; transition: background .2s, color .2s !important; }
#kr-homepage .kr-banner:hover .kr-banner-btn { background: var(--red) !important; border-color: var(--red) !important; color: #fff !important; }


/* ══════════════════════════════════════════════════════════
   4. BRANŻE
   ══════════════════════════════════════════════════════════ */
#kr-homepage .kr-industries { background: var(--white); }
#kr-homepage .kr-industries-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 12px !important; }
#kr-homepage .kr-industry-card { position: relative !important; overflow: hidden !important; min-height: 220px !important; cursor: pointer !important; border: none !important; border-radius: 2px !important; }
#kr-homepage .kr-industry-bg { position: absolute !important; inset: 0 !important; background-size: cover !important; background-position: center !important; transition: transform .5s cubic-bezier(.4,0,.2,1), filter .5s ease !important; z-index: 0 !important; filter: brightness(.7) saturate(.9) !important; }
#kr-homepage .kr-industry-card:hover .kr-industry-bg { transform: scale(1.05) !important; filter: none !important; }
#kr-homepage .kr-industry-bg::after { content: '' !important; position: absolute !important; inset: 0 !important; background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,.15) 60%, transparent 100%) !important; transition: background .4s !important; }
#kr-homepage .kr-industry-card:hover .kr-industry-bg::after { background: none !important; }
#kr-homepage .kr-industry-icon { width: 48px !important; height: 48px !important; background: rgba(255,255,255,.15) !important; border: 1.5px solid rgba(255,255,255,.3) !important; border-radius: 8px !important; display: flex !important; align-items: center !important; justify-content: center !important; margin-bottom: 12px !important; color: #fff !important; padding: 10px !important; backdrop-filter: blur(4px) !important; }
#kr-homepage .kr-industry-icon svg { width: 100% !important; height: 100% !important; }
#kr-homepage .kr-industry-card-inner { position: absolute !important; bottom: 0 !important; left: 0 !important; right: 0 !important; z-index: 1 !important; padding: 20px !important; transition: transform .4s cubic-bezier(.4,0,.2,1), opacity .3s !important; }
#kr-homepage .kr-industry-card:hover .kr-industry-card-inner { transform: translateY(-8px) !important; opacity: 0 !important; }
#kr-homepage .kr-industry-name { font-size: 15px !important; font-weight: 800 !important; color: #fff !important; margin: 0 !important; text-transform: uppercase !important; line-height: 1.3 !important; text-shadow: 0 1px 6px rgba(0,0,0,.6) !important; }
#kr-homepage .kr-industry-overlay { position: absolute !important; inset: 0 !important; background: rgba(227,6,19,0.82) !important; padding: 24px !important; display: flex !important; flex-direction: column !important; justify-content: flex-start !important; opacity: 0 !important; transform: translateY(20px) !important; transition: opacity .35s cubic-bezier(.4,0,.2,1), transform .35s cubic-bezier(.4,0,.2,1) !important; pointer-events: none !important; z-index: 2 !important; }
#kr-homepage .kr-industry-card:hover .kr-industry-overlay { opacity: 1 !important; transform: translateY(0) !important; pointer-events: all !important; }
#kr-homepage .kr-industry-overlay-name { font-size: 18px !important; font-weight: 900 !important; text-transform: uppercase !important; color: #fff !important; margin: auto 0 12px !important; letter-spacing: .04em !important; line-height: 1.2 !important; }
#kr-homepage .kr-industry-overlay-desc { font-size: 13px !important; color: rgba(255,255,255,.92) !important; line-height: 1.65 !important; margin: 0 0 16px !important; }
#kr-homepage .kr-industry-overlay-link { display: inline-flex !important; align-items: center !important; gap: 6px !important; font-size: 12px !important; font-weight: 800 !important; text-transform: uppercase !important; letter-spacing: .06em !important; color: #fff !important; transition: gap .2s !important; text-decoration: none !important; border-bottom: 1px solid rgba(255,255,255,.4) !important; padding-bottom: 2px !important; margin-top: auto !important; }
#kr-homepage .kr-industry-overlay-link:hover { gap: 10px !important; }
/* ══════════════════════════════════════════════════════════
   5. STATYSTYKI
   ══════════════════════════════════════════════════════════ */

   .kr-stats { background: var(--black); padding: 60px 0; position: relative; overflow: hidden; }
   .kr-stats-bg { position: absolute; inset: 0; z-index: 0; opacity: .05; pointer-events: none; }
   .kr-stats-bg svg { width: 100%; height: 100%; }
   .kr-stats .kr-wrap { position: relative; z-index: 1; text-align: center; }
   .kr-stats .kr-section-title--light { text-align: center !important; margin-bottom: 12px !important; padding: 0 !important; text-transform: uppercase !important; color: #fff !important; font-size: clamp(26px, 3.5vw, 42px) !important; }
   .kr-section-desc--light { font-size: 15px !important; color: rgba(255,255,255,.55) !important; line-height: 1.7 !important; margin: 0 auto 56px !important; max-width: 640px !important; text-align: center !important; display: block !important; }
   .stats-grid { display: grid !important; grid-template-columns: repeat(5, 1fr) !important; border: none !important; background: transparent !important; margin-top: 0 !important; gap: 0 !important; }
   .kr-stat { padding: 40px 24px !important; border: none !important; background: transparent !important; text-align: center !important; }
   .kr-stat-num { font-size: clamp(28px, 3vw, 34px) !important; font-weight: 900 !important; color: var(--red) !important; line-height: 1 !important; margin-bottom: 12px !important; }
   .stat-num { display: inline !important; }
   .kr-stat-label { font-size: 12px !important; font-weight: 800 !important; color: var(--white) !important; margin: 0 0 6px !important; text-transform: uppercase !important; letter-spacing: .08em !important; }
   .kr-stat-desc { font-size: 12px !important; color: rgba(255,255,255,.4) !important; margin: 0 !important; line-height: 1.5 !important; }

/* ══════════════════════════════════════════════════════════
   6. AKTUALNOŚCI
   ══════════════════════════════════════════════════════════ */
   .kr-news { background: var(--gray-l); }
.kr-news-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.kr-news-card { background: transparent; overflow: hidden; display: flex; flex-direction: column; opacity: 0; transform: translateY(20px); transition: opacity .5s ease, transform .5s ease; transition-delay: var(--stagger, 0s); border: none; box-shadow: none; }
.kr-news-card.kr-in { opacity: 1; transform: translateY(0); }
.kr-news-thumb { display: block; overflow: hidden; }
.kr-news-thumb img { width: 100%; height: 200px; object-fit: cover; display: block; transition: transform .4s; }
.kr-news-card:hover .kr-news-thumb img { transform: scale(1.05); }
.kr-news-body { padding: 14px 0 0; flex: 1; display: flex; flex-direction: column; background: transparent; }
.kr-news-date { font-size: 12px; font-weight: 600; color: var(--gray-m); display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.kr-news-date::before { content: ''; display: inline-block; width: 20px; height: 2px; background: var(--red); flex-shrink: 0; }
.kr-news-title { font-size: 15px; font-weight: 700; color: var(--black); margin: 0 0 8px; line-height: 1.4; flex: 1; text-transform: none; }
.kr-news-title a { color: inherit; transition: color .2s; text-decoration: none; }
.kr-news-title a:hover { color: var(--red); }
.kr-news-excerpt { font-size: 13px; color: var(--gray-m); line-height: 1.6; margin: 0; display: block; }
/* ══════════════════════════════════════════════════════════
   7. PARTNERZY
   ══════════════════════════════════════════════════════════ */

   .kr-partners { background: var(--white); padding: 40px 0 60px; overflow: hidden; }

   .kr-partners-overtitle { text-align: center !important; color: var(--red) !important; margin: 0 0 8px !important; display: block !important; width: 100% !important; }
   .kr-partners-label { text-align: center !important; font-size: 22px !important; font-weight: 800 !important; text-transform: uppercase !important; letter-spacing: .08em !important; color: var(--black) !important; margin: 0 0 32px !important; display: block !important; width: 100% !important; padding: 0 32px !important; }
   .kr-partners { background: var(--white); padding: 40px 0 60px; overflow: hidden; display: flex; flex-direction: column; align-items: center; gap: 0; }
   .kr-partners .kr-marquee-wrap { width: 100%; margin-bottom: 56px; }
   .kr-partners .kr-marquee-wrap:last-child { margin-bottom: 0; }

   .kr-marquee-wrap { overflow: hidden; position: relative; margin-bottom: 0; }
   .kr-marquee-wrap + .kr-marquee-wrap { margin-top: 48px; }
   .kr-marquee-wrap::before, .kr-marquee-wrap::after { content: ''; position: absolute; top: 0; bottom: 0; width: 100px; z-index: 2; pointer-events: none; }
   .kr-marquee-wrap::before { left: 0; background: linear-gradient(to right, var(--white), transparent); }
   .kr-marquee-wrap::after { right: 0; background: linear-gradient(to left, var(--white), transparent); }
   .kr-marquee-track { display: flex; width: max-content; }
   .kr-marquee-track--ltr { animation: kr-ltr 30s linear infinite; }
   .kr-marquee-track--rtl { animation: kr-rtl 30s linear infinite; }
   .kr-marquee-wrap:hover .kr-marquee-track { animation-play-state: paused; }
   @keyframes kr-ltr { from{transform:translateX(0)} to{transform:translateX(-50%)} }
   @keyframes kr-rtl { from{transform:translateX(-50%)} to{transform:translateX(0)} }
   #kr-homepage .kr-marquee-item { display: flex; align-items: center; justify-content: center; padding: 0 48px; flex-shrink: 0; }
   #kr-homepage .kr-marquee-item img { height: 40px !important; width: auto !important; max-width: 140px !important; object-fit: contain !important; filter: grayscale(1) opacity(.55) !important; transition: filter .3s !important; }
   #kr-homepage .kr-marquee-item:hover img { filter: grayscale(0) opacity(1) !important; }
   #kr-homepage .kr-industry-overlay-icon { width: 44px !important; height: 44px !important; background: rgba(255,255,255,.18) !important; border-radius: 8px !important; display: flex !important; align-items: center !important; justify-content: center !important; margin-bottom: 16px !important; color: #fff !important; padding: 10px !important; flex-shrink: 0 !important; }
   #kr-homepage .kr-industry-overlay-icon svg { width: 100% !important; height: 100% !important; }


/* ══════════════════════════════════════════════════════════
   8. FLOATING CTA
   ══════════════════════════════════════════════════════════ */
.kr-floating-cta { position: fixed; bottom: 80px; right: -300px; z-index: 850; background: var(--white); border: 1.5px solid var(--gray-b); box-shadow: 0 8px 40px rgba(0,0,0,.15); padding: 20px 24px; width: 270px; transition: right .4s cubic-bezier(.4,0,.2,1); border-left: 4px solid var(--red); }
.kr-floating-cta.visible { right: 16px; }
.kr-floating-cta-close { position: absolute; top: 8px; right: 10px; background: none; border: none; cursor: pointer; color: var(--gray-m); font-size: 18px; line-height: 1; padding: 2px 6px; }
.kr-floating-cta-title { font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--black); margin: 0 0 6px; }
.kr-floating-cta-desc { font-size: 12px; color: var(--gray-m); margin: 0 0 14px; line-height: 1.5; }
.kr-floating-cta-btn { display: block; width: 100%; background: var(--red); color: var(--white); border: none; padding: 11px; font-family: var(--font); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; cursor: pointer; text-align: center; transition: background .2s; text-decoration: none; }
.kr-floating-cta-btn:hover { background: var(--red-d); color: var(--white); }


/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  #kr-homepage .kr-offer-grid { grid-template-columns: repeat(2, 1fr) !important; }
  #kr-homepage .kr-offer-card:nth-child(3n) { border-right: 1.5px solid #e2e2e2 !important; }
  #kr-homepage .kr-offer-card:nth-child(2n) { border-right: none !important; }
  #kr-homepage .kr-industries-grid { grid-template-columns: repeat(2, 1fr) !important; }
  #kr-homepage .kr-news-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

@media (max-width: 768px) {
  #kr-homepage .kr-section { padding: 40px 0 !important; }
  #kr-homepage .kr-wrap { padding: 0 16px !important; }
  #kr-homepage .kr-hero { min-height: 420px !important; }
  #kr-homepage .kr-hero-inner { padding: 48px 20px !important; margin-left: 0 !important; max-width: 100% !important; }
  #kr-homepage .kr-hero-h1 { font-size: clamp(22px, 6vw, 32px) !important; }
  #kr-homepage .kr-hero-typewriter { font-size: clamp(22px, 6vw, 32px) !important; }
  #kr-homepage .kr-hero-btns { flex-direction: column !important; gap: 10px !important; }
  #kr-homepage .kr-btn-red, #kr-homepage .kr-btn-outline-white { width: 100% !important; justify-content: center !important;border-radius: 3px; }
  #kr-homepage .kr-offer-grid { grid-template-columns: 1fr !important; }
  #kr-homepage .kr-offer-card { border-right: none !important; }
  #kr-homepage .kr-offer-card:nth-child(3n) { border-right: none !important; }
  #kr-homepage .kr-offer-card:nth-last-child(-n+3) { border-bottom: 1.5px solid #e2e2e2 !important; }
  #kr-homepage .kr-offer-card:last-child { border-bottom: none !important; }
  #kr-homepage .kr-banners-grid { grid-template-columns: 1fr !important; }
  #kr-homepage .kr-banner { min-height: 240px !important; }
  #kr-homepage .kr-banner-body { padding: 24px !important; }
  #kr-homepage .kr-banner-title { font-size: 18px !important; }
  #kr-homepage .kr-industries-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
  #kr-homepage .kr-industry-card { min-height: 180px !important; }

  #kr-homepage .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
    #kr-homepage .kr-stat:nth-child(odd) { border-right: 1px solid rgba(255,255,255,.08) !important; }
    #kr-homepage .kr-stat:nth-child(even) { border-right: none !important; }
    #kr-homepage .kr-stat { padding: 24px 12px !important; }
    #kr-homepage .kr-stat-num { font-size: clamp(24px, 7vw, 40px) !important; white-space: nowrap !important; }


  #kr-homepage .kr-news-grid { grid-template-columns: 1fr !important; }
  #kr-homepage .kr-section-header--flex { flex-direction: column !important; align-items: flex-start !important; gap: 12px !important; }
  #kr-homepage .kr-section-title { font-size: clamp(18px, 5vw, 24px) !important; }
  #kr-homepage .kr-section-desc { font-size: 14px !important; }
  #kr-homepage .kr-marquee-item img { height: 44px !important; }
  #kr-homepage .kr-marquee-item { padding: 0 28px !important; }
}

@media (max-width: 480px) {
  #kr-homepage .stats-grid { grid-template-columns: repeat(2, 1fr) !important; }
  #kr-homepage .kr-stat:nth-child(3n) { border-right: 1px solid rgba(255,255,255,.08) !important; }
  #kr-homepage .kr-stat:nth-child(2n) { border-right: none !important; }
  #kr-homepage .kr-hero-badge { font-size: 9px !important; padding: 4px 10px !important; }
}

/* ── Reset Flatsome ─── */
#kr-homepage .container, #kr-homepage .row, #kr-homepage .col, #kr-homepage .section { all: unset; }


@media (hover: none) {
    #kr-homepage .kr-industry-card.tapped .kr-industry-overlay { opacity: 1 !important; transform: translateY(0) !important; pointer-events: all !important; }
    #kr-homepage .kr-industry-card.tapped .kr-industry-card-inner { opacity: 0 !important; }
    #kr-homepage .kr-banner-desc { display: block !important; }
    #kr-homepage .kr-offer-card.tapped { background: var(--red) !important; border-color: var(--red) !important; }
    #kr-homepage .kr-offer-card.tapped .kr-offer-icon { background: rgba(255,255,255,.18) !important; color: #fff !important; }
    #kr-homepage .kr-offer-card.tapped .kr-offer-name { color: #fff !important; }
    #kr-homepage .kr-offer-card.tapped .kr-offer-desc { color: rgba(255,255,255,.88) !important; }
    #kr-homepage .kr-offer-card.tapped .kr-offer-link { color: #fff !important; }
}


/* ── Oferta — opis na całą szerokość ── */
#kr-homepage .kr-offer-header > div { display: block; width: 100%; }
#kr-homepage .kr-offer-header .kr-section-desc { max-width: 100% !important; }


/* ── Aktualności — bez CAPS LOCK, mniejsza czcionka ── */
#kr-homepage .kr-news .kr-section-title {
    text-transform: none !important;
    font-size: clamp(18px, 2.2vw, 26px) !important;
}


/* ── Branże — overlay z widocznym zdjęciem w tle ── */
#kr-homepage .kr-industry-card:hover .kr-industry-bg {
    filter: none !important;
}


@media (max-width: 600px) {
  #kr-homepage .kr-offer-filters {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    padding-bottom: 8px !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }
  #kr-homepage .kr-offer-filters::-webkit-scrollbar { display: none !important; }
  #kr-homepage .kr-filter-btn {
    padding: 7px 14px !important;
    font-size: 10px !important;
    flex-shrink: 0 !important;
    white-space: nowrap !important;
  }
}


/* ── Statystyki — ostatni licznik wyśrodkowany ── */
@media (max-width: 768px) {
  #kr-homepage .stats-grid .kr-stat:last-child {
    grid-column: 1 / -1 !important;
    border-right: none !important;
  }
}


/* ── Statystyki — usuń linie Flatsome ── */
#kr-homepage section.kr-stats div.stats-grid div.kr-stat {
    border-top: none !important;
    border-bottom: none !important;
    border-left: none !important;
    border-right: none !important;
    box-shadow: none !important;
    outline: none !important;
}
