
/* === variables.css === */
/* ============================================================
   INFLUMODELS — Design Tokens / CSS Custom Properties
   Plik: assets/css/base/variables.css
   Ładowany jako PIERWSZY we wszystkich stronach
   ============================================================ */

:root {

  /* ----------------------------------------------------------
     KOLORY — MARKA
     ---------------------------------------------------------- */

  --color-primary:          #7C3AED;
  --color-primary-dark:     #5B21B6;
  --color-primary-darker:   #3B0E8C;
  --color-primary-light:    #A78BFA;
  --color-primary-lighter:  #C4B5FD;
  --color-primary-bg:       #F5F3FF;
  --color-primary-bg-hover: #EDE9FE;

  --color-secondary:        #DB2777;
  --color-secondary-dark:   #9D174D;
  --color-secondary-darker: #6D0F35;
  --color-secondary-light:  #F472B6;
  --color-secondary-lighter:#FBCFE8;
  --color-secondary-bg:     #FDF2F8;
  --color-secondary-bg-hover:#FCE7F3;

  /* ----------------------------------------------------------
     GRADIENTY
     ---------------------------------------------------------- */

  --gradient-primary:   linear-gradient(135deg, #7C3AED 0%, #DB2777 100%);
  --gradient-primary-r: linear-gradient(135deg, #DB2777 0%, #7C3AED 100%);
  --gradient-light:     linear-gradient(135deg, #F5F3FF 0%, #FDF2F8 100%);
  --gradient-hero:      linear-gradient(135deg, #7C3AED 0%, #9333EA 50%, #DB2777 100%);
  --gradient-card:      linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.72) 100%);
  --gradient-overlay:   linear-gradient(180deg, rgba(124,58,237,0.08) 0%, rgba(219,39,119,0.04) 100%);

  /* ----------------------------------------------------------
     KOLORY — TŁO
     ---------------------------------------------------------- */

  --color-bg:           #FFFFFF;
  --color-bg-alt:       #FAFAFA;
  --color-bg-card:      #FFFFFF;
  --color-bg-input:     #FFFFFF;
  --color-bg-dark:      #0F0A1E;
  --color-bg-footer:    #120B22;

  /* ----------------------------------------------------------
     KOLORY — TEKST
     ---------------------------------------------------------- */

  --color-text:         #111827;
  --color-text-muted:   #6B7280;
  --color-text-light:   #9CA3AF;
  --color-text-xlight:  #D1D5DB;
  --color-text-white:   #FFFFFF;
  --color-text-inverse: #FFFFFF;

  /* ----------------------------------------------------------
     KOLORY — OBRAMOWANIA
     ---------------------------------------------------------- */

  --color-border:       #E5E7EB;
  --color-border-light: #F3F4F6;
  --color-border-focus: #7C3AED;
  --color-border-error: #EF4444;

  /* ----------------------------------------------------------
     KOLORY — STANY SYSTEMOWE
     ---------------------------------------------------------- */

  --color-success:      #10B981;
  --color-success-bg:   #ECFDF5;
  --color-success-dark: #065F46;

  --color-warning:      #F59E0B;
  --color-warning-bg:   #FFFBEB;
  --color-warning-dark: #78350F;

  --color-error:        #EF4444;
  --color-error-bg:     #FEF2F2;
  --color-error-dark:   #7F1D1D;

  --color-info:         #3B82F6;
  --color-info-bg:      #EFF6FF;
  --color-info-dark:    #1E3A5F;

  /* ----------------------------------------------------------
     KOLORY PROFESJI
     ---------------------------------------------------------- */

  --profession-hostessa:    #7C3AED;
  --profession-model:       #DB2777;
  --profession-influencer:  #0EA5E9;
  --profession-promotor:    #10B981;
  --profession-ambasador:   #D97706;
  --profession-fotograf:    #6366F1;
  --profession-mua:         #EC4899;

  /* Tła kafelków profesji (12% opacity) */
  --profession-hostessa-bg:   rgba(124, 58, 237, 0.12);
  --profession-model-bg:      rgba(219, 39, 119, 0.12);
  --profession-influencer-bg: rgba(14, 165, 233, 0.12);
  --profession-promotor-bg:   rgba(16, 185, 129, 0.12);
  --profession-ambasador-bg:  rgba(217, 119,   6, 0.12);
  --profession-fotograf-bg:   rgba(99, 102, 241, 0.12);
  --profession-mua-bg:        rgba(236,  72, 153, 0.12);

  /* Obramowania kafelków profesji (25% opacity) */
  --profession-hostessa-border:   rgba(124, 58, 237, 0.25);
  --profession-model-border:      rgba(219, 39, 119, 0.25);
  --profession-influencer-border: rgba(14, 165, 233, 0.25);
  --profession-promotor-border:   rgba(16, 185, 129, 0.25);
  --profession-ambasador-border:  rgba(217, 119,   6, 0.25);
  --profession-fotograf-border:   rgba(99, 102, 241, 0.25);
  --profession-mua-border:        rgba(236,  72, 153, 0.25);

  /* ----------------------------------------------------------
     TYPOGRAFIA — FONTY
     ---------------------------------------------------------- */

  --font-heading: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-serif:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-mono:    'Courier New', Courier, monospace;

  /* ----------------------------------------------------------
     TYPOGRAFIA — ROZMIARY (clamp: mobile → desktop)
     ---------------------------------------------------------- */

  --text-xs:   0.75rem;    /* 12px */
  --text-sm:   0.875rem;   /* 14px */
  --text-base: 1rem;       /* 16px */
  --text-lg:   1.125rem;   /* 18px */
  --text-xl:   1.25rem;    /* 20px */
  --text-2xl:  1.5rem;     /* 24px */
  --text-3xl:  1.875rem;   /* 30px */
  --text-4xl:  2.25rem;    /* 36px */

  /* Nagłówki responsywne */
  --h1-size:   clamp(2.25rem, 5vw, 4.5rem);
  --h2-size:   clamp(1.75rem, 3vw, 3rem);
  --h3-size:   clamp(1.35rem, 2.2vw, 2rem);
  --h4-size:   clamp(1.15rem, 1.8vw, 1.5rem);
  --h5-size:   clamp(1rem, 1.4vw, 1.25rem);
  --h6-size:   1rem;

  /* ----------------------------------------------------------
     TYPOGRAFIA — WAGI
     ---------------------------------------------------------- */

  --weight-light:    300;
  --weight-regular:  400;
  --weight-medium:   500;
  --weight-semibold: 600;
  --weight-bold:     700;
  --weight-extrabold:800;

  /* ----------------------------------------------------------
     TYPOGRAFIA — WYSOKOŚĆ LINII
     ---------------------------------------------------------- */

  --leading-none:    1;
  --leading-tight:   1.2;
  --leading-snug:    1.35;
  --leading-normal:  1.5;
  --leading-relaxed: 1.65;
  --leading-loose:   1.8;

  /* ----------------------------------------------------------
     TYPOGRAFIA — ODSTĘP LITER
     ---------------------------------------------------------- */

  --tracking-tight:  -0.02em;
  --tracking-normal:  0;
  --tracking-wide:    0.04em;
  --tracking-wider:   0.08em;
  --tracking-widest:  0.15em;

  /* ----------------------------------------------------------
     PRZESTRZEŃ (skala 4px)
     ---------------------------------------------------------- */

  --space-1:  0.25rem;   /* 4px  */
  --space-2:  0.5rem;    /* 8px  */
  --space-3:  0.75rem;   /* 12px */
  --space-4:  1rem;      /* 16px */
  --space-5:  1.25rem;   /* 20px */
  --space-6:  1.5rem;    /* 24px */
  --space-8:  2rem;      /* 32px */
  --space-10: 2.5rem;    /* 40px */
  --space-12: 3rem;      /* 48px */
  --space-16: 4rem;      /* 64px */
  --space-20: 5rem;      /* 80px */
  --space-24: 6rem;      /* 96px */
  --space-32: 8rem;      /* 128px */

  /* Sekcje stron */
  --section-py:       clamp(3rem, 6vw, 5rem);
  --section-py-lg:    clamp(4rem, 8vw, 7rem);

  /* ----------------------------------------------------------
     ZAOKRĄGLENIA
     ---------------------------------------------------------- */

  --radius-xs:   4px;
  --radius-sm:   6px;
  --radius-md:   12px;
  --radius-lg:   20px;
  --radius-xl:   32px;
  --radius-2xl:  48px;
  --radius-full: 9999px;

  /* ----------------------------------------------------------
     CIENIE
     ---------------------------------------------------------- */

  --shadow-xs:     0 1px 2px  rgba(0, 0, 0, 0.05);
  --shadow-sm:     0 1px 3px  rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.06);
  --shadow-md:     0 4px 16px rgba(0, 0, 0, 0.10), 0 2px 4px  rgba(0, 0, 0, 0.06);
  --shadow-lg:     0 8px 32px rgba(0, 0, 0, 0.12), 0 4px 8px  rgba(0, 0, 0, 0.08);
  --shadow-xl:     0 16px 48px rgba(0, 0, 0, 0.14), 0 8px 16px rgba(0, 0, 0, 0.08);
  --shadow-2xl:    0 24px 64px rgba(0, 0, 0, 0.18);

  /* Cienie marki */
  --shadow-purple: 0 8px 32px  rgba(124, 58, 237, 0.20);
  --shadow-pink:   0 8px 32px  rgba(219, 39, 119, 0.18);
  --shadow-brand:  0 12px 40px rgba(124, 58, 237, 0.25);

  /* Cień karty przy hover */
  --shadow-card:       var(--shadow-md);
  --shadow-card-hover: var(--shadow-lg);

  /* ----------------------------------------------------------
     LAYOUT — KONTENERY
     ---------------------------------------------------------- */

  --container-max:    1280px;
  --container-wide:   1440px;
  --container-narrow: 860px;
  --container-xs:     640px;
  --container-px:     clamp(1rem, 4vw, 2rem);  /* padding boczny */

  /* ----------------------------------------------------------
     NAWIGACJA
     ---------------------------------------------------------- */

  --nav-height:      72px;
  --nav-height-sm:   64px;
  --nav-bg:          rgba(255, 255, 255, 0.96);
  --nav-bg-scrolled: rgba(255, 255, 255, 0.99);
  --nav-blur:        blur(12px);

  /* ----------------------------------------------------------
     PRZEJŚCIA / ANIMACJE
     ---------------------------------------------------------- */

  --transition-fast:   150ms ease;
  --transition-base:   250ms ease;
  --transition-slow:   400ms ease;
  --transition-bounce: 350ms cubic-bezier(0.34, 1.56, 0.64, 1);

  /* ----------------------------------------------------------
     Z-INDEX
     ---------------------------------------------------------- */

  --z-below:      -1;
  --z-base:        0;
  --z-raised:      10;
  --z-dropdown:    100;
  --z-sticky:      200;
  --z-overlay:     300;
  --z-modal:       400;
  --z-popup:       500;
  --z-toast:       600;
  --z-nav:         700;
  --z-top:         9999;

  /* ----------------------------------------------------------
     FORMULARZE
     ---------------------------------------------------------- */

  --input-height:     48px;
  --input-height-sm:  40px;
  --input-height-lg:  56px;
  --input-px:         var(--space-4);
  --input-radius:     var(--radius-md);
  --input-border:     1px solid var(--color-border);
  --input-border-focus: 2px solid var(--color-primary);

  /* ----------------------------------------------------------
     KARTY PROFILI
     ---------------------------------------------------------- */

  --card-aspect-portrait:  3 / 4;
  --card-radius:           var(--radius-lg);
  --card-shadow:           var(--shadow-md);
  --card-shadow-hover:     var(--shadow-purple);

  /* ----------------------------------------------------------
     BREAKPOINTY (do użycia w JS — lustro media queries)
     ---------------------------------------------------------- */

  --bp-sm:  480px;
  --bp-md:  768px;
  --bp-lg:  1024px;
  --bp-xl:  1280px;

}

/* ============================================================
   DARK MODE — placeholder (V2)
   ============================================================ */
/* @media (prefers-color-scheme: dark) { :root { ... } } */

/* === reset.css === */
/* ============================================================
   INFLUMODELS — Modern CSS Reset
   Plik: assets/css/base/reset.css
   Oparty na: Andy Bell's Modern Reset + Normalize.css v8
   ============================================================ */

/* ----------------------------------------------------------
   BOX MODEL
   ---------------------------------------------------------- */

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

/* ----------------------------------------------------------
   DOKUMENT
   ---------------------------------------------------------- */

html {
  font-size:               16px;
  scroll-behavior:         smooth;
  text-size-adjust:        100%;
  -webkit-text-size-adjust:100%;
  tab-size:                4;
  hanging-punctuation:     first last;
}

/* Gdy użytkownik preferuje brak animacji */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration:   0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration:  0.01ms !important;
    scroll-behavior:      auto !important;
  }
}

