/* ============================
   style.css
============================= */

/* ========== :ROOT / BASE ========== */
:root{
  --red: #D62828;
  --yellow: #FFCA3A;
  --black: #222222;
  --bg: #FFFFFF;
  --surface: #F7F7F7;
  --muted: #6b6b6b;
  --glass: rgba(255,255,255,0.08);
  --max-width: 1200px;
  --container-pad: 20px;
  --gap: 20px;
  --transition: 0.22s ease;
  --elevation: 0 12px 36px rgba(0,0,0,0.12);
  --accent-gradient: linear-gradient(135deg,var(--yellow),var(--red));
  --cta-texture: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(0,0,0,0.06));
  --radius: 12px;
  --shadow: 0 12px 32px rgba(0,0,0,0.08);
}

/* ========== RESET / BASE ========== */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Montserrat, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background: linear-gradient(180deg,#fff,#f7f7f7 70%);
  color:var(--black);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--container-pad);} 

/* Small helpers */
.center{text-align:center}
.hidden{display:none!important}

/* focus-visible accessibility */
:focus { outline: none; }
:focus-visible {
  outline: 3px solid var(--yellow);
  outline-offset: 3px;
  border-radius: 6px;
}

/* ========== HEADER / NAV ========== */
.site-header{
  background:
    linear-gradient(180deg, rgba(0,0,0,0.55), rgba(0,0,0,0.25)),
    url('../images/header.jpg') center/cover no-repeat;
  color:white;
  padding-bottom:64px;
}
.header-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 0;
  gap:12px;
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit}
.brand-logo{
  width:64px;height:64px;border-radius:12px;background:var(--glass);
  padding:8px;object-fit:contain;display:block;border:2px solid rgba(255,255,255,0.06);
}
.brand-title{
  font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--yellow);
  letter-spacing:0.5px;text-shadow:0 2px 4px rgba(0,0,0,0.35)
}

/* Header actions (phone + toggle) */
.header-actions{display:flex;align-items:center;gap:12px}
.phone-link{
  display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;
  text-decoration:none;color:#fff;font-weight:800;background:var(--accent-gradient);
  box-shadow:0 8px 28px rgba(214,40,40,0.14); position:relative; overflow:hidden;
}
/* subtle texture stripe over CTA */
.phone-link::after{
  content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg, rgba(255,255,255,0.03) 0 4px, transparent 4px 12px);
  mix-blend-mode:overlay;opacity:0.35;pointer-events:none;
}

/* NAV */
.nav-toggle{display:none;background:none;border:0;color:white;font-size:28px;cursor:pointer}
.nav-inner{display:flex;justify-content:space-between;align-items:center;padding:14px 0;width:100%}
.nav-list{display:flex;gap:20px;list-style:none;padding:0;margin:0}
.nav-list a{
  color:white;text-decoration:none;font-weight:700;padding:8px 10px;border-radius:8px;display:inline-block;
  transition:background .18s ease, transform .18s ease;
}
.nav-list a:hover{background:rgba(255,255,255,0.08);transform:translateY(-2px)}

/* Desktop main-nav always visible; mobile handled in media queries */
.main-nav{position:static;transform:none;transition:transform .25s ease;z-index:50}
.main-nav.open{transform:none}

/* ========== HERO ========== */
.hero{display:grid;grid-template-columns:1fr 420px;gap:32px;align-items:center;padding:48px 0}
.hero-left h1{
  font-family:'Bebas Neue',sans-serif;font-size:56px;color:var(--yellow);margin:0 0 12px;
  text-shadow:0 6px 18px rgba(0,0,0,0.45)
}
.lead{color:rgba(255,255,255,0.95);font-size:18px;margin-bottom:20px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;text-decoration:none;border-radius:12px;padding:10px 14px;font-weight:800;cursor:pointer}
.btn.large{padding:14px 20px;border-radius:16px}
.btn-primary{
  background:var(--accent-gradient);color:white;box-shadow:0 14px 40px rgba(214,40,40,0.12);
  position:relative;overflow:hidden;
}
.btn-primary::after{
  content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg, rgba(255,255,255,0.03) 0 6px, transparent 6px 14px);
  mix-blend-mode:overlay;opacity:0.32;pointer-events:none;
}
.btn-outline{
  background:transparent;border:2px solid rgba(255,255,255,0.18);color:white;padding:10px 14px;border-radius:12px;font-weight:800
}

