@charset "UTF-8";
/* =============================================================================
 * style.css
 * ============================================================================= */
@font-face {
  font-family: 'nook-theme';
  font-style: normal;
  font-weight: 400;
  font-display: swap; 
  src: url('fonts/nook-regular.woff2') format('woff2'), 
       url('fonts/nook-regular.woff') format('woff'); 
}

@font-face {
    font-family: 'nook-theme';
    font-style: normal;
    font-weight: 500;
    font-display: swap; 
    src: url('fonts/nook-500.woff2') format('woff2'), 
         url('fonts/nook-500.woff') format('woff'); 
  }

@font-face {
    font-family: 'nook-theme';
    font-style: normal;
    font-weight: 600;
    font-display: swap; 
    src: url('fonts/nook-600.woff2') format('woff2'), 
         url('fonts/nook-600.woff') format('woff'); 
  }

  @font-face {
    font-family: 'nook-theme';
    font-style: normal;
    font-weight: 700;
    font-display: swap; 
    src: url('fonts/nook-700.woff2') format('woff2'), 
         url('fonts/nook-700.woff') format('woff'); 
  }

  @font-face {
    font-family: 'nook-theme';
    font-style: normal;
    font-weight: 800;
    font-display: swap; 
    src: url('fonts/nook-800.woff2') format('woff2'), 
         url('fonts/nook-800.woff') format('woff'); 
  }

  @font-face {
    font-family: 'nook-theme';
    font-style: normal;
    font-weight: 900;
    font-display: swap; 
    src: url('fonts/nook-900.woff2') format('woff2'), 
         url('fonts/nook-900.woff') format('woff'); 
  }

  @font-face {
    font-family: 'nook-display';
    font-style: normal;
    font-weight: 400;
    font-display: swap; 
    src: url('fonts/nook-display.woff2') format('woff2'), 
         url('fonts/nook-display.woff') format('woff'); 
  }

/* div, section, header, footer, main, aside, ul, li, a, h1, h2, h3, h4, p {
    outline: 1px solid rgba(0, 200, 255, 0.5) !important;
}  */

:root {
  --nook-zindex-menu: 1000;
  --nook-zx-sm:5;
  --border-bottom: 1px solid #eee;
}

/* ==========================================================================
   1. DESIGN TOKENS (Centrum Dowodzenia)
   ========================================================================== */
   :root {
    /* TYPOGRAFIA */
    --base-font-family: 'nook-theme';
    --f-display: 'nook-display';
    --nook-fs-body: 0.875rem; /* 14px */
    --nook-fs-h5: 1rem;
    --nook-fs-h4: 1.125rem;
    --nook-fs-h3: 1.25rem;
    --nook-fs-h2: 1.375rem;
    --nook-fs-h1: 1.563rem;
    --nook-fs-card: 14px;
    --nook-fs-footer: 14px;
    --nook-ratio: 1.125;
    --nook-fs-medium: 0.8125rem;
    --nook-fs-small: 0.750rem;
    --nook-fs-xsmall: 0.750rem;
    --nook-fs-xxsmall: 0.750rem;
    --fs-hero: clamp(32px, 5vw, 56px); --lh-hero: 1.1;
    --nook-fs-menu-mob: 1.563rem;
    --nook-fs-menu: 0.875rem;
    --nook-fs-6: 2rem;
    --nook-fs-page-hero:2rem;

    --nook-lh-body: 1.5rem;
    --nook-lh-h5: 1.500rem;
    --nook-lh-h4: 1.750rem;
    --nook-lh-h3: 1.750rem;
    --nook-lh-h2: 1.750rem;
    --nook-lh-h1: 2rem;
    --nook-lh-small: 1rem;
    --nook-lh-xsmall: 1rem;
    --nook-lh-menu-mob: 2rem;
    --nook-lh-menu: 1.250rem;
    --nook-lh-6: 2.500rem;
    --nook-lh-page-hero:2.5rem;

    /* ODSTĘPY (8px Base) */
    --nook-unit: 4px;
    --nook-gap-xs: 4px;
    --nook-gap: calc(var(--nook-unit) * 4); /* 24px */
    --nook-gap-l: calc(var(--nook-unit) * 8); /* 32px */
    --nook-gap-xl: calc(var(--nook-unit) * 16); /* 64px */
    --nook-col-gap: 24px;

    --nook-sp-md: calc(var(--nook-unit) * 8); /* 32px */
    --nook-sp-lg: calc(var(--nook-unit) * 16);
    --nook-sp-xl: calc(var(--nook-unit) * 24);
    --nook-sp-5: calc(var(--nook-unit) * 12);
    --nook-sp-4: calc(var(--nook-unit) * 10);

    /* LAYOUT */
    --nook-max-width: 1240px;
    --nook-col-main: 65%;
    --nook-col-side: 35%;

    /* SKÓRA DOMYŚLNA (Neutral) */
    --nook-c-primary: #d4005d;
    --nook-c-secondary: #00FFFF;
    --nook-c-blue: #00338d;
    --nook-c-cyan: #00ffff;
    --nook-link: #F34D4F;
    --nook-c-text: #323232;
    --nook-c-white: #ffffff;
    --nook-c-mobilemenu:  #0F1228;
    --nook-c-featured: #f8f9fa;
    --nook-blue: #F34D4F;
    --nook-widget-bg: #F6F6F6;
    --nook-footer-bg: #F5F8FF;
    --nook-c-border: #eee;
    --nook-c-border-alt: #f0f0f0;
    --nook-c-dark-base: #0d0221;
    --pink: #ff00de;
    --blue: #00f6ff;
    --nook-bg-alt: #f8f9fa;
    --nook-c-meta: #767676;
    --nook-tag-alt:  #f0f0f0;
    --nook-c-title: #222222;
    --nook-form-holder: #777;
    --nook-c-breadcrumb: #767676;
    --neon-pink: #ff00de;
    --neon-blue: #00f6ff;
    --bg-dark: #050110;
    
    /* --- SPACING --- */
    --sp-1: calc(var(--nook-unit) * 1);
    --sp-2: calc(var(--nook-unit) * 2);
    --sp-3: calc(var(--nook-unit) * 3);
    --sp-4: calc(var(--nook-unit) * 4);
    --sp-5: calc(var(--nook-unit) * 5);
    --sp-6: calc(var(--nook-unit) * 6);
    --sp-8: calc(var(--nook-unit) * 8);
    --sp-10: calc(var(--nook-unit) * 10);
    --sp-12: calc(var(--nook-unit) * 12);
    --sp-16: calc(var(--nook-unit) * 16);
    --sp-20: calc(var(--nook-unit) * 20);

    --nook-section-pad: calc(var(--nook-unit) * 12);
    --nook-section-pad-lg: calc(var(--nook-unit) * 20);

    --nook-radius-lg: 30px;
    --nook-radius: 12px;
    --nook-radius-sm: 8px;
    --nook-radius-xs: 4px;
    --nook-font: 'nook-theme', system-ui, -apple-system, sans-serif;

    --nook-button-color: #FFF;
    --nook-button-border: 1px solid var(--nook-primary);

    --nook-bg-30: #fafafa;
    --nook-bg-50: #eee;
    --nook-bg-100: #dbdbdb;
    --nook-bg-page: #fafafa;    

    --nook-border-50: 1px solid #eee;
    --nook-border-100: 1px solid #dbdbdb;

    --nook-disabled-bg: #d3d3d3;
    --nook-disabled-color: #999;

    --nook-button-transition: filter 0.2s;
    --nook-transition: all 0.2s ease;
    --nook-transition-menu: all 0.4s ease-in-out;
    --trans: 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    --nook-transition-footer: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --nook-transition-footer-alt: 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    --nook-transition-toggle: 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}


 @supports (-webkit-touch-callout: none) {
 
    .ts-control input {
        font-size: 16px !important;
    }
 
}










.offer-description ul {
    list-style: disc;
    margin:1rem 0;
    padding-left: 2rem;
}


 
/* ----------------------------------------------------------------------------
/* Galeria
/* --------------------------------------------------------------------------*/
.nook-gallery-layout { display: flex; flex-direction: column; gap: 15px; }
.nook-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
}
.nook-gallery-featured img, .nook-gallery-grid img {
    width: 100%;
    height: auto;
    border-radius: var(--nook-radius);
    object-fit: cover;
}

/* ----------------------------------------------------------------------------
/* Section
/* --------------------------------------------------------------------------*/
.nook-header {
    margin-bottom: var(--sp-12);
}
.nook-header .eyebrow {
    font-size: var(--nook-fs-xxsmall);
    font-weight: 800;
    text-transform: uppercase;
    color: var(--nook-c-primary);
    letter-spacing: 0.25em;
    margin-bottom: var(--sp-2);
    display: block;
}
.nook-header .title {
    font-weight: 700;
    color: var(--nook-c-blue);
    letter-spacing: -0.02em;
    margin: 0;
}

/* ----------------------------------------------------------------------------
/* nook-critical.js
/* --------------------------------------------------------------------------*/
/* ----------------------------------------------------------------------------
/* Base
/* --------------------------------------------------------------------------*/
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  font-size: var(--nook-fs-body);
  line-height: var(--nook-lh-body);
  font-family: var(--base-font-family);
  color: var(--nook-c-text);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  font-weight: 400;
}

body:not(.front-page) {
  background-color: #fafafa;
}

body * {
  font-family: var(--base-font-family);
}

h1,
.h1 {
  font-size: var(--nook-fs-h1);
  line-height: var(--nook-lh-h1);
  font-weight: 600;
}

h2,
.h2 {
  font-size: var(--nook-fs-h2);
  line-height: var(--nook-lh-h2);
  font-weight: 600;
}

h3,
.h3 {
  font-size: var(--nook-fs-h3);
  line-height: var(--nook-lh-h3);
  font-weight: 600;
}

h4,
.h4 {
  font-size: var(--nook-fs-h4);
  line-height: var(--nook-lh-h4);
  font-weight: 600;
}

.font-small {
  font-size: var(--nook-fs-small);
  line-height: var(--nook-lh-small);
}

a {
  color: var(--nook-text);
  text-decoration: none;
}

a:hover {
  color: var(--nook-link);
}

.m-1 {
  margin: 4px;
}

.m-2 {
  margin: 8px;
}

.m-3 {
  margin: 12px;
}

.pt-8 {
  padding-top: calc(var(--nook-unit) * 8);
}

.mb-line {
  margin-bottom: var(--nook-lh-body);
}

.mb-card {
  margin-bottom: var(--nook-col-gap);
}

.mb-0 {
  margin-bottom: 0 !important;
}

.bg-30 {
  background: var(--nook-bg-30);
}

.bg-50 {
  background: var(--nook-bg-50);
}

.bg-100 {
  background: var(--nook-bg-100);
}

.bg-footer {
  background: var(--nook-footer-bg);
}

.nook-section-alt {
  padding-top: var(--nook-section-pad);
  padding-bottom: var(--nook-section-pad);
}

.nook-section-alt-lg {
  padding-top: var(--nook-section-pad-lg);
  padding-bottom: var(--nook-section-pad-lg);
}

.nook-section {
  margin-top: var(--nook-section-pad);
  margin-bottom: var(--nook-section-pad);
}

.bg-alt {
  background: var(--nook-bg-alt);
}

.bg-blue {
  background: var(--nook-c-blue);
}

