/**
 * ╔══════════════════════════════════════════════════════════════════╗
 * ║  NaturallieFIT — public_html/assets/css/main.css                ║
 * ╚══════════════════════════════════════════════════════════════════╝
 */

:root {
    --bg-page:       #f0f2f0;
    --bg-card:       #ffffff;
    --bg-pill:       #ffffff;
    --bg-muted:      #f8faf8;
    --accent:        #2e9e38;
    --accent-mid:    #237a2b;
    --accent-dark:   #1a5820;
    --accent-light:  #45b84f;
    --accent-pale:   #e8f5ea;
    --text-1:        #111111;
    --text-2:        #444444;
    --text-3:        #777777;
    --text-4:        #aaaaaa;
    --border:        rgba(0,0,0,0.08);
    --border-md:     rgba(0,0,0,0.13);
    --border-accent: rgba(46,158,56,0.35);
    --shadow-sm:     0 1px 4px rgba(0,0,0,0.06);
    --shadow-md:     0 4px 16px rgba(0,0,0,0.08);
    --shadow-lg:     0 8px 32px rgba(0,0,0,0.10);
    --radius-sm:     8px;
    --radius-md:     12px;
    --radius-lg:     16px;
    --radius-xl:     24px;
    --tr:            0.2s ease;
    --tr-s:          0.3s cubic-bezier(0.4,0,0.2,1);
    --font:          'Inter', sans-serif;
    --font-h:        'Sora', sans-serif;
    --z-overlay:     9998;
    --z-sidebar:     9999;
    --z-toast:       10000;
    --z-loading:     10001;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg-page);color:var(--text-1);font-family:var(--font);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:#eee;}
::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--accent-mid);}
button,a,[onclick]{touch-action:manipulation;}

