:root {
  --neon-pink: #ff2d95;
  --neon-cyan: #00f5ff;
  --neon-yellow: #ffe600;
  --neon-green: #39ff14;
  --neon-purple: #b026ff;
  --neon-orange: #ff6e27;
  --bg-dark: #0a0a12;
  --bg-card: rgba(15, 15, 30, 0.85);
  --bg-card-hover: rgba(25, 25, 50, 0.95);
  --text-main: #e8e8f0;
  --text-dim: #8888aa;
  --radius: 16px;
  --radius-sm: 10px;
  --transition: 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  --font-display: 'Orbitron', sans-serif;
  --font-body: 'Rajdhani', sans-serif;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

html{scroll-behavior:smooth;font-size:16px}

body{
  font-family:var(--font-body);
  background:var(--bg-dark);
  color:var(--text-main);
  overflow-x:hidden;
  min-height:100vh;
  line-height:1.5;
}

#neon-particles{
  position:fixed;
  top:0;left:0;
  width:100%;height:100%;
  pointer-events:none;
  z-index:0;
}

.cursor-glow{
  position:fixed;
  width:300px;height:300px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(0,245,255,0.12) 0%,transparent 70%);
  pointer-events:none;
  z-index:1;
  transform:translate(-50%,-50%);
  transition:opacity 0.3s;
  opacity:0;
}
body:hover .cursor-glow{opacity:1}

/* ── HERO ── */
.hero{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:100vh;
  text-align:center;
  z-index:2;
  overflow:hidden;
  background:radial-gradient(ellipse at 50% 80%, rgba(255,45,149,0.08) 0%, transparent 60%),
             radial-gradient(ellipse at 20% 20%, rgba(0,245,255,0.06) 0%, transparent 50%),
             var(--bg-dark);
}

.hero-content{position:relative;z-index:3;padding:2rem}

.logo-wrapper{margin-bottom:1.5rem}

.logo-container{
  position:relative;
  display:inline-block;
  margin:0 auto 0.5rem;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}

.logo-tilt{
  position:relative;
  z-index:2;
  transform-style:preserve-3d;
  will-change:transform;
  animation:logoIdle 6s ease-in-out infinite;
}

.logo-tilt.is-animated{
  animation:none;
}

@keyframes logoIdle{
  0%,100%{transform:perspective(900px) rotateX(4deg) rotateY(-4deg) translateY(0) scale(1.04)}
  50%{transform:perspective(900px) rotateX(-4deg) rotateY(4deg) translateY(-9px) scale(1.04)}
}

.logo-img{
  width:clamp(200px,45vw,380px);
  height:auto;
  display:block;
  position:relative;
  z-index:2;
  border-radius:50%;
  filter:drop-shadow(0 0 30px rgba(255,45,149,0.65)) drop-shadow(0 0 55px rgba(0,245,255,0.45)) drop-shadow(0 0 80px rgba(176,38,255,0.25));
  transition:filter 0.35s ease;
  user-select:none;
  -webkit-user-drag:none;
}

.logo-shine{
  position:absolute;
  inset:0;
  border-radius:50%;
  z-index:3;
  pointer-events:none;
  opacity:1;
  background:radial-gradient(circle at 50% 50%, rgba(255,255,255,0.45) 0%, rgba(255,230,0,0.12) 25%, transparent 55%);
  mix-blend-mode:overlay;
}

.logo-container.is-hover .logo-img{
  filter:drop-shadow(0 0 38px rgba(255,45,149,0.8)) drop-shadow(0 0 65px rgba(0,245,255,0.55)) drop-shadow(0 0 95px rgba(176,38,255,0.35));
}

.logo-sparks{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
  overflow:visible;
}

.logo-spark{
  position:absolute;
  width:6px;height:6px;
  border-radius:50%;
  pointer-events:none;
  animation:sparkFly 0.7s ease-out forwards;
}

@keyframes sparkFly{
  0%{opacity:1;transform:translate(0,0) scale(1)}
  100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0)}
}

.logo-ripple{
  position:absolute;
  left:50%;top:50%;
  width:100%;aspect-ratio:1;
  border-radius:50%;
  border:2px solid var(--neon-cyan);
  transform:translate(-50%,-50%) scale(0.6);
  opacity:0.8;
  pointer-events:none;
  z-index:1;
  animation:logoRipple 0.85s ease-out forwards;
}

