*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  color-scheme:dark;
  --abyss:#050d1a;
  --midnight:#0a1628;
  --deep:#0f2238;
  --hull:#142e48;
  --hull-light:#1c3d5c;
  --steel:#2a4d6e;
  --bone:#e8dfc8;
  --brass:#b8860b;
  --brass-light:#d4a017;
  --brass-glow:#e8b832;
  --gold-shine:#f5cf52;
  --red-flag:#e85a5a;
  --text-light:#e0e8f0;
  --text-mid:#a8bbd0;
  --text-dim:#8ca3bd;
  /* Brass-glow opacity warianty (eliminują 40+ instancji rgba(232,184,50,X)) */
  --brass-glow-04:rgb(232 184 50 / 4%);
  --brass-glow-05:rgb(232 184 50 / 5%);
  --brass-glow-06:rgb(232 184 50 / 6%);
  --brass-glow-08:rgb(232 184 50 / 8%);
  --brass-glow-10:rgb(232 184 50 / 10%);
  --brass-glow-12:rgb(232 184 50 / 12%);
  --brass-glow-15:rgb(232 184 50 / 15%);
  --brass-glow-18:rgb(232 184 50 / 18%);
  --brass-glow-20:rgb(232 184 50 / 20%);
  --brass-glow-25:rgb(232 184 50 / 25%);
  --brass-glow-30:rgb(232 184 50 / 30%);
  --brass-glow-35:rgb(232 184 50 / 35%);
  --brass-glow-40:rgb(232 184 50 / 40%);
  --brass-glow-45:rgb(232 184 50 / 45%);
  --brass-glow-50:rgb(232 184 50 / 50%);
  --brass-glow-55:rgb(232 184 50 / 55%);
  /* Spacing scale */
  --space-xs:0.5rem;
  --space-sm:0.75rem;
  --space-base:1rem;
  --space-md:1.5rem;
  --space-lg:2rem;
  --space-xl:3rem;
  --radius-sm:4px;
  --radius-md:6px;
  --radius:8px;
  --radius-lg:14px;
  --radius-pill:50px;
  /* Shadow scale */
  --shadow-sm:0 2px 8px rgba(0,0,0,0.2);
  --shadow-md:0 4px 20px rgba(0,0,0,0.3);
  --shadow-nav:0 2px 20px rgba(0,0,0,0.4);
  --shadow-lg:0 15px 40px rgba(0,0,0,0.5);
  --shadow-card:0 4px 30px rgba(5,13,26,0.5);
  --shadow-card-hover:0 8px 30px rgba(0,0,0,0.4);
  --shadow-glow-brass:0 8px 25px var(--brass-glow-35);
  /* Focus ring */
  --focus-offset:3px;
  /* Typography */
  --fs-xs:0.72rem;
  --fs-sm:0.85rem;
  --fs-md:1.1rem;
  --fs-lg:1.3rem;
  --fs-xl:1.5rem;
  --fs-h2:clamp(2rem,4vw,3rem);
  --fs-h1:clamp(2.2rem,5vw,3.4rem);
  --fs-hero:clamp(2.8rem,7vw,5rem);
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Source Sans 3',sans-serif;background:var(--midnight);color:var(--text-light);overflow-x:hidden;line-height:1.65}
img{max-width:100%;height:auto}
section{scroll-margin-top:80px}
.hero-title,.section-title,.news-card h3,.article-title{text-wrap:balance}
.section-desc,.article-content p,.article-lead,.history-text p,.about-text p{text-wrap:pretty}
.reveal{opacity:0;transform:translateY(25px);transition:opacity 0.6s ease,transform 0.6s ease;transition-delay:calc(var(--reveal-i,0) * 80ms)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}
.news-list-page .news-grid > article:first-child{grid-column:span 2}
@media (max-width:768px){.news-list-page .news-grid > article:first-child{grid-column:auto}}
.news-card{position:relative}
.news-card .news-card-link::before{content:"";position:absolute;inset:0;z-index:1}

/* ===== CONTACT MAP — CLICK-TO-LOAD ===== */
.contact-map-load{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.5rem;width:100%;height:100%;min-height:280px;padding:2rem;background:linear-gradient(135deg,var(--hull),var(--hull-light));border:1px dashed var(--brass-glow-35);border-radius:var(--radius);color:var(--text-light);cursor:pointer;font-family:inherit;transition:border-color 0.2s,background 0.2s}
.contact-map-load:hover,.contact-map-load:focus-visible{border-color:var(--brass-glow);background:linear-gradient(135deg,var(--hull-light),var(--steel))}
.contact-map-icon{font-size:2.5rem;color:var(--brass-glow)}
.contact-map-icon svg{width:2.5rem;height:2.5rem}
.contact-map-text{font-weight:700;color:var(--brass-glow);font-size:var(--fs-md)}
.contact-map-hint{color:var(--text-mid);font-size:0.8rem;text-align:center}

/* ===== ACCESSIBILITY ===== */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:9999;
  padding:0.85rem 1.5rem;background:var(--brass-glow);color:var(--abyss);
  font-family:'Source Sans 3',sans-serif;font-weight:700;text-decoration:none;
  border-radius:0 0 6px 0;letter-spacing:1px;
}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--brass-glow);outline-offset:var(--focus-offset);border-radius:2px}
.btn:focus-visible,.btn-submit:focus-visible{outline-offset:calc(var(--focus-offset) + 1px)}
.nav-links a:focus-visible{outline-offset:-2px}

