/* ============================================================
   TÜCHLER AUSBAU — Portal Pracowniczy
   css/style.css
   ============================================================ */

:root {
  --red:     #E8001C;
  --red-dark:#B0001A;
  --black:   #0A0A0A;
  --dark:    #141414;
  --dark2:   #1E1E1E;
  --dark3:   #2A2A2A;
  --white:   #F5F5F5;
  --gray:    #888888;
  --light:   #CCCCCC;
  --yellow:  #FFD600;
  --nav-h:   64px;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background:var(--black);
  color:var(--white);
  font-family:'Barlow',sans-serif;
  overflow-x:hidden;
  min-height:100vh;
}
img { max-width:100%; display:block; }
a { color:inherit; }

/* ── NOISE ── */
body::before {
  content:'';
  position:fixed; inset:0;
  background-image: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.04'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:9999;
  opacity:0.35;
}

/* ── NAV ── */
#main-nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 40px; height:var(--nav-h);
  background:rgba(10,10,10,0.93);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(232,0,28,0.18);
  transition:box-shadow .3s;
}
.nav-logo {
  font-family:'Barlow Condensed',sans-serif;
  font-size:22px; font-weight:900; letter-spacing:1px;
  text-decoration:none; color:var(--white);
  display:flex; align-items:center; gap:8px;
}
.nav-logo::before { content:'▲'; color:var(--red); font-size:12px; }
.nav-logo span { color:var(--red); }
.nav-links { display:flex; gap:28px; list-style:none; }
.nav-links a {
  color:var(--gray); text-decoration:none;
  font-size:12px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase;
  transition:color .2s; position:relative; padding-bottom:2px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:1px; background:var(--red); transform:scaleX(0);
  transition:transform .2s;
}
.nav-links a:hover, .nav-links a.active { color:var(--white); }
.nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }
.nav-badge {
  background:var(--red); color:#fff;
  font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  padding:6px 16px;
  clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%);
}
.mobile-menu-btn {
  display:none; background:none; border:none;
  color:var(--white); font-size:22px; cursor:pointer;
}

/* ── MOBILE OVERLAY ── */
.mobile-overlay {
  position:fixed; inset:0; z-index:300;
  background:#0a0a0a;
  display:none; flex-direction:column; justify-content:center;
  padding:60px 40px;
}
.mobile-overlay.open { display:flex; }
.mobile-close {
  position:absolute; top:24px; right:24px;
  background:none; border:none; color:var(--white);
  font-size:28px; cursor:pointer;
}
.mobile-links { list-style:none; }
.mobile-links li { border-bottom:1px solid rgba(255,255,255,0.06); }
.mobile-links li a {
  display:block; padding:18px 0;
  font-family:'Barlow Condensed',sans-serif;
  font-size:32px; font-weight:800; text-transform:uppercase; text-decoration:none;
  color:var(--white); letter-spacing:-0.5px;
  transition:color .15s;
}
.mobile-links li a:hover { color:var(--red); }
.mobile-sep { height:24px; border-bottom:none!important; }

/* ── BUTTONS ── */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--red); color:#fff;
  font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  text-decoration:none; padding:16px 32px;
  clip-path:polygon(12px 0%,100% 0%,calc(100% - 12px) 100%,0% 100%);
  transition:background .2s, transform .2s;
  border:none; cursor:pointer;
}
.btn-primary:hover { background:var(--red-dark); transform:translateX(4px); }
.btn-secondary {
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid rgba(255,255,255,0.2); color:var(--white);
  font-size:12px; font-weight:600; letter-spacing:2px; text-transform:uppercase;
  text-decoration:none; padding:16px 32px;
  transition:border-color .2s, color .2s;
  background:none; cursor:pointer;
}
.btn-secondary:hover { border-color:var(--red); color:var(--red); }
.btn-white {
  display:inline-flex; align-items:center; gap:12px;
  background:#fff; color:var(--red);
  font-size:13px; font-weight:800; letter-spacing:2px; text-transform:uppercase;
  text-decoration:none; padding:18px 36px; white-space:nowrap;
  clip-path:polygon(12px 0%,100% 0%,calc(100% - 12px) 100%,0% 100%);
  transition:transform .2s;
}
.btn-white:hover { transform:scale(1.03); }

