/* ==========================================================
   css/style.css  —  FoodFlow Global Styles
   ========================================================== */

/* ── Reset & Variables ─────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#FFFAF6;--bg2:#FFFFFF;--bg3:#F5F0EB;--bg4:#EDE8E2;
  --primary:#E8450A;--pl:#FFF0EB;--pd:#C23A08;
  --gold:#D4920A;--gl:#FFF8E6;
  --green:#1A7A4A;--greenl:#E8F5EE;
  --blue:#1A4FA0;--bluel:#E8F0FF;
  --text:#1C1A17;--text2:#5C5750;--text3:#9C978F;
  --border:#E8E3DC;--border2:#D4CFC8;
  --r:14px;--rsm:9px;--rxs:6px;
  --pad:22px;--pad-mobile:16px;
  --sh:0 2px 12px rgba(0,0,0,.07);--shm:0 4px 24px rgba(0,0,0,.10);
}
body{font-family:'DM Sans','Segoe UI',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
button{font-family:inherit;cursor:pointer;border:none;outline:none}
input,select,textarea{font-family:inherit}

/* ── Shared Navbar ─────────────────────────────────────── */
.navbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 var(--pad);height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.nav-logo{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;letter-spacing:-.02em;text-decoration:none;color:var(--text)}
.nav-logo-icon{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}
.nav-links{display:flex;gap:2px}
.nl{padding:7px 12px;border-radius:6px;font-size:13px;cursor:pointer;color:var(--text2);transition:.2s;font-weight:500;text-decoration:none;display:inline-block}
.nl:hover,.nl.active{background:var(--pl);color:var(--primary)}
.nl.adm:hover,.nl.adm.active{background:var(--bluel);color:var(--blue)}
.nav-right{display:flex;align-items:center;gap:8px}
.back-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text2);padding:6px 13px;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:.2s;text-decoration:none}
.back-btn:hover{background:var(--bg4)}
.uav{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}

/* ── Auth Forms ────────────────────────────────────────── */
.auth-wrap{min-height:calc(100vh - 56px);display:flex}
.auth-left{flex:1;background:var(--primary);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px;position:relative;overflow:hidden}
.auth-left.admin{background:var(--blue)}
.auth-left::before{content:'';position:absolute;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.06);top:-60px;right:-60px}
.auth-brand{text-align:center;z-index:1;position:relative}
.auth-brand h2{font-size:26px;font-weight:700;color:#fff;margin-bottom:8px}
.auth-brand p{font-size:13px;color:rgba(255,255,255,.75);max-width:220px;line-height:1.6}
.auth-feats{margin-top:32px;z-index:1;position:relative}
.af{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.9);font-size:13px;margin-bottom:12px}
.af-icon{width:28px;height:28px;background:rgba(255,255,255,.15);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.auth-right{width:420px;display:flex;flex-direction:column;justify-content:center;padding:40px 36px;background:var(--bg2);overflow-y:auto}
.atabs{display:flex;background:var(--bg3);border-radius:8px;padding:4px;margin-bottom:24px}
.atab{flex:1;text-align:center;padding:8px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text2);transition:.2s;border:none;background:transparent}
.atab.active{background:var(--bg2);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.1)}