/* ===== REUSABLE ILLUS ===== */
.bg-illus{display:none;position:absolute;pointer-events:none;opacity:0.05;z-index:0}
.bg-illus.compass{width:400px;height:400px;right:-100px;top:-50px}
.bg-illus.anchor{width:200px;height:200px;left:-50px;bottom:20px}
.bg-illus.sailboat{width:300px;height:300px;right:-40px;top:50%;transform:translateY(-50%);opacity:0.04}
.bg-illus.knot{width:160px;height:160px;right:30px;top:40px}
.bg-illus--news{right:5%;top:8%;width:280px;height:140px}
.bg-illus--atrakcje{right:-60px;bottom:-40px;width:500px;height:400px;opacity:0.04}
.bg-illus--historia{left:-80px;bottom:-60px;width:350px;height:350px;opacity:0.04}
.contact-honeypot{position:absolute;left:-9999px;height:0;width:0;opacity:0}
.contact-card address{font-style:normal}
.training-link--mt{margin-top:0.5rem}
.section-header--center{text-align:center}
.section-flag--center{justify-content:center}

/* ===== IMAGE PLACEHOLDER ===== */
.img-placeholder{
  width:100%;aspect-ratio:16/10;
  background:
    repeating-linear-gradient(45deg,var(--brass-glow-04) 0,var(--brass-glow-04) 10px,transparent 10px,transparent 20px),
    linear-gradient(135deg,rgba(20,46,72,0.6),rgba(10,22,40,0.8));
  border:1px dashed var(--brass-glow-30);
  border-radius:var(--radius);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:var(--brass-glow-55);
  font-family:'Cinzel',serif;font-size:0.7rem;
  text-transform:uppercase;letter-spacing:3px;
  margin-bottom:var(--space-md);position:relative;overflow:hidden;
}
.img-placeholder::before{
  content:'';position:absolute;top:50%;left:50%;width:40px;height:40px;
  transform:translate(-50%,calc(-50% - 16px));
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e8b832' stroke-width='1' opacity='0.5'><rect x='3' y='3' width='18' height='18' rx='2'/><circle cx='8.5' cy='8.5' r='1.5'/><path d='M21 15l-5-5L5 21'/></svg>") center/contain no-repeat;
}
.img-placeholder span{margin-top:42px;opacity:0.8}
.img-placeholder.card-top{margin:0;border-radius:0;border-left:none;border-right:none;border-top:none;border-bottom:1px dashed var(--brass-glow-25)}

/* ===== CONTENT IMAGES (zdjęcia sekcji z JSON — geometria 1:1 z placeholderami) ===== */
img.card-top{display:block;width:100%;height:auto;aspect-ratio:16/10;object-fit:cover}
.offer-card img,.about-illustration img,.history-image img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius)}
.offer-card img{margin-bottom:1.25rem}

/* ===== NAV ===== */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:box-shadow 0.4s;
}
/* Tło+blur na ::before, nie na nav: backdrop-filter na przodku tworzy containing
   block dla position:fixed, więc menu mobilne (.nav-links, inset:0) rozciągałoby
   się względem paska navbara zamiast viewportu. */
#navbar::before{content:'';position:absolute;inset:0;z-index:-1;background:rgba(5,13,26,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:background 0.4s}
#navbar.scrolled{box-shadow:var(--shadow-nav)}
#navbar.scrolled::before{background:rgba(5,13,26,0.97)}
#navbar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 5%,var(--brass-glow-25) 30%,var(--brass-glow) 50%,var(--brass-glow-25) 70%,transparent 95%);opacity:0.6}
.nav-inner{max-width:1300px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0.85rem 2rem;gap:1rem}
/* z-index nad .nav-links (999) — logo i hamburger (X) muszą zostać tapowalne
   nad otwartym fullscreenowym menu. */
