/* ============================================================
   Kręć kilometry dla Gdańska 2026 - styl strony
   Wszystkie kolory, fonty, promienie i cienie z foundation.css
   (design system Activy). Mobile first.
   ============================================================ */

html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body {
  margin: 0;
  background: var(--activy-white);
  font-family: var(--activy-font-body);
  color: var(--activy-text);
  font-size: var(--activy-body);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
h1, h2, h3, h4 {
  font-family: var(--activy-font-display);
  color: var(--activy-text-dark);
  letter-spacing: -.01em;
  line-height: 1.15;
  font-weight: 600;
  margin: 0;
  text-wrap: balance;
}
p { margin: 0; text-wrap: pretty; }
a { color: inherit; }

.container { width: min(1160px, 100% - 40px); margin-inline: auto; }

/* ---------- przyciski ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border-radius: var(--activy-r-8);
  padding: 12px 24px 10px;
  font-family: var(--activy-font-body); font-weight: 500; font-size: 1rem;
  border: 1px solid transparent; cursor: pointer; text-decoration: none;
  transition: background .2s, color .2s, border-color .2s, transform .2s, box-shadow .2s;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--activy-green); color: var(--activy-white); }
.btn-primary:hover { background: var(--activy-green-hover); }
.btn-orange { background: var(--activy-orange); color: var(--activy-white); }
.btn-orange:hover { background: oklch(from var(--activy-orange) calc(l - 0.07) c h); }
.btn-ghost { background: transparent; color: var(--activy-white); border-color: rgba(255,255,255,.45); }
.btn-ghost:hover { background: rgba(255,255,255,.12); }

.store-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.store-buttons img { height: 48px; width: auto; transition: transform .2s, filter .2s; }
.store-buttons a:hover img { transform: translateY(-2px); filter: drop-shadow(0 6px 14px rgba(0,0,0,.25)); }

/* pływające ikony dekoracyjne (puste przestrzenie sekcji) */
.float-deco {
  position: absolute; z-index: 2; display: none;
  width: 56px; height: 56px; border-radius: 50%;
  place-items: center;
  background: var(--activy-white); box-shadow: var(--activy-shadow-card);
  animation: bob 7.5s ease-in-out infinite;
  transition: transform .3s;
}
.float-deco svg { width: 28px; height: 28px; }
.float-deco:hover { transform: rotate(-8deg) scale(1.15); }
.float-deco.small { width: 44px; height: 44px; }
.float-deco.small svg { width: 22px; height: 22px; }

.start-right { position: relative; }
.fd-sun { top: 6px; right: -4px; animation-delay: .6s; }
.integrations .container { position: relative; }
.fd-watch { top: -6px; right: 80px; animation-delay: 1s; }
.fd-zap { top: 96px; right: 190px; animation-delay: 2.4s; }
.stats-layout { position: relative; }
.fd-medal { left: 56px; bottom: -6px; animation-delay: 1.4s; display: none !important; }
.fd-plane { top: 16px; right: 60px; animation-delay: .8s; }

@media (min-width: 880px) {
  .float-deco { display: grid; }
}
@media (min-width: 1060px) {
  .fd-medal { display: grid !important; }
}

/* ---------- nagłówki sekcji ---------- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  width: fit-content;
  background: var(--activy-green-light); color: var(--activy-green-hover);
  font-size: 13px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  padding: 6px 14px; border-radius: var(--activy-r-pill);
}
.section-head { display: grid; gap: 14px; max-width: 640px; margin-bottom: 40px; }
.section-head h2 { font-size: clamp(1.75rem, 4.5vw, var(--activy-h2)); }
.section-head .lead { font-size: 1.05rem; }

/* ============================================================
   NAWIGACJA
   ============================================================ */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  background: rgba(255,255,255,.82);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .25s, box-shadow .25s;
}
.nav.scrolled { border-color: var(--activy-border-light); box-shadow: 0 4px 24px rgba(0,0,0,.06); }
.nav-inner { display: flex; align-items: center; gap: 16px; height: 68px; }
.nav-logo img { height: 26px; width: auto; }
.nav-links { display: none; }
.nav-actions { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.btn-results { padding: 9px 18px 8px; font-size: .92rem; }

/* przełącznik miast */
.city-switch {
  display: inline-flex; align-items: center; gap: 2px;
  background: var(--activy-bg); border-radius: var(--activy-r-pill); padding: 3px;
}
.city-switch a {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 12px; border-radius: var(--activy-r-pill);
  font-size: .85rem; font-weight: 600; text-decoration: none;
  color: var(--activy-neutral); transition: background .2s, color .2s, box-shadow .2s;
}
.city-switch img { height: 22px; width: 22px; object-fit: contain; }
.city-switch .active {
  background: var(--activy-white); color: var(--activy-text-dark);
  box-shadow: var(--activy-shadow-chip);
}
.city-switch a:not(.active):hover { color: var(--activy-text-dark); }
.city-switch .label { display: none; }

/* menu mobilne */
.nav-burger {
  display: grid; place-items: center; width: 42px; height: 42px;
  border: none; background: var(--activy-bg); border-radius: var(--activy-r-8); cursor: pointer;
}
.nav-burger svg { width: 20px; height: 20px; stroke: var(--activy-text-dark); }
.nav-sheet {
  display: grid; gap: 4px; padding: 8px 20px 18px;
  border-top: 1px solid var(--activy-border-light);
  background: rgba(255,255,255,.95);
}
.nav-sheet[hidden] { display: none; }
.nav-sheet a {
  padding: 12px 14px; border-radius: var(--activy-r-12);
  font-weight: 500; color: var(--activy-text-dark); text-decoration: none;
}
.nav-sheet a:hover { background: var(--activy-green-light); }

@media (min-width: 880px) {
  .nav-links {
    display: flex; gap: 6px; margin-inline: auto;
  }
  .nav-links a {
    padding: 8px 16px; border-radius: var(--activy-r-pill);
    font-size: .95rem; font-weight: 500; color: var(--activy-text-dark);
    text-decoration: none; transition: background .2s, color .2s;
  }
  .nav-links a:hover { background: var(--activy-green-light); color: var(--activy-green-hover); }
  .nav-actions { margin-left: 0; }
  .nav-burger, .nav-sheet { display: none; }
  .city-switch .label { display: inline; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; overflow: clip;
  background: var(--activy-green);
  background-image:
    radial-gradient(720px 420px at 12% -10%, rgba(255,255,255,.16), transparent 65%),
    radial-gradient(900px 540px at 95% 110%, rgba(4,38,18,.30), transparent 60%);
  padding: 128px 0 150px;
  color: var(--activy-white);
}
.hero-blob {
  position: absolute; border-radius: 50%; pointer-events: none;
  background: rgba(255,255,255,.10); filter: blur(2px);
}
.hero-blob.b1 { width: 340px; height: 340px; top: -120px; right: -90px; animation: drift 14s ease-in-out infinite alternate; }
.hero-blob.b2 { width: 220px; height: 220px; bottom: 60px; left: -110px; background: rgba(4,38,18,.14); animation: drift 18s ease-in-out infinite alternate-reverse; }
@keyframes drift { from { transform: translate(0,0) scale(1); } to { transform: translate(26px, 18px) scale(1.06); } }

.hero-grid { position: relative; display: grid; gap: 48px; align-items: center; }
.hero-dates {
  display: inline-flex; align-items: center; gap: 10px; width: fit-content;
  background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.28);
  border-radius: var(--activy-r-pill); padding: 8px 18px;
  font-weight: 600; font-size: .92rem; letter-spacing: .08em; text-transform: uppercase;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
}
.hero-dates .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--activy-white); animation: pulse 2.4s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .45; transform: scale(.7); } }

