*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#0A0A0A;color:#EEEEEE;overflow-x:hidden}

:focus-visible{
  outline:2px solid #F4A261;
  outline-offset:3px;
}

button,a,input,textarea,label{
  -webkit-tap-highlight-color:transparent;
}

img{
  max-width:100%;
  display:block;
}

.demo-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid rgba(244,162,97,0.35);
  background:rgba(244,162,97,0.12);
  color:#F4A261;
  font-size:10px;
  line-height:1;
  font-weight:800;
  letter-spacing:0.14em;
  text-transform:uppercase;
}

.demo-note{
  border:1px solid rgba(244,162,97,0.35);
  background:linear-gradient(135deg,rgba(244,162,97,0.14),rgba(230,57,70,0.08));
  color:#F4A261;
}

::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:#0A0A0A}
::-webkit-scrollbar-thumb{background:#2A2A2A;border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#E63946}

.gradient-text{
  background:linear-gradient(135deg,#E63946 0%,#F4A261 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}

.btn-primary{
  background:linear-gradient(135deg,#E63946 0%,#D65A31 100%);
  color:#fff;
  padding:14px 32px;
  border-radius:999px;
  font-weight:600;
  letter-spacing:0.3px;
  transition:all .3s cubic-bezier(0.22,1,0.36,1);
  box-shadow:0 8px 24px rgba(230,57,70,0.3);
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  border:none;
  font-family:inherit;
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(230,57,70,0.5);
}
.btn-primary:active{transform:translateY(0)}

.btn-secondary{
  background:rgba(255,255,255,0.05);
  color:#EEEEEE;
  padding:14px 32px;
  border-radius:999px;
  font-weight:500;
  border:1px solid rgba(255,255,255,0.1);
  transition:all .3s ease;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  font-family:inherit;
}
.btn-secondary:hover{
  background:rgba(255,255,255,0.1);
  border-color:rgba(255,255,255,0.2);
}

.glass{
  background:rgba(20,20,20,0.7);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.08);
}

.card-pizza{
  background:linear-gradient(180deg,#1C1C1C 0%,#141414 100%);
  border:1px solid #2A2A2A;
  border-radius:24px;
  overflow:hidden;
  transition:all .4s cubic-bezier(0.22,1,0.36,1);
}
.card-pizza:hover{
  border-color:rgba(230,57,70,0.5);
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(230,57,70,0.15);
}
.card-pizza img{transition:transform .6s ease}
.card-pizza:hover img{transform:scale(1.08)}

.chip{
  display:inline-flex;
  align-items:center;
  padding:6px 14px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  letter-spacing:0.5px;
  text-transform:uppercase;
}
.chip-red{background:rgba(230,57,70,0.15);color:#E63946;border:1px solid rgba(230,57,70,0.3)}
.chip-gold{background:rgba(244,162,97,0.15);color:#F4A261;border:1px solid rgba(244,162,97,0.3)}

.hero-gradient{
  background:
    radial-gradient(ellipse at top left, rgba(230,57,70,0.15) 0%, transparent 50%),
    radial-gradient(ellipse at bottom right, rgba(214,90,49,0.15) 0%, transparent 50%),
    #0A0A0A;
}


.hero-pizza-image{
  object-position:center center;
  filter:saturate(1.05) contrast(1.05);
}

.grain::after{
  content:'';
  position:absolute;
  inset:0;
  opacity:0.03;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.nav-link{
  position:relative;
  color:#EEEEEE;
  padding:8px 4px;
  font-weight:500;
  font-size:14px;
  transition:color .3s ease;
}
.nav-link::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  width:0;
  height:2px;
  background:linear-gradient(90deg,#E63946,#F4A261);
  transition:width .3s ease;
}
.nav-link:hover{color:#fff}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link.active{color:#E63946}

.topping-chip{
  padding:10px 16px;
  border-radius:12px;
  border:1px solid #2A2A2A;
  background:#141414;
  cursor:pointer;
  transition:all .25s ease;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-size:14px;
}
.topping-chip:hover{border-color:#E63946;background:#1C1C1C}
.topping-chip.selected{
  border-color:#E63946;
  background:rgba(230,57,70,0.1);
  color:#fff;
}

.size-option{
  padding:16px;
  border-radius:16px;
  border:2px solid #2A2A2A;
  background:#141414;
  cursor:pointer;
  transition:all .25s ease;
  text-align:center;
}
.size-option:hover{border-color:#3A3A3A}
.size-option.selected{
  border-color:#E63946;
  background:rgba(230,57,70,0.08);
}

.input-field{
  width:100%;
  padding:14px 16px;
  background:#141414;
  border:1px solid #2A2A2A;
  border-radius:12px;
  color:#EEEEEE;
  font-family:inherit;
  font-size:15px;
  transition:all .25s ease;
}
.input-field:focus{
  outline:none;
  border-color:#E63946;
  box-shadow:0 0 0 3px rgba(230,57,70,0.1);
}

.fade-in{animation:fadeIn .6s cubic-bezier(0.22,1,0.36,1)}
@keyframes fadeIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

.stagger-item{opacity:0;animation:staggerIn .6s cubic-bezier(0.22,1,0.36,1) forwards}
@keyframes staggerIn{to{opacity:1;transform:translateY(0)}}

.pizza-float{animation:float 6s ease-in-out infinite}
@keyframes float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-20px) rotate(3deg)}
}

.spin-slow{animation:spin 40s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.shimmer{
  background:linear-gradient(90deg,#1C1C1C 0%,#2A2A2A 50%,#1C1C1C 100%);
  background-size:200% 100%;
  animation:shimmer 1.5s infinite;
}
@keyframes shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

.toast{
  background:rgba(20,20,20,0.95);
  backdrop-filter:blur(20px);
  border:1px solid rgba(230,57,70,0.3);
  border-radius:12px;
  padding:14px 20px;
  display:flex;
  align-items:center;
  gap:12px;
  min-width:280px;
  box-shadow:0 10px 40px rgba(0,0,0,0.5);
  animation:toastIn .4s cubic-bezier(0.22,1,0.36,1);
}
@keyframes toastIn{
  from{transform:translateX(120%);opacity:0}
  to{transform:translateX(0);opacity:1}
}

@media (max-width:768px){
  .hero-title{font-size:3rem!important;line-height:1.05!important}
  .btn-primary,.btn-secondary{width:100%;justify-content:center}
  .toast{min-width:calc(100vw - 32px)}
  #toast-root{left:16px;right:16px;top:16px}
}

@media (max-width:480px){
  .hero-title{font-size:2.55rem!important}
  .chip{font-size:10px;padding:5px 10px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}
}
