/*
Theme Name: Chamas Pizzaria
Theme URI: https://chamaspizzaria.local
Author: Chamas Pizzaria
Description: Tema WordPress customizado para landing page e cardápio interativo da Chamas Pizzaria.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: chamas-pizzaria
*/
:root {
  --bg:#080604;
  --bg2:#130d09;
  --card:#17100b;
  --card2:#21160d;
  --text:#fff8ee;
  --muted:#cbb9a4;
  --line:rgba(255,255,255,.12);
  --fire:#ff3d00;
  --orange:#ff8a00;
  --gold:#ffd36a;
  --green:#25d366;
  --radius:28px;
  --shadow:0 24px 70px rgba(0,0,0,.45);
  --max:1180px
}
* {
  box-sizing:border-box
}
html {
  scroll-behavior:smooth
}
body {
  margin:0;
  font-family:Inter,system-ui,sans-serif;
  background:radial-gradient(circle at 20% 0%,rgba(255,61,0,.2),transparent 30%),linear-gradient(180deg,var(--bg),#0d0704 45%,#050403);
  color:var(--text);
  overflow-x:hidden
}
a {
  color:inherit;
  text-decoration:none
}
img {
  max-width:100%;
  display:block
}
code {
  color:var(--gold)
}
.noise {
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 260 260' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  z-index:3
}
.cursor-glow {
  position:fixed;
  width:420px;
  height:420px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(255,138,0,.14),transparent 62%);
  transform:translate(-50%,-50%);
  pointer-events:none;
  z-index:1
}
.section-padding {
  width:min(var(--max),calc(100% - 36px));
  margin:auto;
  padding:108px 0
}
.site-header {
  position:fixed;
  top:16px;
  left:50%;
  transform:translateX(-50%);
  z-index:20;
  width:min(var(--max),calc(100% - 36px));
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(10,7,4,.72);
  backdrop-filter:blur(20px);
  box-shadow:var(--shadow)
}
.brand {
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em
}
.brand img {
  width:42px;
  height:42px;
  border-radius:50%;
  object-fit:cover
}
.brand strong,.eyebrow {
  color:var(--orange)
}
.nav-links {
  display:flex;
  align-items:center;
  gap:24px;
  color:var(--muted);
  font-weight:700
}
.nav-links a {
  transition:.25s
}
.nav-links a:hover {
  color:var(--gold);
  transform:translateY(-2px)
}
.nav-cta {
  padding:12px 18px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--fire),var(--orange));
  color:#160b03!important;
  box-shadow:0 0 30px rgba(255,91,0,.45)
}
.menu-toggle {
  display:none;
  background:none;
  border:0
}
.hero-video {
  position:relative;
  min-height:100vh;
  display:grid;
  place-items:center;
  overflow:hidden;
  padding:120px 18px 70px
}
.hero-bg-video,.hero-overlay {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover
}
.hero-bg-video {
  z-index:0;
  background:url('assets/hero-video-poster.png') center/cover no-repeat
}
.hero-overlay {
  z-index:1;
  background:linear-gradient(90deg,rgba(5,3,2,.92),rgba(5,3,2,.55),rgba(5,3,2,.85)),radial-gradient(circle at 24% 38%,rgba(255,61,0,.35),transparent 35%)
}
.hero-content {
  position:relative;
  z-index:2;
  width:min(var(--max),100%);
  margin:auto
}
.eyebrow {
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:900;
  font-size:.78rem
}
.pulse-dot {
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--fire);
  box-shadow:0 0 0 0 rgba(255,61,0,.8);
  animation:pulse 1.6s infinite
}
h1,h2 {
  font-family:'Bebas Neue',Impact,sans-serif;
  line-height:.9;
  margin:18px 0;
  letter-spacing:.02em
}
h1 {
  font-size:clamp(4rem,10vw,9rem);
  max-width:920px
}
h2 {
  font-size:clamp(3rem,6vw,5.8rem)
}
h3 {
  margin:0 0 10px
}
.hero-content p,.section-copy p,.section-heading p,.visit-section p,.final-cta p,.menu-callout-copy p {
  font-size:1.15rem;
  line-height:1.75;
  color:var(--muted);
  max-width:650px
}
.hero-actions,.center-actions {
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px
}
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 24px;
  border-radius:999px;
  font-weight:900;
  transition:transform .25s,box-shadow .25s,border .25s
}
.btn-primary {
  background:linear-gradient(135deg,var(--gold),var(--orange),var(--fire));
  color:#1a0c02;
  box-shadow:0 16px 44px rgba(255,91,0,.32)
}
.btn-ghost,.btn-outline {
  border:1px solid rgba(255,211,106,.5);
  background:rgba(255,255,255,.05);
  color:var(--gold)
}
.btn-outline {
  color:var(--text);
  border-color:var(--line)
}
.btn:hover {
  transform:translateY(-4px) scale(1.02)
}
.scroll-cue {
  position:absolute;
  z-index:2;
  bottom:28px;
  color:var(--muted);
  font-weight:800;
  letter-spacing:.08em;
  animation:breathe 2s infinite
}
.quick-info {
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
  color:#e5d0b7;
  font-weight:700
}
.quick-info span,.glass-card {
  border:1px solid var(--line);
  background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.03));
  backdrop-filter:blur(16px);
  border-radius:999px;
  padding:10px 14px
}
.split-section,.contact-section,.final-cta {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center
}
.image-stack {
  position:relative
}
.image-stack img {
  border-radius:var(--radius);
  box-shadow:var(--shadow)
}
.mini-review {
  position:absolute;
  right:20px;
  bottom:20px;
  border-radius:22px;
  max-width:310px
}
.stats-grid,.benefit-grid {
  display:grid;
  gap:18px
}
.stats-grid {
  grid-template-columns:repeat(3,1fr);
  margin-top:28px
}
.stats-grid div,.tilt-card,.contact-card,.contact-form {
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  padding:26px;
  box-shadow:0 18px 45px rgba(0,0,0,.22);
  transition:transform .25s,border .25s,background .25s
}
.stats-grid strong {
  display:block;
  font-size:2rem;
  color:var(--gold)
}
.stats-grid span,.tilt-card p {
  color:var(--muted)
}
.section-heading {
  text-align:center;
  max-width:840px;
  margin:0 auto 44px
}
.benefit-grid {
  grid-template-columns:repeat(4,1fr)
}
.tilt-card:hover {
  border-color:rgba(255,211,106,.45);
  background:linear-gradient(145deg,rgba(255,138,0,.14),rgba(255,255,255,.04))
}
.benefit-icon {
  width:64px;
  height:64px;
  object-fit:contain;
  margin-bottom:24px;
  filter:drop-shadow(0 0 18px rgba(255,138,0,.28))
}
.menu-callout-card {
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  overflow:hidden;
  border:1px solid rgba(255,211,106,.2);
  border-radius:calc(var(--radius) + 14px);
  background:radial-gradient(circle at 18% 20%,rgba(255,61,0,.2),transparent 35%),linear-gradient(135deg,#190f09,#080604);
  box-shadow:var(--shadow)
}
.menu-callout-image {
  min-height:430px;
  background:rgba(255,255,255,.03)
}
.menu-callout-image img {
  width:100%;
  height:100%;
  object-fit:cover
}
.menu-callout-copy {
  padding:56px;
  display:grid;
  align-content:center
}
.contact-section {
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line)
}
.contact-form {
  border-radius:var(--radius);
  display:grid;
  gap:16px
}
.contact-form label {
  display:grid;
  gap:8px;
  color:var(--gold);
  font-weight:900
}
.contact-form input,.contact-form textarea {
  width:100%;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(0,0,0,.25);
  color:var(--text);
  padding:16px;
  font:inherit;
  outline:none
}
.contact-form input:focus,.contact-form textarea:focus {
  border-color:rgba(255,211,106,.65);
  box-shadow:0 0 0 4px rgba(255,138,0,.12)
}
.final-cta {
  width:min(var(--max),calc(100% - 36px));
  margin:40px auto 90px;
  padding:36px;
  border-radius:calc(var(--radius) + 10px);
  background:radial-gradient(circle at 20% 50%,rgba(255,61,0,.2),transparent 30%),linear-gradient(135deg,#1a100a,#080604);
  border:1px solid rgba(255,211,106,.2);
  box-shadow:var(--shadow)
}
.final-cta img {
  max-height:340px;
  margin:auto
}
.floating-whatsapp {
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:30;
  width:64px;
  height:64px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:1.6rem;
  background:var(--green);
  box-shadow:0 18px 45px rgba(37,211,102,.35);
  animation:breathe 2s infinite
}
.site-footer {
  width:min(var(--max),calc(100% - 36px));
  margin:auto;
  padding:48px 0;
  color:var(--muted);
  border-top:1px solid var(--line)
}
.footer-grid {
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:34px
}
.footer-grid h3 {
  color:var(--gold)
}
.footer-grid a {
  display:block;
  color:var(--muted);
  margin:10px 0
}
.social-links {
  display:flex;
  gap:12px;
  margin-top:18px
}
.social-links a {
  width:42px;
  height:42px;
  border:1px solid var(--line);
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.05)
}
.social-links img {
  width:22px;
  height:22px
}
.footer-bottom {
  border-top:1px solid var(--line);
  margin-top:34px;
  padding-top:20px;
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap
}
.menu-page {
  padding-top:130px
}
.menu-page .section-heading {
  text-align:left;
  margin-left:0
}
.menu-section {
  margin-bottom:70px
}
.menu-list {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px
}
.menu-item {
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
  background:rgba(255,255,255,.04)
}
.menu-item strong {
  display:block;
  color:var(--gold);
  text-transform:uppercase
}
.menu-item span {
  display:block;
  color:var(--muted);
  margin-top:8px
}
[data-animate] {
  opacity:1;
  transform:translateY(28px);
  transition:opacity .8s ease,transform .8s ease
}
[data-animate].is-visible {
  opacity:1;
  transform:none
}
@keyframes pulse {
  70% {
    box-shadow:0 0 0 14px rgba(255,61,0,0)
  }

}
@keyframes breathe {
  50% {
    transform:scale(1.04)
  }

}
@media (max-width:900px) {
  .menu-toggle {
    display:grid;
    gap:5px
  }
  .menu-toggle span {
    width:25px;
    height:2px;
    background:var(--gold)
  }
  .nav-links {
    position:absolute;
    top:72px;
    left:0;
    right:0;
    display:none;
    flex-direction:column;
    padding:22px;
    border:1px solid var(--line);
    border-radius:24px;
    background:#0b0705
  }
  .nav-links.open {
    display:flex
  }
  .split-section,.contact-section,.final-cta,.menu-callout-card {
    grid-template-columns:1fr
  }
  .benefit-grid,.menu-list {
    grid-template-columns:1fr 1fr
  }
  .stats-grid {
    grid-template-columns:1fr
  }
  .footer-grid {
    grid-template-columns:1fr 1fr
  }
  .menu-callout-image {
    min-height:320px
  }

}
@media (max-width:560px) {
  .section-padding {
    padding:72px 0
  }
  .benefit-grid,.menu-list,.footer-grid {
    grid-template-columns:1fr
  }
  h1 {
    font-size:4.2rem
  }
  .hero-actions .btn {
    width:100%
  }
  .quick-info span {
    width:100%
  }
  .site-header {
    top:8px
  }
  .brand span {
    font-size:.86rem
  }
  .menu-callout-copy {
    padding:28px
  }
  .footer-bottom {
    display:block
  }
  .mini-review {
    position:static;
    margin-top:14px
  }
  .hero-video {
    padding-top:110px
  }

}
h1 {
  font-size:3rem!important;
  line-height:1.04!important;
  max-width:760px
}
h2 {
  font-size:2rem!important;
  line-height:1.12!important
}
h3 {
  font-size:1.5rem!important;
  line-height:1.18!important
}
.site-header {
  left:50%;
  right:auto;
  max-width:var(--max);
  width:calc(100% - 36px);
  overflow:visible
}
.brand {
  min-width:0;
  flex-shrink:0
}
.brand span {
  white-space:nowrap
}
.nav-links {
  margin-left:auto;
  min-width:0;
  flex-wrap:wrap;
  justify-content:flex-end
}
.nav-links.open {
  display:flex
}
.nav-links a {
  white-space:nowrap
}
.menu-toolbar {
  position:sticky;
  top:98px;
  z-index:10;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  margin:24px 0 42px;
  padding:14px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(10,7,4,.82);
  backdrop-filter:blur(18px)
}
.category-pills {
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding-bottom:2px
}
.category-pills a {
  flex:0 0 auto;
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 14px;
  color:var(--muted);
  font-weight:800
}
.cart-toggle {
  border:0;
  cursor:pointer
}
.menu-item {
  display:grid;
  gap:12px
}
.menu-item-actions {
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between
}
.qty-control {
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 10px;
  background:rgba(0,0,0,.18)
}
.qty-control button,.cart-row button,.cart-close {
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.1);
  color:var(--text);
  width:30px;
  height:30px;
  cursor:pointer;
  font-weight:900
}
.add-to-cart {
  border:0;
  cursor:pointer;
  min-height:44px;
  padding:0 16px
}
.cart-drawer {
  position:fixed;
  top:0;
  right:0;
  bottom:0;
  width:min(430px,100%);
  background:linear-gradient(180deg,#130d09,#070503);
  border-left:1px solid rgba(255,211,106,.22);
  box-shadow:-24px 0 70px rgba(0,0,0,.5);
  z-index:60;
  transform:translateX(105%);
  transition:transform .3s ease;
  display:flex;
  flex-direction:column
}
.cart-drawer.open {
  transform:translateX(0)
}
.cart-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px;
  border-bottom:1px solid var(--line)
}
.cart-head h2 {
  margin:0
}
.cart-body {
  padding:18px;
  overflow:auto;
  display:grid;
  gap:12px
}
.cart-row {
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
  background:rgba(255,255,255,.04);
  display:grid;
  gap:8px
}
.cart-row-top {
  display:flex;
  justify-content:space-between;
  gap:12px
}
.cart-row small {
  color:var(--muted)
}
.cart-row-actions {
  display:flex;
  align-items:center;
  justify-content:space-between
}
.cart-empty {
  color:var(--muted);
  text-align:center;
  padding:34px 12px
}
.cart-footer {
  border-top:1px solid var(--line);
  padding:18px;
  display:grid;
  gap:12px
}
.cart-note {
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(0,0,0,.25);
  color:var(--text);
  padding:14px;
  font:inherit;
  min-height:78px;
  resize:vertical
}
.cart-overlay {
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  z-index:55;
  opacity:0;
  pointer-events:none;
  transition:.25s
}
.cart-overlay.open {
  opacity:1;
  pointer-events:auto
}
.menu-page .section-heading p {
  max-width:720px
}
.menu-help {
  color:var(--muted);
  font-weight:700
}
@media (max-width:900px) {
  .site-header {
    border-radius:28px
  }
  .nav-links {
    position:absolute;
    top:72px;
    left:0;
    right:0;
    margin-left:0;
    display:none;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    padding:22px;
    border:1px solid var(--line);
    border-radius:24px;
    background:#0b0705
  }
  .nav-links.open {
    display:flex
  }
  .menu-toolbar {
    top:90px;
    align-items:stretch;
    flex-direction:column
  }
  .cart-toggle {
    width:100%
  }

}
@media (max-width:560px) {
  h1 {
    font-size:3rem!important
  }
  h2 {
    font-size:2rem!important
  }
  h3 {
    font-size:1.5rem!important
  }
  .brand span {
    font-size:.78rem
  }
  .site-header {
    width:calc(100% - 20px);
    padding:12px
  }
  .menu-page {
    padding-top:112px
  }
  .menu-toolbar {
    top:82px
  }

}
.btn.disabled {
  opacity:.55;
  pointer-events:none;
  filter:grayscale(.35)
}
.site-header {
    left:18px!important;
    right:18px!important;
    width:auto!important;
    max-width:var(--max)!important;
    margin:0 auto!important;
    transform:none!important;
    overflow:visible!important;

}
.site-header .brand {
  flex:0 0 auto;
  min-width:max-content
}
.site-header .nav-links {
  flex:1 1 auto;
  min-width:0;
  justify-content:flex-end;
  overflow:visible
}
.site-header .nav-links a {
  white-space:nowrap
}
@media (max-width:900px) {
    .site-header {
    left:10px!important;
    right:10px!important;
    width:auto!important;
    max-width:none!important
  }
    .site-header .brand {
    min-width:0
  }
    .site-header .nav-links {
    left:0;
    right:0;
    width:auto;
    overflow:visible
  }

}
.promo-banner {
  padding-top:34px;
  padding-bottom:34px
}
.promo-banner-card{
  width:100%;
  max-width:1180px;
  margin:auto;
  overflow:hidden;
  border-radius:32px;
}