.nav-logo{display:flex;align-items:center;gap:0.85rem;text-decoration:none;min-height:44px;position:relative;z-index:1000}
.nav-logo-emblem{width:46px;height:46px}
.nav-logo-emblem svg{width:100%;height:100%}
.nav-logo-title{font-family:'Cinzel',serif;font-weight:700;font-size:var(--fs-md);color:var(--bone);letter-spacing:2px;line-height:1.1}
.nav-logo-sub{font-family:'Lora',serif;font-style:italic;font-size:0.7rem;color:var(--brass-glow);letter-spacing:1px}
.nav-cta{display:flex;align-items:center;gap:1rem;position:relative;z-index:1000}
.nav-phone{
  display:none;align-items:center;gap:0.5rem;
  color:var(--brass-glow);text-decoration:none;font-weight:700;
  font-size:var(--fs-sm);letter-spacing:0.5px;font-family:'Cinzel',serif;
  padding:0.5rem 0.85rem;border:1px solid var(--brass-glow-30);border-radius:var(--radius-md);
  transition:background 0.3s,border-color 0.3s;min-height:44px;
}
.nav-phone:hover{background:var(--brass-glow-10);border-color:var(--brass-glow);color:var(--gold-shine)}
.nav-phone svg{width:14px;height:14px}
.nav-links{display:none;position:fixed;inset:0;z-index:999;background:var(--abyss,#050d1a);flex-direction:column;align-items:center;justify-content:center;gap:0.25rem;padding-top:80px;list-style:none}
.nav-links.open{display:flex}
.nav-links a{
  color:var(--bone);text-decoration:none;font-size:var(--fs-md);
  font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  padding:1rem 2rem;transition:color 0.3s;position:relative;
  min-height:44px;display:inline-flex;align-items:center;
}
.nav-links a:hover,.nav-links a.active{color:var(--brass-glow)}
.nav-links a::after{content:'';position:absolute;bottom:8px;left:50%;width:0;height:1px;background:var(--brass-glow);transition:width 0.3s;transform:translateX(-50%)}
.nav-links a:hover::after,.nav-links a.active::after{width:60%}
.nav-hamburger{display:flex;cursor:pointer;flex-direction:column;gap:5px;background:none;border:none;padding:10px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
.nav-hamburger span{width:24px;height:2px;background:var(--brass-glow);transition:transform 0.3s,opacity 0.3s;border-radius:1px;display:block}
.nav-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, #0c1f3a 0%, transparent 70%),
    linear-gradient(175deg,var(--abyss) 0%,#071427 35%,var(--midnight) 60%,var(--deep) 100%);
}
.hero-light{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 30% 20%, var(--brass-glow-08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 75% 70%, rgba(28,61,92,0.4) 0%, transparent 60%);
}
.hero-stars{position:absolute;top:0;left:0;right:0;height:60%;background:radial-gradient(1px 1px at 12% 18%,rgba(255,255,255,0.7),transparent),radial-gradient(1.5px 1.5px at 42% 12%,rgba(255,255,255,0.8),transparent),radial-gradient(1px 1px at 68% 8%,rgba(255,255,255,0.6),transparent),radial-gradient(1px 1px at 85% 22%,rgba(255,255,255,0.5),transparent),radial-gradient(1.5px 1.5px at 28% 5%,rgba(255,255,255,0.6),transparent),radial-gradient(1px 1px at 55% 15%,rgba(255,255,255,0.5),transparent),radial-gradient(1px 1px at 78% 32%,rgba(255,255,255,0.4),transparent),radial-gradient(1px 1px at 15% 38%,rgba(255,255,255,0.3),transparent)}
.hero-moon{position:absolute;top:12%;right:15%;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#f0e6c8,#c9b88a 60%,#8b7a4f);box-shadow:0 0 60px rgba(240,230,200,0.15),0 0 120px rgba(240,230,200,0.08);opacity:0.85}
.hero-moon::before{content:'';position:absolute;top:18%;left:25%;width:14px;height:14px;border-radius:50%;background:rgba(0,0,0,0.08)}
.hero-moon::after{content:'';position:absolute;top:55%;left:55%;width:10px;height:10px;border-radius:50%;background:rgba(0,0,0,0.06)}

.hero-sailboat{
  position:absolute;bottom:22%;right:10%;width:240px;height:240px;opacity:0.18;
  animation:sailDrift 20s ease-in-out infinite;will-change:transform;
}
@keyframes sailDrift{0%,100%{transform:translate(0,0) rotate(-1deg)}50%{transform:translate(-15px,8px) rotate(1deg)}}
.hero-lighthouse{
  position:absolute;left:7%;bottom:24%;width:80px;opacity:0.2;
}
.hero-lighthouse::after{
  content:'';position:absolute;top:8%;left:50%;width:300px;height:60px;
  transform:translate(-50%,0);
  background:radial-gradient(ellipse 50% 50% at 0% 50%,var(--brass-glow-15),transparent 70%);
  animation:beam 6s ease-in-out infinite;
}
@keyframes beam{0%,100%{opacity:0.4}50%{opacity:0.8}}
.hero-water{position:absolute;bottom:0;left:0;right:0;height:200px}
.hero-water svg{position:absolute;bottom:-3px;left:0;width:200%;will-change:transform}
/* Scroll-driven parallax dla hero-moon (Chrome 115+, fallback static dla starszych) */
@supports (animation-timeline: scroll()) {
  .hero-moon{animation:hero-moon-rise linear;animation-timeline:scroll();animation-range:0 100vh}
  @keyframes hero-moon-rise{from{transform:translateY(0)}to{transform:translateY(-50px)}}
}
@media (prefers-reduced-motion: reduce){.hero-moon{animation:none}}
.wave-1{animation:waveSlow 10s ease-in-out infinite}
.wave-2{animation:waveSlow 13s ease-in-out infinite reverse}
.wave-3{animation:waveSlow 8s ease-in-out infinite}
@keyframes waveSlow{0%,100%{transform:translateX(0)}50%{transform:translateX(-25%)}}

.hero-content{text-align:center;position:relative;z-index:2;padding:9rem 2rem 8rem;max-width:950px;margin:0 auto}
.hero-flag{display:flex;align-items:center;justify-content:center;gap:0.75rem;margin-bottom:2.5rem}
.hero-flag-line{width:50px;height:1px;background:var(--brass-glow-50)}
.hero-flag-text{font-family:'Cinzel',serif;font-weight:400;font-size:0.75rem;color:var(--brass-glow);letter-spacing:4px;text-transform:uppercase}
.hero-title{font-family:'Cinzel',serif;font-weight:700;font-size:var(--fs-hero);line-height:1.1;color:var(--bone);margin-bottom:0.5rem;text-shadow:0 2px 40px rgba(0,0,0,0.6);letter-spacing:2px}
.hero-title-accent{display:block;font-family:'Lora',serif;font-style:italic;font-weight:500;font-size:clamp(1.8rem,4vw,3.2rem);color:var(--brass-glow);margin-top:0.25rem;text-shadow:0 0 30px var(--brass-glow-30);letter-spacing:0}
.hero-divider{display:flex;align-items:center;justify-content:center;gap:1rem;margin:2rem auto;max-width:300px}
.hero-divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--brass-glow-50),transparent)}
.hero-divider-icon{color:var(--brass-glow)}
.hero-subtitle{font-family:'Lora',serif;font-size:clamp(1rem,2.2vw,1.2rem);color:var(--text-mid);max-width:580px;margin:0 auto 2.5rem;line-height:1.8}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn{padding:1rem 2.25rem;border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:700;text-decoration:none;letter-spacing:2px;text-transform:uppercase;transition:transform 0.35s,box-shadow 0.35s,background 0.35s,color 0.35s,border-color 0.35s;display:inline-flex;align-items:center;gap:0.5rem;cursor:pointer;border:none;font-family:'Source Sans 3',sans-serif;min-height:44px}
.btn-brass{background:linear-gradient(135deg,var(--brass-glow),var(--brass-light));color:var(--abyss);box-shadow:0 4px 20px var(--brass-glow-30)}
.btn-brass:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--brass-glow-45);background:linear-gradient(135deg,var(--gold-shine),var(--brass-glow))}
.btn-ghost-light{background:transparent;color:var(--bone);border:1px solid var(--brass-glow-50)}
.btn-ghost-light:hover{border-color:var(--brass-glow);background:var(--brass-glow-08);transform:translateY(-2px);color:var(--brass-glow)}
.hero-direct{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.75rem;flex-wrap:wrap;font-family:'Lora',serif;font-size:0.9rem;color:var(--text-mid)}
.hero-direct a{color:var(--brass-glow);text-decoration:none;font-weight:700;font-family:'Cinzel',serif;letter-spacing:0.5px}
.hero-direct a:hover{color:var(--gold-shine)}
.hero-direct .sep{opacity:0.4}
.hero-coords{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:3rem}
.hero-coord{text-align:center}
.hero-coord-val{font-family:'Cinzel',serif;font-size:var(--fs-xl);font-weight:700;color:var(--brass-glow);line-height:1;text-shadow:0 0 20px var(--brass-glow-40)}
.hero-coord-label{font-size:var(--fs-xs);color:var(--bone);text-transform:uppercase;letter-spacing:2px;margin-top:0.4rem;font-weight:600;opacity:0.85}