/* ----------------------------------------------------------
   BODY
   ---------------------------------------------------------- */

body {
  min-height:          100vh;
  min-height:          100dvh;
  font-family:         var(--font-body);
  font-size:           var(--text-base);
  font-weight:         var(--weight-regular);
  line-height:         var(--leading-normal);
  color:               var(--color-text);
  background-color:    var(--color-bg);
  -webkit-font-smoothing:  antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering:      optimizeLegibility;
  overflow-x:          hidden;
}

/* ----------------------------------------------------------
   NAGŁÓWKI
   ---------------------------------------------------------- */

h1, h2, h3, h4, h5, h6 {
  font-family:    var(--font-heading);
  font-weight:    var(--weight-bold);
  line-height:    var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color:          var(--color-text);
  overflow-wrap:  break-word;
}

/* ----------------------------------------------------------
   TEKST
   ---------------------------------------------------------- */

p {
  overflow-wrap: break-word;
}

p + p {
  margin-top: var(--space-4);
}

/* ----------------------------------------------------------
   LISTY
   ---------------------------------------------------------- */

ul,
ol {
  list-style: none;
}

/* Listy w treści edytorskiej zachowują styl */
.prose ul,
.prose ol,
.content ul,
.content ol {
  list-style: revert;
  padding-left: var(--space-6);
}

/* ----------------------------------------------------------
   LINKI
   ---------------------------------------------------------- */

a {
  color:           inherit;
  text-decoration: none;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* ----------------------------------------------------------
   MEDIA
   ---------------------------------------------------------- */

img,
picture,
video,
canvas,
svg {
  display:   block;
  max-width: 100%;
}

img {
  height:           auto;
  vertical-align:   middle;
  font-style:       italic;  /* alt text stylizowany gdy brak obrazu */
  background-repeat:no-repeat;
  background-size:  cover;
}

/* Lazy loading placeholder */
img[loading="lazy"] {
  opacity:    0;
  transition: opacity var(--transition-base);
}

img.loaded,
img[loading="lazy"].loaded {
  opacity: 1;
}

/* ----------------------------------------------------------
   FORMULARZE
   ---------------------------------------------------------- */

input,
button,
textarea,
select {
  font:         inherit;
  color:        inherit;
  background:   none;
  border:       none;
  outline:      none;
  appearance:   none;
  -webkit-appearance: none;
}

button {
  cursor:    pointer;
  display:   inline-flex;
  align-items: center;
  justify-content: center;
  gap:       var(--space-2);
  line-height: 1;
  border-radius: var(--radius-sm);
}

button:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  cursor:  not-allowed;
  opacity: 0.55;
}

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

/* Number input — usuń strzałki */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  appearance: none;
  -webkit-appearance: none;
}

input[type="number"] {
  -moz-appearance: textfield;
}

/* Search input — usuń ikonę X */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  appearance: none;
  -webkit-appearance: none;
}

/* ----------------------------------------------------------
   FOCUS — DOSTĘPNOŚĆ
   Wyłączamy domyślny outline, ale zachowujemy dla klawiatury
   ---------------------------------------------------------- */

:focus {
  outline: none;
}

:focus-visible {
  outline:        2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius:  var(--radius-xs);
}

/* ----------------------------------------------------------
   TABELA
   ---------------------------------------------------------- */

table {
  border-collapse: collapse;
  border-spacing:  0;
  width:           100%;
}

th {
  font-weight: var(--weight-semibold);
  text-align:  left;
}

/* ----------------------------------------------------------
   INNE
   ---------------------------------------------------------- */

hr {
  border:           none;
  border-top:       1px solid var(--color-border);
  margin:           var(--space-8) 0;
  color:            inherit;
}

abbr[title] {
  text-decoration:  underline dotted;
  cursor:           help;
}

strong, b {
  font-weight: var(--weight-bold);
}

em, i {
  font-style: italic;
}

small {
  font-size: var(--text-sm);
}

sub,
sup {
  font-size:      75%;
  line-height:    0;
  position:       relative;
  vertical-align: baseline;
}

sup { top: -0.5em; }
sub { bottom: -0.25em; }

mark {
  background-color: rgba(124, 58, 237, 0.15);
  color:            var(--color-text);
  border-radius:    var(--radius-xs);
  padding:          0 var(--space-1);
}

code,
kbd,
samp,
pre {
  font-family: var(--font-mono);
  font-size:   0.9em;
}

pre {
  overflow:   auto;
  background: var(--color-bg-alt);
  padding:    var(--space-4);
  border-radius: var(--radius-md);
}

blockquote {
  border-left:   4px solid var(--color-primary);
  padding-left:  var(--space-6);
  font-style:    italic;
  color:         var(--color-text-muted);
}

details > summary {
  cursor: pointer;
}

/* ----------------------------------------------------------
   SCROLLBAR (Webkit/Blink)
   ---------------------------------------------------------- */

::-webkit-scrollbar {
  width:  8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--color-bg-alt);
}

::-webkit-scrollbar-thumb {
  background:    var(--color-primary-light);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-primary);
}

/* ----------------------------------------------------------
   SELEKCJA TEKSTU
   ---------------------------------------------------------- */

::selection {
  background-color: rgba(124, 58, 237, 0.18);
  color:            var(--color-text);
}

/* ----------------------------------------------------------
   PLACEHOLDER
   ---------------------------------------------------------- */

::placeholder {
  color:   var(--color-text-light);
  opacity: 1;
}

/* ----------------------------------------------------------
   UTILITIES RESETUJĄCE HELPER
   ---------------------------------------------------------- */

.sr-only {
  position:   absolute;
  width:      1px;
  height:     1px;
  padding:    0;
  margin:     -1px;
  overflow:   hidden;
  clip:       rect(0, 0, 0, 0);
  white-space:nowrap;
  border:     0;
}

.no-scroll {
  overflow: hidden;
}

/* === typography.css === */
/* ============================================================
   INFLUMODELS — Typography System
   Plik: assets/css/base/typography.css
   Wymaga: variables.css, reset.css
   ============================================================ */

/* ----------------------------------------------------------
   @FONT-FACE — CORMORANT GARAMOND (self-hosted)
   Pliki: assets/fonts/cormorant-garamond/
   Wersja: v21, plik: latin_latin-ext
   ---------------------------------------------------------- */

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  normal;
  font-weight: 300;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-300.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  italic;
  font-weight: 300;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-300italic.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  normal;
  font-weight: 400;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-regular.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  italic;
  font-weight: 400;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-italic.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  normal;
  font-weight: 500;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-500.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  italic;
  font-weight: 500;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-500italic.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  normal;
  font-weight: 600;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-600.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  italic;
  font-weight: 600;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-600italic.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  normal;
  font-weight: 700;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-700.woff2') format('woff2');
}

@font-face {
  font-family: 'Cormorant Garamond';
  font-style:  italic;
  font-weight: 700;
  font-display:swap;
  src: url('base/../../fonts/cormorant-garamond/cormorant-garamond-v21-latin_latin-ext-700italic.woff2') format('woff2');
}

/* ----------------------------------------------------------
   @FONT-FACE — INTER (self-hosted)
   Pliki: assets/fonts/inter/
   Wersja: v20, plik: latin_latin-ext
   ---------------------------------------------------------- */

@font-face {
  font-family: 'Inter';
  font-style:  normal;
  font-weight: 300;
  font-display:swap;
  src: url('base/../../fonts/inter/inter-v20-latin_latin-ext-300.woff2') format('woff2');
}

@font-face {
  font-family: 'Inter';
  font-style:  normal;
  font-weight: 400;
  font-display:swap;
  src: url('base/../../fonts/inter/inter-v20-latin_latin-ext-regular.woff2') format('woff2');
}

@font-face {
  font-family: 'Inter';
  font-style:  normal;
  font-weight: 500;
  font-display:swap;
  src: url('base/../../fonts/inter/inter-v20-latin_latin-ext-500.woff2') format('woff2');
}

@font-face {
  font-family: 'Inter';
  font-style:  normal;
  font-weight: 600;
  font-display:swap;
  src: url('base/../../fonts/inter/inter-v20-latin_latin-ext-600.woff2') format('woff2');
}

@font-face {
  font-family: 'Inter';
  font-style:  normal;
  font-weight: 700;
  font-display:swap;
  src: url('base/../../fonts/inter/inter-v20-latin_latin-ext-700.woff2') format('woff2');
}

@font-face {
  font-family: 'Inter';
  font-style:  normal;
  font-weight: 800;
  font-display:swap;
  src: url('base/../../fonts/inter/inter-v20-latin_latin-ext-800.woff2') format('woff2');
}

/* ----------------------------------------------------------
   NAGŁÓWKI — SKALA
   ---------------------------------------------------------- */

h1 {
  font-size:      var(--h1-size);
  font-weight:    var(--weight-bold);
  line-height:    var(--leading-tight);
  letter-spacing: -0.03em;
}

h2 {
  font-size:      var(--h2-size);
  font-weight:    var(--weight-bold);
  line-height:    var(--leading-tight);
  letter-spacing: -0.025em;
}

h3 {
  font-size:      var(--h3-size);
  font-weight:    var(--weight-semibold);
  line-height:    var(--leading-snug);
  letter-spacing: -0.02em;
}

h4 {
  font-size:      var(--h4-size);
  font-weight:    var(--weight-semibold);
  line-height:    var(--leading-snug);
}

h5 {
  font-size:      var(--h5-size);
  font-weight:    var(--weight-medium);
  line-height:    var(--leading-normal);
}

h6 {
  font-size:      var(--h6-size);
  font-weight:    var(--weight-medium);
  line-height:    var(--leading-normal);
}

/* ----------------------------------------------------------
   NAGŁÓWKI — WARIANTY DEKORACYJNE
   ---------------------------------------------------------- */

.heading-serif {
  font-family:    var(--font-heading);
  font-weight:    var(--weight-bold);
}

.heading-display {
  font-family:    var(--font-heading);
  font-weight:    800;
  letter-spacing: -0.03em;
}

/* Podkreślenie gradientowe pod nagłówkiem sekcji */
.heading-section {
  font-family:    var(--font-heading);
  font-weight:    var(--weight-bold);
  position:       relative;
  display:        inline-block;
}

.heading-section::after {
  content:       '';
  position:      absolute;
  bottom:        -10px;
  left:          0;
  width:         60px;
  height:        3px;
  background:    var(--gradient-primary);
  border-radius: var(--radius-full);
}

.heading-section--center::after {
  left:      50%;
  transform: translateX(-50%);
}

/* ----------------------------------------------------------
   TEKST — KLASY UTILITY
   ---------------------------------------------------------- */

