/*
 Theme Name: Kruszywa Łomianki
 Author: Hubert Ziółek
 Description:
 Version: 1.0.0
 License: GNU General Public License v2 or later
 Text Domain: kruszywa
*/

:root{
  --kl-black:#0b0b0d;
  --kl-gold:#d4b23a;
  --kl-white:#ffffff;
  --kl-gray:#f5f5f7;
}

html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,"Noto Sans",sans-serif;color:var(--kl-white);background:var(--kl-black);}
a{color:var(--kl-gold);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* Topbar */
.topbar{background:linear-gradient(180deg, rgba(0,0,0,.8), rgba(0,0,0,.4));font-size:.95rem}
.topbar .container{display:flex;gap:16px;justify-content:flex-end;align-items:center;padding:8px 20px}
.topbar .container{
  display:flex;
  gap:16px;
  justify-content:flex-end;
  align-items:center;
  padding:8px 20px;
  flex-wrap: wrap;
}
.topbar .container span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}
@media (max-width: 900px){
  .topbar .container{ justify-content:space-between; }
}
@media (max-width: 640px){
  .topbar{ font-size:.9rem; }
  .topbar .container{
    padding:6px 12px;
    gap:6px;
    justify-content:center;
  }
  .topbar .container span{
    flex:1 1 100%;
    text-align:center;
    white-space:normal;
    overflow-wrap:anywhere;
    line-height:1.35;
  }
}

/* Header + menu (podstawy) */
.header{background:var(--kl-black);border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:10}
.header .container{display:flex;align-items:center;justify-content:space-between;padding:14px 20px}
.brand{display:flex;gap:12px;align-items:center}
.custom-logo{height:84px;width:auto;}
nav ul{list-style:none;display:flex;gap:20px;margin:0;padding:0}
nav a{color:var(--kl-white);font-weight:600}