@keyframes logoRipple{
  to{transform:translate(-50%,-50%) scale(1.6);opacity:0;border-color:var(--neon-pink)}
}

.logo-glow-ring{
  position:absolute;
  inset:-20%;
  border-radius:50%;
  border:2px solid rgba(0,245,255,0.45);
  box-shadow:0 0 50px rgba(0,245,255,0.35), inset 0 0 50px rgba(255,45,149,0.12);
  animation:ringPulse 1.2s ease-in-out infinite;
  z-index:1;
  pointer-events:none;
}

.logo-glow-ring-2{
  inset:-35%;
  border-color:rgba(255,45,149,0.35);
  animation-delay:-1.5s;
  animation-duration:1.5s;
}

@keyframes ringPulse{
  0%,100%{transform:scale(1) rotate(0deg);opacity:0.6}
  50%{transform:scale(1.08) rotate(5deg);opacity:1}
}

.logo-container::after{
  content:'';
  position:absolute;
  inset:-10%;
  background:radial-gradient(circle, rgba(255,45,149,0.15) 0%, transparent 70%);
  z-index:0;
  border-radius:50%;
  animation:logoAura 2s ease-in-out infinite;
  opacity:1;
  pointer-events:none;
}

@keyframes logoAura{
  0%,100%{opacity:0.5;transform:scale(1)}
  50%{opacity:1;transform:scale(1.15)}
}

.logo-container.logo-pulse .logo-img{
  animation:logoImgPulse 0.55s cubic-bezier(0.34,1.56,0.64,1);
}

@keyframes logoImgPulse{
  0%,100%{transform:scale(1)}
  45%{transform:scale(1.09)}
}

.logo-subtitle{
  font-family:var(--font-display);
  font-size:clamp(0.9rem,2.5vw,1.4rem);
  letter-spacing:0.5em;
  margin-top:0.8rem;
  color:var(--neon-cyan);
  text-shadow:0 0 10px var(--neon-cyan),0 0 30px var(--neon-cyan);
}

.neon-line::before,.neon-line::after{
  content:'';
  display:inline-block;
  width:clamp(20px,8vw,60px);
  height:1px;
  background:var(--neon-cyan);
  box-shadow:0 0 6px var(--neon-cyan);
  vertical-align:middle;
  margin:0 0.8rem;
}

.hero-tagline{
  font-size:clamp(1rem,2.5vw,1.3rem);
  color:var(--text-dim);
  font-weight:400;
  letter-spacing:0.15em;
  text-transform:uppercase;
}

.scroll-indicator{
  position:absolute;
  bottom:1rem;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0.5rem;
  animation:bobUp 2s ease-in-out infinite;
  color:var(--text-dim);
  font-size:0.85rem;
  letter-spacing:0.15em;
  text-transform:uppercase;
  z-index:3;
}

.scroll-arrow{
  width:20px;height:20px;
  border-right:2px solid var(--neon-cyan);
  border-bottom:2px solid var(--neon-cyan);
  transform:rotate(45deg);
  box-shadow:2px 2px 4px rgba(0,245,255,0.3);
}

@keyframes bobUp{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-8px)}}

/* ── NAV ── */
.category-nav{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(10,10,18,0.95);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(0,245,255,0.12);
  box-shadow:0 4px 30px rgba(0,0,0,0.4);
}

.nav-inner{
  max-width:1100px;
  margin:0 auto;
  padding:0.5rem 1rem;
  display:flex;
  flex-direction:column;
  gap:0.5rem;
}

.table-badge{
  display:flex;
  align-items:center;
  gap:0.5rem;
  justify-content:center;
  font-family:var(--font-display);
  font-size:0.8rem;
  letter-spacing:0.08em;
  color:var(--neon-purple);
  text-shadow:0 0 8px rgba(176,38,255,0.4);
  padding:0.3rem 0;
}

.table-badge svg{filter:drop-shadow(0 0 4px var(--neon-purple))}
.table-badge strong{font-size:1rem;color:var(--neon-cyan);text-shadow:0 0 10px var(--neon-cyan)}

.nav-scroll-wrapper{
  display:flex;
  align-items:center;
  gap:0.4rem;
}

.nav-arrow{
  flex-shrink:0;
  width:34px;height:34px;
  border-radius:50%;
  border:1px solid rgba(0,245,255,0.2);
  background:rgba(0,245,255,0.05);
  color:var(--neon-cyan);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:var(--transition);
  opacity:0.4;
}