/* Rozmiary */
.text-xs     { font-size: var(--text-xs);   }
.text-sm     { font-size: var(--text-sm);   }
.text-base   { font-size: var(--text-base); }
.text-lg     { font-size: var(--text-lg);   }
.text-xl     { font-size: var(--text-xl);   }
.text-2xl    { font-size: var(--text-2xl);  }
.text-3xl    { font-size: var(--text-3xl);  }
.text-4xl    { font-size: var(--text-4xl);  }

/* Wagi */
.font-light     { font-weight: var(--weight-light);    }
.font-regular   { font-weight: var(--weight-regular);  }
.font-medium    { font-weight: var(--weight-medium);   }
.font-semibold  { font-weight: var(--weight-semibold); }
.font-bold      { font-weight: var(--weight-bold);     }

/* Rodziny */
.font-heading { font-family: var(--font-heading); }
.font-body    { font-family: var(--font-body);    }
.font-mono    { font-family: var(--font-mono);    }

/* Kolory tekstu */
.text-primary  { color: var(--color-primary);    }
.text-secondary{ color: var(--color-secondary);  }
.text-muted    { color: var(--color-text-muted); }
.text-light    { color: var(--color-text-light); }
.text-white    { color: var(--color-text-white); }
.text-success  { color: var(--color-success);    }
.text-warning  { color: var(--color-warning);    }
.text-error    { color: var(--color-error);      }

/* Wyrównanie */
.text-left    { text-align: left;    }
.text-center  { text-align: center;  }
.text-right   { text-align: right;   }

/* Styl */
.italic   { font-style:  italic;     }
.not-italic { font-style: normal;    }
.uppercase  { text-transform: uppercase;  }
.lowercase  { text-transform: lowercase;  }
.capitalize { text-transform: capitalize; }
.no-transform { text-transform: none;     }

/* Odstęp liter */
.tracking-tight   { letter-spacing: var(--tracking-tight);   }
.tracking-normal  { letter-spacing: var(--tracking-normal);  }
.tracking-wide    { letter-spacing: var(--tracking-wide);    }
.tracking-wider   { letter-spacing: var(--tracking-wider);   }
.tracking-widest  { letter-spacing: var(--tracking-widest);  }

/* Wysokość linii */
.leading-tight    { line-height: var(--leading-tight);    }
.leading-snug     { line-height: var(--leading-snug);     }
.leading-normal   { line-height: var(--leading-normal);   }
.leading-relaxed  { line-height: var(--leading-relaxed);  }
.leading-loose    { line-height: var(--leading-loose);    }

/* Przepełnienie tekstu */
.truncate {
  overflow:      hidden;
  text-overflow: ellipsis;
  white-space:   nowrap;
}

.line-clamp-2 {
  display:            -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:           hidden;
}

.line-clamp-3 {
  display:            -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:           hidden;
}

/* ----------------------------------------------------------
   EFEKTY SPECJALNE TEKSTU
   ---------------------------------------------------------- */

/* Gradient text — efekt fiolet→róż */
.text-gradient {
  background:              var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip:         text;
  -webkit-text-fill-color: transparent;
  color:                   transparent;
}

/* Podkreślenie w stylu premium */
.text-underline-brand {
  text-decoration:       underline;
  text-decoration-color: var(--color-primary);
  text-underline-offset: 4px;
  text-decoration-thickness: 2px;
}

/* Badge tekst — etykiety statusu */
.text-badge {
  font-size:      var(--text-xs);
  font-weight:    var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
}

/* Tagline — marketing intro nad nagłówkiem */
.text-tagline {
  font-family:    var(--font-body);
  font-size:      var(--text-xs);
  font-weight:    var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color:          var(--color-primary);
}

/* ----------------------------------------------------------
   LINKI
   ---------------------------------------------------------- */

.link {
  color:              var(--color-primary);
  text-decoration:    underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition:         color var(--transition-fast),
                      text-decoration-color var(--transition-fast);
}

.link:hover {
  color:                  var(--color-primary-dark);
  text-decoration-color:  var(--color-primary-dark);
}

.link--subtle {
  color:           var(--color-text-muted);
  text-decoration: none;
  transition:      color var(--transition-fast);
}

.link--subtle:hover {
  color: var(--color-primary);
}

/* ----------------------------------------------------------
   LEAD / WPROWADZENIE
   ---------------------------------------------------------- */

.lead {
  font-size:   var(--text-lg);
  line-height: var(--leading-relaxed);
  color:       var(--color-text-muted);
}

@media (min-width: 768px) {
  .lead {
    font-size: var(--text-xl);
  }
}

/* ----------------------------------------------------------
   PROSE — treść edytorska (regulamin, FAQ, strony CMS)
   ---------------------------------------------------------- */

.prose {
  max-width:   65ch;
  font-size:   var(--text-base);
  line-height: var(--leading-relaxed);
  color:       var(--color-text);
}

.prose h2 {
  font-size:   var(--h3-size);
  margin-top:  var(--space-10);
  margin-bottom: var(--space-4);
}

.prose h3 {
  font-size:   var(--h4-size);
  margin-top:  var(--space-8);
  margin-bottom: var(--space-3);
}

.prose p {
  margin-bottom: var(--space-4);
}

.prose ul,
.prose ol {
  margin-bottom: var(--space-4);
  padding-left:  var(--space-6);
}

.prose ul { list-style: disc;    }
.prose ol { list-style: decimal; }

.prose li {
  margin-bottom: var(--space-2);
}

.prose a {
  color:              var(--color-primary);
  text-decoration:    underline;
  text-underline-offset: 3px;
}

.prose strong {
  font-weight: var(--weight-semibold);
}

.prose blockquote {
  border-left:  4px solid var(--color-primary);
  padding-left: var(--space-5);
  margin:       var(--space-6) 0;
  font-style:   italic;
  color:        var(--color-text-muted);
}

.prose hr {
  margin: var(--space-10) 0;
}

/* ----------------------------------------------------------
   CYTATY / TESTIMONIALE
   ---------------------------------------------------------- */

.quote {
  font-family:    var(--font-heading);
  font-size:      clamp(1.25rem, 2vw, 1.75rem);
  font-style:     italic;
  line-height:    var(--leading-relaxed);
  color:          var(--color-text);
}

.quote::before { content: '\201C'; }
.quote::after  { content: '\201D'; }

/* ----------------------------------------------------------
   STATYSTYKI / LICZBY
   ---------------------------------------------------------- */

.stat-number {
  font-family:    var(--font-heading);
  font-size:      clamp(2.5rem, 5vw, 4rem);
  font-weight:    var(--weight-bold);
  line-height:    var(--leading-none);
  letter-spacing: var(--tracking-tight);
  background:     var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip:         text;
  -webkit-text-fill-color: transparent;
  color:          transparent;
}

.stat-label {
  font-size:      var(--text-sm);
  font-weight:    var(--weight-medium);
  color:          var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  margin-top:     var(--space-1);
}

/* === grid.css === */
/* ============================================================
   INFLUMODELS — Layout: Grid & Container
   assets/css/layout/grid.css
   ============================================================ */

/* ============================================================
   KONTENERY
   ============================================================ */

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

.container--wide {
  max-width: var(--container-wide);
}

.container--narrow {
  max-width: var(--container-narrow);
}

.container--xs {
  max-width: var(--container-xs);
}

/* ============================================================
   SEKCJE STRON
   ============================================================ */

.section {
  padding-block: var(--section-py);
}

.section--lg {
  padding-block: var(--section-py-lg);
}

.section--sm {
  padding-block: clamp(1.5rem, 3vw, 2.5rem);
}

/* Alternatywne tło co drugą sekcję */
.section--alt {
  background-color: var(--color-bg-alt);
}

/* Sekcja z subtelnym gradientem marki */
.section--tinted {
  background: var(--gradient-light);
}

/* Ciemna sekcja (np. CTA) */
.section--dark {
  background-color: var(--color-bg-dark);
  color: var(--color-text-white);
}

/* Separator między sekcjami */
.section-divider {
  height: 1px;
  background: linear-gradient(
    to right,
    transparent,
    var(--color-border),
    transparent
  );
  border: none;
  margin: 0;
}

/* ============================================================
   NAGŁÓWKI SEKCJI
   ============================================================ */

.section-header {
  text-align: center;
  margin-bottom: clamp(2rem, 4vw, 3.5rem);
}

.section-header--left {
  text-align: left;
}

.section-eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-3);
}

.section-title {
  font-family: var(--font-heading);
  font-size: var(--h2-size);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  color: var(--color-text);
  margin-bottom: var(--space-4);
}

.section-title--white {
  color: var(--color-text-white);
}

.section-lead {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  max-width: 600px;
  margin-inline: auto;
}

.section-header--left .section-lead {
  margin-inline: 0;
}

/* ============================================================
   GRID SYSTEM
   ============================================================ */

.grid {
  display: grid;
  gap: var(--space-6);
}

/* Kolumny z auto-fill (np. karty profili) */
.grid-profiles {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-6);
}

.grid-agencies {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-6);
}

/* Stałe gridy */
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-5 { grid-template-columns: repeat(5, 1fr); }
.grid-6 { grid-template-columns: repeat(6, 1fr); }

/* Grid z sidebar */
.grid-sidebar {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-8);
  align-items: start;
}

.grid-sidebar--left {
  grid-template-columns: 320px 1fr;
}

/* ============================================================
   FLEX UTILITIES
   ============================================================ */

.flex           { display: flex; }
.flex-col       { display: flex; flex-direction: column; }
.flex-wrap      { flex-wrap: wrap; }
.flex-center    { display: flex; align-items: center; justify-content: center; }
.flex-between   { display: flex; align-items: center; justify-content: space-between; }
.flex-start     { display: flex; align-items: flex-start; }
.flex-end       { display: flex; align-items: center; justify-content: flex-end; }

.flex-1  { flex: 1; }
.flex-auto { flex: 0 0 auto; }

.gap-1  { gap: var(--space-1); }
.gap-2  { gap: var(--space-2); }
.gap-3  { gap: var(--space-3); }
.gap-4  { gap: var(--space-4); }
.gap-6  { gap: var(--space-6); }
.gap-8  { gap: var(--space-8); }
.gap-12 { gap: var(--space-12); }

/* ============================================================
   SPACING UTILITIES
   ============================================================ */

.mt-auto { margin-top: auto; }
.mb-auto { margin-bottom: auto; }
.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }
.mx-auto { margin-inline: auto; }

/* ============================================================
   DISPLAY / VISIBILITY
   ============================================================ */

.hidden     { display: none !important; }
.invisible  { visibility: hidden; }
.block      { display: block; }
.inline     { display: inline; }
.inline-block { display: inline-block; }

/* ============================================================
   BODY PADDING (compensation for fixed navbar)
   ============================================================ */

body {
  padding-top: var(--nav-height);
}

/* ============================================================
   RESPONSIVE — zmniejszanie kolumn
   ============================================================ */

@media (max-width: 1024px) {
  .grid-sidebar,
  .grid-sidebar--left {
    grid-template-columns: 1fr;
  }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-6 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .grid-2,
  .grid-3,
  .grid-5 { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-6 { grid-template-columns: repeat(2, 1fr); }

  .grid-profiles {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--space-4);
  }
}

@media (max-width: 480px) {
  .grid-4,
  .grid-6 { grid-template-columns: 1fr; }
}

/* === navbar.css === */
/* ============================================================
   INFLUMODELS — Layout: Navbar
   assets/css/layout/navbar.css
   ============================================================ */

/* ============================================================
   NAVBAR — FUNDAMENT
   ============================================================ */

.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-nav);
  height: var(--nav-height);
  background: var(--nav-bg);
  backdrop-filter: var(--nav-blur);
  -webkit-backdrop-filter: var(--nav-blur);
  border-bottom: 1px solid transparent;
  transition:
    background var(--transition-base),
    border-color var(--transition-base),
    box-shadow var(--transition-base);
}

