/* ================================================================
   CRAVE AGENCJA MUZYCZNA — GŁÓWNY ARKUSZ STYLÓW v1.0
   ================================================================
   ABY ZMIENIĆ KOLORY: edytuj wartości w sekcji ":root" poniżej
   ABY ZMIENIĆ FONT:   zmień nazwę w wp_enqueue_style (functions.php) i "--font-display"
   ================================================================ */

/* Google Fonts loaded via wp_enqueue_style in functions.php — no @import needed */

/* font-display: swap ensures text is visible while fonts load.
   To self-host: download WOFF2 files to assets/fonts/, uncomment @font-face below,
   and remove wp_enqueue_style('crave-fonts') from functions.php.

@font-face { font-family:'Lexend'; font-style:normal; font-weight:200; font-display:swap; src:url('../fonts/lexend-200.woff2') format('woff2'); }
@font-face { font-family:'Lexend'; font-style:normal; font-weight:300; font-display:swap; src:url('../fonts/lexend-300.woff2') format('woff2'); }
@font-face { font-family:'Lexend'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/lexend-400.woff2') format('woff2'); }
@font-face { font-family:'Commissioner'; font-style:normal; font-weight:300; font-display:swap; src:url('../fonts/commissioner-300.woff2') format('woff2'); }
@font-face { font-family:'Commissioner'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/commissioner-400.woff2') format('woff2'); }
*/

/* Active fallback — forces swap even if Google Fonts URL doesn't include display=swap */
@font-face { font-family: 'Lexend'; font-display: swap; src: local('Lexend'); }
@font-face { font-family: 'Commissioner'; font-display: swap; src: local('Commissioner'); }

:root {
  --pink:    #FA008F;
  --blue:    #1058E8;
  --purple:  #9618FF;
  --yellow:  #FFC700;
  --green:   #00C878;
  --grad-1:  linear-gradient(103deg,#FFC700,#9618FF);
  --grad-2:  linear-gradient(103deg,#F9008E,#9618FF);
  --grad-3:  linear-gradient(103deg,#F9008E,#FFC700);
  --bg:      #090C09;
  --bg2:     #0d100d;
  --bg3:     #111411;
  --surface: rgba(255,255,255,0.03);
  --surface2:rgba(255,255,255,0.06);
  --border:  rgba(255,255,255,0.08);
  --border-pink: rgba(250,0,143,0.2);
  --text:         #FFFFFF;
  --text-muted:   #A0A0A0;
  --text-faint:   #959595;
  --nav-height:   70px;
  --radius:       12px;
  --radius-sm:    8px;
  --radius-pill:  50px;
  --shadow-pink:  0 8px 30px rgba(250,0,143,0.25);
  --shadow-dark:  0 20px 60px rgba(0,0,0,0.4);
  --font-display: 'Lexend', sans-serif;
  --font-body:    'Commissioner', sans-serif;
  --transition:   all 0.25s ease;
}


/* ══ JĘZYK PL / EN — bez wtyczki ══
   Domyślnie: html nie ma data-lang → pokazuj PL (fallback)
   Po kliknięciu JS ustawia html[data-lang="pl"] lub html[data-lang="en"]
════════════════════════════════════ */
[data-pl], [data-en], [data-pl-b], [data-en-b] { display: none !important; visibility: hidden; }

/* PL — domyślny (brak atrybutu lub pl) */
:root:not([data-lang]) [data-pl],
html[data-lang="pl"] [data-pl]   { display: inline !important; visibility: visible; }
:root:not([data-lang]) a.btn[data-pl],
html[data-lang="pl"] a.btn[data-pl] { display: inline-flex !important; }
:root:not([data-lang]) [data-pl-b],
html[data-lang="pl"] [data-pl-b] { display: block !important; visibility: visible; }

/* EN */
html[data-lang="en"] [data-en]   { display: inline !important; visibility: visible; }
html[data-lang="en"] a.btn[data-en] { display: inline-flex !important; }
html[data-lang="en"] [data-en-b] { display: block !important; visibility: visible; }

/* RESET */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:18px; scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body { background:var(--bg); color:var(--text); font-family:var(--font-body); font-weight:300; line-height:1.7; overflow-x:hidden; }
img  { max-width:100%; height:auto; display:block; }
a    { color:inherit; text-decoration:none; transition:color 0.2s; }
a:hover { color:var(--pink); }
button { cursor:pointer; font-family:var(--font-body); }
:focus-visible { outline:3px solid var(--pink); outline-offset:3px; border-radius:3px; }
ul, ol { padding-left:1.5rem; }

/* TYPOGRAFIA */
h1,h2,h3,h4,h5,h6 { font-family:var(--font-display); font-weight:300; line-height:1.15; color:var(--text); }
h1 { font-size:clamp(2.2rem,5vw,4rem); font-weight:200; }
h2 { font-size:clamp(1.8rem,3.5vw,2.8rem); font-weight:200; }
h3 { font-size:clamp(1.3rem,2.5vw,1.8rem); }
h4 { font-size:1.2rem; }
h5 { font-size:1rem; }
h6 { font-size:0.85rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-muted); }
p  { margin-bottom:1rem; color:var(--text-muted); font-size:0.95rem; line-height:1.85; }
p:last-child { margin-bottom:0; }

/* KLASY POMOCNICZE TEKSTU */
.text-gradient { background:var(--grad-2); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.text-pink   { color:var(--pink); }
.text-yellow { color:var(--yellow); }
.text-purple { color:var(--purple); }
.text-blue   { color:var(--blue); }
.text-muted  { color:var(--text-muted); }
.text-center { text-align:center; }
.text-upper  { text-transform:uppercase; letter-spacing:0.15em; }

/* LAYOUT */
.container   { width:100%; max-width:1280px; margin:0 auto; padding:0 60px; }

/* === ULTRAWIDE CAP (>1440px) === */
body > *:not(#site-header):not(script):not(style) { max-width:1440px; margin-left:auto; margin-right:auto; }
#site-header .nav-inner, #site-header { max-width:100%; }
@media (min-width:1441px) {
  .container { max-width:1320px; }
  #site-header { padding:0 calc((100vw - 1380px)/2); }
}
.section     { padding:80px 0; }
.section-sm  { padding:48px 0; }
.section-lg  { padding:120px 0; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:40px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }

/* NAGŁÓWEK SEKCJI */
.section-tag { display:inline-flex; align-items:center; gap:10px; font-size:0.72rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--pink); margin-bottom:16px; }
.section-tag::before { content:''; display:block; width:24px; height:1px; background:var(--pink); }
.section-title { font-family:var(--font-display); font-weight:200; margin-bottom:16px; }
.section-desc  { font-size:0.95rem; color:var(--text-muted); max-width:600px; line-height:1.8; }

/* PRZYCISKI */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 32px; border-radius:var(--radius-pill); font-family:var(--font-display); font-size:0.82rem; font-weight:400; letter-spacing:0.1em; text-transform:uppercase; border:none; transition:var(--transition); white-space:nowrap; cursor:pointer; }
.btn-primary  { background:var(--pink); color:#fff; }
.btn-primary:hover { background:#BE0070; box-shadow:var(--shadow-pink); transform:translateY(-2px); color:#fff; }
.btn-secondary { background:transparent; color:var(--text); border:1px solid var(--border); }
.btn-secondary:hover { border-color:var(--pink); color:var(--pink); }
.btn-gradient  { background:var(--grad-2); color:#fff; }
.btn-gradient:hover { opacity:0.9; transform:translateY(-2px); box-shadow:var(--shadow-pink); color:#fff; }
.btn-sm    { padding:10px 22px; font-size:0.75rem; min-height:44px; }
.btn-lg    { padding:18px 44px; font-size:0.9rem; }
.btn-block { width:100%; }

/* KARTY */
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:var(--transition); }
.card:hover { border-color:var(--border-pink); transform:translateY(-4px); box-shadow:var(--shadow-dark); }
.card-body   { padding:28px; }
.card-footer { padding:16px 28px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }

/* BADGE */
.badge { display:inline-flex; align-items:center; gap:6px; padding:4px 12px; border-radius:var(--radius-pill); font-family:var(--font-display); font-size:0.65rem; font-weight:400; letter-spacing:0.12em; text-transform:uppercase; }
.badge-pink   { background:rgba(250,0,143,0.15); color:var(--pink); border:1px solid rgba(250,0,143,0.25); }
.badge-blue   { background:rgba(16,88,232,0.15); color:#6B9EFF; border:1px solid rgba(16,88,232,0.25); }
.badge-yellow { background:rgba(255,200,0,0.15); color:var(--yellow); border:1px solid rgba(255,200,0,0.25); }
.badge-purple { background:rgba(150,24,255,0.15); color:#C97FFF; border:1px solid rgba(150,24,255,0.25); }
.badge-green  { background:rgba(0,200,120,0.15); color:var(--green); border:1px solid rgba(0,200,120,0.25); }
.badge-ghost  { background:rgba(255,255,255,0.06); color:var(--text-muted); border:1px solid var(--border); }

/* NAWIGACJA */
#site-header { position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--nav-height); display:flex; align-items:center; padding:0 60px; justify-content:space-between; background:rgba(9,12,9,0.92); backdrop-filter:blur(18px); border-bottom:1px solid var(--border-pink); transition:background 0.3s; }
#site-header.scrolled { background:rgba(9,12,9,0.98); }
.site-logo { display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--text); }
.logo-sygnet { display:flex; align-items:center; gap:2px; }
.logo-bar { width:3px; border-radius:3px; background:var(--pink); }
.logo-bar:nth-child(1) { height:14px; }
.logo-bar:nth-child(2) { height:22px; }
.logo-bar:nth-child(3) { height:14px; }
.logo-c { font-family:var(--font-display); font-size:1.5rem; font-weight:300; color:var(--pink); margin-left:3px; line-height:1; }
.logo-text .brand   { display:block; font-family:var(--font-display); font-size:0.95rem; font-weight:300; letter-spacing:0.22em; }
.logo-text .tagline { display:block; font-size:0.52rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--text-muted); }
#primary-nav { display:flex; align-items:center; gap:4px; list-style:none; }
#primary-nav li a { display:block; padding:8px 14px; font-size:0.8rem; letter-spacing:0.06em; color:var(--text-muted); border-radius:8px; transition:var(--transition); }
#primary-nav li a:hover, #primary-nav li.current-menu-item a { color:var(--text); background:var(--surface2); }
#primary-nav li.menu-item-has-children { position:relative; }
#primary-nav li.menu-item-has-children > a::after { content:'▾'; margin-left:4px; font-size:0.7rem; }
.sub-menu { position:absolute; top:calc(100% + 8px); left:0; min-width:200px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius-sm); list-style:none; padding:8px; opacity:0; pointer-events:none; transform:translateY(-8px); transition:all 0.2s; z-index:100; }
#primary-nav li:hover .sub-menu { opacity:1; pointer-events:all; transform:translateY(0); }
.sub-menu li a { display:block; padding:8px 12px; font-size:0.82rem; color:var(--text-muted); border-radius:6px; }
.sub-menu li a:hover { color:var(--pink); background:rgba(250,0,143,0.06); }
.nav-actions { display:flex; align-items:center; gap:12px; }
.nav-cart-btn { display:flex; align-items:center; gap:8px; padding:8px 18px; border-radius:var(--radius-pill); border:1px solid var(--border); background:transparent; color:var(--text-muted); font-size:0.78rem; letter-spacing:0.06em; transition:var(--transition); text-decoration:none; }
.nav-cart-btn:hover { border-color:var(--pink); color:var(--pink); }
.cart-count { background:var(--pink); color:#fff; width:18px; height:18px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.62rem; font-weight:400; }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:8px; cursor:pointer; }
.hamburger span { display:block; width:24px; height:2px; background:var(--text); border-radius:2px; transition:var(--transition); }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
#mobile-nav { display:none; position:fixed; top:var(--nav-height); left:0; right:0; background:rgba(9,12,9,0.98); backdrop-filter:blur(20px); border-bottom:1px solid var(--border); padding:20px; z-index:999; list-style:none; flex-direction:column; gap:4px; }
#mobile-nav.open { display:flex; }
#mobile-nav li a { display:block; padding:12px 16px; font-size:1rem; color:var(--text-muted); border-radius:var(--radius-sm); border-bottom:1px solid var(--border); }
#mobile-nav li:last-child a { border-bottom:none; }
#mobile-nav li a:hover { color:var(--pink); background:var(--surface); }

/* HERO */
.hero { min-height:100vh; display:flex; align-items:center; padding:calc(var(--nav-height) + 60px) 60px 80px; position:relative; overflow:hidden; }
.hero-blob { position:absolute; border-radius:50%; pointer-events:none; will-change:auto; }
.hero-blob-1 { width:800px; height:800px; top:-200px; right:-200px; background:radial-gradient(circle,rgba(250,0,143,0.14) 0%,rgba(250,0,143,0.05) 40%,transparent 70%); }
.hero-blob-2 { width:700px; height:700px; bottom:-150px; left:25%; background:radial-gradient(circle,rgba(150,24,255,0.09) 0%,rgba(150,24,255,0.03) 40%,transparent 70%); }
.dashed-lines { position:absolute; inset:0; pointer-events:none; z-index:0; contain:strict; }
.dashed-line  { position:absolute; top:0; bottom:0; width:1px; background-image:repeating-linear-gradient(to bottom,currentColor 0,currentColor 6px,transparent 6px,transparent 14px); will-change:transform; }
.dashed-line:nth-child(1) { left:20%; color:var(--pink); opacity:0.1; }
.dashed-line:nth-child(2) { left:40%; color:var(--yellow); opacity:0.06; }
.dashed-line:nth-child(3) { left:60%; color:var(--purple); opacity:0.06; }
.dashed-line:nth-child(4) { left:80%; color:var(--blue); opacity:0.07; }
.hero-content   { position:relative; z-index:1; max-width:760px; }
.hero-title     { font-family:var(--font-display); font-weight:200; font-size:clamp(2.8rem,6vw,5rem); line-height:1.05; margin-bottom:24px; }
.hero-desc      { font-size:1rem; color:var(--text-muted); max-width:560px; margin-bottom:40px; line-height:1.8; } /* spec: 540px→560px */
.hero-cta       { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:60px; }
.hero-stats     { display:flex; gap:40px; flex-wrap:wrap; padding-top:40px; border-top:1px solid var(--border); }
.hero-stat-val  { font-family:var(--font-display); font-weight:300; font-size:2rem; display:block; }
.hero-stat-label { font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--text-faint); ;font-weight:400}
.hero-waves { position:absolute; bottom:0; left:0; right:0; z-index:0; opacity:0.05; pointer-events:none; }

/* TICKER */
.artists-ticker { padding:32px 0; background:var(--bg2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); overflow:hidden; contain:layout style; }
.ticker-track   { display:flex; gap:48px; animation:ticker 20s linear infinite; white-space:nowrap; will-change:transform; contain:layout; }
.ticker-track:hover { animation-play-state:paused; }
@keyframes ticker { from { transform:translateX(0); } to { transform:translateX(-50%); } }
.ticker-item { font-family:var(--font-display); font-weight:200; font-size:1.1rem; letter-spacing:0.08em; color:var(--text-faint); display:flex; align-items:center; gap:16px; flex-shrink:0; }
.ticker-sep  { color:var(--pink); font-size:0.5rem; }

/* USŁUGI */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.service-card  { padding:32px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); transition:var(--transition); position:relative; overflow:hidden; }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad-2); opacity:0; transition:opacity 0.3s; }
.service-card:hover { border-color:var(--border-pink); transform:translateY(-4px); }
.service-card:hover::before { opacity:1; }
.service-icon  { font-size:2rem; margin-bottom:20px; display:block; }
.service-title { font-family:var(--font-display); font-weight:300; font-size:1.05rem; margin-bottom:12px; color:var(--text); }
.service-desc  { font-size:0.85rem; color:var(--text-muted); line-height:1.75; }
.service-link  { display:inline-flex; align-items:center; gap:6px; margin-top:20px; font-size:0.78rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--pink); transition:gap 0.2s; }
.service-link:hover { gap:10px; color:var(--pink); }

