:root{
  --bg:#00040d;
  --card:#121223;
  --fg:#f6f6fb;
  --muted:#b9bbcf;
  --link:#57d2ff;

  --accent:#8a7bff;
  --accent-2:#57d2ff;

  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.35);

  --font-sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial,sans-serif;
  --font-serif:'Cinzel',serif;

  /* specyficzny kolor dla przycisku &#8222;Czytaj&#8221; w kafelku artykułu */
  --read-btn-bg:#1f2330;
  --read-btn-border:#2b3245;
  --read-btn-fg:#e6f1ff;
}

/* podstawa */
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--fg);
  font-weight:400;
}
p, li, a, small, span, div, label, input, button{ font-weight:400; }

/* header */
header{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:16px;
  align-items:center;
  max-width:1200px;
  margin:0 auto;
  padding:16px 16px 0;
  text-align:left;
}
header .logo{ max-width:420px; height:auto; }
header h1{
  margin:0 0 6px;
  font-family:var(--font-serif);
  font-weight:700;
  letter-spacing:.02em;
  font-size:clamp(22px,2.4vw,34px);
}
header p{margin:0;color:var(--muted)}

.wrap{max-width:1200px;margin:16px auto 64px;padding:0 16px}

/* linki */
a, a:visited{color:var(--link)}
a:hover, a:focus-visible{
  color:var(--link);
  text-decoration:underline;
  text-underline-offset:2px;
  outline:none;
}

/* siatka kart */
.catalog{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:16px;
  align-items:start;
}

/* karta */
.card{
  position:relative;
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  aspect-ratio:2/3.2;
  display:grid;
  grid-template-rows:1fr auto;
  transition:transform .2s, box-shadow .2s;
}
@media(hover:hover){
  .card:hover{transform:translateY(-2px); box-shadow:0 14px 40px rgba(0,0,0,.5)}
}
.photo img{width:100%;height:100%;object-fit:cover;display:block}

/* pasek dolny na zdjęciu */
.label{
  position:absolute; left:0; right:0; bottom:0;
  padding:10px 12px 12px;
  background:linear-gradient(180deg,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,.72) 40%,
    rgba(0,0,0,.94) 100%
  );
  display:flex; align-items:flex-end; justify-content:space-between; gap:10px; z-index:2;
}
.name{
  font-family:var(--font-serif);
  font-weight:700;
  letter-spacing:.02em;
  font-size:1.2rem;
}
.pill{
  font-size:.82rem;
  color:#fffbf0;
  font-weight:600;
}

/* przyciski */
.btn{
  appearance:none; border:0; border-radius:3px;
  padding:.20rem .50rem; font-weight:800; cursor:pointer;
  color:#00040d; background:#FFF0D4;
  font-family:var(--font-sans);
  line-height:1.1;
}

/* wariant tekstowy (np. &#8222;Kontakt&#8221; jako linko-przycisk) */
.btn_txt{
  appearance:none;
  display:inline-flex; align-items:center; gap:.4ch;
  border:0; border-radius:6px;
  padding:.20rem .70rem;
  font-family:var(--font-sans);
  font-weight:600; cursor:pointer;
  color:#f6f6fb !important;
  text-decoration:none !important; line-height:1.1;
  transition: color .18s ease, transform .18s ease, box-shadow .18s ease, background .18s ease;
  will-change: transform;
}

/* hover: kolor + delikatne uniesienie */
.btn_txt:hover{
  color:#8ED4FF !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(0,146,220,.18);
  background: rgba(0,146,220,.08);
}

/* focus (klawiatura) &#8211; wyraźny, ale nie agresywny */
.btn_txt:focus-visible{
  outline: none;
  box-shadow: 0 0 0 2px rgba(0,146,220,.35);
  background: rgba(0,146,220,.10);
}

/* active: subtelne &#8222;dociśnięcie&#8221; */
.btn_txt:active{
  transform: translateY(0);
  box-shadow: 0 3px 8px rgba(0,146,220,.18);
}


/* kafelek artykułu &#8211; inny kolor przycisku &#8222;Czytaj&#8221; */
.card--article .btn{
  background:var(--read-btn-bg);
  color:var(--read-btn-fg);
  border:1px solid var(--read-btn-border);
}

/* dane ukryte w kafelku (do modala) */
.expand, .cta{ display:none }

/* backdrop + modal (globalne) */
.backdrop{
  position:fixed; inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(2px);
  z-index:1000; opacity:0; pointer-events:none; transition:opacity .2s ease;
}
.backdrop.show{opacity:1; pointer-events:auto}
.backdrop[hidden], .modal[hidden]{display:none !important}