/* Stan po przewinięciu — wstrzykiwany przez navbar.js */
.navbar[data-scrolled="true"] {
  background: var(--nav-bg-scrolled);
  border-bottom-color: var(--color-border-light);
  box-shadow: var(--shadow-sm);
}

/* ============================================================
   NAVBAR — WEWNĘTRZNY UKŁAD
   ============================================================ */

.navbar__inner {
  display: flex;
  align-items: center;
  height: 100%;
  gap: var(--space-6);
}

/* ============================================================
   LOGO
   ============================================================ */

.navbar__logo {
  font-family: var(--font-body);
  font-size: 1.125rem;
  font-weight: var(--weight-extrabold);
  letter-spacing: var(--tracking-wider);
  text-decoration: none;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap;
  flex-shrink: 0;
  transition: opacity var(--transition-fast);
}

.navbar__logo:hover {
  opacity: 0.85;
}

.navbar__logo-star {
  display: inline-block;
  margin-inline: 1px;
}

/* ============================================================
   NAWIGACJA — DESKTOP
   ============================================================ */

.navbar__nav {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-left: auto;
}

.navbar__link {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  transition:
    color var(--transition-fast),
    background var(--transition-fast);
  white-space: nowrap;
}

.navbar__link:hover {
  color: var(--color-text);
  background: var(--color-bg-alt);
}

.navbar__link--active {
  color: var(--color-primary);
  background: var(--color-primary-bg);
  font-weight: var(--weight-semibold);
}

.navbar__link--active:hover {
  background: var(--color-primary-bg-hover);
}

/* ============================================================
   AKCJE (prawa strona)
   ============================================================ */

.navbar__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}

/* ============================================================
   DROPDOWN UŻYTKOWNIKA
   ============================================================ */

.navbar__user {
  position: relative;
}

.navbar__user-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-2);
  background: none;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text);
  transition: background var(--transition-fast);
}

.navbar__user-btn:hover {
  background: var(--color-bg-alt);
}

/* Avatar z inicjałem */
.navbar__avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-full);
  background: var(--gradient-primary);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  font-style: normal;
  flex-shrink: 0;
}

.navbar__avatar--lg {
  width: 44px;
  height: 44px;
  font-size: var(--text-sm);
}

.navbar__user-name {
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.navbar__chevron {
  color: var(--color-text-muted);
  flex-shrink: 0;
  transition: transform var(--transition-fast);
}

.navbar__user-btn[aria-expanded="true"] .navbar__chevron {
  transform: rotate(180deg);
}

/* Panel dropdown */
.navbar__dropdown {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  min-width: 200px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: var(--space-2);
  animation: dropdownFadeIn 150ms ease;
}

.navbar__dropdown[hidden] {
  display: none;
}

@keyframes dropdownFadeIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.navbar__dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text);
  text-decoration: none;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.navbar__dropdown-item svg {
  color: var(--color-text-muted);
  flex-shrink: 0;
  transition: color var(--transition-fast);
}

.navbar__dropdown-item:hover {
  background: var(--color-bg-alt);
  color: var(--color-primary);
}

.navbar__dropdown-item:hover svg {
  color: var(--color-primary);
}

.navbar__dropdown-item--danger {
  color: var(--color-error);
}

.navbar__dropdown-item--danger svg {
  color: var(--color-error);
}

.navbar__dropdown-item--danger:hover {
  background: var(--color-error-bg);
  color: var(--color-error-dark);
}

.navbar__dropdown-divider {
  height: 1px;
  background: var(--color-border-light);
  margin: var(--space-2) 0;
}

/* ============================================================
   PRZYCISKI AUTH (gość)
   ============================================================ */

.navbar__btn-login,
.navbar__btn-register {
  white-space: nowrap;
}

/* ============================================================
   HAMBURGER (widoczny tylko na mobile)
   ============================================================ */

.navbar__hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  padding: var(--space-2);
  background: none;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  margin-left: auto;
  transition: background var(--transition-fast);
}

.navbar__hamburger:hover {
  background: var(--color-bg-alt);
}

.navbar__bar {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-text);
  border-radius: 2px;
  transform-origin: center;
  transition:
    transform var(--transition-base),
    opacity var(--transition-base),
    background var(--transition-fast);
}

/* Hamburger → X (gdy menu otwarte) */
.navbar__hamburger.is-active .navbar__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.navbar__hamburger.is-active .navbar__bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.navbar__hamburger.is-active .navbar__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ============================================================
   MENU MOBILNE
   ============================================================ */

.navbar__mobile {
  display: none;
  position: fixed;
  top: var(--nav-height);
  left: 0;
  right: 0;
  bottom: 0;
  background: #fff;
  overflow-y: auto;
  padding: var(--space-6) var(--container-px) var(--space-8);
  /* Wyższy od --z-nav bo menu jest poza <header>, musi przykryć treść strony */
  z-index: calc(var(--z-nav) + 10);
  transform: translateY(-8px);
  opacity: 0;
  transition:
    transform var(--transition-base),
    opacity var(--transition-base);
  pointer-events: none;
}

.navbar__mobile.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.navbar__mobile-nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  border-bottom: 1px solid var(--color-border-light);
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-5);
}

.navbar__mobile-link {
  display: block;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--color-text);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: background var(--transition-fast), color var(--transition-fast);
}

.navbar__mobile-link:hover {
  background: var(--color-bg-alt);
  color: var(--color-primary);
}

.navbar__mobile-link--active {
  color: var(--color-primary);
  background: var(--color-primary-bg);
  font-weight: var(--weight-semibold);
}

.navbar__mobile-link--danger {
  color: var(--color-error);
}

.navbar__mobile-link--danger:hover {
  background: var(--color-error-bg);
  color: var(--color-error-dark);
}

/* Panel zalogowanego użytkownika (mobile) */
.navbar__mobile-user {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-top: var(--space-2);
}

.navbar__mobile-user-info {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-primary-bg);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
}

.navbar__mobile-name {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
}

.navbar__mobile-role {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 2px;
}

.navbar__mobile-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