.hero h1 {
  color: var(--activy-white);
  font-size: clamp(2.5rem, 7.5vw, 4.6rem);
  line-height: 1.06; letter-spacing: -.02em;
  margin: 22px 0 18px;
}
.hero h1 .hl { color: var(--activy-green-dark); }
.hero-lead { font-size: 1.1rem; line-height: 1.55; max-width: 460px; color: rgba(255,255,255,.92); margin-bottom: 32px; }

/* notka: zapisy firm — wyróżniony baner u góry hero */
.hero-note {
  display: inline-flex; align-items: center; gap: 14px; width: fit-content;
  margin: 0 0 22px;
  background: var(--activy-orange); border: 2px solid rgba(255,255,255,.6);
  border-radius: var(--activy-r-pill); padding: 13px 28px 13px 13px;
  font-size: clamp(1.05rem, 2.4vw, 1.35rem); font-weight: 700; line-height: 1.2;
  color: var(--activy-white);
  box-shadow: 0 12px 34px rgba(255,134,0,.4);
  animation: noteGlow 2.6s ease-in-out infinite;
}
.hero-note strong { font-weight: 800; }
.hero-note .hn-disc {
  width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
  background: var(--activy-white); display: grid; place-items: center;
}
.hero-note .hn-disc svg { width: 25px; height: 25px; }
@keyframes noteGlow {
  0%,100% { box-shadow: 0 12px 34px rgba(255,134,0,.4); }
  50%     { box-shadow: 0 12px 44px rgba(255,134,0,.7); }
}

/* karta herbu */
.crest-wrap { position: relative; justify-self: center; padding: 96px 0; }
.crest-card {
  position: relative; z-index: 2;
  background: var(--activy-white); border-radius: var(--activy-r-24);
  box-shadow: var(--activy-shadow-float);
  padding: 30px 38px 22px; text-align: center;
  width: min(320px, 78vw);
  transition: transform .3s;
  animation: bob 6s ease-in-out infinite;
}
@keyframes bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
.crest-card .over {
  font-family: var(--activy-font-display); font-weight: 600;
  font-size: .8rem; letter-spacing: .22em; color: var(--activy-neutral);
  text-transform: uppercase; margin-bottom: 6px;
}
.crest-card img { width: 100%; height: auto; }

/* pływające plakietki */
.float-chip {
  position: absolute; z-index: 3;
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--activy-white); color: var(--activy-text-dark);
  border-radius: var(--activy-r-pill); padding: 9px 16px 9px 10px;
  font-size: .85rem; font-weight: 600;
  box-shadow: var(--activy-shadow-card);
  animation: bob 7s ease-in-out infinite;
  white-space: nowrap;
}
.float-chip .disc {
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center; flex-shrink: 0;
}
.float-chip .disc svg { width: 16px; height: 16px; }
/* chipy nad i pod kartą, nigdy na herbie */
.float-chip.fc1 { top: 4px; left: -24px; animation-delay: .8s; }
.float-chip.fc2 { top: 48px; right: -32px; animation-delay: 1.6s; }
.float-chip.fc3 { bottom: 48px; left: -32px; animation-delay: 2.4s; }
.float-chip.fc4 { bottom: 4px; right: -24px; animation-delay: 3.2s; }
.float-chip .green { background: var(--activy-green-light); }
.float-chip .orange { background: var(--activy-orange-light); }
.float-chip .blue { background: var(--activy-blue-light); }
.float-chip .purple { background: var(--activy-purple-light); }

