:root {
  --green:#006233; --green2:#004d27; --green3:#00391d;
  --red:#C8102E; --gold:#c9a84c;
  --white:#F8F5F0; --cream:#fdf9f4; --dark:#0d1a0f; --dark2:#111f13;
  --muted:rgba(255,255,255,0.45); --border:rgba(0,98,51,0.3);

  /* Light/White Theme Variables */
  --surface-white: rgba(255,255,255,0.97);
  --surface-off: rgba(248,245,240,0.6);
  --border-light: rgba(0,98,51,0.12);
  --text-dark: #0d1a0f;
  --text-muted-dark: rgba(13,26,15,0.5);
  --sidebar-bg: rgba(255,255,255,0.96);
  --main-bg: #f4f6f3;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Cairo',sans-serif;background:var(--main-bg);color:var(--text-dark);min-height:100vh;overflow-x:hidden}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#f0f2ef}
::-webkit-scrollbar-thumb{background:var(--green);border-radius:3px}

/* ── BG ── */
.bg-layer{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at 10% 20%,rgba(0,98,51,0.05) 0%,transparent 70%),
  radial-gradient(ellipse 50% 60% at 90% 80%,rgba(0,98,51,0.03) 0%,transparent 70%)}
.bg-grid{position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(0,98,51,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,98,51,0.04) 1px,transparent 1px);
  background-size:48px 48px}

/* ── LAYOUT ── */
.app{position:relative;z-index:1;display:flex;flex-direction:column;min-height:100vh}

/* ── TOP NAVBAR ── */
.navbar{background:var(--sidebar-bg);backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border-light);box-shadow:0 2px 20px rgba(0,98,51,0.07);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;padding:0 28px;height:62px;gap:16px}
.nb-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nb-logo-icon{width:34px;height:34px;border-radius:9px;background:var(--green);display:flex;align-items:center;justify-content:center}
.nb-logo-text{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;
  background:linear-gradient(135deg,var(--green),var(--green2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}

.nb-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
.sb-item{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:9px;
  cursor:pointer;transition:all .2s;color:rgba(13,26,15,0.55);font-size:.86rem;font-weight:600;
  position:relative;text-decoration:none;white-space:nowrap}
.sb-item:hover{background:rgba(0,98,51,0.07);color:var(--green)}
.sb-item.active{background:rgba(0,98,51,0.1);color:var(--green);border:1px solid rgba(0,98,51,0.2)}
.sb-item svg{flex-shrink:0}
.sb-badge{background:var(--red);color:#fff;font-size:.6rem;font-weight:700;
  padding:2px 6px;border-radius:20px;min-width:18px;text-align:center}

.nb-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.sb-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}
.av-student{background:rgba(0,98,51,0.1);color:var(--green);border:1.5px solid rgba(0,98,51,0.3)}
.av-restaurant{background:rgba(201,168,76,0.12);color:#8a6d1a;border:1.5px solid rgba(201,168,76,0.3)}
.av-driver{background:rgba(200,16,46,0.08);color:var(--red);border:1.5px solid rgba(200,16,46,0.25)}
.nb-user-info{display:flex;flex-direction:column;align-items:flex-end}
.sb-name{font-size:.82rem;font-weight:700;color:var(--text-dark);line-height:1.2}
.sb-role{font-size:.68rem;color:var(--text-muted-dark)}
.nb-logout{display:flex;align-items:center;gap:6px;padding:7px 12px;border-radius:9px;
  cursor:pointer;color:rgba(200,16,46,0.6);font-size:.8rem;font-weight:600;transition:all .2s;border:1px solid transparent}
.nb-logout:hover{background:rgba(200,16,46,0.07);color:var(--red);border-color:rgba(200,16,46,0.15)}

/* Sidebar legacy - hidden */
.sidebar{display:none}
.sb-section-label,.sb-footer,.sb-logo,.sb-user,.sb-nav{display:none}

/* ── MAIN ── */
.main{flex:1;padding:28px 32px;min-height:calc(100vh - 62px)}

/* ── TOPBAR ── */
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.topbar-title{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:900;color:var(--text-dark)}
.topbar-sub{font-size:.82rem;color:var(--text-muted-dark);margin-top:2px}
.topbar-actions{display:flex;align-items:center;gap:10px}
.notif-btn{position:relative;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,0.9);
  border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;
  box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.notif-btn:hover{background:rgba(0,98,51,0.08);border-color:rgba(0,98,51,0.3)}
.notif-btn svg{stroke:var(--text-dark)}
.notif-dot{position:absolute;top:8px;left:8px;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid var(--main-bg)}

/* ── PANELS ── */
.panel{display:none;animation:fadeUp .35s ease both}
.panel.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ── CARDS GRID ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.stat-card{background:var(--surface-white);border:1px solid var(--border-light);border-radius:14px;padding:18px 20px;
  display:flex;align-items:center;gap:14px;transition:all .2s;box-shadow:0 1px 6px rgba(0,0,0,0.05)}
.stat-card:hover{border-color:rgba(0,98,51,0.25);box-shadow:0 4px 16px rgba(0,98,51,0.08)}
.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.si-green{background:rgba(0,98,51,0.1)} .si-gold{background:rgba(201,168,76,0.12)}
.si-red{background:rgba(200,16,46,0.08)} .si-blue{background:rgba(0,100,200,0.08)}
.stat-info{}
.stat-num{font-size:1.5rem;font-weight:900;color:var(--text-dark)}
.stat-lbl{font-size:.75rem;color:var(--text-muted-dark);font-weight:600}

/* ── RESTAURANT GRID ── */
.restaurants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.rest-card{background:var(--surface-white);border:1px solid var(--border-light);border-radius:18px;overflow:hidden;
  cursor:pointer;transition:all .3s;box-shadow:0 2px 10px rgba(0,0,0,0.05);position:relative}
.rest-card:hover{transform:translateY(-5px);border-color:rgba(0,98,51,0.3);box-shadow:0 20px 48px rgba(0,98,51,0.12)}
.rest-banner{height:140px;display:flex;align-items:center;justify-content:center;font-size:3.5rem;
  background:linear-gradient(135deg,#e8f5ee,#d4eedd);position:relative;overflow:hidden}
.rest-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,0.08) 100%)}
.rest-banner img{width:100%;height:100%;object-fit:cover}
.rest-banner .rest-emoji{position:relative;z-index:1;filter:drop-shadow(0 4px 12px rgba(0,0,0,0.15))}
.rest-info{padding:16px 18px}
.rest-name{font-size:1.05rem;font-weight:700;color:var(--text-dark);margin-bottom:6px}
.rest-meta{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--text-muted-dark);flex-wrap:wrap}
.rest-rating{color:var(--gold);font-weight:700;display:flex;align-items:center;gap:3px}
.rest-tag{padding:3px 9px;background:rgba(0,98,51,0.1);color:var(--green);border-radius:5px;font-size:.7rem;font-weight:700}
.rest-tag.deal{background:rgba(200,16,46,0.08);color:var(--red)}
.rest-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-light)}

