/*
Theme Name: PXS Theme
Theme URI: https://pixelshark.eu
Author: PixelShark.eu
Author URI: https://pixelshark.eu
Description: Motyw z edycją strony głównej i stopki w panelu „Szablon PXS”.
Version: 1.0.2
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPLv2 or later
Text Domain: pxs
*/

:root{
  --bg:#0a0b0e;
  --bg-alt:#0e0f14;
  --gold:#D4AF37;
  --gold-2:#c49a27;
  --gold-3:#9b7a19;
  --text:#e8e4d9;
  --muted:#bdb7a7;
  --accent:#eacf6b;
  --transition:240ms cubic-bezier(.2,.8,.2,1);
  --content-w:1100px;
  --pad-x:22px;
  --hero-pad: clamp(18px, 5vh, 50px);
  --footer-py: clamp(44px, 6vh, 64px);
  --footer-gap: 28px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 900px at 20% 10%, #1b1e25 0%, var(--bg) 60%) fixed,
    radial-gradient(1200px 900px at 80% -10%, #141821 0%, var(--bg) 60%) fixed,
    var(--bg);
  line-height:1.6;
  overflow-x:hidden;
  scroll-behavior:smooth;
}

.starfield{ position:fixed; inset:0; z-index:0; pointer-events:none }

.nav{
  position:fixed; top:12px;
  right: max(var(--pad-x), calc((100vw - var(--content-w)) / 2 + var(--pad-x)));
  z-index:300;
}
.nav-bar{ position:relative; display:flex; align-items:center; gap:12px; padding:8px 2px }
.nav-bar::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:linear-gradient(90deg, transparent, rgba(212,175,55,.55), transparent);
  filter:blur(.25px) drop-shadow(0 6px 10px rgba(0,0,0,.35));
  opacity:.9;
}
.nav-bar::before{
  content:""; position:absolute; inset:-8px -10px;
  background:linear-gradient(180deg, rgba(10,10,12,.58), rgba(10,10,12,.34));
  backdrop-filter:saturate(120%) blur(10px);
  box-shadow:0 12px 30px rgba(0,0,0,.35);
  opacity:0; transform:translateY(-6px);
  transition:opacity var(--transition), transform var(--transition);
  z-index:-1;
}
.nav.scrolled .nav-bar::before{ opacity:1; transform:translateY(0) }

.nav-list{ display:flex; gap:2px; list-style:none; padding:0; margin:0 }
.nav-list a{
  position:relative; display:inline-block; padding:10px 14px;
  text-decoration:none; color:var(--text); font-weight:700; letter-spacing:.2px;
  text-shadow:0 1px 0 rgba(0,0,0,.4);
  transition:color var(--transition), transform var(--transition);
}
.nav-list a:hover{ color:var(--accent); transform:translateY(-1px) }
.nav-list a::after{
  content:""; position:absolute; left:12px; right:12px; bottom:-6px; height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  transform:scaleX(0); transform-origin:50% 50%;
  transition:transform var(--transition);
}
.nav-list a:hover::after{ transform:scaleX(1) }

.burger{ display:none; width:44px; height:44px; margin-left:6px; background:transparent; border:0; cursor:pointer }
.burger .line{ display:block; width:26px; height:2px; margin:6px auto; background:var(--text); transition:transform var(--transition), opacity var(--transition) }
.burger.open .line:nth-child(1){ transform:translateY(8px) rotate(45deg) }
.burger.open .line:nth-child(2){ opacity:0 }
.burger.open .line:nth-child(3){ transform:translateY(-8px) rotate(-45deg) }

@media (max-width:900px){
  .nav-list{ display:none }
  .burger{ display:block }
}

/* MOBILE MENU */
.mobile{
  position:fixed; top:64px; left:0; right:0; z-index:290; width:100vw;
  background:linear-gradient(180deg, rgba(10,10,12,.96), rgba(10,10,12,.9));
  border-top:1px solid rgba(212,175,55,.18);
  border-bottom:1px solid rgba(212,175,55,.18);
  padding:10px var(--pad-x);
  box-shadow:0 20px 40px rgba(0,0,0,.5);
  display:flex; flex-direction:column; gap:10px;
  transform:translateY(-8px); opacity:0; pointer-events:none;
  transition:transform var(--transition), opacity var(--transition);
}
.mobile.show{ transform:translateY(0); opacity:1; pointer-events:auto }

/* reset punktorów */
.mobile-list{ list-style:none; margin:0; padding:0; }