/* ARTYŚCI */
.artist-card { position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:3/4; background:var(--bg3); }
.artist-card img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s ease; }
.artist-card:hover img { transform:scale(1.05); }
.artist-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(9,12,9,0.9) 0%,transparent 50%); }
.artist-info    { position:absolute; bottom:24px; left:24px; right:24px; }
.artist-name    { font-family:var(--font-display); font-weight:300; font-size:1.1rem; margin-bottom:6px; }
.artist-genre   { font-size:0.72rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-muted); }
.artist-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:4rem; background:linear-gradient(135deg,var(--bg2),var(--bg3)); }

/* KONCERTY */
.concert-item   { display:flex; align-items:center; gap:24px; padding:20px 24px; border-bottom:1px solid var(--border); transition:var(--transition); border-radius:var(--radius-sm); }
.concert-item:hover { background:var(--surface); border-color:var(--border-pink); }
.concert-date   { min-width:60px; text-align:center; flex-shrink:0; }
.concert-date .day   { font-family:var(--font-display); font-weight:300; font-size:1.6rem; line-height:1; color:var(--pink); }
.concert-date .month { font-size:0.68rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-faint); }
.concert-info   { flex:1; }
.concert-artist { font-family:var(--font-display); font-weight:300; font-size:1rem; margin-bottom:4px; }
.concert-venue  { font-size:0.82rem; color:var(--text-muted); }
.concert-city   { font-size:0.78rem; color:var(--text-faint); min-width:100px; }

/* FORMULARZE */
.form-field    { margin-bottom:16px; }
.form-label    { display:block; font-size:0.68rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--text-faint); margin-bottom:8px; }
.form-input, .form-textarea, .form-select { width:100%; padding:12px 16px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.35); border-radius:var(--radius-sm); color:var(--text); font-family:var(--font-body); font-size:0.9rem; transition:border-color 0.2s; }
.form-input:focus, .form-textarea:focus, .form-select:focus { outline:none; border-color:var(--pink); box-shadow:0 0 0 3px rgba(250,0,143,0.1); }
.form-input::placeholder, .form-textarea::placeholder { color:var(--text-faint); }
.form-textarea { min-height:120px; resize:vertical; }
.form-error    { border-color:rgba(250,0,143,0.5) !important; }
.checkbox-wrap { display:flex; align-items:flex-start; gap:12px; cursor:pointer; margin-bottom:12px; }
.checkbox-wrap input[type="checkbox"] { position:absolute; opacity:0; width:0; height:0; }
.checkbox-box  { width:24px; height:24px; flex-shrink:0; margin-top:1px; border:1.5px solid rgba(255,255,255,0.35); border-radius:4px; background:rgba(255,255,255,0.06); transition:all 0.2s; display:flex; align-items:center; justify-content:center; }
.checkbox-wrap input:checked ~ .checkbox-box { background:var(--pink); border-color:var(--pink); }
.checkbox-wrap input:checked ~ .checkbox-box::after { content:''; display:block; width:5px; height:9px; border:2px solid #fff; border-top:none; border-left:none; transform:rotate(45deg) translateY(-1px); }
.checkbox-wrap input:focus-visible ~ .checkbox-box { outline:3px solid var(--pink); outline-offset:2px; }
.checkbox-wrap input:focus ~ .checkbox-box { outline:2px solid var(--pink); outline-offset:2px; }
.checkbox-wrap input:focus:not(:focus-visible) ~ .checkbox-box { outline:none; }
.checkbox-label { font-size:0.8rem; color:var(--text-muted); line-height:1.65; }

/* PROJEKTY */
.project-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.project-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:var(--transition); cursor:pointer; display:flex; flex-direction:column; }
.project-card:hover { border-color:var(--border-pink); transform:translateY(-6px); box-shadow:var(--shadow-dark); }
.project-card-top  { height:180px; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; }
.project-card-icon { font-size:3.5rem; position:relative; z-index:1; }
.project-card-body { padding:24px; flex:1; }
.project-card-cat  { font-size:0.68rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--text-faint); margin-bottom:8px; }
.project-card-title { font-family:var(--font-display); font-weight:300; font-size:1rem; color:var(--text); margin-bottom:10px; line-height:1.3; }
.project-card-desc  { font-size:0.82rem; color:var(--text-muted); line-height:1.7; }
.project-card-footer { padding:14px 24px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }

/* NEWSLETTER */
.newsletter-section { padding:80px 60px; background:var(--bg2); border-top:1px solid var(--border); position:relative; overflow:hidden; }
.newsletter-wrap    { max-width:600px; margin:0 auto; text-align:center; position:relative; z-index:1; }
.newsletter-form    { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.newsletter-form .form-input { flex:1; min-width:220px; }

/* GALERIA */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.gallery-item { aspect-ratio:1; border-radius:var(--radius-sm); overflow:hidden; background:var(--bg3); cursor:pointer; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.3s; }
.gallery-item:hover img { transform:scale(1.05); }
.gallery-item:nth-child(4n+1) { grid-column:span 2; aspect-ratio:2/1; }

/* FOOTER */
#site-footer    { background:var(--bg2); border-top:1px solid var(--border); padding:60px 0 32px; }
.footer-grid    { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; }
.footer-tagline { font-size:0.85rem; color:var(--text-muted); line-height:1.7; max-width:260px; margin-bottom:20px; }
.footer-socials { display:flex; gap:10px; }
.social-btn     { width:36px; height:36px; border-radius:50%; background:var(--surface2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:0.85rem; color:var(--text-muted); transition:var(--transition); text-decoration:none; }
.social-btn:hover { border-color:var(--pink); color:var(--pink); background:rgba(250,0,143,0.08); }
.footer-col-title { font-family:var(--font-display); font-size:0.75rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--text-faint); margin-bottom:16px; }
.footer-menu { list-style:none; padding:0; display:flex; flex-direction:column; gap:8px; }
.footer-menu li a { font-size:0.85rem; color:var(--text-muted); transition:color 0.2s; }
.footer-menu li a:hover { color:var(--pink); }
.footer-bottom { padding-top:24px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy   { font-size:0.78rem; color:var(--text-faint); }
.footer-legal  { display:flex; gap:20px; }
.footer-legal a { font-size:0.78rem; color:var(--text-faint); transition:color 0.2s; }
.footer-legal a:hover { color:var(--pink); }

/* WOOCOMMERCE */
.woocommerce .products { display:grid !important; grid-template-columns:repeat(3,1fr) !important; gap:24px !important; margin:0 !important; }
.woocommerce ul.products li.product { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:var(--transition); float:none !important; width:auto !important; margin:0 !important; padding:0 !important; }
.woocommerce ul.products li.product:hover { border-color:var(--border-pink); transform:translateY(-4px); box-shadow:var(--shadow-dark); }
.woocommerce ul.products li.product a img { width:100%; height:200px; object-fit:cover; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family:var(--font-display) !important; font-weight:300 !important; font-size:0.95rem !important; color:var(--text) !important; padding:16px 20px 8px !important; }
.woocommerce ul.products li.product .price { padding:0 20px !important; color:var(--pink) !important; font-family:var(--font-display) !important; font-size:1rem !important; }
.woocommerce ul.products li.product .button { display:block !important; margin:12px 20px 20px !important; padding:10px 20px !important; background:var(--pink) !important; color:#fff !important; border-radius:var(--radius-pill) !important; font-family:var(--font-display) !important; font-size:0.75rem !important; letter-spacing:0.1em !important; text-transform:uppercase !important; text-align:center !important; border:none !important; transition:var(--transition) !important; }
.woocommerce ul.products li.product .button:hover { background:#BE0070 !important; box-shadow:var(--shadow-pink) !important; }
.woocommerce div.product .product_title { font-family:var(--font-display) !important; font-weight:200 !important; font-size:clamp(1.8rem,4vw,3rem) !important; color:var(--text) !important; }
.woocommerce div.product p.price, .woocommerce div.product span.price { color:var(--pink) !important; font-family:var(--font-display) !important; font-size:1.8rem !important; }
.woocommerce div.product form.cart .single_add_to_cart_button { background:var(--pink) !important; color:#fff !important; border:none !important; border-radius:var(--radius-pill) !important; font-family:var(--font-display) !important; letter-spacing:0.1em !important; text-transform:uppercase !important; padding:14px 32px !important; transition:var(--transition) !important; }
.woocommerce div.product form.cart .single_add_to_cart_button:hover { background:#BE0070 !important; box-shadow:var(--shadow-pink) !important; }
.woocommerce table.cart th { background:var(--surface) !important; color:var(--text-faint) !important; font-family:var(--font-display) !important; font-size:0.7rem !important; letter-spacing:0.15em !important; text-transform:uppercase !important; border-bottom:1px solid var(--border) !important; padding:14px 16px !important; }
.woocommerce table.cart td { border-bottom:1px solid var(--border) !important; color:var(--text-muted) !important; padding:14px 16px !important; vertical-align:middle !important; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button, .woocommerce #payment #place_order, .woocommerce-page #payment #place_order { background:var(--pink) !important; border-radius:var(--radius-pill) !important; font-family:var(--font-display) !important; letter-spacing:0.1em !important; text-transform:uppercase !important; border:none !important; padding:16px 40px !important; transition:var(--transition) !important; }
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover, .woocommerce #payment #place_order:hover { background:#BE0070 !important; box-shadow:var(--shadow-pink) !important; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea { background:rgba(255,255,255,0.05) !important; border:1px solid rgba(255,255,255,0.35) !important; border-radius:var(--radius-sm) !important; color:var(--text) !important; font-family:var(--font-body) !important; padding:12px 16px !important; }
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus { border-color:var(--pink) !important; box-shadow:0 0 0 3px rgba(250,0,143,0.1) !important; outline:none !important; }
.woocommerce form .form-row label { color:var(--text-faint) !important; font-size:0.78rem !important; letter-spacing:0.1em !important; text-transform:uppercase !important; }
.woocommerce-error  { background:rgba(250,0,143,0.1) !important; color:var(--pink) !important; border-top:none !important; border-radius:var(--radius-sm) !important; padding:14px 20px !important; }
.woocommerce-message { background:rgba(0,200,120,0.1) !important; color:var(--green) !important; border-top:none !important; border-radius:var(--radius-sm) !important; padding:14px 20px !important; }
.woocommerce-info   { background:rgba(16,88,232,0.1) !important; color:#6B9EFF !important; border-top:none !important; border-radius:var(--radius-sm) !important; padding:14px 20px !important; }

/* COOKIE BANNER — style przeniesione do cookie-banner.css */

/* ANIMACJE */
@keyframes fadeUp { from { opacity:0; transform:translateY(24px); } to { opacity:1; transform:translateY(0); } }
.fade-up { opacity:0; animation:fadeUp 0.6s ease forwards; }

/* POMOCNICZE */
.divider { height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); margin:48px 0; }
.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; }
.mt-8  { margin-top:8px;  } .mt-16 { margin-top:16px; } .mt-24 { margin-top:24px; } .mt-40 { margin-top:40px; }
.mb-8  { margin-bottom:8px; } .mb-16 { margin-bottom:16px; } .mb-24 { margin-bottom:24px; } .mb-40 { margin-bottom:40px; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width: 1024px) {
  :root { --nav-height:64px; }
  .container { padding:0 28px; }
  #site-header { padding:0 28px; }
  #primary-nav { display:none; }
  .hamburger   { display:flex; }
  .hero { padding:calc(var(--nav-height) + 40px) 28px 60px; }
  .services-grid, .project-grid { grid-template-columns:repeat(2,1fr); }
  .woocommerce .products { grid-template-columns:repeat(2,1fr) !important; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .gallery-item:nth-child(4n+1) { grid-column:span 1; aspect-ratio:1; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .grid-3, .grid-4 { grid-template-columns:repeat(2,1fr); }
  .newsletter-section { padding:60px 28px; }
}
@media (max-width: 768px) {
  html { font-size:16px; }
  .hero-blob-1 { width:400px; height:400px; top:-100px; right:-100px; }
  .hero-blob-2 { width:350px; height:350px; }
  .hero { padding:calc(var(--nav-height) + 32px) 16px 48px; }
  .hero-cta { flex-direction:column; }
  .hero-cta .btn { width:100%; justify-content:center; }
  .hero-stats { gap:24px; }
  .services-grid, .project-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid  { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .footer-legal  { justify-content:center; }
  .grid-2, .grid-3 { grid-template-columns:1fr; }
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .container { padding:0 16px; }
  #site-header { padding:0 16px; }
  .newsletter-section { padding:48px 16px; }
  .newsletter-form { flex-direction:column; }
  .newsletter-form .form-input { min-width:0; }
  .concert-item { flex-wrap:wrap; gap:12px; }
  .concert-city { display:none; }
  .section { padding:56px 0; }
  .section-lg { padding:80px 0; }
}
@media (max-width: 480px) {
  h1 { font-size:1.9rem; }
  h2 { font-size:1.5rem; }
  .woocommerce .products { grid-template-columns:1fr !important; }
  .grid-4 { grid-template-columns:1fr; }
  .gallery-grid, .gallery-item:nth-child(4n+1) { grid-column:span 1; aspect-ratio:1; grid-template-columns:1fr; }
}

/* PAGE CONTENT — style edytora Gutenberg */
.page-content h2 { font-size: 1.6rem; margin: 36px 0 16px; }
.page-content h3 { font-size: 1.2rem; margin: 28px 0 12px; }
.page-content p  { color: var(--text-muted); }
.page-content ul, .page-content ol { padding-left: 24px; color: var(--text-muted); font-size: 0.95rem; line-height: 1.85; margin-bottom: 16px; }
.page-content ul li, .page-content ol li { margin-bottom: 8px; }
.page-content blockquote { border-left: 3px solid var(--pink); padding: 16px 24px; margin: 24px 0; background: var(--surface); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.page-content blockquote p { color: var(--text); font-style: italic; }
.page-content img { border-radius: var(--radius); margin: 24px 0; }
.page-content a { color: var(--pink); text-decoration: underline; }
.page-content table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: 0.88rem; }
.page-content table th { background: var(--surface); color: var(--text-faint); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.page-content table td { padding: 12px 16px; border-bottom: 1px solid var(--border); color: var(--text-muted); }
.page-content .wp-block-separator { border: none; border-top: 1px solid var(--border); margin: 32px 0; }
.stretched-link::after { position: absolute; inset: 0; content: ''; z-index: 1; }

/* Gutenberg — Editor dark mode */
.editor-styles-wrapper { background: var(--bg) !important; color: var(--text) !important; font-family: var(--font-body) !important; }

/* ====== POPRAWKI v1.1 ====== */

/* Service ikony SVG */
.service-icon svg { display: block; }
.service-icon { width: 48px; height: 48px; margin-bottom: 20px; }

/* Filter btn aktywny */
.filter-btn.active {
  background: var(--pink) !important;
  color: #fff !important;
  border-color: var(--pink) !important;
}

/* Concert date fix — pokazuj kiedy brak daty */
.concert-date .day { min-width: 2ch; text-align: center; }

/* Newsletter input */
#newsletter-email { min-width: 200px; }

/* Artysta — inicjały placeholder */
.artist-placeholder {
  letter-spacing: 0.08em;
  user-select: none;
}

/* Mobile nav — wyświetl jako block nie flex kiedy zamknięty */
#mobile-nav { display: none; }
#mobile-nav.open { display: flex; }

/* Projekt card — nie skaluj kiedy brak danych */
.project-card-top svg { flex-shrink: 0; }

/* WooCommerce cart link fix */
.nav-cart-btn svg { width: 18px; height: 18px; flex-shrink: 0; }

/* Logo — zawsze CRAVE nie blog name */
.logo-text .brand { font-family: var(--font-display); letter-spacing: 0.25em; }

/* Footer fix */
.footer-copy { font-size: 0.78rem; color: var(--text-faint); }

  .lang-btn { padding: 6px 8px; }
}

/* ============================================================
   NAWIGACJA v1.3 — identyczna z mockupem
   ============================================================ */

#site-header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 0 60px;
  height: var(--nav-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(9,12,9,0.88);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--border-pink);
  transition: background 0.3s;
}
#site-header.scrolled { background: rgba(9,12,9,0.98); }

/* --- LOGO --- */
.logo {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; color: var(--text);
  flex-shrink: 0;
}
/* Logo SVG images — light/dark mode */
.logo-img { display: block; height: 40px; width: auto; }
/* default = dark mode: hide light logo */
.logo-img--light { display: none; }
/* light mode: hide dark logo, show light logo */
.light-mode .logo-img--light { display: block; }
.light-mode .logo-img--dark { display: none; }
/* explicit dark mode class (after toggle) */
.dark-mode .logo-img--light { display: none; }
.dark-mode .logo-img--dark { display: block; }
/* Hide old sygnet + logo-text if still present */
.logo .sygnet, .logo .logo-text { display: none; }
.sygnet { display: flex; align-items: center; gap: 2px; }
.sygnet .bar { width: 3px; border-radius: 3px; background: var(--pink); }
.sygnet .bar:nth-child(1) { height: 14px; }
.sygnet .bar:nth-child(2) { height: 22px; }
.sygnet .bar:nth-child(3) { height: 14px; }
.sygnet .c-letter {
  font-family: var(--font-display);
  font-size: 1.4rem; font-weight: 300;
  color: var(--pink); margin-left: 2px; line-height: 1;
}
.logo-text { line-height: 1.2; }
.logo-text .brand {
  display: block;
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 300;
  letter-spacing: 0.22em; color: var(--text);
}
.logo-text .sub {
  display: block;
  font-size: 0.52rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--text-muted);
}

/* --- MENU LINKS --- */
.nav-links {
  display: flex;
  gap: 32px;
  list-style: none;
  margin: 0; padding: 0;
}
.nav-links a {
  color: var(--text-muted);
  text-decoration: none;
  font-family: var(--font-body);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 0.2s;
  white-space: nowrap;
}
.nav-links a:hover,
.nav-links .current-menu-item > a,
.nav-links .current_page_item > a { color: var(--pink); }

/* Dropdown submenu */
.nav-links .menu-item-has-children { position: relative; }
.nav-links .menu-item-has-children > a::after { content: ' ▾'; font-size: 0.65rem; opacity: 0.6; }
.nav-links .sub-menu {
  position: absolute; top: calc(100% + 12px); left: 0;
  min-width: 200px; background: var(--bg2);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  list-style: none; padding: 8px;
  opacity: 0; pointer-events: none;
  transform: translateY(-6px); transition: all 0.2s;
  z-index: 200; box-shadow: var(--shadow-dark);
}
.nav-links .menu-item-has-children:hover .sub-menu {
  opacity: 1; pointer-events: all; transform: translateY(0);
}
.nav-links .sub-menu li a {
  display: block; padding: 8px 12px;
  border-radius: 6px; font-size: 0.8rem;
  text-transform: none; letter-spacing: 0.04em;
}
.nav-links .sub-menu li a:hover { background: rgba(250,0,143,0.06); }

/* --- PRAWA STRONA NAV --- */
.nav-right {
  display: flex; align-items: center; gap: 14px;
  flex-shrink: 0;
}

/* CTA button */
.nav-cta {
  background: transparent;
  border: 1px solid var(--pink);
  color: var(--pink);
  padding: 8px 22px;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.25s;
  text-decoration: none;
  white-space: nowrap;
}
.nav-cta:hover { background: var(--pink); color: #fff; }

/* --- SUWAK DARK/LIGHT — identyczny z mockupem --- */
.theme-toggle-wrap {
  display: flex; align-items: center; gap: 7px;
}
.theme-icon {
  font-size: 0.85rem; color: var(--text-muted);
  line-height: 1; transition: color 0.3s;
  user-select: none;
}
.theme-toggle {
  width: 44px; height: 24px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50px;
  cursor: pointer;
  position: relative;
  transition: background 0.3s, border-color 0.3s;
  flex-shrink: 0;
  padding: 0;
}
.theme-toggle::before {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--pink);
  transition: transform 0.3s;
}
body.light-mode .theme-toggle::before { transform: translateX(20px); }
.theme-toggle:hover { border-color: var(--pink); }

/* --- LANG PL | EN --- */
.lang-toggle {
  display: flex; align-items: center; gap: 6px;
}
.lang-btn {
  background: none; border: none;
  font-family: var(--font-display);
  font-size: 0.72rem; font-weight: 300;
  letter-spacing: 0.15em;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px 4px;
  transition: color 0.2s;
  text-decoration: none;
  text-transform: uppercase;
}
.lang-btn.active,
.lang-btn:hover { color: var(--pink); font-weight: 400; }
.lang-sep { color: var(--text-faint); font-size: 0.7rem; }

/* --- KOSZYK --- */
.nav-cart-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-muted);
  font-size: 0.78rem;
  transition: var(--transition);
  text-decoration: none;
  position: relative;
}
.nav-cart-btn:hover { border-color: var(--pink); color: var(--pink); }
.cart-count {
  background: var(--pink); color: #fff;
  width: 16px; height: 16px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.6rem; font-weight: 400;
  position: absolute; top: -4px; right: -4px;
}

/* --- HAMBURGER --- */
.hamburger {
  display: none;
  flex-direction: column; gap: 5px;
  background: none; border: none;
  padding: 8px; cursor: pointer;
}
.hamburger span {
  display: block; width: 24px; height: 2px;
  background: var(--text); border-radius: 2px;
  transition: var(--transition);
}
.hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

/* --- MOBILE NAV --- */
#mobile-nav {
  display: none;
  position: fixed;
  top: var(--nav-height); left: 0; right: 0;
  background: rgba(9,12,9,0.98);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  padding: 20px; z-index: 999;
  list-style: none;
  flex-direction: column; gap: 0;
}
#mobile-nav.open { display: flex; }
#mobile-nav li a {
  display: block; padding: 13px 16px;
  font-size: 0.95rem; font-family: var(--font-body);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-muted);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  transition: var(--transition);
}
#mobile-nav li:last-child a { border-bottom: none; }
#mobile-nav li a:hover { color: var(--pink); padding-left: 24px; }

/* ============================================================
   FRONT-PAGE SPECIFIC SECTIONS (v2)
   ============================================================ */

/* ── MANIFESTO ── */
.fp-manifesto { position:relative; padding:120px 0; overflow:hidden; border-bottom:1px solid var(--border); }
.fp-manifesto-decor { position:absolute; right:48px; top:50%; transform:translateY(-50%); font-family:var(--font-display); font-weight:200; font-size:20rem; line-height:1; background:linear-gradient(180deg,rgba(250,0,143,0.04) 0%,transparent 80%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; pointer-events:none; user-select:none; }
.fp-manifesto-text { font-family:var(--font-display); font-size:clamp(1.2rem,2.4vw,1.9rem); font-weight:200; line-height:1.55; max-width:900px; color:var(--text-muted); margin:0; }
.fp-manifesto-text em { font-style:normal; color:var(--text); }
.fp-manifesto-text strong { font-weight:300; background:var(--grad-3); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ── DNA / BENTO ── */
.fp-bento { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:48px; }
.fp-bento-card { position:relative; padding:40px 32px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--border); overflow:hidden; transition:var(--transition); }
.fp-bento-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; opacity:0; transition:opacity 0.3s; }
.fp-bento-card:hover { border-color:var(--border-pink); transform:translateY(-4px); box-shadow:0 20px 50px rgba(0,0,0,.25); }
.fp-bento-card:hover::before { opacity:1; }
.fp-bento-card:nth-child(1)::before { background:var(--grad-3); }
.fp-bento-card:nth-child(2)::before { background:var(--grad-2); }
.fp-bento-card:nth-child(3)::before { background:linear-gradient(103deg,var(--green),var(--blue)); }
.fp-bento-card:nth-child(4)::before { background:var(--grad-1); }
.fp-bento-icon  { width:44px; height:44px; border-radius:10px; background:rgba(250,0,143,.08); display:flex; align-items:center; justify-content:center; margin-bottom:20px; font-size:1.4rem; }
.fp-bento-label { font-size:0.6rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--pink); margin-bottom:12px; font-family:var(--font-display); }
.fp-bento-title { font-family:var(--font-display); font-size:1.2rem; font-weight:300; margin-bottom:12px; color:var(--text); }
.fp-bento-text  { font-size:0.88rem; color:var(--text-muted); line-height:1.85; margin:0; }

/* ── STATS ── */
.fp-stats { padding:72px 0; background:linear-gradient(135deg,rgba(250,0,143,.04) 0%,rgba(150,24,255,.04) 50%,rgba(255,199,0,.02) 100%); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.fp-stats-row { display:flex; justify-content:center; flex-wrap:wrap; }
.fp-stat { flex:1; min-width:160px; max-width:220px; text-align:center; padding:24px 20px; position:relative; }
.fp-stat + .fp-stat::before { content:''; position:absolute; left:0; top:25%; bottom:25%; width:1px; background:var(--border); }
.fp-stat-val { display:block; font-family:var(--font-display); font-size:clamp(2.2rem,4vw,3.4rem); font-weight:200; line-height:1; margin-bottom:8px; background:var(--grad-3); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.fp-stat-label { font-size:0.68rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--text-muted); ;font-weight:400}

/* ── SERVICES PREVIEW ── */
.fp-sp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px; margin-bottom:48px; }
.fp-sp-card { position:relative; padding:48px 32px; border-radius:var(--radius); background:var(--surface); border:1px solid var(--border); text-align:center; transition:var(--transition); }
.fp-sp-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; opacity:0; transition:opacity 0.3s; }
.fp-sp-card:hover { border-color:var(--border-pink); transform:translateY(-4px); box-shadow:0 20px 50px rgba(0,0,0,.25); }
.fp-sp-card:hover::before { opacity:1; }
.fp-sp-card:nth-child(1)::before { background:var(--grad-3); }
.fp-sp-card:nth-child(2)::before { background:var(--grad-2); }
.fp-sp-card:nth-child(3)::before { background:linear-gradient(103deg,var(--green),var(--blue)); }
.fp-sp-icon  { font-size:2.5rem; margin-bottom:20px; display:block; }
.fp-sp-title { font-family:var(--font-display); font-size:1.1rem; font-weight:300; margin-bottom:10px; color:var(--text); }
.fp-sp-desc  { font-size:0.85rem; color:var(--text-muted); line-height:1.8; margin:0; }