/* Przyciski auth (mobile, gość) */
.navbar__mobile-auth {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* ============================================================
   RESPONSIVE — BREAKPOINT 1024px
   ============================================================ */

@media (max-width: 1024px) {
  .navbar__nav,
  .navbar__actions {
    display: none;
  }

  .navbar__hamburger {
    display: flex;
  }

  .navbar__mobile {
    display: block;
  }
}

/* ── Photo avatar variant ── */
.navbar__avatar--photo {
  object-fit: cover;
  display: block;
}

/* ── FB-style icon buttons ── */
.nb-icon-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--color-bg-alt, #F3F4F6);
  border: none;
  cursor: pointer;
  color: var(--color-text, #1A1A2E);
  flex-shrink: 0;
  transition: background .15s;
  text-decoration: none;
}
.nb-icon-btn:hover { background: #E5E7EB; }
.nb-badge {
  position: absolute;
  top: 1px;
  right: 1px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 9px;
  background: #EF4444;
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  line-height: 18px;
  text-align: center;
  pointer-events: none;
}

/* ── Notification panel ── */
.nb-notif {
  position: relative;
}
.nb-notif-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: -4px;
  width: 360px;
  max-width: calc(100vw - 16px);
  background: var(--color-bg, #fff);
  border: 1px solid var(--color-border, #EAE8F5);
  border-radius: 12px;
  box-shadow: var(--shadow-lg, 0 10px 40px rgba(0,0,0,.14));
  z-index: 9999;
  overflow: hidden;
}
.nb-notif-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .85rem 1rem;
  border-bottom: 1px solid var(--color-border, #EAE8F5);
}
.nb-notif-title {
  font-weight: 700;
  font-size: .95rem;
  color: var(--color-heading, #1A1A2E);
}
.nb-notif-read-all {
  font-size: .78rem;
  color: #7C3AED;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  font-family: inherit;
}
.nb-notif-read-all:hover { text-decoration: underline; }
.nb-notif-list {
  max-height: 420px;
  overflow-y: auto;
}
.nb-notif-empty {
  text-align: center;
  color: #9A9ABA;
  font-size: .85rem;
  padding: 1.75rem 1rem;
  margin: 0;
}
.nb-notif-item {
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  padding: .75rem 1rem;
  border-bottom: 1px solid #F5F3FF;
  cursor: default;
  position: relative;
  transition: background .1s;
  text-decoration: none;
  color: inherit;
}
a.nb-notif-item { cursor: pointer; }
.nb-notif-item:last-child { border-bottom: none; }
.nb-notif-item--unread { background: #F5F3FF; }
.nb-notif-item:hover { background: #EDE9FE; }
.nb-notif-av {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: #EDE9FE;
}
.nb-notif-av--init {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: .8rem;
  color: #7C3AED;
}
.nb-notif-body {
  flex: 1;
  font-size: .82rem;
  line-height: 1.45;
  color: var(--color-text, #3D3D5C);
  min-width: 0;
  word-break: break-word;
}
.nb-notif-body strong { color: var(--color-heading, #1A1A2E); }
.nb-notif-time {
  margin-top: .2rem;
  font-size: .72rem;
  color: #A0A0B8;
}
.nb-notif-thumb {
  width: 44px;
  height: 44px;
  border-radius: 6px;
  object-fit: cover;
  flex-shrink: 0;
}
.nb-notif-dot {
  position: absolute;
  top: 50%;
  right: .65rem;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #7C3AED;
}

/* === footer.css === */
/* ============================================================
   INFLUMODELS — Layout: Footer + Flash Messages
   assets/css/layout/footer.css
   ============================================================ */

/* ============================================================
   FOOTER — FUNDAMENT
   ============================================================ */

.footer {
  background-color: var(--color-bg-footer);
  color: var(--color-text-xlight);
  margin-top: auto;
}

/* ============================================================
   FOOTER — WEWNĘTRZNY UKŁAD (brand + linki)
   ============================================================ */

.footer__inner {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: clamp(2rem, 6vw, 5rem);
  padding-top: clamp(3rem, 6vw, 5rem);
  padding-bottom: clamp(2rem, 4vw, 3.5rem);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

/* ============================================================
   FOOTER — KOLUMNA MARKI
   ============================================================ */

.footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.footer__logo {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 1.1rem;
  font-weight: var(--weight-extrabold);
  letter-spacing: var(--tracking-wider);
  text-decoration: none;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  width: fit-content;
  transition: opacity var(--transition-fast);
}

.footer__logo:hover {
  opacity: 0.85;
}

.footer__logo-star {
  display: inline-block;
  margin-inline: 1px;
}

.footer__tagline {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: rgba(255, 255, 255, 0.45);
}

/* ============================================================
   FOOTER — SOCIAL ICONS
   ============================================================ */

.footer__social {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.footer__social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-full);
  color: rgba(255, 255, 255, 0.45);
  background: rgba(255, 255, 255, 0.06);
  text-decoration: none;
  transition:
    color var(--transition-fast),
    background var(--transition-fast);
}

.footer__social-link:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.14);
}

/* ============================================================
   FOOTER — KOLUMNY LINKÓW
   ============================================================ */

.footer__links {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.footer__col {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer__col-heading {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
}

.footer__col-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer__col-list a {
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.45);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer__col-list a:hover {
  color: rgba(255, 255, 255, 0.85);
}

/* ============================================================
   FOOTER — PASEK DOLNY
   ============================================================ */

.footer__bottom {
  padding-block: var(--space-5);
}

.footer__bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer__copy,
.footer__made {
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.3);
}

.footer__made span {
  color: var(--color-secondary-light);
}

/* ============================================================
   FLASH MESSAGES
   ============================================================ */

.flash-container {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 380px;
  width: calc(100vw - var(--space-12));
  pointer-events: none;
}

.flash {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  box-shadow: var(--shadow-lg);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
  animation: flashSlideIn 250ms ease;
  pointer-events: auto;
}

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

.flash--success {
  background: var(--color-success-bg);
  border-color: rgba(16, 185, 129, 0.25);
  color: var(--color-success-dark);
}

.flash--error {
  background: var(--color-error-bg);
  border-color: rgba(239, 68, 68, 0.25);
  color: var(--color-error-dark);
}

.flash--warning {
  background: var(--color-warning-bg);
  border-color: rgba(245, 158, 11, 0.25);
  color: var(--color-warning-dark);
}

.flash--info {
  background: var(--color-info-bg);
  border-color: rgba(59, 130, 246, 0.25);
  color: var(--color-info-dark);
}

.flash__text {
  flex: 1;
}

.flash__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  padding: 0;
  background: none;
  border: none;
  border-radius: var(--radius-xs);
  cursor: pointer;
  color: currentColor;
  opacity: 0.5;
  flex-shrink: 0;
  transition: opacity var(--transition-fast);
}

.flash__close:hover {
  opacity: 1;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1024px) {
  .footer__links {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

  .footer__links {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .footer__links {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-5) var(--space-4);
  }

  .footer__bottom-inner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-2);
  }

  .flash-container {
    bottom: var(--space-4);
    right: var(--space-4);
    width: calc(100vw - var(--space-8));
  }
}

/* === buttons.css === */
/* ============================================================
   INFLUMODELS — Components: Buttons
   assets/css/components/buttons.css
   ============================================================ */

/* ============================================================
   FUNDAMENT
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.625rem var(--space-5);
  height: var(--input-height);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  line-height: 1;
  letter-spacing: 0.01em;
  text-decoration: none;
  white-space: nowrap;
  border: 2px solid transparent;
  border-radius: var(--radius-full);
  cursor: pointer;
  user-select: none;
  transition:
    background var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast),
    box-shadow var(--transition-fast),
    opacity var(--transition-fast),
    transform 100ms ease;
  position: relative;
  overflow: hidden;
}

.btn:active:not(:disabled) {
  transform: scale(0.97);
}

.btn:disabled,
.btn.is-disabled {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

/* ============================================================
   WARIANTY KOLORÓW
   ============================================================ */

/* Gradient primary (violet → pink) */
.btn-primary {
  background: var(--gradient-primary);
  color: var(--color-text-white);
  border-color: transparent;
}

.btn-primary:hover {
  box-shadow: var(--shadow-brand);
  opacity: 0.92;
  color: var(--color-text-white);
}

.btn-primary:focus-visible {
  outline: 3px solid var(--color-primary-light);
  outline-offset: 2px;
}

/* Secondary (solid violet) */
.btn-secondary {
  background: var(--color-primary);
  color: var(--color-text-white);
  border-color: var(--color-primary);
}

.btn-secondary:hover {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: var(--color-text-white);
  box-shadow: var(--shadow-purple);
}

/* Outline */
.btn-outline {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn-outline:hover {
  background: var(--color-primary-bg);
  color: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
}

/* Ghost (obramowanie szare, hover fioletowy) */
.btn-ghost {
  background: transparent;
  color: var(--color-text-muted);
  border-color: var(--color-border);
}

.btn-ghost:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
}

/* White (na ciemnych tłach) */
.btn-white {
  background: #fff;
  color: var(--color-primary);
  border-color: #fff;
}

.btn-white:hover {
  background: var(--color-primary-bg);
  border-color: var(--color-primary-bg);
}

/* Danger */
.btn-danger {
  background: var(--color-error);
  color: #fff;
  border-color: var(--color-error);
}

.btn-danger:hover {
  background: var(--color-error-dark);
  border-color: var(--color-error-dark);
  box-shadow: 0 4px 16px rgba(239, 68, 68, 0.30);
}

/* Link style (bez tła, bez obramowania) */
.btn-link {
  background: none;
  border-color: transparent;
  color: var(--color-primary);
  padding-inline: var(--space-2);
  height: auto;
}

.btn-link:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}

/* ============================================================
   ROZMIARY
   ============================================================ */

.btn--xs {
  height: 32px;
  font-size: var(--text-xs);
  padding-inline: var(--space-3);
  gap: var(--space-1);
}

.btn--sm {
  height: var(--input-height-sm);
  font-size: var(--text-sm);
  padding-inline: var(--space-4);
}

.btn--lg {
  height: var(--input-height-lg);
  font-size: var(--text-base);
  padding-inline: var(--space-8);
}

.btn--xl {
  height: 60px;
  font-size: var(--text-lg);
  padding-inline: clamp(2rem, 4vw, 3rem);
  border-radius: var(--radius-full);
}

/* Pełna szerokość */
.btn--full {
  width: 100%;
}

/* Kwadratowy (ikona) */
.btn--icon {
  width: var(--input-height);
  padding: 0;
  flex-shrink: 0;
}

.btn--icon.btn--sm {
  width: var(--input-height-sm);
}

.btn--icon.btn--lg {
  width: var(--input-height-lg);
}

/* ============================================================
   STANY
   ============================================================ */

/* Loading — spinner zamiast tekstu */
.btn.is-loading {
  color: transparent;
  pointer-events: none;
}

.btn.is-loading::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-radius: 50%;
  animation: btnSpin 0.6s linear infinite;
  color: #fff;
}

.btn-ghost.is-loading::after,
.btn-outline.is-loading::after {
  color: var(--color-primary);
}

@keyframes btnSpin {
  to { transform: rotate(360deg); }
}

/* ============================================================
   GRUPY PRZYCISKÓW
   ============================================================ */

.btn-group {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.btn-group--center {
  justify-content: center;
}

.btn-group--full {
  display: flex;
}

.btn-group--full .btn {
  flex: 1;
}

/* === cards.css === */
/* ============================================================
   INFLUMODELS — Components: Cards
   assets/css/components/cards.css
   ============================================================ */

/* ============================================================
   KARTA GENERYCZNA
   ============================================================ */

.card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  overflow: hidden;
  transition:
    box-shadow var(--transition-base),
    transform var(--transition-base);
}

.card--hoverable:hover {
  box-shadow: var(--card-shadow-hover);
  transform: translateY(-3px);
}

.card__body {
  padding: var(--space-6);
}

.card__header {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-border-light);
}

.card__footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border-light);
  background: var(--color-bg-alt);
}

.card__title {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}

.card__subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ============================================================
   KARTA PROFILU (persona) — portret 3:4
   ============================================================ */

.profile-card {
  background: var(--color-bg-card);
  border-radius: var(--card-radius);
  overflow: hidden;
  box-shadow: var(--card-shadow);
  transition:
    box-shadow var(--transition-base),
    transform var(--transition-base);
  display: flex;
  flex-direction: column;
}

.profile-card:hover {
  box-shadow: var(--card-shadow-hover);
  transform: translateY(-4px);
}

/* Obraz — proporcja 3:4 */
.profile-card__image-wrap {
  position: relative;
  display: block;
  aspect-ratio: var(--card-aspect-portrait);
  overflow: hidden;
  background: var(--color-bg-alt);
  text-decoration: none;
}

.profile-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.5s ease;
}

.profile-card:hover .profile-card__img {
  transform: scale(1.04);
}

/* Gradient overlay (na dole zdjęcia) */
.profile-card__overlay {
  position: absolute;
  inset: 0;
  background: var(--gradient-card);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-3);
  pointer-events: none;
}

/* Blurowanie (dla niezalogowanych użytkowników) */
.profile-card__blur {
  display: none;
  position: absolute;
  inset: 0;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background: rgba(255, 255, 255, 0.20);
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-6);
}

.profile-card__blur-msg {
  color: #fff;
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-shadow: 0 1px 4px rgba(0,0,0,0.4);
  line-height: var(--leading-snug);
  margin-bottom: var(--space-3);
}

/* Aktywuj blur na poziomie body */
body:not(.user-logged-in) .profile-card__blur {
  display: flex;
  flex-direction: column;
}

/* Kafelki profesji (na zdjęciu, dół) */
.profile-card__professions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  position: absolute;
  bottom: var(--space-3);
  left: var(--space-3);
  right: var(--space-3);
  pointer-events: none;
}

/* Odznaki statusu (góra-prawa) */
.profile-card__badges {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  align-items: flex-end;
}

/* Treść karty (pod zdjęciem) */
.profile-card__body {
  padding: var(--space-4);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.profile-card__name {
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  line-height: var(--leading-snug);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.profile-card__meta {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.profile-card__meta-dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--color-border);
  flex-shrink: 0;
}

.profile-card__actions {
  margin-top: auto;
  padding-top: var(--space-2);
  display: flex;
  gap: var(--space-2);
}

/* ============================================================
   KARTA AGENCJI
   ============================================================ */

.agency-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition:
    box-shadow var(--transition-base),
    transform var(--transition-base),
    border-color var(--transition-base);
}

.agency-card:hover {
  box-shadow: var(--shadow-purple);
  transform: translateY(-3px);
  border-color: var(--color-primary-lighter);
}

.agency-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.agency-card__logo {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  object-fit: cover;
  background: var(--color-bg-alt);
  flex-shrink: 0;
  border: 1px solid var(--color-border);
}

.agency-card__info {
  min-width: 0;
}

.agency-card__name {
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.agency-card__type {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 2px;
}

.agency-card__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.agency-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-top: auto;
}

.agency-card__count {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

/* ============================================================
   KARTA FIRMY
   ============================================================ */

.company-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  padding: var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  transition:
    box-shadow var(--transition-base),
    border-color var(--transition-base);
}

.company-card:hover {
  box-shadow: var(--card-shadow-hover);
  border-color: var(--color-primary-lighter);
}

.company-card__logo {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  object-fit: contain;
  background: var(--color-bg-alt);
  flex-shrink: 0;
}

.company-card__info {
  flex: 1;
  min-width: 0;
}

.company-card__name {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
}

.company-card__industry {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* ============================================================
   KARTA STATYSTYK (dashboard / homepage)
   ============================================================ */

.stat-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
}

.stat-card__value {
  font-family: var(--font-heading);
  font-size: var(--h2-size);
  font-weight: var(--weight-bold);
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: var(--space-2);
}

.stat-card__label {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-weight: var(--weight-medium);
}

/* ============================================================
   KARTA PROMOCJI (featured slider)
   ============================================================ */

.promo-card {
  position: relative;
  border-radius: var(--card-radius);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  display: block;
  text-decoration: none;
}

.promo-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.promo-card:hover .promo-card__img {
  transform: scale(1.03);
}

.promo-card__body {
  position: absolute;
  inset: 0;
  background: var(--gradient-card);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-6);
  color: #fff;
}

.promo-card__title {
  font-family: var(--font-heading);
  font-size: var(--h4-size);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-2);
}

.promo-card__sub {
  font-size: var(--text-sm);
  opacity: 0.75;
}

/* === forms.css === */
/* ============================================================
   INFLUMODELS — Components: Forms
   assets/css/components/forms.css
   ============================================================ */

/* ============================================================
   FUNDAMENT FORMULARZA
   ============================================================ */

.form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.form-section-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border-light);
  margin-bottom: var(--space-2);
}

/* Wiersz z wieloma polami */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.form-row--3 {
  grid-template-columns: 1fr 1fr 1fr;
}

@media (max-width: 640px) {
  .form-row,
  .form-row--3 {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   GROUP — label + input + hint/error
   ============================================================ */

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.form-label .required {
  color: var(--color-error);
  font-size: var(--text-xs);
}

/* ============================================================
   POLA TEKSTOWE
   ============================================================ */

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  height: var(--input-height);
  padding: 0 var(--input-px);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-regular);
  color: var(--color-text);
  background: var(--color-bg-input);
  border: var(--input-border);
  border-radius: var(--input-radius);
  outline: none;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
  appearance: none;
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--color-text-light);
}

.form-input:hover,
.form-select:hover,
.form-textarea:hover {
  border-color: var(--color-text-light);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border: var(--input-border-focus);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.12);
}