.bg-efx1 {
  background: radial-gradient(circle at 50% 50%, rgba(139, 31, 221, 0.35) 0%, transparent 80%), radial-gradient(circle at 0% 50%, rgba(255, 0, 222, 0.4) 0%, transparent 60%), radial-gradient(circle at 100% 50%, rgba(0, 246, 255, 0.4) 0%, transparent 60%), #050110;
}

.p-relative {
  position: relative;
}

/* ----------------------------------------------------------------------------
/* Nook Theme
/* --------------------------------------------------------------------------*/
.section {
  margin-top: 40px;
  margin-bottom: 40px
}

@media (min-width:573px) {
  .section {
    margin-top: 40px;
    margin-bottom: 40px
  }
}

@media (min-width:1320px) {
  .section {
    margin-top: 100px;
    margin-bottom: 100px
  }
}

.section-inv {
  padding-top: 40px;
  padding-bottom: 40px
}

@media (min-width:573px) {
  .section-inv {
    padding-top: 40px;
    padding-bottom: 40px
  }
}

@media (min-width:1320px) {
  .section-inv {
    padding-top: 100px;
    padding-bottom: 100px
  }
}

.section-open {
  margin-top: 40px;
  margin-bottom: 40px
}

@media (min-width:1320px) {
  .section-open {
    margin-top: 40px;
    margin-bottom: 100px
  }
}

.section-open-inv {
  padding-top: 40px;
  padding-bottom: 40px
}

@media (min-width:1320px) {
  .section-open-inv {
    padding-top: 40px;
    padding-bottom: 100px
  }
}

.section-lg {
  margin-top: 40px;
  margin-bottom: 40px
}

@media (min-width:1320px) {
  .section-lg {
    margin-top: 100px;
    margin-bottom: 100px
  }
}

.section-lg-inv {
  padding-top: 40px;
  padding-bottom: 40px
}

@media (min-width:1320px) {
  .section-lg-inv {
    padding-top: 100px;
    padding-bottom: 100px
  }
}

.section-small {
  margin-top: 20px;
  margin-bottom: 20px
}

@media (min-width:1320px) {
  .section-small {
    margin-top: 40px;
    margin-bottom: 40px
  }
}

.section-small-inv {
  padding-top: 20px;
  padding-bottom: 20px
}

@media (min-width:1320px) {
  .section-small-inv {
    padding-top: 40px;
    padding-bottom: 40px
  }
}

a,
address,
blockquote,
body,
button,
caption,
dl,
fieldset,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
img,
input,
legend,
ol,
p,
pre,
select,
table,
td,
textarea,
th,
ul {
  margin: 0;
  padding: 0
}

ol,
ul {
  list-style: none
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 400
}

img {
  max-width: 100%;
  height: auto
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
mark,
nav,
section,
summary,
time {
  display: block
}

a img {
  border: 0
}

input,
textarea {
  outline: 0
}

html {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-y: scroll
}

.flex {
  display: flex
}

.inline-flex {
  display: inline-flex
}

.justify-start {
  justify-content: flex-start
}

.justify-center {
  justify-content: center
}

.justify-end {
  justify-content: flex-end
}

.justify-between {
  justify-content: space-between
}

.justify-around {
  justify-content: space-around
}

.justify-evenly {
  justify-content: space-evenly
}

.align-start {
  align-items: flex-start
}

.align-center {
  align-items: center
}

.align-end {
  align-items: flex-end
}

.align-stretch {
  align-items: stretch
}

.flex-1 {
  flex: 1 1 0
}

.flex-2 {
  flex: 2 1 0
}

.flex-3 {
  flex: 3 1 0
}

.flex-4 {
  flex: 4 1 0
}

.flex-auto {
  flex: 1 1 auto
}

.flex-none {
  flex: none
}

.gap-0 {
  gap: 0
}

.gap-25 {
  gap: 1px
}

.gap-50 {
  gap: 2px
}

.gap-100 {
  gap: 4px
}

.gap-150 {
  gap: 6px
}

.gap-200 {
  gap: 8px
}

.gap-300 {
  gap: 12px
}

@media (min-width:573px) {
  .flex-sm {
    display: flex
  }

  .inline-flex-sm {
    display: inline-flex
  }

  .justify-start-sm {
    justify-content: flex-start
  }

  .justify-center-sm {
    justify-content: center
  }

  .justify-end-sm {
    justify-content: flex-end
  }

  .justify-between-sm {
    justify-content: space-between
  }

  .justify-around-sm {
    justify-content: space-around
  }

  .justify-evenly-sm {
    justify-content: space-evenly
  }

  .align-start-sm {
    align-items: flex-start
  }

  .align-center-sm {
    align-items: center
  }

  .align-end-sm {
    align-items: flex-end
  }

  .align-stretch-sm {
    align-items: stretch
  }

  .flex-1-sm {
    flex: 1 1 0
  }

  .flex-2-sm {
    flex: 2 1 0
  }

  .flex-3-sm {
    flex: 3 1 0
  }

  .flex-4-sm {
    flex: 4 1 0
  }

  .flex-auto-sm {
    flex: 1 1 auto
  }

  .flex-none-sm {
    flex: none
  }

  .gap-0-sm {
    gap: 0
  }

  .gap-25-sm {
    gap: 1px
  }

  .gap-50-sm {
    gap: 2px
  }

  .gap-100-sm {
    gap: 4px
  }

  .gap-150-sm {
    gap: 6px
  }

  .gap-200-sm {
    gap: 8px
  }

  .gap-300-sm {
    gap: 12px
  }
}

@media (min-width:768px) {
  .flex-md {
    display: flex
  }

  .inline-flex-md {
    display: inline-flex
  }

  .justify-start-md {
    justify-content: flex-start
  }

  .justify-center-md {
    justify-content: center
  }

  .justify-end-md {
    justify-content: flex-end
  }

  .justify-between-md {
    justify-content: space-between
  }

  .justify-around-md {
    justify-content: space-around
  }

  .justify-evenly-md {
    justify-content: space-evenly
  }

  .align-start-md {
    align-items: flex-start
  }

  .align-center-md {
    align-items: center
  }

  .align-end-md {
    align-items: flex-end
  }

  .align-stretch-md {
    align-items: stretch
  }

  .flex-1-md {
    flex: 1 1 0
  }

  .flex-2-md {
    flex: 2 1 0
  }

  .flex-3-md {
    flex: 3 1 0
  }

  .flex-4-md {
    flex: 4 1 0
  }

  .flex-auto-md {
    flex: 1 1 auto
  }

  .flex-none-md {
    flex: none
  }

  .gap-0-md {
    gap: 0
  }

  .gap-25-md {
    gap: 1px
  }

  .gap-50-md {
    gap: 2px
  }

  .gap-100-md {
    gap: 4px
  }

  .gap-150-md {
    gap: 6px
  }

  .gap-200-md {
    gap: 8px
  }

  .gap-300-md {
    gap: 12px
  }
}

@media (min-width:1024px) {
  .flex-lg {
    display: flex
  }

  .inline-flex-lg {
    display: inline-flex
  }

  .justify-start-lg {
    justify-content: flex-start
  }

  .justify-center-lg {
    justify-content: center
  }

  .justify-end-lg {
    justify-content: flex-end
  }

  .justify-between-lg {
    justify-content: space-between
  }

  .justify-around-lg {
    justify-content: space-around
  }

  .justify-evenly-lg {
    justify-content: space-evenly
  }

  .align-start-lg {
    align-items: flex-start
  }

  .align-center-lg {
    align-items: center
  }

  .align-end-lg {
    align-items: flex-end
  }

  .align-stretch-lg {
    align-items: stretch
  }

  .flex-1-lg {
    flex: 1 1 0
  }

  .flex-2-lg {
    flex: 2 1 0
  }

  .flex-3-lg {
    flex: 3 1 0
  }

  .flex-4-lg {
    flex: 4 1 0
  }

  .flex-auto-lg {
    flex: 1 1 auto
  }

  .flex-none-lg {
    flex: none
  }

  .gap-0-lg {
    gap: 0
  }

  .gap-25-lg {
    gap: 1px
  }

  .gap-50-lg {
    gap: 2px
  }

  .gap-100-lg {
    gap: 4px
  }

  .gap-150-lg {
    gap: 6px
  }

  .gap-200-lg {
    gap: 8px
  }

  .gap-300-lg {
    gap: 12px
  }
}

@media (min-width:1320px) {
  .flex-xl {
    display: flex
  }

  .inline-flex-xl {
    display: inline-flex
  }

  .justify-start-xl {
    justify-content: flex-start
  }

  .justify-center-xl {
    justify-content: center
  }

  .justify-end-xl {
    justify-content: flex-end
  }

  .justify-between-xl {
    justify-content: space-between
  }

  .justify-around-xl {
    justify-content: space-around
  }

  .justify-evenly-xl {
    justify-content: space-evenly
  }

  .align-start-xl {
    align-items: flex-start
  }

  .align-center-xl {
    align-items: center
  }

  .align-end-xl {
    align-items: flex-end
  }

  .align-stretch-xl {
    align-items: stretch
  }

  .flex-1-xl {
    flex: 1 1 0
  }

  .flex-2-xl {
    flex: 2 1 0
  }

  .flex-3-xl {
    flex: 3 1 0
  }

  .flex-4-xl {
    flex: 4 1 0
  }

  .flex-auto-xl {
    flex: 1 1 auto
  }

  .flex-none-xl {
    flex: none
  }

  .gap-0-xl {
    gap: 0
  }

  .gap-25-xl {
    gap: 1px
  }

  .gap-50-xl {
    gap: 2px
  }

  .gap-100-xl {
    gap: 4px
  }

  .gap-150-xl {
    gap: 6px
  }

  .gap-200-xl {
    gap: 8px
  }

  .gap-300-xl {
    gap: 12px
  }
}

.flex-row {
  flex-direction: row
}

.flex-row-reverse {
  flex-direction: row-reverse
}

.flex-column {
  flex-direction: column
}

.flex-column-reverse {
  flex-direction: column-reverse
}

.flex-wrap {
  flex-wrap: wrap
}

.flex-nowrap {
  flex-wrap: nowrap
}

.order-0 {
  order: 0
}

.order-1 {
  order: 1
}

.order-2 {
  order: 2
}

.order-3 {
  order: 3
}

@media (min-width:573px) {
  .flex-row-sm {
    flex-direction: row
  }

  .flex-row-reverse-sm {
    flex-direction: row-reverse
  }

  .flex-column-sm {
    flex-direction: column
  }

  .flex-column-reverse-sm {
    flex-direction: column-reverse
  }

  .flex-wrap-sm {
    flex-wrap: wrap
  }

  .flex-nowrap-sm {
    flex-wrap: nowrap
  }

  .order-0-sm {
    order: 0
  }

  .order-1-sm {
    order: 1
  }

  .order-2-sm {
    order: 2
  }

  .order-3-sm {
    order: 3
  }
}

@media (min-width:768px) {
  .flex-row-md {
    flex-direction: row
  }

  .flex-row-reverse-md {
    flex-direction: row-reverse
  }

  .flex-column-md {
    flex-direction: column
  }

  .flex-column-reverse-md {
    flex-direction: column-reverse
  }

  .flex-wrap-md {
    flex-wrap: wrap
  }

  .flex-nowrap-md {
    flex-wrap: nowrap
  }

  .order-0-md {
    order: 0
  }

  .order-1-md {
    order: 1
  }

  .order-2-md {
    order: 2
  }

  .order-3-md {
    order: 3
  }
}

@media (min-width:1024px) {
  .flex-row-lg {
    flex-direction: row
  }

  .flex-row-reverse-lg {
    flex-direction: row-reverse
  }

  .flex-column-lg {
    flex-direction: column
  }

  .flex-column-reverse-lg {
    flex-direction: column-reverse
  }

  .flex-wrap-lg {
    flex-wrap: wrap
  }

  .flex-nowrap-lg {
    flex-wrap: nowrap
  }

  .order-0-lg {
    order: 0
  }

  .order-1-lg {
    order: 1
  }

  .order-2-lg {
    order: 2
  }

  .order-3-lg {
    order: 3
  }
}

@media (min-width:1320px) {
  .flex-row-xl {
    flex-direction: row
  }

  .flex-row-reverse-xl {
    flex-direction: row-reverse
  }

  .flex-column-xl {
    flex-direction: column
  }

  .flex-column-reverse-xl {
    flex-direction: column-reverse
  }

  .flex-wrap-xl {
    flex-wrap: wrap
  }

  .flex-nowrap-xl {
    flex-wrap: nowrap
  }

  .order-0-xl {
    order: 0
  }

  .order-1-xl {
    order: 1
  }

  .order-2-xl {
    order: 2
  }

  .order-3-xl {
    order: 3
  }
}

.w-100 {
  width: 100%
}

.h-100 {
  height: 100%
}

.display-block {
  display: block
}

.display-none {
  display: none
}

.position-absolute {
  position: absolute
}

.position-relative {
  position: relative
}

.position-static {
  position: static
}

@media (min-width:573px) {
  .w-100-sm {
    width: 100%
  }

  .h-100-sm {
    height: 100%
  }

  .display-block-sm {
    display: block
  }

  .display-none-sm {
    display: none
  }

  .position-absolute-sm {
    position: absolute
  }

  .position-relative-sm {
    position: relative
  }

  .position-static-sm {
    position: static
  }
}

@media (min-width:768px) {
  .w-100-md {
    width: 100%
  }

  .h-100-md {
    height: 100%
  }

  .display-block-md {
    display: block
  }

  .display-none-md {
    display: none
  }

  .position-absolute-md {
    position: absolute
  }

  .position-relative-md {
    position: relative
  }

  .position-static-md {
    position: static
  }
}

@media (min-width:1024px) {
  .w-100-lg {
    width: 100%
  }

  .h-100-lg {
    height: 100%
  }

  .display-block-lg {
    display: block
  }

  .display-none-lg {
    display: none
  }

  .position-absolute-lg {
    position: absolute
  }

  .position-relative-lg {
    position: relative
  }

  .position-static-lg {
    position: static
  }
}

@media (min-width:1320px) {
  .w-100-xl {
    width: 100%
  }

  .h-100-xl {
    height: 100%
  }

  .display-block-xl {
    display: block
  }

  .display-none-xl {
    display: none
  }

  .position-absolute-xl {
    position: absolute
  }

  .position-relative-xl {
    position: relative
  }

  .position-static-xl {
    position: static
  }
}

.txt-right {
  text-align: right
}

.txt-center {
  text-align: center
}

.txt-left {
  text-align: left
}

.txt-bold {
  font-weight: 700
}

.txt-normal {
  font-weight: 400
}

.txt-uppercase {
  text-transform: uppercase
}

@media (min-width:573px) {
  .txt-right-sm {
    text-align: right
  }

  .txt-center-sm {
    text-align: center
  }

  .txt-left-sm {
    text-align: left
  }

  .txt-bold-sm {
    font-weight: 700
  }

  .txt-normal-sm {
    font-weight: 400
  }

  .txt-uppercase-sm {
    text-transform: uppercase
  }
}

@media (min-width:768px) {
  .txt-right-md {
    text-align: right
  }

  .txt-center-md {
    text-align: center
  }

  .txt-left-md {
    text-align: left
  }

  .txt-bold-md {
    font-weight: 700
  }

  .txt-normal-md {
    font-weight: 400
  }

  .txt-uppercase-md {
    text-transform: uppercase
  }
}

@media (min-width:1024px) {
  .txt-right-lg {
    text-align: right
  }

  .txt-center-lg {
    text-align: center
  }

  .txt-left-lg {
    text-align: left
  }

  .txt-bold-lg {
    font-weight: 700
  }

  .txt-normal-lg {
    font-weight: 400
  }

  .txt-uppercase-lg {
    text-transform: uppercase
  }
}

@media (min-width:1320px) {
  .txt-right-xl {
    text-align: right
  }

  .txt-center-xl {
    text-align: center
  }

  .txt-left-xl {
    text-align: left
  }

  .txt-bold-xl {
    font-weight: 700
  }

  .txt-normal-xl {
    font-weight: 400
  }

  .txt-uppercase-xl {
    text-transform: uppercase
  }
}

.img-fill img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center
}

