*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --black:#0A0A0A; --dark:#111111; --dark2:#1A1A1A; --dark3:#222222;
  --brick:#DD8441; --fire:#FB8A04; --fire2:#FF5500;
  --green:#0D8C45; --red:#DD2226; --white:#F0EEEE;
  --muted:#888888; --border:rgba(221,132,65,0.18); --card:rgba(255,255,255,0.04);
}
html{scroll-behavior:smooth;}
body{font-family:'Nunito',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;}

/* ── LOADER ── */
#loader{position:fixed;inset:0;z-index:9999;background:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .7s,visibility .7s;}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.loader-logo{width:min(320px,78vw);animation:loaderIn .8s cubic-bezier(.16,1,.3,1) both;filter:drop-shadow(0 0 40px rgba(251,138,4,.5));}
.loader-logo{animation:loaderIn .8s cubic-bezier(.16,1,.3,1) both, flamePulse 1.6s ease-in-out .8s infinite;}
.loader-dots{display:flex;gap:.6rem;margin-top:2.5rem;animation:loaderIn .6s 1s both;}
.loader-dots span{width:8px;height:8px;border-radius:50%;background:var(--brick);animation:dotBounce 1.2s ease-in-out infinite;}
.loader-dots span:nth-child(2){animation-delay:.15s;background:var(--fire);}
.loader-dots span:nth-child(3){animation-delay:.3s;background:var(--red);}
.loader-text{margin-top:1.2rem;font-size:.78rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);animation:loaderIn .6s 1.1s both;}
@keyframes loaderIn{from{opacity:0;transform:scale(.85) translateY(20px)}to{opacity:1;transform:none}}
@keyframes flamePulse{0%,100%{filter:drop-shadow(0 0 30px rgba(251,138,4,.45))}50%{filter:drop-shadow(0 0 65px rgba(251,138,4,.9));transform:scale(1.02)}}
@keyframes dotBounce{0%,80%,100%{transform:translateY(0);opacity:.4}40%{transform:translateY(-8px);opacity:1}}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:.9rem 5vw;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid transparent;transition:background .3s,border-color .3s,backdrop-filter .3s;}
nav.scrolled{background:rgba(10,10,10,.93);backdrop-filter:blur(20px);border-color:var(--border);}
.nav-logo img{height:50px;width:auto;filter:drop-shadow(0 2px 8px rgba(251,138,4,.3));transition:filter .3s;}
.nav-logo img:hover{filter:drop-shadow(0 4px 18px rgba(251,138,4,.6));}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{color:rgba(240,238,238,.65);text-decoration:none;font-weight:600;font-size:.9rem;transition:color .2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:2px;background:var(--fire);transform:scaleX(0);transform-origin:left;transition:transform .25s;}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{transform:scaleX(1);}
.btn-reserve{background:linear-gradient(135deg,var(--fire2),var(--red));color:#fff;border:none;padding:.6rem 1.4rem;border-radius:100px;font-weight:700;font-size:.88rem;cursor:pointer;transition:all .2s;text-decoration:none;box-shadow:0 4px 20px rgba(251,138,4,.25);}
.btn-reserve:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(251,138,4,.5);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-menu{display:none;position:fixed;top:72px;left:0;right:0;z-index:499;background:rgba(10,10,10,.97);backdrop-filter:blur(20px);padding:2rem 5vw;flex-direction:column;gap:1.5rem;border-bottom:1px solid var(--border);}
.mobile-menu.open{display:flex;}
.mobile-menu a{color:var(--white);text-decoration:none;font-size:1.1rem;font-weight:600;}
@media(max-width:768px){.nav-links{display:none;}.hamburger{display:flex;}}

/* ── COMMON ── */
.section-tag{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brick);margin-bottom:.6rem;}
h2.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;line-height:1.2;letter-spacing:-0.02em;color:var(--white);margin-bottom:.8rem;}
.section-sub{color:var(--muted);max-width:500px;font-size:.95rem;line-height:1.7;}
.container{max-width:1200px;margin:0 auto;padding:0 5vw;}
section{padding:6rem 5vw;}
.flag-divider{height:4px;background:linear-gradient(90deg,var(--green) 33.3%,var(--white) 33.3%,var(--white) 66.6%,var(--red) 66.6%);}