/* Stan błędu */
.form-input.is-error,
.form-select.is-error,
.form-textarea.is-error {
  border-color: var(--color-error);
}

.form-input.is-error:focus,
.form-select.is-error:focus,
.form-textarea.is-error:focus {
  border-color: var(--color-error);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.12);
}

/* Stan poprawny */
.form-input.is-valid,
.form-select.is-valid {
  border-color: var(--color-success);
}

/* Wyłączone */
.form-input:disabled,
.form-select:disabled,
.form-textarea:disabled {
  background: var(--color-bg-alt);
  color: var(--color-text-muted);
  cursor: not-allowed;
  opacity: 0.7;
}

/* Textarea */
.form-textarea {
  height: auto;
  min-height: 120px;
  padding: var(--space-3) var(--input-px);
  resize: vertical;
  line-height: var(--leading-normal);
}

/* Select — arrow */
.form-select {
  padding-right: calc(var(--input-px) + 1.5rem);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--input-px) center;
  cursor: pointer;
}

/* Input z ikoną po lewej */
.form-input-wrap {
  position: relative;
}

.form-input-wrap .form-input {
  padding-left: calc(var(--input-px) + 1.5rem);
}

.form-input-wrap .form-input-icon {
  position: absolute;
  left: var(--input-px);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
}

/* Input z przyciskiem po prawej (np. search) */
.form-input-action {
  display: flex;
  gap: 0;
}

.form-input-action .form-input {
  border-radius: var(--input-radius) 0 0 var(--input-radius);
  border-right: none;
}

.form-input-action .btn {
  border-radius: 0 var(--input-radius) var(--input-radius) 0;
  flex-shrink: 0;
}

/* ============================================================
   CHECKBOX / RADIO
   ============================================================ */

.form-check {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  cursor: pointer;
}

.form-check-input {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  min-width: 18px;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-xs);
  background: var(--color-bg-input);
  cursor: pointer;
  margin-top: 1px;
  transition:
    border-color var(--transition-fast),
    background var(--transition-fast);
  position: relative;
}

.form-check-input[type="radio"] {
  border-radius: 50%;
}

.form-check-input:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.form-check-input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 4px;
  width: 6px;
  height: 9px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(40deg);
}

.form-check-input[type="radio"]:checked::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
}

.form-check-input:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

.form-check-label {
  font-size: var(--text-sm);
  color: var(--color-text);
  cursor: pointer;
  line-height: var(--leading-snug);
}

.form-check-label a {
  color: var(--color-primary);
  text-decoration: underline;
}

/* ============================================================
   TOGGLE (przełącznik)
   ============================================================ */

.form-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
}

.form-toggle-input {
  appearance: none;
  -webkit-appearance: none;
  width: 44px;
  height: 24px;
  border-radius: var(--radius-full);
  background: var(--color-border);
  border: none;
  cursor: pointer;
  position: relative;
  transition: background var(--transition-base);
  flex-shrink: 0;
}

.form-toggle-input::after {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  top: 3px;
  left: 3px;
  transition: transform var(--transition-base);
  box-shadow: var(--shadow-xs);
}

.form-toggle-input:checked {
  background: var(--color-primary);
}

.form-toggle-input:checked::after {
  transform: translateX(20px);
}

.form-toggle-label {
  font-size: var(--text-sm);
  color: var(--color-text);
  cursor: pointer;
}

/* ============================================================
   TEKSTY POMOCNICZE
   ============================================================ */

.form-hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

.form-error {
  font-size: var(--text-xs);
  color: var(--color-error);
  font-weight: var(--weight-medium);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

/* ============================================================
   SEARCH BAR (globalna wyszukiwarka)
   ============================================================ */

.search-bar {
  display: flex;
  align-items: center;
  background: #fff;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-full);
  padding: var(--space-2) var(--space-2) var(--space-2) var(--space-5);
  gap: var(--space-2);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.search-bar:focus-within {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.12);
}

.search-bar__input {
  flex: 1;
  border: none;
  outline: none;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: transparent;
  min-width: 0;
}

.search-bar__input::placeholder {
  color: var(--color-text-light);
}

.search-bar__btn {
  flex-shrink: 0;
}

/* ============================================================
   UPLOAD ZDJĘCIA
   ============================================================ */

.form-upload {
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  cursor: pointer;
  transition:
    border-color var(--transition-fast),
    background var(--transition-fast);
}

.form-upload:hover,
.form-upload.is-drag {
  border-color: var(--color-primary);
  background: var(--color-primary-bg);
}

.form-upload__icon {
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}

.form-upload__text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.form-upload__link {
  color: var(--color-primary);
  font-weight: var(--weight-medium);
}

.form-upload__hint {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  margin-top: var(--space-2);
}

.form-upload input[type="file"] {
  display: none;
}

/* === badges.css === */
/* ============================================================
   INFLUMODELS — Components: Badges & Profession Tiles
   assets/css/components/badges.css
   ============================================================ */

/* ============================================================
   BADGE — BAZOWY
   ============================================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  line-height: 1;
  white-space: nowrap;
  letter-spacing: 0.01em;
}

/* ============================================================
   BADGE — TRUST LABELS (publiczne etykiety statusu)
   Zgodne z get_trust_labels() w functions.php
   ============================================================ */

/* Zweryfikowana Persona */
.badge--verified {
  background: rgba(16, 185, 129, 0.12);
  color: var(--color-success-dark);
  border: 1px solid rgba(16, 185, 129, 0.25);
}

/* Top Persona / Top Agencja */
.badge--top {
  background: rgba(245, 158, 11, 0.12);
  color: var(--color-warning-dark);
  border: 1px solid rgba(245, 158, 11, 0.25);
}

/* Premium */
.badge--premium {
  background: var(--gradient-primary);
  color: #fff;
  border: none;
}

/* Dostępna teraz */
.badge--available {
  background: rgba(16, 185, 129, 0.10);
  color: var(--color-success-dark);
  border: 1px solid rgba(16, 185, 129, 0.20);
}

.badge--available::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-success);
  flex-shrink: 0;
  animation: badgePulse 2s ease infinite;
}

@keyframes badgePulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.45; }
}

/* Nowe (np. nowy profil) */
.badge--new {
  background: var(--color-primary-bg);
  color: var(--color-primary);
  border: 1px solid var(--color-primary-lighter);
}

/* Promowany */
.badge--featured {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.12), rgba(219, 39, 119, 0.10));
  color: var(--color-primary);
  border: 1px solid var(--color-primary-lighter);
}

/* ============================================================
   BADGE — STATUSY SYSTEMOWE
   ============================================================ */

.badge--success {
  background: var(--color-success-bg);
  color: var(--color-success-dark);
  border: 1px solid rgba(16, 185, 129, 0.2);
}

.badge--error {
  background: var(--color-error-bg);
  color: var(--color-error-dark);
  border: 1px solid rgba(239, 68, 68, 0.2);
}

.badge--warning {
  background: var(--color-warning-bg);
  color: var(--color-warning-dark);
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.badge--info {
  background: var(--color-info-bg);
  color: var(--color-info-dark);
  border: 1px solid rgba(59, 130, 246, 0.2);
}

.badge--neutral {
  background: var(--color-bg-alt);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
}

/* ============================================================
   BADGE — ROZMIARY
   ============================================================ */

.badge--sm {
  font-size: 10px;
  padding: 2px 7px;
}

.badge--lg {
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-4);
}

/* ============================================================
   KAFELEK PROFESJI
   Klasy: tile--hostessa, tile--model, tile--influencer,
          tile--promotor, tile--ambasador, tile--fotograf, tile--mua
   ============================================================ */

.profession-tile {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  border-radius: var(--radius-full);
  font-size: 11px;
  font-weight: var(--weight-semibold);
  line-height: 1;
  white-space: nowrap;
  border: 1px solid transparent;
}

/* Hostessa / Host */
.tile--hostessa {
  background: var(--profession-hostessa-bg);
  color: var(--profession-hostessa);
  border-color: var(--profession-hostessa-border);
}

/* Model */
.tile--model {
  background: var(--profession-model-bg);
  color: var(--profession-model);
  border-color: var(--profession-model-border);
}

/* Influencer */
.tile--influencer {
  background: var(--profession-influencer-bg);
  color: var(--profession-influencer);
  border-color: var(--profession-influencer-border);
}

/* Promotor */
.tile--promotor {
  background: var(--profession-promotor-bg);
  color: var(--profession-promotor);
  border-color: var(--profession-promotor-border);
}

/* Ambasador marki */
.tile--ambasador {
  background: var(--profession-ambasador-bg);
  color: var(--profession-ambasador);
  border-color: var(--profession-ambasador-border);
}

/* Fotograf */
.tile--fotograf {
  background: var(--profession-fotograf-bg);
  color: var(--profession-fotograf);
  border-color: var(--profession-fotograf-border);
}

/* MUA */
.tile--mua {
  background: var(--profession-mua-bg);
  color: var(--profession-mua);
  border-color: var(--profession-mua-border);
}

/* ============================================================
   WERYFIKACJA / ROLA KONTA (lista profilu)
   ============================================================ */

.role-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.role-badge--persona  { background: var(--color-primary-bg);   color: var(--color-primary); }
.role-badge--agency   { background: var(--color-secondary-bg); color: var(--color-secondary); }
.role-badge--company  { background: var(--color-info-bg);      color: var(--color-info-dark); }
.role-badge--admin    { background: var(--color-warning-bg);   color: var(--color-warning-dark); }

/* ============================================================
   LICZNIK (powiadomienia, wiadomości)
   ============================================================ */

.count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: var(--radius-full);
  background: var(--gradient-primary);
  color: #fff;
  font-size: 10px;
  font-weight: var(--weight-bold);
  line-height: 1;
}

.count-badge--sm {
  min-width: 14px;
  height: 14px;
  font-size: 9px;
}

/* === modals.css === */
/* ============================================================
   INFLUMODELS — Components: Modals & Drawers
   assets/css/components/modals.css
   ============================================================ */

/* ============================================================
   OVERLAY / BACKDROP
   ============================================================ */

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  animation: overlayFadeIn 200ms ease;
}

.modal-overlay[aria-hidden="true"],
.modal-overlay.is-hidden {
  display: none;
}

@keyframes overlayFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ============================================================
   MODAL — PANEL
   ============================================================ */

.modal {
  background: var(--color-bg);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  width: 100%;
  max-width: 520px;
  max-height: calc(100vh - var(--space-8));
  overflow-y: auto;
  position: relative;
  animation: modalSlideIn 250ms cubic-bezier(0.34, 1.3, 0.64, 1);
}

.modal--sm   { max-width: 380px; }
.modal--md   { max-width: 520px; }
.modal--lg   { max-width: 760px; }
.modal--xl   { max-width: 1000px; }

@keyframes modalSlideIn {
  from { opacity: 0; transform: scale(0.94) translateY(12px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* ============================================================
   MODAL — SEKCJE
   ============================================================ */

.modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-6) var(--space-5);
  border-bottom: 1px solid var(--color-border-light);
}

.modal__title {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  line-height: var(--leading-snug);
}

.modal__subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}

.modal__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: none;
  border: none;
  border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  cursor: pointer;
  flex-shrink: 0;
  transition:
    background var(--transition-fast),
    color var(--transition-fast);
}

.modal__close:hover {
  background: var(--color-bg-alt);
  color: var(--color-text);
}

.modal__body {
  padding: var(--space-6);
}

.modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--color-border-light);
  background: var(--color-bg-alt);
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

/* ============================================================
   MODAL — POPUP REJESTRACJI
   Wyzwalany przez JS przy próbie dostępu do pełnego profilu
   ============================================================ */

.modal--register {
  max-width: 440px;
  text-align: center;
}

.modal--register .modal__body {
  padding: var(--space-8) var(--space-6);
}

