:root{
  --bg:#0b1220;
  --bg2:#0f1a2f;
  --text:#e8eefc;
  --muted:#b9c6e4;
  --card:rgba(10,16,30,0.55);
  --stroke:rgba(255,255,255,0.10);
  --accent:#7dd3fc;
  --accent2:#fbbf24;
  --shadow: 0 14px 40px rgba(0,0,0,0.45);
  --radius: 18px;
  --radius2: 24px;
  --navH: 72px;
  --max: 1180px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  font-family:var(--font);
  background: radial-gradient(900px 500px at 30% 0%, rgba(125,211,252,0.12), transparent 60%),
              radial-gradient(900px 600px at 70% 10%, rgba(251,191,36,0.10), transparent 60%),
              linear-gradient(180deg, var(--bg), var(--bg2));
  color:var(--text);
}

a{color:inherit; text-decoration:none;}
.main{padding-top:var(--navH); min-height: calc(100vh - var(--navH));}

/* Navbar */
.navbar{
  position:fixed; top:0; left:0; right:0;
  height:var(--navH);
  backdrop-filter: blur(10px);
  background: rgba(6,10,18,0.55);
  border-bottom: 1px solid var(--stroke);
  z-index:1000;
}
.navbar__inner{
  height:100%;
  max-width:var(--max);
  margin:0 auto;
  padding: 0 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  flex-wrap: nowrap;
}
.brand{display:flex; align-items:center; gap: 4px; white-space:nowrap; flex:0 0 auto;}
.brand__icon{
  width:36px; height:36px;
  display:grid; place-items:center;
  border-radius:12px;
  background: rgba(125,211,252,0.12);
  border:1px solid rgba(125,211,252,0.22);
}
.brand__text{font-weight:800; letter-spacing:0.2px;}

.nav{display:flex; gap:10px; flex:1 1 auto; min-width:0; flex-wrap:nowrap; justify-content:center; align-items:center; white-space:nowrap; overflow-x:auto; overflow-y:hidden; scrollbar-width:none; -webkit-overflow-scrolling: touch;}
.nav__link{
  white-space: nowrap;
  flex: 0 0 auto;

  padding:10px 12px;
  border-radius: 12px;
  border: 1px solid transparent;
  color: var(--muted);
  transition: transform .12s ease, background .12s ease, border-color .12s ease, color .12s ease;
}
.nav__link:hover{
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.10);
  color: var(--text);
  transform: translateY(-1px);
}
.nav__link.is-active{
  background: rgba(125,211,252,0.12);
  border-color: rgba(125,211,252,0.28);
  color: var(--text);
}

/* PRO highlight: Opinie */
.nav__link--opinie{
  position: relative;
  font-weight: 900;
  color: rgba(255,246,214,0.95);
  border-color: rgba(251,191,36,0.26);
  background: linear-gradient(180deg, rgba(251,191,36,0.18), rgba(10,16,28,0.20));
  box-shadow: 0 10px 28px rgba(0,0,0,0.30);
}
.nav__link--opinie:hover{
  background: linear-gradient(180deg, rgba(251,191,36,0.24), rgba(10,16,28,0.26));
  border-color: rgba(251,191,36,0.38);
}
.nav__link--opinie::after{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius: 14px;
  pointer-events:none;
  opacity:.0;
  border:1px solid rgba(251,191,36,0.35);
  animation: opinieRing 1.8s ease-out infinite;
}
@keyframes opinieRing{
  0%{ opacity: 0; transform: scale(0.95); }
  35%{ opacity: .55; }
  100%{ opacity: 0; transform: scale(1.08); }
}

.nav::-webkit-scrollbar{display:none;}

/* Clock */
.navRight{
  display:flex;
  align-items:center;
  gap: 12px;
  white-space: nowrap;
  flex: 0 0 auto;
}

