/* --------------------
   Modern Elegant Theme — FIXED & CLEANED
   -------------------- */
:root{
  --bg: #FFFFFF;           /* krem tła */
  --surface: #FFFFFF;      /* karty/panele */
  --text: #37512E;         /* główny tekst zamiast czerni */
  --muted: #5F6B62;        /* opisy, daty */
  --green: #6C8430;        /* zielony akcent z liści */
  --lav: #826C93;          /* lawenda z logo */
  --accent-yellow: #D6B953;/* żółty z kwiatów */
  --stroke: #EAE2D4;       /* delikatne obramowania */
  --radius: 18px;
  --shadow-1: 0 2px 10px rgba(0,0,0,.06);
  --shadow-2: 0 10px 30px rgba(0,0,0,.10);
  --container: 1120px;
}

/* Dark: zostawiamy białe tła zgodnie z brandem, porządkujemy nawiasy */
@media (prefers-color-scheme: dark){
  :root{
    --bg:#FFFFFF;
    --surface:#FFFFFF;
    --text:#37512E;
    --muted:#5F6B62;
    --green:#6C8430;
    --lav:#826C93;
    --stroke:#EAE2D4;
  }
  .btn-secondary{ background:#F3F1ED; }
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: clamp(15px, 1.6vw, 17px);
  overflow-x: hidden; /* zapobiega wyciekaniu w poziomie */
}

.container{ max-width: var(--container); margin: 0 auto; padding: 0 18px; }

/* NAVBAR */

/* --- Fix: hover highlight spill in header on index --- */
.topbar{ overflow: clip; }
@supports not (overflow: clip){
  .topbar{ overflow: hidden; }
}
/* Make nav pills tighter and clip background to padding box */
.nav-links a{ display:inline-block; line-height:1.2; }
.nav-links a:hover{ background-clip: padding-box; }

.topbar{
  position: sticky; top: 0; z-index: 1000;
  backdrop-filter: saturate(1.1) blur(8px);
  background: var(--surface);
  border-bottom: 1px solid var(--stroke);
}
.nav-inner{
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.brand{ display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--text); font-weight:700; }
.brand .logo{ height: 36px; width:auto; border-radius: 10px; box-shadow: var(--shadow-1); }

#navToggle{
  appearance:none;
  background: var(--surface);
  padding: 10px 14px;
  border-radius: 14px;
  cursor: pointer;

  /* NOWE: obramowanie dookoła */
  border: 2px solid var(--green);

  color: var(--green);
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  box-shadow: var(--shadow-1);
}
#navToggle:hover{
  background: #F3F1ED;
  border-color: var(--lav); /* delikatne podbicie na hover (opcjonalnie) */
}
#navToggle:focus-visible{ outline: 2px solid var(--lav); outline-offset: 2px; }
#navToggle .menu-label{ line-height: 1; }
#navToggle i{ color: var(--green); font-size: 18px; }

@media (min-width: 881px){
  #navToggle{ display: none; } /* ukryj na desktopie */
}