.ratio-16-9 img {
  aspect-ratio: 16/9
}

.ratio-9-16 img {
  aspect-ratio: 9/16
}

.ratio-4-5 img {
  aspect-ratio: 4/5
}

.ratio-5-4 img {
  aspect-ratio: 5/4
}

.ratio-4-3 img {
  aspect-ratio: 4/3
}

.ratio-3-4 img {
  aspect-ratio: 3/4
}

.ratio-2-3 img {
  aspect-ratio: 2/3
}

.ratio-3-2 img {
  aspect-ratio: 3/2
}

.ratio-1-1 img {
  aspect-ratio: 1/1
}

@media (min-width:573px) {
  .ratio-sm-16-9 img {
    aspect-ratio: 16/9
  }

  .ratio-sm-9-16 img {
    aspect-ratio: 9/16
  }

  .ratio-sm-4-5 img {
    aspect-ratio: 4/5
  }

  .ratio-sm-5-4 img {
    aspect-ratio: 5/4
  }

  .ratio-sm-4-3 img {
    aspect-ratio: 4/3
  }

  .ratio-sm-3-4 img {
    aspect-ratio: 3/4
  }

  .ratio-sm-2-3 img {
    aspect-ratio: 2/3
  }

  .ratio-sm-3-2 img {
    aspect-ratio: 3/2
  }

  .ratio-sm-1-1 img {
    aspect-ratio: 1/1
  }
}

@media (min-width:768px) {
  .ratio-md-16-9 img {
    aspect-ratio: 16/9
  }

  .ratio-md-9-16 img {
    aspect-ratio: 9/16
  }

  .ratio-md-4-5 img {
    aspect-ratio: 4/5
  }

  .ratio-md-5-4 img {
    aspect-ratio: 5/4
  }

  .ratio-md-4-3 img {
    aspect-ratio: 4/3
  }

  .ratio-md-3-4 img {
    aspect-ratio: 3/4
  }

  .ratio-md-2-3 img {
    aspect-ratio: 2/3
  }

  .ratio-md-3-2 img {
    aspect-ratio: 3/2
  }

  .ratio-md-1-1 img {
    aspect-ratio: 1/1
  }
}

@media (min-width:1024px) {
  .ratio-lg-16-9 img {
    aspect-ratio: 16/9
  }

  .ratio-lg-9-16 img {
    aspect-ratio: 9/16
  }

  .ratio-lg-4-5 img {
    aspect-ratio: 4/5
  }

  .ratio-lg-5-4 img {
    aspect-ratio: 5/4
  }

  .ratio-lg-4-3 img {
    aspect-ratio: 4/3
  }

  .ratio-lg-3-4 img {
    aspect-ratio: 3/4
  }

  .ratio-lg-2-3 img {
    aspect-ratio: 2/3
  }

  .ratio-lg-3-2 img {
    aspect-ratio: 3/2
  }

  .ratio-lg-1-1 img {
    aspect-ratio: 1/1
  }
}

@media (min-width:1320px) {
  .ratio-xl-16-9 img {
    aspect-ratio: 16/9
  }

  .ratio-xl-9-16 img {
    aspect-ratio: 9/16
  }

  .ratio-xl-4-5 img {
    aspect-ratio: 4/5
  }

  .ratio-xl-5-4 img {
    aspect-ratio: 5/4
  }

  .ratio-xl-4-3 img {
    aspect-ratio: 4/3
  }

  .ratio-xl-3-4 img {
    aspect-ratio: 3/4
  }

  .ratio-xl-2-3 img {
    aspect-ratio: 2/3
  }

  .ratio-xl-3-2 img {
    aspect-ratio: 3/2
  }

  .ratio-xl-1-1 img {
    aspect-ratio: 1/1
  }
}

.line-x1 {
  padding-bottom: 20px
}

.line-x2 {
  padding-bottom: 40px
}

@media (min-width:573px) {
  .line-x1-sm {
    padding-bottom: 20px
  }

  .line-x2-sm {
    padding-bottom: 40px
  }
}

@media (min-width:768px) {
  .line-x1-md {
    padding-bottom: 20px
  }

  .line-x2-md {
    padding-bottom: 40px
  }
}

@media (min-width:1024px) {
  .line-x1-lg {
    padding-bottom: 20px
  }

  .line-x2-lg {
    padding-bottom: 40px
  }
}

@media (min-width:1320px) {
  .line-x1-xl {
    padding-bottom: 20px
  }

  .line-x2-xl {
    padding-bottom: 40px
  }
}

body,
html {
  -webkit-text-size-adjust: 100%
}

.container,
.container-fluid {
  width: 100%;
  margin-right: auto;
  margin-left: auto
}

.container,
.container-fluid,
.container-fluid-full {
  padding-right: 24px;
  padding-left: 24px
}

.container-fluid-full.no-gutter,
.container-fluid-full:has(.container) {
  padding-left: 0;
  padding-right: 0
}

@media (min-width:1320px) {
  .container {
    max-width: 1320px
  }
}

*,
::after,
::before {
  box-sizing: border-box
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin-left: -12px;
  margin-right: -12px
}

.row>[class*=col-] {
  padding-left: 12px;
  padding-right: 12px
}

.row-full {
  margin-left: 0;
  margin-right: 0
}

.col-1 {
  flex: 0 0 8.33%;
  max-width: 8.33%
}

.col-2 {
  flex: 0 0 16.67%;
  max-width: 16.67%
}

.col-3 {
  flex: 0 0 25%;
  max-width: 25%
}

.col-4 {
  flex: 0 0 33.33%;
  max-width: 33.33%
}

.col-5 {
  flex: 0 0 41.67%;
  max-width: 41.67%
}

.col-6 {
  flex: 0 0 50%;
  max-width: 50%
}

.col-7 {
  flex: 0 0 58.33%;
  max-width: 58.33%
}

.col-8 {
  flex: 0 0 66.6667%;
  max-width: 66.6667%
}

.col-9 {
  flex: 0 0 75%;
  max-width: 75%
}

.col-10 {
  flex: 0 0 83.33%;
  max-width: 83.33%
}

.col-11 {
  flex: 0 0 91.67%;
  max-width: 91.67%
}

.col-12 {
  flex: 0 0 100%;
  max-width: 100%
}