/* ===== SECTIONS ===== */
section{padding:5rem 1.25rem;position:relative;overflow:hidden}
.container{max-width:min(1200px,100%);margin:0 auto;position:relative;z-index:1}
.section-divider{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--brass-glow-18),transparent)}
.section-divider.top{top:0}
.section-divider.bottom{bottom:0}
.section-header{margin-bottom:3rem}
.section-flag{display:flex;align-items:center;gap:0.85rem;margin-bottom:1rem}
.section-flag-icon{width:34px;height:34px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--brass-light),var(--brass));display:inline-flex;align-items:center;justify-content:center;color:var(--abyss);box-shadow:0 2px 8px var(--brass-glow-20),inset 0 1px 0 rgba(255,255,255,0.2)}
.section-flag-icon svg{width:18px;height:18px}
.section-flag-text{font-family:'Cinzel',serif;font-size:0.75rem;letter-spacing:3px;text-transform:uppercase;color:var(--brass-glow);font-weight:600}
.section-title{font-family:'Cinzel',serif;font-weight:700;font-size:var(--fs-h2);color:var(--bone);line-height:1.2;letter-spacing:1px}
.section-title em{font-family:'Lora',serif;font-style:italic;color:var(--brass-glow);font-weight:500;letter-spacing:0}
.section-desc{color:var(--text-light);font-size:1rem;max-width:620px;line-height:1.8;margin-top:1rem;font-family:'Lora',serif;opacity:0.9}

/* ===== ABOUT ===== */
#oklubie{background:var(--midnight)}
.about-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl);align-items:center}
.about-text p{color:var(--text-light);line-height:1.9;margin-bottom:1.5rem;font-size:0.95rem;font-family:'Lora',serif;opacity:0.92}
.about-visual{position:relative;display:flex;justify-content:center}
.about-illustration{width:100%;max-width:480px;position:relative}
.about-illustration .img-placeholder{aspect-ratio:4/3;margin-bottom:0;font-size:0.8rem}
.about-memberships{display:flex;flex-wrap:wrap;gap:0.6rem;margin-top:2rem;list-style:none;padding:0}
.about-membership{
  background:var(--brass-glow-10);border:1px solid var(--brass-glow-35);
  padding:0.5rem 1rem;border-radius:var(--radius-pill);font-size:0.78rem;
  color:var(--brass-glow);letter-spacing:0.5px;font-weight:700;
}

/* ===== CARDS COMMON ===== */
.dark-card{
  background:linear-gradient(180deg,var(--hull),var(--midnight));
  border:1px solid var(--brass-glow-15);
  border-radius:var(--radius);overflow:hidden;
  transition:transform 0.4s,box-shadow 0.4s,border-color 0.4s;
  position:relative;contain:layout paint;
  box-shadow:var(--shadow-md);
}
.dark-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--brass-glow-40)}
.dark-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brass-light),var(--brass-glow));transform:scaleX(0);transition:transform 0.4s;transform-origin:left;z-index:2}
.dark-card:hover::before{transform:scaleX(1)}

/* ===== OFFER ===== */
#oferta{background:var(--deep)}
.offer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}
.offer-card{padding:1.5rem}
.offer-card .img-placeholder{aspect-ratio:4/3;margin-bottom:1.25rem}
.offer-card h3{font-family:'Cinzel',serif;font-weight:700;font-size:1.05rem;color:var(--bone);margin-bottom:0.75rem;letter-spacing:1px}
.offer-card p{color:var(--text-light);font-size:0.9rem;line-height:1.7;font-family:'Lora',serif;opacity:0.88}
.offer-cta{margin-top:var(--space-lg);text-align:center}