/* Features chips */
.feature-list{display:flex;flex-wrap:wrap;gap:12px;padding:0;margin:18px 0 0 0;list-style:none}
.feature-list li{
  padding:10px 16px;background:rgba(255,255,255,0.12);border-radius:999px;font-weight:700;color:white;
  display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;font-size:14px
}
.hero-right{text-align:right}
.hero-image{width:100%;border-radius:18px;box-shadow:0 18px 50px rgba(0,0,0,0.55);border:5px solid rgba(255,255,255,0.12);display:block}

/* ========== SECTIONS ========== */
.section{padding:64px 0}
.section h2{font-family:'Bebas Neue',sans-serif;font-size:38px;color:var(--yellow);margin:0 0 12px}
.section-sub{color:var(--muted);margin-bottom:18px}

/* ========== ABOUT ========== */
.about-flex{display:flex;gap:40px;align-items:center}
.about-image-box{flex:1;position:relative}
.about-image-box img{
  width:100%;border-radius:16px;box-shadow:0 12px 35px rgba(0,0,0,0.18);height:100%;max-height:380px;object-fit:cover;border:4px solid rgba(255,255,255,0.08);display:block
}
.about-content{flex:1;display:flex;flex-direction:column;gap:14px}

/* ========== STATS (kafelki) ========== */
.stats-wrapper{display:flex;gap:20px;margin-top:18px}
.stat-card{
  flex:1;padding:18px;border-radius:14px;color:white;background:var(--accent-gradient);
  box-shadow:var(--elevation);text-align:center;transition:transform .22s ease,box-shadow .22s ease;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
}
.stat-card:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(0,0,0,0.22)}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:44px;line-height:1}
.stat-label{font-weight:700;opacity:0.98}

/* ========== MENU ========== */
.menu-filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.chip{
  padding:10px 14px;border-radius:999px;background:var(--surface);border:0;font-weight:800;cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,0.04);transition:transform .12s ease,background .12s ease;
}
.chip:active{transform:translateY(1px)}
.chip.active{background:var(--red);color:white;box-shadow:0 14px 40px rgba(214,40,40,0.12)}
.chip:hover:not(.active){background:var(--yellow);color:var(--black)}

.menu-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:white;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,0.04);display:flex;flex-direction:column}
.card img{width:100%;height:200px;object-fit:cover;display:block}
.card-body{padding:14px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.card-row{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.price{color:var(--red);font-weight:800;font-size:18px}

/* ========== GALLERY ========== */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}
.gallery a{display:block;border-radius:12px;overflow:hidden}
.gallery img{
  width:100%;height:200px;object-fit:cover;border-radius:12px;display:block;
  transition:transform .35s ease,box-shadow .35s ease,opacity .6s ease;opacity:0;transform:translateY(18px)
}
.gallery img.visible{opacity:1;transform:translateY(0)}
.gallery img:hover{transform:scale(1.03);box-shadow:0 18px 48px rgba(0,0,0,0.18)}

/* Lightbox (JS toggles .open) */
.lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.75);z-index:12000;opacity:0;pointer-events:none;transition:opacity .2s ease}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox .inner{max-width:90%;max-height:90%;border-radius:12px;overflow:hidden}
.lightbox img{width:100%;height:auto;display:block}
.lightbox .caption{margin-top:8px;color:#fff;text-align:center;font-size:14px;opacity:0.95}

/* ========== LOKALIZACJA / KONTAKT ========== */
.kontakt-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:30px;align-items:start}
.kontakt-info{
  background:var(--surface);padding:22px;border-radius:14px;position:relative;overflow:visible;
  box-shadow:0 10px 28px rgba(0,0,0,0.06);
}
.kontakt-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.kontakt-row .k-icon{
  width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,rgba(0,0,0,0.03),rgba(0,0,0,0.01));font-size:18px;color:var(--red);flex-shrink:0;
  box-shadow:0 6px 20px rgba(0,0,0,0.06)
}
.kontakt-row p{margin:0;color:var(--black);line-height:1.35;font-size:15px}
.kontakt-row a{text-decoration:none;color:var(--red);font-weight:700}