/* ── LOADING ── */
.loading-screen {
    position:fixed; inset:0;
    background:#fff;
    display:flex; align-items:center; justify-content:center;
    z-index:var(--z-loading);
    transition:opacity 1s ease, visibility 1s ease;
}
.loading-screen.hide{opacity:0;visibility:hidden;pointer-events:none;}
.loading-bg-blur {
    position:absolute; inset:0;
    background:radial-gradient(ellipse at center, var(--accent-pale) 0%, #fff 70%);
}
.loading-center {
    position:relative; display:flex; flex-direction:column;
    align-items:center; gap:14px; z-index:1;
}
.loading-logo-wrap {
    position:relative; width:120px; height:120px;
    display:flex; align-items:center; justify-content:center;
}
.loading-ring {
    position:absolute; inset:0; border-radius:50%;
    border:3px solid var(--accent-pale);
    border-top-color:var(--accent);
    animation:spin 1.2s linear infinite;
}
.loading-logo-img {
    width:80px; height:80px; object-fit:contain;
    animation:loading-float 2s ease-in-out infinite;
    filter:drop-shadow(0 4px 12px rgba(46,158,56,0.25));
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes loading-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.loading-brand {
    font-family:var(--font-h); font-size:1.3rem; font-weight:800;
    color:var(--accent-dark); letter-spacing:-0.5px;
}
.loading-tagline {
    font-size:.8rem; color:var(--text-3); letter-spacing:1px;
}
.loading-dots{display:flex;gap:8px;}
.ldot {
    width:8px; height:8px; border-radius:50%; background:var(--accent);
    animation:ldot-pop 1.2s ease-in-out infinite;
}
.ldot:nth-child(2){animation-delay:.2s;}
.ldot:nth-child(3){animation-delay:.4s;}
@keyframes ldot-pop{0%,80%,100%{transform:scale(.5);opacity:.4}40%{transform:scale(1);opacity:1}}

/* ── NAVBAR DESKTOP ── */
.navbar-desktop {
    position:relative;
    display:flex; align-items:center; justify-content:center; gap:20px;
    padding:18px 32px 14px;
    background:var(--bg-page);
}
.navbar-logo-outside {
    height:64px; width:auto;
    filter:drop-shadow(0 2px 8px rgba(0,0,0,0.08));
    flex-shrink:0;
}
.navbar-pill {
    display:inline-flex; align-items:center;
    padding:8px 10px 8px 16px;
    background:var(--bg-card);
    border-radius:60px;
    border:1px solid var(--border-accent);
box-shadow:var(--shadow-md), 0 0 0 1px rgba(46,158,56,0.15);
}
.navbar-links{display:flex;align-items:center;gap:2px;}
.navbar-links a,.nav-chatbot{
    text-decoration:none;color:var(--text-2);font-weight:500;font-size:.83rem;
    padding:7px 13px;border-radius:30px;white-space:nowrap;
    transition:all var(--tr);cursor:pointer;
    display:inline-flex;align-items:center;gap:5px;
}
.navbar-links a:hover{color:var(--text-1);background:var(--bg-muted);}
.nav-chatbot{color:var(--text-4);cursor:default;font-size:.8rem;}

/* ── BOTÃO ENTRAR — hover corrigido (sem branco no fundo branco) ── */
.navbar-btn-login {
    background:var(--accent);
    color:#fff !important;
    padding:8px 20px;
    border-radius:30px;
    font-weight:600;
    font-size:.83rem;
    text-decoration:none;
    margin-left:4px;
    transition:all var(--tr);
    display:inline-block;
    box-shadow:0 2px 8px rgba(46,158,56,.3);
}
/* Fix: garantir que o hover do ancestral .navbar-links a não sobrescreva */
.navbar-links .navbar-btn-login:hover,
.navbar-btn-login:hover {
    background:var(--accent-mid) !important;
    color:#fff !important;
    box-shadow:0 4px 14px rgba(46,158,56,.5);
    transform:translateY(-1px);
}

/* Nav user dropdown */
.nav-user-wrap{position:relative;margin-left:4px;}
.nav-user-btn{display:flex;align-items:center;gap:8px;padding:7px 14px;border-radius:30px;background:var(--bg-muted);border:1px solid var(--border);color:var(--text-1);cursor:pointer;font-size:.83rem;font-weight:500;transition:all var(--tr);font-family:var(--font);}
.nav-user-btn:hover{border-color:var(--border-md);background:#eee;}
.nav-user-avatar-sm{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;}
.chevron{font-size:.6rem;color:var(--text-4);transition:transform .25s;}
.nav-user-wrap.open .chevron{transform:rotate(180deg);}
.nav-user-menu{
    position:absolute;top:calc(100% + 8px);right:0;
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:var(--radius-md);padding:6px;min-width:220px;
    box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;
    transform:translateY(-6px) scale(.97);transition:all .25s;z-index:600;
}
.nav-user-wrap.open .nav-user-menu{opacity:1;visibility:visible;transform:translateY(0) scale(1);}
.nav-user-hdr{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-muted);border-radius:var(--radius-sm);margin-bottom:4px;}
.nav-user-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;flex-shrink:0;}
.nav-user-hdr-name{font-weight:600;color:var(--text-1);font-size:.85rem;}
.nav-user-hdr-role{font-size:.68rem;color:var(--text-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px;}
.nav-user-item{display:flex;align-items:center;gap:10px;padding:9px 12px;color:var(--text-2);border-radius:var(--radius-sm);text-decoration:none;font-size:.83rem;font-weight:500;transition:all var(--tr);margin:2px 0;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;font-family:var(--font);}
.nav-user-item:hover{background:var(--bg-muted);color:var(--text-1);}
.nav-user-item i{width:16px;text-align:center;color:var(--text-3);font-size:.82rem;}
.nav-menu-divider{height:1px;background:var(--border);margin:4px 0;}
.nav-user-item.danger{color:#dc2626;}
.nav-user-item.danger i{color:#dc2626;}
.nav-user-item.danger:hover{background:#fff5f5;}

/* ── NAVBAR MOBILE ── */
.navbar-mobile {
    display:none;
    position:relative;
    align-items:center; justify-content:space-between; gap:14px;
    padding:14px 20px 12px;
    background:var(--bg-page);
}
.navbar-logo-outside-mobile {
    height:56px; width:auto; flex-shrink:0;
    filter:drop-shadow(0 2px 6px rgba(0,0,0,0.08));
}
.navbar-pill-mobile {
    display:inline-flex; align-items:center; gap:6px;
    padding:5px 10px;
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:60px;
    box-shadow:var(--shadow-md);
    flex:0 1 auto; justify-content:flex-end;
    position:relative; /* necessário para o dropdown */
}
.navbar-pill-login {
    display:inline-flex; align-items:center; gap:6px;
    font-size:.82rem; font-weight:600; color:var(--accent);
    text-decoration:none; padding:4px 2px;
    transition:color var(--tr);
}
.navbar-pill-login:hover{color:var(--accent-dark);}
.navbar-pill-chatbot {
    width:32px; height:32px; border-radius:50%;
    background:var(--bg-muted); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-4); font-size:.85rem; cursor:default;
    flex-shrink:0;
}
.nav-pill-user-btn {
    display:flex; align-items:center; gap:6px;
    background:none; border:none; cursor:pointer;
    font-size:.82rem; font-weight:600; color:var(--text-1);
    font-family:var(--font); padding:2px;
}
.nav-pill-user-btn:hover{color:var(--accent);}

/* ── DROPDOWN MOBILE — sempre logo abaixo do botão, alinhado à direita da pílula ── */
.nav-user-menu-mobile {
    position:absolute;
    top:calc(100% + 10px);
    right:0;
    left:auto;
    min-width:250px;
    /* evita sair da tela em telas pequenas */
    max-width:calc(100vw - 28px);
}

/* ── PAGE MAIN ── */
.page-main{max-width:1400px;margin:0 auto;padding:0 24px 100px;overflow-x:hidden;}

/* ── SECTION DIVIDER — alinhado à esquerda junto ao carrossel ── */
.section-divider-label{
    display:flex;
    align-items:center;
    margin:28px 0 18px;
}
/* Linha curta antes: empurra o texto para ~centro do carrossel (coluna 1fr) */
.section-divider-label::before{
    content:'';
    flex:1;
    height:1px;
    background:var(--border-md);
}
.section-divider-label::after{
    content:'';
    flex:1;
    height:1px;
    background:var(--border-md);
}
.section-divider-label span{
    font-size:.65rem;letter-spacing:2.5px;text-transform:uppercase;
    color:var(--text-4);padding:0 18px;white-space:nowrap;font-weight:500;
}

.top-row{display:grid;grid-template-columns:1fr 300px;gap:16px;}

/* Info col */
.info-col{display:flex;flex-direction:column;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;}
.info-col-header{padding:14px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.info-col-header i{color:var(--accent);font-size:.85rem;}
.info-col-header span{font-size:.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-3);}
.info-col-body{flex:1;padding:6px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;}
.info-block{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);transition:background var(--tr);}
.info-block:hover{background:var(--bg-muted);}
.info-block-icon{width:30px;height:30px;border-radius:var(--radius-sm);background:var(--accent-pale);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:.8rem;flex-shrink:0;}
.info-block-label{font-size:.6rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3);margin-bottom:1px;display:block;font-weight:600;}
.info-block-value{font-size:.76rem;color:var(--text-2);line-height:1.4;}
.info-col-cta{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;margin:4px 12px 12px;background:#25D366;border-radius:var(--radius-md);color:#fff;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;text-decoration:none;transition:all var(--tr);}
.info-col-cta:hover{background:#1fa554;color:#fff;}

/* Location Bar */
.location-bar{margin-top:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 20px;display:flex;align-items:center;}
.location-item{display:flex;align-items:center;gap:10px;flex:1;min-width:150px;padding:5px 16px;border-right:1px solid var(--border);text-decoration:none;transition:background var(--tr);border-radius:var(--radius-sm);}
.location-item:last-child{border-right:none;}
.location-item:hover .loc-value{color:var(--accent);}
.loc-icon{width:28px;height:28px;border-radius:7px;background:var(--accent-pale);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:.78rem;flex-shrink:0;}
.loc-label{font-size:.58rem;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-4);display:block;font-weight:600;}
.loc-value{font-size:.78rem;color:var(--text-2);font-weight:500;transition:color var(--tr);}
.content-divider{height:1px;margin:20px 0;background:var(--border);}

.bottom-row{display:block;}
.bottom-row-left{width:100%;min-width:0;overflow:hidden;max-width:100%;}

/* ── SIDEBAR HEADER ELEGANTE ── */
.sidebar-hdr-elegante {
    display:flex;
    align-items:center;
    gap:12px;
    padding:14px 16px 12px;
    border-bottom:1px solid var(--border);
    background:var(--bg-muted);
    flex-shrink:0;
}
.she-icon {
    width:36px; height:36px;
    border-radius:var(--radius-sm);
    background:var(--accent-pale);
    display:flex; align-items:center; justify-content:center;
    color:var(--accent); font-size:.95rem;
    flex-shrink:0;
}
.she-titulo {
    font-size:.88rem;
    font-weight:700;
    color:var(--text-1);
    line-height:1.2;
}
.she-sub {
    font-size:.68rem;
    color:var(--text-4);
    margin-top:1px;
}
.she-close {
    margin-left:auto;
    background:none; border:none;
    color:var(--text-4); cursor:pointer;
    font-size:.95rem; padding:4px;
    border-radius:6px;
    transition:all var(--tr);
    flex-shrink:0;
}
.she-close:hover { color:var(--text-1); background:var(--bg-muted); }

/* ── NOTIFICAÇÃO INTERNA DO SIDEBAR ── */
.sidebar-notif-area {
    flex-shrink:0;
    padding:0;
    overflow:hidden;
}
.snb {
    display:flex;
    align-items:flex-start;
    gap:10px;
    padding:10px 14px;
    border-bottom:1px solid transparent;
    animation:snbIn .3s ease;
}
@keyframes snbIn { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
.snb.snb-success { background:#f0fff4; border-bottom-color:rgba(46,158,56,.2); }
.snb.snb-error   { background:#fff5f5; border-bottom-color:rgba(239,68,68,.2); }
.snb.snb-warning { background:#fffbeb; border-bottom-color:rgba(245,158,11,.2); }
.snb.snb-info    { background:#eff6ff; border-bottom-color:rgba(59,130,246,.2); }
.snb-icon { font-size:.9rem; flex-shrink:0; margin-top:2px; }
.snb.snb-success .snb-icon { color:var(--accent); }
.snb.snb-error   .snb-icon { color:#ef4444; }
.snb.snb-warning .snb-icon { color:#f59e0b; }
.snb.snb-info    .snb-icon { color:#3b82f6; }
.snb-title  { font-size:.78rem; font-weight:700; color:var(--text-1); }
.snb-text   { font-size:.7rem; color:var(--text-2); margin-top:1px; line-height:1.4; }
.snb-close  { margin-left:auto; background:none; border:none; cursor:pointer; color:var(--text-4); font-size:.7rem; padding:2px; flex-shrink:0; }
.snb-close:hover { color:var(--text-1); }

/* ── TOAST (fallback quando nenhum sidebar aberto) ── */
.notification-toast{position:fixed;bottom:20px;left:20px;min-width:280px;max-width:340px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-toast);animation:slideInLeft .35s cubic-bezier(0.4,0,0.2,1);overflow:hidden;}
.notification-toast.success{background:#f0fff4;border-left:3px solid var(--accent);}
.notification-toast.error{background:#fff5f5;border-left:3px solid #ef4444;}
.notification-toast.warning{background:#fffbeb;border-left:3px solid #f59e0b;}
.notification-toast.info{background:#eff6ff;border-left:3px solid #3b82f6;}
.toast-content{display:flex;align-items:flex-start;padding:12px 14px;gap:10px;}
.toast-icon{font-size:1.05rem;flex-shrink:0;margin-top:1px;}
.toast-icon.success{color:var(--accent)}.toast-icon.error{color:#ef4444}.toast-icon.warning{color:#f59e0b}.toast-icon.info{color:#3b82f6}
.toast-title{font-weight:700;font-size:.82rem;color:var(--text-1);margin-bottom:1px;}
.toast-text{font-size:.72rem;color:var(--text-2);line-height:1.4;}

/* ── OVERLAYS ── */
.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:var(--z-overlay);opacity:0;visibility:hidden;transition:all var(--tr-s);backdrop-filter:blur(2px);}
.sidebar-overlay.show,.sidebar-overlay.active{opacity:1;visibility:visible;}

/* ── SIDEBAR BASE — fix sombra vazando no canto direito quando fechado ── */
.sidebar-marmita,
.cart-sidebar,
.sidebar-checkout,
.sidebar-pedidos {
    position:fixed;
    top:0;
    height:100%;
    background:var(--bg-card);
    z-index:var(--z-sidebar);
    display:flex;
    flex-direction:column;
    border-left:1px solid var(--border);
    transition:right var(--tr-s), box-shadow var(--tr-s), visibility var(--tr-s);
    /* Quando fechado: sem sombra e invisível (elimina cinza no canto) */
    box-shadow:none;
    visibility:hidden;
}
.sidebar-marmita.show,
.cart-sidebar.active,
.sidebar-checkout.show,
.sidebar-pedidos.show {
    box-shadow:-4px 0 20px rgba(0,0,0,.1);
    visibility:visible;
}

/* ── BOTÕES SIDEBAR ── */
.sidebar-footer-actions{display:flex;gap:8px;padding:14px 16px;border-top:1px solid var(--border);background:var(--bg-card);flex-shrink:0;}
.sb-btn{flex:1;padding:11px 14px;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.78rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--tr);text-transform:uppercase;letter-spacing:.5px;font-family:var(--font);}
.sb-confirm{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(46,158,56,.25);}
.sb-confirm:hover{background:var(--accent-mid);transform:translateY(-1px);}
.sb-checkout{background:transparent;color:var(--accent-dark);border:1.5px solid var(--border-accent);}
.sb-checkout:hover{background:var(--accent-pale);color:var(--accent-dark);border-color:var(--accent);}
.sb-add{background:var(--accent-pale);color:var(--accent-dark);border:1.5px solid var(--border-accent);}
.sb-add:hover{background:var(--accent);color:#fff;}
.sb-cancel{background:var(--bg-muted);color:var(--text-3);border:1px solid var(--border);}
.sb-cancel:hover{border-color:#ef4444;color:#ef4444;background:#fff5f5;}
.sb-back{background:var(--bg-muted);color:var(--text-2);border:1px solid var(--border);}
.sb-back:hover{background:#eee;color:var(--text-1);}
.sb-ghost{background:transparent;color:var(--text-3);border:1px solid var(--border);}
.sb-ghost:hover{background:var(--bg-muted);color:var(--text-1);}
.sb-danger{background:#ef4444;color:#fff;border:none;}
.sb-danger:hover{background:#dc2626;}
.sb-btn:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none;}

/* ── CART SIDEBAR ── */
.cart-sidebar{right:-420px;width:420px;}
.cart-sidebar.active{right:0;}
.sidebar-content{flex:1;overflow-y:auto;}
.cart-items{padding:14px;}

/* ── CARRINHO VAZIO — elegante, sem botão ── */
.cart-empty {
    text-align:center;
    padding:48px 28px;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:10px;
}
/* Wrapper do ícone estilo delivery */
.cart-empty-icon-wrap {
    width:80px; height:80px;
    border-radius:50%;
    background:linear-gradient(135deg, var(--accent-pale) 0%, #d4edda 100%);
    border:2px solid var(--border-accent);
    display:flex; align-items:center; justify-content:center;
    margin-bottom:8px;
    box-shadow:0 4px 16px rgba(46,158,56,.12);
}
.cart-empty-icon-wrap i {
    font-size:2.2rem;
    color:var(--accent);
}
.cart-empty-title {
    font-size:.92rem;
    font-weight:700;
    color:var(--text-2);
}
.cart-empty-sub {
    font-size:.78rem;
    color:var(--text-4);
    line-height:1.6;
    max-width:220px;
}

.cart-item{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;margin-bottom:10px;animation:fadeInUp .25s ease;}
.cart-item-inner{display:flex;gap:10px;align-items:flex-start;}
.cart-item-img{width:64px;height:64px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);flex-shrink:0;}
.cart-item-img img{width:100%;height:100%;object-fit:cover;}
.cart-item-info{flex:1;min-width:0;}
.cart-item-top{display:flex;justify-content:space-between;align-items:flex-start;gap:6px;margin-bottom:4px;}
.cart-item-name{font-size:.85rem;font-weight:600;color:var(--text-1);line-height:1.3;}
.cart-item-remove{background:none;border:none;color:#d1d5db;cursor:pointer;padding:2px;font-size:.8rem;transition:color var(--tr);flex-shrink:0;}
.cart-item-remove:hover{color:#ef4444;}
.cart-item-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.cart-item-details{font-size:.75rem;color:var(--text-3);}
.cart-item-price{font-size:.75rem;font-weight:600;color:var(--text-3);}
.cart-item-controls{display:flex;justify-content:space-between;align-items:center;}
.qty-controls-mini{display:flex;align-items:center;gap:6px;}
.qty-mini-btn{width:22px;height:22px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.6rem;transition:all var(--tr);}
.qty-mini-btn:hover{border-color:var(--border-accent);color:var(--accent);}
.qty-mini-num{font-size:.85rem;font-weight:700;color:var(--text-1);min-width:22px;text-align:center;}
.cart-item-subtotal{font-size:.88rem;font-weight:700;color:var(--accent);}
.cart-item-obs{font-size:.72rem;color:var(--text-3);margin-top:6px;padding-top:6px;border-top:1px solid var(--border);font-style:italic;}
.summary-total-line{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;font-weight:700;font-size:.95rem;border-bottom:1px solid var(--border);}

/* ── SIDEBAR PEDIDOS ── */
.sidebar-pedidos{right:-520px;width:520px;}
.sidebar-pedidos.show{right:0;}
.sidebar-pedidos-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0;}
.sidebar-pedidos-header h3{font-size:.95rem;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px;margin:0;}
.sidebar-pedidos-header h3 i{color:var(--accent);}
.sidebar-pedidos-header button{background:none;border:none;font-size:1rem;color:var(--text-3);cursor:pointer;padding:4px;transition:color var(--tr);}
.sidebar-pedidos-header button:hover{color:var(--text-1);}
.sidebar-pedidos-body{flex:1;overflow-y:auto;padding:16px;}
.loading-pedidos,.pedidos-empty{text-align:center;padding:50px 20px;color:var(--text-3);display:flex;flex-direction:column;align-items:center;gap:12px;}
.loading-pedidos i,.pedidos-empty i{color:#d1d5db;}
.pedidos-empty h4{color:var(--text-1);font-size:1rem;}

/* ── MODAL CONFIRMAR ── */
.modal-confirmar{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:20000;display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-confirmar-box{background:var(--bg-card);border-radius:var(--radius-lg);padding:28px 24px;max-width:360px;width:100%;text-align:center;box-shadow:var(--shadow-lg);animation:fadeInUp .3s ease;}
.modal-confirmar-icon{font-size:2rem;color:#f59e0b;margin-bottom:12px;}
.modal-confirmar-box h4{font-size:1rem;font-weight:700;color:var(--text-1);margin-bottom:6px;}
.modal-confirmar-box p{font-size:.85rem;color:var(--text-3);margin-bottom:20px;}
.modal-confirmar-actions{display:flex;gap:10px;justify-content:center;}

/* ── BOOTSTRAP MODAL ── */
.modal{z-index:10500!important;}
.modal-backdrop{z-index:10499!important;}
.modal-content{border-radius:var(--radius-lg);border:1px solid var(--border);}
.modal-header{border-bottom:1px solid var(--border);}
.modal-footer{border-top:1px solid var(--border);gap:8px;}

/* ── WELCOME BANNER ── */
.welcome-banner{background:var(--accent-pale);border:1px solid var(--border-accent);border-radius:var(--radius-md);margin:20px 0;padding:14px 18px;animation:slideInDown .4s ease;}
.welcome-content{display:flex;align-items:center;gap:12px;}
.welcome-content>i{color:var(--accent);font-size:1.5rem;flex-shrink:0;}
.welcome-content h3{font-size:.9rem;font-weight:700;color:var(--accent-dark);margin-bottom:2px;}
.welcome-content p{font-size:.8rem;color:var(--text-2);margin:0;}
.welcome-content button{background:none;border:none;color:var(--text-4);cursor:pointer;font-size:.9rem;margin-left:auto;transition:color var(--tr);padding:2px;}
.welcome-content button:hover{color:var(--text-1);}

/* ── ANIMAÇÕES ── */
@keyframes slideInLeft{from{transform:translateX(-110%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes slideOutLeft{from{transform:translateX(0);opacity:1}to{transform:translateX(-110%);opacity:0}}
@keyframes slideInDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}

/* ── MOBILE BOTTOM NAV ── */
.mobile-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);z-index:750;display:none;box-shadow:0 -2px 12px rgba(0,0,0,.08);padding-bottom:max(4px,env(safe-area-inset-bottom));}
.mobile-nav-inner{display:flex;}
.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-4);text-decoration:none;min-height:52px;transition:all var(--tr);padding:6px 4px;background:none;border:none;border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;position:relative;}
.mobile-nav-item i{font-size:1.15rem;margin-bottom:2px;}
.mobile-nav-item span{font-size:.58rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;}
.mobile-nav-item:hover,.mobile-nav-item.active{color:var(--accent);}
.cart-badge{position:absolute;top:4px;right:12px;background:#ef4444;color:#fff;border-radius:50%;width:16px;height:16px;font-size:.58rem;display:flex;align-items:center;justify-content:center;font-weight:700;}

/* ── FOOTER ── */
.site-footer{
    background:var(--bg-card);
    color:var(--text-1);
    border-top:1px solid var(--border);
    margin-top:60px;
    box-shadow:0 -6px 32px rgba(0,0,0,0.06);
}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1.3fr 1fr;gap:40px;padding:48px 60px 32px;max-width:1400px;margin:0 auto;}
.footer-brand-col p{font-size:.84rem;color:var(--text-3);line-height:1.7;margin:12px 0 16px;}
.footer-logo-img{height:36px;width:auto;}
.footer-social{display:flex;gap:8px;}
.footer-social a{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--bg-muted);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-2);text-decoration:none;transition:all var(--tr);font-size:.9rem;}
.footer-social a:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-2px);}
.footer-links-col h5,.footer-contact-col h5,.footer-cta-col h5{font-family:var(--font-h);font-size:.7rem;font-weight:700;color:var(--text-4);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:16px;}
.footer-links-col a{display:flex;align-items:center;gap:8px;color:var(--text-2);text-decoration:none;font-size:.85rem;margin-bottom:10px;transition:color var(--tr);}
.footer-links-col a:hover{color:var(--accent);}
.footer-links-col a i{color:var(--accent);width:14px;font-size:.8rem;}
.footer-contact-col a,.footer-contact-col div{display:flex;align-items:center;gap:8px;color:var(--text-2);text-decoration:none;font-size:.84rem;margin-bottom:10px;transition:color var(--tr);}
.footer-contact-col a:hover{color:var(--accent);}
.footer-contact-col a i,.footer-contact-col div i{color:var(--accent);width:14px;font-size:.82rem;}
.footer-hours-row{color:var(--text-3)!important;cursor:default;}
.footer-cta-col p{font-size:.84rem;color:var(--text-3);line-height:1.6;margin-bottom:14px;}
.footer-wa-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;background:#25D366;border-radius:var(--radius-md);color:#fff;font-size:.82rem;font-weight:700;text-decoration:none;transition:all var(--tr);}
.footer-wa-btn:hover{background:#1fa554;color:#fff;transform:translateY(-2px);box-shadow:0 4px 14px rgba(37,211,102,.3);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:16px 60px;border-top:1px solid var(--border);font-size:.76rem;color:var(--text-4);max-width:1400px;margin:0 auto;}
.footer-bottom strong{color:var(--text-2);}
.footer-bottom a{color:var(--text-3);text-decoration:none;transition:color var(--tr);}
.footer-bottom a:hover{color:var(--accent);}

/* ── RESPONSIVO ── */
@media(max-width:1100px){
    .top-row{grid-template-columns:1fr 260px;}
    .footer-inner{grid-template-columns:1fr 1fr;gap:28px;}
}
@media(max-width:900px){
    body{padding-bottom:calc(60px + env(safe-area-inset-bottom));}
    .site-footer{padding-bottom:calc(72px + env(safe-area-inset-bottom));}
    .top-row{grid-template-columns:1fr;}
    .navbar-desktop{display:none;}
    .navbar-mobile{display:flex;}
    .mobile-nav{display:block;}
    .page-main{padding:0 14px 80px;}
    .sidebar-pedidos{width:100%;right:-100%;}
    .cart-sidebar{width:100%;right:-100%;}
    .section-divider-label::before { flex:1; }
    .sidebar-checkout{width:100%;right:-100%;}
    #navUserWrapMobile{position:static;}
    .footer-inner{grid-template-columns:1fr;gap:24px;padding:32px 20px 20px;}
    .footer-bottom{padding:14px 20px;flex-direction:column;gap:6px;text-align:center;}
}
@media(max-width:600px){
    .location-bar{flex-direction:column;padding:10px 14px;gap:0;}
    .location-item{border-right:none;border-bottom:1px solid var(--border);padding:8px 0;min-width:unset;width:100%;}
    .location-item:last-child{border-bottom:none;}
}