/* ===== TRAINING ===== */
#szkolenia{background:linear-gradient(135deg,var(--abyss) 0%,var(--midnight) 100%)}
#szkolenia::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 0%,var(--brass-glow-05),transparent 60%);pointer-events:none}
.training-grid{display:grid;grid-template-columns:1fr;gap:var(--space-lg)}
.training-card{display:flex;flex-direction:column;background:rgba(20,46,72,0.5)}
.training-card-body{padding:2rem}
.training-card h3{font-family:'Cinzel',serif;font-size:var(--fs-lg);color:var(--bone);margin-bottom:1rem;letter-spacing:1px}
.training-card p{color:var(--text-light);line-height:1.8;font-size:0.95rem;font-family:'Lora',serif;opacity:0.9}
.training-link{display:inline-flex;align-items:center;gap:0.5rem;margin-top:1.5rem;color:var(--brass-glow);font-weight:700;text-decoration:none;font-size:1rem;transition:color 0.3s;min-height:44px}
.training-link:hover{color:var(--gold-shine)}

/* ===== AKTUALNOŚCI ===== */
#aktualnosci{background:var(--deep)}
.news-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}
.news-card{display:flex;flex-direction:column}
.news-card-body{padding:1.75rem;display:flex;flex-direction:column;flex:1}
.news-meta{display:flex;align-items:center;gap:0.85rem;margin-bottom:1rem;flex-wrap:wrap}
.news-date{font-family:'Cinzel',serif;font-size:var(--fs-xs);font-weight:700;color:var(--brass-glow);letter-spacing:2px;text-transform:uppercase}
.news-card h3{font-family:'Cinzel',serif;font-weight:700;font-size:var(--fs-md);color:var(--bone);margin-bottom:0.75rem;line-height:1.35;letter-spacing:0.5px}
.news-card p{color:var(--text-light);font-size:0.9rem;line-height:1.7;font-family:'Lora',serif;margin-bottom:1.25rem;flex:1;opacity:0.9}
.news-link{color:var(--brass-glow);text-decoration:none;font-size:0.8rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;display:inline-flex;align-items:center;gap:0.4rem;transition:gap 0.3s,color 0.3s;align-self:flex-start;padding:0.5rem 0;min-height:44px}
.news-link:hover,.news-card:hover .news-link{gap:0.7rem;color:var(--gold-shine)}
.news-link svg{width:14px;height:14px}
.news-cta{text-align:center;margin-top:3rem}

/* ===== HISTORY ===== */
#historia{background:var(--midnight)}
.history-layout{display:grid;grid-template-columns:1fr;gap:var(--space-xl);align-items:start}
.history-text{font-family:'Lora',serif;color:var(--text-light);line-height:2;font-size:0.95rem;opacity:0.92}
.history-text p{margin-bottom:1.5rem}
.history-text p:first-child::first-letter{font-family:'Cinzel',serif;font-size:2rem;color:var(--brass-glow);float:left;margin-right:0.35rem;line-height:1;font-weight:700}
.history-image{margin-bottom:2.5rem}
.history-image .img-placeholder{aspect-ratio:4/3;margin-bottom:0}
.history-timeline{position:static;margin-top:2rem;border-left:2px solid var(--brass-glow-40);padding-left:2rem}
.timeline-item{position:relative;margin-bottom:2.5rem}
.timeline-item::before{content:'';position:absolute;left:-2.55rem;top:0.5rem;width:12px;height:12px;border-radius:50%;background:var(--brass-glow);box-shadow:0 0 0 4px var(--midnight),0 0 0 6px var(--brass-glow-40),0 0 12px var(--brass-glow-50)}
.timeline-year{font-family:'Cinzel',serif;font-size:2rem;color:var(--brass-glow);font-weight:700;line-height:1;text-shadow:0 0 15px var(--brass-glow-30)}
.timeline-desc{color:var(--text-light);font-size:0.9rem;margin-top:0.4rem;font-family:'Lora',serif;line-height:1.6;opacity:0.92}