/* fala na dole hero */
.hero-wave {
  position: absolute; left: 0; right: 0; bottom: -1px; height: 110px;
  pointer-events: none;
}
.hero-wave svg { position: absolute; bottom: 0; left: 0; width: 200%; height: 100%; animation: wave 22s linear infinite; }
.hero-wave svg.back { opacity: .4; animation-duration: 34s; animation-direction: reverse; }
@keyframes wave { from { transform: translateX(0); } to { transform: translateX(-50%); } }

@media (min-width: 880px) {
  .hero { padding: 168px 0 170px; }
  .hero-grid { grid-template-columns: 1.15fr .85fr; gap: 40px; }
  .crest-card { padding: 38px 46px 28px; }
}

/* ============================================================
   WYNIKI KONKURSU
   ============================================================ */
.stats { padding: 72px 0 36px; }
.stats-layout { display: grid; gap: 36px; }
.stats-layout .section-head { margin-bottom: 0; }
.stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.stat-tile {
  border-radius: var(--activy-r-20);
  padding: 22px 20px 20px;
  display: grid; gap: 10px; align-content: start;
  min-height: 150px;
  transition: transform .25s, box-shadow .25s;
}
.stat-tile:hover { transform: translateY(-4px); box-shadow: var(--activy-shadow-card); }
.stat-tile .disc {
  width: 44px; height: 44px; border-radius: var(--activy-r-12);
  background: var(--activy-white); display: grid; place-items: center;
  box-shadow: var(--activy-shadow-chip);
}
.stat-tile .disc svg { width: 24px; height: 24px; }
.stat-tile .num {
  font-family: var(--activy-font-display); font-weight: 600;
  font-size: clamp(1.9rem, 5.5vw, 2.6rem); letter-spacing: -.02em; line-height: 1;
  color: var(--activy-text-dark);
  font-variant-numeric: tabular-nums;
}
.stat-tile .lab { font-size: .9rem; font-weight: 500; }
.stat-tile.t-green  { background: var(--activy-green-light); }
.stat-tile.t-blue   { background: var(--activy-blue-light); }
.stat-tile.t-orange { background: var(--activy-orange-light); }
.stat-tile.t-purple { background: var(--activy-purple-light); }

/* skeleton */
.stat-tile .sk { display: none; }
.stats-grid.loading .num, .stats-grid.loading .lab { visibility: hidden; }
.stats-grid.loading .sk {
  display: block; position: relative; overflow: hidden;
  border-radius: var(--activy-r-6); background: rgba(0,0,0,.07);
}
.stats-grid.loading .sk::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.65), transparent);
  animation: shimmer 1.3s infinite;
}
@keyframes shimmer { from { transform: translateX(-100%); } to { transform: translateX(100%); } }
.sk-num { height: 34px; width: 70%; margin-top: -44px; }
.sk-lab { height: 14px; width: 50%; margin-top: -20px; }
.stats-note { margin-top: 14px; font-size: .8rem; color: var(--activy-neutral-light); }

@media (min-width: 880px) {
  .stats { padding: 96px 0 48px; }
  .stats-grid { gap: 20px; }
  .stat-tile { padding: 28px 26px 26px; min-height: 180px; }
}
@media (min-width: 1060px) {
  .stats-layout { grid-template-columns: minmax(300px, 400px) 1fr; gap: 64px; align-items: center; }
}

/* ============================================================
   JAK WEJŚĆ DO GRY
   ============================================================ */
.start { padding: 64px 0; }
.start-grid { display: grid; gap: 48px; align-items: center; }
.steps { display: grid; gap: 10px; counter-reset: step; }
.step {
  display: flex; gap: 18px; align-items: flex-start;
  padding: 18px; border-radius: var(--activy-r-16);
  border: 1px solid var(--activy-border-light);
  background: var(--activy-white);
  transition: border-color .25s, box-shadow .25s, transform .25s;
}
.step:hover { border-color: var(--activy-green); box-shadow: var(--activy-shadow-card); transform: translateX(4px); }
.step .num {
  flex-shrink: 0;
  width: 52px; height: 52px; border-radius: var(--activy-r-12);
  display: grid; place-items: center;
  font-family: var(--activy-font-display); font-weight: 600; font-size: 1.5rem;
  background: var(--activy-green-light); color: var(--activy-green-hover);
}
.step .ico {
  margin-left: auto; align-self: center; flex-shrink: 0;
  width: 42px; height: 42px; border-radius: 50%;
  display: grid; place-items: center;
}
.step .ico svg { width: 21px; height: 21px; }
.step h3 { font-size: 1.12rem; margin-bottom: 4px; }
.step p { font-size: .92rem; }

.download-panel {
  display: grid; gap: 20px; justify-items: center; text-align: center;
  background: var(--activy-green-light); border-radius: var(--activy-r-24);
  padding: 32px 24px;
  width: 100%; max-width: 440px; justify-self: center;
  box-sizing: border-box;
}
.download-panel .colt {
  font-family: var(--activy-font-display); font-weight: 600;
  font-size: .82rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--activy-neutral);
}
.qr-box {
  width: 132px; height: 132px; border-radius: var(--activy-r-16);
  background: var(--activy-white); box-shadow: var(--activy-shadow-chip);
  display: grid; place-items: center; padding: 10px;
  overflow: hidden;
}
.qr-box img { width: 100%; height: 100%; object-fit: contain; }
.qr-cap { font-size: .8rem; color: var(--activy-neutral-light); margin-top: -10px; }

.start-phone { justify-self: center; }
.start-rider {
  width: min(380px, 80vw); height: auto; justify-self: center;
  margin-top: 24px;
  animation: bob 7s ease-in-out infinite;
}

@media (min-width: 880px) {
  .start { padding: 88px 0; }
  .start-grid { grid-template-columns: 1.05fr .95fr; gap: 64px; align-items: start; }
  .start-right { display: grid; gap: 24px; justify-items: center; }
}

