/*
Theme Name: Natanek Theme
Theme URI: https://natanek.important.is
Author: important.is
Description: Custom theme for Natanek Logistics
Version: 1.0.0
Text Domain: natanek
*/

/* ─── TOKENS ─── */
:root {
  --dark-900: #060D18;
  --dark-800: #0E1F30;
  --dark-700: #1C2B3A;
  --dark-600: #3D5268;
  --accent:   #007FDA;
  --accent-2: #0880B8;
  --light-100: #F4F6F8;
  --light-200: #E0E6EC;
  --white:    #FFFFFF;

  --text-w:   #FFFFFF;
  --text-w-m: rgba(255,255,255,0.5);
  --text-w-s: rgba(255,255,255,0.2);
  --text-d:   #060D18;
  --text-d-m: #3D5268;
  --text-d-s: rgba(6,13,24,0.5);

  --display: 'Saira Condensed', sans-serif;
  --body:    'Instrument Sans', sans-serif;

  --max-w:  1440px;
  --gutter: clamp(24px, 6.25vw, 96px);
  --r-sm:   4px;
  --r-md:   8px;

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --clip-size: 40px;
  --clip-corner: polygon(var(--clip-size) 0, 100% 0, 100% calc(100% - var(--clip-size)), calc(100% - var(--clip-size)) 100%, 0 100%, 0 var(--clip-size));

  /* Clip-path tokens — dla elementów mniejszych niż sekcyjne karty.
     Zsynchronizowane z home.css; style.css jest ładowany globalnie więc nav
     i inne strony też mają do nich dostęp. */
  --clip-sm:  8px;
  --clip-btn: 12px;
  --clip-md:  16px;
  --clip-lg:  20px;
  --clip-xl:  24px;

  --clip-corner-sm:  polygon(var(--clip-sm)  0, 100% 0, 100% calc(100% - var(--clip-sm)),  calc(100% - var(--clip-sm))  100%, 0 100%, 0 var(--clip-sm));
  --clip-corner-btn: polygon(var(--clip-btn) 0, 100% 0, 100% calc(100% - var(--clip-btn)), calc(100% - var(--clip-btn)) 100%, 0 100%, 0 var(--clip-btn));
  --clip-corner-md:  polygon(var(--clip-md)  0, 100% 0, 100% calc(100% - var(--clip-md)),  calc(100% - var(--clip-md))  100%, 0 100%, 0 var(--clip-md));
  --clip-corner-lg:  polygon(var(--clip-lg)  0, 100% 0, 100% calc(100% - var(--clip-lg)),  calc(100% - var(--clip-lg))  100%, 0 100%, 0 var(--clip-lg));
  --clip-corner-xl:  polygon(var(--clip-xl)  0, 100% 0, 100% calc(100% - var(--clip-xl)),  calc(100% - var(--clip-xl))  100%, 0 100%, 0 var(--clip-xl));

  /* Layout */
  --section-py: 160px;
  --section-py-lg: 200px;
  --max-w-content: 1246px;
  --page-gutter: clamp(24px, 12.5vw, 240px);

  /* Z-index scale */
  --z-page-scrollbar: 500;
  --z-nav: 1000;
  --z-modal: 9000;
  --z-noise: 9999;
}

/* ─── ACCESSIBILITY — szanuj preferencję redukcji ruchu ─── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
/* Delikatny, ZAWSZE widoczny pasek (Chrome/Safari) — stylowany ::-webkit-scrollbar
   wymusza klasyczny pasek rezerwujący szerokość, więc nie znika jak overlay macOS.
   UWAGA: świadomie NIE ustawiamy scrollbar-width/-color — w nowym Chromium te
   standardowe właściwości włączają natywny overlay (auto-chowanie) i nadpisują poniższe. */