/* ===== PRICING ===== */
#cennik{background:var(--deep)}
.pricing-table{display:flex;flex-direction:column;gap:1.5rem}
.pricing-group{
  width:100%;border-collapse:collapse;
  background:var(--hull);border:1px solid var(--brass-glow-20);
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card-hover);
}
.pricing-group caption{
  background:linear-gradient(135deg,var(--hull-light),var(--steel));
  padding:1rem 1.5rem;font-family:'Cinzel',serif;font-weight:700;
  font-size:1rem;color:var(--brass-glow);letter-spacing:1px;
  text-align:left;display:flex;align-items:center;gap:0.85rem;
  border-bottom:1px solid var(--brass-glow-20);caption-side:top;
}
.pricing-group caption svg{width:20px;height:20px;flex-shrink:0}
.pricing-group thead{position:absolute;left:-9999px}
.pricing-group tbody tr{display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,0.04);transition:background 0.3s;gap:0.4rem}
.pricing-group tbody tr:hover{background:var(--brass-glow-06)}
.pricing-group tbody tr:last-child{border-bottom:none}
.pricing-group th[scope="row"]{color:var(--text-light);font-size:0.92rem;flex:1;font-family:'Lora',serif;font-weight:400;text-align:left;opacity:0.92}
.pricing-group td{color:var(--brass-glow);font-weight:700;font-size:1rem;font-family:'Cinzel',serif;white-space:nowrap;letter-spacing:0.5px}
.pricing-group th a,.pricing-group td a{color:var(--brass-glow);text-decoration:underline}
.pricing-warning{background:rgba(232,90,90,0.08);border:1px solid rgba(232,90,90,0.3);border-left:3px solid var(--red-flag);border-radius:var(--radius);padding:1.25rem 2rem;margin-top:1.5rem;color:#f0c0c0;font-size:0.9rem;line-height:1.7;font-family:'Lora',serif}
.pricing-warning strong{color:var(--red-flag);font-weight:700}
.pricing-warning a{color:var(--red-flag);text-decoration:underline;font-weight:700}
.pricing-bank{margin-top:1.5rem;color:var(--text-light);font-size:0.9rem;opacity:0.9}
.pricing-bank span{color:var(--brass-glow);font-weight:700;font-family:'Cinzel',serif;letter-spacing:0.5px}

/* ===== ATTRACTIONS ===== */
#atrakcje{background:var(--midnight)}
.attractions-grid{display:grid;grid-template-columns:1fr;gap:var(--space-md)}
.attraction-card{display:flex;flex-direction:column}
.attraction-card-body{padding:1.5rem 1.75rem 1.75rem}
.attraction-card h3{font-family:'Cinzel',serif;font-weight:700;font-size:1rem;color:var(--bone);margin-bottom:0.75rem;letter-spacing:1px}
.attraction-card p{color:var(--text-light);font-size:0.88rem;line-height:1.7;font-family:'Lora',serif;opacity:0.9}

/* ===== CONTACT ===== */
#kontakt{background:linear-gradient(180deg,var(--deep),var(--abyss));padding-bottom:4rem}
.contact-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}
.contact-cards{display:flex;flex-direction:column;gap:1rem}
.contact-card{background:rgba(20,46,72,0.5);border:1px solid var(--brass-glow-15);border-radius:var(--radius);padding:1.5rem 1.75rem;display:flex;align-items:flex-start;gap:1.25rem;transition:transform 0.3s,border-color 0.3s,background 0.3s}
.contact-card:hover{border-color:var(--brass-glow-40);background:rgba(20,46,72,0.7);transform:translateX(3px)}
.contact-card-img{
  width:48px;height:48px;border-radius:var(--radius);
  background:linear-gradient(135deg,var(--brass-light),var(--brass));
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--abyss);
  box-shadow:0 2px 8px var(--brass-glow-20);
}
.contact-card-img svg{width:22px;height:22px}
.contact-card h3{font-family:'Cinzel',serif;font-size:0.95rem;color:var(--brass-glow);margin-bottom:0.3rem;letter-spacing:0.5px;font-weight:700}
.contact-card p,.contact-card a{color:var(--text-light);font-size:0.9rem;line-height:1.6;text-decoration:none;transition:color 0.3s;font-family:'Lora',serif;opacity:0.95}
.contact-card a:hover{color:var(--brass-glow)}
.contact-card p,.contact-card a,.training-link{overflow-wrap:anywhere}
.contact-hours{color:var(--brass-glow);font-weight:700;font-family:'Cinzel',serif;font-size:0.78rem;letter-spacing:1px;margin-top:0.4rem;display:block}
.contact-map{margin-top:1rem;border-radius:var(--radius);overflow:hidden;border:1px solid var(--brass-glow-20);box-shadow:var(--shadow-md)}
.contact-map iframe{display:block;width:100%;height:280px;border:0;filter:saturate(0.8) contrast(1.1) brightness(0.85)}
.contact-form-box{background:linear-gradient(180deg,var(--hull),var(--deep));border:1px solid var(--brass-glow-20);border-radius:12px;padding:1.75rem;box-shadow:var(--shadow-card-hover)}
.contact-form-box h3{font-family:'Cinzel',serif;font-size:var(--fs-lg);color:var(--bone);margin-bottom:1.5rem;letter-spacing:1px}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;color:var(--brass-glow);font-size:0.75rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:0.5rem;font-weight:700}
.form-group label .req{color:var(--red-flag);margin-left:2px}
.form-group input,.form-group textarea{width:100%;padding:0.85rem 1.1rem;background:rgba(5,13,26,0.6);border:1px solid var(--brass-glow-25);border-radius:var(--radius-md);color:var(--bone);font-family:'Lora',serif;font-size:0.95rem;transition:border-color 0.3s,box-shadow 0.3s,background 0.3s;outline:none;min-height:44px}
.form-group input::placeholder,.form-group textarea::placeholder{color:#9fb5ce;opacity:1}
.form-group input:hover,.form-group textarea:hover{border-color:var(--brass-glow-45)}
.form-group input:focus,.form-group textarea:focus{border-color:var(--brass-glow);box-shadow:0 0 0 3px var(--brass-glow-15);background:rgba(5,13,26,0.8)}
.form-group input:invalid:not(:placeholder-shown),.form-group textarea:invalid:not(:placeholder-shown){border-color:var(--red-flag)}
.form-group input[aria-invalid="true"],.form-group textarea[aria-invalid="true"]{border-color:var(--red-flag)}
.form-error{display:block;color:var(--red-flag);font-size:0.8rem;font-family:'Lora',serif;margin-top:0.35rem;min-height:1.1em}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr;gap:1rem}
.btn-submit{width:100%;padding:1rem;margin-top:0.5rem;background:linear-gradient(135deg,var(--brass-glow),var(--brass-light));color:var(--abyss);border:none;border-radius:var(--radius-md);font-weight:700;font-size:var(--fs-sm);cursor:pointer;font-family:'Source Sans 3',sans-serif;letter-spacing:2px;text-transform:uppercase;transition:transform 0.35s,box-shadow 0.35s,background 0.35s;min-height:48px}
.btn-submit:hover{background:linear-gradient(135deg,var(--gold-shine),var(--brass-glow));box-shadow:var(--shadow-glow-brass);transform:translateY(-2px)}
.form-status{margin-top:0.85rem;font-size:var(--fs-sm);font-family:'Lora',serif;color:var(--brass-glow);min-height:1.2em}
.form-fallback{margin-top:1rem;font-size:0.8rem;color:var(--text-mid);font-family:'Lora',serif;text-align:center}
.form-fallback a{color:var(--brass-glow);text-decoration:none;font-weight:700}
.form-fallback a:hover{color:var(--gold-shine)}