@media (min-width:573px) {
  .col-sm-1 {
    flex: 0 0 8.33%;
    max-width: 8.33%
  }

  .col-sm-2 {
    flex: 0 0 16.67%;
    max-width: 16.67%
  }

  .col-sm-3 {
    flex: 0 0 25%;
    max-width: 25%
  }

  .col-sm-4 {
    flex: 0 0 33.33%;
    max-width: 33.33%
  }

  .col-sm-5 {
    flex: 0 0 41.67%;
    max-width: 41.67%
  }

  .col-sm-6 {
    flex: 0 0 50%;
    max-width: 50%
  }

  .col-sm-7 {
    flex: 0 0 58.33%;
    max-width: 58.33%
  }

  .col-sm-8 {
    flex: 0 0 66.6667%;
    max-width: 66.6667%
  }

  .col-sm-9 {
    flex: 0 0 75%;
    max-width: 75%
  }

  .col-sm-10 {
    flex: 0 0 83.33%;
    max-width: 83.33%
  }

  .col-sm-11 {
    flex: 0 0 91.67%;
    max-width: 91.67%
  }

  .col-sm-12 {
    flex: 0 0 100%;
    max-width: 100%
  }
}

@media (min-width:768px) {
  .col-md-1 {
    flex: 0 0 8.33%;
    max-width: 8.33%
  }

  .col-md-2 {
    flex: 0 0 16.67%;
    max-width: 16.67%
  }

  .col-md-3 {
    flex: 0 0 25%;
    max-width: 25%
  }

  .col-md-4 {
    flex: 0 0 33.33%;
    max-width: 33.33%
  }

  .col-md-5 {
    flex: 0 0 41.67%;
    max-width: 41.67%
  }

  .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%
  }

  .col-md-7 {
    flex: 0 0 58.33%;
    max-width: 58.33%
  }

  .col-md-8 {
    flex: 0 0 66.6667%;
    max-width: 66.6667%
  }

  .col-md-9 {
    flex: 0 0 75%;
    max-width: 75%
  }

  .col-md-10 {
    flex: 0 0 83.33%;
    max-width: 83.33%
  }

  .col-md-11 {
    flex: 0 0 91.67%;
    max-width: 91.67%
  }

  .col-md-12 {
    flex: 0 0 100%;
    max-width: 100%
  }
}

@media (min-width:1024px) {
  .col-lg-1 {
    flex: 0 0 8.33%;
    max-width: 8.33%
  }

  .col-lg-2 {
    flex: 0 0 16.67%;
    max-width: 16.67%
  }

  .col-lg-3 {
    flex: 0 0 25%;
    max-width: 25%
  }

  .col-lg-4 {
    flex: 0 0 33.33%;
    max-width: 33.33%
  }

  .col-lg-5 {
    flex: 0 0 41.67%;
    max-width: 41.67%
  }

  .col-lg-6 {
    flex: 0 0 50%;
    max-width: 50%
  }

  .col-lg-7 {
    flex: 0 0 58.33%;
    max-width: 58.33%
  }

  .col-lg-8 {
    flex: 0 0 66.6667%;
    max-width: 66.6667%
  }

  .col-lg-9 {
    flex: 0 0 75%;
    max-width: 75%
  }

  .col-lg-10 {
    flex: 0 0 83.33%;
    max-width: 83.33%
  }

  .col-lg-11 {
    flex: 0 0 91.67%;
    max-width: 91.67%
  }

  .col-lg-12 {
    flex: 0 0 100%;
    max-width: 100%
  }
}

@media (min-width:1320px) {
  .col-xl-1 {
    flex: 0 0 8.33%;
    max-width: 8.33%
  }

  .col-xl-2 {
    flex: 0 0 16.67%;
    max-width: 16.67%
  }

  .col-xl-3 {
    flex: 0 0 25%;
    max-width: 25%
  }

  .col-xl-4 {
    flex: 0 0 33.33%;
    max-width: 33.33%
  }

  .col-xl-5 {
    flex: 0 0 41.67%;
    max-width: 41.67%
  }

  .col-xl-6 {
    flex: 0 0 50%;
    max-width: 50%
  }

  .col-xl-7 {
    flex: 0 0 58.33%;
    max-width: 58.33%
  }

  .col-xl-8 {
    flex: 0 0 66.6667%;
    max-width: 66.6667%
  }

  .col-xl-9 {
    flex: 0 0 75%;
    max-width: 75%
  }

  .col-xl-10 {
    flex: 0 0 83.33%;
    max-width: 83.33%
  }

  .col-xl-11 {
    flex: 0 0 91.67%;
    max-width: 91.67%
  }

  .col-xl-12 {
    flex: 0 0 100%;
    max-width: 100%
  }
}

.no-gutters {
  margin-left: 0 !important;
  margin-right: 0 !important
}

.no-gutters>[class*=col-] {
  padding-left: 0 !important;
  padding-right: 0 !important
}

.col-auto {
  flex: 0 0 auto;
  width: auto;
  max-width: 100%
}

.col-fill {
  flex: 1 0 0%
}

.grid-cols_2,
.grid-cols_3,
.grid-cols_4 {
  display: grid;
  grid-auto-flow: row;
  grid-template-columns: 1fr;
  gap: 20px;
  padding-left: 12px;
  padding-right: 12px
}

@media (min-width:573px) {
  .grid-cols_2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 60px
  }

  .grid-cols_3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 60px
  }

  .grid-cols_4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 60px
  }
}

/* ----------------------------------------------------------------------------
/* nook-main.css
/* --------------------------------------------------------------------------*/
/* ----------------------------------------------------------------------------
/* Przyciski
/* --------------------------------------------------------------------------*/
.nook-btn,
button[type="submit"],
.btn-submit {
  display: inline-block;
  background: var(--nook-primary);
  color: var(--nook-button-color);
  padding: 14px 28px;
  border-radius: var(--nook-radius);
  font-weight: 700;
  border: var(--nook-button-border);
  cursor: pointer;
  text-align: center;
  transition: var(--nook-button-transition);
}

.nook-btn:hover,
button[type="submit"]:hover:not(:disabled),
.btn-submit:hover {
  filter: brightness(1.2);
}

.nook-btn:disabled {
  background: #ccc;
  cursor: not-allowed;
  transform: none;
}

/* ----------------------------------------------------------------------------
/* Select, input, textarea
/* --------------------------------------------------------------------------*/
.nook-select,
.nook-input,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
textarea,
select {
  border: var(--nook-border-50);
  border-radius: var(--nook-radius);
  background: #fff;
  font-family: inherit;
  font-size: var(--nook-fs-body);
  line-height: var(--nook-lh-body);
}

.nook-select,
.nook-input,
textarea,
select {
  width: 100%;
  padding: 14px !important;
}

/* ----------------------------------------------------------------------------
/* Forms
/* --------------------------------------------------------------------------*/
/* ---- LAYOUT PÓL ---- */
.form-group {
  display: flex; flex-direction: column; gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

.form-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
@media (max-width: 573px) {
  .form-row { grid-template-columns: 1fr; }
}

/* ---- ETYKIETY ---- */
.form-group label,
.wpcf7-form label {
  font-size: var(--nook-fs-xsmall);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--nook-c-meta);
}

/* ---- POLA INPUT ---- */
.form-group input,
.form-group textarea,
.form-group select,
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="date"],
.wpcf7-form textarea,
.wpcf7-form select {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  border: var(--nook-border-50);
  border-radius: var(--nook-radius-sm);
  font-family: var(--nook-font);
  font-size: var(--nook-fs-body);
  color: var(--nook-c-text);
  background: var(--nook-bg-page);
  outline: none;
  transition: var(--nook-transition);
  -webkit-appearance: none;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus,
.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
  border-color: var(--nook-c-blue);
  background: var(--nook-c-white);
  box-shadow: 0 0 0 3px rgba(0,51,141,0.06);
}

.wpcf7-form textarea { resize: vertical; min-height: 120px; }

/* ---- SUBMIT ---- */
.wpcf7-form input[type="submit"] {
  width: 100%;
  padding: var(--sp-4) var(--sp-8);
  background: var(--nook-c-primary);
  color: var(--nook-c-white);
  border: none;
  border-radius: var(--nook-radius-sm);
  font-family: var(--nook-font);
  font-size: var(--nook-fs-body);
  font-weight: 700;
  cursor: pointer;
  transition: var(--nook-transition);
  box-shadow: 0 4px 14px rgba(212,0,93,0.22);
}
.wpcf7-form input[type="submit"]:hover { filter: brightness(0.9); }

/* ---- NOTA PRYWATNOŚCI ---- */
.form-note {
  font-size: var(--nook-fs-xsmall);
  color: var(--nook-c-meta);
  text-align: center;
  margin-top: var(--sp-3);
  line-height: 1.5;
}

/* ---- WALIDACJA CF7 ---- */
.wpcf7-not-valid-tip {
  font-size: var(--nook-fs-xsmall);
  color: var(--nook-c-primary);
  margin-top: var(--sp-2);
  display: block;
}
.wpcf7-not-valid {
  border-color: var(--nook-c-primary) !important;
}
.wpcf7-response-output {
  margin-top: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--nook-radius-sm);
  font-size: var(--nook-fs-small);
  border: var(--nook-border-50) !important;
}

/* ---- UKRYTE POLA CF7 (kreator wyceny) ---- */
.wpcf7-form .sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}


/* ----------------------------------------------------------------------------
/* Header & Logo
/* --------------------------------------------------------------------------*/
.nook-site-header {
  height: 72px;
}
body:not(.front-page) .nook-site-header {
  border-bottom: 1px solid var(--nook-c-border-alt);
  background: #FFF;
  box-shadow: 0 4px 20px #0000000d;
  position: fixed;
  top:0;
  left:0;
  width:100%;
  z-index: 10000;
}
body:not(.front-page) main {
  padding-top: 72px;
}
.custom-logo { 
  max-width: 60px;
}
@media(min-width: 1024px) {
  .custom-logo { 
      max-width: 60px;
  }    
}
.nook-site-header .custom-logo { 
  display: block; 
}

.logo { 
  font-weight: 900;
  color: var(--nook-c-white); 
  letter-spacing: -0.02em; 
  text-transform: uppercase; 
}
body.front-page .nook-site-header:not(.sticky) .logo:hover {
  color: #FFF;
}
.logo span { 
  color: var(--nook-c-primary); 
}
body:not(.front-page) .logo {
  color: var(--nook-c-blue);
}
body:not(.front-page) .logo span {
  color: var(--nook-c-primary);
}
.nook-f .brand-space .logo  {
  color: #FFF;
}

/* ----------------------------------------------------------------------------
/* Logo efx
/* --------------------------------------------------------------------------*/
.efx1 {
  position: relative;
  display: inline-block;
  text-decoration: none;
  font-size: 1.8rem;
  font-weight: 900;
  user-select: none;
  animation: heavy-shake 6s infinite step-end;
}

.efx1 span {
  color: inherit;
}

.efx1::before,
.efx1::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  pointer-events: none;
}

.efx1::before {
  color: var(--pink);
  z-index: -1;
  animation: glitch-vfx-1 6s infinite step-end;
}

.efx1::after {
  color: var(--blue);
  z-index: -2;
  animation: glitch-vfx-2 6s infinite step-end;
}

@keyframes glitch-vfx-1 {
  0%, 90% { opacity: 0; transform: translate(0); }
  91% { opacity: 1; transform: translate(-8px, 4px); clip-path: inset(10% 0 80% 0); }
  92% { opacity: 1; transform: translate(8px, -4px); clip-path: inset(40% 0 30% 0); }
  93% { opacity: 0; }
  95% { opacity: 1; transform: translate(-5px); clip-path: inset(70% 0 10% 0); }
  96% { opacity: 0; }
}

