/* Base */
:root{
  --bg:#fff;
  --text:#222;
  --muted:#6b7280;
  --primary:#a01111; /* tom vermelho vinho */
  --primary-700:#7f0d0d;
  --accent:#2ecc71;
  --surface:#f7f7f8;
  --ring: rgba(160,17,17,.35);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: 'Montserrat', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
}
.scroll-locked{overflow:hidden}
.container{max-width:1100px;margin:0 auto;padding:0 20px}

/* Header */
.site-header{position:sticky;top:0;background:#fff;border-bottom:1px solid #eee;z-index:500}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px;gap:16px}
.brand{display:flex;align-items:center;gap:12px}
.logo{font-size:28px}
.brand-text strong{display:block;font-weight:800}
.brand-text small{display:block;color:var(--muted)}
.actions{display:flex;gap:10px}

/* Buttons */
.btn{appearance:none;border:none;border-radius:999px;padding:10px 16px;font-weight:700;cursor:pointer;transition:.25s transform,.2s background,.2s box-shadow}
.btn.primary{background:var(--primary);color:#fff}
.btn.primary:hover{background:var(--primary-700)}
.btn.ghost{background:#fff;border:1px solid #ddd;color:var(--text)}
.btn:active{transform:translateY(1px) scale(.98)}
.btn:focus{outline:none;box-shadow:0 0 0 4px var(--ring)}

/* Hero */
.hero{padding:36px 20px 8px 20px;text-align:center}
.hero h1{font-size:48px;margin:8px 0 0 0;color:var(--primary);font-weight:800}
.hero h2{margin:6px 0 0 0;font-weight:800}
.hero .subtitle{color:var(--muted);max-width:760px;margin:10px auto 0}

/* Timer oferta */
.offer-timer{position:sticky;top:68px;background:#A01111;color:#fff;font-weight:700;z-index:60;margin-top:8px}
.offer-timer .container{padding:10px 20px;display:flex;align-items:center;justify-content:center;text-align:center}
.offer-text{display:flex;flex-direction:column;gap:4px}
.offer-title{font-size:20px;font-weight:800;letter-spacing:.2px}
.offer-sub{font-size:16px;font-weight:700}
.old-price{color:#9ca3af;text-decoration:line-through;font-weight:600}

/* Combos grid */
.combos{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:28px 0}
.combo-card{background:var(--surface);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:8px;border:1px solid #eee;position:relative;overflow:hidden}
.combo-card::after{content:"";position:absolute;inset:0;background:radial-gradient(800px 200px at 50% -20%, rgba(160,17,17,.08), transparent 60%);pointer-events:none;opacity:0;transition:.35s opacity}
.combo-card:hover::after{opacity:1}
.combo-header h3{margin:0 0 6px 0;font-size:22px}
.combo-items{margin:0;color:var(--muted);min-height:48px}
.combo-media{display:grid;place-items:center;height:160px}
.combo-media img{max-width:100%;max-height:150px;object-fit:contain;transition:.45s transform,.45s filter}
.combo-footer{display:flex;align-items:center;justify-content:space-between}
.price{font-size:28px;font-weight:800;color:#19a34a}
.price small{font-size:14px;vertical-align:top;margin-right:2px}
.see-btn{background:transparent;border:1px dashed var(--primary);color:var(--primary)}

/* Interactive press effect */
.combo-card.active{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,.08)}
.combo-card.active .combo-media img{transform:scale(1.05) rotate(-1deg);filter:drop-shadow(0 10px 20px rgba(160,17,17,.22))}
.combo-card.active .see-btn{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Top pizzas */
.top-pizzas{padding:20px 0 60px 0;text-align:center}
.top-pizzas h2{font-size:34px;margin:0 0 6px 0}
.top-pizzas p{color:var(--muted)}
.chips{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.chips .chip{padding:10px 14px;border:1px solid #ddd;border-radius:999px;background:#fff;font-weight:600}

/* Avaliações */
.reviews{padding:26px 0}
.reviews h2{margin:0 0 12px 0}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.review-card{display:flex;flex-direction:column;gap:8px;align-items:flex-start;border:1px solid #eee;background:#fff;border-radius:12px;padding:10px}
.review-photo{width:100%;height:200px;border-radius:10px;object-fit:cover}
.stars{color:#f59e0b;font-size:16px}

/* Footer */
.site-footer{border-top:1px solid #eee;background:#fff}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:22px 0}
.footer-links{display:flex;gap:14px}
.footer-links a{color:var(--muted);text-decoration:none}
.footer-links a:hover{text-decoration:underline}

/* Modal */
.modal{position:fixed;inset:0;display:none;z-index:1000}
.modal[aria-hidden="false"]{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:saturate(120%) blur(2px)}
.modal-dialog{position:relative;margin:10vh auto 0 auto;max-width:760px;background:#fff;border-radius:16px;padding:20px 20px 16px 20px;box-shadow:0 30px 80px rgba(0,0,0,.28)}
.modal-close{position:absolute;top:8px;right:12px;border:none;background:transparent;font-size:28px;cursor:pointer}
.modal-sub{color:var(--muted);margin-top:-8px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.checkbox{display:flex;align-items:center;gap:8px;padding:8px;border:1px solid #eee;border-radius:10px;background:#fafafa}
.notice{margin-top:10px;color:var(--primary);font-weight:700;min-height:20px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:12px;position:sticky;bottom:0;background:#fff;padding-top:10px}
.modal-dialog{max-height:88vh;overflow:auto}

/* Responsive */
@media (max-width: 980px){
  .combos{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 560px){
  .combos{grid-template-columns:1fr}
  .hero h1{font-size:38px}
  .offer-timer{top:60px}
  .reviews-grid{grid-template-columns:1fr}
  /* Cabeçalho: ações em 3 colunas e tamanhos consistentes */
  .actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;justify-content:unset}
  .actions .btn{width:100%;padding:10px 8px;font-size:15px}
  .header-inner{height:auto}
  /* Footer dos combos alinhado: preço à esquerda, botão à direita */
  .combo-footer{display:grid;grid-template-columns:1fr auto;align-items:center;gap:14px}
  .price{font-size:32px}
  .price small{display:block;font-size:14px;margin:0 0 2px 0}
  /* Imagem maior nos combos */
  .combo-media{height:200px}
  .combo-media img{max-height:180px}
  .offer-title{font-size:18px}
  .offer-sub{font-size:15px}
}

@media (max-width: 420px) {
  .container { padding: 0 6px; }
  .header-inner { flex-direction: column; height: auto; gap: 8px; align-items: stretch; }
  .brand-text small { font-size: 13px; }
  .logo img { height: 32px; }
  .actions { display:grid; grid-template-columns: repeat(3,1fr); gap: 6px; width: 100%; }
  .btn { padding: 10px 8px; font-size: 14px; width: 100%; }
  .hero { padding: 26px 4px 8px 4px; }
  .hero h1 { font-size: 26px; }
  .hero h2 { font-size: 18px; }
  .combos { gap: 10px; padding: 10px 0; }
  .combo-card { padding: 10px; gap: 4px; }
  .combo-header h3 { font-size: 16px; }
  .combo-items { font-size: 13px; min-height: 30px; }
  .combo-media { height: 140px; }
  .combo-media img { max-height: 130px; }
  .price { font-size: 20px; }
  .see-btn { font-size: 14px; padding: 7px 10px; }
  .top-pizzas { padding: 8px 0 30px 0; }
  .top-pizzas h2 { font-size: 18px; }
  .chips .chip { padding: 7px 8px; font-size: 13px; }
  .site-footer { font-size: 13px; }
  .footer-inner { flex-direction: column; gap: 10px; padding: 10px 0; align-items: center; text-align:center; }
  .footer-links { gap: 8px; justify-content:center; width:100%; display:flex; }
  .modal-dialog { max-width: 99vw; padding: 8px 2px 10px 2px; margin: 12vh auto 0 auto; }
  .modal-actions{position:static;background:transparent;padding-top:12px;box-shadow:none}
  .modal-close { font-size: 22px; top: 2px; right: 4px; }
  .modal-sub { font-size: 13px; }
  .grid-2 { grid-template-columns: 1fr; gap: 4px; }
  .checkbox { font-size: 14px; padding: 6px; }
  .modal-actions { gap: 4px; }
  .notice { font-size: 13px; min-height: 14px; }
}

/* Acessibilidade de rolagem e navegação móvel */
html{scroll-behavior:smooth}
.site-header + .user-location-bar{position:sticky;top:0;z-index:45}
section[id]{scroll-margin-top:112px}