/* ── HERO ── */
#hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:#000;}
.hero-bg-video{
  position:absolute;inset:0;
  background-image:url('hero.jpg');
  background-size:cover;
  background-position:center 40%;
  background-repeat:no-repeat;
  transform:scale(1.04);
  animation:heroZoom 18s ease-in-out infinite alternate;
  will-change:transform;
}
.hero-bg-video::after{
  content:'';
  position:absolute;inset:0;
  background:
    linear-gradient(to right, rgba(0,0,0,.82) 0%, rgba(0,0,0,.55) 55%, rgba(0,0,0,.3) 100%),
    linear-gradient(to bottom, rgba(0,0,0,.25) 0%, transparent 40%, rgba(0,0,0,.5) 100%);
}
@keyframes heroZoom{from{transform:scale(1.04) translateX(0)}to{transform:scale(1.0) translateX(-1%)}}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(221,132,65,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(221,132,65,.04) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 60% 80% at 20% 50%,black 20%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 60% 80% at 20% 50%,black 20%,transparent 80%);}
.hero-content{position:relative;z-index:2;padding:8rem 5vw 5rem;max-width:700px;}
.hero-logo-wrap{margin-bottom:2.5rem;animation:fadeUp .9s .1s both;}
.hero-logo-wrap img{height:160px;width:auto;filter:drop-shadow(0 0 30px rgba(251,138,4,.4));animation:heroLogoPulse 4s ease-in-out 1s infinite;}
@media(max-width:600px){.hero-logo-wrap img{height:115px;}}
@keyframes heroLogoPulse{0%,100%{filter:drop-shadow(0 0 25px rgba(251,138,4,.35))}50%{filter:drop-shadow(0 0 55px rgba(251,138,4,.7))}}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(221,132,65,.1);border:1px solid rgba(221,132,65,.3);color:var(--brick);padding:.4rem 1rem;border-radius:100px;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.5rem;animation:fadeUp .8s .3s both;}
.hero-badge::before{content:'';width:7px;height:7px;background:var(--fire);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.5}}
h1.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,6vw,4.8rem);font-weight:800;line-height:1.05;letter-spacing:-0.02em;color:var(--white);margin-bottom:1.3rem;animation:fadeUp .8s .45s both;}
h1.hero-title em{font-style:italic;color:var(--brick);}
.hero-sub{color:rgba(240,238,238,.65);font-size:1.05rem;line-height:1.75;max-width:480px;margin-bottom:2.5rem;animation:fadeUp .8s .6s both;}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .8s .75s both;}
.btn-primary{background:linear-gradient(135deg,var(--brick),var(--fire2));color:#fff;border:none;padding:.95rem 2.2rem;border-radius:100px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .25s;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 6px 25px rgba(251,138,4,.3);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(251,138,4,.55);}
.btn-secondary{background:rgba(255,255,255,.06);color:var(--white);border:1px solid rgba(255,255,255,.15);padding:.95rem 2.2rem;border-radius:100px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;}
.btn-secondary:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3);}
.hero-info{display:flex;gap:2.5rem;margin-top:4rem;padding-top:2rem;border-top:1px solid rgba(221,132,65,.2);animation:fadeUp .8s .9s both;flex-wrap:wrap;}
.hero-info-item{color:rgba(240,238,238,.5);font-size:.82rem;display:flex;align-items:center;gap:.5rem;}
.hero-info-item strong{color:var(--white);font-size:.9rem;}
@keyframes fadeUp{from{opacity:0;transform:translateY(25px)}to{opacity:1;transform:none}}

/* ── MENU ── */
#menu{background:var(--dark);}
.menu-header{margin-bottom:2.5rem;}
.menu-title-row{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;}

/* Main category tabs */
.cat-tabs{display:flex;gap:0;overflow-x:auto;scrollbar-width:none;border-bottom:2px solid rgba(221,132,65,.15);padding-bottom:0;-webkit-overflow-scrolling:touch;}
.cat-tabs::-webkit-scrollbar{display:none;}
.cat-tab{background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;color:var(--muted);padding:.8rem 1.4rem;font-size:.9rem;font-weight:700;cursor:pointer;font-family:'Nunito',sans-serif;white-space:nowrap;transition:color .2s,border-color .2s;position:relative;}
.cat-tab:hover{color:var(--white);}
.cat-tab.active{color:var(--brick);border-bottom-color:var(--brick);}
.cat-tab.hidden-cat{opacity:.35;}
/* ── MOBILE: mniejsze taby + gradient wskazujący że można scrollować ── */
@media(max-width:640px){
  .cat-tab{
    padding:.65rem .85rem;
    font-size:.76rem;
  }
}
.menu-header{position:relative;}
.menu-header::after{
  content:'';
  position:absolute;
  right:0;
  bottom:2px;
  width:50px;
  height:46px;
  background:linear-gradient(to right, transparent, var(--dark));
  pointer-events:none;
  z-index:1;
}