@keyframes glitch-vfx-2 {
  0%, 90% { opacity: 0; transform: translate(0); }
  91% { opacity: 1; transform: translate(10px, -2px); clip-path: inset(20% 0 60% 0); }
  92% { opacity: 1; transform: translate(-10px, 2px); clip-path: inset(50% 0 20% 0); }
  94% { opacity: 0; }
  97% { opacity: 1; transform: translate(5px); clip-path: inset(10% 0 70% 0); }
  98% { opacity: 0; }
}

@keyframes heavy-shake {
  0%, 90% { transform: translate(0); }
  91% { transform: translate(-2px, 2px); }
  92% { transform: translate(2px, -2px); }
  93% { transform: translate(-1px, -1px); }
  94% { transform: translate(0); }
}

.sticky .efx1, 
.sticky .efx1::before,
.sticky .efx1::after,
.sticky .efx1 * { animation: none !important;}

/* ----------------------------------------------------------------------------
/* Quick CTA
/* --------------------------------------------------------------------------*/
.nook-quick-cta {
  display: inline-flex;
  align-items: center;
  padding: 0.65rem 1.4rem;
  border-radius: var(--nook-radius);
  font-weight: 800;
  text-transform: uppercase;
  font-size: 0.8rem;
  letter-spacing: 0.8px;
  transition: var(--trans);
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  position: relative;
}
.front-page .nook-quick-cta {
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.25);
  color: #ffffff;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}
.front-page .nook-quick-cta:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.5);
  box-shadow: 0 8px 32px rgba(212, 0, 93, 0.2);
}
.nook-quick-cta,
.nook-site-header.sticky .nook-quick-cta {
  background: var(--nook-c-white);
  color: var(--nook-c-primary);
  border: 1px solid rgba(212, 0, 93, 0.15);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}
.nook-quick-cta:hover,
.nook-site-header.sticky .nook-quick-cta:hover {
  background: var(--nook-c-primary);
  color: var(--nook-c-white);
  border-color: var(--nook-c-primary);
  box-shadow: 0 8px 20px rgba(212, 0, 93, 0.2);
}
.nook-quick-cta::before,
.nook-site-header.sticky .nook-quick-cta::before {
  content: '';
  width: 8px;
  height: 8px;
  background-color: var(--nook-c-primary);
  border-radius: 50%;
  margin-right: 12px;
  display: inline-block;
  position: relative;
  box-shadow: 0 0 0 0 rgba(212, 0, 93, 0.4);
  animation: nook-dot-pulse 2s infinite;
}
.nook-quick-cta:hover::before,
.nook-site-header.sticky  .nook-quick-cta:hover::before{
  background-color: var(--nook-c-white);
  animation: nook-dot-pulse-white 2s infinite;
}
.front-page .nook-quick-cta::before {
  background-color: #ffffff;
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.4);
  animation: nook-dot-pulse-white 2s infinite;
}
@keyframes nook-dot-pulse {
  0% {
      transform: scale(0.95);
      box-shadow: 0 0 0 0 rgba(212, 0, 93, 0.7);
  }
  70% {
      transform: scale(1);
      box-shadow: 0 0 0 6px rgba(212, 0, 93, 0);
  }
  100% {
      transform: scale(0.95);
      box-shadow: 0 0 0 0 rgba(212, 0, 93, 0);
  }
}

@keyframes nook-dot-pulse-white {
  0% {
      transform: scale(0.95);
      box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.7);
  }
  70% {
      transform: scale(1);
      box-shadow: 0 0 0 6px rgba(255, 255, 255, 0);
  }
  100% {
      transform: scale(0.95);
      box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
  }
}

/* ----------------------------------------------------------------------------
/* Menu
/* --------------------------------------------------------------------------*/
.front-page .nook-site-header {
  position: fixed;
  left:0;
  width: 100%;
  z-index: var(--nook-zindex-menu);
}
/* Full screen/mobile */
@media (max-width: 1023px) {
  #nook-menu-trigger {
      position: relative;
      z-index: 1000;
      background: none;
      border: none;
      cursor: pointer;
      padding: 4px;
      display: flex;
      flex-direction: column;
  }

  .nook-bar {
      display: block;
      width: 28px;
      height: 4px;
      background: var(--nook-c-white);
      margin: 2px 0;
      transition: 0.4s;
      border-radius: 4px;
  }
  body:not(.front-page):not(.nav-open) .nook-bar {
      background: var(--nook-c-text);
  }
  .nav-open .nook-bar {
      background: #fff;
  }
  body.nav-open #nook-menu-trigger {
      position: fixed;
      top: 26px;
      right: 32px;
  }
  body.nav-open .nook-bar:nth-child(1) { transform: translateY(9px) rotate(45deg); }
  body.nav-open .nook-bar:nth-child(2) { opacity: 0; }
  body.nav-open .nook-bar:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

  #nook-main-nav {
      position: fixed;
      top: 0; left: 0;
      width: 100%; height: 100vh;
      z-index: 999;
      display: none;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      opacity: 0;
      visibility: hidden;
      transition: var(--nook-transition-menu);
      background:
          radial-gradient(circle at 50% 50%, rgba(139,31,221,0.15) 0%, transparent 80%),
          radial-gradient(circle at 0%   50%, rgba(255,0,222,0.1)   0%, transparent 60%),
          radial-gradient(circle at 100% 50%, rgba(0,246,255,0.1)   0%, transparent 60%),
          #050110;
  }
  #nook-main-nav::before {
      content: "";
      position: absolute; inset: 0;
      background: linear-gradient(rgba(18,16,16,0) 50%, rgba(0,0,0,0.15) 50%);
      background-size: 100% 4px;
      z-index: 20;
      pointer-events: none;
      opacity: 0.4;
  }
  #nook-main-nav::after {
      content: "";
      position: absolute; inset: 0;
      box-shadow: inset 0 0 200px rgba(0,0,0,0.9);
      pointer-events: none;
  }

  body.nav-open #nook-main-nav {
      opacity: 1;
      visibility: visible;
      display: flex;
  }
  
  body.nav-open #nook-main-nav .nook-nav-container {
      display: flex;
      flex-direction: column;
      gap:2rem;
  }

  #nook-main-nav ul {
      list-style: none;
      padding: 0;
      text-align: center;
      display: flex;
      flex-direction: column;
      gap: 1rem;
      position: relative;
      z-index: 21;
  }
  #nook-main-nav ul li a {
      font-size: clamp(1.5rem, 5vw, 3.5rem);
      line-height: 1.2;
      color: #fff;
      text-transform: uppercase;
      letter-spacing: 4px;
      cursor: pointer;
      transition: all 0.3s ease;
      text-shadow: 0 0 10px rgba(255,255,255,0.2);
      opacity: 0.9;
      font-weight: 600;
      display: block;
  }
  #nook-main-nav ul li a:hover {
      opacity: 1;
      color: var(--neon-blue);
      text-shadow:
          0 0 10px var(--neon-blue),
          0 0 40px rgba(0,246,255,0.5);
      letter-spacing: 6px;
  }

  .nook-nav-trigger {
      font-size: clamp(1.5rem, 5vw, 3.5rem);
      line-height: 1.2;
      color: #fff;
      text-transform: uppercase;
      letter-spacing: 4px;
      transition: all 0.3s ease;
      text-shadow: 0 0 10px rgba(255,255,255,0.2);
      opacity: 0.9;
      font-weight: 600;
      background: none;
      border: none;
      cursor: pointer;
      font-family: var(--nook-font);
      padding: 0;
      display: block;
      width: 100%;
      text-align: center;
  }
  .nook-nav-trigger:hover {
      opacity: 1;
      color: var(--neon-blue);
      text-shadow:
          0 0 10px var(--neon-blue),
          0 0 40px rgba(0,246,255,0.5);
      letter-spacing: 6px;
  }
  .nook-nav-trigger-icon { display: none; }

  .nook-nav-footer {
 
      width: 100%;
      text-align: center;
      padding: 0 var(--nook-col-gap);
      z-index: 21;
  }
  .nook-nav-info {
      font-size: 0.9rem;
      margin-bottom: var(--nook-col-gap);
      opacity: 0.7;
      color: rgba(255,255,255,0.5);
  }
  .nook-nav-info a { color: #fff; }
  .nook-btn-alt {
      display: inline-block;
      padding: calc(0.5 * var(--nook-col-gap)) calc(1.25 * var(--nook-col-gap));
      border: 2px solid var(--nook-c-primary);
      color: #fff;
      text-decoration: none;
      border-radius: var(--nook-radius-lg);
      font-weight: 600;
  }
  .nook-btn-alt:hover { color: var(--nook-c-primary); }
  .nook-nav-logo {
      margin-top: calc(2 * var(--nook-col-gap));
      opacity: 0.3;
  }

  .nook-eventy-panel {
      top: 0;
      z-index: 1001; 
      max-height: 100vh;
      overflow-y: auto;
  }
  .nook-eventy-overlay {
      z-index: 1000; 
  }
  .nook-cities-list { grid-template-columns: 1fr 1fr; }
  .nook-types-list  { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 400px) {
  .nook-cities-list { grid-template-columns: 1fr; }
  .nook-types-list  { grid-template-columns: 1fr; }
}

/* Desktop */
@media (min-width: 1024px) {
  #nook-menu-trigger,
  .nook-nav-footer {
      display: none;
  }

  #nook-main-nav {
      position: static;
      height: auto;
      background: none;
      opacity: 1;
      visibility: visible;
  }

  #nook-main-nav ul {
      display: flex;
      gap: 2px;
      list-style: none;
  }

  #nook-main-nav ul li a {
      color: var(--nook-c-white);
      font-size: var(--nook-fs-menu);
      line-height: var(--nook-lh-menu);
      font-weight: 700;
      text-transform: uppercase;
      text-decoration: none;
      display: flex;
      position: relative;
      overflow: hidden;
      padding: 8px 12px;
      border-radius: var(--nook-radius-sm);
      letter-spacing: 0.01em;
      transition: var(--nook-transition-toggle);
  }
  #nook-main-nav ul li a:hover {
      color: var(--nook-c-white);
      background: rgba(255,255,255,0.12);
      text-shadow: 0 0 12px rgba(255,255,255,0.4);
  }

  body:not(.front-page) #nook-main-nav ul li a {
      color: var(--nook-c-text);
  }
  body:not(.front-page) #nook-main-nav ul li a:hover {
      background: rgba(0,51,141,0.05);
      color: var(--nook-c-blue);
      text-shadow: none;
  }
  body:not(.front-page) #nook-main-nav ul:hover a:not(:hover) {
      opacity: 1;
  }

  .nook-nav-trigger {
      color: var(--nook-c-white);
      font-size: var(--nook-fs-menu);
      line-height: var(--nook-lh-menu);
      font-weight: 700;
      text-transform: uppercase;
      background: none;
      border: none;
      cursor: pointer;
      font-family: var(--nook-font);
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 12px;
      border-radius: var(--nook-radius-sm);
      letter-spacing: 0.01em;
      transition: var(--nook-transition-toggle);
  }
  .nook-nav-trigger:hover {
      color: var(--nook-c-white);
      text-shadow: 0 0 12px rgba(255,255,255,0.4);
  }

  body:not(.front-page) .nook-nav-trigger {
      color: var(--nook-c-text);
  }
  body:not(.front-page) .nook-nav-trigger:hover {
      background: rgba(0,51,141,0.05);
      color: var(--nook-c-blue);
      text-shadow: none;
  }

  .nook-nav-trigger-icon {
      display: inline-block;
      width: 7px; height: 7px;
      border-right: 2px solid currentColor;
      border-bottom: 2px solid currentColor;
      transform: rotate(45deg) translateY(-2px);
      transition: transform 0.2s ease;
      flex-shrink: 0;
  }
  .nook-nav-trigger[aria-expanded="true"] .nook-nav-trigger-icon {
      transform: rotate(-135deg) translateY(-2px);
  }

  .nook-eventy-panel {
      top: 72px;
      z-index: var(--nook-zindex-menu);
  }
  .nook-eventy-overlay {
      z-index: calc(var(--nook-zindex-menu) - 1);
  }
  .nook-cities-list {
      grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  }
  .nook-types-list {
      grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }
}