.modal__register-icon {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-full);
  background: var(--gradient-light);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-5);
  border: 2px solid var(--color-primary-lighter);
}

.modal__register-title {
  font-family: var(--font-heading);
  font-size: var(--h4-size);
  font-weight: var(--weight-bold);
  color: var(--color-text);
  margin-bottom: var(--space-3);
}

.modal__register-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-6);
}

.modal__register-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.modal__register-login {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-3);
}

.modal__register-login a {
  color: var(--color-primary);
  font-weight: var(--weight-medium);
  text-decoration: underline;
}

/* ============================================================
   DRAWER (panel boczny — np. filtry)
   ============================================================ */

.drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: var(--z-modal);
  animation: overlayFadeIn 200ms ease;
}

.drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(420px, 100vw);
  background: var(--color-bg);
  box-shadow: var(--shadow-2xl);
  z-index: calc(var(--z-modal) + 1);
  overflow-y: auto;
  animation: drawerSlideIn 280ms cubic-bezier(0.32, 0.72, 0, 1);
}

.drawer--left {
  left: 0;
  right: auto;
  animation: drawerSlideInLeft 280ms cubic-bezier(0.32, 0.72, 0, 1);
}

@keyframes drawerSlideIn {
  from { transform: translateX(100%); }
  to   { transform: translateX(0); }
}

@keyframes drawerSlideInLeft {
  from { transform: translateX(-100%); }
  to   { transform: translateX(0); }
}

.drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--color-border-light);
  position: sticky;
  top: 0;
  background: var(--color-bg);
  z-index: 1;
}

.drawer__title {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
}

.drawer__body {
  padding: var(--space-6);
}

.drawer__footer {
  padding: var(--space-5) var(--space-6);
  border-top: 1px solid var(--color-border-light);
  position: sticky;
  bottom: 0;
  background: var(--color-bg);
  display: flex;
  gap: var(--space-3);
}

/* === alerts.css === */
/* ============================================================
   INFLUMODELS — Components: Alerts (inline)
   assets/css/components/alerts.css

   Różnica od flash messages (footer.css):
   - Flash = powiadomienia toast (fixed, auto-dismiss)
   - Alert = inline bloki informacyjne w treści strony
   ============================================================ */

/* ============================================================
   ALERT — FUNDAMENT
   ============================================================ */

.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.alert--sm {
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-xs);
  gap: var(--space-2);
}

.alert--lg {
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-base);
}

/* ============================================================
   WARIANTY
   ============================================================ */

.alert--success {
  background: var(--color-success-bg);
  border-color: rgba(16, 185, 129, 0.25);
  color: var(--color-success-dark);
}

.alert--error {
  background: var(--color-error-bg);
  border-color: rgba(239, 68, 68, 0.25);
  color: var(--color-error-dark);
}

.alert--warning {
  background: var(--color-warning-bg);
  border-color: rgba(245, 158, 11, 0.25);
  color: var(--color-warning-dark);
}

.alert--info {
  background: var(--color-info-bg);
  border-color: rgba(59, 130, 246, 0.25);
  color: var(--color-info-dark);
}

.alert--neutral {
  background: var(--color-bg-alt);
  border-color: var(--color-border);
  color: var(--color-text-muted);
}

/* Alert z gradientem marki (np. CTA weryfikacji) */
.alert--brand {
  background: var(--gradient-light);
  border-color: var(--color-primary-lighter);
  color: var(--color-primary-dark);
}

/* ============================================================
   ELEMENTY WEWNĘTRZNE
   ============================================================ */

.alert__icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  margin-top: 1px;
}

.alert--sm .alert__icon {
  width: 16px;
  height: 16px;
}

.alert__content {
  flex: 1;
  min-width: 0;
}

.alert__title {
  font-weight: var(--weight-semibold);
  margin-bottom: var(--space-1);
  line-height: var(--leading-snug);
}

.alert__body {
  opacity: 0.85;
}

.alert__body a {
  color: inherit;
  font-weight: var(--weight-semibold);
  text-decoration: underline;
}

.alert__body ul {
  margin-top: var(--space-2);
  padding-left: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.alert__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: none;
  border: none;
  border-radius: var(--radius-xs);
  cursor: pointer;
  color: currentColor;
  opacity: 0.5;
  flex-shrink: 0;
  padding: 0;
  transition: opacity var(--transition-fast);
}

.alert__close:hover {
  opacity: 1;
}

.alert__action {
  margin-top: var(--space-3);
}

/* ============================================================
   BANNER (pełna szerokość, np. ogłoszenie systemowe)
   ============================================================ */

.banner {
  padding: var(--space-3) var(--container-px);
  text-align: center;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
}

.banner--info    { background: var(--color-info-bg);    color: var(--color-info-dark); }
.banner--warning { background: var(--color-warning-bg); color: var(--color-warning-dark); }
.banner--error   { background: var(--color-error-bg);   color: var(--color-error-dark); }
.banner--brand   { background: var(--gradient-primary); color: #fff; }

.banner a {
  color: inherit;
  font-weight: var(--weight-semibold);
  text-decoration: underline;
  margin-left: var(--space-2);
}

/* ============================================================
   EMPTY STATE (brak wyników)
   ============================================================ */

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(3rem, 8vw, 6rem) var(--space-6);
  gap: var(--space-4);
}

.empty-state__icon {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-full);
  background: var(--color-bg-alt);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-light);
  margin-bottom: var(--space-2);
}

.empty-state__title {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
}

.empty-state__desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  max-width: 400px;
}

/* ============================================================
   LOADING SKELETON
   ============================================================ */

.skeleton {
  background: linear-gradient(
    90deg,
    var(--color-bg-alt) 25%,
    var(--color-border-light) 50%,
    var(--color-bg-alt) 75%
  );
  background-size: 200% 100%;
  animation: skeletonShimmer 1.5s ease infinite;
  border-radius: var(--radius-sm);
  display: block;
}

@keyframes skeletonShimmer {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}

.skeleton-card {
  border-radius: var(--card-radius);
  aspect-ratio: var(--card-aspect-portrait);
}

.skeleton-text {
  height: 1em;
  border-radius: var(--radius-xs);
}

.skeleton-avatar {
  border-radius: var(--radius-full);
}

/* === pagination.css === */
/* ============================================================
   INFLUMODELS — Components: Pagination
   assets/css/components/pagination.css

   Struktura generowana przez pagination_html() w functions.php:
   <nav class="pagination" aria-label="Paginacja">
     <ul class="pagination__list">
       <li><a class="pagination__btn">‹</a></li>
       <li><span class="pagination__btn pagination__btn--active">1</span></li>
       <li><span class="pagination__ellipsis">…</span></li>
       <li><a class="pagination__btn">›</a></li>
     </ul>
   </nav>
   ============================================================ */

.pagination {
  display: flex;
  justify-content: center;
  margin-top: clamp(2rem, 4vw, 3rem);
}

.pagination__list {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  list-style: none;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
  justify-content: center;
}

.pagination__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  background: transparent;
  border: 1px solid transparent;
  transition:
    background var(--transition-fast),
    color var(--transition-fast),
    border-color var(--transition-fast);
  cursor: pointer;
  user-select: none;
}

a.pagination__btn:hover {
  background: var(--color-bg-alt);
  color: var(--color-primary);
  border-color: var(--color-border);
}

.pagination__btn--active {
  background: var(--gradient-primary);
  color: #fff;
  border-color: transparent;
  box-shadow: var(--shadow-purple);
  cursor: default;
}

.pagination__ellipsis {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  font-size: var(--text-sm);
  color: var(--color-text-light);
  cursor: default;
  user-select: none;
}

/* Prev / Next — szersze */
.pagination__btn[aria-label="Poprzednia"],
.pagination__btn[aria-label="Następna"] {
  font-size: var(--text-lg);
  font-weight: var(--weight-regular);
  color: var(--color-text-muted);
}

/* Kompaktowa (mniejsze przyciski) */
.pagination--sm .pagination__btn,
.pagination--sm .pagination__ellipsis {
  width: 32px;
  height: 32px;
  font-size: var(--text-xs);
}

/* ============================================================
   LOAD MORE (alternatywna paginacja)
   ============================================================ */

.load-more {
  display: flex;
  justify-content: center;
  margin-top: clamp(2rem, 4vw, 3rem);
}

.load-more__info {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-align: center;
  margin-bottom: var(--space-3);
}

.load-more__bar {
  width: 100%;
  max-width: 300px;
  height: 4px;
  background: var(--color-border);
  border-radius: var(--radius-full);
  overflow: hidden;
  margin: 0 auto var(--space-4);
}

.load-more__bar-fill {
  height: 100%;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  transition: width var(--transition-slow);
}

/* === animations.css === */
/* ============================================================
   INFLUMODELS — Animations & Motion
   assets/css/base/animations.css
   ============================================================ */

/* ============================================================
   KEYFRAMES
   ============================================================ */

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

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

@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-24px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-24px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes fadeInRight {
  from { opacity: 0; transform: translateX(24px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.92); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes scaleInBounce {
  from { opacity: 0; transform: scale(0.85); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes slideInLeft {
  from { transform: translateX(-100%); }
  to   { transform: translateX(0); }
}

@keyframes slideInRight {
  from { transform: translateX(100%); }
  to   { transform: translateX(0); }
}

@keyframes slideInUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.7; transform: scale(0.96); }
}

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

@keyframes pingOnce {
  0%   { transform: scale(1); opacity: 1; }
  75%  { transform: scale(1.8); opacity: 0; }
  100% { transform: scale(1.8); opacity: 0; }
}

/* Gradient animowany (hero, banery) */
@keyframes gradientShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Bounce (loading dots) */
@keyframes bounceDot {
  0%, 80%, 100% { transform: scale(0.8); opacity: 0.5; }
  40%           { transform: scale(1.1); opacity: 1; }
}

/* Shimmer (skeleton) — zdefiniowany w alerts.css, tu alias */
@keyframes shimmer {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}

/* Glow pulsujący (wyróżnione elementy) */
@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(124, 58, 237, 0); }
  50%       { box-shadow: 0 0 0 8px rgba(124, 58, 237, 0.15); }
}

/* Float (elementy dekoracyjne) */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-10px); }
}

/* ============================================================
   KLASY UŻYTKOWE — jednorazowe animacje CSS
   ============================================================ */

.animate-fade-in    { animation: fadeIn    var(--transition-slow) ease both; }
.animate-fade-up    { animation: fadeInUp  var(--transition-slow) ease both; }
.animate-fade-down  { animation: fadeInDown var(--transition-slow) ease both; }
.animate-scale-in   { animation: scaleIn   var(--transition-base) cubic-bezier(0.34, 1.3, 0.64, 1) both; }

/* Stagger delays (data-delay lub klasa) */
.delay-100  { animation-delay: 100ms; }
.delay-200  { animation-delay: 200ms; }
.delay-300  { animation-delay: 300ms; }
.delay-400  { animation-delay: 400ms; }
.delay-500  { animation-delay: 500ms; }
.delay-600  { animation-delay: 600ms; }
.delay-700  { animation-delay: 700ms; }
.delay-800  { animation-delay: 800ms; }

/* ============================================================
   HOVER UTILITIES
   ============================================================ */