/* ============================================================
   TELEFON (mockup CSS)
   ============================================================ */
.phone {
  width: 272px; background: var(--activy-black);
  border-radius: 44px; padding: 10px;
  box-shadow: var(--activy-shadow-float);
}
.phone-screen {
  background: var(--activy-white); border-radius: 36px; overflow: hidden;
  font-size: 12.5px; line-height: 1.45; color: var(--activy-text-dark);
}
.phone-status {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 20px 6px; font-weight: 600; font-size: 11px;
}
.phone-status .pill { width: 64px; height: 18px; border-radius: 10px; background: var(--activy-black); margin-inline: auto; position: absolute; left: 0; right: 0; top: 10px; }
.phone-screen { position: relative; }
.phone-body { padding: 10px 14px 18px; display: grid; gap: 10px; }
.phone-h {
  font-family: var(--activy-font-display); font-weight: 600; font-size: 15px;
  padding: 6px 2px 0;
}
.app-card {
  border: 1px solid var(--activy-border-light); border-radius: var(--activy-r-12);
  padding: 11px 12px; display: grid; gap: 6px;
  background: var(--activy-white);
}
.app-card.sel { border-color: var(--activy-green); background: var(--activy-green-light); }
.app-card .row { display: flex; align-items: center; gap: 8px; }
.app-card .t { font-weight: 600; font-size: 12.5px; }
.app-card .s { font-size: 11px; color: var(--activy-text); }
.app-tag {
  margin-left: auto; flex-shrink: 0;
  background: var(--activy-green); color: var(--activy-white);
  font-size: 9px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
  border-radius: var(--activy-r-pill); padding: 3px 8px;
}
.act-disc {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: var(--activy-orange); display: grid; place-items: center;
}
.act-disc img { width: 17px; height: 17px; filter: brightness(0) invert(1); }
.act-disc.sm { width: 26px; height: 26px; }
.act-disc.sm img { width: 15px; height: 15px; }

.app-map {
  height: 118px; border-radius: var(--activy-r-12); position: relative; overflow: hidden;
  background: var(--activy-green-light);
}
.app-map svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.ride-stats { display: flex; justify-content: space-between; padding: 2px 6px; }
.ride-stats .v { font-family: var(--activy-font-display); font-weight: 600; font-size: 16px; }
.ride-stats .k { font-size: 10px; color: var(--activy-neutral); }
.ride-points {
  display: flex; align-items: center; gap: 8px;
  background: var(--activy-green-light); border-radius: var(--activy-r-12);
  padding: 9px 12px; font-weight: 600; font-size: 12px; color: var(--activy-green-hover);
}

/* telefon w sekcji aplikacji - pod kątem, z plakietkami */
.app-visual { position: relative; justify-self: center; padding: 26px 10px; }
.app-visual .phone { position: relative; z-index: 1; transform: rotate(4deg); }
.hex-deco { position: absolute; z-index: 0; height: auto; }
.hex-deco.hd1 { top: -2px; right: -38px; width: 110px; }
.hex-deco.hd2 { bottom: -6px; left: -42px; width: 80px; }
.badge-float {
  position: absolute; z-index: 4;
  background: var(--activy-white); border-radius: var(--activy-r-16);
  box-shadow: var(--activy-shadow-card);
  padding: 10px 14px; display: flex; align-items: center; gap: 10px;
  font-size: .82rem; font-weight: 600; color: var(--activy-text-dark);
  animation: bob 6.5s ease-in-out infinite;
  white-space: nowrap;
}
.badge-float .big { font-family: var(--activy-font-display); font-size: 1.15rem; font-weight: 600; }
.badge-float.bf1 { top: 6px; left: -26px; animation-delay: .4s; }
.badge-float.bf2 { top: 42%; right: -38px; animation-delay: 1.2s; }
.badge-float.bf3 { bottom: 16px; left: -14px; animation-delay: 2s; }
.ring { width: 34px; height: 34px; flex-shrink: 0; }
.ring circle { fill: none; stroke-width: 4; }
.ring .bgc { stroke: var(--activy-orange-light); }
.ring .fgc { stroke: var(--activy-orange); stroke-linecap: round; stroke-dasharray: 75.4; stroke-dashoffset: 15; transform: rotate(-90deg); transform-origin: center; }
.heart { color: var(--activy-blue); }

/* ============================================================
   ZASADY I PUNKTACJA
   ============================================================ */
.rules {
  position: relative; overflow: clip;
  background: var(--activy-green);
  background-image:
    radial-gradient(800px 460px at 85% 0%, rgba(255,255,255,.16), transparent 60%),
    radial-gradient(640px 420px at 0% 100%, rgba(4,38,18,.28), transparent 60%);
  color: rgba(255,255,255,.92);
  padding: 80px 0 88px;
}
.rules .section-head { max-width: none; display: grid; gap: 24px; }
.rules h2 { color: var(--activy-white); max-width: 560px; }
.rules .eyebrow { background: rgba(255,255,255,.2); color: var(--activy-white); }
.rules-head-grid { display: grid; gap: 28px; align-items: center; }
.rider-slot-cap { font-size: .78rem; color: rgba(255,255,255,.6); margin-top: 8px; text-align: center; }
.rules-illustration { justify-self: center; }
.rules-rider {
  width: min(330px, 72vw); height: auto;
  filter: drop-shadow(0 14px 30px rgba(4,38,18,.25));
  animation: bob 7s ease-in-out infinite;
}
.rules-deco { position: absolute; color: rgba(255,255,255,.16); pointer-events: none; display: none; }
.rules-deco.rd1 { top: 70px; right: 1%; width: 110px; }
.rules-deco.rd2 { bottom: 36px; left: 1.5%; width: 150px; }
@media (min-width: 1200px) { .rules-deco { display: block; } }

