/*
Theme Name: Lumen
Theme URI: https://s.it/
Description: Nowoczesny, w pełni responsywny motyw dla wspólnoty katolickiej i kanału z muzyką religijną. Hero z wersetem, sekcje „Czym żyjemy", artykuły, modlitwy, „Słowo na dziś", wydarzenia z odliczaniem, integracja ze Spotify i blog. Paleta bordo + złoto. Klasyczny motyw PHP.
Version: 1.0.0
Author: SKOT
Text Domain: lumen
Tags: catholic, faith, music, blog, responsive, custom-front-page
*/

/* =========================================================================
   ZMIENNE / PALETA (bordo + złoto, liturgiczna)
   ========================================================================= */
:root{
  --wine-900:#5a1620;
  --wine-800:#6b1f2a;
  --wine-700:#7a2532;
  --wine-500:#9a3340;
  --gold-500:#c9a227;
  --gold-400:#d8b94a;
  --cream:#f7f3ec;
  --paper:#ffffff;
  --ink:#2a1c1e;
  --muted:#6e5e60;
  --line:#e8ddd2;
  --shadow:0 18px 40px -24px rgba(90,22,32,.45);
  --radius:18px;
  --radius-sm:12px;
  --maxw:1180px;
  --font-head:"Playfair Display","Georgia",serif;
  --font-body:"Inter","Segoe UI",system-ui,sans-serif;
}

/* =========================================================================
   RESET / BAZA
   ========================================================================= */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--font-body);font-size:16px;line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--wine-700);text-decoration:none}
a:hover{color:var(--gold-500)}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.18;color:var(--ink);margin:0 0 .5em;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem)}
h3{font-size:1.25rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:clamp(48px,8vw,96px) 0}
.section--cream{background:var(--cream)}
.section--paper{background:var(--paper)}
.section--wine{background:var(--wine-900);color:#f3e7e0}
.section--wine h2,.section--wine h3{color:#fff}

/* eyebrow + nagłówki sekcji */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-body);font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;font-size:.78rem;color:var(--gold-500);margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold-500)}
.section-head{max-width:680px;margin:0 auto clamp(32px,5vw,56px);text-align:center}
.section-head .eyebrow{justify-content:center}
.section-head p{color:var(--muted)}