/* ── NEWSLETTER FORM ── */
.nl-form { max-width:560px; margin:0 auto; text-align:left; }
.nl-fields { display:flex; gap:12px; margin-bottom:20px; }
.nl-field { flex:1; }
.nl-label { display:block; font-family:var(--font-display); font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; }
.nl-req { color:var(--pink); }
.nl-input { width:100%; padding:14px 20px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-pill); color:var(--text); font-family:var(--font-body); font-size:.85rem; outline:none; transition:border-color 0.2s; }
.nl-input:focus { border-color:var(--pink); }
.nl-input::placeholder { color:var(--text-faint); }
.nl-checkboxes { display:flex; flex-direction:column; gap:14px; margin-top:20px; }
.nl-checkbox { display:flex; align-items:flex-start; gap:12px; cursor:pointer; position:relative; }
.nl-checkbox input { position:absolute; opacity:0; width:0; height:0; }
.nl-checkmark { flex-shrink:0; width:24px; height:24px; border:1px solid var(--border); border-radius:4px; background:var(--surface); display:flex; align-items:center; justify-content:center; transition:all 0.2s; margin-top:1px; }
.nl-checkmark::after { content:'\2713'; font-size:0.7rem; color:var(--pink); opacity:0; transition:opacity 0.2s; }
.nl-checkbox input:checked ~ .nl-checkmark { border-color:var(--pink); background:rgba(250,0,143,.1); }
.nl-checkbox input:checked ~ .nl-checkmark::after { opacity:1; }
.nl-checkbox input:focus-visible ~ .nl-checkmark { outline:3px solid var(--pink); outline-offset:2px; }
.nl-checkbox input:focus ~ .nl-checkmark { outline:2px solid var(--pink); outline-offset:2px; }
.nl-checkbox input:focus:not(:focus-visible) ~ .nl-checkmark { outline:none; }
.nl-checkbox-text { font-size:0.75rem; color:var(--text-muted); line-height:1.6; }