.nav-arrow:hover{
  opacity:1;
  background:rgba(0,245,255,0.15);
  box-shadow:0 0 12px rgba(0,245,255,0.3);
}

.nav-track{
  display:flex;
  gap:0.5rem;
  overflow-x:auto;
  scrollbar-width:none;
  scroll-behavior:smooth;
  padding:0.2rem 0;
}
.nav-track::-webkit-scrollbar{display:none}

.nav-btn{
  font-family:var(--font-body);
  font-size:0.9rem;
  font-weight:600;
  letter-spacing:0.04em;
  padding:0.55rem 1.2rem;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:50px;
  background:rgba(255,255,255,0.03);
  color:var(--text-dim);
  cursor:pointer;
  white-space:nowrap;
  transition:var(--transition);
  position:relative;
  overflow:hidden;
  flex-shrink:0;
}

.nav-btn::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  opacity:0;
  transition:opacity var(--transition);
}

.nav-btn:hover{
  color:#fff;
  border-color:rgba(0,245,255,0.3);
  background:rgba(0,245,255,0.06);
  text-shadow:0 0 6px var(--neon-cyan);
}

.nav-btn.active{
  color:#fff;
  border-color:var(--neon-cyan);
  background:linear-gradient(135deg,rgba(0,245,255,0.2),rgba(176,38,255,0.15));
  text-shadow:0 0 10px var(--neon-cyan),0 0 30px var(--neon-cyan);
  box-shadow:0 0 20px rgba(0,245,255,0.2),0 0 40px rgba(0,245,255,0.05),inset 0 0 20px rgba(0,245,255,0.08);
}

.nav-btn.active::before{
  background:linear-gradient(90deg,transparent,rgba(0,245,255,0.15),transparent);
  opacity:1;
  animation:shimmer 2s infinite;
}

@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ── MENU SECTIONS ── */
.menu-container{
  position:relative;
  z-index:2;
  max-width:1100px;
  margin:0 auto;
  padding:2rem 1.2rem 4rem;
}

.menu-section{
  margin-bottom:3.5rem;
  opacity:0;
  transform:translateY(40px);
  transition:opacity 0.6s ease, transform 0.6s ease;
}

.menu-section.visible{
  opacity:1;
  transform:translateY(0);
}

.section-title{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,4vw,2.2rem);
  font-weight:700;
  margin-bottom:1.5rem;
  padding-bottom:0.6rem;
  border-bottom:2px solid;
  display:flex;
  align-items:center;
  gap:0.6rem;
}

.section-icon{
  font-size:1.5em;
  filter:drop-shadow(0 0 6px currentColor);
}

.products-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:1rem;
}

/* ── PRODUCT CARD ── */
.product-card{
  position:relative;
  background:var(--bg-card);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--radius);
  padding:1.4rem 1.3rem;
  display:flex;
  flex-direction:column;
  gap:0.7rem;
  cursor:pointer;
  transition:var(--transition);
  overflow:hidden;
}

.product-card::before{
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg,transparent 40%,var(--neon-pink) 50%,var(--neon-cyan) 60%,transparent 70%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  opacity:0;
  transition:opacity var(--transition);
}

.product-card:hover{
  background:var(--bg-card-hover);
  transform:translateY(-4px) scale(1.01);
  box-shadow:0 8px 40px rgba(0,0,0,0.4),0 0 20px rgba(0,245,255,0.08);
}
.product-card:hover::before{opacity:1}

.product-name{
  font-size:1.25rem;
  font-weight:700;
  color:#fff;
  letter-spacing:0.02em;
}

.product-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:auto;
}

.product-price{
  font-family:var(--font-display);
  font-size:1.35rem;
  font-weight:700;
  color:var(--neon-yellow);
  text-shadow:0 0 8px rgba(255,230,0,0.4);
}

.add-btn{
  width:42px;height:42px;
  border-radius:50%;
  border:2px solid var(--neon-green);
  background:transparent;
  color:var(--neon-green);
  font-size:1.5rem;
  font-weight:300;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:var(--transition);
  position:relative;
  overflow:hidden;
  line-height:1;
}

.add-btn::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:50%;
  background:var(--neon-green);
  opacity:0;
  transition:opacity var(--transition);
}

.add-btn:hover{
  color:var(--bg-dark);
  box-shadow:0 0 20px var(--neon-green),0 0 40px rgba(57,255,20,0.3);
  transform:scale(1.15);
}
.add-btn:hover::before{opacity:1}
.add-btn span{position:relative;z-index:1}