.rules-grid { display: grid; gap: 16px; margin-top: 40px; }
.rule-card {
  background: var(--activy-white); border-radius: var(--activy-r-20);
  padding: 26px 24px; display: grid; gap: 12px; align-content: start;
  color: var(--activy-text);
  transition: transform .25s, box-shadow .25s;
}
.rule-card:hover { transform: translateY(-5px); box-shadow: 0 16px 44px rgba(4,38,18,.35); }
.rule-card h3 { font-size: 1.1rem; }
.rule-card p { font-size: .92rem; }
.hex {
  width: 76px; height: 84px;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  background: var(--activy-green-light);
  display: grid; place-items: center; text-align: center;
  font-family: var(--activy-font-display); font-weight: 600;
  color: var(--activy-green-hover); line-height: 1;
}
.hex .v { font-size: 1.55rem; letter-spacing: -.02em; }
.hex .u { font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; }
.hex.hx-orange { background: var(--activy-orange-light); color: var(--activy-orange); }
.hex.hx-blue { background: var(--activy-blue-light); color: var(--activy-blue); }

/* karta-akcent: mnożniki */
.rule-card.accent {
  background: var(--activy-green-dark); color: rgba(255,255,255,.92);
}
.rule-card.accent h3 { color: var(--activy-white); }
.rule-card.accent p { color: rgba(255,255,255,.88); }
.rule-card.accent .hex { background: rgba(255,255,255,.18); color: var(--activy-white); }
.rule-card.accent:hover { box-shadow: 0 16px 44px rgba(4,38,18,.45); }
.timeline { display: grid; gap: 0; margin-top: 4px; }
.tl-row {
  display: grid; grid-template-columns: 18px 1fr; gap: 12px; align-items: start;
  position: relative; padding-bottom: 14px;
}
.tl-row:last-child { padding-bottom: 0; }
.tl-row::before {
  content: ""; position: absolute; left: 8px; top: 18px; bottom: 0;
  width: 2px; background: rgba(255,255,255,.30);
}
.tl-row:last-child::before { display: none; }
.tl-dot {
  width: 14px; height: 14px; border-radius: 50%; margin-top: 4px;
  background: rgba(255,255,255,.35); border: 2px solid var(--activy-white);
  box-sizing: border-box;
}
.tl-row.hot .tl-dot { background: var(--activy-white); }
.tl-date { font-size: .72rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.66); }
.tl-val { font-family: var(--activy-font-display); font-weight: 600; font-size: 1.05rem; color: var(--activy-white); }

@media (min-width: 700px) {
  .rules-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1060px) {
  .rules { padding: 104px 0 112px; }
  .rules-head-grid { grid-template-columns: 1fr auto; }
  .rules-grid { grid-template-columns: repeat(4, 1fr); gap: 20px; }
}

/* ============================================================
   ZAPROŚ ZNAJOMYCH (bonus)
   ============================================================ */
.invite { padding: 56px 0; }
.invite-card {
  position: relative; overflow: clip;
  border-radius: var(--activy-r-24);
  background:
    radial-gradient(620px 320px at 88% -20%, rgba(255,255,255,.24), transparent 62%),
    linear-gradient(135deg, #ff9d2e 0%, var(--activy-orange) 46%, #f06600 100%);
  color: var(--activy-white);
  padding: 36px 26px;
  box-shadow: 0 22px 54px rgba(255,134,0,.30);
}
.invite-grid { position: relative; z-index: 2; display: grid; gap: 30px; align-items: center; }
.invite-copy .eyebrow { background: rgba(255,255,255,.22); color: var(--activy-white); }
.invite-copy h2 { color: var(--activy-white); font-size: clamp(1.55rem, 4.2vw, 2.35rem); margin: 14px 0 12px; }
.invite-copy .lead { color: rgba(255,255,255,.95); font-size: 1.05rem; line-height: 1.55; }
.invite-copy .lead strong { color: var(--activy-white); font-weight: 700; }

/* rozwijane „jak zdobyć" */
.invite-how {
  margin-top: 22px;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.3);
  border-radius: var(--activy-r-16); overflow: hidden;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
}
.invite-how summary {
  list-style: none; cursor: pointer; user-select: none;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 15px 20px;
  font-family: var(--activy-font-display); font-weight: 600; font-size: 1.02rem;
  color: var(--activy-white);
}
.invite-how summary::-webkit-details-marker { display: none; }
.invite-how summary::marker { content: ""; }
.invite-how .chev { width: 20px; height: 20px; flex-shrink: 0; transition: transform .3s ease; }
.invite-how[open] .chev { transform: rotate(180deg); }
.invite-how .mini-steps { padding: 2px 20px 20px; }
.invite-how .mini-steps li { color: var(--activy-white); font-size: .95rem; }
.invite-how .mini-steps li strong { color: var(--activy-white); font-weight: 700; }
.invite-how .mini-steps li::before,
.invite-how .mini-steps li:nth-child(2)::before,
.invite-how .mini-steps li:nth-child(3)::before {
  background: var(--activy-white); color: var(--activy-orange);
}