/* Pizza sub-tabs */
.pizza-sub-wrap{display:none;margin:1.5rem 0 2rem;gap:.5rem;flex-wrap:wrap;}
.pizza-sub-wrap.visible{display:flex;}
.sub-tab{background:transparent;border:1.5px solid rgba(221,132,65,.2);color:var(--muted);padding:.45rem 1.1rem;border-radius:100px;font-size:.82rem;font-weight:700;cursor:pointer;font-family:'Nunito',sans-serif;transition:all .2s;}
.sub-tab:hover{border-color:rgba(221,132,65,.5);color:var(--white);}
.sub-tab.active{background:var(--brick);border-color:var(--brick);color:#fff;box-shadow:0 4px 16px rgba(221,132,65,.35);}

/* Pizza label badge on card */
.pizza-sub-badge{position:absolute;top:12px;left:12px;font-size:.62rem;font-weight:800;padding:.22rem .65rem;border-radius:100px;text-transform:uppercase;letter-spacing:.06em;z-index:2;}
.psb-rosso{background:rgba(221,34,38,.85);color:#fff;}
.psb-bianco{background:rgba(240,238,238,.9);color:#111;}
.psb-sezonowe{background:rgba(13,140,69,.85);color:#fff;}

/* Items grid */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:1.5rem;}
.menu-card{background:var(--dark2);border-radius:18px;overflow:hidden;border:1px solid rgba(221,132,65,.1);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;}
.menu-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.6),0 0 0 1px rgba(221,132,65,.28);border-color:rgba(221,132,65,.32);}
.menu-img{height:195px;position:relative;overflow:hidden;background:var(--dark3);}
.menu-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.menu-card:hover .menu-img img{transform:scale(1.06);}
.menu-img-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;background:linear-gradient(135deg,var(--dark2),var(--dark3));}
.menu-img-placeholder .ph-icon{font-size:4rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4));}
.menu-img-placeholder .ph-label{font-size:.7rem;color:var(--muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase;}
.badge-new{position:absolute;top:12px;right:12px;background:var(--green);color:#fff;font-size:.63rem;font-weight:800;padding:.22rem .65rem;border-radius:100px;letter-spacing:.05em;text-transform:uppercase;z-index:2;}
.badge-popular{position:absolute;top:12px;right:12px;background:linear-gradient(135deg,var(--fire2),var(--brick));color:#fff;font-size:.63rem;font-weight:800;padding:.22rem .65rem;border-radius:100px;letter-spacing:.05em;text-transform:uppercase;z-index:2;}
.menu-body{padding:1.1rem 1.4rem 1.4rem;}
.menu-name{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;margin-bottom:.3rem;color:var(--white);}
.menu-desc{color:var(--muted);font-size:.8rem;line-height:1.6;margin-bottom:.7rem;}
.menu-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.7rem;}
.menu-tag{background:rgba(221,132,65,.08);color:rgba(221,132,65,.75);font-size:.68rem;font-weight:700;padding:.18rem .55rem;border-radius:100px;border:1px solid rgba(221,132,65,.15);}
.menu-price{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:800;color:var(--brick);}
.menu-price small{font-family:'Nunito',sans-serif;font-size:.72rem;color:var(--muted);font-weight:400;}
.menu-empty{text-align:center;padding:3rem;color:var(--muted);grid-column:1/-1;font-size:.95rem;}

/* ── ABOUT ── */
#about{background:var(--black);}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
@media(max-width:900px){.about-inner{grid-template-columns:1fr;gap:3rem;}}
.about-visual{position:relative;}
.about-img-box{background:linear-gradient(135deg,var(--dark2),var(--dark3));border-radius:20px;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);overflow:hidden;}
.about-logo-big{width:70%;opacity:.9;filter:drop-shadow(0 0 30px rgba(251,138,4,.3));}
.about-badge{position:absolute;bottom:-20px;right:-20px;background:linear-gradient(135deg,var(--brick),var(--fire2));color:#fff;padding:1.2rem;border-radius:16px;text-align:center;box-shadow:0 8px 30px rgba(221,132,65,.5);}
.about-badge .num{font-family:'Playfair Display',serif;font-size:2rem;font-weight:800;display:block;}
.about-badge small{font-size:.7rem;font-weight:600;opacity:.85;}
.about-text p{color:var(--muted);line-height:1.85;margin-bottom:1.2rem;font-size:.95rem;}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem;}
.about-stat{text-align:center;background:var(--dark2);border-radius:12px;padding:1rem;border:1px solid var(--border);transition:border-color .2s;}
.about-stat:hover{border-color:rgba(221,132,65,.4);}
.about-stat .n{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:800;color:var(--brick);}
.about-stat small{font-size:.75rem;color:var(--muted);font-weight:600;}

/* ── FOOTER ── */
footer{background:#050505;border-top:1px solid var(--border);padding:2.5rem 5vw;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.footer-logo img{height:46px;opacity:.85;}
footer p{font-size:.82rem;color:var(--muted);}
.footer-flag{display:flex;gap:.3rem;align-items:center;}
.ff{width:24px;height:3px;border-radius:2px;}
.ff.g{background:var(--green);}.ff.w{background:var(--white);}.ff.r{background:var(--red);}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(25px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.reveal.visible{opacity:1;transform:none;}
.reveal-d2{transition-delay:.2s;}.reveal-d3{transition-delay:.3s;}