/* ── CART FAB ── */
.cart-fab{
  position:fixed;
  bottom:2rem;right:2rem;
  width:60px;height:60px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--neon-pink),var(--neon-purple));
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:200;
  box-shadow:0 4px 25px rgba(255,45,149,0.4),0 0 40px rgba(176,38,255,0.2);
  transition:var(--transition);
  animation:pulseFab 3s ease-in-out infinite;
}

@keyframes pulseFab{
  0%,100%{box-shadow:0 4px 25px rgba(255,45,149,0.4),0 0 40px rgba(176,38,255,0.2)}
  50%{box-shadow:0 4px 35px rgba(255,45,149,0.6),0 0 60px rgba(176,38,255,0.4)}
}

.cart-fab:hover{
  transform:scale(1.12);
  box-shadow:0 4px 35px rgba(255,45,149,0.6),0 0 60px rgba(176,38,255,0.4);
}

.cart-count{
  position:absolute;
  top:-4px;right:-4px;
  width:22px;height:22px;
  border-radius:50%;
  background:var(--neon-cyan);
  color:var(--bg-dark);
  font-family:var(--font-display);
  font-size:0.7rem;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform 0.3s cubic-bezier(0.68,-0.55,0.27,1.55);
}
.cart-count.bounce{animation:bounceCount 0.4s cubic-bezier(0.68,-0.55,0.27,1.55)}

@keyframes bounceCount{0%{transform:scale(1)}50%{transform:scale(1.5)}100%{transform:scale(1)}}

/* ── CART PANEL ── */
.overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.6);
  backdrop-filter:blur(4px);
  z-index:250;
  opacity:0;
  pointer-events:none;
  transition:opacity var(--transition);
}
.overlay.active{opacity:1;pointer-events:all}

.cart-panel{
  position:fixed;
  top:0;right:-100%;
  width:min(420px,90vw);
  height:100vh;
  background:rgba(10,10,20,0.97);
  border-left:1px solid rgba(0,245,255,0.2);
  z-index:300;
  display:flex;
  flex-direction:column;
  transition:right 0.45s cubic-bezier(0.25,0.8,0.25,1);
  box-shadow:-10px 0 50px rgba(0,0,0,0.5);
}

.cart-panel.active{right:0}

.cart-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1.5rem;
  border-bottom:1px solid rgba(0,245,255,0.12);
}

.cart-header h2{
  font-family:var(--font-display);
  font-size:1.3rem;
  color:var(--neon-cyan);
  text-shadow:0 0 10px var(--neon-cyan);
  letter-spacing:0.05em;
}

.cart-close{
  width:36px;height:36px;
  border-radius:50%;
  border:1px solid rgba(0,245,255,0.3);
  background:transparent;
  color:var(--neon-cyan);
  font-size:1.4rem;
  cursor:pointer;
  transition:var(--transition);
  display:flex;align-items:center;justify-content:center;
}
.cart-close:hover{
  background:rgba(0,245,255,0.1);
  box-shadow:0 0 15px rgba(0,245,255,0.3);
}

.cart-items{
  flex:1;
  overflow-y:auto;
  padding:1rem 1.5rem;
  scrollbar-width:thin;
  scrollbar-color:rgba(0,245,255,0.3) transparent;
}

.cart-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0.9rem 0;
  border-bottom:1px solid rgba(255,255,255,0.05);
  animation:slideIn 0.3s ease;
}

@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

.cart-item-info{flex:1}
.cart-item-name{font-weight:600;font-size:1.05rem}
.cart-item-price{font-size:0.85rem;color:var(--neon-yellow);margin-top:0.15rem}

.cart-item-qty{
  display:flex;
  align-items:center;
  gap:0.6rem;
  margin:0 1rem;
}

.qty-btn{
  width:28px;height:28px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,0.2);
  background:transparent;
  color:#fff;
  font-size:1rem;
  cursor:pointer;
  transition:var(--transition);
  display:flex;align-items:center;justify-content:center;
}
.qty-btn:hover{border-color:var(--neon-cyan);color:var(--neon-cyan);box-shadow:0 0 10px rgba(0,245,255,0.2)}

.qty-num{font-family:var(--font-display);font-weight:700;min-width:1.2rem;text-align:center}