/* ----------------------------------------------------------------------------
/* Menu - panel
/* --------------------------------------------------------------------------*/
.nook-eventy-panel {
  position: fixed;
  top: 72px; left: 0; right: 0;
  z-index: var(--nook-zindex-menu);
  background: var(--nook-c-white);
  border-bottom: var(--nook-border-50);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  transform: translateY(-6px);
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.nook-eventy-panel.active {
  opacity: 1; pointer-events: auto;
  transform: translateY(0);
}
body.nav-open .nook-eventy-panel {
  top:0;
}

.front-page .nook-eventy-panel {
  left: 50%;
  right: auto;
  width: calc(100% - 48px);
  max-width: var(--nook-max-width);
  transform: translateX(-50%) translateY(-6px);
  background: var(--nook-c-dark-base);
  border: 1px solid rgba(255,255,255,0.08);
  border-top: none;
  border-radius: 0 0 var(--nook-radius) var(--nook-radius);
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
  overflow: hidden;
}
.front-page .nook-eventy-panel::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
      radial-gradient(ellipse at 0% 0%,    rgba(212,0,93,0.14)  0%, transparent 55%),
      radial-gradient(ellipse at 100% 100%, rgba(0,246,255,0.08) 0%, transparent 55%);
}
.front-page .nook-eventy-panel.active {
  transform: translateX(-50%) translateY(0);
}

/* .nook-eventy-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.28);
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s ease;
}
.nook-eventy-overlay.active { opacity: 1; pointer-events: auto; } */

.nook-eventy-inner {
  position: relative; z-index: 1;
}

.nook-eventy-view { animation: nookFadeIn 0.2s ease; }
@keyframes nookFadeIn {
  from { opacity: 0; transform: translateX(8px); }
  to   { opacity: 1; transform: translateX(0); }
}

.nook-eventy-view-header {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: var(--sp-5) 0 var(--sp-4);
  border-bottom: var(--nook-border-50); margin-bottom: var(--sp-4);
}
.front-page .nook-eventy-view-header { border-bottom-color: rgba(255,255,255,0.10); }

.nook-eventy-view-title {
  font-size: var(--nook-fs-xsmall); font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.14em; color: var(--nook-c-meta);
}
.front-page .nook-eventy-view-title { color: rgba(255,255,255,0.35); }

.nook-eventy-close {
  background: none; border: none; cursor: pointer;
  font-size: var(--nook-fs-body); color: var(--nook-c-meta);
  padding: var(--sp-1) var(--sp-2); border-radius: var(--nook-radius-xs);
  transition: var(--nook-transition); line-height: 1;
}
.nook-eventy-close:hover { color: var(--nook-c-text); background: var(--nook-bg-page); }
.front-page .nook-eventy-close { color: rgba(255,255,255,0.4); }
.front-page .nook-eventy-close:hover { color: #fff; background: rgba(255,255,255,0.08); }

.nook-eventy-back {
  background: none; border: none; cursor: pointer;
  font-family: var(--nook-font); font-size: var(--nook-fs-small); font-weight: 700;
  color: var(--nook-c-blue); padding: 0;
  display: flex; align-items: center; gap: var(--sp-2);
  transition: var(--nook-transition);
}
.nook-eventy-back:hover { color: var(--nook-c-primary); }
.front-page .nook-eventy-back { color: rgba(255,255,255,0.7); }
.front-page .nook-eventy-back:hover { color: var(--nook-c-primary); }

/* miasta */
.nook-cities-list {
  list-style: none; display: grid;
  gap: var(--sp-2); padding-bottom: var(--sp-6);
}
.nook-city-link {
  display: flex; align-items: center;
  justify-content: space-between; gap: var(--sp-2);
  background: var(--nook-bg-page); border: var(--nook-border-50);
  border-radius: var(--nook-radius-sm); padding: var(--sp-3) var(--sp-4);
  font-size: var(--nook-fs-body); font-weight: 600;
  color: var(--nook-c-text); transition: var(--nook-transition);
  white-space: nowrap;
}
.nook-city-link:hover {
  border-color: var(--nook-c-blue); color: var(--nook-c-blue);
  background: var(--nook-c-white);
}
.front-page .nook-city-link {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.75);
}
.front-page .nook-city-link:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.30);
  color: var(--nook-c-white);
}
.nook-city-arrow { font-size: var(--nook-fs-small); color: var(--nook-c-meta); flex-shrink: 0; }
.front-page .nook-city-arrow { color: rgba(255,255,255,0.30); }

.nook-city-all-link {
  display: inline-block; font-size: var(--nook-fs-small); font-weight: 700;
  color: var(--nook-c-primary); margin-bottom: var(--sp-4); transition: var(--nook-transition);
}
.nook-city-all-link:hover { color: #b8004f; }
.front-page .nook-city-all-link { color: var(--pink); }
.front-page .nook-city-all-link:hover { color: #fff; }

/* typy */
.nook-types-list {
  list-style: none; display: grid;
  gap: var(--sp-2); padding-bottom: var(--sp-6);
}
.nook-types-list a {
  display: block; background: var(--nook-bg-page); border: var(--nook-border-50);
  border-radius: var(--nook-radius-sm); padding: var(--sp-3) var(--sp-4);
  font-size: var(--nook-fs-body); font-weight: 600;
  color: var(--nook-c-text); transition: var(--nook-transition);
  white-space: nowrap;
}
.nook-types-list a:hover {
  border-color: var(--nook-c-primary); color: var(--nook-c-primary);
  background: var(--nook-c-white);
}
.front-page .nook-types-list a {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.10);
  color: rgba(255,255,255,0.75);
}
.front-page .nook-types-list a:hover {
  background: rgba(255,255,255,0.10);
  border-color: var(--nook-c-primary);
  color: var(--nook-c-white);
}

/* ----------------------------------------------------------------------------
/* Sticky
/* --------------------------------------------------------------------------*/
.nook-site-header.sticky {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  padding: 12px 0;
  z-index: 1000;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
  border-bottom: 1px solid rgba(0,0,0,0.05);
  transition: background 0.4s cubic-bezier(0.165, 0.84, 0.44, 1),
              box-shadow 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.nook-site-header.sticky .logo { color: var(--nook-c-blue); }
.nook-site-header.sticky .logo span { color: var(--nook-c-primary); }
.nook-site-header.sticky #nook-main-nav ul li a {
  color: var(--nook-c-text);
  text-shadow: none;
}
.nook-site-header.sticky #nook-main-nav ul li a:hover {
  color: var(--nook-c-blue);
  background: rgba(0,51,141,0.05);
  text-shadow: none;
}
.nook-site-header.sticky #nook-main-nav ul:hover a:not(:hover) {
  opacity: 1;
}
.nook-site-header.sticky .nook-nav-trigger {
  color: var(--nook-c-text);
  text-shadow: none;
}
.nook-site-header.sticky .nook-nav-trigger:hover {
  color: var(--nook-c-blue);
  background: rgba(0,51,141,0.05);
  text-shadow: none;
}
.nook-site-header.sticky .nook-bar {
  background: var(--nook-c-text);
}
.nook-site-header.sticky .nook-nav-trigger {
  color: var(--nook-c-text);
  text-shadow: none;
}
.nook-site-header.sticky .nook-nav-trigger:hover {
  color: var(--nook-c-blue);
  background: rgba(0,51,141,0.05);
  text-shadow: none;
}
.nook-site-header.sticky ~ .nook-eventy-panel {
  top: 60px;
}

/* ----------------------------------------------------------------------------
/* WP admin bar fix
/* --------------------------------------------------------------------------*/
body.nav-open.admin-bar #nook-menu-trigger { top: 62px; }
.admin-bar .nook-site-header.sticky { top: 26px; }

@media (max-width: 767px) {
    body.nav-open.admin-bar #nook-menu-trigger { top: 72px; }
    .admin-bar .nook-site-header.sticky { top: 42px; }
}

/* ----------------------------------------------------------------------------
/* Footer
/* --------------------------------------------------------------------------*/
.nook-f {
  position: relative;
  background:
      radial-gradient(ellipse at 50% 45%, rgba(255, 0, 200, 0.05), transparent 70%),
      radial-gradient(ellipse at 50% 50%, rgba(0, 255, 255, 0.04), transparent 75%),
      radial-gradient(ellipse at 20% 0%, rgba(212, 0, 93, 0.3) 0%, transparent 70%),
      radial-gradient(ellipse at 80% 0%, rgba(0, 255, 255, 0.2) 0%, transparent 70%),
      radial-gradient(circle at 50% 100%, rgba(180, 0, 255, 0.15), transparent 60%),
      radial-gradient(circle at 80% 90%, rgba(0, 255, 255, 0.1), transparent 50%),
      linear-gradient(to bottom, var(--nook-c-dark-base) 0%, #000 100%);
  filter: contrast(1.1) saturate(1.3);
  color: rgba(255, 255, 255, 0.7);
  padding: var(--nook-sp-xl) 0 var(--nook-sp-md) 0;
  overflow: hidden;
}

@media(max-width: 48rem) {
  .nook-f {
      background:
          radial-gradient(ellipse 140% 100% at 50% 50%, rgba(255, 0, 200, 0.04), transparent 90%),
          radial-gradient(ellipse 140% 80% at 50% 50%, rgba(255, 0, 200, 0.08), transparent 75%),
          radial-gradient(ellipse 140% 80% at 50% 50%, rgba(0, 255, 255, 0.06), transparent 80%),
          radial-gradient(ellipse at 0% 50%, rgba(212, 0, 93, 0.28), transparent 70%),
          radial-gradient(ellipse at 100% 50%, rgba(0, 255, 255, 0.22), transparent 70%),
          linear-gradient(to bottom, var(--nook-c-dark-base) 0%, #000 100%);
  }   
}

.nook-f .container {
  z-index: var(--nook-zx-sm);
}
.f-authority, .f-grid {
  position: relative;
  border: none;
}
.f-authority {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--nook-gap);
  padding-bottom: var( --nook-sp-lg);
  margin-bottom: var( --nook-sp-xl);
}

.f-authority {
  position: relative;
}

.f-authority::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 10%;
  width: 80%;
  height: 1px;

  background:
      /* highlight */
      linear-gradient(
          90deg,
          transparent 0%,
          transparent 40%,
          rgba(255,255,255,0.15) 50%,
          transparent 60%,
          transparent 100%
      ),
      /* baza */
      linear-gradient(
          90deg,
          transparent,
          rgba(255, 0, 122, 0.7),
          rgba(0, 255, 255, 0.7),
          transparent
      );

  background-size: 200% 100%, 100% 100%;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 5;
}

.f-bottom {
  position: relative;
}