html::-webkit-scrollbar { width: 10px; }
html::-webkit-scrollbar-track { background: transparent; }
html::-webkit-scrollbar-thumb {
  background: rgba(61, 82, 104, 0.5);
  border-radius: 8px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
html::-webkit-scrollbar-thumb:hover { background: rgba(61, 82, 104, 0.8); }
/* Stary truck/akcentowy custom scrollbar wyłączony */
.page-scrollbar { display: none !important; }

body {
  font-family: var(--body);
  font-size: 16px;
  color: var(--text-d);
  background: var(--dark-900);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { border: none; background: none; cursor: pointer; font-family: inherit; }

.container {
  max-width: var(--max-w);
  margin: 0 auto;
  padding-inline: var(--gutter);
  width: 100%;
}

/* ─── NAV ─── */
.site-nav {
  position: fixed;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - clamp(48px, 6vw, 96px));
  max-width: 1246px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 1000;
  pointer-events: none;
}
.site-nav > * { pointer-events: auto; }

.site-nav-logo {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; flex-shrink: 0;
  --fill-0: #FFFFFF;
}
.site-nav-logo-combined { height: 32px; width: auto; display: block; }
.site-nav.nav-on-light .site-nav-logo { --fill-0: #060D18; }

.site-nav-center {
  display: flex; align-items: center;
  background: rgba(6,13,24,0.6);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 4px;
  transition: background 0.4s cubic-bezier(0.16,1,0.3,1), border-color 0.4s cubic-bezier(0.16,1,0.3,1);
}
.site-nav.scrolled .site-nav-center { background: rgba(6,13,24,0.92); border-color: rgba(255,255,255,0.06); }
.site-nav.nav-on-light .site-nav-center { background: rgba(255,255,255,0.88); border-color: rgba(6,13,24,0.1); }
.site-nav.nav-on-light.scrolled .site-nav-center { background: rgba(255,255,255,0.97); border-color: rgba(6,13,24,0.08); }

.site-nav-link {
  display: block;
  padding: 14px 20px;
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.95);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.2s;
}
.site-nav-link:hover, .site-nav-link.site-nav-active { color: #60B8FF; }
.site-nav.nav-on-light .site-nav-link { color: rgba(6,13,24,0.75); }
.site-nav.nav-on-light .site-nav-link:hover,
.site-nav.nav-on-light .site-nav-link.site-nav-active { color: #005DB0; }

.site-nav-dd { position: relative; display: flex; align-items: center; }
.site-nav-dd-text {
  display: block;
  padding: 14px 6px 14px 20px;
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.95);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.2s;
}
.site-nav-dd:hover .site-nav-dd-text, .site-nav-dd.open .site-nav-dd-text { color: #60B8FF; }
.site-nav.nav-on-light .site-nav-dd-text { color: rgba(6,13,24,0.75); }
.site-nav.nav-on-light .site-nav-dd:hover .site-nav-dd-text,
.site-nav.nav-on-light .site-nav-dd.open .site-nav-dd-text { color: #005DB0; }

.site-nav-dd-btn {
  display: flex; align-items: center;
  padding: 14px 14px 14px 4px;
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,0.95);
  transition: color 0.2s;
}
.site-nav-dd:hover .site-nav-dd-btn, .site-nav-dd.open .site-nav-dd-btn { color: #60B8FF; }
.site-nav.nav-on-light .site-nav-dd-btn { color: rgba(6,13,24,0.75); }
.site-nav.nav-on-light .site-nav-dd:hover .site-nav-dd-btn,
.site-nav.nav-on-light .site-nav-dd.open .site-nav-dd-btn { color: #005DB0; }

.site-nav-dd-arrow { flex-shrink: 0; transition: transform 0.22s cubic-bezier(0.16,1,0.3,1); }
.site-nav-dd:hover .site-nav-dd-arrow, .site-nav-dd.open .site-nav-dd-arrow { transform: rotate(180deg); }

.site-nav-panel {
  position: absolute;
  top: 100%;
  left: 50%;
  min-width: 210px;
  padding: 10px 8px 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(-4px);
  transition: opacity 0.18s, visibility 0.18s, transform 0.22s cubic-bezier(0.16,1,0.3,1);
  pointer-events: none;
}
.site-nav-panel-inner {
  background: rgba(6,13,24,0.97);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 4px;
  padding: 8px;
}
.site-nav-dd:hover .site-nav-panel, .site-nav-dd.open .site-nav-panel {
  opacity: 1; visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.site-nav-panel-item {
  display: block;
  padding: 10px 16px;
  font-family: 'Instrument Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.68);
  text-decoration: none;
  border-radius: 2px;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.site-nav-panel-item:hover, .site-nav-panel-item.site-nav-active {
  background: rgba(0,127,218,0.14);
  color: #007FDA;
}

.nav-left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.nav-logo-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
}

.nav-tagline {
  font-family: 'Instrument Sans', sans-serif;
  font-size: 8px;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  white-space: nowrap;
  transition: color 0.2s;
}
.site-nav.nav-on-light .nav-tagline {
  color: rgba(6,13,24,0.4);
}
@media (max-width: 900px) { .nav-tagline { display: none; } }

.nav-cert-badges {
  display: flex;
  align-items: center;
  gap: 6px;
}
.nav-cert-badge {
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 700;
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  background: rgba(255,255,255,0.06);
  border: 0;
  border-radius: 0;
  clip-path: polygon(4px 0, 100% 0, 100% calc(100% - 4px), calc(100% - 4px) 100%, 0 100%, 0 4px);
  padding: 3px 6px;
  white-space: nowrap;
  transition: color 0.2s, background 0.2s;
}
.site-nav.nav-on-light .nav-cert-badge {
  color: rgba(6,13,24,0.45);
  background: rgba(6,13,24,0.05);
}
@media (max-width: 900px) { .nav-cert-badges { display: none; } }

.site-nav-cta {
  flex-shrink: 0;
  align-self: center;
  display: flex;
  align-items: center;
  background: #007FDA;
  color: #FFFFFF;
  padding: 14px 24px;
  border-radius: 0;
  clip-path: var(--clip-corner-btn);
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.2s;
}
.site-nav-cta:hover { opacity: 0.85; }

/* ─── BURGER (priority+ overflow) ─── */
/* Force [hidden] on nav children — overrides .site-nav-link { display: block } */
.site-nav-center > [hidden] { display: none !important; }

.site-nav-burger { position: relative; display: flex; align-items: center; }
.site-nav-burger-btn {
  display: flex; align-items: center; justify-content: center;
  padding: 14px 16px;
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,0.95);
  transition: color 0.2s;
}
.site-nav-burger-btn:hover,
.site-nav-burger.open .site-nav-burger-btn { color: #60B8FF; }
.site-nav.nav-on-light .site-nav-burger-btn { color: rgba(6,13,24,0.75); }
.site-nav.nav-on-light .site-nav-burger-btn:hover,
.site-nav.nav-on-light .site-nav-burger.open .site-nav-burger-btn { color: #005DB0; }

.site-nav-more-panel {
  position: absolute;
  top: 100%;
  right: 0;
  min-width: 220px;
  padding: 10px 0 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity 0.18s, visibility 0.18s, transform 0.22s cubic-bezier(0.16,1,0.3,1);
  pointer-events: none;
}
.site-nav-more-panel-inner {
  background: rgba(6,13,24,0.97);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 4px;
  padding: 8px;
  display: flex; flex-direction: column;
}
.site-nav.nav-on-light .site-nav-more-panel-inner {
  background: rgba(255,255,255,0.98);
  border-color: rgba(6,13,24,0.08);
}
.site-nav-burger.open .site-nav-more-panel {
  opacity: 1; visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.site-nav-more-panel .site-nav-link,
.site-nav-more-panel .site-nav-dd-text {
  display: block;
  padding: 10px 16px;
  font-size: 13px;
  letter-spacing: 0.3px;
  color: rgba(255,255,255,0.78);
  border-radius: 2px;
}
.site-nav.nav-on-light .site-nav-more-panel .site-nav-link,
.site-nav.nav-on-light .site-nav-more-panel .site-nav-dd-text {
  color: rgba(6,13,24,0.78);
}
.site-nav-more-panel .site-nav-link:hover,
.site-nav-more-panel .site-nav-dd-text:hover,
.site-nav-more-panel .site-nav-active {
  background: rgba(0,127,218,0.14);
  color: #007FDA;
}
/* When a dd is cloned into the burger panel, neutralize its dropdown UI */
.site-nav-more-panel .site-nav-dd { display: block; }
.site-nav-more-panel .site-nav-dd-btn,
.site-nav-more-panel .site-nav-panel { display: none; }

/* ─── FOOTER ─── */
.footer {
  background: var(--dark-900);
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 64px var(--gutter) 0;
}
.footer-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  gap: 80px;
  padding-bottom: 48px;
}
.footer-brand { flex: 0 0 280px; }
.footer-tagline {
  font-size: 13px;
  color: var(--text-w-m);
  line-height: 1.6;
  margin: 16px 0 24px;
}
.footer-social { display: flex; gap: 12px; }
.footer-social a {
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 4px;
  color: rgba(255,255,255,0.5);
  transition: color 0.2s, border-color 0.2s;
}
.footer-social a:hover { color: var(--accent); }

.footer-links { display: flex; gap: 64px; flex: 1; }
.footer-col { display: flex; flex-direction: column; gap: 12px; }
.footer-col-title {
  font-family: var(--display);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-w-m);
  margin-bottom: 4px;
}
.footer-col a {
  font-size: 14px;
  color: rgba(255,255,255,0.6);
  transition: color 0.2s;
}
.footer-col a:hover { color: var(--white); }

.footer-bottom {
  max-width: var(--max-w);
  margin: 0 auto;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-size: 12px;
  color: rgba(255,255,255,0.3);
}

/* ─── NOISE OVERLAY ─── */
.noise {
  position: fixed; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.03;
}

/* ─── REVEAL ANIMATION ─── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.reveal.visible { opacity: 1; transform: none; }

/* ─── FLUENT FORMS — dark theme override ─── */
.contact-form-box .fluentform,
.contact-form-box .fluentform_wrapper { width: 100%; }

/* Remove FF outer padding/bg */
.contact-form-box .ff-default { background: transparent !important; padding: 0 !important; }

/* Labels */
.contact-form-box .ff-el-input--label label {
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  margin-bottom: 8px;
}

/* Inputs & Textarea */
.contact-form-box .ff-el-form-control {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 0 !important;
  color: #ffffff !important;
  font-family: 'Instrument Sans', sans-serif !important;
  font-size: 15px !important;
  padding: 14px 16px !important;
  transition: border-color 0.2s !important;
  box-shadow: none !important;
  outline: none !important;
}
.contact-form-box .ff-el-form-control::placeholder { color: rgba(255,255,255,0.25) !important; }
.contact-form-box .ff-el-form-control:focus {
  border-color: rgba(0,127,218,0.6) !important;
  background: rgba(0,127,218,0.04) !important;
  box-shadow: none !important;
}

/* Textarea */
.contact-form-box textarea.ff-el-form-control { min-height: 120px !important; resize: vertical !important; }

/* Required asterisk */
.contact-form-box .ff-el-is-required .asterisk-right label::after { color: var(--accent) !important; }

/* Field groups spacing */
.contact-form-box .ff-el-group { margin-bottom: 20px !important; }
.contact-form-box .ff-t-container { gap: 16px !important; }
.contact-form-box .ff-t-cell { flex: 1 !important; }

/* Submit button */
.contact-form-box .ff-btn-submit,
.contact-form-box button[type="submit"] {
  background: var(--accent) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: 'Instrument Sans', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  letter-spacing: 0.04em !important;
  padding: 16px 32px !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: opacity 0.2s !important;
  box-shadow: none !important;
  text-transform: uppercase !important;
}
.contact-form-box .ff-btn-submit:hover { opacity: 0.85 !important; }

/* Success message */
.contact-form-box .ff-message-success {
  background: rgba(0,127,218,0.1) !important;
  border: 1px solid rgba(0,127,218,0.3) !important;
  color: rgba(255,255,255,0.85) !important;
  border-radius: 0 !important;
  font-family: 'Instrument Sans', sans-serif !important;
  padding: 20px 24px !important;
}

/* Error messages */
.contact-form-box .error { color: #ff6b6b !important; font-size: 12px !important; margin-top: 6px !important; }

/* Remove FF default wrapper margin */
.contact-form-box .frm-fluent-form { margin: 0 !important; }

/* Submit wrapper */
.contact-form-box .ff_submit_btn_wrapper { margin-top: 8px !important; }

/* ─── ICON — globalna base class dla wszystkich ikon (brand convention) ───
   Każdy <div> zawierający ikonkę (svg, badge, accent square) owiń w class="icon ..."
   Dziedziczy:
     - flex centering (svg w środku)
     - clip-path ścięcia 8px (brand corner)
   Klasa kontekstowa (.cert-card-icon, .value-icon, .jp-service-icon) dodaje size + color.
*/
.icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  clip-path: var(--clip-corner-sm);
}

/* ─── BUTTONS — globalna konwencja brand (wszystkie strony) ───
   Klasy .btn / .btn-primary / .btn-secondary / .btn-outline* / .btn--ghost*
   były wcześniej w home.css (front-page only). Przeniesione tutaj żeby
   przyciski na /o-nas/, /kontakt/, /zaplecze/, /sprzedaz-pojazdow/,
   /serwis/ i wszystkich spec pages renderowały się spójnie.

   Konwencja brand:
   - clip-path: var(--clip-corner-btn) ← 12px (spójny z .site-nav-cta i .form-submit-btn)
   - border: 0; border-radius: 0
   - text-transform: uppercase, font-weight: 600, font-size: 15px
*/
.btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 18px 40px;
  border: 0;
  border-radius: 0;
  clip-path: var(--clip-corner-btn);
  text-decoration: none;
  font-family: var(--body);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  transition: opacity 0.2s;
  cursor: pointer;
  white-space: nowrap;
}
.btn:hover { opacity: 0.85; }
.btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 4px; }

.btn-primary { background: var(--accent); color: var(--white); }
.btn-secondary { background: rgba(255,255,255,0.08); color: var(--white); }
.btn-secondary:hover { background: rgba(255,255,255,0.14); opacity: 1; }

.btn--ghost { background: rgba(255,255,255,0.08); color: var(--white); }
.btn--ghost:hover { background: rgba(255,255,255,0.14); opacity: 1; }
.btn--ghost-on-light { background: rgba(6,13,24,0.06); color: var(--text-d); }
.btn--ghost-on-light:hover { background: rgba(6,13,24,0.10); opacity: 1; }

.btn-outline { background: rgba(6,13,24,0.06); color: var(--text-d); }
.btn-outline:hover { background: rgba(6,13,24,0.10); opacity: 1; }
.btn-outline-dark { background: rgba(6,13,24,0.06); color: var(--text-d); }
.btn-outline-dark:hover { background: rgba(6,13,24,0.10); opacity: 1; }
.btn-white-outline { background: rgba(255,255,255,0.08); color: var(--white); }
.btn-white-outline:hover { background: rgba(255,255,255,0.14); opacity: 1; }

.btn-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.btn-arrow img { width: 16px; height: 16px; }

/* ─── CERT LOGO — globalna konwencja brand (single source via CPT 'cert') ───
   Renderowane przez natanek_render_cert_logo($slug, $size, $extra_class).
   ZMIANA STYLU TUTAJ → wszystkie cert-iconki na stronie się zaktualizują.
   Rozmiary: sm (48px), md (72px), lg (96px), xl (120px). */
.cert-logo {
  background: #fff;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  /* clip-path 8px z .icon (icon base class) */
}
.cert-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.cert-logo--sm { width: 64px; height: 64px; padding: 4px; }
.cert-logo--md { width: 112px; height: 112px; padding: 8px; }
.cert-logo--lg { width: 144px; height: 144px; padding: 10px; }
.cert-logo--xl { width: 180px; height: 180px; padding: 12px; }

/* ───────────────────────────────────────
   CROSS-NAV CARDS — globalne style dla
   shortcode [natanek_spec_cross_nav].
   Używane na każdej spec page (post_content).
   ─────────────────────────────────────── */
.cross-nav-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 900px) {
  .cross-nav-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 500px) {
  .cross-nav-grid { grid-template-columns: 1fr; }
}
.cross-nav-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--white);
  text-decoration: none;
  color: var(--text-d);
  clip-path: var(--clip-corner, polygon(40px 0,100% 0,100% calc(100% - 40px),calc(100% - 40px) 100%,0 100%,0 40px));
  border: 1px solid var(--border-on-light, rgba(6,13,24,0.08));
  transition: transform 0.4s var(--ease-out-expo, cubic-bezier(0.16,1,0.3,1)), box-shadow 0.3s ease;
  min-height: 280px;
}
.cross-nav-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.08);
}
.cross-nav-card-img {
  width: 100%;
  height: 140px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--light-100, #F4F6F8);
}
.cross-nav-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s var(--ease-out-expo, cubic-bezier(0.16,1,0.3,1));
}
.cross-nav-card:hover .cross-nav-card-img img { transform: scale(1.06); }
.cross-nav-card-body {
  padding: 24px 28px 28px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.cross-nav-card-eyebrow {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.cross-nav-card-title {
  font-family: var(--display);
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: 10px;
}
.cross-nav-card-desc {
  font-size: 0.875rem;
  color: var(--text-d-m);
  line-height: 1.5;
  flex-grow: 1;
  margin-bottom: 16px;
}
.cross-nav-card-arrow {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: gap 0.3s var(--ease-out-expo, cubic-bezier(0.16,1,0.3,1));
}
.cross-nav-card:hover .cross-nav-card-arrow { gap: 12px; }