.cart-item-total{
  font-family:var(--font-display);
  font-weight:700;
  color:var(--neon-green);
  text-shadow:0 0 6px rgba(57,255,20,0.4);
  min-width:70px;
  text-align:right;
}

.cart-footer{
  padding:1.5rem;
  border-top:1px solid rgba(0,245,255,0.12);
}

.cart-table-info{
  display:flex;
  align-items:center;
  gap:0.4rem;
  justify-content:center;
  font-family:var(--font-display);
  font-size:0.8rem;
  letter-spacing:0.06em;
  color:var(--text-dim);
  margin-bottom:1rem;
  padding:0.5rem 1rem;
  background:rgba(176,38,255,0.08);
  border:1px solid rgba(176,38,255,0.2);
  border-radius:var(--radius-sm);
}

.cart-table-info svg{color:var(--neon-purple);filter:drop-shadow(0 0 4px var(--neon-purple))}
.cart-table-info strong{color:var(--neon-cyan);text-shadow:0 0 8px var(--neon-cyan);font-size:1rem}

.send-order-btn{
  width:100%;
  padding:0.9rem 1.5rem;
  border:none;
  border-radius:var(--radius-sm);
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:#fff;
  font-family:var(--font-body);
  font-size:1.05rem;
  font-weight:700;
  letter-spacing:0.04em;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0.6rem;
  transition:var(--transition);
  margin-top:0.8rem;
  position:relative;
  overflow:hidden;
}

.send-order-btn::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
  transform:translateX(-100%);
  transition:transform 0.6s;
}

.send-order-btn:hover::after{transform:translateX(100%)}

.send-order-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 25px rgba(37,211,102,0.4),0 0 50px rgba(37,211,102,0.15);
}

.send-order-btn:active{transform:translateY(0)}

.send-order-btn:disabled{
  opacity:0.4;
  cursor:not-allowed;
  filter:grayscale(0.5);
}
.send-order-btn:disabled:hover{transform:none;box-shadow:none}
.send-order-btn:disabled::after{display:none}

.cart-total{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--font-display);
  font-size:1.3rem;
  font-weight:700;
  margin-bottom:0.4rem;
}

.cart-total span:first-child{color:var(--text-dim);letter-spacing:0.1em}
.cart-total span:last-child{color:var(--neon-yellow);text-shadow:0 0 12px rgba(255,230,0,0.5)}

.tax-note{font-size:0.8rem;color:var(--text-dim);text-align:center}

.cart-empty{
  text-align:center;
  padding:3rem 1rem;
  color:var(--text-dim);
}

.cart-empty-icon{font-size:3rem;margin-bottom:1rem;opacity:0.4}
.cart-empty p{font-size:1.1rem;letter-spacing:0.05em}

/* ── FOOTER ── */
.footer{
  position:relative;
  z-index:2;
  text-align:center;
  padding:2rem 1rem;
  color:var(--text-dim);
  font-size:0.85rem;
  border-top:1px solid rgba(255,255,255,0.05);
}

/* ── TOAST ── */
.toast{
  position:fixed;
  bottom:6rem;left:50%;
  transform:translateX(-50%) translateY(80px);
  background:rgba(57,255,20,0.15);
  border:1px solid var(--neon-green);
  color:var(--neon-green);
  padding:0.7rem 1.5rem;
  border-radius:50px;
  font-family:var(--font-body);
  font-size:0.95rem;
  font-weight:600;
  letter-spacing:0.03em;
  z-index:999;
  opacity:0;
  pointer-events:none;
  transition:all 0.4s cubic-bezier(0.68,-0.55,0.27,1.55);
  box-shadow:0 0 20px rgba(57,255,20,0.2);
  text-shadow:0 0 8px rgba(57,255,20,0.5);
}
.toast.show{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .products-grid{grid-template-columns:1fr}
  .product-card{padding:1.1rem 1rem}
  .cart-fab{bottom:1.2rem;right:1.2rem;width:54px;height:54px}
  .hero{min-height:85vh}
  .nav-inner{padding:0.4rem 0.6rem}
  .nav-btn{font-size:0.82rem;padding:0.45rem 0.9rem}
  .logo-img{width:clamp(170px,58vw,280px)}
}

@media(max-width:480px){
  .nav-btn{font-size:0.78rem;padding:0.4rem 0.8rem}
  .section-title{font-size:1.3rem}
  .nav-arrow{width:30px;height:30px}
}

@media(min-width:769px){
  .products-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
}