body {
    margin:0;
    font-family:-apple-system, BlinkMacSystemFont, sans-serif;
    background:#f7f7f7;
}

/* HEADER */
.header {
    background: #f2f2f2; /* cinza claro */
    padding: 15px 20px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.08);
    position: sticky;
    top: 0;
    z-index: 10;
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: center; /* centraliza ícone + texto */
    gap: 15px; /* espaço entre ícone e texto */
}

.header-inner .logo {
    width: 60px;
    height: 60px;
    border-radius: 12px;
    object-fit: cover;
}

.header-inner h1 {
    margin: 0;
    font-size: 26px;
    font-weight: 700;
    color: #000; /* texto preto */
}

/* CATEGORIAS */
.categorias {
    display:flex;
    overflow-x:auto;
    gap:10px;
    padding:10px;
    background:#fff;
}
.categoria-btn {
    padding:8px 14px;
    background:#eee;
    border-radius:20px;
    font-size:14px;
    white-space:nowrap;
    cursor:pointer;
}
.categoria-btn.active {
    background:#e21;
    color:#fff;
}

/* PRODUTOS */
.container { padding:10px; }
/* CARD PRODUTO */
/* CARD PRODUTO */
.card {
    background:#fff;
    border-radius:14px;
    margin-bottom:6px; /* Borda inferior mais discreta */
    display:flex;
    overflow:hidden;
    box-shadow:0 3px 10px rgba(0,0,0,0.04);
    transition:0.2s;
}

.card:active {
    transform:scale(0.98);
}

.card img {
    width:110px;
    height:110px;
    object-fit:cover;
    border-radius:14px 0 0 14px;
}

.card-info {
    flex:1;
    padding:10px 10px 8px 10px; /* padding inferior menor */
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}

.card-info h3 {
    margin:0 0 4px 0;
    font-size:16px;
}

.card-info p {
    margin:0 0 6px 0;
    font-size:13px;
    color:#666;
}

/* Footer do card para alinhar preço e botão */
.card-footer {
    display:flex;
    justify-content:space-between;
    align-items:center;
}

.preco {
    font-weight: bold;
    font-size: 15px;
    color: #e21;
    margin-top: 9px; /* Desce mais o preço */
}

.btn-add {
    background:#e21;
    color:#fff;
    border:none;
    padding:6px 14px;
    border-radius:8px;
    cursor:pointer;
    font-size:14px;
    transition:0.2s;
}

.btn-add:active {
    transform:scale(0.97);
}
/* BOTÃO CARRINHO FIXO */
.carrinho {
    position:fixed;
    bottom:15px;
    left:50%;
    transform:translateX(-50%);
    background:#e21;
    color:#fff;
    padding:12px 20px;
    border-radius:30px;
    box-shadow:0 4px 15px rgba(0,0,0,0.2);
    font-weight:bold;
    display:none;
}

/* MODAL DE COMPLEMENTOS */
.modal {
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.4);
    display:none;
    align-items:flex-end;
    z-index:99;
}
.modal-content {
    background:#fff;
    width:100%;
    border-radius:20px 20px 0 0;
    padding:20px;
    animation:slideUp 0.3s ease;
}
@keyframes slideUp { from {transform:translateY(100%)} to {transform:translateY(0)} }
.opcao {
    padding:12px;
    border:1px solid #ddd;
    border-radius:12px;
    margin-bottom:10px;
    cursor:pointer;
    transition:0.2s;
}
.opcao.active { border:2px solid #e21; background:#fff5f5; }

/* CART SHEET */
.cart-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.4); display:none; z-index:50; }
.cart-sheet {
    position:fixed;
    bottom:-100%;
    width:100%;
    height:75%;
    background:#fff;
    border-radius:20px 20px 0 0;
    transition:0.3s;
    z-index:60;
    display:flex;
    flex-direction:column;
}
.cart-sheet.open { bottom:0; }

#cartItems { flex:1; overflow:auto; padding:10px; }

.cart-item {
    display:flex;
    gap:12px;
    background:#fff;
    border-radius:16px;
    padding:10px;
    margin-bottom:12px;
    box-shadow:0 3px 10px rgba(0,0,0,0.06);
    position:relative;
}
.cart-item::after{
    content:"🗑️";
    position:absolute;
    right:15px;
    top:50%;
    transform:translateY(-50%);
    opacity:0;
    transition:0.2s;
}
.cart-item.swipe::after{ opacity:1; }

.cart-img { width:70px; height:70px; border-radius:12px; object-fit:cover; }