.f-bottom::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;

  background:
      /* highlight */
      linear-gradient(
          90deg,
          transparent 0%,
          transparent 40%,
          rgba(255,255,255,0.2) 50%,
          transparent 60%,
          transparent 100%
      ),
      /* baza */
      linear-gradient(
          90deg,
          transparent,
          rgba(212, 0, 93, 0.4),
          rgba(0, 255, 255, 0.4),
          transparent
      );

  background-size: 200% 100%, 100% 100%;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 5;
}

.auth-block {
  display: flex;
  flex-direction: column;
  gap: var(--nook-gap-xs);
}

.auth-num {
  font-size: var(--nook-fs-6);
  line-height: 1;
  font-weight: 800;
  color: var(--nook-c-white);
  letter-spacing: -1px;
  text-shadow: 0 0 20px rgba(255, 255, 255, 0.2);
}

.auth-label {
  font-size: var(--nook-fs-xsmall);
  line-height: var(--nook-lh-xsmall);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--nook-c-primary);
  font-weight: 700;
}

.f-grid {
  display: grid;
  grid-template-columns: 1.5fr repeat(3, 1fr);
  gap: var(--nook-gap-l);
}

.brand-space .logo {
  font-size: var(--nook-fs-6);
  line-height: var(--nook-lh-6);
  font-weight: 900;
  letter-spacing: -2px;
  color: var(--nook-c-white);
  text-decoration: none;
  display: block;
  margin-bottom: var(--nook-sp-md);
}

.brand-space .logo span { 
  color: var(--nook-c-primary); 
  text-shadow: 0 0 15px var(--nook-c-primary);
}

.brand-space p {
  font-size: var(--nook-fs-h5);
  line-height: var(--nook-lh-h5);
  color: rgba(255,255,255,0.5);
  max-width: 340px;
}

.nav-head {
  font-size: var(--nook-fs-xsmall);
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--nook-c-white);
  margin-bottom: var(--nook-sp-4);
  display: block;
  font-weight: 700;
}

.f-list { list-style: none; padding: 0; margin: 0; }
.f-list li { margin-bottom: 1rem;  }
.f-list li a {
  text-decoration: none;
  color: rgba(255,255,255,0.5);
  font-size: var(--nook-fs-body);
  display: flex;
  align-items: center;
  transition: var(--nook-transition-footer);
}

.f-list li a::before {
  content: '';
  width: 0;
  height: 6px;
  background: var(--nook-c-primary);
  border-radius: 50%;
  margin-right: 0;
  transition: var(--nook-transition-footer);
  box-shadow: 0 0 10px var(--nook-c-primary);
  opacity: 0;
}

.f-list li a:hover {
  color: var(--nook-c-white);
  padding-left: 0.25rem;
}

.f-list li a:hover::before {
  width: 6px;
  margin-right: 0.75rem;
  opacity: 1;
}

.seo-tag {
  font-size: 9px;
  margin-left: 0.75rem;
  color: var(--nook-c-cyan);
  opacity: 0.6;
  font-weight: 600;
}

.f-bottom {
  margin-top: var(--nook-sp-xl);
  padding-top: var(--nook-sp-lg);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
}

.f-contact-wrap { display: flex; gap: var(--nook-gap-xl); }

.f-contact-item span { 
  font-size: var(--nook-fs-xsmall); 
  text-transform: uppercase; 
  color: rgba(255,255,255,0.3); 
  display: block; 
  margin-bottom: 0.25rem;
}

.f-contact-link {
  font-size: var(--nook-fs-h4);
  font-weight: 600;
  color: var(--nook-c-white);
  text-decoration: none;
  transition: var(--nook-transition);
  position: relative;
}

.f-contact-link::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--nook-c-cyan);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.4s ease;
}

.f-contact-link:hover { color: var(--nook-c-cyan); }
.f-contact-link:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

.f-copyright {
  text-align: right;
  font-size: var(--nook-fs-xsmall);
  line-height: var(--nook-lh-xsmall);
  color: rgba(255,255,255,0.4);

}

.f-copyright b { color: var(--nook-c-white); }

.f-copyright { display: flex; gap: 0.75rem; align-items: flex-end; display: flex; flex-direction: column;}

@media (max-width: 1024px) {
  .f-authority { grid-template-columns: 1fr 1fr; }
  .f-grid { grid-template-columns: 1fr 1fr; }
  .brand-space { grid-column: span 2; }
}

@media (max-width: 573px) {
  .f-grid { grid-template-columns: 1fr 1fr; }
  .f-bottom { flex-direction: column; align-items: center; gap: var(--nook-gap-l); flex-direction: start; }
  .f-copyright { align-items: center;}
}

/* ----------------------------------------------------------------------------
/* Card
/* --------------------------------------------------------------------------*/
/* base */
.nook-offer-card {
  display: flex;
  width: 100%;
  backface-visibility: hidden;
}
.nook-offer-link:hover {
  color: var(--nook-c-text);
}
.nook-offer-link,
.nook-offer {
  display: flex;
  flex-direction: column;
  width: 100%;
  background: var(--nook-c-white);
  border: var(--nook-border-50);
  border-radius: var(--nook-radius) var(--nook-radius) var(--nook-radius-lg) var(--nook-radius);
  text-decoration: none;
  color: var(--nook-c-text);
  overflow: hidden;
  transition: var(--trans);
  backface-visibility: hidden;

}
.nook-offer-card:hover .nook-offer-link,
.nook-offer-card:hover .nook-offer {
  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

/* media */
.offer-media {
  position: relative;
  overflow: hidden;
}
.offer-tag {
  position: absolute;
  top: var(--sp-2);
  right: var(--sp-2);
  background: var(--nook-c-primary);
  color: var(--nook-c-white);
  font-size: var(--nook-fs-xsmall);
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--nook-radius-xs);
}

/* content */
.offer-content {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: var(--sp-4);
}

/* typo + meta */
.offer-meta-top,
.card-meta-top {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-2);
  font-size: var(--nook-fs-xsmall);
  line-height: var(--nook-lh-xsmall);
  color: var(--nook-c-text);
  opacity: .7;
  margin-bottom: var(--sp-2);
}
.offer-title,
.nook-offer-link h3 {
  font-size: var(--nook-fs-h4);
  line-height: var(--nook-lh-h4);
  margin-bottom: var(--sp-3);
  font-weight: 600;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* specs/extra */
.offer-specs {
  display: flex;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}

/* footer */
.offer-footer,
.card-footer-mini {
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2);
}

/* price */
.price-value {
  font-weight: 700;
  color: var(--nook-c-primary);
}
.price-label {
  font-size: var(--nook-fs-xsmall);
  opacity: .7;
}

/* cta/arrow */
.offer-arrow,
.view-link {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--nook-fs-small);
  font-weight: 600;
  transition: var(--nook-transition);
}
.offer-arrow {
  width: 30px;
  height: 30px;
  background: #eee;
  border-radius: 50%;
}

/* variants */
/* type-card */
.nook-offer.is-matrix {
  padding: var(--sp-6);
  border-radius: var(--nook-radius-sm) var(--nook-radius-sm) var(--nook-radius-lg) var(--nook-radius-sm);
  min-height: 160px;
}

.nook-offer.is-featured {
  background: var(--nook-c-featured);
  border-top: 4px solid var(--nook-c-primary);
}
.nook-offer.is-matrix .type-label {
  font-size: var(--nook-fs-xxsmall);
  font-weight: 700;
  text-transform: uppercase;
  color: var(--c-blue);
  background: #00338d0f;
  padding: 2px 6px;
  border-radius: 4px;  
}
.nook-offer.is-matrix .card-footer-mini {
  display: flex;
justify-content: space-between;
align-items: center;
padding-top: var(--sp-sm);
border-top: 1px solid #f5f5f5;
}

/* mobile */
@media (max-width: 500px) {
  .offer-title {
      -webkit-line-clamp: 3;
  }
}

.nook-offer-link.is-matrix-clean {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--sp-6);
  background: var(--nook-c-white);
  border: var(--nook-border-50);
  border-radius: var(--nook-radius-sm) var(--nook-radius-sm) var(--nook-radius-lg) var(--nook-radius-sm);
  min-height: 160px;
  text-decoration: none;
  color: var(--nook-c-text);
  transition: var(--trans);
  gap: var(--sp-3);
}

.nook-offer-link.is-matrix-clean:hover {
  border-color: var(--nook-bg-100);
  box-shadow: 0 12px 24px rgba(0,0,0,0.04);
}

.nook-offer-link.is-matrix-clean .card-meta-top {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--sp-3);
}

.nook-offer-link.is-matrix-clean .type-label {
  font-size: var(--nook-fs-xxsmall);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.nook-offer-link.is-matrix-clean .price-tag {
  font-size: var(--nook-fs-xsmall);
}

.nook-offer-link.is-matrix-clean .price-tag strong {
  font-weight: 700;
}

.nook-offer-link.is-matrix-clean .card-footer-mini {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--sp-3);
  border-top: 1px solid var(--nook-bg-50);
}

.nook-offer-link.is-matrix-clean .info-item {
  font-size: var(--nook-fs-xsmall);
  opacity: .7;
}

.nook-offer-link.is-matrix-clean .view-link {
  font-size: var(--nook-fs-xsmall);
  font-weight: 600;
  color: var(--nook-c-primary);
  transition: var(--nook-transition);
}

.nook-offer-link.is-matrix-clean.is-featured {
  background: var(--nook-c-featured);
  border-top: 4px solid var(--nook-c-primary);
}

/* Mały pasek pod zdjęciem w karcie */
.offer-media::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, var(--pink), var(--blue));
  opacity: 0.8;
}

/* ----------------------------------------------------------------------------
/* Breadcrumb
/* --------------------------------------------------------------------------*/
.nook-breadcrumbs { 
  color: var(--nook-c-breadcrumb);
  font-size: var(--nook-fs-xsmall);
  text-transform: uppercase;

} 
.nook-breadcrumbs a {
  font-weight: 600;
}

/* ----------------------------------------------------------------------------
/* Search
/* --------------------------------------------------------------------------*/
.nook-search {
  border-radius: 1rem;
  align-items: center;
  gap: 0.5rem;
}
.nook-search select {
  transition: var(--trans);  
}
.nook-search .ts-control {
  background: #FFF;
  padding: 0.75rem 1rem;
  border-radius: var(--nook-radius);
  border: 1px solid var(--nook-c-border);
  transition: var(--trans);  
}
.nook-search input, 
.nook-search select { 
  font-size: var(--nook-fs-body);
  color: var(--nook-fs-body); 
  border: none; 
  outline: none; 
}
.nook-search #search-submit {
  border: none;
  font-weight: 800;
  border-radius: var(--nook-radius);
  cursor: pointer;
  text-transform: uppercase;
  transition: var(--trans);
  margin:0.5rem;
}

@media(max-width: 1023px) {
  .nook-search { 
    grid-template-columns: 1fr; 
  }
}

/* Loading state */
.nook-search.is-loading {
  pointer-events: none;
  position: relative;
}
/* spinner */
.nook-search.is-loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18px;
  height: 18px;
  border: 2px solid #ccc;
  border-top-color: #000;
  border-radius: 50%;
  animation: nook-spin 0.6s linear infinite;
  z-index: 11;
}

@keyframes nook-spin {
  to { transform: rotate(360deg); }
}

.nook-search.is-loading::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.5);
  backdrop-filter: blur(4px);
  z-index: 10;
  border-radius: 1rem;
}
 