/* Uniesienie w górę */
.hover-lift {
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.hover-lift:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

/* Powiększenie */
.hover-scale {
  transition: transform var(--transition-base);
}
.hover-scale:hover {
  transform: scale(1.03);
}

/* Fioletowy blask */
.hover-glow {
  transition: box-shadow var(--transition-base);
}
.hover-glow:hover {
  box-shadow: var(--shadow-brand);
}

/* Zmiana opacity */
.hover-dim {
  transition: opacity var(--transition-fast);
}
.hover-dim:hover {
  opacity: 0.75;
}

/* ============================================================
   AOS — Animate On Scroll (nadpisanie domyślnych wartości)
   Vendor AOS inicjalizowany w footer.php:
   AOS.init({ duration: 600, once: true, offset: 60 })
   ============================================================ */

[data-aos] {
  pointer-events: none;
}

[data-aos].aos-animate {
  pointer-events: auto;
}

/* Wolniejsze animacje dla bloków sekcji */
[data-aos][data-aos-duration="800"] {
  transition-duration: 800ms;
}

/* ============================================================
   GRADIENT ANIMOWANY (hero, banery premium)
   ============================================================ */

.gradient-animated {
  background: linear-gradient(
    270deg,
    #7C3AED, #9333EA, #DB2777, #9333EA, #7C3AED
  );
  background-size: 300% 300%;
  animation: gradientShift 8s ease infinite;
}

/* Tekst z animowanym gradientem */
.text-gradient-animated {
  background: linear-gradient(
    270deg,
    #7C3AED, #DB2777, #7C3AED
  );
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradientShift 4s ease infinite;
}

/* ============================================================
   LOADING STATES
   ============================================================ */

/* Spinner inline */
.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: spin 0.65s linear infinite;
  flex-shrink: 0;
}

.spinner--sm {
  width: 14px;
  height: 14px;
}

.spinner--lg {
  width: 32px;
  height: 32px;
  border-width: 3px;
}

.spinner--white {
  border-color: rgba(255,255,255,0.3);
  border-top-color: #fff;
}

/* Dots loader */
.dots-loader {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.dots-loader span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary);
  animation: bounceDot 1.2s ease infinite;
}

.dots-loader span:nth-child(2) { animation-delay: 0.15s; }
.dots-loader span:nth-child(3) { animation-delay: 0.30s; }

/* Pełnoekranowy loader (np. pierwsza wizyta) */
.page-loader {
  position: fixed;
  inset: 0;
  background: var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-top);
  transition: opacity var(--transition-slow);
}

.page-loader.is-done {
  opacity: 0;
  pointer-events: none;
}

/* ============================================================
   EFEKTY SPECJALNE
   ============================================================ */

/* Pulsujący pierścień (glow ring) — np. zweryfikowana persona */
.glow-ring {
  animation: glowPulse 2.5s ease infinite;
}

/* Floating element — dekoracje hero */
.float {
  animation: float 4s ease-in-out infinite;
}

.float--slow  { animation-duration: 6s; }
.float--fast  { animation-duration: 2.5s; }
.float--delay { animation-delay: 1.2s; }

/* Ping (nowe powiadomienie) */
.ping {
  position: relative;
}

.ping::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: var(--color-primary);
  opacity: 0;
  animation: pingOnce 1.5s ease 0.5s;
}

/* ============================================================
   TRANSITIONS — globalne klasy pomocnicze
   ============================================================ */

.transition-all    { transition: all var(--transition-base); }
.transition-colors { transition: color var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast); }
.transition-shadow { transition: box-shadow var(--transition-base); }
.transition-transform { transition: transform var(--transition-base); }
.transition-opacity { transition: opacity var(--transition-base); }

/* ============================================================
   REDUCED MOTION — dostępność
   Wyłącza wszystkie animacje gdy użytkownik preferuje
   ============================================================ */

@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;
  }

  [data-aos] {
    opacity: 1 !important;
    transform: none !important;
  }

  .float,
  .glow-ring,
  .gradient-animated,
  .text-gradient-animated,
  .spinner,
  .dots-loader span {
    animation: none !important;
  }
}

/* === responsive.css === */
/* ============================================================
   INFLUMODELS — Responsive Utilities
   assets/css/base/responsive.css
   Ładowany jako OSTATNI plik CSS (nadpisuje wcześniejsze style)

   Breakpoints (z variables.css):
   --bp-sm:  480px
   --bp-md:  768px
   --bp-lg:  1024px
   --bp-xl:  1280px
   ============================================================ */

/* ============================================================
   SHOW / HIDE NA BREAKPOINTACH
   ============================================================ */

/* Domyślnie widoczne, ukryte poniżej breakpointu */
.hide-sm   { display: block; }
.hide-md   { display: block; }
.hide-lg   { display: block; }

/* Domyślnie ukryte, widoczne powyżej breakpointu */
.show-sm   { display: none; }
.show-md   { display: none; }
.show-lg   { display: none; }

/* Mobile only (ukryte na desktop) */
.mobile-only  { display: none; }
.desktop-only { display: block; }

@media (max-width: 480px) {
  .hide-sm { display: none !important; }
  .show-sm { display: block !important; }
}

@media (max-width: 768px) {
  .hide-md      { display: none !important; }
  .show-md      { display: block !important; }
  .mobile-only  { display: block; }
  .desktop-only { display: none; }
}

@media (max-width: 1024px) {
  .hide-lg { display: none !important; }
  .show-lg { display: block !important; }
}

/* Flex-specificzne wersje */
.hide-md-flex { display: flex; }
.show-md-flex { display: none; }

@media (max-width: 768px) {
  .hide-md-flex { display: none !important; }
  .show-md-flex { display: flex !important; }
}

/* ============================================================
   RESPONSYWNA TYPOGRAFIA — korekty przy mniejszych ekranach
   ============================================================ */

@media (max-width: 768px) {
  /* Bardziej kompaktowe nagłówki sekcji */
  .section-header {
    margin-bottom: var(--space-8);
  }

  .section-lead {
    font-size: var(--text-base);
  }

  /* Przyciski — nie stacked na mobile jeśli side-by-side */
  .btn-group {
    gap: var(--space-2);
  }

  .btn-group .btn--lg {
    height: var(--input-height);
    font-size: var(--text-sm);
    padding-inline: var(--space-5);
  }
}

@media (max-width: 480px) {
  /* Pionowe grupy przycisków na małych ekranach */
  .btn-group--stack-sm {
    flex-direction: column;
    width: 100%;
  }

  .btn-group--stack-sm .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ============================================================
   RESPONSYWNE GRIDY — dodatkowe nadpisania
   ============================================================ */

@media (max-width: 768px) {
  /* Statystyki: 2 kolumny zamiast 4 */
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Profil: sidebar idzie na dół */
  .profile-layout {
    grid-template-columns: 1fr;
  }

  /* Agencje: 1 kolumna */
  .grid-agencies {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  /* Profile na bardzo małych ekranach: 2 wąskie kolumny */
  .grid-profiles {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
  }

  /* Jedna kolumna statystyk na phoneach */
  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ============================================================
   RESPONSYWNE SEKCJE — odstępy
   ============================================================ */

@media (max-width: 768px) {
  .section {
    padding-block: var(--space-12);
  }

  .section--lg {
    padding-block: var(--space-16);
  }
}

@media (max-width: 480px) {
  .section {
    padding-block: var(--space-10);
  }

  .section--lg {
    padding-block: var(--space-12);
  }
}

/* ============================================================
   KARTY PROFILÓW — mobile
   ============================================================ */

@media (max-width: 480px) {
  /* Nieco mniejszy padding */
  .profile-card__body {
    padding: var(--space-3);
  }

  .profile-card__name {
    font-size: var(--text-sm);
  }

  /* Ukryj akcje na małych kartach — dostępne po kliknięciu */
  .profile-card__actions {
    display: none;
  }

  /* Agencje pełna szerokość */
  .agency-card {
    padding: var(--space-4);
  }
}

/* ============================================================
   FORMULARZ — mobile
   ============================================================ */

@media (max-width: 480px) {
  .form-input,
  .form-select,
  .form-textarea {
    font-size: 16px; /* zapobiega zoom na iOS */
  }

  .search-bar {
    padding: var(--space-2) var(--space-2) var(--space-2) var(--space-4);
  }
}

/* ============================================================
   TABELE — horizontal scroll na mobile
   ============================================================ */

.table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

th {
  background: var(--color-bg-alt);
  font-weight: var(--weight-semibold);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  white-space: nowrap;
}

td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-text);
  vertical-align: middle;
}

tr:last-child td {
  border-bottom: none;
}

tr:hover td {
  background: var(--color-bg-alt);
}

/* ============================================================
   TOUCH — specyficzne zachowania
   ============================================================ */

@media (hover: none) and (pointer: coarse) {
  /* Na urządzeniach dotykowych: wyłącz hover-lift bo wygląda dziwnie */
  .hover-lift:hover,
  .profile-card:hover,
  .agency-card:hover {
    transform: none;
  }

  /* Większe obszary klikania na linkach nav */
  .navbar__link {
    padding: var(--space-3) var(--space-3);
  }

  /* Kursor normalny (brak myszki) */
  * {
    cursor: auto;
  }

  .btn,
  a,
  button,
  [role="button"],
  label {
    cursor: pointer;
  }
}

/* ============================================================
   DRUKOWANIE
   ============================================================ */

@media print {
  .navbar,
  .footer,
  .flash-container,
  .modal-overlay,
  .btn,
  .pagination {
    display: none !important;
  }

  body {
    padding-top: 0;
    font-size: 12pt;
    color: #000;
    background: #fff;
  }

  a {
    color: inherit;
    text-decoration: none;
  }

  a[href]::after {
    content: " (" attr(href) ")";
    font-size: 9pt;
    color: #666;
  }

  .container {
    max-width: 100%;
    padding: 0;
  }

  h1, h2, h3 {
    page-break-after: avoid;
  }

  img {
    max-width: 100%;
    page-break-inside: avoid;
  }
}

/* ============================================================
   FOCUS — globalne style dostępności
   ============================================================ */

/* Wyczyść domyślny outline wszędzie */
:focus {
  outline: none;
}

/* Pokaż czytelny focus tylko przy nawigacji klawiaturą */
:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: var(--radius-xs);
}

/* Wyjątek — inputy obsługują focus przez border+shadow w forms.css */
.form-input:focus-visible,
.form-select:focus-visible,
.form-textarea:focus-visible {
  outline: none;
}

/* Skip-to-content (dostępność klawiaturowa) */
.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-4);
  padding: var(--space-3) var(--space-5);
  background: var(--color-primary);
  color: #fff;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-decoration: none;
  z-index: var(--z-top);
  transition: top var(--transition-fast);
}

.skip-link:focus {
  top: 0;
}

/* ============================================================
   SCROLL SMOOTH
   ============================================================ */

html {
  scroll-behavior: smooth;
}

/* Scroll z uwzględnieniem fixed navbara */
:target {
  scroll-margin-top: calc(var(--nav-height) + var(--space-6));
}

/* ============================================================
   SELECTION
   ============================================================ */

::selection {
  background: rgba(124, 58, 237, 0.18);
  color: var(--color-primary-dark);
}

/* ============================================================
   WIDTHS — pomocnicze klasy szerokości
   ============================================================ */

.w-full   { width: 100%; }
.w-auto   { width: auto; }
.max-w-sm { max-width: var(--container-xs); }
.max-w-md { max-width: var(--container-narrow); }
.max-w-lg { max-width: var(--container-max); }
.min-w-0  { min-width: 0; }

/* ============================================================
   TEXT UTILITIES (responsywne)
   ============================================================ */

.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

.truncate {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.break-words {
  overflow-wrap: break-word;
  word-break: break-word;
}

.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

@media (max-width: 768px) {
  .text-center-md { text-align: center; }
}

/* ============================================================
   ASPECT RATIOS — utility
   ============================================================ */

.aspect-square    { aspect-ratio: 1 / 1; }
.aspect-video     { aspect-ratio: 16 / 9; }
.aspect-portrait  { aspect-ratio: 3 / 4; }
.aspect-landscape { aspect-ratio: 4 / 3; }

/* ============================================================
   OVERFLOW
   ============================================================ */

.overflow-hidden { overflow: hidden; }
.overflow-auto   { overflow: auto; }
.overflow-x-auto { overflow-x: auto; -webkit-overflow-scrolling: touch; }