/* kafelek-grafika z punktami */
.invite-visual {
  position: relative;
  display: grid; gap: 16px; justify-items: center; text-align: center;
  background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.28);
  border-radius: var(--activy-r-20); padding: 30px 24px;
}
.inv-meter { display: grid; gap: 4px; }
.inv-big {
  font-family: var(--activy-font-display); font-weight: 700;
  font-size: clamp(2.9rem, 9vw, 4.1rem); line-height: 1; letter-spacing: -.02em;
}
.inv-unit { font-size: .82rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; opacity: .92; }
.inv-people { display: flex; align-items: center; justify-content: center; }
.inv-ava {
  width: 46px; height: 46px; border-radius: 50%;
  background: var(--activy-white); border: 3px solid var(--activy-orange);
  display: grid; place-items: center; margin-left: -12px;
  box-shadow: 0 4px 12px rgba(0,0,0,.14);
  animation: bob 6s ease-in-out infinite;
}
.inv-ava:first-child { margin-left: 0; }
.inv-ava:nth-child(2) { animation-delay: .5s; }
.inv-ava:nth-child(3) { animation-delay: 1s; }
.inv-ava:nth-child(4) { animation-delay: 1.5s; }
.inv-ava:nth-child(5) { animation-delay: 2s; }
.inv-ava svg { width: 24px; height: 24px; }
.inv-ava.more {
  font-family: var(--activy-font-display); font-weight: 700; font-size: .92rem;
  color: var(--activy-orange);
}
.inv-cap { font-size: .9rem; font-weight: 600; opacity: .92; }
.inv-cap.alt { font-size: .82rem; opacity: .85; margin-top: -8px; }

/* pływające plakietki +20 pkt */
.inv-chip {
  position: absolute; z-index: 3; display: none;
  background: var(--activy-white); color: var(--activy-orange);
  font-family: var(--activy-font-display); font-weight: 700; font-size: .9rem;
  padding: 7px 15px; border-radius: var(--activy-r-pill);
  box-shadow: var(--activy-shadow-card);
  animation: bob 7s ease-in-out infinite;
}
.inv-chip.ic1 { top: 22px; right: 34px; animation-delay: .3s; }
.inv-chip.ic2 { bottom: 70px; right: 18px; animation-delay: 1.2s; }
.inv-chip.ic3 { bottom: 26px; left: 30px; animation-delay: 2s; }

@media (min-width: 880px) {
  .invite { padding: 80px 0; }
  .invite-card { padding: 54px 52px; }
  .invite-grid { grid-template-columns: 1.08fr .92fr; gap: 54px; }
  .inv-chip { display: block; }
}

/* ============================================================
   NOWA ODSŁONA APLIKACJI
   ============================================================ */
.app-section { padding: 80px 0; }
.app-grid { display: grid; gap: 56px; align-items: center; }
.values { display: grid; gap: 8px; margin-top: 28px; }
.value-row {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 16px; border-radius: var(--activy-r-16);
  transition: background .25s;
}
.value-row:hover { background: var(--activy-bg); }
.value-row .disc {
  flex-shrink: 0; width: 48px; height: 48px; border-radius: var(--activy-r-12);
  display: grid; place-items: center;
}
.value-row .disc svg { width: 24px; height: 24px; }
.value-row h3 { font-size: 1.08rem; margin-bottom: 3px; }
.value-row p { font-size: .92rem; }
.d-green { background: var(--activy-green-light); }
.d-orange { background: var(--activy-orange-light); }
.d-blue { background: var(--activy-blue-light); }

@media (min-width: 880px) {
  .app-section { padding: 104px 0; }
  .app-grid { grid-template-columns: 1fr 1fr; gap: 48px; }
}

/* ============================================================
   EKO
   ============================================================ */
.eco { position: relative; overflow: clip; background: var(--activy-green-light); padding: 72px 0 96px; }
.eco-grid { position: relative; display: grid; gap: 40px; align-items: center; }
.eco .eyebrow { background: var(--activy-white); }

/* fakty na chipach */
.eco-facts { display: grid; gap: 12px; margin-top: 26px; }
.eco-fact {
  display: flex; gap: 16px; align-items: center;
  background: var(--activy-white); border-radius: var(--activy-r-16);
  padding: 14px 20px 14px 14px;
  box-shadow: var(--activy-shadow-chip);
  transition: transform .25s, box-shadow .25s;
}
.eco-fact:hover { transform: translateX(8px); box-shadow: var(--activy-shadow-card); }
.eco-fact .disc {
  flex-shrink: 0; width: 46px; height: 46px; border-radius: var(--activy-r-12);
  display: grid; place-items: center;
}
.eco-fact .disc svg { width: 24px; height: 24px; }
.eco-fact .t { font-family: var(--activy-font-display); font-weight: 600; font-size: 1.02rem; color: var(--activy-text-dark); }
.eco-fact .s { font-size: .85rem; }

/* pływające liście i drzewa */
.eco-leaf {
  position: absolute; pointer-events: auto; cursor: default;
  color: var(--activy-green);
  animation: bob 8s ease-in-out infinite;
  transition: transform .3s;
  opacity: .85;
}
.eco-leaf:hover { transform: rotate(-10deg) scale(1.18); }
.eco-leaf.el1 { top: 36px; left: 4%; width: 42px; animation-delay: .5s; }
.eco-leaf.el2 { top: 24px; right: 6%; width: 54px; animation-delay: 1.4s; }
.eco-leaf.el3 { bottom: 90px; left: 46%; width: 36px; animation-delay: 2.2s; opacity: .55; }
.eco-trees {
  position: absolute; left: 0; right: 0; bottom: -2px; height: 64px;
  color: var(--activy-green); opacity: .35; pointer-events: none;
}
.eco-trees svg { width: 100%; height: 100%; }
.eco-rider {
  position: absolute; bottom: 26px; left: 49%; width: 150px; height: auto;
  display: none; pointer-events: none;
  animation: bob 6.5s ease-in-out infinite;
}
@media (min-width: 880px) { .eco-rider { display: block; } }