.navBtn{
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  color: var(--text);
  font-weight: 800;
  letter-spacing: 0.2px;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.navBtn:hover{
  background: rgba(125,211,252,0.14);
  border-color: rgba(125,211,252,0.28);
  transform: translateY(-1px);
}

.clock{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:2px;
  min-width: 0;
}
.clock__time{font-weight:800; letter-spacing:0.3px;}
.clock__date{font-size:12px; color:var(--muted);}

/* Footer */
.footer{
  border-top: 1px solid var(--stroke);
  background: rgba(6,10,18,0.55);
  backdrop-filter: blur(10px);
}
.footer__inner{
  max-width:var(--max);
  margin:0 auto;
  padding: 16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.footer__links{display:flex; gap:14px; flex-wrap:wrap;}
.footer__link{color:var(--muted); padding:6px 10px; border-radius: 10px;}
.footer__link:hover{background: rgba(255,255,255,0.06); color:var(--text);}
.footer__note{color:var(--muted); font-size:12px;}

/* Generic page */
.page{padding: 44px 18px;}
.page__inner{max-width: var(--max); margin:0 auto;}
.page__title{margin: 0 0 8px 0; font-size: 36px;}
.page__desc{margin: 0 0 20px 0; color: var(--muted); max-width: 820px;}

.placeholder{
  border: 1px solid var(--stroke);
  border-radius: var(--radius2);
  padding: 18px;
  background: rgba(10,16,30,0.40);
  box-shadow: var(--shadow);
}
.placeholder__badge{
  display:inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(251,191,36,0.35);
  background: rgba(251,191,36,0.12);
  color: var(--text);
  font-weight: 700;
  margin-bottom: 10px;
}
.placeholder__text{margin:0; color: var(--muted); line-height: 1.55;}


/* Globalne tło z logo (widoczne na każdej podstronie) */
.site-bg{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(900px 600px at 20% 0%, rgba(125,211,252,0.10), transparent 60%),
    radial-gradient(900px 600px at 80% 20%, rgba(251,191,36,0.08), transparent 60%),
    url('../img/hero-bg.png') center / cover no-repeat;
  opacity:0.14;
  filter: saturate(1.05) contrast(1.05);
}
@media (max-width: 680px){
  .site-bg{opacity:0.12;}
}


/* Podstrony (Licencja/RODO/Regulamin/Kontakt) */
.page{padding: 26px 16px;}
.page__card{max-width: 980px; margin: 0 auto; background: var(--card); border: 1px solid var(--stroke); border-radius: var(--radius2); box-shadow: var(--shadow); padding: 22px 20px; backdrop-filter: blur(10px);}
.page__title{margin:0 0 10px 0; font-size: clamp(22px, 3vw, 30px); letter-spacing: -0.02em;}
.page__content{color: var(--text); line-height: 1.6;}
.list{margin: 12px 0 14px 0; padding-left: 18px;}
.list li{margin: 6px 0;}
.muted{color: var(--muted);}
.callout{margin: 14px 0; padding: 12px 14px; border-radius: 14px; border: 1px solid var(--stroke); background: rgba(15,26,47,0.55);}
code{background: rgba(255,255,255,0.08); padding: 2px 6px; border-radius: 8px;}


/* ===== BRAND ICON + TEXT TWEAK (AUTO) ===== */
.brand {
  display: flex;
  align-items: center;
  gap: 4px;
}

.brand__icon-img {
  width: 26px;
  height: 26px;
  display: block;
}

.brand__text {
  margin-left: -18px;
  letter-spacing: 0.2px;
}
/* ===== END BRAND ICON + TEXT TWEAK (AUTO) ===== */


/* ===== NAVBAR BRAND SPACING FIX (AUTO v3) ===== */
.navbar__inner {
  gap: 18px;            /* więcej luzu między brand a menu */
}

.brand {
  position: relative;
  z-index: 2;           /* brand zawsze nad podświetleniem linków */
  padding-right: 6px;   /* minimalny bufor */
}

.nav--center {
  padding-left: 10px;   /* odsuń pierwszy link (Start) od brand */
}

.brand__icon-svg {
  width: 28px;
  height: 28px;
  display: block;
}

.brand__text {
  margin-left: -10px;   /* bardziej w lewo, bliżej ikony */
}
/* ===== END NAVBAR BRAND SPACING FIX (AUTO v3) ===== */


/* ===== NAVBAR LEFT ALIGN (USER FIX) ===== */
/* Nie usuwamy niczego wyżej – tylko nadpisujemy, aby logo "Pogoda" było maksymalnie z lewej. */
.navbar__inner{
  justify-content: flex-start;
}

.nav{
  justify-content: flex-start;
}

/* Unikamy agresywnych ujemnych marginesów, które powodowały nachodzenie na Start */
.brand__text{
  margin-left: 0 !important;
}

/* Drobny odstęp, żeby "Start" nie wchodził na logo */
.nav{
  padding-left: 10px;
}
/* ===== END NAVBAR LEFT ALIGN (USER FIX) ===== */


/* ===== NAVBAR RIGHT ALIGN (USER FIX) ===== */
/* Nie ruszamy lewej strony (brand). Poprawiamy tylko prawą stronę (zegar + Zaloguj) */
.navRight{
  margin-left: auto;          /* przyklej do prawej krawędzi */
  padding-left: 14px;         /* oddech od ostatniego linku */
  gap: 14px;
  align-items: center;
}

.clock{
  min-width: 86px;            /* stabilna szerokość, nie "skacze" */
  padding: 6px 10px;          /* wygląda jak element UI */
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(8px);
}

.clock__time{
  font-size: 16px;
  line-height: 1.05;
}

.clock__date{
  font-size: 11px;
  line-height: 1.05;
}

.navBtn{
  white-space: nowrap;
  padding: 10px 16px;
  border-radius: 16px;
}

/* Na węższych ekranach: zachowaj prawą stronę, a menu niech się przewija */
@media (max-width: 900px){
  .navRight{ gap: 10px; padding-left: 10px; }
  .clock{ padding: 6px 8px; min-width: 78px; }
  .navBtn{ padding: 9px 14px; }
}
/* ===== END NAVBAR RIGHT ALIGN (USER FIX) ===== */

/* ===== NAVBAR RIGHT EDGE FIX (USER) ===== */
/* Problem: przy max-width treść navbara jest zawężona, a prawa sekcja (zegar/zaloguj)
   przykrywa ostatnie linki. Rozwiązanie: navbar ma być pełnej szerokości, a prawa sekcja
   przyklejona do prawej krawędzi. Lewa strona bez zmian. */
.navbar__inner{
  max-width: none;           /* pełna szerokość paska */
  width: 100%;
}

.navRight{
  margin-left: auto;         /* przyklej do prawej */
  flex: 0 0 auto;
}
/* ===== END NAVBAR RIGHT EDGE FIX (USER) ===== */

/* ==========================================================
   Mobile polish (audit patch) — non-breaking enhancements
   ========================================================== */
html, body { overflow-x: hidden; -webkit-text-size-adjust: 100%; }

@media (max-width: 900px){
  .page{ padding: 28px 14px; }
  .page__title{ font-size: 30px; }
}
@media (max-width: 560px){
  .navbar__inner{ padding: 0 12px; gap: 10px; }
  .nav{ justify-content:flex-start; gap:8px; }
  .nav__link{ padding: 9px 10px; font-size: 13px; }
  .navRight{ gap: 8px; padding-left: 8px; }
  .clock{ padding: 6px 8px; }
  .clock__date{ display:none; }
  .clock__time{ font-size: 12px; }
  .navBtn{ padding: 8px 10px; font-size: 13px; }
}
@media (max-width: 420px){
  .brand__text{ display:none; }
  .brand__icon{ width:34px; height:34px; border-radius:11px; }
  .nav__link{ padding: 8px 9px; font-size: 12.5px; border-radius: 11px; }
}


/* =========================
   Scrollable top navigation (PRO)
   Works with static/js/navscroll.js
========================= */
.navWrap{
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
#topNav.nav{
  display: flex;
  align-items: center;
  gap: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  min-width: 0;
  padding: 2px 4px;
}
#topNav.nav::-webkit-scrollbar{ height: 0; }

.navArrow{
  appearance: none;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,15,25,.55);
  color: rgba(255,255,255,.9);
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  cursor: pointer;
  user-select: none;
  transition: transform .12s ease, opacity .12s ease, background .12s ease;
  opacity: .0;
  pointer-events: none;
}
.navArrow[data-show]{ opacity: 1; pointer-events: auto; }
.navArrow:active{ transform: scale(.96); }
.navArrow:hover{ background: rgba(20,30,55,.6); }

.navFade{
  position: absolute;
  top: 0;
  bottom: 0;
  width: 22px;
  pointer-events: none;
  opacity: 0;
  transition: opacity .18s ease;
}
.navFade--left{
  left: 42px;
  background: linear-gradient(90deg, rgba(11,18,32,1), rgba(11,18,32,0));
}
.navFade--right{
  right: 42px;
  background: linear-gradient(270deg, rgba(11,18,32,1), rgba(11,18,32,0));
}

/* Small screens: keep arrows but make nav take full width */
@media (max-width: 820px){
  .navbar__inner{ gap: 10px; }
  .navWrap{ flex: 1; }
}

/* Zorza dropdown (2D/3D) */
.navDrop{ position: relative; display: inline-flex; align-items: center; }
.navDrop__menu{
  position:absolute; top: 110%; left: 0;
  min-width: 160px;
  padding: 8px;
  border-radius: 14px;
  background: rgba(12,16,22,.92);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
  display:none;
  z-index: 50;
  backdrop-filter: blur(12px);
}
.navDrop:hover .navDrop__menu{ display:block; }
.navDrop__item{
  display:block;
  padding: 10px 12px;
  border-radius: 12px;
  color: rgba(255,255,255,.9);
  text-decoration:none;
  font-weight: 600;
}
.navDrop__item:hover{ background: rgba(255,255,255,.08); }


/* Footer support pulse */
.footer__link--support{
  border: 1px solid rgba(251,191,36,0.30);
  background: rgba(251,191,36,0.10);
  color: var(--text);
  animation: footerSupportPulse 1.8s ease-in-out infinite;
}
.footer__link--support:hover{background: rgba(251,191,36,0.16);}
@keyframes footerSupportPulse{
  0%,100%{transform: translateZ(0) scale(1); box-shadow: 0 0 0 rgba(251,191,36,0.0);}
  50%{transform: translateZ(0) scale(1.03); box-shadow: 0 0 18px rgba(251,191,36,0.22);}
}