/* ===== FOOTER ===== */
footer{background:var(--abyss);color:var(--text-mid);padding:2.5rem 2rem;border-top:1px solid var(--brass-glow-20)}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;text-align:center;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:0.4rem 1.25rem}
.footer-nav a{color:var(--text-mid);text-decoration:none;font-size:var(--fs-sm);padding:0.3rem 0;transition:color 0.3s}
.footer-nav a:hover{color:var(--brass-glow)}
.footer-contact{font-size:var(--fs-sm);display:flex;gap:0.6rem;align-items:center}
.footer-contact a{color:var(--brass-glow);text-decoration:none;font-weight:700;padding:0.3rem 0}
.footer-contact a:hover{color:var(--gold-shine)}
.footer-copy{font-size:var(--fs-sm);font-family:'Lora',serif;color:var(--text-light);opacity:0.85}
.footer-coords{font-family:'Cinzel',serif;font-weight:700;font-size:0.8rem;letter-spacing:1.5px;color:var(--brass-glow);opacity:0.8}

/* ===== RESPONSIVE — mobile-first (base = mobile, min-width steps up) ===== */
@media (min-width:768px){
  /* Tablet i wyżej: 2-column grids gdzie sensowne */
  .news-grid,.attractions-grid,.offer-grid{grid-template-columns:repeat(2,1fr)}
  .training-grid,.about-grid,.history-layout,.contact-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr 1fr}
  /* Nav: visible horizontal, hamburger ukryty */
  .nav-links{display:flex;position:static;background:transparent;flex-direction:row;gap:1.75rem;padding-top:0;padding-left:0;width:auto;height:auto;align-items:center;justify-content:flex-end;list-style:none}
  .nav-links a{font-size:0.78rem;padding:0.4rem 0;color:var(--text-mid);min-height:auto}
  .nav-hamburger{display:none}
  /* Hero rozkroczony */
  .hero-coords{gap:1.5rem}
  .hero-coord-val{font-size:1.7rem}
  .hero-coord-label{font-size:var(--fs-xs)}
  .hero-direct{font-size:var(--fs-sm)}
  /* Sections większe padding */
  section{padding:7rem 2rem}
  /* Bg-illus widoczne */
  .bg-illus{display:block}
  /* Footer: row layout */
  .footer-inner{flex-direction:row;text-align:left}
  /* Pricing: row tr + widoczne nagłówki kolumn (mobile: sr-only) */
  .pricing-group tbody tr{flex-direction:row;align-items:center;justify-content:space-between;gap:2rem;padding:0.95rem 2rem}
  .pricing-group caption{padding:1.1rem 2rem}
  .pricing-group thead{position:static;left:auto}
  .pricing-group thead tr{display:flex;justify-content:space-between;gap:2rem;padding:0.6rem 2rem;border-bottom:1px solid var(--brass-glow-20)}
  .pricing-group thead th{font-family:'Cinzel',serif;font-size:0.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);text-align:left}
  /* Nav phone: sama ikona na tablecie */
  .nav-phone{display:inline-flex}
  .nav-phone span{display:none}
  /* Contact form większy padding */
  .contact-form-box{padding:2.5rem}
  /* Cards: backdrop blur (lepszy GPU desktop) */
  .training-card,.contact-card{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
}
@media (min-width:1024px){
  /* Desktop: pełne grids */
  .offer-grid{grid-template-columns:repeat(4,1fr)}
  .news-grid,.attractions-grid{grid-template-columns:repeat(3,1fr)}
  /* Nav phone CTA: pełny numer */
  .nav-phone span{display:inline}
  /* History timeline sticky */
  .history-timeline{position:sticky;top:120px;margin-top:0}
}

/* ===== MOTION ===== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
  html{scroll-behavior:auto}
  .hero-water,.hero-sailboat,.hero-lighthouse::after{animation:none!important}
}

/* ===== NEWS CARDS — clickable wrapper ===== */
.news-card-link:focus-visible{outline:2px solid var(--brass-glow);outline-offset:3px;border-radius:var(--radius-md)}
@supports selector(:has(a)){
  .news-card-link:focus-visible{outline:none}
  .news-card:has(.news-card-link:focus-visible){outline:2px solid var(--brass-glow);outline-offset:3px;border-radius:var(--radius-md)}
}
.news-card-image{width:100%;height:auto;aspect-ratio:1200/750;object-fit:cover;display:block}
.news-card .news-card-body{flex:1;display:flex;flex-direction:column}
.news-card .news-link{margin-top:auto;padding-top:1rem;display:inline-flex;align-items:center;gap:0.5rem;color:var(--brass-glow);font-weight:600;font-size:0.95rem}
.news-card .news-link svg{width:1em;height:1em;transition:transform 0.2s}
.news-card:hover .news-link svg{transform:translateX(3px)}
.news-empty{grid-column:1/-1;text-align:center;color:var(--text-mid);padding:2rem}