.nav-links{ display:flex; gap: 20px; align-items:center; }
.nav-links a{
  text-decoration: none; font-weight: 600; color: var(--green); opacity:.95;
  padding: 8px 10px; border-radius: 10px;
}
.nav-links a:hover{ background: var(--stroke); }
@media (max-width: 880px){
  .nav-links{
    position: fixed;
    inset: 64px 0 auto 0;             /* pod sticky topbar (64px) */
    background: var(--surface);
    border-bottom: 1px solid var(--stroke);
    padding: 6px max(18px, env(safe-area-inset-left)) 6px max(18px, env(safe-area-inset-right));
    display: none;
    flex-direction: column;           /* <— pionowo */
    align-items: stretch;             /* pełna szerokość */
    gap: 0;                           /* bez przerw między wierszami */
    z-index: 1000;
  }
  .nav-links.open{ display: flex; }

  /* Link = pełna szerokość, duży tap target */
  .nav-links a{
    display: block;
    width: 100%;
    padding: 14px 18px;
    border-radius: 0;
    border-top: 1px solid var(--stroke);
    font-size: 16px;
  }
  .nav-links a:first-child{ border-top: none; }
  .nav-links a:hover{ background: #F3F1ED; }

  /* wsparcie dla bezpiecznych krawędzi (iPhone) */
  @supports(padding: max(0px)){
    .nav-links{ padding-bottom: max(6px, env(safe-area-inset-bottom)); }
  }
}

/* HERO */
.hero, .subhero{
  position: relative; color: #fff; text-align: center;
  background: linear-gradient(120deg, rgba(63,122,85,.85), rgba(142,127,179,.85)), url('assets/herbs-background.jpg') center/cover no-repeat;
}
.hero{ padding: clamp(90px, 16vw, 160px) 20px; }
.subhero{ padding: clamp(60px, 12vw, 90px) 20px; }
.hero-inner{ max-width: 900px; margin: 0 auto; padding: 0 18px; }
.logo{ max-height: clamp(90px, 12vw, 140px); margin-bottom: 16px; border-radius: 16px; }
.hero h1, .subhero h1{ font-size: clamp(28px, 6vw, 54px); margin: 6px 0; letter-spacing: .4px; }
.hero p, .subhero p{ font-size: clamp(15px, 3vw, 20px); opacity: .95; }

/* MAIN */
main{ padding: clamp(26px, 5vw, 42px) 0; }
section{ padding: clamp(36px, 6vw, 64px) 0; }
h2{
  color: var(--green); font-size: clamp(22px, 4.5vw, 34px); text-align:center; margin: 0 0 28px 0; font-weight: 700;
}
h2::after{
  content: ''; display:block; width: 80px; height: 3px; background: var(--lav); margin: 12px auto 0; border-radius: 3px;
}

/* GRID & CARDS */
.grid{ display:grid; grid-template-columns: repeat(12, 1fr); gap: 18px; }
.grid > *{ grid-column: span 4; }
@media (max-width: 980px){ .grid > *{ grid-column: span 6; } }
@media (max-width: 640px){ .grid > *{ grid-column: span 12; } }

.card, .post, .event{
  background: var(--surface); border-radius: var(--radius); box-shadow: var(--shadow-1);
  padding: clamp(16px, 3vw, 24px); border: 1px solid var(--stroke);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.card:hover, .post:hover, .event:hover{ transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: color-mix(in srgb, var(--lav) 30%, var(--stroke)); }
.post + .post, .event + .event{ margin-top: 14px; }

.post h3, .event h3{ margin: 0 0 6px 0; font-size: clamp(18px, 3.2vw, 22px); }
.meta{ color: var(--muted); font-size: .95em; }

.thumb{
  width: 100%; height: clamp(160px, 32vw, 260px);
  object-fit: cover; border-radius: 14px; margin-bottom: 10px; display:block;
}

/* Buttons */
.btn{
  display:inline-block; padding: 10px 14px; border-radius: 12px; text-decoration:none; cursor:pointer;
  border: 1px solid var(--stroke); background: var(--surface); color: var(--text); font-weight: 600;
  transition: background .2s ease, transform .15s ease, box-shadow .2s ease;
}
.btn:hover{ transform: translateY(-2px); box-shadow: var(--shadow-1); }
.btn-primary{ background: linear-gradient(135deg, var(--green), var(--lav)); color: #fff; border-color: transparent; }
.btn-secondary{ background: #F3F1ED; }
@media (prefers-color-scheme: dark){ .btn-secondary{ background: #242424; } }

/* Media embeds */
.media{ max-width:100%; display:block; border-radius: 14px; box-shadow: var(--shadow-1); overflow:hidden; }
.media.video iframe{ width:100%; height: clamp(220px, 42vw, 420px); border:0; display:block; }

/* Footer */
footer{
  background: linear-gradient(135deg, var(--green), var(--lav));
  color: #fff; text-align:center; padding: 32px; margin-top: 60px;
}

/* Anchors offset */
#onas, #aktualnosci, #przepisy, #galeria, #wydarzenia, #kontakt{ scroll-margin-top: 84px; }

/* Admin polish */
.admin-wrap{ max-width: var(--container); margin:0 auto; padding: 12px 18px; }
.table{ width:100%; border-collapse: collapse; background: var(--surface); border:1px solid var(--stroke); border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-1); }
.table th, .table td{ padding: 12px 14px; border-bottom: 1px solid var(--stroke); text-align:left; vertical-align: top; }
.table tr:hover td{ background: #faf8f5; }
.form-field{ margin-bottom: 14px; }
.form-field label{ display:block; font-weight:600; margin-bottom:6px; }
.form-field input[type="text"], .form-field input[type="datetime-local"], .form-field textarea, .form-field select{
  width:100%; padding: 10px 12px; border-radius: 12px; border:1px solid var(--stroke); background: var(--surface);
  color: var(--text); font-family: inherit; font-size: 1rem;
}
.flash{ padding: 12px 14px; border-radius: 12px; margin: 10px 0; background: #f1f8e9; border: 1px solid #dcedc8; }
.login-box{ max-width: 420px; margin: 60px auto; background: var(--surface); padding: 22px; border-radius: 16px; box-shadow: var(--shadow-2); border:1px solid var(--stroke); }
.small{ font-size: .92rem; color: var(--muted); }

/* Focus ring for a11y */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline: 2px solid var(--lav);
  outline-offset: 2px;
}

/* Safe-area padding for iOS */
@supports(padding:max(0px)){
  .topbar{ padding-left: max(0px, env(safe-area-inset-left)); padding-right: max(0px, env(safe-area-inset-right)); }
}

/* Brand headings font */
h1,h2,h3{ font-family: "Cormorant Garamond", serif; }

/* Icons default color per brand (no black) */
.fa, .fa-solid, .fa-regular{ color: var(--green); }
#navToggle i{ color: var(--green); }

/* === Facebook feed responsywny === */
#facebook-feed{ margin: 20px 0 30px; text-align: center; }
#facebook-feed h2{ margin-bottom: 10px; }
#facebook-feed .fb-page{min-height:520px;display:block;}
.fb-wrap{min-height:320px;}
.fb-follow{display:inline-block;}

.fb-embed{ max-width: 100%; overflow-x: hidden; margin: 0 auto; }
.fb-embed iframe,
.fb-embed .fb-page,
.fb-embed > div{ max-width: 100% !important; width: 100% !important; box-sizing: border-box; }
@media (max-width: 768px){
  .fb-embed iframe,
  .fb-embed .fb-page{ height: 400px !important; }
}

#fb-card{
  width: 100%; max-width: 600px; margin: 0 auto; background: #fff;
  border-radius: 12px; box-shadow: 0 4px 14px rgba(0,0,0,0.08); padding: 10px;
}
.fb-iframe-wrap{ display: flex; justify-content: center; margin: 0; padding: 0; }
#fb-iframe{ display: block; margin: 0 auto; height: auto !important; }

/* ===================== */
/*       KALENDARZ       */
/* ===================== */

/* Baza desktopowa — duży kalendarz w siatce */
.zb-cal{
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  width: 100%;
  max-width: 100%;
}

.zb-cal-cell{
  min-width: 0;
  padding: 8px;
  text-align: center;
  background: #f9f9f9;
  border-radius: 8px;
  font-size: 14px;
  border: 1px solid #eee;
}

/* Podświetlenie dzisiejszego dnia */
.zb-cal-cell.today{
  background: #e6f2e6;
  border: 2px solid #6C8430;
  font-weight: bold;
}

/* Widok mobilny — lista kart (bez zmian w UX) */
@media (max-width: 768px){
  .zb-cal{ display: block; }
  .zb-cal-cell{
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 12px; margin-bottom: 6px; font-size: 16px;
    background: #fff; border: 1px solid #ddd; border-radius: 10px; box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  }
  .zb-cal-cell .num{ font-weight: bold; font-size: 18px; color: #37512E; }
  .zb-cal-cell.has-events .ring{ display:inline-block; margin-left:8px; width:10px; height:10px; background:#6C8430; border-radius:50%; }
}

/* Duży desktop — powiększone komórki, kwadratowe pola */
@media (min-width: 992px){
  #wydarzenia .zb-cal, .zb-cal{
    gap: 16px;
    padding: 24px;
    max-width: min(1400px, 100%);
    margin: 0 auto;
  }
  #wydarzenia .zb-cal-cell, .zb-cal-cell{
    aspect-ratio: 1 / 1;       /* klucz: kwadratowe dni */
    padding: 16px;
    font-size: 18px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid var(--stroke);
  }
  #wydarzenia .zb-cal-cell .num, .zb-cal-cell .num{ font-size: 20px; font-weight: 700; }
}

/* Bardzo duże ekrany */
@media (min-width: 1400px){
  #wydarzenia .zb-cal-cell, .zb-cal-cell{ font-size: 19px; padding: 18px; }
  #wydarzenia .zb-cal-cell .num, .zb-cal-cell .num{ font-size: 22px; }
}

/* Pełna szerokość tylko dla sekcji kalendarza na desktopie */
#wydarzenia .container{ max-width: 100% !important; }

/* === Tabele i kalendarz przewijany horyzontalnie na wąskich ekranach === */
.calendar, .events-table{ max-width: 100%; width: 100%; overflow-x: auto; display: block; }
.calendar table, .events-table table{ width: 100%; table-layout: auto; }

/* Modal */
.modal{ display: none; position: fixed; z-index: 10000; inset: 0; background: rgba(0,0,0,0.6); justify-content: center; align-items: center; padding: 20px; }
.modal-content{ background: #fff; border-radius: 12px; max-width: 800px; width: 100%; padding: 20px; position: relative; box-shadow: 0 4px 14px rgba(0,0,0,0.2); max-height: 90vh; overflow-y: auto; animation: fadeInUp .3s ease; }
.modal-content h3{ margin-top: 0; }
.modal-close{ position: absolute; top: 10px; right: 15px; font-size: 24px; cursor: pointer; color: #333; }
#modal-body img, #modal-body iframe, #modal-body video{ max-width: 100%; height: auto; display: block; margin: 12px auto; border-radius: 8px; }
@keyframes fadeInUp{ from{ opacity:0; transform: translateY(30px);} to{ opacity:1; transform: translateY(0);} }

/* News box */
.news-box{ background:#fff; border-radius:14px; box-shadow:0 4px 14px rgba(0,0,0,0.08); padding:20px; margin:20px auto; max-width:720px; }
.news-box h3{ margin:0 0 10px; font-size:20px; color:#37512E; }
.news-box .meta{ font-size:14px; color:#666; margin-bottom:12px; }
.news-box p, .news-box div{ font-size:15px; line-height:1.6; color:#444; }
#aktualnosci, #aktualnosci .news-box{ max-width:100%; width:100%; box-sizing:border-box; margin-left:auto; margin-right:auto; }
#aktualnosci .excerpt{ word-wrap: break-word; overflow-wrap: break-word; }


/* Użyj klasy .fullbleed na sekcji z kalendarzem, aby rozciągnąć go na szerokość okna
   nawet jeśli jest wewnątrz .container. Działa tylko na desktopie. */
@media (min-width: 992px){
  .fullbleed{ width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
  .fullbleed > .container{ max-width: min(1400px, 100%); }

  /* Jeśli nie możesz dodać .fullbleed, to poszerz automatycznie kontener
     dla sekcji, która zawiera .zb-cal (współczesne przeglądarki). */
  @supports(selector(:has(*))){
    section:has(.zb-cal) > .container{ max-width: min(1400px, 100%); }
  }
}

/* Desktop: powiększ siatkę właściwego kontenera (.zb-cal-grid) */
@media (min-width: 992px){
  /* rozmiar siatki i odstępy */
  .zb-cal-grid{
    grid-template-columns: repeat(7, minmax(140px, 1fr));
    gap: 16px;
    padding: 24px;
    max-width: min(1400px, 100%);
    margin: 0 auto;
    display: grid !important; /* na wszelki wypadek, aby nadpisać mobilne reguły */
  }

  /* większe komórki i numerki dni */
  .zb-cal-cell{ padding: 16px; font-size: 18px; display: block !important; }
  .zb-cal-cell .num{ font-size: 20px; font-weight: 700; }
  
  /* jeśli sekcja ma klasę .container tak jak teraz, poszerz ją na desktopie */
  section.container:has(.zb-cal){ max-width: 1400px !important; }
}

/* ===== Fix: desktop grid belongs to .zb-cal-grid (wrapper .zb-cal should not be grid) ===== */
@media (min-width: 992px){
  .zb-cal{ display: block; }           /* wrapper tylko jako opakowanie */
  .zb-cal-grid{                        /* faktyczna siatka */
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 12px;
  }
}

/* === Floating "Back to top" button === */
.to-top{ 
  position: fixed; right: 16px; bottom: 18px; z-index: 1000;
  display: none; align-items: center; gap: 8px;
  box-shadow: var(--shadow-1);
}
.to-top.show{ display: inline-flex; }
.to-top i{ pointer-events: none; }

/* Na wąskich ekranach kompaktowo */
@media (max-width: 520px){
  .to-top{ right: 12px; bottom: 12px; padding: 10px 12px; }
  .to-top .label{ display: none; } /* na mobile tylko ikonka */
}

/* biała strzałka na przycisku "Do góry" */
.to-top i,
.to-top .fa,
.to-top .fa-solid{
  pointer-events: none;
  margin-left: 6px;
  color: #fff !important;
}

/* Ukryj przycisk "Do góry" na smartfonach */
@media (max-width: 880px){
  #toTop,
  .to-top{
    display: none !important;
  }
}



/* --- Strong Chrome mobile fix: prevent clipping & stacking bugs --- */
@media (max-width: 880px){
  .topbar{
    overflow: visible !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }
  #navMenu.nav-links{
    z-index: 10000 !important;
    pointer-events: auto !important;
  }
  .nav-links{ pointer-events: auto; }
  .nav-links.open{ display: flex !important; }
}