/* ── Form Inputs ───────────────────────────────────────── */
.fg{margin-bottom:14px}
.fl{font-size:11px;font-weight:600;color:var(--text2);margin-bottom:5px;display:block;text-transform:uppercase;letter-spacing:.05em}
.fi{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:7px;font-size:13.5px;color:var(--text);background:var(--bg);transition:.2s;outline:none}
.fi:focus{border-color:var(--primary)}
.fi.admin:focus{border-color:var(--blue)}
.btn-p{background:var(--primary);color:#fff;padding:12px 20px;border-radius:8px;font-size:13.5px;font-weight:700;width:100%;transition:.2s;border:none;cursor:pointer}
.btn-p:hover{background:var(--pd)}
.btn-p.admin{background:var(--blue)}
.btn-p.admin:hover{background:#143d80}
.btn-g{background:transparent;color:var(--text2);padding:9px 16px;border-radius:7px;font-size:12px;border:1.5px solid var(--border);transition:.2s;cursor:pointer}
.btn-g:hover{border-color:var(--border2);color:var(--text)}

/* ── Alerts ────────────────────────────────────────────── */
.alert{padding:11px 14px;border-radius:8px;font-size:13px;margin-bottom:14px}
.alert-err{background:#fdecea;color:#a32d2d;border:1px solid #f7c1c1}
.alert-ok{background:var(--greenl);color:var(--green);border:1px solid #A7D4BC}

/* ── Menu / Home ───────────────────────────────────────── */
.hero{background:var(--primary);padding:36px var(--pad);color:#fff;position:relative;overflow:hidden}
.hero::after{content:'🍔';font-size:120px;position:absolute;right:140px;top:50%;transform:translateY(-50%);opacity:.1}
.hero h2{font-size:28px;font-weight:700;margin-bottom:8px;line-height:1.2}
.hero p{font-size:14px;color:rgba(255,255,255,.8);margin-bottom:18px;max-width:340px}
.hero-search{display:flex;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.25);border-radius:8px;overflow:hidden;max-width:380px}
.hero-search input{flex:1;background:transparent;border:none;outline:none;padding:11px 14px;color:#fff;font-size:13px}
.hero-search input::placeholder{color:rgba(255,255,255,.55)}
.hero-search button{background:rgba(255,255,255,.2);border:none;padding:11px 15px;color:#fff;cursor:pointer;font-size:14px}
.hero-stats{display:flex;gap:24px;margin-top:20px}
.hs-val{font-size:20px;font-weight:700}.hs-lbl{font-size:10px;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.06em}
.cats{padding:16px var(--pad);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;gap:8px;overflow-x:auto}
.cc{padding:7px 16px;border-radius:20px;font-size:12.5px;font-weight:500;cursor:pointer;border:1.5px solid var(--border);color:var(--text2);white-space:nowrap;transition:.2s;text-decoration:none}
.cc:hover{border-color:var(--primary);color:var(--primary)}
.cc.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.msec{padding:22px var(--pad)}
@media (max-width:640px){
  .msec{padding:18px var(--pad-mobile)}
  .navbar{padding:0 var(--pad-mobile)}
}
.mhdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.mtitle{font-size:20px;font-weight:700}
.mgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}
.fc{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:.2s}
.fc:hover{box-shadow:var(--shm);transform:translateY(-2px);border-color:var(--border2)}
.fi-img{height:110px;display:flex;align-items:center;justify-content:center;font-size:50px;background:var(--bg3);position:relative}
.fbadge{position:absolute;top:7px;left:7px;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:700}
.bh{background:#FFF0EB;color:var(--primary);border:1px solid #FFDDD0}
.bn{background:#E8F5EE;color:var(--green);border:1px solid #C0E8D0}
.fb{padding:12px}
.fn{font-weight:600;font-size:13.5px;margin-bottom:3px}
.fd{font-size:11.5px;color:var(--text3);margin-bottom:8px;line-height:1.4}
.ff{display:flex;align-items:center;justify-content:space-between}
.fp{font-size:17px;font-weight:700;color:var(--primary)}
.add-btn{width:28px;height:28px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;border:none;cursor:pointer;transition:.2s;flex-shrink:0}
.add-btn:hover{background:var(--pd);transform:scale(1.1)}
.ftag{font-size:10px;background:var(--bg3);color:var(--text3);padding:2px 6px;border-radius:4px;margin-bottom:6px;display:inline-block}

/* ── Cart ──────────────────────────────────────────────── */
.cart-btn{background:var(--primary);color:#fff;padding:7px 14px;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:5px;border:none;transition:.2s}
.cart-btn:hover{background:var(--pd)}
.cart-ct{background:#fff;color:var(--primary);border-radius:50%;width:17px;height:17px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:200;display:none}
.cart-overlay.open{display:block}
.cart-panel{position:fixed;top:0;right:0;height:100%;width:360px;background:var(--bg2);z-index:201;display:flex;flex-direction:column;box-shadow:-4px 0 24px rgba(0,0,0,.12);transform:translateX(100%);transition:.3s}
.cart-panel.open{transform:translateX(0)}
.cphead{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.cphead h3{font-size:17px;font-weight:700}
.cc-btn{width:30px;height:30px;background:var(--bg3);border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;border:none}
.citems{flex:1;overflow-y:auto;padding:14px 20px}
.ci{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.ci:last-child{border-bottom:none}
.ci-em{width:40px;height:40px;background:var(--bg3);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ci-info{flex:1;min-width:0}
.ci-top{display:flex;align-items:flex-start;justify-content:space-between;gap:6px;margin-bottom:2px}
.ci-name{font-size:13px;font-weight:600;flex:1;min-width:0}
.ci-remove{background:transparent;border:none;color:var(--text3);cursor:pointer;font-size:13px;padding:0 2px;line-height:1;transition:.15s;flex-shrink:0}
.ci-remove:hover{color:var(--primary)}
.ci-vars{font-size:11px;color:var(--text3);margin-bottom:4px;line-height:1.5}
.ci-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:5px}
.ci-price{font-size:12.5px;color:var(--primary);font-weight:600}
.qty-ctrl{display:flex;align-items:center;gap:6px}
.qb{width:22px;height:22px;border-radius:5px;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;font-weight:600;color:var(--text2);transition:.2s}
.qb:hover{background:var(--pl);color:var(--primary);border-color:var(--primary)}
.qb-add:hover{background:var(--greenl);color:var(--green);border-color:var(--green)}
.qv{font-size:12.5px;font-weight:600;min-width:18px;text-align:center}
.cfooter{padding:14px 20px;border-top:1px solid var(--border)}
.crow{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px;color:var(--text2)}
.crow.tot{font-weight:700;font-size:14.5px;color:var(--text);margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}
.promo-row{display:flex;gap:7px;margin-bottom:10px}
.promo-row input{flex:1;padding:8px 11px;border:1.5px solid var(--border);border-radius:6px;font-size:12.5px;outline:none;background:var(--bg)}
.promo-row input:focus{border-color:var(--primary)}
.promo-row button{padding:8px 12px;background:var(--bg3);border:1.5px solid var(--border);border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;color:var(--text2);transition:.2s}
.promo-row button:hover{background:var(--pl);color:var(--primary);border-color:var(--primary)}
.pts-hint{background:var(--gl);border:1px solid #FFE4A0;border-radius:6px;padding:7px 11px;font-size:11.5px;color:#7A5800;margin-bottom:10px}
.chk-btn{width:100%;background:var(--primary);color:#fff;padding:12px;border-radius:8px;font-size:13.5px;font-weight:700;cursor:pointer;border:none;transition:.2s}
.chk-btn:hover{background:var(--pd)}
.empty-cart{text-align:center;padding:40px 20px;color:var(--text3)}

/* ── Badges ────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:10.5px;font-weight:600}
.badge-wait{background:#FFF8E6;color:var(--gold);border:1px solid #FFE4A0}
.badge-prep{background:var(--bluel);color:var(--blue);border:1px solid #BDD0FF}
.badge-way{background:var(--pl);color:var(--primary);border:1px solid #FFDDD0}
.badge-done{background:var(--greenl);color:var(--green);border:1px solid #A7D4BC}
.badge-rej{background:#f5e8e8;color:#a32d2d;border:1px solid #f7c1c1}

/* ── Tracking ──────────────────────────────────────────── */
.tw{max-width:640px;margin:0 auto;padding:24px 20px}

/* ── Loyalty ───────────────────────────────────────────── */
.lw{max-width:640px;margin:0 auto;padding:24px 20px}
.lhero{background:var(--primary);border-radius:var(--r);padding:24px;color:#fff;margin-bottom:16px;position:relative;overflow:hidden}
.lhero::after{content:'⭐';font-size:80px;position:absolute;right:-10px;top:50%;transform:translateY(-50%);opacity:.12}
.ltier{background:rgba(255,255,255,.2);color:#fff;padding:3px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.05em;display:inline-block;margin-bottom:10px}
.lpts{font-size:40px;font-weight:700;line-height:1}
.lsub{font-size:12.5px;color:rgba(255,255,255,.75);margin-top:5px}
.pbar-wrap{background:rgba(255,255,255,.2);height:7px;border-radius:4px;margin-top:14px;overflow:hidden}
.pbar-fill{height:100%;background:#fff;border-radius:4px;transition:width 1s}
.rcard{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;margin-bottom:14px}
.rgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.ritem{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:14px;text-align:center;transition:.2s}
.ritem:hover{border-color:var(--border2)}
.rem-btn{width:100%;padding:6px;border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;border:1.5px solid var(--primary);color:var(--primary);background:transparent;transition:.2s}
.rem-btn:hover{background:var(--primary);color:#fff}
.rem-btn:disabled{opacity:.4;cursor:default;border-color:var(--border);color:var(--text3)}

/* ── Account ───────────────────────────────────────────── */
.aw{max-width:620px;margin:0 auto;padding:24px 20px}
.prof-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:14px;display:flex;align-items:center;gap:14px}
.pav{width:56px;height:56px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0}

/* ── Admin ─────────────────────────────────────────────── */
.admin-wrap{display:flex;min-height:calc(100vh - 56px)}
.admin-sidebar{width:200px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 10px}
.sni{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:7px;cursor:pointer;font-size:13px;color:var(--text2);font-weight:500;transition:.2s;margin-bottom:2px;text-decoration:none}
.sni:hover,.sni.active{background:var(--bluel);color:var(--blue)}
.admin-content{flex:1;padding:22px;overflow-y:auto}
.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.sc{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px}
.sc-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-bottom:6px}
.sc-val{font-size:26px;font-weight:700;line-height:1}
.up{color:var(--green)}.dn{color:var(--primary)}
.orders-table,.ot{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;border-collapse:collapse}
.ot thead th{text-align:left;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);padding:10px 14px;background:var(--bg3);border-bottom:1px solid var(--border)}
.ot td{padding:11px 14px;font-size:13px;border-bottom:1px solid var(--border)}
.ot tr:last-child td{border-bottom:none}
.ot tr:hover td{background:var(--bg3)}
.acc-btn{background:var(--greenl);color:var(--green);border:1.5px solid #A7D4BC;padding:5px 12px;border-radius:6px;font-size:11.5px;font-weight:700;cursor:pointer;transition:.2s;margin-right:5px}
.acc-btn:hover{background:var(--green);color:#fff}
.rej-btn{background:#f5e8e8;color:#a32d2d;border:1.5px solid #f7c1c1;padding:5px 12px;border-radius:6px;font-size:11.5px;font-weight:700;cursor:pointer;transition:.2s}
.rej-btn:hover{background:#a32d2d;color:#fff}
.notif-dot{width:7px;height:7px;background:var(--primary);border-radius:50%;display:inline-block;margin-left:4px;animation:blink 1.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.ct{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;border-collapse:collapse}
.ct th{text-align:left;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);padding:10px 14px;background:var(--bg3);border-bottom:1px solid var(--border)}
.ct td{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border)}
.ct tr:last-child td{border-bottom:none}

/* ── Modal ─────────────────────────────────────────────── */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none;align-items:center;justify-content:center;min-height:100vh}
.modal-ov.open{display:flex}
.modal{background:var(--bg2);border-radius:var(--r);padding:32px 28px;max-width:380px;width:90%;text-align:center;box-shadow:var(--shm)}
.modal-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px}

/* ── Toast ─────────────────────────────────────────────── */
.toast{position:fixed;bottom:90px;right:20px;background:var(--text);color:#fff;padding:11px 18px;border-radius:8px;font-size:13px;font-weight:500;z-index:999;opacity:0;transform:translateY(10px);transition:.3s;pointer-events:none;max-width:280px}
.toast.show{opacity:1;transform:translateY(0)}