/* ===== ARTICLE PAGE ===== */
.article-page{padding:8rem 0 5rem;background:var(--midnight)}
.container-narrow{max-width:760px;margin:0 auto;padding:0 var(--space-md)}
.breadcrumb{font-size:0.9rem;color:var(--text-mid);margin-bottom:2rem;display:flex;flex-wrap:wrap;gap:0.5rem;align-items:center}
.breadcrumb a{color:var(--brass-glow);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb [aria-current]{color:var(--text-light)}
.draft-banner{background:var(--brass-glow-12);border-left:3px solid var(--brass-glow);color:var(--brass-glow);padding:0.75rem 1rem;margin-bottom:1.5rem;font-weight:600;border-radius:var(--radius-sm)}
.article-header{margin-bottom:2rem}
.article-date{display:inline-block;color:var(--brass-glow);font-size:0.95rem;letter-spacing:0.05em;text-transform:uppercase;font-weight:600;margin-bottom:1rem}
.article-title{font-family:'Cinzel',serif;font-size:var(--fs-h1);line-height:1.2;color:var(--bone);margin-bottom:1.5rem}
.article-lead{font-size:1.2rem;line-height:1.6;color:var(--text-light);font-family:'Lora',serif;font-style:italic;margin-bottom:0}
.article-figure{margin:2.5rem 0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}
.article-figure img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}
.article-content{font-size:1.05rem;line-height:1.75;color:var(--text-light)}
.article-content p{margin-bottom:1.2rem}
.article-content h3{font-family:'Cinzel',serif;color:var(--bone);font-size:var(--fs-xl);margin:2rem 0 1rem}
.article-content h4{color:var(--brass-glow);font-size:1.15rem;margin:1.5rem 0 0.75rem}
.article-content a{color:var(--brass-glow);text-decoration:underline}
.article-content a:hover{color:var(--gold-shine)}
.article-content ul,.article-content ol{margin:1rem 0 1.2rem 1.5rem}
.article-content li{margin-bottom:0.5rem}
.article-content blockquote{border-left:3px solid var(--brass-glow);padding:0.5rem 0 0.5rem 1.25rem;margin:1.5rem 0;font-style:italic;color:var(--text-mid)}
.article-content strong{color:var(--bone)}
.article-gallery{margin:3rem 0}
.article-gallery-title{font-family:'Cinzel',serif;color:var(--bone);font-size:var(--fs-xl);margin-bottom:1.25rem}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:0.75rem}
.gallery-item{display:block;border-radius:var(--radius-md);overflow:hidden;cursor:zoom-in;background:var(--hull);position:relative;aspect-ratio:1}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.3s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item:focus-visible{outline:2px solid var(--brass-glow);outline-offset:2px}
.article-cta{margin:2.5rem 0;text-align:center}
.article-back{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--steel)}
.article-others{padding:4rem 0 5rem;background:var(--deep);position:relative}
.article-others::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--brass-glow-18),transparent)}
.article-others-title{font-family:'Cinzel',serif;color:var(--bone);font-size:1.8rem;margin-bottom:2rem;text-align:center}
.page-404{padding:10rem 0 6rem;text-align:center}
.page-404 h1{font-family:'Cinzel',serif;color:var(--bone);font-size:2.5rem;margin-bottom:1rem}
.page-404 p{color:var(--text-mid);margin-bottom:1.5rem}

/* ===== LIGHTBOX ===== */
.lightbox-overlay{position:fixed;inset:0;background:rgba(5,13,26,0.95);z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem;opacity:0;pointer-events:none;transition:opacity 0.2s}
.lightbox-overlay.open{opacity:1;pointer-events:auto}
.lightbox-image{max-width:100%;max-height:85vh;display:block;border-radius:var(--radius-sm)}
.lightbox-caption{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:var(--text-light);background:rgba(5,13,26,0.7);padding:0.5rem 1rem;border-radius:var(--radius-sm);font-size:0.95rem;max-width:80%;text-align:center}
.lightbox-close,.lightbox-prev,.lightbox-next{position:absolute;background:rgba(20,46,72,0.8);border:1px solid var(--steel);color:var(--bone);width:48px;height:48px;border-radius:50%;font-size:var(--fs-xl);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{border-color:var(--brass-glow);color:var(--brass-glow)}
.lightbox-close{top:1.5rem;right:1.5rem}
.lightbox-prev{left:1.5rem;top:50%;transform:translateY(-50%)}
.lightbox-next{right:1.5rem;top:50%;transform:translateY(-50%)}
@media (max-width:600px){.lightbox-prev,.lightbox-next{width:40px;height:40px;font-size:1.25rem}.lightbox-close{top:1rem;right:1rem}}

/* ===== NEWS LIST PAGE ===== */
.news-list-page{padding:8rem 0 5rem}
.pagination{margin-top:3rem;display:flex;justify-content:center;align-items:center;gap:1rem;flex-wrap:wrap}
.pagination-btn{padding:0.6rem 1rem;border:1px solid var(--steel);color:var(--text-light);text-decoration:none;border-radius:var(--radius-md);font-weight:600;transition:all 0.2s}
.pagination-btn:hover{border-color:var(--brass-glow);color:var(--brass-glow)}
.pagination-pages{display:flex;list-style:none;gap:0.4rem;padding:0;margin:0}
.pagination-pages a,.pagination-current{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);text-decoration:none;font-weight:600;transition:all 0.2s}
.pagination-pages a{color:var(--text-mid);border:1px solid transparent}
.pagination-pages a:hover{color:var(--brass-glow);border-color:var(--steel)}
.pagination-current{background:var(--brass-glow);color:var(--abyss)}
.pagination-ellipsis{display:flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--text-dim)}