/* ── SECTION BASICS ── */
section { padding:100px 40px; }
.section-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:60px; flex-wrap:wrap; gap:20px;
}
.section-tag {
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  color:var(--red); margin-bottom:10px;
  display:flex; align-items:center; gap:10px;
}
.section-tag::before { content:''; width:20px; height:2px; background:var(--red); }
.section-title {
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(36px,4vw,56px); font-weight:900;
  text-transform:uppercase; line-height:1; letter-spacing:-1px;
}

/* ── HERO (index) ── */
.hero {
  min-height:100vh; display:grid; grid-template-columns:1fr 1fr;
  align-items:center; padding:calc(var(--nav-h) + 60px) 40px 80px;
  position:relative; overflow:hidden;
}
.hero::after {
  content:''; position:absolute; top:-200px; right:-200px;
  width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle,rgba(232,0,28,.14) 0%,transparent 70%);
  pointer-events:none;
}
.hero-content { position:relative; z-index:1; }
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  color:var(--red); margin-bottom:24px;
}
.hero-eyebrow::before { content:''; width:32px; height:2px; background:var(--red); }
.hero-title {
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(64px,8vw,110px); font-weight:900;
  line-height:.92; letter-spacing:-2px; text-transform:uppercase; margin-bottom:32px;
}
.hero-title em  { font-style:normal; color:var(--red); display:block; }
.hero-title .outline { -webkit-text-stroke:2px var(--white); color:transparent; }
.hero-sub { font-size:16px; color:var(--light); line-height:1.7; max-width:440px; margin-bottom:48px; }
.hero-cta-row { display:flex; gap:16px; flex-wrap:wrap; }
.hero-right {
  display:flex; flex-direction:column; gap:0;
  padding-left:60px; border-left:1px solid rgba(255,255,255,0.06);
}
.stat-block { padding:28px 0; border-bottom:1px solid rgba(255,255,255,0.06); }
.stat-block:last-child { border-bottom:none; }
.stat-label { font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:var(--gray); margin-bottom:6px; }
.stat-value { font-family:'Barlow Condensed',sans-serif; font-size:52px; font-weight:900; line-height:1; letter-spacing:-1px; }
.stat-value .unit { font-size:22px; color:var(--red); vertical-align:top; margin-top:6px; }
.stat-note { font-size:13px; color:var(--gray); margin-top:4px; }

/* ── TICKER ── */
.ticker { background:var(--red); padding:13px 0; overflow:hidden; white-space:nowrap; }
.ticker-inner { display:inline-flex; animation:ticker 34s linear infinite; }
.ticker-item { font-family:'Barlow Condensed',sans-serif; font-size:14px; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:0 36px; color:#fff; }
.ticker-item::after { content:'◆'; margin-left:36px; opacity:.45; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── NEWS GRID ── */
.news-grid { display:grid; grid-template-columns:2fr 1fr 1fr; grid-template-rows:auto auto; gap:2px; }
.news-card {
  background:var(--dark2); padding:36px; position:relative;
  overflow:hidden; cursor:pointer; transition:background .2s;
  text-decoration:none; color:inherit; display:block;
}
.news-card:hover { background:var(--dark3); }
.news-card.featured {
  grid-row:span 2; display:flex; flex-direction:column; justify-content:flex-end;
  min-height:520px; padding:48px;
  background:linear-gradient(160deg,#1a0005 0%,var(--dark2) 100%);
}
.news-card.featured::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--red); }
.news-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:.15;
  transition:opacity .3s;
}
.news-card:hover .news-bg { opacity:.22; }
.news-tag {
  display:inline-block; background:var(--red); color:#fff;
  font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  padding:4px 12px; margin-bottom:14px; position:relative; z-index:1;
}
.news-date { font-size:10px; letter-spacing:1px; color:var(--gray); margin-bottom:10px; position:relative; z-index:1; }
.news-title {
  font-family:'Barlow Condensed',sans-serif; font-weight:800;
  text-transform:uppercase; line-height:1.05; position:relative; z-index:1;
}
.news-card.featured .news-title { font-size:36px; margin-bottom:16px; }
.news-card:not(.featured) .news-title { font-size:20px; margin-bottom:8px; }
.news-excerpt { font-size:13px; color:var(--light); line-height:1.6; position:relative; z-index:1; }
.news-arrow {
  position:absolute; bottom:36px; right:36px;
  width:40px; height:40px; border:1px solid rgba(255,255,255,0.15);
  display:flex; align-items:center; justify-content:center; font-size:18px;
  transition:background .2s, border-color .2s; z-index:1;
}
.news-card:hover .news-arrow { background:var(--red); border-color:var(--red); }

