/* ══════════════════════════════════════════════
   CARFood Delivery — app.css
══════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --gold:#c8922a;--gold-lt:#e0a93a;--gold-dim:#8a6420;
  --bg:#0d0d0d;--surf:#141414;--surf2:#1c1c1c;--surf3:#242424;
  --border:#2a2a2a;--border2:#333;
  --text:#f0f0f0;--text2:#aaa;--muted:#666;
  --green:#25c665;--red:#ff4444;
  --radius:14px;--radius-sm:8px;
  --transition:.18s ease;
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;overflow:hidden}

/* ── LOADER ─────────────────────────────────── */
#loader{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;gap:16px}
.loader-logo{font-family:'Bebas Neue',sans-serif;font-size:42px;letter-spacing:6px}
.loader-logo span{color:var(--gold)}
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#loader.hidden{display:none}

/* ── APP ────────────────────────────────────── */
#app{position:fixed;inset:0;display:flex;flex-direction:column}

/* ── TELAS ──────────────────────────────────── */
.screen{position:absolute;inset:0;display:flex;flex-direction:column;background:var(--bg);transition:transform .25s ease,opacity .25s ease}
.screen.hidden{transform:translateX(100%);opacity:0;pointer-events:none}

/* ── HEADER ─────────────────────────────────── */
.header{background:var(--surf);border-bottom:1px solid var(--border);padding:0 16px;height:56px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-logo{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:3px}
.header-logo span{color:var(--gold)}
.header-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:2px;flex:1;text-align:center}
.btn-back{background:none;border:none;color:var(--text2);cursor:pointer;padding:8px 4px;display:flex;align-items:center;gap:6px;font-size:14px;font-family:'DM Sans',sans-serif}
.btn-back svg{width:20px;height:20px;flex-shrink:0}
.header-spacer{flex:1}

