/* ══════════════════════════════════════════════
   GRIZZLIES GORZÓW WLKP. — style.css
   Wersja: 2026.04.23-v4 (Zaktualizowane tło)
   ══════════════════════════════════════════════ */

/* ── RESET & ZMIENNE ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --yellow:      #FFCC00;
  --yellow-dark: #CCA300;
  --black:       #000000;
  --black2:      #0a0a0a;
  --black3:      #111111;
  --gray:        #1e1e1e;
  --white:       #ffffff;
  --off-white:   #f2f2f2;
  --nav-h:       64px;
  --fd: 'Bebas Neue', sans-serif;
  --fc: 'Barlow Condensed', sans-serif;
  --fb: 'Barlow', sans-serif;
  --ease: cubic-bezier(0.19, 1, 0.22, 1);

  /* Globalne marginesy boczne — zwiększone, aby odsunąć zawartość od krawędzi */
  --gutter:    6vw;    /* desktop - responsywne odsuwanie */
  --gutter-md: 4vw;    /* tablet  */
  --gutter-sm: 24px;   /* mobile  */

  /* Odstęp wewnętrzny sekcji (góra/dół) — zwiększony dla lepszego oddechu */
  --section-py: 5vh; 
}

html, body {
  width: 100%; height: 100%; overflow: hidden;
  background: var(--black);
  font-family: var(--fb);
  font-weight: 300;
  color: var(--off-white);
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
img, video { display: block; max-width: 100%; }

/* ── SCROLL WRAPPER ── */
#app {
  position: fixed; inset: 0;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
}
#app::-webkit-scrollbar { width: 3px; }
#app::-webkit-scrollbar-thumb { background: var(--yellow-dark); border-radius: 2px; }

section {
  scroll-snap-align: start;
  scroll-snap-stop: always;
  width: 100%; height: 100vh;
  max-height: 100vh;
  overflow: hidden;
  position: relative;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
}

/* ══════════════════════════════════════
   NAVBAR
══════════════════════════════════════ */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 9999;
  height: var(--nav-h);
  background: rgba(0,0,0,0.88);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,204,0,.1);
}
.nav-wrap {
  max-width: 1440px; margin: 0 auto; height: 100%;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--gutter);
}
.logo {
  font-family: var(--fc); font-size: 1.35rem; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  display: flex; align-items: center; gap: 10px; white-space: nowrap;
}
.logo-bear { color: var(--yellow); font-size: 1.5rem; }
.logo em { color: var(--yellow); font-style: normal; }

.nav-ul { display: flex; list-style: none; gap: 36px; }
.nav-ul a {
  font-family: var(--fc); font-size: .88rem; font-weight: 600;
  letter-spacing: 2px; text-transform: uppercase;
  color: rgba(255,255,255,.65);
  position: relative; transition: color .25s;
}
.nav-ul a::after {
  content: ''; position: absolute; bottom: -4px; left: 0;
  height: 2px; width: 0; background: var(--yellow);
  transition: width .3s var(--ease);
}
.nav-ul a:hover { color: #fff; }
.nav-ul a:hover::after { width: 100%; }

/* Burger */
#burger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 6px;
}
#burger span { display: block; width: 24px; height: 2px; background: #fff; transition: .3s; }
#burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
#burger.open span:nth-child(2) { opacity: 0; }
#burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile dropdown */
#mob-menu {
  display: none;
  position: fixed; top: var(--nav-h); left: 0; right: 0; z-index: 9998;
  background: rgba(0,0,0,.97); backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,204,0,.15);
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: .3s ease;
  padding: 10px var(--gutter-sm);
}
#mob-menu.open { opacity: 1; visibility: visible; transform: none; }
#mob-menu a {
  display: block; padding: 16px 22px;
  font-family: var(--fc); font-size: 1.15rem; letter-spacing: 3px;
  text-transform: uppercase; color: rgba(255,255,255,.8);
  border-bottom: 1px solid rgba(255,255,255,.05);
  transition: color .2s, background .2s;
}
#mob-menu a:hover { color: var(--yellow); background: rgba(255,204,0,.04); }

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
@keyframes slideUp { from { opacity:0; transform:translateY(36px); } to { opacity:1; transform:none; } }
@keyframes inRight { from { transform:translateX(100%); } to { transform:none; } }
@keyframes inLeft  { from { transform:translateX(-100%) scaleX(-1); } to { transform:scaleX(-1); } }