/* Noscript */
.search-noscript ul {
  padding-left: 18px;
}
.search-noscript a {
  color: #000;
  text-decoration: none;
}
.search-noscript a:hover {
  text-decoration: underline;
}

/* Feedback box */
#search-feedback {
  margin-top: 1rem;
  padding: 1rem;
  background: #f8f8f8;
  border-radius: var(--nook-border);
  font-size: var(--nook-fs-body);
}
#search-feedback a {
  display: inline-block;
  margin-top: 0.5rem;
  font-weight: 600;
  color: var(--nook-c-text);
  text-decoration: none;
}
#search-feedback a:hover {
  text-decoration: underline;
}

/* ----------------------------------------------------------------------------
/* Search category
/* --------------------------------------------------------------------------*/
.nook-search--cat {
  display: flex;
}
.nook-search--cat .choices {
  margin:0;
  overflow: visible !important;
}
.nook-search--cat .choices__inner:focus-within {
  transform: none !important; 
}
.nook-search--cat #search-submit {
  height: 40px;
  padding: 0 15px;
  border: none;
  margin:0;
  background: var(--nook-c-blue);
  box-shadow: none;
  font-size: var(--nook-fs-small);
}
.nook-search--cat .ts-control {
  padding: 8px 32px 8px 12px; 
  font-size: var(--nook-fs-small);
  font-weight: 600;
  background: var(--nook-bg-page);
}
.nook-search--cat .ts-dropdown-content {
  font-size: var(--nook-fs-small);
}
.filters-bar {
  background: var(--nook-c-white);
  border-bottom: var(--nook-border-50);
  padding: 14px 0;
  position: sticky;
  top: 0;
  z-index: 50;
}
.filters-inner {
  display: flex;
  align-items: center;
  gap: 12px;
  width:100%;
}
.filters-label {
  font-size: 10px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--nook-c-meta); white-space: nowrap;
  flex-shrink: 0;
}
.filter-group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
}
.filters-count {
flex: 1;
text-align: right;
}

@media (max-width: 768px) {
    .filters-inner {
        flex-wrap: wrap;
        gap: 8px;
    }

    .filters-label {
        display: none;
    }

    .filter-group {
        flex: 1 1 100%;
        flex-direction: column;
    }

    .filter-group .ts-wrapper {
        flex: 1 1 100%; /* każdy select pełna szerokość */
    }

    .filter-group #search-submit {
        width: 100%;
    }

    .filters-count {
        flex: 0 0 100%;
        text-align: left;
    }
}


/* ----------------------------------------------------------------------------
/* Talk to us
/* --------------------------------------------------------------------------*/
.break { color: #FFF;}
.pattern-overlay {
    position: absolute; inset: 0; opacity: 0.07;
    background-image: radial-gradient(#ccd6e8 1px, transparent 1px);
    background-size: 24px 24px;
}
.break-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--sp-12); align-items: center; position: relative; z-index: 2; }
.break h2 { font-size: 2rem; line-height:2.1rem; font-weight: 800; margin: 0; letter-spacing: -0.04em; }
.break p { font-size: var(--nook-fs-h3); line-height: var(--nook-lh-h3); opacity: 0.8; margin: 12px 0 0; }

.quick-form { display: flex; gap: 0; background: #FFF; padding: 4px; border-radius: 8px; }
.quick-form input { 
    border: none; padding: 12px 16px; flex: 1;   font-size: var(--nook-fs-body); outline: none;
}
.quick-form button { 
    background: var(--nook-c-primary); color: #FFF; border: none; 
    padding: 0 24px; font-weight: 700; cursor: pointer; border-radius: 6px; transition: 0.3s;
}
.quick-form button:hover { opacity: 0.9; }
.break .eyebrow {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  color: var(--c-magenta);
  letter-spacing: 0.2em;
  margin-bottom: 8px;
  display: block;
}
@media (max-width: 767px) {
  .break-grid {
    grid-template-columns: 1fr;
  }
}

/* ----------------------------------------------------------------------------
/* How it works
/* --------------------------------------------------------------------------*/
.flow-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr 1fr; 
  gap: var(--sp-5);
  align-items: stretch;
  max-width: 1200px;
  margin: 0 auto;
}

.flow-card {
  background: #fff;
  padding: var(--sp-8);
  border-radius: 12px;
  border: 1px solid var(--nook-c-border);
  display: flex;
  flex-direction: column;
}

.flow-card.direct-book {
  background: radial-gradient(circle at 50% 50%, rgba(139, 31, 221, 0.35) 0%, transparent 80%),    radial-gradient(circle at 0% 50%, rgba(255, 0, 222, 0.4) 0%, transparent 60%),    radial-gradient(circle at 100% 50%, rgba(0, 246, 255, 0.4) 0%, transparent 60%),    #050110;
  color: #fff;
  border: none;
  transform: scale(1.05); 
  border-radius: 12px 12px 80px 12px;
  z-index: 2;
  position: relative;
}

.promo-badge {
  position: absolute;
  top: -12px;
  left: 34px;
  background: var(--nook-c-primary);
  padding: var(--sp-1) var(--sp-4);;
  border-radius: 20px;
  font-size: var(--nook-fs-xsmall);
  font-weight: 800;
  color: #fff;
}

.step-tag {
  font-size: var(--nook-fs-xxsmall);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #767676;
  margin-bottom: var(--sp-5);
  display: block;
}

.step-tag.white { color: rgba(255,255,255,0.6); }

.flow-card h3 {
  font-size: var(--nook-fs-h1);
  line-height: var(--nook-lh-f1);
  margin-bottom: 1rem;
}

.flow-card p {
  opacity: 0.9;
}

.mini-iframe-mockup {
  margin-top: auto;
  padding-top: var(--sp-5);
  border-top: 1px solid rgba(255,255,255,0.2);
}

.mock-btn {
  background: #fff;
  color: var(--nook-c-blue);
  font-size: var(--nook-fs-small);
  font-weight: 800;
  padding: var(--sp-3);
  text-align: center;
  border-radius: 20px;
  margin-top: var(--sp-3);
}

.btn-text {
  margin-top: auto;
  color: #d4005d;
  text-decoration: none;
  font-weight: 700;
  font-size: var(--nook-fs-small);
}

@media(max-width: 767px) {
  .flow-grid {
    grid-template-columns: 1fr; 
  }  

  .flow-card.direct-book {
    transform: scale(1); 
  }
}

/* ----------------------------------------------------------------------------
/* Toggle
/* --------------------------------------------------------------------------*/
.nook-accordion { 
  border-top: 1px solid var(--nook-c-border); 
  margin-top: var(--sp-6);
}

.nook-snippet { 
  border-bottom: 1px solid var(--nook-c-border); 
}

.nook-snippet-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  outline: none;
}

.nook-snippet-trigger span {
  font-size: var(--nook-fs-body);
  font-weight: 700;
  color: var(--nook-c-text);
  transition: var(--nook-transition-toggle);
  padding-right: 24px;
}

.nook-arrow {
  position: relative;
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}

.nook-arrow::before, .nook-arrow::after {
  content: '';
  position: absolute;
  background: var(--nook-c-primary);
  transition: var(--nook-transition-toggle);
}

.nook-arrow::before { 
  width: 50%;
  height: 2px;
  top: 5px;
  left: 0;
}

.nook-arrow::after { 
  width: 2px;
  height: 100%;
  top: 0;
  left: 5px;
}

.nook-snippet.active .nook-arrow::after { 
  transform: rotate(90deg); 
  opacity: 0; 
}

.nook-snippet.active .nook-snippet-trigger span { 
  color: var(--nook-c-primary); 
}

.nook-snippet-content {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}

.nook-snippet-content .inner {
  min-height: 0;
}

.nook-snippet.active .nook-snippet-content {
  grid-template-rows: 1fr;
}

.nook-snippet-content p {
  padding-bottom: 24px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--nook-c-text);
}

.nook-snippet-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 16px; 
  margin: 0 -16px;  
  width: calc(100% + 32px); 
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  outline: none;
  transition: background-color 0.3s ease;
  font-size: var(--nook-fs-body);
  line-height: var(--nook-lh-body);
}

.nook-snippet-trigger:hover {
  background-color: rgba(0, 0, 0, 0.02);
}

.nook-snippet-trigger:hover span {
  color: var(--nook-c-primary); 
}

/* Opcjonalnie: zmiana koloru tła gdy akordeon jest otwarty */
.nook-snippet.active .nook-snippet-trigger {
  background-color: rgba(0, 0, 0, 0.01);
}

/* =============================================================================
 * nook-page.css
 * ============================================================================= */
/* ----------------------------------------------------------------------------
/* Single page
/* --------------------------------------------------------------------------*/
.page-header {
  padding: var(--sp-16) 0 var(--sp-10);
  background: var(--nook-bg-page);
  border-bottom: var(--nook-border-50);
  margin-bottom: var(--sp-12);
}

.page-title {
  font-family: var(--nook-font-display);
  font-size: var(--nook-fs-h1);
  line-height: var(--nook-lh-h1);
  color: var(--nook-c-title);
  letter-spacing: 0.01em;
  margin-bottom: var(--sp-3);
}
@media (min-width: 1024px) {
  .page-title { font-size: var(--nook-fs-6); line-height: var(--nook-lh-6); }
}

.page-desc {
  font-size: var(--nook-fs-body);
  color: var(--nook-c-meta);
  max-width: 560px;
}

/* ---- PAGE CONTENT ---- */
.page-content {
  padding-bottom: var(--sp-16);
  font-size: var(--nook-fs-body);
  line-height: var(--nook-lh-body);
  color: var(--nook-c-text);
}
.page-content p  { margin-bottom: var(--sp-6); }
.page-content h2 {
  font-size: var(--nook-fs-h2); line-height: var(--nook-lh-h2);
  color: var(--nook-c-title); margin: var(--sp-10) 0 var(--sp-4);
}
.page-content h3 {
  font-size: var(--nook-fs-h3); line-height: var(--nook-lh-h3);
  color: var(--nook-c-title); margin: var(--sp-8) 0 var(--sp-3);
}
.page-content ul,
.page-content ol {
  margin: 0 0 var(--sp-6) var(--sp-6);
  display: flex; flex-direction: column; gap: var(--sp-2);
}
.page-content a { color: var(--nook-c-primary); }
.page-content a:hover { color: #b8004f; }
/* ----------------------------------------------------------------------------
/* 404
/* --------------------------------------------------------------------------*/
.error-404 {
  padding: var(--sp-12) 0 var(--sp-20);
  display: flex; flex-direction: column;
  gap: var(--sp-5);
}

.error-404-code {
  font-family: var(--nook-font-display);
  font-size: 8rem; line-height: 1;
  color: var(--nook-c-border);
  letter-spacing: -4px;
}

.error-404-text {
  font-size: var(--nook-fs-body);
  color: var(--nook-c-meta);
  max-width: 480px;
}

.error-404-btn {
  display: inline-flex; align-items: center;
  padding: var(--sp-4) var(--sp-8);
  background: var(--nook-c-primary);
  color: var(--nook-c-white);
  border-radius: var(--nook-radius-sm);
  font-size: var(--nook-fs-body); font-weight: 700;
  transition: var(--nook-transition);
  box-shadow: 0 4px 14px rgba(212,0,93,0.22);
  align-self: flex-start;
}
.error-404-btn:hover { filter: brightness(0.9); color: var(--nook-c-white); }