/* full clickable overlay */
.kontakt-info .full-link{position:absolute;inset:0;z-index:1;text-indent:-9999px}
.kontakt-info .actions{display:flex;gap:10px;margin-top:12px;z-index:2;position:relative}
.kontakt-btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;background:var(--red);color:white;text-decoration:none;font-weight:800;box-shadow:0 10px 28px rgba(214,40,40,0.12)
}
.kontakt-btn.secondary{background:transparent;color:var(--black);border:1px solid rgba(0,0,0,0.06)}

/* map wrapper */
.map-wrapper{width:100%;height:420px;border-radius:12px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,0.12)}
.map-wrapper iframe{width:100%;height:100%;border:0;display:block}

/* tap hint */
.kontakt-tap-hint{font-size:13px;color:var(--muted);margin-top:8px}

/* ========== FOOTER – 3 kolumny ========== */
.site-footer{background:#121212;color:#fff;padding:36px 0}
.footer-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.footer-col{padding:0 12px}
.footer-col p{margin:8px 0;color:#ddd}
.logo-mini{height:48px;width:auto;display:block;margin-bottom:6px}

/* center column nav */
.footer-nav{display:flex;flex-direction:column;gap:8px;align-items:center}
.footer-nav a{color:#fff;text-decoration:none;font-weight:700;padding:6px 10px;border-radius:8px;transition:background .18s ease}
.footer-nav a:hover{background:rgba(255,255,255,0.04)}

/* right column actions + socials */
.footer-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-end}
.footer-actions a{
  display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,0.04);color:#fff;text-decoration:none;font-weight:700
}
.footer-actions a.primary{background:var(--red);box-shadow:0 12px 36px rgba(214,40,40,0.12)}
.socials{display:flex;gap:8px;align-items:center;justify-content:flex-end;margin-top:12px}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,0.04);color:#fff;text-decoration:none;font-weight:700}
.socials a:hover{background:var(--yellow);color:var(--black)}

/* small print centered under footer for mobile */
.footer-muted{grid-column:1/-1;text-align:center;color:#bdbdbd;margin-top:14px;font-size:13px}

/* ========== RESPONSIVE TABLET ========== */
@media (max-width:1100px){
  .hero{grid-template-columns:1fr 360px}
  .menu-cards{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .kontakt-grid{grid-template-columns:1fr}
}

/* Desktop guarantee: ensure nav visible */
@media (min-width:721px){
  .main-nav{transform:none !important;position:static;width:auto;height:auto;background:transparent;padding:0}
  .main-nav .nav-list{align-items:center}
}
/* === CATERING BOX === */
.catering-box h2 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 38px;
  color: var(--yellow);
  margin-bottom: 12px;
}

.catering-inner {
  background: var(--surface);
  border-radius: 14px;
  padding: 22px;
  box-shadow: 0 12px 28px rgba(0,0,0,0.08);
  border: 1px solid rgba(0,0,0,0.04);
}

.catering-inner .intro {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 14px;
  color: var(--black);
}

.catering-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px 0;
}

.catering-list li {
  padding: 8px 0;
  font-weight: 600;
  color: var(--black);
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.catering-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  background: var(--red);
  color: white;
  font-weight: 800;
  text-decoration: none;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(214,40,40,0.15);
  transition: transform 0.18s ease;
}

.catering-btn:hover {
  transform: translateY(-2px);
}