/* ── WAGES ── */
.wages-layout { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.wages-intro p { font-size:15px; color:var(--light); line-height:1.7; margin-bottom:20px; }
.update-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,214,0,.1); border:1px solid rgba(255,214,0,.3);
  color:var(--yellow); font-size:11px; font-weight:600; letter-spacing:1px;
  padding:8px 16px; margin-bottom:28px;
}
.update-badge::before { content:'★'; }
.wage-table { width:100%; border-collapse:collapse; }
.wage-table tr { border-bottom:1px solid rgba(255,255,255,0.06); transition:background .15s; }
.wage-table tr:hover { background:rgba(232,0,28,.05); }
.wage-table td { padding:18px 14px; font-size:14px; }
.wage-table td:first-child { color:var(--light); }
.wage-table td:last-child { text-align:right; font-family:'Barlow Condensed',sans-serif; font-size:26px; font-weight:800; }
.wage-table td:last-child .eur { font-size:13px; color:var(--red); margin-left:4px; }
.wage-table .highlight td { background:rgba(232,0,28,.08); }
.wage-table .highlight td:first-child { color:var(--white); font-weight:600; }
.wage-update-note { margin-top:18px; padding:16px 20px; background:rgba(232,0,28,.06); border-left:3px solid var(--red); font-size:13px; color:var(--gray); line-height:1.6; }
.wages-full { max-width:1200px; margin:0 auto; }

/* ── SCHEDULE ── */
.schedule-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:2px; margin-bottom:2px; }
.day-card { background:var(--dark2); padding:28px 16px; text-align:center; }
.day-card.active { background:var(--red); }
.day-card.off { background:var(--dark2); opacity:.4; }
.day-name { font-family:'Barlow Condensed',sans-serif; font-size:10px; font-weight:700; letter-spacing:3px; text-transform:uppercase; margin-bottom:12px; color:rgba(255,255,255,.65); }
.day-hours { font-family:'Barlow Condensed',sans-serif; font-size:24px; font-weight:900; line-height:1.2; }
.day-label { font-size:11px; margin-top:8px; color:rgba(255,255,255,.5); }
.day-card.active .day-name, .day-card.active .day-label { color:rgba(255,255,255,.8); }
.schedule-info-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }

/* ── INFO BLOCKS ── */
.info-block { background:var(--dark2); padding:32px; }
.info-block-icon { font-size:26px; margin-bottom:14px; }
.info-block-title { font-family:'Barlow Condensed',sans-serif; font-size:20px; font-weight:800; text-transform:uppercase; margin-bottom:8px; }
.info-block-text { font-size:14px; color:var(--gray); line-height:1.6; }
.info-block-highlight { font-family:'Barlow Condensed',sans-serif; font-size:36px; font-weight:900; color:var(--red); line-height:1; margin-bottom:6px; }
.info-cards-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }

/* ── QUICK LINKS ── */
.links-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.link-card {
  background:var(--dark2); padding:36px 28px;
  text-decoration:none; color:inherit; display:block; position:relative;
  overflow:hidden; transition:background .2s; border-bottom:3px solid transparent;
}
.link-card:hover { background:var(--dark3); border-bottom-color:var(--red); }
.link-icon { font-size:30px; margin-bottom:18px; display:block; }
.link-badge {
  position:absolute; top:20px; right:20px;
  background:rgba(232,0,28,.15); border:1px solid rgba(232,0,28,.4);
  color:var(--red); font-size:9px; font-weight:700; letter-spacing:1.5px;
  text-transform:uppercase; padding:3px 8px;
}
.link-title { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:800; text-transform:uppercase; margin-bottom:8px; }
.link-desc { font-size:13px; color:var(--gray); line-height:1.5; }
.link-arrow { position:absolute; bottom:28px; right:28px; color:var(--red); font-size:20px; opacity:0; transition:opacity .2s, transform .2s; }
.link-card:hover .link-arrow { opacity:1; transform:translateX(4px); }

/* ── KV BANNER ── */
.kv-inner { display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.kv-eyebrow { font-size:11px; letter-spacing:3px; text-transform:uppercase; opacity:.75; margin-bottom:10px; }
.kv-title { font-family:'Barlow Condensed',sans-serif; font-size:52px; font-weight:900; text-transform:uppercase; line-height:1; letter-spacing:-1px; }
.kv-sub { font-size:16px; opacity:.85; margin-top:12px; max-width:440px; }

/* ── BETRIEBSRAT ── */
.br-grid { display:grid; grid-template-columns:1fr 2fr; gap:60px; align-items:center; }
.br-number { font-family:'Barlow Condensed',sans-serif; font-size:140px; font-weight:900; line-height:1; -webkit-text-stroke:2px rgba(232,0,28,.4); color:transparent; letter-spacing:-4px; }
.br-title { font-family:'Barlow Condensed',sans-serif; font-size:42px; font-weight:900; text-transform:uppercase; line-height:1.05; margin-bottom:20px; }
.br-text { font-size:15px; color:var(--light); line-height:1.7; margin-bottom:28px; }
.br-topics { display:flex; flex-wrap:wrap; gap:8px; }
.br-topic { background:rgba(232,0,28,.12); border:1px solid rgba(232,0,28,.3); color:var(--red); font-size:11px; font-weight:600; letter-spacing:1px; text-transform:uppercase; padding:6px 14px; }

/* ── PAGE HERO (podstrony) ── */
.page-hero {
  padding:calc(var(--nav-h) + 60px) 40px 80px;
  background:var(--dark);
  border-bottom:1px solid rgba(255,255,255,0.04);
  position:relative; overflow:hidden;
}
.page-hero::after {
  content:''; position:absolute; top:-300px; right:-200px;
  width:600px; height:600px; border-radius:50%;
  background:radial-gradient(circle,rgba(232,0,28,.1) 0%,transparent 70%);
  pointer-events:none;
}
.page-hero-inner { position:relative; z-index:1; }
.page-title { font-family:'Barlow Condensed',sans-serif; font-size:clamp(52px,6vw,90px); font-weight:900; text-transform:uppercase; line-height:.95; letter-spacing:-2px; margin-bottom:20px; }
.page-sub { font-size:16px; color:var(--light); max-width:540px; line-height:1.7; }

/* ── GALERIA ── */
.gallery-filters { display:flex; flex-wrap:wrap; gap:8px; }
.gallery-filter { background:var(--dark2); border:1px solid rgba(255,255,255,0.08); color:var(--gray); font-size:11px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; padding:8px 18px; cursor:pointer; transition:all .2s; }
.gallery-filter.active, .gallery-filter:hover { background:var(--red); border-color:var(--red); color:#fff; }
.photo-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:4px; }
.photo-item { position:relative; aspect-ratio:4/3; overflow:hidden; display:block; cursor:pointer; }
.photo-item img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.photo-item:hover img { transform:scale(1.06); }
.photo-placeholder { width:100%; height:100%; background:var(--dark2); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; color:var(--gray); }
.photo-placeholder span { font-size:40px; }
.photo-placeholder small { font-size:11px; letter-spacing:1px; }
.photo-overlay { position:absolute; inset:0; background:rgba(232,0,28,.7); display:flex; align-items:center; justify-content:center; font-size:28px; opacity:0; transition:opacity .2s; }
.photo-item:hover .photo-overlay { opacity:1; }
/* Lightbox */
.lightbox { position:fixed; inset:0; z-index:500; background:rgba(0,0,0,.95); display:none; align-items:center; justify-content:center; }
.lightbox.open { display:flex; }
.lightbox-img-wrap { max-width:90vw; max-height:90vh; }
.lightbox-img-wrap img { max-width:100%; max-height:90vh; object-fit:contain; }
.lightbox-close, .lightbox-prev, .lightbox-next { position:absolute; background:none; border:1px solid rgba(255,255,255,.2); color:#fff; font-size:24px; cursor:pointer; padding:12px 18px; transition:background .2s; }
.lightbox-close { top:20px; right:20px; }
.lightbox-prev { left:20px; top:50%; transform:translateY(-50%); }
.lightbox-next { right:20px; top:50%; transform:translateY(-50%); }
.lightbox-close:hover, .lightbox-prev:hover, .lightbox-next:hover { background:var(--red); border-color:var(--red); }

/* ── MONTAŻE ── */
.montage-card { background:var(--dark2); padding:36px; transition:background .2s; }
.montage-card:hover { background:var(--dark3); }
.montage-header { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:16px; }
.montage-title { font-family:'Barlow Condensed',sans-serif; font-size:32px; font-weight:900; text-transform:uppercase; line-height:1; }
.montage-location { font-size:13px; color:var(--gray); margin-top:6px; }
.montage-status { font-size:13px; font-weight:700; letter-spacing:1px; text-transform:uppercase; }
.montage-meta { display:flex; flex-wrap:wrap; gap:24px; font-size:13px; color:var(--gray); }

/* ── PDF LINKS ── */
.pdf-link {
  display:flex; align-items:center; gap:16px;
  background:var(--dark2); padding:20px 24px;
  text-decoration:none; color:inherit;
  border-left:3px solid transparent; transition:all .2s;
}
.pdf-link:hover { background:var(--dark3); border-left-color:var(--red); }
.pdf-icon { font-size:24px; flex-shrink:0; }
.pdf-link div { flex:1; }
.pdf-link div strong { font-size:15px; display:block; margin-bottom:2px; }
.pdf-link div small { font-size:12px; color:var(--gray); }
.pdf-dl { font-family:'Barlow Condensed',sans-serif; font-size:18px; font-weight:800; color:var(--red); flex-shrink:0; }

/* ── FAQ ── */
.faq-list { display:flex; flex-direction:column; }
.faq-item { border-bottom:1px solid rgba(255,255,255,0.06); }
.faq-q {
  width:100%; display:flex; justify-content:space-between; align-items:center;
  padding:20px 0; background:none; border:none; color:var(--white);
  font-family:'Barlow',sans-serif; font-size:15px; font-weight:500;
  text-align:left; cursor:pointer; transition:color .2s; gap:16px;
}
.faq-q:hover { color:var(--red); }
.faq-icon { font-size:20px; color:var(--red); flex-shrink:0; transition:transform .25s; }
.faq-q.open .faq-icon { transform:rotate(45deg); }
.faq-a { display:none; padding:0 0 20px; }
.faq-a.open { display:block; }
.faq-a p { font-size:14px; color:var(--light); line-height:1.7; }

/* ── FOOTER ── */
footer { background:#050505; padding:60px 40px; border-top:1px solid rgba(255,255,255,0.04); }
.footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; margin-bottom:48px; }
.footer-brand .logo { font-family:'Barlow Condensed',sans-serif; font-size:26px; font-weight:900; letter-spacing:1px; margin-bottom:14px; display:flex; align-items:center; gap:8px; }
.footer-brand .logo span { color:var(--red); }
.footer-brand p { font-size:13px; color:var(--gray); line-height:1.7; max-width:260px; }
.footer-col h4 { font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:var(--gray); margin-bottom:18px; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { color:var(--light); text-decoration:none; font-size:13px; transition:color .2s; }
.footer-col ul li a:hover { color:var(--red); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; padding-top:24px; border-top:1px solid rgba(255,255,255,0.05); flex-wrap:wrap; gap:12px; }
.footer-bottom p { font-size:11px; color:var(--gray); letter-spacing:.5px; }
.footer-bottom a { color:var(--red); text-decoration:none; }

/* ── ANIMATIONS ── */
.fade-in { opacity:0; transform:translateY(20px); transition:opacity .65s ease, transform .65s ease; }
.fade-in.visible { opacity:1; transform:translateY(0); }
.fade-in:nth-child(2){transition-delay:.1s}
.fade-in:nth-child(3){transition-delay:.2s}
.fade-in:nth-child(4){transition-delay:.3s}

/* ── RESPONSIVE ── */
@media (max-width:1200px) {
  .links-grid { grid-template-columns:repeat(3,1fr); }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media (max-width:1024px) {
  .hero { grid-template-columns:1fr; }
  .hero-right { display:none; }
  .news-grid { grid-template-columns:1fr; }
  .news-card.featured { grid-row:span 1; min-height:300px; }
  .wages-layout { grid-template-columns:1fr; }
  .br-grid { grid-template-columns:1fr; }
  .br-number { font-size:80px; }
  .schedule-info-grid { grid-template-columns:1fr; }
  .info-cards-3 { grid-template-columns:1fr; }
}
@media (max-width:768px) {
  #main-nav { padding:0 20px; }
  .nav-links, .nav-badge { display:none; }
  .mobile-menu-btn { display:block; }
  section { padding:60px 20px; }
  .hero { padding:calc(var(--nav-h) + 40px) 20px 60px; }
  .page-hero { padding:calc(var(--nav-h) + 40px) 20px 60px; }
  .schedule-grid { grid-template-columns:repeat(5,1fr); }
  .links-grid { grid-template-columns:1fr 1fr; }
  .kv-inner { flex-direction:column; }
  .kv-title { font-size:38px; }
  .footer-inner { grid-template-columns:1fr; gap:32px; }
  footer { padding:40px 20px; }
  #kv { padding:60px 20px; }
  .montage-header { flex-direction:column; }
  .news-grid { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .links-grid { grid-template-columns:1fr; }
  .schedule-grid { grid-template-columns:repeat(5,1fr); }
  .day-hours { font-size:14px; }
  .day-name { font-size:8px; letter-spacing:1px; }
  .hero-title { font-size:clamp(48px,12vw,90px); }
}

/* ── LANGUAGE SWITCHER ── */
.lang-switcher {
  display:flex; gap:4px; align-items:center;
}
.lang-btn {
  display:inline-flex; align-items:center; gap:5px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  color:var(--gray); text-decoration:none;
  font-size:11px; font-weight:700; letter-spacing:1px;
  padding:5px 10px; transition:all .2s; white-space:nowrap;
}
.lang-btn:hover { background:rgba(232,0,28,.15); border-color:rgba(232,0,28,.4); color:var(--white); }
.lang-btn.active { background:var(--red); border-color:var(--red); color:#fff; }
.lang-code { font-size:10px; }
.flag { font-size:14px; }

/* Mobile lang */
.mobile-lang {
  display:flex; gap:8px; margin-bottom:32px;
}
.mobile-lang .lang-btn { font-size:14px; padding:10px 16px; }

/* ── LIGHTBOX COUNTER ── */
.lightbox-counter {
  position:absolute; bottom:20px; left:50%;
  transform:translateX(-50%);
  font-family:'Barlow Condensed',sans-serif;
  font-size:16px; font-weight:700; letter-spacing:2px;
  color:rgba(255,255,255,0.5);
}

/* ── GALLERY AUTO-SCAN PLACEHOLDER ── */
.gallery-empty {
  padding:60px 40px; background:var(--dark2);
  text-align:center; color:var(--gray);
}

/* ════════════════════════════════════════════════════════════
   KOLLEKTIVVERTRAG PAGE
   ════════════════════════════════════════════════════════════ */

/* TOC BAR */
.kv-toc-bar {
  position:sticky; top:70px; z-index:90;
  background:rgba(10,10,10,0.97);
  border-bottom:1px solid rgba(232,0,28,0.3);
  backdrop-filter:blur(10px);
}
.kv-toc-inner {
  max-width:1200px; margin:0 auto;
  padding:0 40px;
  display:flex; align-items:center; gap:4px;
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.kv-toc-inner::-webkit-scrollbar { display:none; }
.kv-toc-label {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  color:var(--gray); white-space:nowrap; margin-right:8px;
  padding:14px 0;
}
.kv-toc-inner a {
  font-size:11px; font-weight:700; letter-spacing:1px;
  text-transform:uppercase; color:var(--gray);
  text-decoration:none; white-space:nowrap;
  padding:14px 12px; border-bottom:2px solid transparent;
  transition:all .2s;
}
.kv-toc-inner a:hover { color:var(--white); border-bottom-color:var(--red); }

/* PAGE */
.kv-page {
  background:var(--black);
}

/* SECTION */
.kv-section {
  max-width:1100px; margin:0 auto;
  padding:64px 40px;
  border-bottom:1px solid rgba(255,255,255,0.05);
}
.kv-section:last-child { border-bottom:none; }

.kv-section-head {
  display:flex; align-items:flex-start; gap:32px;
  margin-bottom:40px;
}
.kv-par {
  font-family:'Barlow Condensed',sans-serif;
  font-size:48px; font-weight:900;
  color:rgba(232,0,28,0.15); line-height:1;
  white-space:nowrap; min-width:80px;
  padding-top:4px;
}
.kv-section-tag {
  font-size:10px; letter-spacing:3px;
  text-transform:uppercase; color:var(--red);
  margin-bottom:8px;
}
.kv-section-title {
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(28px,3vw,42px);
  font-weight:900; text-transform:uppercase;
  line-height:1.1; margin:0;
}

/* EXPLAIN BOX */
.kv-explain {
  padding:20px 24px;
  border-left:4px solid;
  margin-bottom:32px;
  font-size:15px; line-height:1.7;
  border-radius:0 4px 4px 0;
}
.kv-explain-green { border-color:#22c55e; background:rgba(34,197,94,0.06); }
.kv-explain-blue  { border-color:#3b82f6; background:rgba(59,130,246,0.06); }
.kv-explain-red   { border-color:var(--red); background:rgba(232,0,28,0.06); }

/* TABLE */
.kv-table-wrap { overflow-x:auto; margin-bottom:24px; }
.kv-table {
  width:100%; border-collapse:collapse;
  font-size:14px;
}
.kv-table thead tr {
  background:rgba(255,255,255,0.03);
  border-bottom:1px solid rgba(232,0,28,0.3);
}
.kv-table th {
  padding:14px 16px;
  text-align:left; font-size:10px;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--gray); font-weight:700;
}
.kv-table td {
  padding:16px 16px;
  border-bottom:1px solid rgba(255,255,255,0.04);
  vertical-align:middle; line-height:1.5;
}
.kv-table tr:hover td { background:rgba(255,255,255,0.02); }
.kv-table tr.kv-highlight td { background:rgba(232,0,28,0.06); }
.kv-table tr.kv-highlight td:first-child {
  border-left:3px solid var(--red);
}
.kv-rate {
  font-family:'Barlow Condensed',sans-serif;
  font-size:24px; font-weight:900;
  white-space:nowrap;
}
.kv-rate.kv-green { color:#22c55e; }
.kv-month {
  font-family:'Barlow Condensed',sans-serif;
  font-size:16px; font-weight:700;
  color:var(--gray); white-space:nowrap;
}
.kv-footnote { font-size:13px; color:var(--gray); margin-top:12px; }

/* CARDS */
.kv-cards-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:16px; margin-bottom:24px;
}
.kv-card {
  background:var(--dark2);
  border:1px solid rgba(255,255,255,0.06);
  padding:24px;
  transition:border-color .2s;
}
.kv-card:hover { border-color:rgba(232,0,28,0.3); }
.kv-card.kv-card-highlight {
  border-color:rgba(232,0,28,0.3);
  background:rgba(232,0,28,0.05);
}
.kv-card.kv-card-urgent {
  border-color:rgba(255,170,0,0.3);
  background:rgba(255,170,0,0.04);
}
.kv-card-icon { font-size:28px; margin-bottom:12px; }
.kv-card-title {
  font-family:'Barlow Condensed',sans-serif;
  font-size:18px; font-weight:800;
  text-transform:uppercase; margin-bottom:8px;
}
.kv-card-bignum {
  font-family:'Barlow Condensed',sans-serif;
  font-size:36px; font-weight:900;
  color:var(--red); line-height:1;
  margin-bottom:8px;
}
.kv-card-text { font-size:13px; color:var(--gray); line-height:1.6; }

/* NOTE BOX */
.kv-note-box {
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  padding:24px 28px; margin-top:24px;
}
.kv-note-box ul { margin:0; padding-left:20px; }
.kv-note-box li { font-size:14px; color:var(--light); margin-bottom:10px; line-height:1.6; }
.kv-note-box li:last-child { margin-bottom:0; }
.kv-note-box strong { color:var(--white); }

/* ZULAGEN GRID */
.kv-extra-zulagen { margin-top:40px; }
.kv-extra-zulagen h3 {
  font-family:'Barlow Condensed',sans-serif;
  font-size:22px; font-weight:800; text-transform:uppercase;
  margin-bottom:20px; color:var(--white);
}
.kv-zulage-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:12px; margin-bottom:16px;
}
.kv-zulage-card {
  background:var(--dark);
  border:1px solid rgba(255,255,255,0.06);
  padding:20px;
}
.kv-zulage-pct {
  font-family:'Barlow Condensed',sans-serif;
  font-size:32px; font-weight:900; color:var(--red);
  line-height:1; margin-bottom:6px;
}
.kv-zulage-name {
  font-size:13px; font-weight:700;
  color:var(--white); margin-bottom:8px;
}
.kv-zulage-desc { font-size:12px; color:var(--gray); line-height:1.5; }
.kv-zulage-rule { font-size:13px; color:var(--gray); }

/* HELP BANNER */
.kv-help-banner {
  display:flex; gap:24px; align-items:flex-start;
  background:rgba(232,0,28,0.08);
  border:1px solid rgba(232,0,28,0.25);
  padding:32px; margin-top:40px;
}
.kv-help-icon { font-size:40px; flex-shrink:0; }
.kv-help-title {
  font-family:'Barlow Condensed',sans-serif;
  font-size:22px; font-weight:800;
  text-transform:uppercase; margin-bottom:8px;
}
.kv-help-text { font-size:14px; color:var(--gray); line-height:1.6; }

/* RESPONSIVE */
@media (max-width:768px) {
  .kv-section { padding:48px 20px; }
  .kv-section-head { gap:16px; }
  .kv-par { font-size:32px; min-width:56px; }
  .kv-cards-grid { grid-template-columns:1fr; }
  .kv-help-banner { flex-direction:column; gap:16px; }
  .kv-toc-inner { padding:0 16px; }
}