/* przyciski */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  padding:14px 28px;border-radius:999px;border:2px solid transparent;
  transition:transform .2s,box-shadow .2s,background .2s,color .2s;
}
.btn:hover{transform:translateY(-2px)}
.btn--gold{background:var(--gold-500);color:#3a2c05}
.btn--gold:hover{background:var(--gold-400);color:#3a2c05;box-shadow:var(--shadow)}
.btn--wine{background:var(--wine-700);color:#fff}
.btn--wine:hover{background:var(--wine-900);color:#fff}
.btn--ghost{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.btn--ghost:hover{background:#fff;color:var(--wine-900)}
.btn--outline{background:transparent;border-color:var(--wine-700);color:var(--wine-700)}
.btn--outline:hover{background:var(--wine-700);color:#fff}
.btn--spotify{background:#1DB954;color:#fff}
.btn--spotify:hover{background:#1ed760;color:#063}

/* =========================================================================
   TOP BAR + HEADER
   ========================================================================= */
.topbar{background:var(--wine-900);color:#e7cdc9;font-size:.85rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;
  gap:16px;min-height:42px;flex-wrap:wrap}
.topbar a{color:#e7cdc9}
.topbar a:hover{color:var(--gold-400)}
.topbar__info{display:flex;gap:22px;flex-wrap:wrap}
.topbar__info span{display:inline-flex;align-items:center;gap:7px}
.topbar__social{display:flex;gap:14px}

.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.site-header.is-stuck{box-shadow:0 10px 30px -18px rgba(0,0,0,.35)}
.site-header .container{display:flex;align-items:center;gap:20px;min-height:78px}
.site-brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);
  font-weight:700;font-size:1.4rem;color:var(--wine-900)}
.site-brand .mark{width:42px;height:42px;flex:0 0 auto}
.site-brand small{display:block;font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-500);font-weight:600;font-family:var(--font-body)}

.main-nav{margin-left:auto}
.main-nav ul{list-style:none;display:flex;gap:6px;margin:0;padding:0}
.main-nav a{display:block;padding:10px 14px;border-radius:10px;font-family:var(--font-body);
  font-weight:500;font-size:.95rem;color:var(--ink)}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--wine-700);background:var(--cream)}
.main-nav .menu-item-has-children>a::after{content:"▾";margin-left:6px;font-size:.7em;opacity:.6}
.main-nav .sub-menu{position:absolute;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);padding:8px;min-width:210px;display:none;
  flex-direction:column;margin-top:8px}
.main-nav li{position:relative}
.main-nav li:hover>.sub-menu{display:flex}

.header-cta{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);
  background:#fff;border-radius:12px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:"";display:block;width:22px;height:2px;background:var(--ink);position:relative;
  transition:.25s}
.nav-toggle span::before{position:absolute;top:-7px}
.nav-toggle span::after{position:absolute;top:7px}
body.nav-open .nav-toggle span{background:transparent}
body.nav-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
body.nav-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;color:#fff;overflow:hidden;
  background:linear-gradient(120deg,rgba(90,22,32,.93),rgba(122,37,50,.80)),
    url('assets/img/hero.jpg') center/cover no-repeat,
    radial-gradient(circle at 70% 30%,#7a2532,#5a1620);}
.hero::after{content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M27 8h6v13h13v6H33v25h-6V27H14v-6h13z' fill='%23ffffff' fill-opacity='0.05'/%3E%3C/svg%3E");
  opacity:.7;pointer-events:none}
.hero .container{position:relative;z-index:2;padding-top:clamp(70px,12vw,130px);
  padding-bottom:clamp(70px,12vw,130px);max-width:840px}
.hero .eyebrow{color:var(--gold-400)}
.hero h1{color:#fff;font-size:clamp(2.3rem,6vw,4rem)}
.hero p{font-size:1.12rem;color:#f1ddd7;max-width:580px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* =========================================================================
   ABOUT
   ========================================================================= */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,60px);
  align-items:center}
.about-media{position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--wine-700)
    url('assets/img/about.jpg') center/cover}
.about-media .badge{position:absolute;left:18px;bottom:18px;background:var(--gold-500);
  color:#3a2c05;font-family:var(--font-head);font-weight:700;border-radius:14px;
  padding:14px 18px;line-height:1.1}
.about-media .badge b{display:block;font-size:1.8rem}
.about-content h2{margin-top:6px}
.about-content ul{list-style:none;padding:0;margin:18px 0;display:grid;gap:10px}
.about-content li{display:flex;gap:10px;align-items:flex-start;color:var(--muted)}
.about-content li svg{flex:0 0 auto;margin-top:3px;color:var(--wine-500)}

/* =========================================================================
   CZYM ŻYJEMY (dawne „filary")
   ========================================================================= */
.pillars{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 18px;text-align:center;transition:transform .25s,box-shadow .25s}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pillar .ico{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(140deg,var(--wine-700),var(--wine-500));color:#fff}
.pillar h3{font-size:1.05rem;margin-bottom:4px}
.pillar p{font-size:.85rem;color:var(--muted);margin:0}

/* =========================================================================
   KARTY (co u nas znajdziesz / blog)
   ========================================================================= */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;
  background:linear-gradient(90deg,var(--wine-500),var(--gold-500));
  transform:scaleX(0);transform-origin:left;transition:transform .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card:hover::before{transform:scaleX(1)}
.card .ico{width:58px;height:58px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;background:var(--cream);color:var(--wine-700);margin-bottom:18px}
.card h3{margin-bottom:8px}
.card p{color:var(--muted);font-size:.93rem;margin-bottom:16px}
.card .more{font-family:var(--font-body);font-weight:600;font-size:.85rem;
  display:inline-flex;gap:6px;align-items:center}

/* =========================================================================
   SŁOWO NA DZIŚ (werset)
   ========================================================================= */
.verse-band{text-align:center;max-width:820px;margin:0 auto;position:relative}
.verse-band .quote-mark{font-family:var(--font-head);font-size:7rem;line-height:.5;
  color:var(--gold-500);opacity:.28;display:block;height:46px}
.verse-band .quote{font-family:var(--font-head);font-style:italic;
  font-size:clamp(1.5rem,3.5vw,2.2rem);line-height:1.45;color:#fff;margin:6px 0 18px}
.verse-band .quote::before{content:"„"}
.verse-band .quote::after{content:"”"}
.verse-band .ornament{display:flex;align-items:center;justify-content:center;gap:14px;
  color:var(--gold-400);font-size:1.1rem;margin:0 0 14px}
.verse-band .ornament span{height:1px;width:60px;
  background:linear-gradient(90deg,transparent,var(--gold-500))}
.verse-band .ornament span:last-child{background:linear-gradient(90deg,var(--gold-500),transparent)}
.verse-band .ref{color:var(--gold-400);font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}

/* =========================================================================
   ZAPAL ŚWIECZKĘ (fallback, gdy wtyczka wyłączona)
   ========================================================================= */
.candle-cta{background:linear-gradient(180deg,#3a0f16,#2a0d12);color:#f3e7e0;
  border-radius:var(--radius);padding:clamp(32px,6vw,56px);text-align:center}
.candle-cta__ico{font-size:3rem;display:block;margin-bottom:12px}
.candle-cta p{margin:0;color:#d7b6b1}
.prayer-cta{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(32px,6vw,56px);text-align:center}
.prayer-cta__ico{font-size:3rem;display:block;margin-bottom:12px}
.prayer-cta p{margin:0;color:var(--muted)}

/* =========================================================================
   WYDARZENIA + ODLICZANIE
   ========================================================================= */
.events{display:grid;gap:20px}
.event{display:grid;grid-template-columns:120px 1fr auto;gap:24px;align-items:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:22px 26px}
.event__date{text-align:center;background:var(--gold-500);color:#3a2c05;border-radius:14px;
  padding:14px 8px;font-family:var(--font-head)}
.event__date b{display:block;font-size:2rem;line-height:1}
.event__date span{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}
.event__body h3{color:#fff;margin-bottom:6px}
.event__meta{display:flex;gap:18px;flex-wrap:wrap;color:#e3c7c1;font-size:.85rem}
.event__meta span{display:inline-flex;gap:6px;align-items:center}
.countdown{display:flex;gap:10px}
.countdown div{background:rgba(255,255,255,.1);border-radius:10px;padding:8px 12px;
  text-align:center;min-width:54px;font-family:var(--font-head)}
.countdown b{display:block;font-size:1.3rem;color:var(--gold-400)}
.countdown small{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#e3c7c1}

/* =========================================================================
   BLOG
   ========================================================================= */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-card__img{aspect-ratio:16/10;background:var(--wine-700) center/cover;position:relative;display:block}
.post-card__img .cat{position:absolute;left:14px;top:14px;background:var(--gold-500);
  color:#3a2c05;font-size:.72rem;font-weight:600;padding:5px 12px;border-radius:999px;
  font-family:var(--font-body)}
.post-card__body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.post-card__meta{font-size:.78rem;color:var(--muted);display:flex;gap:14px}
.post-card h3{font-size:1.12rem;margin:0}
.post-card h3 a{color:var(--ink)}
.post-card h3 a:hover{color:var(--wine-700)}
.post-card .more{margin-top:auto;font-family:var(--font-body);font-weight:600;font-size:.85rem}

/* =========================================================================
   FAQ (rozwijane pytania)
   ========================================================================= */
.faq{max-width:820px;margin:0 auto;display:grid;gap:12px}
.faq__item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:2px 20px;transition:box-shadow .2s}
.faq__item[open]{box-shadow:var(--shadow)}
.faq__q{cursor:pointer;list-style:none;font-family:var(--font-head);font-weight:600;
  font-size:1.08rem;color:var(--ink);padding:16px 30px 16px 0;position:relative;outline:none}
.faq__q::-webkit-details-marker{display:none}
.faq__q::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-size:1.5rem;color:var(--gold-500);font-family:var(--font-body);line-height:1}
.faq__item[open] .faq__q::after{content:"–"}
.faq__q:hover{color:var(--wine-700)}
.faq__a{color:var(--muted);padding:0 0 18px;line-height:1.65}

/* =========================================================================
   PAS SPOTIFY
   ========================================================================= */
.cta-band{background:linear-gradient(120deg,var(--wine-900),var(--wine-700));
  color:#fff;border-radius:var(--radius);padding:clamp(32px,6vw,60px);
  display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
  position:relative;overflow:hidden}
.cta-band h2{color:#fff;margin:0 0 8px}
.cta-band p{color:#f1ddd7;margin:0;max-width:520px}
.cta-band__embed{flex:1 1 320px;min-width:280px}
.cta-band__embed iframe{border-radius:14px;width:100%}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{background:#43101a;color:#d7b6b1;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:36px;
  padding:clamp(48px,7vw,80px) 0 40px}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:18px;font-family:var(--font-head)}
.site-footer a{color:#d7b6b1}
.site-footer a:hover{color:var(--gold-400)}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer-brand .site-brand{color:#fff;margin-bottom:16px}
.footer-brand .site-brand small{color:var(--gold-400)}
.newsletter{display:flex;gap:8px;margin-top:14px}
.newsletter input{flex:1;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);
  color:#fff;border-radius:10px;padding:12px 14px;font-size:.9rem}
.newsletter input::placeholder{color:#b78d88}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.85rem}

/* =========================================================================
   STRONY WEWNĘTRZNE
   ========================================================================= */
.page-hero{background:linear-gradient(120deg,var(--wine-900),var(--wine-700));
  color:#fff;text-align:center;padding:clamp(48px,8vw,90px) 0}
.page-hero h1{color:#fff}
.page-hero .crumbs{color:#f1ddd7;font-size:.9rem}
.page-hero .crumbs a{color:var(--gold-400)}
.content-area{max-width:820px;margin:0 auto}
.entry-content p{margin-bottom:1.2rem}
.entry-content img{border-radius:var(--radius);margin:1.5rem 0}
.entry-content blockquote{border-left:4px solid var(--gold-500);background:var(--cream);
  padding:18px 24px;border-radius:0 12px 12px 0;margin:1.5rem 0;font-style:italic}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.pagination .page-numbers{padding:10px 16px;border-radius:10px;border:1px solid var(--line);
  background:#fff;font-family:var(--font-head)}
.pagination .current{background:var(--wine-700);color:#fff;border-color:var(--wine-700)}
.error-404{text-align:center;padding:clamp(60px,10vw,120px) 0}
.error-404 .big{font-size:clamp(5rem,18vw,11rem);font-family:var(--font-head);
  font-weight:700;color:var(--wine-700);line-height:1;opacity:.15}

/* =========================================================================
   RESPONSYWNOŚĆ
   ========================================================================= */
@media (max-width:1024px){
  .pillars{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .header-cta{margin-left:auto}              /* przyklej przycisk menu do prawej krawędzi */
  .header-cta .btn{display:none}
  .nav-toggle{display:flex}
  /* Menu rozwija się pełną szerokością tuż pod nagłówkiem (kotwiczone do sticky headera). */
  .main-nav{position:absolute;top:100%;left:0;right:0;background:#fff;
    margin:0;padding:12px 16px 18px;
    box-shadow:0 26px 40px -26px rgba(0,0,0,.55);border-top:1px solid var(--line);
    max-height:78vh;overflow-y:auto;z-index:55;
    opacity:0;visibility:hidden;transform:translateY(-10px);
    transition:opacity .25s ease,transform .25s ease,visibility .25s}
  body.nav-open .main-nav{opacity:1;visibility:visible;transform:none}
  body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:40}
  .main-nav ul{flex-direction:column;gap:10px}
  /* Duże, łatwe do kliknięcia belki ze stronami */
  .main-nav a{display:block;padding:18px 18px;border-radius:14px;font-size:1.12rem;
    font-weight:600;background:var(--cream);border:1px solid var(--line);text-align:left}
  .main-nav a:hover,.main-nav .current-menu-item>a{background:var(--wine-700);color:#fff;border-color:var(--wine-700)}
  .main-nav .menu-item-has-children>a::after{float:right}
  .main-nav .sub-menu{position:static;display:flex;flex-direction:column;box-shadow:none;border:0;
    padding:8px 0 0 12px;margin:0;gap:8px}
  .main-nav .sub-menu a{font-size:1rem;padding:14px 16px;background:#fff}
  .about-grid{grid-template-columns:1fr}
  .cards,.posts{grid-template-columns:1fr 1fr}
  .event{grid-template-columns:90px 1fr;gap:16px}
  .event .countdown{grid-column:1/-1}
}
@media (max-width:600px){
  .topbar__info{gap:14px}
  .pillars{grid-template-columns:1fr 1fr}
  .cards,.posts{grid-template-columns:1fr}
  .cta-band{flex-direction:column;align-items:flex-start;text-align:left}
  .hero__actions .btn{flex:1;justify-content:center}
}