.eco-card {
  background: var(--activy-white); border-radius: var(--activy-r-24);
  box-shadow: var(--activy-shadow-card);
  padding: 36px 32px; text-align: center; display: grid; gap: 6px; justify-items: center;
}
.eco-card .conv {
  display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; justify-content: center;
  font-family: var(--activy-font-display); font-weight: 600; color: var(--activy-text-dark);
}
.eco-card .conv .n { font-size: clamp(2.6rem, 7vw, 3.6rem); letter-spacing: -.02em; }
.eco-card .conv .eq { font-size: 1.6rem; color: var(--activy-green); }
.eco-card .cap { font-size: .9rem; color: var(--activy-text); max-width: 300px; }
.eco-card .leaf-disc {
  width: 56px; height: 56px; border-radius: 50%; background: var(--activy-green-light);
  display: grid; place-items: center; margin-bottom: 8px;
}
.eco-card .leaf-disc svg { width: 28px; height: 28px; }

@media (min-width: 880px) {
  .eco { padding: 96px 0 120px; }
  .eco-grid { grid-template-columns: 1.1fr .9fr; gap: 64px; }
}

/* ============================================================
   INTEGRACJE
   ============================================================ */
.integrations { padding: 80px 0; }
.logo-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
}
.logo-cell {
  display: grid; place-items: center; gap: 8px;
  border-radius: var(--activy-r-16);
  padding: 22px 12px; min-height: 96px;
  text-decoration: none;
  background: var(--activy-white);
  border: 1px solid var(--activy-border);
  transition: box-shadow .25s, transform .25s, border-color .25s;
}
.logo-cell img {
  max-height: 34px; max-width: 120px; width: auto; object-fit: contain;
}
.logo-cell:hover { box-shadow: var(--activy-shadow-chip); transform: translateY(-3px); border-color: var(--activy-border-strong); }
.logo-cell .cap { font-size: .72rem; color: var(--activy-neutral); font-weight: 600; }

.int-cards { display: grid; gap: 16px; margin-top: 28px; }
.int-card {
  border: 1px solid var(--activy-border-light); border-radius: var(--activy-r-20);
  padding: 32px 30px; display: grid; gap: 12px; align-content: start;
  background: var(--activy-white);
}
.int-card .ic {
  width: 56px; height: 56px; border-radius: var(--activy-r-12);
  display: grid; place-items: center; background: var(--activy-bg);
  margin-bottom: 4px;
}
.int-card .ic img { max-height: 28px; max-width: 30px; object-fit: contain; }
.int-card .ic svg { width: 28px; height: 28px; }
.int-card h3 { font-size: 1.3rem; }
.int-card p { font-size: .98rem; }
.int-card.watch { background: var(--activy-blue-light); border-color: transparent; }
.int-card.watch .ic { background: var(--activy-white); box-shadow: var(--activy-shadow-chip); }
.int-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.int-pill {
  background: var(--activy-white); border-radius: var(--activy-r-pill);
  padding: 7px 16px; font-size: .85rem; font-weight: 600;
  color: var(--activy-text-dark); box-shadow: var(--activy-shadow-chip);
}
.int-card.faq { background: var(--activy-green); border-color: transparent; color: rgba(255,255,255,.92); }
.int-card.faq h3 { color: var(--activy-white); }
.int-card.faq p { color: rgba(255,255,255,.92); }
.int-card.faq .ic { background: rgba(255,255,255,.2); }
.int-card.faq .btn { margin-top: 6px; justify-self: start; }
.btn-light { background: var(--activy-white); color: var(--activy-green-hover); }
.btn-light:hover { background: var(--activy-green-light); }

@media (min-width: 700px) {
  .logo-grid { grid-template-columns: repeat(3, 1fr); }
  .int-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1060px) {
  .logo-grid { grid-template-columns: repeat(6, 1fr); }
}
@media (min-width: 880px) {
  .integrations { padding: 104px 0; }
  .logo-grid { gap: 16px; }
}

/* ============================================================
   KONTAKT + STOPKA
   ============================================================ */
.contact-footer {
  position: relative; overflow: clip;
  background: linear-gradient(180deg, var(--activy-green), var(--activy-green-hover) 88%);
  color: rgba(255,255,255,.88);
  padding: 80px 0 0;
}
.contact { position: relative; }
.contact .eyebrow { background: rgba(255,255,255,.2); color: var(--activy-white); }
.contact h2 { color: var(--activy-white); }
.contact-grid { display: grid; gap: 16px; margin-top: 36px; }
.contact-card {
  background: var(--activy-white); border-radius: var(--activy-r-20);
  padding: 28px 26px; display: grid; gap: 10px; align-content: start;
  color: var(--activy-text);
}
.contact-card .colt {
  font-family: var(--activy-font-display); font-weight: 600;
  font-size: .78rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--activy-neutral);
}
.contact-card .disc {
  width: 52px; height: 52px; border-radius: 50%;
  display: grid; place-items: center;
}
.contact-card .disc svg { width: 26px; height: 26px; }
.contact-card a.mail {
  font-family: var(--activy-font-display); font-weight: 600; font-size: 1.15rem;
  color: var(--activy-text-dark); text-decoration: none; word-break: break-all;
}
.contact-card a.mail:hover { color: var(--activy-green-hover); }
.contact-card .sub { font-size: .9rem; }
.support-how { font-size: 1rem; line-height: 1.7; }
.support-how strong { color: var(--activy-text-dark); }
.mini-steps {
  margin: 0; padding: 0; list-style: none;
  display: grid; gap: 10px; counter-reset: ms;
}
.mini-steps li {
  counter-increment: ms;
  display: flex; align-items: flex-start; gap: 12px;
  font-size: .95rem; line-height: 1.5;
  text-align: left;
}
.mini-steps li::before {
  content: counter(ms);
  flex-shrink: 0; margin-top: -2px;
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--activy-green-light); color: var(--activy-green-hover);
  font-family: var(--activy-font-display); font-weight: 600; font-size: .85rem;
}
.mini-steps li:nth-child(2)::before { background: var(--activy-orange-light); color: var(--activy-orange); }
.mini-steps li:nth-child(3)::before { background: var(--activy-blue-light); color: var(--activy-blue); }
.contact-topics { display: grid; gap: 8px; }
.topic-row { display: flex; gap: 12px; align-items: center; font-size: .95rem; }
.topic-row .ti {
  flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
}
.topic-row .ti svg { width: 15px; height: 15px; }