.modal{
  position:fixed; inset:auto 0 0 0; margin:auto; width:100%; max-width:960px;
  background:var(--card); border-radius:16px 16px 0 0; box-shadow:0 25px 80px rgba(0,0,0,.65);
  z-index:1001; transform:translateY(100%); transition:transform .28s ease;
  display:flex; flex-direction:column; max-height:92dvh; overflow:hidden;
}
.modal.show{transform:translateY(0)}
@media(min-width:768px){
  .modal{
    inset:50% auto auto 50%;
    transform:translate(-50%, calc(50% + 16px));
    width:min(92vw,780px); border-radius:20px;
  }
  .modal.show{ transform:translate(-50%,-50%) }
}

/* modal: nagłówek i foto */
.modal__header{position:relative; padding:0}
.modal__photo{width:100%; max-height:48vh; overflow:hidden; background:#000}
.modal__photo img{width:100%; height:auto; object-fit:contain; display:block}
.modal__bar{
  position:absolute; left:0; right:0; bottom:0;
  padding:10px 12px;
  background:linear-gradient(180deg,rgba(0,0,0,0) 0%, rgba(0,0,0,.6) 40%, rgba(0,0,0,.95) 100%);
  display:flex; align-items:flex-end; justify-content:space-between; gap:10px;
}
.modal__name{
  font-family:var(--font-serif);
  font-weight:700; letter-spacing:.02em;
  font-size:1.25rem;
}
.modal__pill{font-size:.86rem; color:#fffbf0}
.modal__close{
  position:absolute; top:8px; right:8px; border:0; border-radius:10px;
  padding:.4rem .6rem; background:rgba(0,0,0,.7); color:#fff; font-weight:800; cursor:pointer;
}

/* modal: treść */
.modal__body{
  flex:1 1 auto; min-height:0; overflow:auto; -webkit-overflow-scrolling:touch;
  padding:12px 16px;
  background:linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.85) 100%);
}
.modal__body h3{
  margin:.2rem 0 .5rem;
  font-size:1.5rem;
  font-family:var(--font-serif);
  font-weight:600;
}
.modal__body p{margin:.2rem 0 .7rem; color:var(--muted); font-size:1rem}

/* modal: stopka */
.modal__footer{
  position:sticky; bottom:0;
  background:rgba(0,0,0,.88);
  border-top:1px solid rgba(255,255,255,.08);
  padding:12px 16px;
}
.modal__footer p {
margin:0px;
padding:0px 0px 0px 20px;
}
.sms{;
  word-break:break-word;
  overflow-wrap:anywhere;
  padding:0px 0px 10px 20px;
}
.disclaimer{
  font-size:.9rem;
  color:var(--muted);
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;   /* <-- wyśrodkuj w poziomie */
  text-align:center;        /* <-- centrowanie tekstu przy zawijaniu */
  margin:.3rem 0 0;
  width:100%;               /* upewnij się, że zajmuje pełną szerokość */
}

.footer-links{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;   /* <-- wyśrodkuj w poziomie */
  margin-top:23px;
  text-align:center;        /* opcjonalnie (gdy linki łamią się w linie) */
}