/* style linków wewnątrz listy */
.mobile a,
.mobile-list a{
  display:block; padding:14px 14px; border-radius:8px;
  background:rgba(255,255,255,.02); border:1px solid rgba(255,255,255,.06);
  text-decoration:none; color:var(--text); font-weight:600;
}
.mobile hr{ border:none; height:1px; background:linear-gradient(90deg, transparent, rgba(212,175,55,.35), transparent); margin:6px 2px }

/* HERO */
.hero{
  position:relative; height:100dvh; min-height:100svh;
  display:grid; place-items:center; isolation:isolate; overflow:hidden; z-index:1;
  padding-block: var(--hero-pad);
  background:transparent;
}

.cloud-wrap{ position:absolute; top:0; left:0; height:100%; z-index:1; overflow:hidden; pointer-events:none }
.hero-clouds{
  height:100%; width:auto; display:block; object-fit:contain; opacity:.95;
  will-change:transform; transform-origin: top left;
  animation: cloudDriftX 7.2s ease-in-out infinite alternate;
}
@keyframes cloudDriftX{
  0%{ transform: translateX(0) scale(1.02) }
  100%{ transform: translateX(-14px) scale(1.02) }
}

.hero-image{
  z-index:2;
  max-height: calc(100dvh - (var(--hero-pad) * 2));
  height:auto; width:auto;
  max-width: min(100%, 100vw - (var(--pad-x) * 2));
  object-fit:contain; object-position:center; transform:translateZ(0);
}

section{ scroll-margin-top:92px }
.wrap{ max-width:var(--content-w); margin:0 auto; padding:70px var(--pad-x); position:relative; z-index:1 }
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.06); border-radius:18px;
  box-shadow:0 0 0 1px rgba(212,175,55,.12), 0 12px 30px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
  overflow:hidden;
}

.about{ display:grid; grid-template-columns: 1.1fr .9fr; gap:42px; align-items:stretch }
.about .content{ padding:34px }
.eyebrow{ color:var(--accent); letter-spacing:.26em; text-transform:uppercase; font-weight:600; font-size:.8rem }
h1,h2{ font-family:Cinzel,serif; line-height:1.2; margin:.4em 0 .6em }
h2{ font-weight:700; font-size:clamp(28px,4vw,40px); color:var(--gold) }
p{ color:#e8e4d9; opacity:.95 }
.about p{ margin:0 0 16px }
.inline{ color:var(--accent); text-decoration:none; border-bottom:1px dashed rgba(212,175,55,.35) }
.inline:hover{ color:var(--gold) }
.about-img{ position:relative; min-height:340px; background:radial-gradient(60% 60% at 70% 20%, rgba(221,189,90,.25), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.08)) }
.about-img img{ width:100%; height:100%; object-fit:cover; display:block; filter:saturate(95%) contrast(102%) }

.gold-divider{ height:1px; background:linear-gradient(90deg, transparent, var(--gold), transparent); border:none; margin:18px 0 24px; opacity:.6 }

.btn-row{ display:flex; gap:12px; flex-wrap:wrap; margin-top:8px }
.btn{
  --b:rgba(212,175,55,.35);
  display:inline-flex; align-items:center; gap:10px; padding:12px 16px; border-radius:14px;
  border:1px solid var(--b); background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  color:var(--text); text-decoration:none; font-weight:600; letter-spacing:.2px;
  box-shadow:0 0 0 1px rgba(212,175,55,.12), 0 12px 30px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
  transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition)
}
.btn:hover{ transform:translateY(-2px); border-color:var(--gold); box-shadow:0 10px 26px rgba(212,175,55,.12) }
.btn .dot{ width:10px; height:10px; border-radius:50%; background:var(--gold) }

.authors .content{ padding:28px }
.tracklist{ display:flex; flex-direction:column; gap:14px; margin-top:10px }
.track{
  display:grid; grid-template-columns:auto 1fr 160px; align-items:center; gap:14px;
  padding:12px; border-radius:14px; background:rgba(255,255,255,.02); border:1px solid rgba(255,255,255,.06)
}
.track .play{
  width:42px; height:42px; border-radius:50%; border:1px solid rgba(212,175,55,.35);
  background:rgba(255,255,255,.03); color:var(--gold); cursor:pointer; font-size:16px;
  box-shadow:0 0 0 1px rgba(212,175,55,.12), 0 12px 30px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
  transition:transform var(--transition), background var(--transition), border-color var(--transition)
}
.track .play:hover{ transform:translateY(-2px); background:rgba(255,255,255,.1); border-color:var(--gold) }
.track .meta small{ color:var(--muted) }
.track .bar{ position:relative; height:8px; background:rgba(255,255,255,.06); border-radius:999px; overflow:hidden }
.track .bar span{ position:absolute; inset:0 auto 0 0; width:0%; background:linear-gradient(90deg, var(--gold-3), var(--gold)); border-radius:inherit; transition:width .2s ease }