@media (min-width: 700px) {
  .contact-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
}

.footer { padding: 72px 0 36px; }
.footer-grid { display: grid; gap: 32px; }
.footer-logo img { height: 30px; width: auto; }
.footer .tagline { margin-top: 16px; max-width: 320px; font-size: .95rem; line-height: 1.6; }
.footer .colt {
  font-family: var(--activy-font-display); font-weight: 600;
  font-size: .75rem; letter-spacing: .12em; text-transform: uppercase;
  opacity: .55; margin-bottom: 12px;
}
.footer-links { display: grid; gap: 2px; }
.footer-links a { color: rgba(255,255,255,.92); text-decoration: none; padding: 5px 0; font-size: .92rem; }
.footer-links a:hover { color: var(--activy-white); text-decoration: underline; }
.footer address { font-style: normal; font-size: .88rem; line-height: 1.7; }
.footer-bottom {
  margin-top: 44px; padding: 18px 0 0;
  border-top: 1px solid rgba(255,255,255,.25);
  display: flex; flex-wrap: wrap; gap: 12px; justify-content: space-between;
  font-size: .78rem; color: rgba(255,255,255,.65);
}
@media (min-width: 880px) {
  .footer-grid { grid-template-columns: 2fr 1fr 1fr; gap: 48px; }
}

/* ============================================================
   JAK DOŁĄCZYĆ — dwie ścieżki (tylko Sopot)
   ============================================================ */
.join { padding: 56px 0 8px; }
.join-grid { display: grid; gap: 20px; }
.join-card {
  position: relative;
  display: flex; flex-direction: column; align-items: flex-start; gap: 12px;
  background: var(--activy-white); border: 1px solid var(--activy-border);
  border-radius: var(--activy-r-20); padding: 28px 26px;
  box-shadow: var(--activy-shadow-chip);
  transition: border-color .2s, box-shadow .2s, transform .2s;
}
.join-card:hover { border-color: var(--activy-green); box-shadow: var(--activy-shadow-card); transform: translateY(-3px); }
.join-card .join-ic {
  width: 54px; height: 54px; border-radius: var(--activy-r-16);
  display: grid; place-items: center; flex-shrink: 0;
}
.join-card .join-ic svg { width: 28px; height: 28px; }
.join-card h3 { font-size: 1.22rem; }
.join-card p { font-size: .96rem; line-height: 1.55; }
.join-card .join-cta { margin-top: 6px; }
.join-soon {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--activy-orange-light); color: #b35e00;
  border-radius: var(--activy-r-pill); padding: 7px 14px;
  font-size: .85rem; font-weight: 600;
}
.join-soon svg { width: 16px; height: 16px; flex-shrink: 0; }
.btn.is-disabled {
  background: var(--activy-border); color: var(--activy-neutral);
  cursor: not-allowed; pointer-events: none;
}
@media (min-width: 760px) {
  .join { padding: 72px 0 12px; }
  .join-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .join-card { padding: 32px 30px; }
}

/* Sopot: „Jak wejść do gry" w 2 krokach — luźniejszy, wyśrodkowany układ */
.steps-2 { gap: 16px; }
.steps-2 .step { padding: 24px 22px; }
.steps-2 .step h3 { font-size: 1.18rem; }
.steps-2 .step p { font-size: .95rem; }
@media (min-width: 880px) {
  .start-sopot .start-grid { align-items: center; }
}

/* ============================================================
   PARTNERZY (logo wall — generowane dynamicznie z gdansk.js)
   ============================================================ */
.partners { padding: 72px 0; background: var(--activy-bg); }
.partners .container { position: relative; }
.partners .section-head { margin-bottom: 32px; }

.partners-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
}
.partner-cell {
  display: grid; place-items: center;
  background: var(--activy-white);
  border: 1px solid var(--activy-border);
  border-radius: var(--activy-r-16);
  padding: 22px 16px; min-height: 110px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.partner-cell img {
  max-height: 52px; max-width: 82%; width: auto; height: auto;
  object-fit: contain;
}
.partner-cell:hover {
  transform: translateY(-4px);
  box-shadow: var(--activy-shadow-card);
  border-color: var(--activy-border-strong);
}

@media (min-width: 560px) {
  .partners-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 880px) {
  .partners { padding: 96px 0; }
  .partners-grid { grid-template-columns: repeat(4, 1fr); gap: 16px; }
  .partner-cell { min-height: 124px; padding: 26px 20px; }
  .partner-cell img { max-height: 58px; }
}
@media (min-width: 1060px) {
  .partners-grid { grid-template-columns: repeat(5, 1fr); }
}

/* ============================================================
   ANIMACJE WEJŚCIA + REDUCED MOTION
   ============================================================ */
.rv { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s ease; }
.rv.in { opacity: 1; transform: none; }
.rv-d1 { transition-delay: .08s; }
.rv-d2 { transition-delay: .16s; }
.rv-d3 { transition-delay: .24s; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .rv { opacity: 1; transform: none; transition: none; }
  .crest-card, .float-chip, .badge-float, .hero-blob, .hero-wave svg, .hero-dates .dot, .eco-leaf, .float-deco, .rules-rider, .start-rider, .inv-ava, .inv-chip { animation: none; }
}