@media(min-width:768px){ .sms{font-size:1.5rem; font-size:1.5rem; font-weight:800; color:#DC0000} }

body.lock{overflow:hidden; height:100dvh}

/* cookie banner (bez zmian funkcjonalnych) */
.cookie-banner{
  position:fixed; left:0; right:0; bottom:0;
  background:#0f0f12; color:#f5f5f7;
  border-top:1px solid #26262c; z-index:9999;
  padding:16px 18px;
}
.cookie-inner{ width:min(1100px,92%); margin:0 auto; display:grid; gap:12px; }
.cookie-title{ font-weight:700; font-size:1.05rem; font-family:var(--font-sans) }
.cookie-row{ display:flex; flex-wrap:wrap; gap:10px 12px; align-items:center; }
.cookie-btn{ padding:10px 14px; border:0; border-radius:999px; font-weight:700; cursor:pointer; }
.cookie-btn.primary{ background:#6ee7ff; color:#031318; }
.cookie-btn.secondary{ background:#1e1e24; color:#f5f5f7; border:1px solid #2a2a31; }
.cookie-modal{
  position:fixed; inset:0; background:rgba(0,0,0,.6);
  display:none; align-items:center; justify-content:center; z-index:10000;
}
.cookie-card{
  background:#17171c; color:#f5f5f7; width:min(560px,94%);
  border-radius:16px; border:1px solid #24242a; padding:16px; display:grid; gap:12px;
}
.cookie-list{ display:grid; gap:10px; }
.cookie-list label{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.cookie-list input{ transform:scale(1.2); }

/* sms sheet */
.sms-sheet{
  position:fixed; inset:0; display:none;
  align-items:center; justify-content:center;
  background:rgba(0,0,0,.45); backdrop-filter:blur(2px);
  z-index:10050;
}
.sms-sheet.show{ display:flex; }
.sms-card{
  width:min(520px,92vw);
  background:#17171c; color:#f5f5f7;
  border:1px solid #24242a; border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.55);
  padding:16px 16px 12px; position:relative;
}
.sms-title{ margin:0 0 20px; font-size:1.2rem; color:#00DCDC }
.sms-copy{ margin:0 0 10px; color:#c9cbe0; line-height:1.45; font-size:.95rem; }
.sms-links{ display:flex; gap:8px; align-items:center; color:#9aa0b8; font-size:.9rem; }
.sms-actions{ display:flex; justify-content:flex-end; margin-top:12px; }
.sms-btn.ok{ padding:8px 14px; border:0; border-radius:999px; font-weight:700; cursor:pointer; background:#6ee7ff; color:#031318; }
.sms-close{
  position:absolute; top:8px; right:8px; width:28px; height:28px; line-height:28px;
  border:0; border-radius:8px; background:#22232a; color:#eaeaf6; cursor:pointer; font-size:18px;
}
@media (max-width:480px){
  .sms-card{ padding:14px 14px 10px; }
  .sms-title{ font-size:1rem; }
  .sms-copy{ font-size:.92rem; }
}

/* stopka / logo LN */
.site-footer{ color:#b9bbcf; padding:5px; margin:15px 0; font-size:.95rem; display:flex; justify-content:center; }
.site-footer table{
  max-width:800px; width:100%; margin:0 auto;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px; padding:14px 16px; color:var(--fg);
}
.footer-wrap{ width:min(1100px,98%); margin:0 auto; display:grid; gap:10px; justify-items:center; }
.footer-brand{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; padding-bottom:7px;}
.footer-name{ color:#f6f6fb; font-weight:700; font-family:var(--font-sans) }
.footer-links{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; text-align:center; }
.footer-links a{ display:inline-block; }
.footer-copy{ color:#8f91a6; display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.footer-ecosystem p{ margin:10px; font-size:.8rem; font-weight:normal; }
.reklamacje{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }

.site-footer{ position:relative; }
.footer-wrap{ position:relative; }
.ln-logo{
  max-width:90px; height:auto; opacity:.95;
  transition:opacity .2s ease, transform .2s ease;
}

@media (max-width:640px){
  .ln-logo{ position:static; margin-left:auto; display:block; }
}

/* intro box */
.top-intro{
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:14px 16px;
  color:var(--fg);
}
.top-intro h2{
  margin:0 0 6px;
  font-size:clamp(18px,2vw,22px);
  font-weight:800;
  line-height:1.5;
  font-family:var(--font-serif);
}
.top-intro__lead{ margin:0 0 8px; color:var(--muted); line-height:1.5; }
.top-steps{ margin:0 0 8px 18px; padding:0; color:#dfe1f6; line-height:1.45; }
.top-steps li{ margin:2px 0; }
.top-steps em{ font-style:normal; color:#ffe5a4; font-weight:800; }
.top-legal{ margin:8px 0 6px; font-size:1rem; line-height:1.4; color:#c9cbe0; }
.top-links{ margin:0; font-size:.9rem; }

@media (max-width:820px){
  header{ grid-template-columns:1fr; text-align:left; }
  header .logo{ width:min(88vw,380px); }
  .top-intro{ padding:12px 14px; }
  .top-intro h2{ font-size:1rem; }
  .top-steps{ margin-left:16px; }
  .top-legal{ font-size:.88rem; }
  .top-links{ font-size:.88rem; }
}

.sms-langflags {
  display:flex; gap:8px; justify-content:center; align-items:center;
  margin-top:10px;
}
.sms-langflags .flag{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px; border-radius:10px; border:1px solid rgba(0,0,0,.15);
  background:#fff; cursor:pointer; font: inherit; line-height:1;
  transition: transform .08s ease, border-color .15s ease, background .15s ease;
}
.sms-langflags .flag span{ font-weight:600; font-size:12px; opacity:.9; }
.sms-langflags .flag[aria-pressed="true"]{
  border-color: var(--accent, #8a7bff);
  box-shadow: 0 0 0 2px rgba(138,123,255,.15) inset;
}
.sms-langflags .flag:active{ transform: scale(.98); }
@media (prefers-color-scheme: dark){
  .sms-langflags .flag{ background:#111318; border-color: rgba(255,255,255,.18); }
}
.site-lang{
  display:flex; gap:8px; align-items:center; margin:8px 0;
}
.site-lang--footer{ justify-content:center; margin:16px 0 24px; }

.site-lang .flag{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px; border-radius:10px; border:1px solid rgba(0,0,0,.15);
  background:#fff; cursor:pointer; font:inherit; line-height:1;
  transition:transform .08s ease, border-color .15s ease, background .15s ease;
}
.site-lang .flag span{ font-weight:600; font-size:12px; opacity:.9; }
.site-lang .flag[aria-pressed="true"]{
  border-color: var(--accent, #8a7bff);
  box-shadow: 0 0 0 2px rgba(138,123,255,.15) inset;
}
.site-lang .flag:active{ transform: scale(.98); }

@media (prefers-color-scheme: dark){
  .site-lang .flag{ background:#111318; border-color: rgba(255,255,255,.18); }
}
.flag-ico{
  width: 18px;  /* możesz zmienić na 20px/24px */
  height: 12px;
  display:inline-block;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0,0,0,.15) inset;
  vertical-align: -2px; /* wyrównanie z tekstem */
}
.site-lang .flag{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px; border-radius:10px; border:1px solid rgba(0,0,0,.15);
  background:#fff; cursor:pointer; font:inherit; line-height:1;
}
.site-lang .flag[aria-pressed="true"]{
  border-color: var(--accent, #8a7bff);
  box-shadow: 0 0 0 2px rgba(138,123,255,.15) inset;
}
@media (prefers-color-scheme: dark){
  .site-lang .flag{ background:#111318; border-color: rgba(255,255,255,.18); }
  .flag-ico{ box-shadow: 0 0 0 1px rgba(255,255,255,.2) inset; }
}
/* Zostawiamy Twoje reguły&#8230; */
.ln-logo:hover{
  opacity:1;         /* OK */
  /* transform:translateY(-1px);  &#8592; usuń, by nie biło się z animacją linku */
}

/* Luna Noctis &#8212; efekt magiczny (shimmer + sparkles, #0092DC) */
a[href="https://lunanoctis.pl"]{
  position: relative;
  display: inline-block;
  line-height: 0;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.25));
  transition: filter .25s ease, transform .25s ease;
}
a[href="https://lunanoctis.pl"] .ln-logo{
  position: relative; z-index: 1;
  display:block;
  transition: transform .25s ease, filter .25s ease;
  will-change: transform, filter;
}


/* SPARKLES (iskierki) &#8212; nad obrazkiem, w tonacji #0092DC */
a[href="https://lunanoctis.pl"]::before{
  content:"";
  position:absolute; inset:-18% -6%;
  pointer-events:none;
  opacity:0;
  filter: blur(.2px);
  transform: scale(.96);
  z-index: 2;
  background:
    radial-gradient(6px 6px at 15% 35%, rgba(255,255,255,.95), transparent 60%),
    radial-gradient(5px 5px at 78% 22%, rgba(0,146,220,.95), transparent 60%),     /* #0092DC */
    radial-gradient(4px 4px at 40% 78%, rgba(140,220,255,.95), transparent 60%),   /* jaśniejszy błękit */
    radial-gradient(3px 3px at 68% 62%, rgba(120,200,255,.95), transparent 60%);
}

/* HOVER: aktywacja efektów (JEDYNY zestaw :hover) */
a[href="https://lunanoctis.pl"]:hover{
  transform: translateY(-2px);
  filter: drop-shadow(0 8px 22px rgba(0,146,220,.45));
}
a[href="https://lunanoctis.pl"]:hover .ln-logo{
  transform: scale(1.02);
  filter: saturate(1.06) drop-shadow(0 0 12px rgba(0,146,220,.55));
}
a[href="https://lunanoctis.pl"]:hover::after{
  opacity:1;
  animation: ln-shine 900ms cubic-bezier(.2,.6,.2,1) 1 forwards;
}
a[href="https://lunanoctis.pl"]:hover::before{
  opacity:1;
  animation: ln-sparkles 1200ms ease-in-out forwards;
}

/* Animacje */
@keyframes ln-shine{
  0%   { transform: translateX(-60%) skewX(-25deg); }
  100% { transform: translateX(160%) skewX(-25deg); }
}
@keyframes ln-sparkles{
  0%   { transform: translateY(3px) scale(.96); opacity:.0; }
  18%  { opacity:1; }
  60%  { transform: translateY(-2px) scale(1.03); }
  100% { transform: translateY(-4px) scale(1.06); opacity:.25; }
}

/* Preferencje dostępności */
@media (prefers-reduced-motion: reduce){
  a[href="https://lunanoctis.pl"],
  a[href="https://lunanoctis.pl"] .ln-logo,
  a[href="https://lunanoctis.pl"]::before,
  a[href="https://lunanoctis.pl"]::after{
    transition: none !important;
    animation: none !important;
  }
}
/* Header logo &#8212; tylko glow (#0092DC) + iskierki */
.logo{ width:300px; }
/* Header logo &#8212; glow + wyraźniejsze iskry (#0092DC), bez shimmera */
a[href="index.php"]{
  position: relative;
  display: inline-block;
  line-height: 0;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.25));
  transition: transform .25s ease, filter .25s ease;
  overflow: visible;            /* NIE przycinaj pseudo-elementu */
  z-index: 0;                   /* własny stacking context */
}
a[href="index.php"] .logo{
  position: relative;
  z-index: 1;                   /* obrazek poniżej iskierek */
  display: block;
  height: auto;
  transition: transform .25s ease, filter .25s ease;
  will-change: transform, filter;
}

/* Hover: delikatny podskok + niebieski glow */
a[href="index.php"]:hover{
  transform: translateY(-1px);
  filter: drop-shadow(0 6px 18px rgba(0,146,220,.38));
}
a[href="index.php"]:hover .logo{
  transform: scale(1.01);
  filter: saturate(1.04) drop-shadow(0 0 10px rgba(0,146,220,.45));
}

/* ISKRY &#8212; przycięte do obszaru logo, na wierzchu */
a[href="index.php"]::before{
  content:"";
  position:absolute; left:0; top:0; width:100%; height:100%;
  pointer-events:none;
  z-index: 2;                        /* NAD obrazkiem */
  opacity:0;
  transform: translateY(0) scale(1);
  filter: blur(.2px);
  mix-blend-mode: screen;            /* ładnie &#8222;świeci&#8221; na ciemnym */
  background:
    radial-gradient(6px 6px at 18% 28%, rgba(255,255,255,.95), transparent 60%),
    radial-gradient(5px 5px at 82% 22%, rgba(0,146,220,.95), transparent 60%),
    radial-gradient(4px 4px at 42% 78%, rgba(140,220,255,.95), transparent 60%),
    radial-gradient(3px 3px at 64% 62%, rgba(120,200,255,.95), transparent 60%),
    radial-gradient(3px 3px at 32% 58%, rgba(255,255,255,.8), transparent 60%),
	 radial-gradient(5px 5px at 12% 60%, rgba(0,146,220,.9), transparent 62%),
    radial-gradient(4px 4px at 28% 18%, rgba(140,220,255,.9), transparent 62%),
    radial-gradient(3px 3px at 50% 12%, rgba(255,255,255,.85), transparent 62%),
    radial-gradient(5px 5px at 70% 78%, rgba(0,146,220,.85), transparent 62%),
    radial-gradient(4px 4px at 86% 58%, rgba(120,200,255,.9), transparent 62%),
    radial-gradient(3px 3px at 38% 86%, rgba(255,255,255,.8), transparent 62%),
    radial-gradient(4px 4px at 58% 48%, rgba(140,220,255,.9), transparent 62%);
}
a[href="index.php"]:hover::before{
  opacity: 1;                      /* mocniej, żeby było widać */
  animation: hdr-sparkles 1400ms ease-in-out forwards;
}

/* &#8222;oddech&#8221; iskierek */
@keyframes hdr-sparkles{
  0%   { transform: translateY(2px) scale(.98); opacity:0; }
  20%  { opacity:.95; }
  60%  { transform: translateY(-1px) scale(1.01); }
  100% { transform: translateY(-2px) scale(1.03); opacity:.35; }
}

/* dostępność */
@media (prefers-reduced-motion: reduce){
  a[href="index.php"],
  a[href="index.php"] .logo,
  a[href="index.php"]::before{
    transition: none !important;
    animation: none !important;
  }
}