/* ── HERO STATS (واجهة رئيسية) ── */
.home-hero{background:linear-gradient(135deg,var(--green) 0%,var(--green2) 60%,var(--green3) 100%);
  border-radius:20px;padding:28px 32px;margin-bottom:24px;position:relative;overflow:hidden;
  box-shadow:0 8px 32px rgba(0,98,51,0.25)}
.home-hero::before{content:'';position:absolute;top:-40px;left:-40px;width:200px;height:200px;
  border-radius:50%;background:rgba(255,255,255,0.06)}
.home-hero::after{content:'';position:absolute;bottom:-30px;right:-20px;width:150px;height:150px;
  border-radius:50%;background:rgba(255,255,255,0.04)}
.hero-content{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:20px}
.hero-text h2{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:900;color:#fff;margin-bottom:6px}
.hero-text p{font-size:.88rem;color:rgba(255,255,255,0.75);max-width:360px;line-height:1.6}
.hero-stats{display:flex;gap:20px}
.hero-stat{background:rgba(255,255,255,0.12);backdrop-filter:blur(8px);border-radius:14px;
  padding:14px 20px;text-align:center;border:1px solid rgba(255,255,255,0.15);min-width:90px}
.hero-stat-num{font-size:1.6rem;font-weight:900;color:#fff}
.hero-stat-lbl{font-size:.7rem;color:rgba(255,255,255,0.7);font-weight:600;margin-top:2px}

/* ── FILTER PILLS ── */
.filter-pills{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.pill{padding:7px 16px;border-radius:30px;font-size:.8rem;font-weight:700;cursor:pointer;
  border:1.5px solid var(--border-light);background:white;color:rgba(13,26,15,0.55);transition:all .2s}
.pill:hover{border-color:rgba(0,98,51,0.3);color:var(--green)}
.pill.active{background:var(--green);color:white;border-color:var(--green);box-shadow:0 4px 12px rgba(0,98,51,0.2)}

/* ── MENU ── */
.menu-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.back-btn{display:flex;align-items:center;gap:6px;color:var(--text-muted-dark);cursor:pointer;
  font-size:.85rem;font-weight:600;background:none;border:none;font-family:'Cairo',sans-serif;transition:color .2s}
.back-btn:hover{color:var(--green)}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.meal-card{background:var(--surface-white);border:1px solid var(--border-light);border-radius:14px;
  padding:0;overflow:hidden;transition:all .2s;box-shadow:0 1px 5px rgba(0,0,0,0.05)}
.meal-card:hover{border-color:rgba(0,98,51,0.2);box-shadow:0 6px 20px rgba(0,98,51,0.08)}
.meal-img-wrap{height:130px;background:#e8f5ee;display:flex;align-items:center;justify-content:center;overflow:hidden}
.meal-img-wrap img{width:100%;height:100%;object-fit:cover}
.meal-img-placeholder{font-size:2.4rem}
.meal-body{padding:14px}
.meal-name{font-size:.95rem;font-weight:700;color:var(--text-dark);margin-bottom:4px}
.meal-desc{font-size:.77rem;color:var(--text-muted-dark);margin-bottom:12px;line-height:1.5}
.meal-footer{display:flex;align-items:center;justify-content:space-between}
.meal-price{font-size:1rem;font-weight:700;color:var(--green)}
.meal-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.mtag{font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px}
.mtag-green{background:rgba(0,98,51,0.1);color:var(--green)}
.mtag-red{background:rgba(200,16,46,0.08);color:var(--red)}
.mtag-gold{background:rgba(201,168,76,0.12);color:#8a6d1a}
.add-btn{display:flex;align-items:center;gap:6px;background:var(--green);color:#fff;
  border:none;border-radius:8px;padding:7px 14px;font-family:'Cairo',sans-serif;
  font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s}
.add-btn:hover{background:var(--green2);transform:scale(1.04)}
.add-btn:active{transform:scale(.97)}

/* ── CART ── */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:20px}
.cart-items{}
.cart-item{display:flex;align-items:center;gap:14px;background:var(--surface-white);
  border:1px solid var(--border-light);border-radius:12px;padding:14px;margin-bottom:10px;
  box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.cart-item-img{width:48px;height:48px;border-radius:8px;object-fit:cover;background:#e8f5ee;
  display:flex;align-items:center;justify-content:center;font-size:1.5rem;overflow:hidden;flex-shrink:0}
.cart-item-img img{width:100%;height:100%;object-fit:cover}
.cart-item-info{flex:1}
.cart-item-name{font-size:.92rem;font-weight:700;color:var(--text-dark)}
.cart-item-rest{font-size:.75rem;color:var(--text-muted-dark)}
.cart-item-price{font-size:.92rem;font-weight:700;color:var(--green)}
.qty-ctrl{display:flex;align-items:center;gap:8px}
.qty-btn{width:26px;height:26px;border-radius:6px;border:none;background:rgba(0,98,51,0.1);
  color:var(--green);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:all .2s;font-family:'Cairo',sans-serif}
.qty-btn:hover{background:var(--green);color:#fff}
.qty-num{font-weight:700;font-size:.9rem;min-width:18px;text-align:center;color:var(--text-dark)}
.del-btn{background:none;border:none;color:rgba(200,16,46,0.5);cursor:pointer;transition:color .2s;padding:4px}
.del-btn:hover{color:var(--red)}

.cart-summary{background:var(--surface-white);border:1px solid var(--border-light);border-radius:16px;
  padding:20px;height:fit-content;position:sticky;top:20px;box-shadow:0 2px 10px rgba(0,0,0,0.05)}
.cs-title{font-size:1rem;font-weight:700;color:var(--text-dark);margin-bottom:16px}
.cs-row{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-muted-dark);margin-bottom:10px}
.cs-row.total{color:var(--text-dark);font-weight:700;font-size:1rem;border-top:1px solid var(--border-light);
  padding-top:12px;margin-top:4px}
.cs-row.total span:last-child{color:var(--green)}

.delivery-options{margin:14px 0}
.dlv-opt{display:flex;align-items:center;gap:10px;border:1.5px solid var(--border-light);border-radius:10px;
  padding:12px;cursor:pointer;transition:all .2s;margin-bottom:8px}
.dlv-opt:hover{border-color:rgba(0,98,51,0.3)}
.dlv-opt.selected{border-color:var(--green);background:rgba(0,98,51,0.05)}
.dlv-opt input{accent-color:var(--green)}
.dlv-info{flex:1}
.dlv-name{font-size:.85rem;font-weight:700;color:var(--text-dark)}
.dlv-desc{font-size:.73rem;color:var(--text-muted-dark)}
.dlv-price{font-size:.9rem;font-weight:700;color:var(--green)}

.addr-input{width:100%;background:rgba(0,98,51,0.03);border:1px solid var(--border-light);border-radius:10px;
  padding:10px 14px;color:var(--text-dark);font-family:'Cairo',sans-serif;font-size:.85rem;margin:10px 0 14px;
  transition:border-color .2s;outline:none}
.addr-input:focus{border-color:var(--green)}
.addr-input::placeholder{color:var(--text-muted-dark)}

.checkout-btn{width:100%;background:var(--green);color:#fff;border:none;border-radius:10px;
  padding:14px;font-family:'Cairo',sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;
  transition:all .25s;display:flex;align-items:center;justify-content:center;gap:8px}
.checkout-btn:hover{background:var(--green2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,98,51,0.25)}
.checkout-btn:disabled{background:rgba(0,0,0,0.08);color:var(--text-muted-dark);cursor:not-allowed;transform:none;box-shadow:none}
/* ── TRACKING ── */
.track-card{background:var(--surface-white);border:1px solid var(--border-light);border-radius:16px;
  padding:22px;margin-bottom:14px;box-shadow:0 1px 6px rgba(0,0,0,0.04)}
.track-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.track-order-id{font-size:.78rem;color:var(--text-muted-dark)}
.track-status-badge{padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:700}
.tsb-preparing{background:rgba(201,168,76,0.12);color:#8a6d1a}
.tsb-onway{background:rgba(0,98,51,0.1);color:var(--green)}
.tsb-delivered{background:rgba(0,150,70,0.1);color:#1a7a3a}
.tsb-pending{background:rgba(0,0,0,0.06);color:var(--text-muted-dark)}
.tsb-rejected{background:rgba(200,16,46,0.08);color:var(--red)}

.track-steps{display:flex;flex-direction:column;gap:0}
.track-step{display:flex;align-items:flex-start;gap:14px;padding:10px 0}
.track-step:not(:last-child){border-bottom:1px dashed rgba(0,98,51,0.1)}
.ts-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.tsd-done{background:var(--green)}
.tsd-active{background:var(--green);animation:pulseDot 1.5s infinite}
.tsd-pending{background:rgba(0,0,0,0.06);border:1.5px dashed rgba(0,98,51,0.2)}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 rgba(0,98,51,0.3)}50%{box-shadow:0 0 0 6px rgba(0,98,51,0)}}
.ts-info{}
.ts-label{font-size:.88rem;font-weight:700;color:var(--text-dark)}
.ts-time{font-size:.75rem;color:var(--text-muted-dark);margin-top:2px}

.driver-card{display:flex;align-items:center;gap:12px;background:rgba(0,98,51,0.05);
  border:1px solid rgba(0,98,51,0.15);border-radius:12px;padding:14px;margin-top:14px}
.driver-avatar{width:44px;height:44px;border-radius:50%;background:rgba(0,98,51,0.1);
  display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.driver-name{font-size:.88rem;font-weight:700;color:var(--text-dark)}
.driver-rating{font-size:.75rem;color:var(--text-muted-dark);display:flex;align-items:center;gap:4px}
.dr-star{color:var(--gold)}

.rate-section{margin-top:16px;background:rgba(0,98,51,0.03);border:1px solid var(--border-light);
  border-radius:12px;padding:16px}
.rate-title{font-size:.88rem;font-weight:700;color:var(--text-dark);margin-bottom:12px}
.stars{display:flex;gap:6px;margin-bottom:12px}
.star{font-size:1.6rem;cursor:pointer;transition:transform .2s;filter:grayscale(1)opacity(.3)}
.star.active{filter:grayscale(0);transform:scale(1.15)}
.rate-input{width:100%;background:white;border:1px solid var(--border-light);border-radius:8px;
  padding:8px 12px;color:var(--text-dark);font-family:'Cairo',sans-serif;font-size:.83rem;margin-bottom:10px;
  outline:none;resize:none;transition:border-color .2s}
.rate-input:focus{border-color:var(--green)}
.rate-input::placeholder{color:var(--text-muted-dark)}
.rate-btn{background:var(--green);color:#fff;border:none;border-radius:8px;padding:9px 18px;
  font-family:'Cairo',sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s}
.rate-btn:hover{background:var(--green2)}

/* ── RESTAURANT DASHBOARD ── */
.orders-list{}
.order-card{background:var(--surface-white);border:1px solid var(--border-light);border-radius:14px;
  padding:16px;margin-bottom:12px;transition:border-color .2s;box-shadow:0 1px 5px rgba(0,0,0,0.04)}
.order-card:hover{border-color:rgba(0,98,51,0.2);box-shadow:0 4px 14px rgba(0,98,51,0.07)}
.order-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.order-id{font-size:.8rem;color:var(--text-muted-dark)}
.order-student{font-size:.95rem;font-weight:700;color:var(--text-dark)}
.order-items-list{font-size:.83rem;color:rgba(13,26,15,0.7);margin-bottom:12px;line-height:1.8}
.order-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.order-total{font-size:.95rem;font-weight:700;color:var(--green)}
.order-addr{font-size:.75rem;color:var(--text-muted-dark);display:flex;align-items:center;gap:4px}
.order-actions{display:flex;gap:8px}
.btn-accept{background:var(--green);color:#fff;border:none;border-radius:8px;padding:8px 16px;
  font-family:'Cairo',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:all .2s}
.btn-accept:hover{background:var(--green2)}
.btn-reject{background:rgba(200,16,46,0.08);color:var(--red);border:1px solid rgba(200,16,46,0.2);
  border-radius:8px;padding:8px 16px;font-family:'Cairo',sans-serif;font-size:.82rem;font-weight:700;
  cursor:pointer;transition:all .2s}
.btn-reject:hover{background:rgba(200,16,46,0.15)}

.driver-assign{margin-top:10px;background:rgba(0,98,51,0.04);border:1px solid rgba(0,98,51,0.12);
  border-radius:10px;padding:12px}
.da-title{font-size:.8rem;font-weight:700;color:var(--text-muted-dark);margin-bottom:8px}
.driver-select{width:100%;background:white;border:1px solid var(--border-light);border-radius:8px;
  padding:9px 12px;color:var(--text-dark);font-family:'Cairo',sans-serif;font-size:.85rem;outline:none;
  transition:border-color .2s}
.driver-select:focus{border-color:var(--green)}
.driver-select option{background:white}
.assign-btn{margin-top:8px;background:rgba(0,98,51,0.08);color:var(--green);border:1px solid rgba(0,98,51,0.2);
  border-radius:8px;padding:8px 14px;font-family:'Cairo',sans-serif;font-size:.82rem;font-weight:700;
  cursor:pointer;transition:all .2s;width:100%}
.assign-btn:hover{background:var(--green);color:#fff}

.status-select{background:white;border:1px solid var(--border-light);border-radius:8px;
  padding:8px 12px;color:var(--text-dark);font-family:'Cairo',sans-serif;font-size:.82rem;outline:none;
  transition:border-color .2s;margin-top:8px;width:100%}
.status-select:focus{border-color:var(--green)}
.status-select option{background:white}

/* ── MENU MANAGER ── */
.add-meal-form{background:var(--surface-white);border:1px solid var(--border-light);border-radius:14px;padding:20px;margin-bottom:20px;
  box-shadow:0 1px 6px rgba(0,0,0,0.04)}
.form-title{font-size:1rem;font-weight:700;color:var(--text-dark);margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:.8rem;font-weight:700;color:rgba(13,26,15,0.6)}
.form-input{background:rgba(0,98,51,0.03);border:1px solid var(--border-light);border-radius:8px;
  padding:10px 12px;color:var(--text-dark);font-family:'Cairo',sans-serif;font-size:.85rem;outline:none;
  transition:border-color .2s}
.form-input:focus{border-color:var(--green)}
.form-input::placeholder{color:var(--text-muted-dark)}
.form-select{background:rgba(0,98,51,0.03);border:1px solid var(--border-light);border-radius:8px;
  padding:10px 12px;color:var(--text-dark);font-family:'Cairo',sans-serif;font-size:.85rem;outline:none}
.form-select option{background:white}
.form-submit{background:var(--green);color:#fff;border:none;border-radius:9px;padding:11px 22px;
  font-family:'Cairo',sans-serif;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s}
.form-submit:hover{background:var(--green2);transform:translateY(-1px)}
.checkbox-group{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.cb-item{display:flex;align-items:center;gap:6px;font-size:.82rem;color:rgba(13,26,15,0.7);cursor:pointer}
.cb-item input{accent-color:var(--green)}

/* Image upload */
.img-upload-area{border:2px dashed var(--border-light);border-radius:10px;padding:16px;text-align:center;
  cursor:pointer;transition:all .2s;background:rgba(0,98,51,0.02);min-height:80px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.img-upload-area:hover{border-color:var(--green);background:rgba(0,98,51,0.04)}
.img-upload-area.has-img{border-style:solid;border-color:rgba(0,98,51,0.2)}
.img-upload-area img{width:80px;height:80px;object-fit:cover;border-radius:8px}
.img-upload-label{font-size:.78rem;color:var(--text-muted-dark);font-weight:600}

.menu-items-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.mi-card{background:var(--surface-white);border:1px solid var(--border-light);border-radius:12px;overflow:hidden;
  box-shadow:0 1px 4px rgba(0,0,0,0.04)}
.mi-img{width:100%;height:90px;object-fit:cover;background:#e8f5ee;display:flex;align-items:center;justify-content:center}
.mi-img img{width:100%;height:100%;object-fit:cover}
.mi-body{padding:12px}
.mi-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.mi-name{font-size:.9rem;font-weight:700;color:var(--text-dark)}
.mi-price{font-weight:700;color:var(--green)}
.mi-desc{font-size:.75rem;color:var(--text-muted-dark);margin-bottom:8px;line-height:1.5}
.mi-actions{display:flex;gap:6px}
.mi-del{background:rgba(200,16,46,0.07);color:var(--red);border:none;border-radius:6px;
  padding:5px 10px;font-family:'Cairo',sans-serif;font-size:.75rem;cursor:pointer;transition:all .2s}
.mi-del:hover{background:rgba(200,16,46,0.15)}
.toggle-avail{background:rgba(0,98,51,0.08);color:var(--green);border:1px solid rgba(0,98,51,0.2);
  border-radius:6px;padding:5px 10px;font-family:'Cairo',sans-serif;font-size:.75rem;cursor:pointer;transition:all .2s}
.toggle-avail:hover{background:rgba(0,98,51,0.15)}
.unavail .mi-name{color:var(--text-muted-dark);text-decoration:line-through}

/* ── DRIVER PANEL ── */
.driver-orders{}
.dorder-card{background:var(--surface-white);border:1px solid var(--border-light);border-radius:14px;padding:16px;margin-bottom:12px;
  box-shadow:0 1px 5px rgba(0,0,0,0.04)}
.dorder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.dorder-id{font-size:.78rem;color:var(--text-muted-dark)}
.dorder-student{font-size:.92rem;font-weight:700;color:var(--text-dark)}
.dorder-addr{font-size:.8rem;color:rgba(13,26,15,0.6);display:flex;align-items:center;gap:6px;margin-bottom:12px}
.dorder-actions{display:flex;gap:8px;flex-wrap:wrap}
.status-btn{padding:8px 14px;border-radius:8px;font-family:'Cairo',sans-serif;font-size:.8rem;
  font-weight:700;cursor:pointer;border:none;transition:all .2s}
.sb-transit{background:rgba(201,168,76,0.12);color:#8a6d1a}
.sb-transit:hover{background:rgba(201,168,76,0.2)}
.sb-delivered{background:rgba(0,98,51,0.1);color:var(--green)}
.sb-delivered:hover{background:var(--green);color:#fff}

/* ── NOTIFICATIONS ── */
.notif-panel{position:fixed;top:70px;left:auto;right:140px;width:320px;background:var(--surface-white);
  backdrop-filter:blur(24px);border:1px solid var(--border-light);border-radius:14px;padding:14px;
  z-index:200;display:none;box-shadow:0 8px 32px rgba(0,0,0,0.1)}
.notif-panel.open{display:block;animation:fadeUp .2s ease}
.np-header{font-size:.88rem;font-weight:700;color:var(--text-dark);margin-bottom:10px;
  display:flex;justify-content:space-between}
.np-clear{font-size:.75rem;color:var(--text-muted-dark);cursor:pointer;transition:color .2s}
.np-clear:hover{color:var(--green)}
.notif-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid rgba(0,0,0,0.05)}
.notif-item:last-child{border-bottom:none}
.ni-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ni-green{background:rgba(0,98,51,0.1)}
.ni-red{background:rgba(200,16,46,0.08)}
.ni-gold{background:rgba(201,168,76,0.1)}
.ni-text{font-size:.8rem;color:rgba(13,26,15,0.8);line-height:1.5}
.ni-time{font-size:.7rem;color:var(--text-muted-dark);margin-top:2px}

/* ── TOAST ── */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(100px);
  background:var(--text-dark);border:none;border-radius:12px;
  padding:12px 20px;font-size:.88rem;font-weight:600;color:#fff;
  z-index:999;transition:transform .35s cubic-bezier(.34,1.56,.64,1);
  backdrop-filter:blur(20px);white-space:nowrap;box-shadow:0 8px 24px rgba(0,0,0,0.15)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--red)}

/* ── EMPTY ── */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted-dark)}
.empty-icon{font-size:3rem;margin-bottom:12px;opacity:.5}
.empty-text{font-size:.95rem}

/* ── SECTION DIVIDER ── */
.section-divider{margin:24px 0;border:none;border-top:1px solid var(--border-light)}

/* ── SEARCH ── */
.search-bar{display:flex;align-items:center;gap:10px;background:var(--surface-white);
  border:1px solid var(--border-light);border-radius:10px;padding:10px 14px;margin-bottom:20px;
  transition:border-color .2s;box-shadow:0 1px 4px rgba(0,0,0,0.05)}
.search-bar:focus-within{border-color:rgba(0,98,51,0.3)}
.search-bar input{flex:1;background:none;border:none;outline:none;color:var(--text-dark);
  font-family:'Cairo',sans-serif;font-size:.9rem}
.search-bar input::placeholder{color:var(--text-muted-dark)}

/* ── SCROLLABLE TABLE ── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{text-align:right;font-size:.75rem;font-weight:700;color:var(--text-muted-dark);
  padding:10px 14px;border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.5px}
td{padding:12px 14px;font-size:.85rem;color:rgba(13,26,15,0.8);border-bottom:1px solid rgba(0,0,0,0.04)}
tr:hover td{background:rgba(0,98,51,0.03)}

/* ── RESTAURANT SETTINGS ── */
.settings-section{background:var(--surface-white);border:1px solid var(--border-light);
  border-radius:16px;padding:24px;margin-bottom:20px;box-shadow:0 1px 6px rgba(0,0,0,0.04)}
.settings-title{font-size:1rem;font-weight:700;color:var(--text-dark);margin-bottom:18px;
  display:flex;align-items:center;gap:8px}
.settings-title svg{color:var(--green)}
.banner-upload-area{border:2px dashed var(--border-light);border-radius:14px;
  cursor:pointer;transition:all .25s;background:rgba(0,98,51,0.02);overflow:hidden;
  min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  position:relative}
.banner-upload-area:hover{border-color:var(--green);background:rgba(0,98,51,0.04)}
.banner-upload-area.has-banner{border-style:solid;border-color:rgba(0,98,51,0.25);padding:0}
.banner-upload-area.has-banner img{width:100%;height:160px;object-fit:cover;display:block}
.banner-upload-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.4);
  display:flex;align-items:center;justify-content:center;gap:8px;
  color:white;font-size:.85rem;font-weight:700;opacity:0;transition:.2s}
.banner-upload-area.has-banner:hover .banner-upload-overlay{opacity:1}
.save-settings-btn{background:var(--green);color:#fff;border:none;border-radius:10px;
  padding:12px 24px;font-family:'Cairo',sans-serif;font-size:.9rem;font-weight:700;
  cursor:pointer;transition:all .25s;display:flex;align-items:center;gap:8px}
.save-settings-btn:hover{background:var(--green2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,98,51,0.2)}

/* RESPONSIVE */
@media(max-width:900px){
  .main{padding:16px 14px}
  .cart-layout{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .nb-nav{gap:2px}
  .sb-item span{display:none}
  .sb-item{padding:8px 10px}
  .nb-user-info{display:none}
  .hero-stats{display:none}
  .home-hero{padding:20px}
  .nb-logout span{display:none}
}
/* ══════════════════════════════════════════
   MOBILE RESPONSIVE — store.css
   ══════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── NAVBAR ── */
  .nb-nav { gap: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .nb-nav::-webkit-scrollbar { display: none; }
  .sb-item { padding: 10px 12px; flex-shrink: 0; }
  .sb-item span { font-size: .72rem; }
  .nb-user-info { display: none; }
  .nb-logout span { display: none; }
  .nb-logout { padding: 6px 10px; }
  .hero-stats { display: none; }

  /* ── MAIN ── */
  .main { padding: 14px 12px 24px; }

  /* ── HOME HERO ── */
  .home-hero {
    padding: 22px 16px 20px;
    border-radius: 16px;
    margin-bottom: 16px;
  }
  .home-hero h1 { font-size: 1.5rem; line-height: 1.25; margin-bottom: 8px; }
  .home-hero p { font-size: .83rem; margin-bottom: 14px; }

  /* ── SECTION HEADERS ── */
  .section-head { flex-direction: column; align-items: flex-start; gap: 8px; margin-bottom: 14px; }
  .section-head h2 { font-size: 1rem; }

  /* ── RESTAURANT CARDS GRID ── */
  .rest-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px;
  }
  .rest-card { border-radius: 14px; }
  .rest-img { height: 110px; }
  .rest-name { font-size: .82rem; }
  .rest-meta { font-size: .7rem; flex-wrap: wrap; gap: 4px; }
  .rest-delivery-badge { font-size: .65rem; padding: 3px 8px; }

  /* ── MENU ITEMS ── */
  .menu-grid {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }
  .menu-item { padding: 12px; flex-direction: row; align-items: center; gap: 12px; }
  .menu-item-img { width: 70px; height: 70px; border-radius: 10px; flex-shrink: 0; }
  .menu-item-body { flex: 1; }
  .menu-item-name { font-size: .86rem; }
  .menu-item-desc { font-size: .73rem; -webkit-line-clamp: 1; }

  /* ── CART ── */
  .cart-layout {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .cart-summary {
    position: static !important;
    border-radius: 14px;
  }
  .cart-item { gap: 10px; }
  .cart-item-img { width: 60px; height: 60px; border-radius: 10px; }
  .cart-item-name { font-size: .84rem; }
  .cart-item-price { font-size: .84rem; }
  .qty-btn { width: 28px; height: 28px; font-size: .9rem; }
  .qty-val { font-size: .88rem; min-width: 28px; }

  /* ── DELIVERY OPTIONS ── */
  .delivery-options { gap: 8px; }
  .dlv-opt { padding: 10px 12px; border-radius: 10px; }
  .dlv-name { font-size: .82rem; }
  .dlv-desc { font-size: .72rem; }
  .dlv-price { font-size: .82rem; }

  /* ── ADDRESS INPUT ── */
  .addr-input { font-size: .86rem; padding: 12px 14px; }

  /* ── CHECKOUT BTN ── */
  .checkout-btn { padding: 14px; font-size: .92rem; }

  /* ── ORDERS LIST ── */
  .order-card { padding: 14px; border-radius: 14px; }
  .order-card-header { flex-wrap: wrap; gap: 6px; }
  .order-id { font-size: .72rem; }

  /* ── TRACKING STEPS ── */
  .track-step { gap: 10px; }
  .ts-dot { width: 32px; height: 32px; flex-shrink: 0; }
  .ts-label { font-size: .82rem; }
  .ts-time { font-size: .72rem; }

  /* ── FORM ── */
  .form-row { grid-template-columns: 1fr !important; gap: 10px; }

  /* ── PAYMENT MODAL (store) ── */
  #paymentModal > div {
    border-radius: 20px 20px 0 0 !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    padding: 24px 18px !important;
  }
}

@media (max-width: 480px) {
  .rest-grid { grid-template-columns: 1fr !important; }
}