.promo-banner-card img{
  width:100%;
  height:auto;
  display:block;
}

@media (max-width:760px) {
  .promo-banner {
    padding-top:22px
  }
  .promo-banner-content {
    position:static;
    border-radius:0;
    border-left:0;
    border-right:0;
    border-bottom:0
  }
  .promo-banner-content .hero-actions .btn {
    width:100%
  }

}
.qty-control  {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    width: fit-content;
    white-space: nowrap;

}
.qty-control button  {
    flex: 0 0 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;

}
.menu-item-actions  {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px;

}
.menu-actions {
    display:flex;
    justify-content:left;
    gap:16px;
    margin-top:28px;
    flex-wrap:wrap;

}
.menu-actions .btn {
    min-width:220px;

}
@media (max-width:560px) {
    .menu-actions {
        flex-direction:column;

  }
    .menu-actions .btn {
        width:100%;

  }

}

/* Carrossel de promoções */
.promo-carousel {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 420px;
  overflow: hidden;
  background: #090604;
}

.promo-slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transform: scale(1.025);
  transition: opacity .9s ease, transform 7s ease;
}

.promo-slide.active {
  opacity: 1;
  transform: scale(1);
}

.promo-dots {
  position: absolute;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  background: rgba(8,6,4,.48);
  backdrop-filter: blur(12px);
}

.promo-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.38);
  transition: .3s ease;
}

.promo-dots span.active {
  width: 26px;
  border-radius: 999px;
  background: var(--gold);
  box-shadow: 0 0 18px rgba(255,211,106,.55);
}

@media (max-width:760px) {
  .promo-carousel {
    aspect-ratio: 4 / 5;
    min-height: 360px;
  }

  .promo-slide {
    object-fit: cover;
  }
}


/* Ajustes WordPress */
body.admin-bar .site-header{top:48px}
@media (min-width:783px){body.admin-bar .site-header{top:48px}}
@media (max-width:782px){body.admin-bar .site-header{top:62px}}
.qty-control{display:inline-flex!important;flex-direction:row!important;align-items:center!important;justify-content:center!important;gap:10px!important;width:fit-content;white-space:nowrap}
.qty-control button{flex:0 0 30px;display:inline-flex;align-items:center;justify-content:center}
.menu-item-actions{display:flex!important;flex-direction:row!important;align-items:center!important;justify-content:space-between!important;gap:12px}