/* Front page — utility classes replacing inline styles */
.text-center { text-align:center; }
.section-alt  { background:var(--bg2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:48px; flex-wrap:wrap; gap:16px; }
.badge-pos-tl { position:absolute; top:12px; left:12px; font-size:0.6rem; }
.badge-pos-tr { position:absolute; top:12px; right:12px; }
.project-footer-meta { font-size:0.75rem; color:var(--text-faint); }
.artist-placeholder { color:var(--pink); font-family:var(--font-display); font-size:2.5rem; font-weight:200; }
.icon-large { font-size:3rem; }
.nl-blob { opacity:0.06; }
.nl-tag-center { justify-content:center; }
.nl-title { font-size:clamp(1.6rem,3vw,2.2rem); }
.nl-desc { color:var(--text-muted); margin-bottom:32px; }
.nl-required-note { font-size:.7rem; color:var(--text-faint); margin-top:16px; }
.nl-status-box { display:none; text-align:center; margin-top:12px; padding:10px; border-radius:8px; font-size:.85rem; }
.nl-submit-wrap { text-align:center; }
.nl-submit-wrap .btn { margin-top:16px; }
.nl-footer-note { font-size:0.72rem; color:var(--text-faint); margin-top:16px; }
.nl-footer-note a { color:var(--text-faint); text-decoration:underline; }
.nl-email-reveal { background:none; border:none; color:var(--pink); cursor:pointer; font-size:inherit; font-family:inherit; text-decoration:underline; padding:0; }
.nl-email-reveal.revealed { cursor:default; text-decoration:none; }
.nl-email-reveal { background:none; border:1px dashed var(--pink); color:var(--pink); padding:2px 10px; border-radius:4px; font-size:0.72rem; font-family:var(--font-display); cursor:pointer; transition:all 0.2s; letter-spacing:0.02em; }
.nl-email-reveal:hover { background:rgba(250,0,143,.1); }

/* ── FP RESPONSIVE ── */
@media (max-width:1024px) {
  .fp-bento { grid-template-columns:1fr; }
  .fp-sp-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .fp-manifesto { padding:80px 0; }
  .fp-manifesto-decor { display:none; }
  .fp-stats-row { flex-direction:column; align-items:center; }
  .fp-stat { min-width:100%; max-width:100%; }
  .fp-stat + .fp-stat::before { display:none; }
  .fp-sp-grid { grid-template-columns:1fr; }
  .nl-fields { flex-direction:column; }
}

/* ============================================================
   DARK / LIGHT MODE v1.3
   ============================================================ */
body.light-mode {
  --bg:          #F0F0F0;
  --bg2:         #E8E8E8;
  --bg3:         #DEDEDE;
  --surface:     rgba(0,0,0,0.04);
  --surface2:    rgba(0,0,0,0.07);
  --border:      rgba(0,0,0,0.10);
  --border-pink: rgba(250,0,143,0.15);
  --text:        #0A0A0A;
  --text-muted:  #4A4A4A;
  --text-faint:  #555555;
  --shadow-dark: 0 20px 60px rgba(0,0,0,0.10);
  --muted:       #767676;
  --pink:        #C5006E;
}
body.light-mode #site-header { background: rgba(240,240,240,0.92); }
body.light-mode #site-header.scrolled { background: rgba(240,240,240,0.99); }
body.light-mode .nav-links a { color: var(--text-muted); }
body.light-mode .nav-links .sub-menu { background: #fff; }
body.light-mode .service-card { background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
body.light-mode .project-card { background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
body.light-mode .card { background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
body.light-mode #site-footer { background: var(--bg2); }
body.light-mode #mobile-nav { background: rgba(240,240,240,0.98); }
body.light-mode #mobile-nav li a { color: var(--text-muted); }

/* Mobile menu dark/light toggle */
.mobile-theme-toggle-li {
  border-bottom: none !important;
  padding: 0 !important;
}
.mobile-theme-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 16px;
  border-top: 1px solid var(--border);
}
.mobile-theme-toggle .moon-icon,
.mobile-theme-toggle .sun-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  transition: color 0.3s;
  flex-shrink: 0;
}
.mobile-theme-toggle .moon-icon::before {
  content: '';
  display: block;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  box-shadow: -3px 0 0 2px currentColor;
  background: transparent;
}
.mobile-theme-toggle .sun-icon::before {
  content: '';
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
  box-shadow:
    0 -5px 0 1.5px currentColor,
    0  5px 0 1.5px currentColor,
    -5px 0 0 1.5px currentColor,
     5px 0 0 1.5px currentColor,
    -3.5px -3.5px 0 1.5px currentColor,
     3.5px -3.5px 0 1.5px currentColor,
    -3.5px  3.5px 0 1.5px currentColor,
     3.5px  3.5px 0 1.5px currentColor;
}
body.light-mode .concert-item:hover { background: var(--surface2); }
body.light-mode .form-input,
body.light-mode .form-textarea,
body.light-mode #newsletter-email { background: #fff; border-color: rgba(0,0,0,0.18); color: var(--text); }
body.light-mode .hero-blob-1 { background: radial-gradient(circle, rgba(250,0,143,0.06) 0%, rgba(250,0,143,0.02) 40%, transparent 70%); }
body.light-mode .hero-blob-2 { background: radial-gradient(circle, rgba(150,24,255,0.04) 0%, rgba(150,24,255,0.01) 40%, transparent 70%); }
body.light-mode .artists-ticker { background: var(--bg2); }
body.light-mode .widget { background: #fff; }
body.light-mode .woocommerce ul.products li.product { background: #fff !important; }

/* ── LIGHT MODE — FRONT-PAGE NEW SECTIONS ── */
body.light-mode .fp-manifesto-decor { background: linear-gradient(180deg,rgba(250,0,143,0.06) 0%,transparent 80%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
body.light-mode .fp-manifesto-text { color: var(--text-muted); }
body.light-mode .fp-manifesto-text em { color: var(--text); }
body.light-mode .fp-bento-card { background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
body.light-mode .fp-bento-icon { background: rgba(250,0,143,0.06); }
body.light-mode .fp-stats { background: linear-gradient(135deg,rgba(250,0,143,0.03) 0%,rgba(150,24,255,0.03) 50%,rgba(255,199,0,0.02) 100%); }
body.light-mode .fp-sp-card { background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
body.light-mode .nl-input { background: #fff; border-color: rgba(0,0,0,0.18); color: var(--text); }
body.light-mode .nl-input::placeholder { color: var(--text-faint); }
body.light-mode .nl-checkmark { background: #fff; border-color: rgba(0,0,0,0.15); }
body.light-mode .nl-checkbox input:checked ~ .nl-checkmark { background: rgba(250,0,143,0.08); border-color: var(--pink); }
body.light-mode .nl-email-reveal { border-color: rgba(250,0,143,0.4); }
body.light-mode .newsletter-section { background: var(--bg2); }

/* ============================================================
   RESPONSIVE — NAWIGACJA
   ============================================================ */
@media (max-width:1440px){.nav-cta{display:none}#site-header{padding:0 32px}}@media (max-width: 1100px) {
  #site-header { padding: 0 28px; }
  .nav-links { gap: 20px; }
  .nav-links a { font-size: 0.75rem; }
  .nav-cta { display: none; }
}
@media (max-width: 900px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  #site-header { padding: 0 20px; }
}
@media (max-width: 480px) {
  .theme-toggle-wrap { display: none; }
  .lang-toggle { display: none; }
}

/* ============================================================
   SEKCJA WSPÓŁPRACA / KONTAKT — identyczna z mockupem
   ============================================================ */

.contact-section {
  background: var(--bg2);
  padding: 100px 60px;
  border-top: 1px solid rgba(255,255,255,0.05);
  position: relative;
  overflow: hidden;
}
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.7fr;
  gap: 80px;
  align-items: start;
  margin-top: 56px;
}
.contact-left { position: sticky; top: calc(var(--nav-height) + 20px); }
.contact-left p {
  font-size: 0.9rem; line-height: 1.85;
  color: var(--text-muted); margin-bottom: 36px;
}
.contact-info-item {
  display: flex; align-items: flex-start;
  gap: 14px; margin-bottom: 20px;
}
.contact-info-icon {
  width: 38px; height: 38px; flex-shrink: 0;
  border: 1px solid rgba(250,0,143,0.3); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem; color: var(--pink);
}
.contact-info-text { font-size: 0.92rem; line-height: 1.65; }
.contact-info-text strong {
  display: block; color: var(--text);
  font-family: var(--font-display); font-weight: 300;
  letter-spacing: 0.04em; margin-bottom: 2px;
}
.contact-info-text span,
.contact-info-text a { color: var(--text-muted); text-decoration: none; transition: color 0.2s; }
.contact-info-text a:hover { color: var(--pink); }

/* Karta formularza */
.contact-form-wrap {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 44px 44px 48px;
  position: relative; overflow: hidden;
}
.contact-form-wrap::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--grad-2);
}
.form-section-title {
  font-family: var(--font-display); font-weight: 300;
  font-size: 1.3rem; letter-spacing: 0.02em;
  margin-bottom: 6px; color: var(--text);
}
.form-section-sub {
  font-size: 0.82rem; color: var(--text-muted);
  line-height: 1.6; margin-bottom: 32px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { margin-bottom: 20px; }
.form-label {
  display: block;
  font-size: 0.78rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgba(255,255,255,0.62);
  margin-bottom: 8px;
}
.required-star { color: var(--pink); }

/* Inputs */
.form-input, .form-textarea {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 8px;
  padding: 13px 16px;
  color: var(--text);
  font-family: var(--font-body);
  font-size: 0.88rem;
  outline: none;
  transition: border-color 0.2s, background 0.2s;
}
.form-input:focus, .form-textarea:focus {
  border-color: var(--pink);
  background: rgba(250,0,143,0.04);
}
.form-input::placeholder, .form-textarea::placeholder { color: #707070; }
.form-textarea { resize: vertical; min-height: 110px; line-height: 1.6; }

/* Checkboxy */
.checkbox-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 2px;
}
.checkbox-item {
  display: flex; align-items: center; gap: 10px; cursor: pointer;
  padding: 11px 14px;
  border: 1px solid var(--border); border-radius: 8px;
  transition: border-color 0.2s, background 0.2s;
  user-select: none;
}
.checkbox-item:hover { border-color: rgba(250,0,143,0.35); background: rgba(250,0,143,0.04); }
.checkbox-item.checked { border-color: rgba(250,0,143,0.4); background: rgba(250,0,143,0.05); }
.checkbox-item input[type="checkbox"] { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.checkbox-item input[type="checkbox"]:focus-visible ~ .checkbox-box { outline: 3px solid var(--pink); outline-offset: 2px; border-radius: 4px; }
.checkbox-box {
  width: 18px; height: 18px; flex-shrink: 0;
  border: 1.5px solid rgba(255,255,255,0.35); border-radius: 4px;
  background: rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.checkbox-box::after {
  content: '✓'; font-size: 0.7rem; color: #fff; opacity: 0; transition: opacity 0.15s;
}
.checkbox-item input:checked ~ .checkbox-box {
  background: var(--pink); border-color: var(--pink);
  box-shadow: 0 0 10px rgba(250,0,143,0.35);
}
.checkbox-item input:checked ~ .checkbox-box::after { opacity: 1; }
.checkbox-item input:checked ~ .checkbox-label { color: var(--text); }
.checkbox-label { font-size: 0.88rem; color: var(--text-muted); transition: color 0.2s; line-height: 1.3; }

/* GDPR checkboxy */
.checkbox-item--gdpr { align-items: flex-start; padding: 14px 16px; border-color: rgba(255,255,255,0.07); }
.checkbox-item--gdpr .checkbox-box { margin-top: 2px; flex-shrink: 0; }
.checkbox-label--small { font-size: 0.82rem; line-height: 1.7; }

/* Social inputs */
.social-inputs { display: flex; flex-direction: column; gap: 10px; }
.social-input-row { display: flex; align-items: center; }
.social-input-row .form-input { border-radius: 0 8px 8px 0; border-left: none; }
.social-icon {
  width: 44px; height: 44px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10); border-right: none;
  border-radius: 8px 0 0 8px;
  font-size: 0.85rem; font-weight: 400; transition: background 0.2s;
}
.social-input-row:focus-within .social-icon { background: rgba(250,0,143,0.1); border-color: var(--pink); }
.social-input-row:focus-within .form-input { border-color: var(--pink); background: rgba(250,0,143,0.04); }
.social-icon.yt { color: #FF4444; }
.social-icon.sp { color: #1DB954; }
.social-icon.ig { color: #E1306C; }

/* Submit button */
.form-submit {
  width: 100%; margin-top: 8px;
  background: var(--grad-2);
  border: none; border-radius: 50px;
  color: #fff;
  font-family: var(--font-body);
  font-size: 0.88rem; letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 15px; cursor: pointer;
  transition: transform 0.2s, box-shadow 0.2s, opacity 0.2s;
}
.form-submit:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(250,0,143,0.35);
}
.form-submit:disabled { opacity: 0.6; cursor: not-allowed; }
.form-note { text-align: center; margin-top: 14px; font-size: 0.8rem; color: var(--text-faint); line-height: 1.6; }

/* Success */
.form-success { text-align: center; padding: 48px 20px; }
.success-icon { font-size: 3rem; margin-bottom: 20px; }
.success-title { font-family: var(--font-display); font-weight: 300; font-size: 1.6rem; margin-bottom: 10px; }
.success-sub { font-size: 0.88rem; color: var(--text-muted); line-height: 1.7; }

/* Light mode overrides */
body.light-mode .form-input,
body.light-mode .form-textarea { background: #fff; border-color: rgba(0,0,0,0.15); color: var(--text); }
body.light-mode .form-input:focus,
body.light-mode .form-textarea:focus { border-color: var(--pink); background: rgba(250,0,143,0.03); }
body.light-mode .form-label { color: rgba(0,0,0,0.6); }
body.light-mode .checkbox-box { border-color: rgba(0,0,0,0.3); background: rgba(0,0,0,0.04); }
body.light-mode .social-icon { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.12); }
body.light-mode .contact-form-wrap { background: #fff; border-color: rgba(0,0,0,0.08); }
body.light-mode .contact-section { background: var(--bg2); }

/* Responsive */
@media (max-width: 900px) {
  .contact-section { padding: 80px 32px; }
  .contact-layout { grid-template-columns: 1fr; gap: 40px; }
  .contact-left { position: static; }
  .form-row { grid-template-columns: 1fr; }
  .checkbox-grid { grid-template-columns: 1fr; }
  .contact-form-wrap { padding: 36px 32px 40px; }
  .form-group { margin-bottom: 16px; }
}
@media (max-width: 600px) {
  .contact-section { padding: 64px 20px; }
  .contact-form-wrap { padding: 28px 24px 32px; }
  .social-icon { width: 36px; height: 36px; font-size: 0.75rem; }
  .social-input-row .form-input { padding: 11px 12px; font-size: 0.82rem; }
}
@media (max-width: 380px) {
  .social-input-row { flex-wrap: wrap; }
  .social-icon { width: 100%; height: auto; padding: 8px; border-radius: 8px 8px 0 0; border-right: 1px solid rgba(255,255,255,0.10); border-bottom: none; }
  .social-input-row .form-input { border-radius: 0 0 8px 8px; border-left: 1px solid rgba(255,255,255,0.10); border-top: none; }
}

/* Brand asterisk dekoracja */
.brand-asterisk {
  position: absolute; font-size: 2rem; opacity: 0.15;
  color: var(--pink); pointer-events: none; z-index: 0;
}
.section-blob-pink {
  position: absolute; border-radius: 50%;
  background: radial-gradient(circle, rgba(250,0,143,0.15), transparent 70%);
  pointer-events: none; z-index: 0;
  will-change: transform; contain: layout style;
}

/* reCAPTCHA mock */
.recaptcha-mock {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 18px;
  transition: border-color 0.2s;
}
.recaptcha-checkbox-row {
  display: flex; align-items: center; gap: 12px; cursor: pointer;
}
.recaptcha-checkbox-row input[type="checkbox"] { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.recaptcha-checkbox-row input[type="checkbox"]:focus-visible ~ .recaptcha-box { outline: 3px solid var(--pink); outline-offset: 3px; border-radius: 3px; }
.recaptcha-box {
  width: 24px; height: 24px; flex-shrink: 0;
  border: 2px solid rgba(255,255,255,0.3); border-radius: 3px;
  background: rgba(255,255,255,0.05);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.recaptcha-box::after { content: '✓'; font-size: 0.85rem; color: #fff; opacity: 0; transition: opacity 0.15s; }
.recaptcha-checkbox-row input:checked ~ .recaptcha-box {
  background: #4A90D9; border-color: #4A90D9;
}
.recaptcha-checkbox-row input:checked ~ .recaptcha-box::after { opacity: 1; }
.recaptcha-label { font-size: 0.9rem; color: var(--text-muted); }
.recaptcha-logo { display: flex; align-items: center; gap: 8px; }
.recaptcha-logo-text { text-align: right; line-height: 1.3; }
.recaptcha-logo-text span { display: block; font-size: 0.7rem; color: var(--text-muted); }
.recaptcha-logo-text small { font-size: 0.6rem; color: var(--text-faint); }

/* Link w tekście checkboxa */
.form-link { color: var(--pink); text-decoration: underline; text-underline-offset: 2px; }
.form-link:hover { opacity: 0.8; }

/* Light mode recaptcha */
body.light-mode .recaptcha-mock { background: rgba(0,0,0,0.02); }
body.light-mode .recaptcha-box { border-color: rgba(0,0,0,0.3); background: rgba(0,0,0,0.04); }

/* Email reveal — ochrona przed spamem */
.email-reveal-wrap { display: inline-flex; align-items: center; }
.email-reveal-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(250,0,143,0.06);
  border: 1px solid rgba(250,0,143,0.25);
  border-radius: var(--radius-pill);
  color: var(--pink);
  font-size: 0.78rem; font-family: var(--font-body);
  padding: 5px 12px; cursor: pointer;
  transition: var(--transition);
  letter-spacing: 0.04em;
}
.email-reveal-btn:hover {
  background: rgba(250,0,143,0.12);
  border-color: var(--pink);
}
.email-reveal-address {
  color: var(--text-muted);
  text-decoration: none;
  font-size: 0.92rem;
  transition: color 0.2s;
}
.email-reveal-address:hover { color: var(--pink); }
body.light-mode .email-reveal-btn { background: rgba(250,0,143,0.06); }

/* Email reveal — wersja inline w tekście checkboxa */
.email-reveal-btn--inline {
  font-size: 0.72rem;
  padding: 2px 8px;
  vertical-align: middle;
  line-height: 1.4;
  border-radius: 20px;
  margin: 0 2px;
}
.email-reveal-address--inline {
  color: var(--pink);
  text-decoration: none;
  font-size: inherit;
  margin: 0 2px;
}
.email-reveal-address--inline:hover { text-decoration: underline; }


/* ============================================================
   STRONA KONTAKT / CONTACT PAGE — Concept C "Immersive Dark"
   ============================================================ */

/* ── Hero ── */
.kt-hero {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: flex-start; /* BUG#8 fix: center→flex-start */
  text-align: left; /* BUG#8 fix: center→left (spójność z front page) */
  padding: calc(var(--nav-height) + 60px) 60px 80px; /* BUG#8 fix: padding 40px→60px (spójność z .hero) */
  position: relative; overflow: hidden;
  background: var(--bg);
}
.kt-hero-blob1 {
  position: absolute; width: 500px; height: 500px; border-radius: 50%;
  background: radial-gradient(circle, rgba(250,0,143,0.1), transparent 65%);
  top: -100px; right: -100px; pointer-events: none;
  will-change: transform;
  animation: kt-float 8s ease-in-out infinite;
}
.kt-hero-blob2 {
  position: absolute; width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(circle, rgba(150,24,255,0.06), transparent 65%);
  bottom: -80px; left: -60px; pointer-events: none;
  will-change: transform;
  animation: kt-float 10s ease-in-out infinite reverse;
}
@keyframes kt-float {
  0%,100% { transform: translate(0,0); }
  50% { transform: translate(20px,-20px); }
}
.kt-hero-grain {
  position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events: none;
}
.kt-hero-content { position: relative; z-index: 2; max-width: 760px; text-align: left; } /* BUG#8 fix: max-width 720→760, text-align left */
.kt-tag {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; /* spec: 0.65rem→0.72rem, 0.3em→0.22em */
  color: var(--pink); margin-bottom: 16px;
  /* spec: usunięto padding, border-radius, border, background — prosty tag jak .section-tag */
}
.kt-tag::before { content: ''; display: block; width: 24px; height: 1px; background: var(--pink); } /* spec: dash prefix */
.kt-h1 {
  font-family: var(--font-display); font-weight: 200;
  font-size: clamp(2.8rem, 6vw, 5rem); line-height: 1.05; /* BUG#8 fix: 4.5rem→5rem, spójność z .hero-title */
  margin-bottom: 20px;
}
.kt-h1-grad {
  display: block;
  background: var(--grad-2); /* BUG#8 fix: #FA008F→#FFC700 (yellow) zmieniony na grad-2 (pink→purple) */
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.kt-sub {
  font-size: 1rem; color: var(--text-muted); line-height: 1.8; /* spec: ujednolicenie z .hero-desc */
  max-width: 560px; margin-bottom: 44px; text-align: left; /* spec: dodano max-width i text-align */
}

/* ── Department cards ── */
.kt-dept-cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  margin-top: 48px; max-width: 860px; margin-left: auto; margin-right: auto;
}
.kt-card {
  padding: 28px 24px; border-radius: 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  backdrop-filter: blur(12px);
  text-align: left;
  display: flex; flex-direction: column;
  transition: all 0.35s; cursor: default;
  position: relative; overflow: hidden;
}
.kt-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--grad-2); opacity: 1;
}
.kt-card:hover {
  border-color: var(--border-pink);
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
}
.kt-card--highlight {
  border-color: var(--border);
  background: rgba(255,255,255,0.03);
}
.kt-card-label {
  font-size: 0.58rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--pink); margin-bottom: 10px;
}
.kt-card-name {
  font-family: var(--font-display); font-weight: 300;
  font-size: 1.05rem; margin-bottom: 6px;
}
.kt-card-desc {
  font-size: 0.8rem; color: var(--text-muted); line-height: 1.65;
  margin-bottom: 16px;
}
.kt-card-contact { display: flex; flex-direction: column; gap: 8px; margin-top: auto; padding-top: 16px; }
.kt-email-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: var(--radius-sm);
  background: rgba(250,0,143,0.06); border: 1px solid rgba(250,0,143,0.15);
  color: var(--pink); font-family: var(--font-body);
  font-size: 0.78rem; cursor: pointer; transition: all 0.2s;
}
.kt-email-btn:hover {
  background: rgba(250,0,143,0.12); border-color: rgba(250,0,143,0.3);
}
.kt-email-addr {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.82rem; color: var(--pink);
  padding: 8px 0; transition: color 0.2s;
}
.kt-email-addr:hover { color: #fff; }


/* ── Form section ── */
.kt-form-section {
  padding: 100px 0; position: relative;
  background: linear-gradient(180deg, var(--bg2), var(--bg));
}
.kt-form-glow-top {
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(250,0,143,0.3), transparent);
}
.kt-form-header {
  text-align: center; margin-bottom: 48px;
}
.kt-form-h2 {
  font-family: var(--font-display); font-weight: 200;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem); margin-bottom: 12px;
}
.kt-form-sub {
  color: var(--text-muted); font-size: 0.95rem; line-height: 1.8;
}
.kt-form-glass {
  max-width: 740px; margin: 0 auto;
  background: rgba(255,255,255,0.025); border: 1px solid var(--border);
  border-radius: 20px; padding: 48px;
  backdrop-filter: blur(8px);
  position: relative; overflow: hidden;
}
.kt-form-glass-glow {
  position: absolute; top: -1px; left: 20%; right: 20%; height: 2px;
  background: linear-gradient(90deg, transparent, var(--pink), transparent);
}
.kt-form-actions { text-align: center; margin-top: 8px; }
.kt-form-actions .form-submit { min-width: 240px; }

/* ── FAQ + Map ── */
.kt-bottom-section {
  padding: 100px 0;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.kt-bottom-grid {
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 64px; align-items: start;
}
.kt-bottom-h2 {
  font-family: var(--font-display); font-weight: 200;
  font-size: clamp(1.6rem, 3vw, 2.2rem); margin-bottom: 28px;
}
.kt-faq-item {
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  margin-bottom: 12px; overflow: hidden; transition: all 0.25s;
}
.kt-faq-item[open] {
  border-color: var(--border-pink);
  background: rgba(250,0,143,0.02);
}
.kt-faq-q {
  padding: 16px 20px;
  font-family: var(--font-display); font-size: 0.9rem; font-weight: 400;
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  transition: color 0.2s;
}
.kt-faq-q::-webkit-details-marker { display: none; }
.kt-faq-q::after {
  content: '+'; font-size: 1.2rem; color: var(--pink);
  flex-shrink: 0; transition: transform 0.3s;
}
.kt-faq-item[open] .kt-faq-q::after { transform: rotate(45deg); }
.kt-faq-q:hover { color: var(--pink); }
.kt-faq-a {
  padding: 0 20px 16px; font-size: 0.88rem;
  color: var(--text-muted); line-height: 1.75;
}
.kt-faq-a a { color: var(--pink); text-decoration: underline; }

/* Map */
.kt-map {
  border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--border);
}
.kt-map iframe { display: block; }
.kt-map-facade {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  min-height: 380px; gap: 12px;
  background: rgba(255,255,255,0.02);
  border: 1px dashed var(--border);
  border-radius: var(--radius);
}
.kt-map-facade-icon { opacity: 0.6; }
.kt-map-facade-label {
  font-size: 0.9rem; color: var(--text-muted); text-align: center;
}
.kt-map-facade-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 24px; border-radius: 40px;
  background: rgba(250,0,143,0.08); border: 1px solid rgba(250,0,143,0.2);
  color: var(--pink); font-family: var(--font-body);
  font-size: 0.85rem; cursor: pointer; transition: all 0.2s;
}
.kt-map-facade-btn:hover {
  background: rgba(250,0,143,0.15); border-color: rgba(250,0,143,0.4);
}
.kt-map-facade-btn:focus-visible {
  outline: 2px solid var(--pink); outline-offset: 2px;
}
.kt-map-facade-note {
  font-size: 0.68rem; color: var(--text-faint); text-align: center; max-width: 300px;
}
body.light-mode .kt-map-facade { background: rgba(0,0,0,0.02); border-color: rgba(0,0,0,0.1); }
.kt-map-address {
  display: flex; align-items: center; gap: 10px;
  margin-top: 16px; font-size: 0.88rem; color: var(--text-muted);
}
.kt-extra-info {
  margin-top: 24px; padding-top: 20px;
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 16px;
}
.kt-extra-item {
  display: flex; align-items: flex-start; gap: 12px;
}
.kt-extra-item svg { flex-shrink: 0; margin-top: 2px; }
.kt-extra-item strong {
  display: block; font-size: 0.72rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-faint); font-weight: 400; margin-bottom: 2px;
}
.kt-extra-item span { font-size: 0.88rem; color: var(--text-muted); }
.kt-extra-item a { color: var(--text-muted); transition: color 0.2s; }
.kt-extra-item a:hover { color: var(--pink); }

/* ── Light mode ── */
body.light-mode .kt-hero { background: var(--bg2); }
body.light-mode .kt-card {
  background: rgba(255,255,255,0.8); border-color: rgba(0,0,0,0.06);
  box-shadow: 0 2px 16px rgba(0,0,0,0.04); backdrop-filter: none;
}
body.light-mode .kt-card:hover {
  box-shadow: 0 12px 40px rgba(0,0,0,0.08); border-color: rgba(250,0,143,0.2);
}
body.light-mode .kt-card--highlight { background: rgba(255,255,255,0.8); }
body.light-mode .kt-email-btn { background: rgba(250,0,143,0.05); border-color: rgba(250,0,143,0.12); }
body.light-mode .kt-form-section { background: linear-gradient(180deg, var(--bg2), #f8f8f8); }
body.light-mode .kt-form-glass {
  background: rgba(255,255,255,0.7); border-color: rgba(0,0,0,0.08);
  backdrop-filter: none;
}
body.light-mode .kt-faq-item { border-color: rgba(0,0,0,0.08); }
body.light-mode .kt-faq-item[open] { background: rgba(250,0,143,0.02); border-color: rgba(250,0,143,0.15); }
body.light-mode .kt-map { border-color: rgba(0,0,0,0.1); }
body.light-mode .kt-tag { color: #C70073; } /* spec: tylko kolor, bez obsolete background/border */
body.light-mode .kt-hero-blob1 { background: radial-gradient(circle, rgba(250,0,143,0.06), transparent 65%); }
body.light-mode .kt-hero-blob2 { background: radial-gradient(circle, rgba(150,24,255,0.04), transparent 65%); }
body.light-mode .kt-sub,
body.light-mode .kt-form-sub,
body.light-mode .kt-card-desc,
body.light-mode .kt-faq-a { color: #555; }
body.light-mode .kt-h1 { color: #111; }
body.light-mode .kt-card-name { color: #111; }
body.light-mode .kt-bottom-h2 { color: #111; }
body.light-mode .kt-form-h2 { color: #111; }
body.light-mode .kt-faq-q { color: #222; }

/* ── Responsive ── */
@media (max-width: 1024px) {
  .kt-bottom-grid { grid-template-columns: 1fr; gap: 48px; }
}
@media (max-width: 900px) {
  .kt-dept-cards { grid-template-columns: 1fr; max-width: 400px; }
}
@media (max-width: 768px) {
  .kt-hero { padding: calc(var(--nav-height) + 40px) 20px 48px; min-height: auto; }
  .kt-dept-cards { grid-template-columns: 1fr; max-width: 340px; }
  .kt-card { width: 100%; }
  .kt-form-section { padding: 60px 0; }
  .kt-form-glass { padding: 32px 24px; border-radius: 16px; }
  .kt-bottom-section { padding: 60px 0; }
  .kt-map iframe { height: 280px; }
  .kt-hero-blob1 { width: 300px; height: 300px; top: -60px; right: -60px; }
  .kt-hero-blob2 { width: 250px; height: 250px; }
  .kt-sub br, .kt-form-sub br { display: none; }
  .kt-card, .kt-form-glass { backdrop-filter: none; }
}
@media (max-width: 480px) {
  .kt-form-glass { padding: 24px 20px; }
  .kt-h1 { font-size: 2rem; }
  .kt-sub { font-size: 0.88rem; }
}
@media (prefers-reduced-motion: reduce) {
  /* Kontakt page */
  .kt-hero-blob1, .kt-hero-blob2 { animation: none; }
  .kt-card { transition: none; }
  .kt-faq-q::after { transition: none; }
  .kt-faq-item { transition: none; }
  .kt-email-btn { transition: none; }
  .kt-email-addr { transition: none; }
  .kt-faq-q { transition: none; }

  /* Front page — ticker */
  .ticker-track { animation: none; }

  /* Front page — fade-up elements */
  .fade-up { animation: none; opacity: 1; transform: none; transition: none; }

  /* Front page — hero blobs */
  .hero-blob { animation: none; transition: none; }

  /* Front page — section blobs */
  .section-blob-pink { animation: none; transition: none; }

  /* Global — all cards, buttons, links transitions */
  .service-card, .project-card, .artist-card, .concert-item { transition: none; opacity: 1; transform: none; }
  .btn, .filter-btn, .nav-link { transition: none; }
  .nl-input, .nl-checkmark { transition: none; }
}

/* ── Focus-visible (keyboard navigation) ── */
.kt-email-btn:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.kt-faq-q:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: -2px;
}
.kt-faq-a a:focus-visible,
.kt-email-addr:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
.form-submit:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}


/* ============================================================
   [A2 FIX] Card gradient variants — zastępują inline styles
   Użycie: class="card--grad-1" zamiast style="background:..."
   ============================================================ */
.card--grad-1 { background: linear-gradient(135deg, #0d0812, #2a0a30); }
.card--grad-2 { background: linear-gradient(160deg, #0a1628, #1a0a30); }
.card--grad-3 { background: linear-gradient(135deg, #0d0a1e, #2d1060); }
.card--grad-4 { background: linear-gradient(160deg, #1a0820, #3a0840); }
.card--grad-5 { background: linear-gradient(160deg, #0a1628, #1a2848); }
.card--grad-6 { background: linear-gradient(160deg, #120820, #280a40); }
.card--grad-7 { background: linear-gradient(160deg, #1a1000, #3a2800); }
.card--grad-8 { background: linear-gradient(160deg, #001a10, #003828); }
.card--grad-9 { background: linear-gradient(160deg, #1a0010, #3a0028); }
.eve-btn--sidebar-sold-out{width:100%;justify-content:center;background:var(--surface,#111411);border:1px solid var(--border,rgba(255,255,255,.08));color:var(--muted,rgba(240,240,236,.46));padding:12px 16px;font-size:11px;cursor:not-allowed;opacity:.7;display:flex;align-items:center;font-family:var(--font-ui,'Barlow',sans-serif);font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-radius:4px}.eve-breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:4px 6px;font-size:11px;font-family:var(--font-ui,'Barlow',sans-serif);font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--muted,rgba(240,240,236,.46));margin-top:80px;margin-bottom:20px}.eve-breadcrumb a{color:var(--muted,rgba(240,240,236,.46));text-decoration:none}.eve-breadcrumb a:hover{color:var(--text,#F0F0EC)}.eve-breadcrumb__sep{color:var(--muted,rgba(240,240,236,.46));opacity:.5}.eve-breadcrumb__current{color:var(--text,#F0F0EC)}
/* ── Light-mode fixes: event page ── */
body.light-mode .eve-poster__archive-badge { color: #fff; }
body.light-mode .eve-poster__placeholder-hint { color: var(--text-faint); }
body.light-mode .eve-pill { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.1); color: var(--text); }
body.light-mode .eve-pill__label { color: var(--text-muted); }
body.light-mode .eve-pill__value { color: var(--text); }
body.light-mode .eve-section-overline { color: var(--text-muted); }
body.light-mode .eve-info-card { background: #fff; border-color: rgba(0,0,0,0.08); }
body.light-mode .eve-info-card__header { color: var(--text-muted); }
body.light-mode .eve-srow__label { color: var(--text-muted); }
body.light-mode .eve-srow__value { color: var(--text); }
body.light-mode .eve-srow__map-link { color: var(--pink); }
body.light-mode .eve-breadcrumb { color: var(--text-muted); }
body.light-mode .eve-breadcrumb a { color: var(--text-muted); }
body.light-mode .eve-breadcrumb a:hover { color: var(--text); }
body.light-mode .eve-breadcrumb__current { color: var(--text); }
body.light-mode .eve-btn--fb { color: var(--text); border-color: rgba(0,0,0,0.15); }
body.light-mode .eve-btn--fb:hover { background: rgba(0,0,0,0.05); }
body.light-mode .eve-article__body { color: var(--text); }

/* ── Eve Poster Lightbox ── */
.eve-poster--lightbox { cursor: zoom-in; }
.eve-poster--lightbox:focus-visible { outline: 2px solid var(--pink); outline-offset: 3px; }
#eve-lightbox-overlay {
  display: flex; align-items: center; justify-content: center;
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.85);
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease;
}
#eve-lightbox-overlay.is-open { opacity: 1; pointer-events: all; }
.eve-lightbox__img-wrap { max-width: 90vw; max-height: 90vh; }
.eve-lightbox__img { display: block; max-width: 100%; max-height: 90vh; object-fit: contain; border-radius: 8px; box-shadow: 0 24px 80px rgba(0,0,0,.6); }
.eve-lightbox__close {
  position: absolute; top: 16px; right: 20px;
  background: none; border: none; cursor: pointer;
  color: #fff; font-size: 36px; line-height: 1;
  padding: 4px 10px; border-radius: 4px;
  transition: background .15s;
}
.eve-lightbox__close:hover { background: rgba(255,255,255,.15); }
.eve-lightbox__close:focus-visible { outline: 2px solid var(--pink); }

/* eve-srow__note — dopisek do ceny (JSON-LD / opis) */
.eve-srow__note { display:block; font-size:.75rem; color:var(--muted); margin-top:.2rem; }
body.light-mode .eve-srow__note { color:rgba(17,17,17,.46); }

/* Theme toggle — ukryj CSS ::before gdy SVG wstrzykniete */
.theme-toggle:has(svg)::before { display: none; }
.theme-toggle svg { display: block; width: 20px; height: 20px; pointer-events: none; }


/* ── Eve Gallery ── */
.eve-gallery {
  padding: 60px 0;
  border-top: 1px solid var(--border);
}
.eve-gallery__header {
  margin-bottom: 32px;
}
.eve-gallery__title {
  font-size: 1.1rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0;
}
.eve-gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.eve-gallery__item {
  display: block;
  overflow: hidden;
  border-radius: 8px;
  aspect-ratio: 1;
  background: var(--surface2);
}
.eve-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease, opacity .3s ease;
}
.eve-gallery__item:hover img,
.eve-gallery__item:focus-visible img {
  transform: scale(1.04);
  opacity: .9;
}
.eve-gallery__item:focus-visible {
  outline: 2px solid var(--pink);
  outline-offset: 2px;
}
@media (max-width: 600px) {
  .eve-gallery__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}


/* ── Eve Lightbox — nawigacja galerii ── */
#eve-lightbox-overlay {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.92);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
}
#eve-lightbox-overlay.is-open {
  opacity: 1;
  pointer-events: all;
}
.eve-lightbox__img-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 90vw;
  max-height: 90vh;
}
.eve-lightbox__img {
  display: block;
  max-width: 100%;
  max-height: 82vh;
  object-fit: contain;
  border-radius: 6px;
  box-shadow: 0 24px 80px rgba(0,0,0,.6);
}
.eve-lightbox__caption {
  margin: 10px 0 0;
  color: rgba(255,255,255,.6);
  font-size: .8rem;
  text-align: center;
}
.eve-lightbox__close {
  position: absolute;
  top: 16px;
  right: 20px;
  background: none;
  border: none;
  cursor: pointer;
  color: #fff;
  font-size: 36px;
  line-height: 1;
  padding: 4px 10px;
  border-radius: 4px;
  transition: background .15s;
  z-index: 1;
}
.eve-lightbox__close:hover { background: rgba(255,255,255,.15); }
.eve-lightbox__close:focus-visible { outline: 2px solid var(--pink); }

.eve-lightbox__prev,
.eve-lightbox__next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  font-size: 42px;
  line-height: 1;
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  transition: background .15s;
  z-index: 1;
  user-select: none;
}
.eve-lightbox__prev { left: 20px; }
.eve-lightbox__next { right: 20px; }
.eve-lightbox__prev:hover,
.eve-lightbox__next:hover { background: rgba(255,255,255,.25); }
.eve-lightbox__prev:focus-visible,
.eve-lightbox__next:focus-visible { outline: 2px solid var(--pink); }

@media (max-width: 600px) {
  .eve-lightbox__prev { left: 8px; padding: 6px 12px; font-size: 32px; }
  .eve-lightbox__next { right: 8px; padding: 6px 12px; font-size: 32px; }
}

/* âââââââââââââââââââââââââââââââââââââââââââââââ
   ARCHIWUM KONCERTOW
   âââââââââââââââââââââââââââââââââââââââââââââââ */

/* Hero */
.arc-main { padding-bottom: 80px; }

.arc-hero { padding: 48px 0 40px; }
.arc-hero__tag {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--pink);
    margin-bottom: 12px;
}
.arc-hero__tag::before { content: '\2014 '; }
.arc-hero__title {
    font-size: clamp(2rem, 5vw, 3.25rem);
    font-weight: 700;
    line-height: 1.1;
    margin: 0 0 14px;
    color: var(--text);
}
.arc-hero__desc {
    font-size: 1rem;
    color: var(--muted);
    max-width: 560px;
    margin: 0;
}

/* Controls */
.arc-controls {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    margin-bottom: 28px;
}

.arc-search-wrap {
    position: relative;
    flex: 1;
    min-width: 220px;
    max-width: 420px;
}
.arc-search-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: var(--muted);
    pointer-events: none;
    display: flex;
    align-items: center;
}
.arc-search-input {
    width: 100%;
    padding: 10px 14px 10px 40px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--text);
    font-size: .95rem;
    font-family: inherit;
    outline: none;
    transition: border-color .2s;
    box-sizing: border-box;
}
.arc-search-input::placeholder { color: var(--muted); }
.arc-search-input:focus { border-color: var(--pink); }

.arc-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
.arc-count {
    font-size: .85rem;
    color: var(--muted);
}
.arc-count strong { color: var(--text); }

.arc-clear-btn {
    background: none;
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 6px 12px;
    font-size: .8rem;
    color: var(--muted);
    cursor: pointer;
    font-family: inherit;
    transition: color .15s, border-color .15s;
}
.arc-clear-btn:hover { color: var(--text); border-color: var(--pink); }

/* Grid */
.arc-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 40px;
}

@media (max-width: 900px) {
    .arc-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
    .arc-grid { grid-template-columns: 1fr; }
}

/* Card */
.arc-card {
    display: block;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    text-decoration: none;
    transition: border-color .2s, transform .2s, box-shadow .2s;
    position: relative;
    overflow: hidden;
}
.arc-card:hover {
    border-color: rgba(249,0,142,.35);
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(0,0,0,.35);
}
.arc-card:focus-visible {
    outline: 2px solid var(--pink);
    outline-offset: 2px;
}

.arc-card-inner {
    padding: 20px 22px 18px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    height: 100%;
    box-sizing: border-box;
}

.arc-card-label {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--pink);
}

.arc-card-artist {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text);
    margin: 0;
    line-height: 1.2;
}

.arc-card-venue {
    font-size: .85rem;
    color: var(--muted);
    line-height: 1.3;
}

.arc-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: 12px;
}

.arc-card-city {
    font-size: .75rem;
    color: var(--muted);
    background: var(--surface2, rgba(255,255,255,.05));
    padding: 3px 8px;
    border-radius: 4px;
    border: 1px solid var(--border);
}

.arc-card-link {
    font-size: .8rem;
    color: var(--pink);
    font-weight: 600;
    letter-spacing: .02em;
}

/* Empty state */
.arc-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 64px 20px;
    color: var(--muted);
}
.arc-empty-icon { font-size: 2.5rem; margin-bottom: 16px; }
.arc-empty-title { font-size: 1.1rem; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.arc-empty-sub { font-size: .9rem; }

/* Paginacja */
.arc-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
    padding-top: 8px;
}
.arc-pag-info {
    font-size: .8rem;
    color: var(--muted);
    flex-shrink: 0;
}
.arc-pag-pages {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
}
.arc-pag-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 6px;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    font-size: .85rem;
    font-family: inherit;
    text-decoration: none;
    cursor: pointer;
    transition: border-color .15s, background .15s, color .15s;
}
.arc-pag-btn:hover { border-color: var(--pink); color: var(--pink); }
.arc-pag-btn.is-active {
    background: var(--pink);
    border-color: var(--pink);
    color: #fff;
    font-weight: 700;
    cursor: default;
}
.arc-pag-btn.is-disabled {
    opacity: .35;
    pointer-events: none;
    cursor: default;
}
.arc-pag-ellipsis {
    color: var(--muted);
    padding: 0 4px;
    font-size: .85rem;
    line-height: 34px;
}

.arc-per-page {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.arc-per-page label {
    font-size: .8rem;
    color: var(--muted);
}
.arc-per-page select {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text);
    font-family: inherit;
    font-size: .8rem;
    padding: 5px 28px 5px 10px;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(240,240,236,.4)'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    outline: none;
}
.arc-per-page select:focus { border-color: var(--pink); }

/* Light mode overrides */
body.light-mode .arc-card { background: var(--surface); }
body.light-mode .arc-card:hover { box-shadow: 0 8px 32px rgba(0,0,0,.12); }
body.light-mode .arc-card-city { background: rgba(0,0,0,.04); }
body.light-mode .arc-per-page select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(17,17,17,.4)'/%3E%3C/svg%3E");
}

@media (max-width: 600px) {
    .arc-hero { padding: 32px 0 24px; }
    .arc-controls { gap: 10px; }
    .arc-search-wrap { max-width: 100%; }
    .arc-pagination { justify-content: center; }
    .arc-pag-info { width: 100%; text-align: center; }
    .arc-per-page { width: 100%; justify-content: center; }
}

/* Breadcrumb fix na stronie archiwum */
.arc-hero .breadcrumb ol {
    list-style: none;
    padding: 0;
    margin: 0 0 20px;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.arc-hero .breadcrumb li {
    font-size: .8rem;
    color: var(--muted);
}
.arc-hero .breadcrumb li + li::before {
    content: '\203a';
    margin-right: 6px;
    color: var(--muted);
}
.arc-hero .breadcrumb a {
    color: var(--muted);
    text-decoration: none;
}
.arc-hero .breadcrumb a:hover { color: var(--pink); }
.arc-hero .breadcrumb [aria-current="page"] { color: var(--text); }

.mobile-theme-label{font-family:var(--font-body);font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);transition:color .3s,font-weight .2s;min-width:44px;text-align:center;user-select:none}body:not(.light-mode) .mobile-theme-label--dark,body.light-mode .mobile-theme-label--light{color:var(--pink);font-weight:600}#theme-toggle-mobile{min-width:52px;min-height:32px;cursor:pointer}#mobile-nav{overflow-y:auto;max-height:calc(100vh - var(--nav-height) - 16px);padding-bottom:8px}#mobile-nav li a{padding:10px 16px!important}

.filter-strip-inner{-webkit-mask-image:linear-gradient(to right,black 80%,transparent 100%);mask-image:linear-gradient(to right,black 80%,transparent 100%)}.filter-strip-inner.scrolled{-webkit-mask-image:linear-gradient(to right,transparent 0%,black 8%,black 80%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 8%,black 80%,transparent 100%)}.filter-strip-inner.at-end{-webkit-mask-image:linear-gradient(to right,transparent 0%,black 8%,black 100%);mask-image:linear-gradient(to right,transparent 0%,black 8%,black 100%)}.filter-strip-inner.no-scroll{-webkit-mask-image:none;mask-image:none}
@media (max-width:600px){.filter-strip-inner{flex-direction:column;align-items:stretch;gap:8px}.filters-group{width:100%;min-width:0}.filter-strip-inner{-webkit-mask-image:none;mask-image:none}.filters-group{-webkit-mask-image:linear-gradient(to right,black 82%,transparent 100%);mask-image:linear-gradient(to right,black 82%,transparent 100%)}.filters-group.at-end{-webkit-mask-image:linear-gradient(to left,black 82%,transparent 100%);mask-image:linear-gradient(to left,black 82%,transparent 100%)}.filters-group.scrolled:not(.at-end){-webkit-mask-image:linear-gradient(to right,transparent 0%,black 6%,black 82%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,black 6%,black 82%,transparent 100%)}.filters-group.no-scroll{-webkit-mask-image:none;mask-image:none}}
@media (max-width:480px){.artyci-hero{padding-left:16px;padding-right:16px}.hero-title{font-size:clamp(2.4rem,9vw,2.8rem)!important}}
.artist-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:55%;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.3) 60%,transparent 100%);pointer-events:none;z-index:1}.artist-info{z-index:2}.artist-name{color:#fff!important;font-weight:400;text-shadow:0 1px 4px rgba(0,0,0,.5)}body.light-mode .artist-card::after{background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.35) 60%,transparent 100%)}
.artist-name{font-size:.72rem!important;font-weight:400!important;letter-spacing:.12em;text-transform:uppercase;opacity:.85}
.artist-placeholder{text-align:center} /* lang-toggle dropdown na mobile (<=900px) */@media(max-width:900px){.lang-sep{display:none}.lang-toggle .lang-btn:not(.active){display:none}.lang-btn.active{display:flex;align-items:center;gap:3px;padding:4px 6px;border:1px solid var(--border);border-radius:var(--radius-sm,6px);font-size:.75rem;font-weight:500;cursor:pointer;background:transparent;color:var(--text)}.nav-right .lang-toggle{flex:1;justify-content:center}.lang-btn.active::after{content:"\25BE";font-size:.7rem;margin-left:2px;opacity:.7}.lang-toggle{position:relative;display:flex}.lang-toggle.open .lang-btn:not(.active){display:flex;position:absolute;top:calc(100% + 6px);right:0;align-items:center;gap:4px;padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius-sm,6px);font-size:.85rem;background:var(--bg-card,var(--bg));color:var(--text);white-space:nowrap;z-index:200;box-shadow:0 4px 12px rgba(0,0,0,.15)}}@media(max-width:480px){.lang-toggle{display:flex}}