.cart-info { flex:1; display:flex; flex-direction:column; justify-content:space-between; }
.cart-top { display:flex; justify-content:space-between; font-size:14px; }
.cart-top span { font-weight:bold; color:#e21; }
.cart-info small { color:#777; font-size:12px; }
.cart-controls { display:flex; align-items:center; gap:8px; margin-top:6px; }
.cart-controls button {
    width:28px; height:28px; border:none; border-radius:8px; background:#f1f1f1;
    font-weight:bold; cursor:pointer;
}
.cart-controls span { min-width:20px; text-align:center; font-weight:bold; }

.cart-footer {
    padding:15px;
    border-top:1px solid #eee;
    background:#fff;
}
.total-info {
    display:flex;
    justify-content:space-between;
    font-size:18px;
    font-weight:bold;
    margin-bottom:10px;
}
.cart-actions {
    display:flex;
    gap:10px;
}
/* ===========================
   BOTÕES GERAIS
=========================== */
button {
    outline: none;
    font-family: -apple-system, BlinkMacSystemFont, sans-serif;
}

/* BOTÃO ADICIONAR PRODUTO */
.btn-add {
    background: #e21;
    color: #fff;
    border: none;
    padding: 6px 12px;
    border-radius: 8px;
    margin-top: 8px;
    cursor: pointer;
    font-weight: 500;
    font-size: 13px;
    transition: background 0.2s ease;
}

.btn-add:hover {
    background: #c11919;
}

/* BOTÃO CONTINUAR COMPRANDO */
.btn-continue {
    flex:1;
    padding:10px;
    background:#fff;
    border:1px solid #e21;
    border-radius:10px;
    font-weight:500;
    font-size:14px;
    color:#e21;
    cursor:pointer;
    display:flex;
    justify-content:center;
    align-items:center;
    gap:6px;
    transition: all 0.2s;
}

.btn-continue:hover {
    background:#fef0f0;
}

/* BOTÃO FINALIZAR PEDIDO */
.btn-checkout {
    width:100%;
    padding:12px;
    background:#e21;
    color:#fff;
    border:none;
    border-radius:10px;
    font-size:15px;
    font-weight:600;
    cursor:pointer;
    transition: background 0.2s ease, transform 0.1s;
}

.btn-checkout:hover {
    background:#c11919;
}

.btn-checkout:active {
    transform:scale(0.97);
}

/* CARRINHO */
.cart-overlay {
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.3);
    display:none;
    z-index:50;
}
.header-content {
    display: flex;
    align-items: center;
    gap: 10px; /* Espaço entre o ícone e o nome */
}

.header-content .logo {
    width: 40px;  /* tamanho do ícone */
    height: 40px;
    border-radius: 8px; /* opcional, arredonda os cantos */
    object-fit: cover;
}
.cart-sheet {
    position:fixed;
    bottom:-100%;
    width:100%;
    height:70%;
    background:#fff;
    border-radius:16px 16px 0 0;
    transition:0.3s;
    z-index:60;
    display:flex;
    flex-direction:column;
}

.cart-sheet.open { bottom:0 }

#cartItems { flex:1; overflow:auto; padding:10px }

/* ITENS DO CARRINHO */
.cart-item {
    display:flex;
    gap:12px;
    background:#fff;
    border-radius:12px;
    padding:8px;
    margin-bottom:10px;
    box-shadow:0 2px 6px rgba(0,0,0,0.05);
    transition:0.2s;
    position:relative;
}

.cart-img {
    width:60px;
    height:60px;
    border-radius:8px;
    object-fit:cover;
}

.cart-info {
    flex:1;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}

.cart-top {
    display:flex;
    justify-content:space-between;
    font-size:13px;
}

.cart-top span {
    font-weight:500;
    color:#e21;
}

.cart-info small {
    color:#555;
    font-size:12px;
}

.cart-controls {
    display:flex;
    align-items:center;
    gap:6px;
    margin-top:4px;
}

.cart-controls button {
    width:28px;
    height:28px;
    border:none;
    border-radius:6px;
    background:#f1f1f1;
    font-weight:bold;
    cursor:pointer;
    transition:0.2s;
}

.cart-controls button:active {
    background:#ddd;
    transform:scale(0.95);
}

.cart-controls span {
    min-width:18px;
    text-align:center;
    font-weight:500;
}

/* FOOTER DO CARRINHO */
.cart-footer {
    padding:12px;
    border-top:1px solid #eee;
    background:#fff;
    display:flex;
    flex-direction:column;
    gap:6px;
}

.cart-footer span {
    font-size:16px;
    font-weight:600;
}

/* MODAL DE COMPLEMENTOS */
.modal {
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.3);
    display:none;
    align-items:flex-end;
    z-index:99;
}

.modal-content {
    background:#fff;
    width:100%;
    border-radius:16px 16px 0 0;
    padding:16px;
    animation:slideUp 0.25s ease;
}

@keyframes slideUp {
    from {transform:translateY(100%)}
    to {transform:translateY(0)}
}

.opcao {
    padding:10px;
    border:1px solid #ddd;
    border-radius:10px;
    margin-bottom:8px;
    cursor:pointer;
    transition:0.2s;
}

.opcao.active {
    border:2px solid #e21;
    background:#fff5f5;
}