/* ── SCROLL ─────────────────────────────────── */
.scroll-area{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.scroll-area::-webkit-scrollbar{display:none}

/* ── BOTTOM BAR ─────────────────────────────── */
.bottom-bar{background:var(--surf);border-top:1px solid var(--border);padding:12px 16px;flex-shrink:0;padding-bottom:calc(12px + env(safe-area-inset-bottom))}

/* ── BOTÕES ─────────────────────────────────── */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;font-family:'DM Sans',sans-serif;cursor:pointer;transition:var(--transition);border:none;width:100%;letter-spacing:.3px}
.btn-gold{background:var(--gold);color:#000}
.btn-gold:hover{background:var(--gold-lt)}
.btn-gold:active{transform:scale(.98)}
.btn-gold:disabled{background:var(--gold-dim);color:#555;cursor:not-allowed}
.btn-outline{background:transparent;color:var(--gold);border:1px solid var(--gold)}
.btn-outline:hover{background:rgba(200,146,42,.1)}
.btn-ghost{background:var(--surf2);color:var(--text2)}
.btn-ghost:hover{background:var(--surf3)}
.btn-sm{padding:9px 16px;font-size:13px;width:auto;border-radius:var(--radius-sm)}

/* ── INPUTS ─────────────────────────────────── */
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:6px;letter-spacing:.8px;text-transform:uppercase}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;background:var(--surf2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:15px;font-family:'DM Sans',sans-serif;outline:none;transition:border-color var(--transition)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}
.field textarea{resize:none;min-height:76px}
.field select option{background:var(--surf2)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ── TOAST ──────────────────────────────────── */
#toast{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(16px);background:var(--surf3);border:1px solid var(--border2);color:var(--text);padding:11px 20px;border-radius:99px;font-size:13px;z-index:9998;opacity:0;transition:.25s;white-space:nowrap;max-width:90vw;text-align:center;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.erro{border-color:var(--red);color:var(--red)}
#toast.ok{border-color:var(--green);color:var(--green)}

/* ══ TELA: FECHADO/ERRO ════════════════════════ */
.screen-center{align-items:center;justify-content:center;padding:32px 24px;text-align:center;gap:0}
.closed-icon{font-size:64px;margin-bottom:20px}
.closed-titulo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;margin-bottom:10px}
.closed-sub{color:var(--text2);font-size:14px;line-height:1.6;max-width:320px}

/* ══ TELA: AUTH ════════════════════════════════ */
.auth-wrap{padding:32px 24px;overflow-y:auto;flex:1}
.auth-logo{font-family:'Bebas Neue',sans-serif;font-size:40px;letter-spacing:6px;text-align:center;margin-bottom:6px}
.auth-logo span{color:var(--gold)}
.auth-sub{text-align:center;color:var(--text2);font-size:13px;margin-bottom:28px}
.auth-tabs{display:flex;margin-bottom:22px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.auth-tab{flex:1;padding:12px;text-align:center;font-size:14px;font-weight:500;cursor:pointer;background:var(--surf2);color:var(--text2);transition:var(--transition)}
.auth-tab.ativo{background:var(--gold);color:#000}
.auth-form{display:none}
.auth-form.ativo{display:block}

/* ══ TELA: MAIN (cardápio) ═════════════════════ */
.rest-hero{padding:22px 16px 14px;display:flex;align-items:center;gap:14px}
.rest-logo{width:60px;height:60px;border-radius:50%;background:var(--surf2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:26px;overflow:hidden;flex-shrink:0}
.rest-logo img{width:100%;height:100%;object-fit:cover}
.rest-nome{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:2px;line-height:1.1}
.rest-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;padding:3px 10px;border-radius:99px;margin-top:5px}
.rest-badge.aberto{background:rgba(37,198,101,.15);color:var(--green)}
.rest-badge.fechado{background:rgba(255,68,68,.15);color:var(--red)}
.rest-meta{display:flex;gap:14px;padding:0 16px 14px;flex-wrap:wrap}
.rest-meta-item{font-size:12px;color:var(--text2)}

/* Tabs categorias */
.cat-tabs{display:flex;gap:8px;padding:0 16px 12px;overflow-x:auto;flex-shrink:0}
.cat-tabs::-webkit-scrollbar{display:none}
.cat-tab{flex-shrink:0;padding:6px 14px;border-radius:99px;font-size:13px;font-weight:500;cursor:pointer;background:var(--surf2);color:var(--text2);border:1px solid var(--border);transition:var(--transition)}
.cat-tab.ativo{background:var(--gold);color:#000;border-color:var(--gold)}

/* Itens */
.cat-section{padding:0 16px}
.cat-titulo{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:2px;color:var(--muted);padding:10px 0 8px}
.item-card{background:var(--surf);border:1px solid var(--border);border-radius:var(--radius);display:flex;gap:12px;padding:14px;margin-bottom:10px;cursor:pointer;transition:border-color var(--transition)}
.item-card:active{background:var(--surf2)}
.item-card:hover{border-color:var(--border2)}
.item-foto{width:68px;height:68px;border-radius:10px;background:var(--surf2);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:26px}
.item-foto img{width:100%;height:100%;object-fit:cover}
.item-info{flex:1;min-width:0}
.item-nome{font-weight:600;font-size:15px;margin-bottom:3px}
.item-desc{font-size:12px;color:var(--text2);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.item-preco{font-family:'Bebas Neue',sans-serif;font-size:17px;color:var(--gold)}

/* FAB carrinho */
#cart-fab{position:absolute;bottom:calc(16px + env(safe-area-inset-bottom));left:16px;right:16px;z-index:10}
#cart-fab .btn{background:var(--gold);color:#000;border-radius:var(--radius);height:50px}
.cart-badge{background:#000;color:var(--gold);border-radius:99px;padding:2px 8px;font-size:12px;font-weight:700;min-width:22px;text-align:center}
.cart-fab-total{margin-left:auto;font-weight:700}

/* ══ TELA: ITEM ════════════════════════════════ */
.item-hero-img{width:100%;height:210px;background:var(--surf2);display:flex;align-items:center;justify-content:center;font-size:68px;flex-shrink:0;overflow:hidden}
.item-hero-img img{width:100%;height:100%;object-fit:cover}
.item-body{padding:18px 16px}
.item-body .item-nome{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:2px;margin-bottom:6px}
.item-body .item-desc{font-size:13px;color:var(--text2);margin-bottom:12px;line-height:1.5}
.item-preco-base{font-size:20px;font-weight:700;color:var(--gold);margin-bottom:20px}

/* Grupos */
.grupo{margin-bottom:18px}
.grupo-titulo{font-weight:600;font-size:14px;margin-bottom:3px}
.grupo-sub{font-size:12px;color:var(--text2);margin-bottom:10px}
.opcao-item{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--surf2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:7px;cursor:pointer;transition:border-color var(--transition)}
.opcao-item.sel{border-color:var(--gold);background:rgba(200,146,42,.07)}
.opcao-nome{flex:1;font-size:14px}
.opcao-preco{font-size:13px;color:var(--text2)}
.opcao-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}
.opcao-item.sel .opcao-check{background:var(--gold);border-color:var(--gold)}
.opcao-check-icon{display:none;width:11px;height:11px}
.opcao-item.sel .opcao-check-icon{display:block}

/* Qty */
.qty-ctrl{display:flex;align-items:center;gap:18px;justify-content:center;margin:18px 0}
.qty-btn{width:40px;height:40px;border-radius:50%;background:var(--surf2);border:1px solid var(--border);color:var(--text);font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);line-height:1}
.qty-btn:hover{border-color:var(--gold)}
.qty-val{font-family:'Bebas Neue',sans-serif;font-size:28px;min-width:36px;text-align:center}

/* ══ TELA: CARRINHO ════════════════════════════ */
.cart-empty{text-align:center;padding:48px 24px;color:var(--muted)}
.cart-empty-icon{font-size:48px;margin-bottom:12px}
.cart-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}
.cart-item:last-child{border-bottom:none}
.cart-item-info{flex:1;min-width:0}
.cart-item-nome{font-weight:600;font-size:14px;margin-bottom:3px}
.cart-item-opcoes{font-size:12px;color:var(--text2);margin-bottom:5px}
.cart-item-preco{font-size:14px;color:var(--gold);font-weight:600}
.cart-qty{display:flex;align-items:center;gap:10px}
.cart-qty-btn{width:28px;height:28px;border-radius:50%;background:var(--surf2);border:1px solid var(--border);color:var(--text);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1}
.cart-qty-val{font-size:15px;font-weight:600;min-width:20px;text-align:center}
.cart-totais{padding:14px 16px;border-top:1px solid var(--border)}
.total-row{display:flex;justify-content:space-between;font-size:14px;color:var(--text2);padding:4px 0}
.total-row.final{font-size:16px;font-weight:700;color:var(--text);border-top:1px solid var(--border);margin-top:8px;padding-top:12px}
.obs-section{padding:0 16px 16px}

/* ══ TELA: CHECKOUT ════════════════════════════ */
.checkout-section{padding:16px;border-bottom:1px solid var(--border)}
.checkout-titulo{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;color:var(--muted);margin-bottom:12px}
.end-card{background:var(--surf2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px;margin-bottom:8px;cursor:pointer;display:flex;align-items:flex-start;gap:12px;transition:border-color var(--transition)}
.end-card.sel{border-color:var(--gold)}
.radio-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--border2);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.end-card.sel .radio-dot,.pag-opcao.sel .radio-dot{border-color:var(--gold);background:var(--gold)}
.end-card.sel .radio-dot::after,.pag-opcao.sel .radio-dot::after{content:'';width:6px;height:6px;border-radius:50%;background:#000}
.end-info{flex:1}
.end-apelido{font-weight:600;font-size:14px;margin-bottom:2px}
.end-linha{font-size:12px;color:var(--text2)}
.pag-opcao{background:var(--surf2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px;margin-bottom:8px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:border-color var(--transition)}
.pag-opcao.sel{border-color:var(--gold)}
.pag-label{flex:1;font-size:14px;font-weight:500}
.pag-taxa{font-size:12px;color:var(--gold)}

/* ══ TELA: STATUS ══════════════════════════════ */
.status-icon{font-size:72px;margin-bottom:20px}
.status-titulo{font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:3px;margin-bottom:10px}
.status-num{font-size:14px;color:var(--text2);margin-bottom:8px}
.status-num strong{color:var(--gold);font-size:18px}
.status-sub{color:var(--text2);font-size:14px;margin-bottom:28px;line-height:1.5;max-width:300px;text-align:center}

/* ══ MODAL ENDEREÇO ════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;display:flex;align-items:flex-end}
.modal-overlay.hidden{display:none}
.modal-box{background:var(--surf);border-radius:var(--radius) var(--radius) 0 0;padding:24px 20px;width:100%;max-height:90vh;overflow-y:auto}
.modal-titulo{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:2px;margin-bottom:20px}
.modal-btns{display:flex;gap:10px;margin-top:6px}

/* ── UTILITÁRIOS ─────────────────────────────── */
.pad{padding:16px}
.gap-bot{height:90px}