/* Zmienione tło na zdjęcie z serwera z gradientem */
#hero { 
  background-video: 
    linear-gradient(rgba(0, 0, 0, 0.4), rgba(0, 0, 0, 0.8)), 
    url('https://grizzliesgorzow.pl/image/w1.mp4');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.hero-vid {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; z-index: 0; opacity: .3; pointer-events: none;
}
.hero-side {
  position: absolute; top: 0; height: 100%; width: 22vw;
  object-fit: cover; z-index: 1; pointer-events: none;
}
.hero-side.r { right: 0; animation: inRight 1.4s var(--ease) .2s both; }
.hero-side.l { left: 0; transform: scaleX(-1); animation: inLeft 1.4s var(--ease) .2s both; }

.hero-body {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  padding: 0 var(--gutter);
  max-width: 880px;
  margin-top: var(--nav-h);
  opacity: 0; animation: slideUp 1.2s var(--ease) .4s forwards;
}
.eyebrow {
  font-family: var(--fc); font-size: clamp(.8rem,1.5vw,1rem);
  letter-spacing: 6px; color: var(--yellow); text-transform: uppercase;
  font-weight: 600; margin-bottom: 14px;
}
h1.display {
  font-family: var(--fd); text-transform: uppercase; line-height: .85;
  text-shadow: 0 6px 24px rgba(0,0,0,.7);
}
h1.display .l1 { display: block; font-size: clamp(2.4rem,6vw,6.5rem); color: #fff; }
h1.display .l2 { display: block; font-size: clamp(3.2rem,9vw,9.5rem); color: var(--yellow); }

.hero-sub {
  margin-top: 18px; max-width: 540px; line-height: 1.6;
  font-size: clamp(.85rem,1.4vw,1.1rem); color: rgba(255,255,255,.7);
}
.cta-row {
  display: flex; gap: 12px; flex-wrap: wrap; justify-content: center;
  margin-top: 28px;
}
.btn {
  font-family: var(--fc); font-size: .92rem; font-weight: 700;
  letter-spacing: 2px; text-transform: uppercase;
  padding: 13px 26px; border-radius: 4px; cursor: pointer;
  border: 2px solid transparent; transition: .3s ease; display: inline-block;
}
.btn-y { background: var(--yellow); color: var(--black); }
.btn-y:hover { background: #fff; box-shadow: 0 0 20px rgba(255,204,0,.4); transform: translateY(-2px); }
.btn-g { border-color: rgba(255,255,255,.3); color: #fff; }
.btn-g:hover { border-color: var(--yellow); color: var(--yellow); transform: translateY(-2px); }

/* ══════════════════════════════════════
   O NAS
══════════════════════════════════════ */
#about { background: var(--black); }
.about-wrap {
  width: 100%; max-width: 1300px; height: 100%;
  display: flex; align-items: center; gap: 48px;
  padding: calc(var(--nav-h) + var(--section-py)) var(--gutter) var(--section-py);
}

/* Carousel */
.car-wrap {
  flex: 0 0 44%; position: relative; height: 68%;
  display: flex; align-items: center; justify-content: center;
}
.car-slide {
  position: absolute; width: 68%; height: 90%;
  object-fit: cover; border-radius: 10px;
  transition: all .5s cubic-bezier(.25,1,.5,1);
  box-shadow: 0 10px 28px rgba(0,0,0,.6);
  cursor: pointer;
}
.car-slide.active { z-index: 3; opacity: 1; filter: none; transform: none; }
.car-slide.prev   { z-index: 1; opacity: .3; filter: blur(4px); transform: translateX(-40%) scale(.82); }
.car-slide.next   { z-index: 1; opacity: .3; filter: blur(4px); transform: translateX(40%) scale(.82); }

.car-btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(0,0,0,.6); border: 1px solid rgba(255,204,0,.5);
  color: var(--yellow); font-size: .9rem; cursor: pointer; z-index: 10;
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(4px); transition: .3s;
}
.car-btn:hover { background: var(--yellow); color: var(--black); }
.car-btn.p { left: 0; }
.car-btn.n { right: 0; }

/* Tekst */
.about-text { flex: 1; max-width: 520px; }
.tag {
  font-family: var(--fc); font-size: .82rem; font-weight: 700;
  letter-spacing: 4px; color: var(--yellow); text-transform: uppercase;
  display: block; margin-bottom: 8px;
}
h2.sec {
  font-family: var(--fd); font-size: clamp(2rem,3.5vw,3.2rem);
  color: #fff; line-height: 1; margin-bottom: 14px;
}
h2.sec em { font-style: normal; color: var(--yellow); }
.body-p {
  font-size: clamp(.88rem,1vw,1.02rem); line-height: 1.65;
  color: rgba(255,255,255,.68); margin-bottom: 12px;
}
.body-p strong { color: #fff; font-weight: 500; }
.stats {
  display: flex; gap: 22px; flex-wrap: wrap;
  margin-top: 22px; padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.09);
}
.stat-n { font-family: var(--fd); font-size: clamp(1.5rem,2.4vw,2.1rem); color: var(--yellow); line-height: 1; }
.stat-l { font-family: var(--fc); font-size: .72rem; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.4); font-weight: 600; }

/* ══════════════════════════════════════
   SKŁAD
══════════════════════════════════════ */
#roster { background: var(--black2); border-top: 1px solid rgba(255,255,255,.04); }
.roster-wrap {
  width: 100%; max-width: 960px; height: 100%;
  display: flex; flex-direction: column;
  padding: calc(var(--nav-h) + var(--section-py)) var(--gutter) var(--section-py);
}
.sec-head { text-align: center; margin-bottom: 12px; flex-shrink: 0; }
.sec-sub { margin-top: 5px; font-size: .88rem; color: rgba(255,255,255,.38); }

/* Panel gracza */
.panel {
  flex-shrink: 0; background: var(--black3);
  border: 1px solid rgba(255,204,0,.2); border-left: 4px solid var(--yellow);
  border-radius: 8px; overflow: hidden;
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows .35s ease, margin-bottom .35s ease;
  margin-bottom: 0;
}
.panel.open { grid-template-rows: 1fr; margin-bottom: 16px; }
.panel > div { overflow: hidden; }
.panel-body { padding: 14px 18px; display: flex; flex-direction: column; gap: 5px; }
.panel-body h3 { font-family: var(--fd); font-size: 1.55rem; color: #fff; }
.panel-body h3 span { color: var(--yellow); }
.p-pos { font-family: var(--fc); font-size: .78rem; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.4); }
.p-desc { font-size: .88rem; line-height: 1.5; color: rgba(255,255,255,.72); }
.p-meta {
  display: flex; gap: 12px; flex-wrap: wrap;
  font-family: var(--fc); font-size: .8rem; letter-spacing: 1px; color: var(--yellow);
  padding-top: 9px; border-top: 1px solid rgba(255,255,255,.07);
}

/* Tabela */
.tbl-wrap {
  flex: 1; min-height: 0; display: flex; flex-direction: column;
  background: var(--black); border-radius: 8px;
  border: 1px solid rgba(255,255,255,.05); overflow: hidden;
}
.tbl-head {
  display: flex; padding: 10px 18px; flex-shrink: 0;
  background: rgba(255,255,255,.02); border-bottom: 1px solid rgba(255,255,255,.05);
  font-family: var(--fc); font-size: .78rem; letter-spacing: 2px;
  text-transform: uppercase; color: rgba(255,255,255,.35);
}
.c-n { width: 44px; }
.c-name { flex: 1; }
.c-pos { width: 80px; }
.c-arr { width: 24px; text-align: right; }

.tbl-body { overflow-y: auto; flex: 1; }
.tbl-body::-webkit-scrollbar { width: 3px; }
.tbl-body::-webkit-scrollbar-thumb { background: var(--yellow-dark); }

.row-wrap { border-bottom: 1px solid rgba(255,255,255,.05); }
.row {
  display: flex; align-items: center; padding: 13px 18px;
  cursor: pointer; transition: background .2s;
}
.row-wrap:hover .row,
.row-wrap.sel .row { background: rgba(255,204,0,.05); }

.cell { font-size: .93rem; color: rgba(255,255,255,.78); }
.cell.num { font-family: var(--fd); font-size: 1.35rem; color: var(--yellow); width: 44px; }
.cell.name { flex: 1; font-weight: 500; color: #fff; transition: color .2s; }
.row-wrap:hover .cell.name,
.row-wrap.sel .cell.name { color: var(--yellow); }
.cell.pos { width: 80px; }
.badge {
  display: inline-block; font-family: var(--fc); font-size: .72rem; font-weight: 700;
  letter-spacing: 1px; padding: 3px 8px; border-radius: 4px;
  text-transform: uppercase; background: var(--gray);
  color: #fff; border: 1px solid rgba(255,255,255,.08);
}
.cell.arr {
  width: 24px; text-align: right; font-size: .85rem;
  color: rgba(255,255,255,.2); transition: transform .3s, color .2s;
}
.row-wrap:hover .cell.arr { color: var(--yellow); }
.row-wrap.sel .cell.arr { transform: rotate(180deg); color: var(--yellow); }

/* ══════════════════════════════════════
   KONTAKT
══════════════════════════════════════ */
#contact { background: var(--black); }
.contact-wrap {
  width: 100%; max-width: 1300px; height: 100%;
  display: flex; flex-direction: column; justify-content: center;
  padding: calc(var(--nav-h) + var(--section-py)) var(--gutter) var(--section-py);
  gap: 24px;
}
.contact-head { text-align: center; }
.cards { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.card {
  background: var(--black2); border: 1px solid rgba(255,255,255,.06);
  padding: 24px 16px; border-radius: 8px; text-align: center;
  display: flex; flex-direction: column; align-items: center;
  transition: .3s;
}
.card:hover { border-color: var(--yellow); transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,.5); }
.card-icon { font-size: 1.5rem; margin-bottom: 8px; }
.card-lbl { font-family: var(--fc); font-size: .78rem; letter-spacing: 2px; text-transform: uppercase; color: var(--yellow); margin-bottom: 5px; font-weight: 700; }
.card-val { font-size: .85rem; color: rgba(255,255,255,.62); line-height: 1.4; }

.map-area {
  flex: 1; min-height: 0; border-radius: 8px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.05); position: relative;
}
.map-area svg { width: 100%; height: 100%; display: block; background: var(--black2); }
.map-cap {
  position: absolute; bottom: 0; left: 0; right: 0; padding: 12px;
  background: rgba(0,0,0,.92); font-family: var(--fc); font-size: .83rem;
  letter-spacing: 1px; color: rgba(255,255,255,.4); text-align: center;
}
.map-cap a { color: var(--yellow); font-weight: 600; }

.footer {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px; flex-shrink: 0;
  padding-top: 16px; border-top: 1px solid rgba(255,255,255,.07);
}
.footer p { font-size: .76rem; color: rgba(255,255,255,.3); }
.footer .tag-f { font-family: var(--fc); letter-spacing: 2px; text-transform: uppercase; color: var(--yellow) !important; font-weight: 600; }

/* ══════════════════════════════════════
   RESPONSIVE — TABLET (≤1024px)
══════════════════════════════════════ */
@media (max-width: 1024px) {
  :root { --gutter: var(--gutter-md); }

  .hero-side { width: 26vw; }
  .about-wrap { flex-direction: column; gap: 20px; }
  .car-wrap { flex: 0 0 auto; width: 100%; height: 36vh; }
  .car-slide { width: 58%; height: 95%; }
  .about-text { max-width: 100%; text-align: center; }
  .stats { justify-content: center; }
  .cards { grid-template-columns: repeat(2,1fr); }
}

/* ══════════════════════════════════════
   RESPONSIVE — MOBILE (≤768px)
══════════════════════════════════════ */
@media (max-width: 768px) {
  :root {
    --nav-h: 56px;
    --gutter: var(--gutter-sm);
    --section-py: 24px;
  }

  .nav-ul { display: none; }
  #burger { display: flex; }
  #mob-menu { display: block; }
  .hero-side { display: none; }
  .hero-vid { opacity: .22; }
  .cta-row { flex-direction: column; align-items: center; }
  .btn { width: min(270px,80vw); text-align: center; }
  .about-wrap { flex-direction: column; gap: 14px; }
  .car-wrap { height: 28vh; width: 100%; }
  .car-slide.prev, .car-slide.next { opacity: 0; pointer-events: none; }
  .car-slide.active { width: 82%; height: 100%; }
  .about-text { text-align: center; }
  .stats { justify-content: center; gap: 18px; margin-top: 14px; padding-top: 14px; }
  .c-pos, .cell.pos { display: none; }
  .row { padding: 11px 12px; }
  .cards { gap: 12px; }
  .card { padding: 16px 10px; }
  .footer { flex-direction: column; text-align: center; }
  h2.sec { font-size: 1.85rem; }
}

@media (max-width: 420px) {
  .cards { grid-template-columns: 1fr; } 
}