/* Przyciski */
.btn{display:inline-block;background:var(--kl-gold);color:#111;padding:12px 18px;border-radius:10px;font-weight:700}
.btn-outline{background:transparent;border:2px solid var(--kl-gold);color:var(--kl-gold)}

/* Hero */
.hero{position:relative;background:#111 url(assets/bg.jpg) center/cover no-repeat;padding:120px 0}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.6), rgba(0,0,0,.7));}
.hero .container{position:relative;z-index:1}
.hero h1{font-size:48px;margin:0 0 16px;font-weight:900;letter-spacing:.5px}
.hero p{max-width:720px;font-size:18px;opacity:.95}

/* Karty i sekcje */
.grid{display:grid;gap:20px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.card{background:#16171a;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.card .thumb{aspect-ratio:4/3;background:#222 url(assets/bg.jpg) center/cover no-repeat}
.card .content{padding:16px}
.section{padding:64px 0;background:#0f1012}
.section.alt{background:#121316}
.section h2{margin:0 0 24px;font-size:34px}

/* ===== Kontakt: responsywne kolumny ===== */
.kontakt-columns{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:32px;
  align-items:start;
}
.kontakt-columns h3{margin:0 0 8px}
/* tablet */
@media (max-width: 1024px){
  .kontakt-columns{
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap:24px;
  }
}
/* telefon */
@media (max-width: 640px){
  .kontakt-columns{
    grid-template-columns: 1fr;
    gap:16px;
  }
  .kontakt-columns > *{ min-width:0; }
  .kontakt-columns p,
  .kontakt-columns li,
  .kontakt-columns div{
    overflow-wrap:anywhere;
    word-break:break-word;
  }
}

/* Stopka i tabela */
.footer{background:#0b0b0d;border-top:1px solid rgba(255,255,255,.08);padding:28px 0;color:#c9c9ce}
.badge{display:inline-block;background:var(--kl-gold);color:#111;font-weight:800;padding:4px 10px;border-radius:999px;font-size:.8rem}
.table{width:100%;border-collapse:collapse;border:1px solid rgba(255,255,255,.1)}
.table th,.table td{border-bottom:1px solid rgba(255,255,255,.08);padding:12px;text-align:left}
* { box-sizing: border-box; }

.grid { align-items: stretch; }
.grid .card { display:flex; flex-direction:column; height:100%; }
.card .thumb { flex:0 0 auto; }
.card .content { flex:1 1 auto; }
.card h3 { margin:0 0 .4rem; line-height:1.2; }

/* Mobile layout zmiany ogólne */
@media (max-width: 640px){
  .custom-logo { height: 52px; }
  .grid.cols-3, .grid.cols-4 { grid-template-columns: 1fr; }
  .hero h1 { font-size: 28px; line-height: 1.3; }
  .btn { padding: 10px 14px; font-size: 14px; }
}

/* Układ: desktop 2 kolumny, mobile 1 kolumna (pojedyncza karta kruszywa) */
.kruszywo-layout{
  display:grid;
  grid-template-columns: 1.5fr 1fr;
  gap:24px;
}
@media (max-width: 960px){
  .kruszywo-layout{ grid-template-columns:1fr; }
}

/* Wrapper na zdjęcie – proporcje i kadrowanie */
.kruszywo-photo{
  position:relative;
  width:100%;
  aspect-ratio: 4 / 3;
  overflow:hidden;
  border-radius:12px;
  background:#111;
}
@media (max-width: 900px){
  .kruszywo-photo{ aspect-ratio:auto; height:56vw; max-height:520px; }
}
.kruszywo-photo img.kruszywo-thumb{
  position:absolute;
  inset:0;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block;
  border-radius:12px;
}

/* Slider: Kategorie kruszyw */
.kl-kruszywa-swiper { position: relative; }
.kl-kruszywa-swiper .swiper-slide { height: auto; }
.kl-kruszywa-swiper .card { height: 100%; }

/* Strzałki slidera */
.kl-swiper-prev, .kl-swiper-next{
  position:absolute;
  top:-48px;
  right:44px;
  width:36px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.08);
  cursor:pointer;
}
.kl-swiper-prev{ right:88px; }
.kl-swiper-prev::before, .kl-swiper-next::before{
  content:"";
  display:block;
  width:10px;
  height:10px;
  border-top:2px solid #fff;
  border-right:2px solid #fff;
  margin:11px auto;
  transform: rotate(225deg);
}
.kl-swiper-next::before{ transform: rotate(45deg); }
.kl-swiper-prev:hover, .kl-swiper-next:hover{ background:rgba(255,255,255,.16); }
@media (max-width: 640px){
  .kl-swiper-prev, .kl-swiper-next{ top:-40px; width:32px; height:32px; }
  .kl-swiper-prev{ right:76px; }
}
/* Ukrywamy paginację (kropki) */
.kl-kruszywa-swiper .swiper-pagination { display:none !important; }

/* ===== Menu mobilne — kompaktowe + overlay (overlay nie zakrywa panelu) ===== */
.menu-toggle{ display:none; }

@media (max-width: 768px){
  :root{ --drawer-w: min(80vw, 320px); }       /* szerokość szuflady */

  .custom-logo{ height:44px; }
  .brand strong{ font-size:18px; line-height:1.1; }

  .menu-toggle{
    display:inline-flex; align-items:center; justify-content:center;
    width:40px; height:40px; border:1px solid rgba(255,255,255,.18);
    border-radius:10px; background:rgba(255,255,255,.06); cursor:pointer;
    touch-action: manipulation;
  }
  .menu-toggle span{ display:block; width:20px; height:2px; background:#fff; margin:3px 0; }
@media (max-width: 768px){
  .menu-toggle{
    -webkit-tap-highlight-color: transparent;
    user-select: none;
  }
}

  /* Panel nawigacji (nad overlayem) */
  .site-nav{
    display:none;
    position:fixed;
    top:56px; right:0;
    width:var(--drawer-w);
    height:auto;
    max-height:80vh;
    overflow:auto;
    -webkit-overflow-scrolling: touch;
    background:#111315;
    border-left:1px solid rgba(255,255,255,.08);
    padding:14px;
    z-index:3001;                               /* NAD overlayem */
    box-shadow:-12px 0 30px rgba(0,0,0,.35);
    border-bottom-left-radius:12px;
    pointer-events:auto;
  }
  body.menu-open .site-nav{ display:block; }

  .site-nav ul{ display:flex; flex-direction:column; gap:12px; margin:0; padding:0; list-style:none; }
  .site-nav a{ display:block; padding:10px 8px; font-size:18px; color:#fff; touch-action: manipulation; }

  /* Overlay – nie nachodzi na panel (ma prawą krawędź przy lewej krawędzi panelu) */
  .menu-overlay{
    display:none;
    position:fixed;
    top:0; bottom:0; left:0; right:0;
    background:rgba(0,0,0,.4);
    z-index:3000;                               /* POD panelem */
  }
  body.menu-open .menu-overlay{
    display:block;
    right:var(--drawer-w);                      /* <-- klucz: odsuwamy overlay spod panelu */
  }

  /* drobny limit szerokości na bardzo małych ekranach dla bezpieczeństwa */
  .header nav{ max-width:240px; width:65vw; margin-left:auto; }

  body.menu-open{ overflow:hidden; }
}
@media (max-width: 360px){
  .site-nav{ width:85vw; padding:12px; }
  .site-nav a{ font-size:16px; padding:8px 6px; }
}

/* ===== Desktop reset ===== */
@media (min-width: 769px){
  .menu-toggle{ display:none !important; }
  .header .container{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

  .site-nav{
    display:block !important;
    position:static !important;
    inset:auto !important;
    width:auto !important; height:auto !important;
    padding:0 !important; background:transparent !important;
    border:0 !important; box-shadow:none !important;
    overflow:visible !important;
    z-index:auto !important;
  }
  .site-nav ul{
    display:flex !important;
    flex-direction:row !important;
    gap:22px !important;
  }
  .site-nav a{ padding:0; font-size:16px; }
  .menu-overlay{ display:none !important; }
}