.reveal{ opacity:0; transform:translateY(18px); transition:opacity .9s ease, transform .9s ease }
.reveal.in{ opacity:1; transform:none }

footer{
  border-top:1px solid rgba(212,175,55,.12);
  background:linear-gradient(180deg, rgba(10,10,12,.75), rgba(10,10,12,.95));
  position:relative; z-index:1;
  padding:15px;
}
.footer-wrap{ padding-top:var(--footer-py); padding-bottom:var(--footer-py) }
.footer-grid{
  max-width:var(--content-w); margin:0 auto; padding:0 var(--pad-x);
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; column-gap:var(--footer-gap); row-gap:16px;
}
.social{ display:flex; gap:14px; flex-wrap:wrap; align-self:flex-start; margin-top:-6px }
.social a, .social a:visited{ color:var(--gold) }
.social a{
  width:42px; height:42px; display:grid; place-items:center; border-radius:12px;
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06);
  transition:transform var(--transition), background var(--transition), border-color var(--transition)
}
.social a:hover{ transform:translateY(-2px); background:rgba(212,175,55,.09); border-color:rgba(212,175,55,.45) }

.legal{
  display:flex; justify-content:center; align-items:center; gap:14px; text-align:center; flex-wrap:wrap;
}
.legal a{
  color:var(--text); text-decoration:none; border-bottom:1px dashed rgba(212,175,55,.35);
  transition:color var(--transition), border-color var(--transition)
}
.legal a:hover{ color:var(--gold); border-color:var(--gold) }
.legal .sep{ color:var(--muted) }

.copy{
  color:var(--muted); font-size:.95rem; display:flex; align-items:center; gap:8px; justify-content:flex-end; flex-wrap:wrap;
}
.copy strong{ color:var(--gold) }
.gold-heart{ color:var(--gold); vertical-align:-2px }

@media (max-width:980px){
  :root{ --hero-pad: clamp(12px, 4vh, 32px); --footer-py: clamp(36px, 6vh, 56px); --footer-gap: 20px }
  .about{ grid-template-columns:1fr }
  .about-img{ order:-1; min-height:260px }
  .footer-grid{ grid-template-columns:1fr; justify-items:center; text-align:center; }
  .social{ align-self:center; margin-top:-4px }
  .copy{ justify-content:center }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; scroll-behavior:auto!important }
}

/* SUBHEADER / PAGE */
.subheader{position:relative;overflow:hidden;padding:140px var(--pad-x) 42px;margin:0}
.subheader .subheader-inner{max-width:var(--content-w);margin:0 auto;text-align:center;position:relative;z-index:1}
.subheader h1{font-family:Cinzel,serif;margin:.1em 0 .35em}
.subheader .cloud-wrap{position:absolute;inset:0 0 auto 0;height:260px;z-index:0;pointer-events:none}
.sub-clouds{height:100%;width:auto;opacity:.9;display:block;object-fit:contain;animation:cloudDriftX 7.2s ease-in-out infinite alternate}
.breadcrumbs{display:inline-flex;gap:10px;align-items:center}
.breadcrumbs a{color:var(--text);text-decoration:none;border-bottom:1px dashed rgba(212,175,55,.35)}
.crumb-sep{opacity:.6}
.page-wrap{max-width:var(--content-w);margin:18px auto 0;padding:0 var(--pad-x) 70px;position:relative;z-index:1}
.page.card{padding:28px}
.page h2{margin-top:1.2em}
.page h3{margin-top:1.1em;font-size:1.05rem;color:var(--accent)}
.page p{margin:.5em 0 1em}
.page ul{margin:.4em 0 1.2em;padding-left:1.1em}
.page li{margin:.35em 0}
.meta-note{color:var(--muted);font-size:.95rem;margin-top:6px}

/* Małe logo tylko na podstronach */
.brand{position:fixed; top:14px; left: max(var(--pad-x), calc((100vw - var(--content-w)) / 2 + var(--pad-x))); z-index:320; display:inline-block}
.brand img{height:34px; width:auto; display:block; filter:drop-shadow(0 4px 10px rgba(0,0,0,.35))}
.home .brand, .front-page .brand{display:none}
