
:root{
  --orange:#ff6500;--orange-light:#ff8533;--orange-dim:#fff3ed;
  --yellow:#ffc422;--yellow-dim:#fffbeb;
  --dark:#160f04;--brown:#3a2810;--cream:#fdfaf5;
  --surface:#ffffff;--surface-2:#faf7f2;--surface-3:#f3ede3;
  --border:#e8ddd0;--border-light:#f0e8dc;
  --text:#1a1208;--text-2:#5a4a34;--text-3:#9a8878;
  --success:#16a34a;--success-dim:#dcfce7;
  --danger:#dc2626;--danger-dim:#fee2e2;
  --blue:#2563eb;--blue-dim:#dbeafe;
  --purple:#7c3aed;--purple-dim:#ede9fe;
  --shadow-sm:0 1px 3px rgba(26,18,8,.06),0 1px 2px rgba(26,18,8,.04);
  --shadow-md:0 4px 16px rgba(26,18,8,.08),0 2px 4px rgba(26,18,8,.04);
  --shadow-lg:0 12px 40px rgba(26,18,8,.12),0 4px 8px rgba(26,18,8,.06);
  --shadow-orange:0 8px 32px rgba(255,101,0,.25);
  --radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;
  --font-display:'Roboto',sans-serif;--font-body:'Roboto',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;overscroll-behavior:none;}
body{font-family:var(--font-body);background:var(--cream);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;overscroll-behavior:none;}
.view{display:none;}.view.active{display:block;}
button{font-family:var(--font-body);cursor:pointer;}
input,select,textarea{font-family:var(--font-body);}

/* ===== COUNTDOWN BANNER ===== */
.countdown-banner{background:var(--dark);color:white;text-align:center;padding:9px 16px;font-size:0.78rem;font-weight:500;position:relative;z-index:60;letter-spacing:0.1px;}
.countdown-banner.late{background:#7c2d12;}
.countdown-banner.urgent{background:#991b1b;animation:pulse-bg 1.2s ease-in-out infinite;}
@keyframes pulse-bg{0%,100%{opacity:1;}50%{opacity:.82;}}
.countdown-timer{font-family:var(--font-display);font-weight:800;font-size:0.95rem;color:var(--yellow);margin-left:5px;letter-spacing:0.5px;}
.late-fee-badge{background:var(--danger);color:white;font-size:0.68rem;font-weight:700;padding:2px 8px;border-radius:20px;margin-left:8px;vertical-align:middle;}

/* ===== HERO ===== */
.hero{background:linear-gradient(150deg,#ff6500 0%,#c94200 55%,#9c3300 100%);padding:0 0 40px;position:relative;overflow:visible;}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,196,34,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.04) 0%,transparent 40%);pointer-events:none;}
.hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:32px;background:var(--cream);border-radius:32px 32px 0 0;}
.top-nav{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;position:relative;z-index:1000;overflow:visible;}
.logo{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:white;letter-spacing:-0.3px;display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;}
.logo-text{cursor:pointer;transition:opacity 0.15s;}
.logo-text:active{opacity:0.8;}
.logo-emoji{cursor:pointer;transition:transform 0.15s;}
.logo-emoji:active{transform:scale(1.1);}
.logo-dot{color:var(--yellow);}
.hero-content{text-align:center;padding:12px 20px 0;position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:white;font-weight:600;font-size:0.68rem;padding:4px 11px;border-radius:20px;letter-spacing:0.3px;margin-bottom:10px;text-transform:uppercase;}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:1.95rem;color:white;line-height:1.15;margin-bottom:8px;letter-spacing:-0.5px;}
.hero h1 em{font-style:normal;color:var(--yellow);}
.hero p{color:rgba(255,255,255,.85);font-size:0.85rem;line-height:1.5;max-width:280px;margin:0 auto 12px;}
.hero-tags{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin-bottom:0;}
.tag{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.9);padding:4px 9px;border-radius:16px;font-size:0.7rem;font-weight:500;}

/* ===== HERO CAROUSEL (3 rotating cards) ===== */


/* ===== CUSTOMER TABS ===== */
.customer-tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm);}
.cust-tab{flex:1;padding:13px 6px;text-align:center;font-weight:600;font-size:0.8rem;cursor:pointer;color:var(--text-3);border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:all 0.2s;font-family:var(--font-display);letter-spacing:0.1px;}
.cust-tab.active{color:var(--orange);border-bottom-color:var(--orange);}
.cust-panel{display:none;}.cust-panel.active{display:block;}

/* ===== MENU AREA ===== */
.main-content{padding:0 16px 100px;margin-top:-6px;}
.day-selector{display:flex;gap:7px;overflow-x:auto;padding:18px 0 12px;scrollbar-width:none;}
.day-selector::-webkit-scrollbar{display:none;}
.day-btn{flex-shrink:0;padding:8px 16px;border-radius:24px;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;font-family:var(--font-display);font-weight:700;font-size:0.78rem;color:var(--text-2);transition:all 0.2s;white-space:nowrap;}
.day-btn.active{background:var(--orange);border-color:var(--orange);color:white;box-shadow:var(--shadow-orange);}
.day-btn.no-menu{opacity:.4;}
.day-btn.next-day{border-color:var(--orange);color:var(--orange);}
.menu-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.section-title{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--text);}
.view-toggle{display:flex;background:var(--surface-3);border-radius:10px;padding:3px;gap:2px;}
.vt-btn{width:32px;height:28px;border-radius:7px;border:none;background:transparent;color:var(--text-3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.18s;font-size:0.95rem;}
.vt-btn.active{background:var(--surface);color:var(--orange);box-shadow:var(--shadow-sm);}
.meal-time-label{display:inline-flex;align-items:center;gap:5px;font-size:0.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:10px;}
.food-grid-list{display:flex;flex-direction:column;gap:9px;}
.food-card{background:var(--surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;align-items:center;transition:all 0.2s;border:1px solid var(--border-light);}
.food-card:active{transform:scale(.99);}
.food-card-img{width:88px;height:80px;object-fit:cover;flex-shrink:0;}
.food-card-body{padding:10px 11px;flex:1;min-width:0;}
.food-card-name{font-family:var(--font-display);font-weight:700;font-size:0.88rem;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.food-card-desc{font-size:0.72rem;color:var(--text-3);line-height:1.4;margin-bottom:5px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.food-card-footer{display:flex;align-items:center;justify-content:space-between;}
.food-price{font-weight:700;color:var(--orange);font-size:0.88rem;font-family:var(--font-display);}
.meal-type-badge{font-size:0.62rem;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase;letter-spacing:0.3px;}
.badge-breakfast{background:#fff3e0;color:#c44d00;}
.badge-lunch{background:#d1fae5;color:#166534;}
.badge-addon{background:var(--purple-dim);color:var(--purple);}
.badge-general{background:var(--purple-dim);color:var(--purple);}
.add-btn{width:30px;height:30px;border-radius:50%;background:var(--orange);color:white;border:none;font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-right:10px;flex-shrink:0;transition:all 0.18s;box-shadow:0 2px 8px rgba(255,101,0,.3);}
.add-btn:hover{transform:scale(1.08);}
.add-btn.added{background:var(--success);box-shadow:0 2px 8px rgba(22,163,74,.3);}
.food-grid-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.food-card-sq{background:var(--surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:all 0.2s;position:relative;}
.food-card-sq:active{transform:scale(.98);}
.food-card-sq-img{width:100%;height:120px;object-fit:cover;}
.food-card-sq-body{padding:9px 10px 10px;}
.food-card-sq-name{font-family:var(--font-display);font-weight:700;font-size:0.82rem;line-height:1.25;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.food-card-sq-desc{font-size:0.72rem;color:var(--text-3);line-height:1.35;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.food-card-sq-desc{font-size:0.72rem;color:var(--text-3);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:2px;}
.food-card-sq-footer{display:flex;align-items:center;justify-content:space-between;margin-top:6px;}
.food-card-sq-price{font-weight:700;color:var(--orange);font-size:0.85rem;font-family:var(--font-display);}
.add-btn-sq{width:26px;height:26px;border-radius:50%;background:var(--orange);color:white;border:none;font-size:0.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.18s;box-shadow:0 2px 8px rgba(255,101,0,.3);}
.add-btn-sq:hover{transform:scale(1.1);}
.add-btn-sq.added{background:var(--success);}
.food-card-sq-badge{position:absolute;top:8px;left:8px;}
.no-menu-msg{text-align:center;padding:48px 20px;color:var(--text-3);font-size:0.88rem;}
.no-menu-msg .emoji{font-size:2.8rem;display:block;margin-bottom:10px;}
.next-day-notice{background:var(--yellow-dim);border:1px solid #fde68a;border-radius:var(--radius-sm);padding:10px 13px;font-size:0.78rem;color:#92400e;margin-bottom:12px;display:flex;align-items:center;gap:7px;}

/* ===== SUBSCRIPTIONS ===== */
.sub-panel{padding:22px 16px 100px;}
.sub-header h2{font-family:var(--font-display);font-weight:800;font-size:1.4rem;margin-bottom:5px;}
.sub-header p{color:var(--text-2);font-size:0.85rem;line-height:1.6;margin-bottom:20px;}
.sub-meal-selector{margin-bottom:20px;}
.sub-meal-label{font-family:var(--font-display);font-weight:700;font-size:0.85rem;margin-bottom:10px;color:var(--text-2);}
.meal-choice-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.meal-choice{padding:11px 6px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;text-align:center;transition:all 0.2s;}
.meal-choice.selected{border-color:var(--orange);background:var(--orange-dim);}
.meal-choice-icon{font-size:1.4rem;margin-bottom:3px;}
.meal-choice-name{font-size:0.74rem;font-weight:700;color:var(--text);}
.meal-choice-sub{font-size:0.62rem;color:var(--text-3);}
.plans-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;}
.plan-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-md);border:1.5px solid var(--border-light);cursor:pointer;transition:all 0.22s;position:relative;overflow:hidden;}
.plan-card.selected{border-color:var(--orange);box-shadow:var(--shadow-orange);}
.plan-card.popular::before{content:'POPULAR';position:absolute;top:12px;right:-26px;background:var(--yellow);color:var(--dark);font-size:0.58rem;font-weight:800;padding:3px 32px;transform:rotate(45deg) translateX(8px);letter-spacing:0.6px;}
.plan-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;}
.plan-name{font-family:var(--font-display);font-weight:800;font-size:1rem;}
.plan-price{font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--orange);}
.plan-price span{font-size:0.72rem;color:var(--text-3);font-weight:400;}
.plan-features{margin-top:9px;display:flex;flex-direction:column;gap:4px;}
.plan-feat{font-size:0.76rem;color:var(--text-2);display:flex;align-items:center;gap:5px;}
.plan-feat::before{content:'✓';color:var(--success);font-weight:700;font-size:0.8rem;}
.plan-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;transition:all 0.2s;display:flex;align-items:center;justify-content:center;margin-top:2px;}
.plan-card.selected .plan-radio{border-color:var(--orange);background:var(--orange);}
.plan-card.selected .plan-radio::after{content:'';width:7px;height:7px;border-radius:50%;background:white;display:block;}
.subscribe-btn{width:100%;padding:15px;background:var(--orange);color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.95rem;cursor:pointer;transition:all 0.2s;box-shadow:var(--shadow-orange);}

/* ===== CART BAR ===== */
.cart-bar{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom, 0px));left:0;right:0;background:var(--dark);color:white;padding:13px 18px 14px;display:flex;align-items:center;justify-content:space-between;transform:translateY(110%);transition:transform 0.35s cubic-bezier(.34,1.56,.64,1);z-index:100;border-radius:22px 22px 0 0;box-shadow:0 -8px 40px rgba(0,0,0,.25);}
.cart-bar.visible{transform:translateY(0);}
.cart-info{display:flex;align-items:center;gap:10px;}
.cart-count{background:var(--orange);color:white;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.8rem;box-shadow:0 0 0 2px rgba(255,255,255,.15);}
.cart-text{font-size:0.86rem;line-height:1.3;}
.cart-text strong{font-family:var(--font-display);}
.checkout-btn{background:var(--orange);color:white;border:none;padding:9px 20px;border-radius:24px;font-weight:700;cursor:pointer;font-size:0.85rem;transition:all 0.2s;letter-spacing:0.2px;}

/* ===== MODALS ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(22,15,4,.6);z-index:200;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.25s;}
.modal-overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(3px);}
.modal{background:var(--surface);border-radius:28px 28px 0 0;width:100%;max-width:520px;padding:20px 20px 32px;max-height:78vh;overflow-y:auto;transform:translateY(50px);transition:transform 0.32s cubic-bezier(.34,1.56,.64,1);}
.modal-overlay.open .modal{transform:translateY(0);}
/* Profile edit slide-up overlay */
.profile-edit-overlay{position:fixed;inset:0;background:rgba(22,15,4,.55);z-index:210;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.25s;}
.profile-edit-overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(3px);}
.profile-edit-sheet{background:var(--surface);border-radius:28px 28px 0 0;width:100%;max-width:520px;padding:20px 20px 36px;max-height:88vh;overflow-y:auto;transform:translateY(60px);transition:transform 0.32s cubic-bezier(.34,1.56,.64,1);}
.profile-edit-overlay.open .profile-edit-sheet{transform:translateY(0);}
.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 18px;}
.modal-title{font-family:var(--font-display);font-weight:800;font-size:1.3rem;margin-bottom:4px;}
.modal-subtitle{color:var(--text-3);font-size:0.84rem;margin-bottom:16px;}
.cart-item-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light);}
.cart-item-img{width:44px;height:44px;border-radius:10px;object-fit:cover;flex-shrink:0;}
.cart-item-info{flex:1;min-width:0;}
.cart-item-name{font-weight:600;font-size:0.86rem;}
.cart-item-price{color:var(--orange);font-weight:700;font-size:0.8rem;font-family:var(--font-display);}
.qty-controls{display:flex;align-items:center;gap:6px;}
.qty-btn{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;font-size:0.85rem;display:flex;align-items:center;justify-content:center;font-weight:700;transition:all 0.15s;}
.qty-btn:hover{border-color:var(--orange);color:var(--orange);}
.qty-num{font-weight:700;font-size:0.86rem;min-width:18px;text-align:center;}
.cart-total{display:flex;justify-content:space-between;align-items:center;padding:14px 0 4px;font-family:var(--font-display);font-weight:700;}
.cart-total-price{font-size:1.2rem;color:var(--orange);}
.late-fee-notice{background:var(--danger-dim);border:1px solid #fecaca;border-radius:var(--radius-sm);padding:10px 12px;font-size:0.78rem;color:#991b1b;margin-bottom:10px;display:flex;align-items:center;gap:8px;}

/* ===== UPSELL ===== */
.upsell-section{margin:12px 0;}
.upsell-title{font-family:var(--font-display);font-weight:700;font-size:0.9rem;margin-bottom:9px;display:flex;align-items:center;gap:6px;}
.upsell-scroll{display:flex;gap:9px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;}
.upsell-scroll::-webkit-scrollbar{display:none;}
.upsell-card{flex-shrink:0;width:115px;background:var(--surface-2);border-radius:var(--radius-md);overflow:hidden;border:1.5px solid transparent;cursor:pointer;transition:all 0.2s;}
.upsell-card.selected{border-color:var(--orange);background:var(--orange-dim);}
.upsell-card img{width:100%;height:66px;object-fit:cover;}
.upsell-card-body{padding:7px 8px 8px;}
.upsell-name{font-size:0.72rem;font-weight:700;margin-bottom:3px;line-height:1.25;}
.upsell-price{font-size:0.7rem;color:var(--orange);font-weight:700;font-family:var(--font-display);}
.upsell-add-btn{width:20px;height:20px;border-radius:50%;background:var(--orange);color:white;border:none;font-size:0.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:auto;margin-top:4px;}
.upsell-card.selected .upsell-add-btn{background:var(--success);}

/* ===== FORMS ===== */
.form-group{margin-bottom:12px;}
.form-label{display:block;font-weight:600;font-size:0.78rem;margin-bottom:5px;color:var(--text-2);letter-spacing:0.2px;}
.form-input{width:100%;padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.9rem;background:var(--surface-2);color:var(--text);transition:all 0.18s;outline:none;}
.form-input:focus{border-color:var(--orange);background:var(--surface);box-shadow:0 0 0 3px rgba(255,101,0,.1);}
.form-input::placeholder{color:var(--text-3);}
.aff-input-wrap{position:relative;}
.aff-badge{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:0.7rem;font-weight:700;padding:2px 8px;border-radius:10px;display:none;}
.aff-badge.valid{display:block;background:var(--success-dim);color:#166534;}
.aff-badge.invalid{display:block;background:var(--danger-dim);color:#991b1b;}
/* ===== PASSWORD TOGGLE ===== */
.pw-input-wrap{position:relative;display:flex;align-items:center;}
.pw-input-wrap .form-input{width:100%;}
.pw-toggle-btn{position:absolute;right:12px;background:none;border:none;color:var(--text-3);font-size:1.1rem;cursor:pointer;padding:4px 8px;display:flex;align-items:center;justify-content:center;transition:color 0.2s;}
.pw-toggle-btn:hover{color:var(--orange);}
.settings-pw-wrap{position:relative;display:flex;align-items:center;}
.settings-pw-wrap .settings-input{padding-right:42px;}
.pw-toggle-settings-btn{position:absolute;right:12px;background:none;border:none;color:var(--text-3);font-size:1rem;cursor:pointer;padding:4px 8px;display:flex;align-items:center;justify-content:center;transition:color 0.2s;}
.pw-toggle-settings-btn:hover{color:var(--orange);}
.pay-now-btn{width:100%;padding:14px;background:var(--orange);color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.95rem;cursor:pointer;transition:all 0.2s;box-shadow:var(--shadow-orange);margin-top:8px;}
.support-note{text-align:center;color:var(--text-3);font-size:0.75rem;margin-top:11px;}
.support-note a{color:var(--orange);font-weight:600;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.btn-back{background:none;border:none;color:var(--orange);font-weight:700;cursor:pointer;font-size:0.84rem;padding:4px 0;margin-bottom:12px;display:flex;align-items:center;gap:4px;}

/* ===== IMAGE UPLOAD ===== */
.img-upload-wrap{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:12px;cursor:pointer;text-align:center;transition:border-color 0.2s;background:var(--surface-2);position:relative;}
.img-upload-wrap:hover{border-color:var(--orange);}
.img-upload-wrap.has-img{padding:0;border:none;background:none;}
.img-upload-preview{width:100%;height:90px;object-fit:cover;border-radius:var(--radius-sm);display:block;}
.img-upload-label{font-size:0.74rem;color:var(--text-3);margin-top:4px;}
.img-upload-icon{font-size:1.5rem;display:block;margin-bottom:4px;}
/* Must NOT be display:none on iOS — programmatic .click() fails on hidden inputs */
.img-upload-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2;}
.img-upload-wrap.has-img .img-upload-input{display:none;}
.img-change-btn{background:var(--surface-3);border:1px solid var(--border);color:var(--text-2);padding:4px 10px;border-radius:var(--radius-sm);font-size:0.7rem;font-weight:600;cursor:pointer;margin-top:5px;display:block;width:100%;}

/* ===== INSTALL BANNER ===== */
.install-banner{background:linear-gradient(135deg,var(--dark) 0%,#2d1a07 100%);color:white;padding:11px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.install-banner-text{font-size:0.78rem;line-height:1.4;flex:1;}
.install-banner-text strong{display:block;font-family:var(--font-display);font-size:0.84rem;}
.install-btn{background:var(--orange);color:white;border:none;padding:7px 14px;border-radius:20px;font-weight:700;cursor:pointer;font-size:0.76rem;white-space:nowrap;flex-shrink:0;}
.install-dismiss{background:none;border:none;color:rgba(255,255,255,.45);cursor:pointer;font-size:1.1rem;padding:2px;flex-shrink:0;}

/* ===== TOAST ===== */
.toast{position:fixed;top:16px;left:50%;transform:translateX(-50%) translateY(-90px);background:var(--dark);color:white;padding:10px 18px;border-radius:24px;font-size:0.82rem;font-weight:600;z-index:9999;transition:transform 0.3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;box-shadow:var(--shadow-lg);}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast.success{background:#15803d;}
.toast.error{background:#b91c1c;}

/* ===== CUSTOM DIALOG (replaces browser confirm/alert) ===== */
.dialog-overlay{position:fixed;inset:0;background:rgba(22,15,4,.55);z-index:10000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity 0.2s;}
.dialog-overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(4px);}
.dialog-box{background:var(--surface);border-radius:var(--radius-xl);padding:26px 22px 20px;max-width:340px;width:100%;box-shadow:var(--shadow-lg);transform:scale(0.92) translateY(12px);transition:transform 0.25s cubic-bezier(.34,1.56,.64,1);}
.dialog-overlay.open .dialog-box{transform:scale(1) translateY(0);}
.dialog-icon{font-size:2rem;text-align:center;margin-bottom:10px;}
.dialog-title{font-family:var(--font-display);font-weight:800;font-size:1.1rem;text-align:center;margin-bottom:6px;}
.dialog-msg{font-size:0.85rem;color:var(--text-2);text-align:center;line-height:1.6;margin-bottom:20px;}
.dialog-btns{display:grid;gap:8px;}
.dialog-btns.two{grid-template-columns:1fr 1fr;}
.dialog-btn{padding:11px;border-radius:var(--radius-md);border:none;font-family:var(--font-display);font-weight:700;font-size:0.88rem;cursor:pointer;transition:all 0.18s;}
.dialog-btn.primary{background:var(--orange);color:white;box-shadow:var(--shadow-orange);}
.dialog-btn.primary:hover{background:var(--orange-light);}
.dialog-btn.secondary{background:var(--surface-3);color:var(--text-2);border:1.5px solid var(--border);}
.dialog-btn.secondary:hover{background:var(--surface-2);}
.dialog-btn.danger{background:var(--danger);color:white;}

/* ===== ADMIN ===== */
#admin-view{min-height:100vh;background:var(--surface-2);overflow:visible;}
.auth-screen{max-width:360px;margin:0 auto;padding:52px 24px;display:flex;flex-direction:column;align-items:center;}
.auth-logo{font-family:var(--font-display);font-weight:800;font-size:2rem;color:var(--orange);margin-bottom:4px;letter-spacing:-1px;}
.auth-screen h2{font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin-bottom:4px;}
.auth-screen p{color:var(--text-3);font-size:0.84rem;margin-bottom:22px;text-align:center;line-height:1.55;}
.auth-screen .form-input{background:var(--surface);margin-bottom:10px;display:block;}
.auth-btn{width:100%;padding:13px;background:var(--orange);color:white;border:none;border-radius:var(--radius-md);font-weight:700;font-size:0.92rem;cursor:pointer;font-family:var(--font-display);box-shadow:var(--shadow-orange);}
.auth-error{color:var(--danger);font-size:0.8rem;margin-top:7px;display:none;}
.admin-dashboard{display:none;min-height:100vh;}
.admin-header{background:var(--dark);color:white;padding:13px 18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:90;box-shadow:0 2px 12px rgba(0,0,0,.35);}
.admin-header-left{display:flex;align-items:center;gap:12px;}
.hamburger-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:white;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.2s;flex-shrink:0;}
.hamburger-icon{display:flex;flex-direction:column;gap:4px;}
.hamburger-icon span{display:block;width:16px;height:1.5px;background:white;border-radius:2px;transition:all 0.25s;}
.hamburger-btn.open .hamburger-icon span:nth-child(1){transform:rotate(45deg) translate(4px,4px);}
.hamburger-btn.open .hamburger-icon span:nth-child(2){opacity:0;transform:translateX(-4px);}
.hamburger-btn.open .hamburger-icon span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px);}
.admin-logo{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:white;}
.admin-logo span{color:var(--yellow);}
.admin-signout{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:white;padding:6px 12px;border-radius:20px;cursor:pointer;font-size:0.75rem;font-weight:600;}
.admin-nav-drawer{position:fixed;top:0;left:-280px;width:270px;height:100vh;background:var(--dark);z-index:95;transition:left 0.3s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);}
.admin-nav-drawer.open{left:0;}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:94;opacity:0;pointer-events:none;transition:opacity 0.3s;}
.drawer-overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(2px);}
.drawer-header{padding:54px 20px 18px;border-bottom:1px solid rgba(255,255,255,.08);}
.drawer-logo{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:white;}
.drawer-logo span{color:var(--yellow);}
.drawer-sub{font-size:0.75rem;color:rgba(255,255,255,.45);margin-top:2px;}
.drawer-nav{padding:10px 12px;flex:1;}
.drawer-nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:var(--radius-sm);color:rgba(255,255,255,.65);cursor:pointer;transition:all 0.18s;font-size:0.86rem;font-weight:500;margin-bottom:2px;}
.drawer-nav-item:hover{background:rgba(255,255,255,.07);color:white;}
.drawer-nav-item.active{background:rgba(255,101,0,.25);color:var(--orange);font-weight:600;}
.drawer-nav-item .nav-icon{font-size:1rem;width:22px;text-align:center;}
.drawer-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.08);}
.drawer-signout{width:100%;padding:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.7);border-radius:var(--radius-sm);cursor:pointer;font-size:0.82rem;font-weight:600;}
.admin-panel{display:none;padding:16px 16px 40px;max-width:720px;margin:0 auto;}
.admin-panel.active{display:block;}
.admin-section-title{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin-bottom:12px;color:var(--text);}
.admin-section-sub{font-size:0.78rem;color:var(--text-3);margin-bottom:13px;margin-top:-8px;line-height:1.5;}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px;}
.stat-card{background:var(--surface);border-radius:var(--radius-md);padding:15px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);}
.stat-val{font-family:var(--font-display);font-weight:800;font-size:1.45rem;color:var(--orange);}
.stat-label{font-size:0.72rem;color:var(--text-3);margin-top:2px;font-weight:500;}
.stat-card.highlight{background:linear-gradient(135deg,var(--orange) 0%,#c94200 100%);border-color:transparent;box-shadow:var(--shadow-orange);}
.stat-card.highlight .stat-val{color:var(--yellow);}
.stat-card.highlight .stat-label{color:rgba(255,255,255,.75);}
.insights-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px;}
.insight-card{background:var(--surface);border-radius:var(--radius-md);padding:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);}
.insight-icon{font-size:1.25rem;margin-bottom:5px;}
.insight-label{font-size:0.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:3px;font-weight:600;}
.insight-val{font-family:var(--font-display);font-weight:800;font-size:0.92rem;color:var(--text);line-height:1.2;}
.insight-sub{font-size:0.68rem;color:var(--text-3);margin-top:2px;}
.insight-card.good .insight-val{color:var(--success);}
.insight-card.warn .insight-val{color:var(--danger);}
.day-perf-row{display:flex;align-items:center;gap:10px;margin-bottom:9px;}
.day-perf-label{font-size:0.78rem;font-weight:700;min-width:28px;color:var(--text-2);}
.day-perf-bar-wrap{flex:1;background:var(--surface-3);border-radius:6px;height:9px;overflow:hidden;}
.day-perf-bar{height:100%;background:linear-gradient(90deg,var(--orange),var(--orange-light));border-radius:6px;transition:width 0.7s cubic-bezier(.4,0,.2,1);}
.day-perf-val{font-size:0.72rem;font-weight:700;color:var(--text-3);min-width:52px;text-align:right;}
.orders-list{display:flex;flex-direction:column;gap:9px;}
.order-card{background:var(--surface);border-radius:var(--radius-md);padding:13px 14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);}
.order-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px;}
.order-ref{font-family:var(--font-display);font-weight:700;font-size:0.82rem;}
.order-amount{font-weight:700;color:var(--orange);font-family:var(--font-display);}
.order-details{font-size:0.75rem;color:var(--text-3);line-height:1.6;}
.order-status{display:inline-block;font-size:0.68rem;font-weight:700;padding:2px 8px;border-radius:10px;margin-top:5px;}
.status-paid{background:var(--success-dim);color:#166534;}
.menu-day-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-bottom:16px;}
.menu-day-chip{padding:9px 4px;text-align:center;border-radius:var(--radius-sm);border:1.5px solid var(--border);cursor:pointer;font-weight:700;font-size:0.74rem;transition:all 0.2s;background:var(--surface);color:var(--text-2);}
.menu-day-chip.active{background:var(--orange);border-color:var(--orange);color:white;}
.food-manager-list{display:flex;flex-direction:column;gap:8px;margin-bottom:13px;}
.food-mgr-item{display:flex;align-items:center;gap:10px;background:var(--surface);border-radius:var(--radius-sm);padding:9px 11px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);}
.food-mgr-img{width:42px;height:42px;border-radius:8px;object-fit:cover;flex-shrink:0;}
.food-mgr-info{flex:1;min-width:0;}
.food-mgr-name{font-weight:600;font-size:0.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.food-mgr-price{font-size:0.74rem;color:var(--orange);font-weight:700;font-family:var(--font-display);}
.food-mgr-type{font-size:0.68rem;color:var(--text-3);}
.toggle-day-btn{padding:5px 10px;border-radius:20px;font-size:0.72rem;font-weight:700;cursor:pointer;border:none;transition:all 0.18s;white-space:nowrap;flex-shrink:0;}
.toggle-day-btn.on{background:var(--success-dim);color:#166534;}
.toggle-day-btn.off{background:var(--danger-dim);color:#b91c1c;}
.del-btn{background:none;border:none;color:var(--border);cursor:pointer;font-size:0.92rem;padding:4px;transition:color 0.18s;flex-shrink:0;}
.del-btn:hover{color:var(--danger);}
.add-food-card,.add-affiliate-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-md);margin-top:13px;border:1px solid var(--border-light);}
.add-food-title{font-family:var(--font-display);font-weight:700;margin-bottom:13px;font-size:0.92rem;}
.add-food-btn,.add-affiliate-btn{width:100%;padding:12px;color:white;border:none;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;font-family:var(--font-display);margin-top:10px;font-size:0.88rem;}
.add-food-btn{background:var(--orange);box-shadow:0 3px 12px rgba(255,101,0,.3);}
.add-affiliate-btn{background:var(--dark);}
.affiliate-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px;}
.affiliate-card{background:var(--surface);border-radius:var(--radius-lg);padding:15px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);}
.affiliate-card-top{display:flex;justify-content:space-between;align-items:flex-start;}
.affiliate-name{font-family:var(--font-display);font-weight:700;font-size:0.92rem;}
.affiliate-code{font-family:monospace;font-size:0.8rem;background:var(--surface-2);padding:3px 8px;border-radius:6px;color:var(--brown);margin-top:3px;display:inline-block;}
.affiliate-stats{display:flex;gap:12px;margin-top:9px;flex-wrap:wrap;}
.aff-stat-sm{font-size:0.76rem;color:var(--text-3);}
.aff-stat-sm strong{color:var(--text);font-weight:700;}
.qr-wrap{text-align:center;margin-top:10px;}
.qr-label{font-size:0.68rem;color:var(--text-3);margin-top:3px;}
.del-aff-btn{background:none;border:1px solid #fecaca;color:var(--danger);padding:4px 9px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.72rem;font-weight:600;}
.sub-plans-admin{display:flex;flex-direction:column;gap:12px;}
.sub-plan-admin-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);}
.sub-plan-admin-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.sub-plan-admin-name{font-family:var(--font-display);font-weight:700;font-size:0.92rem;}
.sub-toggle{width:40px;height:22px;border-radius:11px;background:var(--border);cursor:pointer;position:relative;transition:background 0.2s;border:none;flex-shrink:0;}
.sub-toggle.on{background:var(--success);}
.sub-toggle::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:white;top:3px;left:3px;transition:left 0.2s;box-shadow:0 1px 4px rgba(0,0,0,.2);}
.sub-toggle.on::after{left:21px;}
.price-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px;}
.price-field label{font-size:0.7rem;color:var(--text-3);display:block;margin-bottom:4px;font-weight:600;}
.sub-price-input{width:100%;padding:8px 9px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:700;font-size:0.9rem;color:var(--orange);background:var(--surface-2);outline:none;}
.sub-price-input:focus{border-color:var(--orange);background:var(--surface);}
.sub-text-input{width:100%;padding:8px 9px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.8rem;background:var(--surface-2);outline:none;margin-top:6px;}
.sub-text-input:focus{border-color:var(--orange);background:var(--surface);}
.save-all-btn{width:100%;padding:10px;background:var(--dark);color:white;border:none;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;margin-top:10px;font-family:var(--font-display);font-size:0.84rem;}
.settings-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:11px;border:1px solid var(--border-light);}
.settings-card-title{font-family:var(--font-display);font-weight:700;font-size:0.86rem;margin-bottom:10px;color:var(--text-2);}
.settings-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border-light);}
.settings-row:last-child{border-bottom:none;}
.settings-row-info{flex:1;}
.settings-row-label{font-weight:600;font-size:0.84rem;}
.settings-row-desc{font-size:0.72rem;color:var(--text-3);margin-top:1px;}
.toggle-switch{width:40px;height:22px;border-radius:11px;background:var(--border);cursor:pointer;position:relative;transition:background 0.2s;border:none;flex-shrink:0;margin-left:12px;}
.toggle-switch.on{background:var(--success);}
.toggle-switch::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:white;top:3px;left:3px;transition:left 0.2s;box-shadow:0 1px 4px rgba(0,0,0,.2);}
.toggle-switch.on::after{left:21px;}
.settings-input-row{display:flex;align-items:center;gap:9px;margin-top:8px;}
.settings-input{flex:1;padding:9px 11px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.88rem;background:var(--surface-2);outline:none;}
.settings-input:focus{border-color:var(--orange);background:var(--surface);}
.settings-save-btn{padding:9px 14px;background:var(--orange);color:white;border:none;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;font-size:0.78rem;white-space:nowrap;}
.admin-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);margin-bottom:14px;}

/* ===== AFFILIATE PORTAL ===== */
#affiliate-view{min-height:100vh;background:var(--cream);}
.aff-dashboard{display:none;}
.aff-dash-header{background:linear-gradient(150deg,#ff6500 0%,#c94200 60%,#9c3300 100%);padding:22px 20px;position:sticky;top:0;z-index:90;overflow:hidden;}
.aff-dash-header::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,196,34,.12) 0%,transparent 50%);pointer-events:none;}
.aff-dash-inner{position:relative;z-index:2;}
.aff-dash-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.aff-dash-logo{font-family:var(--font-display);font-weight:800;color:white;font-size:1.1rem;}
.aff-dash-logo span{color:var(--yellow);}
.aff-signout{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);color:white;padding:6px 12px;border-radius:20px;cursor:pointer;font-size:0.74rem;font-weight:600;}
.aff-welcome p{font-size:0.8rem;color:rgba(255,255,255,.8);margin-bottom:2px;}
.aff-welcome h2{font-family:var(--font-display);font-weight:800;font-size:1.45rem;color:white;}
.aff-stats-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:14px;}
.aff-stat-pill{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);padding:10px;text-align:center;}
.aff-pill-val{font-family:var(--font-display);font-weight:800;font-size:1.2rem;color:white;}
.aff-pill-lbl{font-size:0.65rem;color:rgba(255,255,255,.75);margin-top:1px;}
.aff-content{padding:18px;max-width:520px;margin:0 auto;padding-bottom:40px;}
.aff-section{margin-bottom:22px;}
.aff-section-title{font-family:var(--font-display);font-weight:700;font-size:0.92rem;margin-bottom:11px;color:var(--text);}
.aff-qr-card{background:var(--surface);border-radius:var(--radius-xl);padding:22px;box-shadow:var(--shadow-md);text-align:center;border:1px solid var(--border-light);}
.aff-qr-card h3{font-family:var(--font-display);font-weight:700;margin-bottom:5px;}
.aff-qr-card p{font-size:0.78rem;color:var(--text-3);margin-bottom:15px;line-height:1.55;}
.aff-code-display{background:var(--surface-2);border-radius:var(--radius-md);padding:10px 16px;display:inline-flex;align-items:center;gap:9px;margin-bottom:15px;border:1px solid var(--border);}
.aff-code-val{font-family:var(--font-display);font-weight:800;font-size:1.2rem;color:var(--orange);letter-spacing:1px;}
.copy-btn{background:var(--orange);color:white;border:none;padding:5px 12px;border-radius:var(--radius-sm);font-size:0.72rem;font-weight:700;cursor:pointer;}
.qr-container{display:flex;justify-content:center;margin:13px 0;}
.share-link-box{background:var(--surface-2);border-radius:var(--radius-sm);padding:8px 11px;font-size:0.7rem;color:var(--text-3);word-break:break-all;margin-top:9px;border:1px solid var(--border);}
.dl-qr-btn{background:var(--surface-2);border:1.5px solid var(--border);color:var(--text);padding:9px 18px;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;font-size:0.8rem;width:100%;margin-top:9px;}
.aff-orders-list{display:flex;flex-direction:column;gap:8px;}
.aff-order-row{background:var(--surface);border-radius:var(--radius-md);padding:11px 13px;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border-light);}
.aff-order-info{font-size:0.78rem;}
.aff-order-name{font-weight:600;}
.aff-order-date{color:var(--text-3);font-size:0.71rem;}
.aff-order-comm{font-weight:700;color:var(--success);font-size:0.86rem;font-family:var(--font-display);}
.empty-msg{color:var(--text-3);font-size:0.82rem;padding:10px 0;}

@media(max-width:380px){
  .hero h1{font-size:2rem;}
  .menu-day-grid{grid-template-columns:repeat(3,1fr);}
  .aff-stats-row{grid-template-columns:1fr 1fr;}
  .price-grid{grid-template-columns:1fr 1fr;}
  .food-grid-cards{grid-template-columns:repeat(2,1fr);}
}
@media(min-width:640px){
  .stats-grid{grid-template-columns:repeat(4,1fr);}
  .insights-grid{grid-template-columns:repeat(4,1fr);}
  .food-grid-cards{grid-template-columns:repeat(3,1fr);}
}

.delivery-banner{display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#ff8c00,#ffa500);color:#fff;padding:10px 16px;font-size:0.8rem;font-weight:600;text-align:center;line-height:1.35;z-index:59;flex-wrap:wrap;}
.delivery-banner .db-icon{font-size:1.1rem;flex-shrink:0;}
.delivery-banner .db-main{font-size:0.82rem;font-weight:700;}
.delivery-banner .db-sub{font-size:0.73rem;font-weight:500;opacity:.88;}
.delivery-info-row{display:flex;align-items:center;gap:8px;background:#fff7ed;border:1.5px solid #fed7aa;border-radius:10px;padding:10px 13px;margin:12px 0 4px;}
.delivery-info-row .di-icon{font-size:1.2rem;flex-shrink:0;}
.delivery-info-row .di-text{font-size:0.8rem;line-height:1.4;}
.delivery-info-row .di-date{font-weight:700;color:#c2410c;font-size:0.85rem;}
.delivery-info-row .di-note{color:var(--text-3);font-size:0.73rem;}
/* ===== CART FEE BREAKDOWN ===== */
.cart-fee-breakdown{padding:10px 0 0;}
.cart-fee-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:0.82rem;color:var(--text-2);}
.cart-fee-row .fee-val{font-weight:700;}
.cart-fee-row.fee-extra .fee-val{color:var(--orange);}
.cart-fee-row.fee-late .fee-val{color:#b91c1c;}
.cart-fee-divider{height:1px;background:var(--border);margin:8px 0;}
.cart-fee-total{display:flex;justify-content:space-between;align-items:center;padding-top:6px;font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:var(--dark);}
.cart-fee-total .fee-total-val{color:var(--orange);font-size:1.1rem;}
/* ===== CHECKOUT TOTAL BOX ===== */
.checkout-total-box{background:linear-gradient(135deg,var(--orange-dim),#fffbf5);border:1.5px solid #fbbf7a;border-radius:var(--radius-md);padding:11px 14px;margin:10px 0 14px;}
.ct-row{display:flex;justify-content:space-between;align-items:center;font-size:0.8rem;color:var(--text-2);margin-bottom:4px;}
.ct-row:last-child{margin-bottom:0;}
.ct-row span:last-child{font-weight:700;}
.ct-row.ct-late span:last-child{color:#b91c1c;}
.ct-row.ct-hostel span:last-child{color:var(--orange);}
.ct-divider{height:1px;background:rgba(255,100,0,.18);margin:7px 0;}
.ct-total-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display);font-weight:800;font-size:1rem;color:var(--dark);padding-top:2px;}
.ct-total-row span:last-child{color:var(--orange);font-size:1.05rem;}
/* ===== AFFILIATE EARNINGS BREAKDOWN ===== */
.aff-earn-breakdown{background:rgba(0,0,0,.15);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-md);padding:11px 14px;margin-top:12px;}
.ae-row{display:flex;justify-content:space-between;align-items:center;font-size:0.78rem;color:rgba(255,255,255,.75);margin-bottom:5px;}
.ae-row:last-child{margin-bottom:0;}
.ae-row .ae-val{font-weight:700;color:rgba(255,255,255,.95);}
.ae-divider{height:1px;background:rgba(255,255,255,.15);margin:7px 0;}
.ae-total-row{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display);font-weight:800;font-size:0.9rem;color:white;}
.ae-total-row .ae-total-val{color:#ffc422;font-size:0.96rem;}
/* ===== COOKIE NOTICE ===== */
.ref-cookie-notice{display:flex;align-items:center;gap:7px;background:var(--orange-dim);border:1.5px solid var(--orange);border-radius:var(--radius-sm);padding:7px 11px;font-size:0.75rem;color:var(--orange);font-weight:600;margin-bottom:10px;}
.ref-cookie-notice span{flex:1;}
.delivery-type-row{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:2px;}
.delivery-type-opt{border:2px solid var(--border);border-radius:var(--radius-md);padding:11px 10px;cursor:pointer;text-align:center;transition:all 0.2s;background:var(--surface-2);}
.delivery-type-opt.selected{border-color:var(--orange);background:var(--orange-dim);}
.dt-icon{font-size:1.5rem;margin-bottom:3px;}
.dt-name{font-family:var(--font-display);font-weight:700;font-size:0.82rem;}
.dt-fee{font-size:0.72rem;color:var(--text-3);margin-top:2px;}
.delivery-type-opt.selected .dt-fee{color:var(--orange);font-weight:700;}
/* ===== EDIT ITEM MODAL ===== */
.edit-modal-img-preview{width:100%;height:90px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:8px;display:block;}
/* ===== COMMISSION PAID BADGE ===== */
.comm-paid-badge{display:inline-flex;align-items:center;gap:4px;background:var(--success-dim);color:#166534;font-size:0.65rem;font-weight:700;padding:2px 8px;border-radius:10px;}
.comm-unpaid-badge{display:inline-flex;align-items:center;gap:4px;background:#fef9c3;color:#854d0e;font-size:0.65rem;font-weight:700;padding:2px 8px;border-radius:10px;}
.mark-paid-btn{background:var(--success-dim);border:1px solid #bbf7d0;color:#166534;padding:5px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:0.72rem;font-weight:700;white-space:nowrap;}
.mark-paid-btn.paid{background:var(--surface-3);border-color:var(--border);color:var(--text-3);}
/* ===== MARKETER SECTION ===== */
.marketer-section{margin-top:24px;}
.marketer-section-title{font-family:var(--font-display);font-weight:700;font-size:0.92rem;color:var(--text-2);margin-bottom:11px;display:flex;align-items:center;gap:7px;}
.marketer-card{background:var(--surface);border-radius:var(--radius-md);padding:12px 13px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);margin-bottom:8px;}
.marketer-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:7px;}
.marketer-name{font-family:var(--font-display);font-weight:700;font-size:0.86rem;}
.marketer-code{font-family:monospace;font-size:0.78rem;background:var(--surface-2);padding:2px 7px;border-radius:6px;color:var(--brown);display:inline-block;margin-top:2px;}
.marketer-parent{font-size:0.72rem;color:var(--text-3);margin-top:3px;}
.marketer-stats{display:flex;gap:10px;flex-wrap:wrap;margin-top:5px;}
.mkt-stat{font-size:0.75rem;color:var(--text-3);}
.mkt-stat strong{color:var(--text);font-weight:700;}
/* ===== ADMIN AFFILIATES TABS ===== */
.aff-admin-tabs{display:flex;gap:7px;margin-bottom:14px;}
.aff-admin-tab{flex:1;padding:8px 6px;text-align:center;font-weight:700;font-size:0.78rem;cursor:pointer;border-radius:var(--radius-sm);background:var(--surface-3);color:var(--text-3);transition:all 0.18s;border:1.5px solid transparent;font-family:var(--font-display);}
.aff-admin-tab.active{background:var(--orange-dim);color:var(--orange);border-color:var(--orange);}
.aff-admin-panel{display:none;}.aff-admin-panel.active{display:block;}
/* ===== AFF PORTAL MARKETERS ===== */
.aff-mkr-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-md);padding:13px 14px;margin-bottom:10px;}
.aff-mkr-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;}
.aff-mkr-name{font-weight:700;font-size:0.88rem;color:white;}
.aff-mkr-code-badge{display:inline-block;font-family:monospace;font-size:0.75rem;background:rgba(255,255,255,.15);padding:2px 8px;border-radius:6px;color:rgba(255,255,255,.9);margin-top:3px;}
.aff-mkr-stats-row{display:flex;gap:12px;flex-wrap:wrap;margin:8px 0 10px;}
.aff-mkr-stat{font-size:0.75rem;color:rgba(255,255,255,.7);}
.aff-mkr-stat strong{color:white;font-weight:700;}
.aff-mkr-link-row{display:flex;align-items:center;gap:7px;background:rgba(0,0,0,.2);border-radius:8px;padding:6px 10px;font-size:0.72rem;color:rgba(255,255,255,.6);word-break:break-all;cursor:pointer;}
.aff-mkr-copy-btn{flex-shrink:0;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);color:white;padding:4px 9px;border-radius:6px;font-size:0.7rem;font-weight:700;cursor:pointer;white-space:nowrap;}
.aff-mkr-qr-row{display:flex;justify-content:center;margin-top:10px;}
.aff-mkr-qr-wrap{display:flex;flex-direction:column;align-items:center;gap:5px;}
.aff-mkr-qr-label{font-size:0.68rem;color:rgba(255,255,255,.5);text-align:center;}
.order-success-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;}
.order-success-card{background:#fff;border-radius:20px;padding:32px 24px;text-align:center;max-width:340px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.25);animation:popIn .35s cubic-bezier(.34,1.56,.64,1);}
@keyframes popIn{from{transform:scale(.75);opacity:0}to{transform:scale(1);opacity:1}}
.osc-check{font-size:3.2rem;margin-bottom:8px;}
.osc-title{font-family:var(--font-display);font-weight:800;font-size:1.3rem;margin-bottom:4px;color:var(--dark);}
.osc-sub{font-size:0.83rem;color:var(--text-2);margin-bottom:18px;}
.osc-delivery-box{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1.5px solid #fed7aa;border-radius:12px;padding:14px 16px;margin-bottom:16px;text-align:left;}
.osc-delivery-label{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#9a3412;margin-bottom:6px;}
.osc-delivery-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;}
.osc-delivery-row:last-child{margin-bottom:0;}
.osc-delivery-row span:first-child{font-size:1rem;}
.osc-delivery-row span:last-child{font-size:0.84rem;font-weight:600;color:var(--dark);}
.osc-note{font-size:0.75rem;color:var(--text-3);margin-bottom:18px;}
.osc-btn{width:100%;padding:13px;background:var(--orange);color:#fff;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.92rem;cursor:pointer;}


/* ===== SAME DAY DELIVERY SECTION ===== */
.sds-wrap{background:linear-gradient(135deg,#065f46,#047857);border-radius:0 0 var(--radius-lg) var(--radius-lg);padding:16px 16px 20px;margin-bottom:0;}
.sds-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.sds-heading{display:flex;align-items:center;gap:8px;}
.sds-badge{background:#10b981;color:white;font-size:0.62rem;font-weight:800;padding:3px 8px;border-radius:20px;letter-spacing:0.5px;text-transform:uppercase;animation:pulse-sds 1.8s ease-in-out infinite;}
@keyframes pulse-sds{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(16,185,129,.5);}50%{opacity:.9;box-shadow:0 0 0 6px rgba(16,185,129,0);}}
.sds-title{font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:white;}
.sds-cutoff-wrap{display:flex;flex-direction:column;align-items:flex-end;}
.sds-cutoff-label{font-size:0.6rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:0.4px;}
.sds-cutoff-timer{font-family:var(--font-display);font-weight:800;font-size:0.95rem;color:#6ee7b7;letter-spacing:0.3px;}
.sds-cutoff-timer.urgent{color:#fbbf24;animation:pulse-bg 1s ease-in-out infinite;}
.sds-delivery-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);font-size:0.72rem;font-weight:600;padding:4px 10px;border-radius:20px;margin-bottom:10px;}
.sds-view-toggle{display:flex;background:rgba(0,0,0,.2);border-radius:10px;padding:3px;gap:2px;}
.sds-vt-btn{width:30px;height:26px;border-radius:7px;border:none;background:transparent;color:rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.18s;font-size:0.9rem;}
.sds-vt-btn.active{background:rgba(255,255,255,.18);color:white;}
.sds-foods{margin-top:4px;}
.sds-empty{text-align:center;padding:20px;color:rgba(255,255,255,.55);font-size:0.84rem;}
.sds-food-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;}
.sds-food-list{display:flex;flex-direction:column;gap:8px;}
/* Same-day food card (list) */
.sds-card{background:rgba(255,255,255,.1);border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;border:1px solid rgba(255,255,255,.12);transition:all 0.2s;}
.sds-card:active{transform:scale(.99);}
.sds-card-img{width:82px;height:74px;object-fit:cover;flex-shrink:0;}
.sds-card-body{padding:9px 10px;flex:1;min-width:0;}
.sds-card-name{font-family:var(--font-display);font-weight:700;font-size:0.84rem;color:white;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sds-card-desc{font-size:0.7rem;color:rgba(255,255,255,.6);margin:2px 0 4px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.sds-card-price{font-weight:700;color:#6ee7b7;font-size:0.86rem;font-family:var(--font-display);}
.sds-add-btn{width:30px;height:30px;border-radius:50%;background:#10b981;color:white;border:none;font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-right:9px;flex-shrink:0;transition:all 0.18s;box-shadow:0 2px 8px rgba(16,185,129,.4);}
.sds-add-btn.added{background:#065f46;}
/* Same-day food card (grid) */
.sds-card-sq{background:rgba(255,255,255,.1);border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(255,255,255,.12);transition:all 0.2s;position:relative;}
.sds-card-sq:active{transform:scale(.98);}
.sds-card-sq-img{width:100%;height:114px;object-fit:cover;}
.sds-card-sq-body{padding:8px 9px 9px;}
.sds-card-sq-name{font-family:var(--font-display);font-weight:700;font-size:0.8rem;color:white;line-height:1.25;margin-bottom:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.sds-card-sq-desc{font-size:0.68rem;color:rgba(255,255,255,.5);margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.sds-card-sq-footer{display:flex;align-items:center;justify-content:space-between;margin-top:5px;}
.sds-card-sq-price{font-weight:700;color:#6ee7b7;font-size:0.82rem;font-family:var(--font-display);}
.sds-add-btn-sq{width:26px;height:26px;border-radius:50%;background:#10b981;color:white;border:none;font-size:0.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.18s;box-shadow:0 2px 8px rgba(16,185,129,.4);}
.sds-add-btn-sq.added{background:#065f46;}
/* Preorder section header */
.preorder-header{display:flex;align-items:center;gap:8px;padding:16px 0 2px;}
.preorder-label{font-family:var(--font-display);font-weight:800;font-size:0.78rem;color:var(--text-3);text-transform:uppercase;letter-spacing:0.6px;}
.preorder-divider{flex:1;height:1px;background:var(--border-light);}
/* Cart delivery group headers */
.cart-delivery-group{margin-bottom:12px;}
.cart-group-header{display:flex;align-items:center;gap:7px;padding:7px 10px;border-radius:var(--radius-sm);margin-bottom:6px;font-size:0.77rem;font-weight:700;}
.cart-group-sameday{background:#d1fae5;color:#065f46;}
.cart-group-preorder{background:var(--orange-dim);color:#9a3412;}


/* ===== USER ACCOUNT VIEW ===== */
.user-auth-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:32px 24px;background:var(--cream);}
.user-auth-logo{font-family:var(--font-display);font-weight:800;font-size:1.6rem;color:var(--orange);margin-bottom:6px;}
.user-auth-sub{font-size:0.82rem;color:var(--text-3);margin-bottom:28px;text-align:center;}
.user-auth-card{background:var(--surface);border-radius:var(--radius-xl);padding:26px 22px;box-shadow:var(--shadow-lg);width:100%;max-width:400px;}
.user-auth-tabs{display:flex;background:var(--surface-3);border-radius:10px;padding:3px;gap:2px;margin-bottom:20px;}
.user-auth-tab{flex:1;padding:9px 6px;text-align:center;border-radius:8px;font-weight:700;font-size:0.8rem;cursor:pointer;color:var(--text-3);transition:all 0.2s;font-family:var(--font-display);}
.user-auth-tab.active{background:var(--surface);color:var(--orange);box-shadow:var(--shadow-sm);}

/* User Dashboard */
.user-dashboard{max-width:520px;margin:0 auto;padding-bottom:40px;}
.user-dash-header{background:linear-gradient(135deg,#1e1006,#3a2810);padding:28px 20px 32px;position:relative;overflow:hidden;}
.user-dash-header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:28px;background:var(--cream);border-radius:28px 28px 0 0;}
.user-dash-header::before{content:'🍳';position:absolute;right:20px;top:18px;font-size:3rem;opacity:0.15;}
.udh-greeting{font-size:0.78rem;color:rgba(255,255,255,.55);margin-bottom:3px;}
.udh-name{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:white;margin-bottom:14px;}
.udh-plan-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,165,0,.18);border:1px solid rgba(255,165,0,.35);color:#ffc422;font-size:0.74rem;font-weight:700;padding:5px 12px;border-radius:20px;margin-bottom:8px;}
.udh-plan-pill.expired{background:rgba(220,38,38,.18);border-color:rgba(220,38,38,.35);color:#fca5a5;}
.udh-plan-pill.vip{background:rgba(124,58,237,.2);border-color:rgba(124,58,237,.4);color:#c4b5fd;}
.user-dash-body{padding:0 16px 100px;}
/* Plan card */
.plan-status-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-md);border:1.5px solid var(--border-light);margin-bottom:14px;margin-top:16px;}
.psc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;}
.psc-info{}
.psc-plan-name{font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:var(--text);margin-bottom:2px;}
.psc-meal{font-size:0.76rem;color:var(--text-3);}
.psc-right{text-align:right;}
.psc-days{font-family:var(--font-display);font-weight:800;font-size:2rem;color:var(--orange);line-height:1;}
.psc-days-label{font-size:0.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:0.4px;}
.psc-days.expired{color:var(--danger);}
.psc-progress-wrap{margin-bottom:14px;}
.psc-progress-bar{height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden;}
.psc-progress-fill{height:100%;background:var(--orange);border-radius:3px;transition:width 0.5s;}
.psc-progress-fill.expired{background:var(--danger);}
.psc-progress-label{font-size:0.7rem;color:var(--text-3);margin-top:4px;}
.psc-actions{display:flex;gap:9px;flex-wrap:wrap;}
.psc-btn{flex:1;min-width:120px;padding:11px 14px;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.82rem;cursor:pointer;transition:all 0.2s;text-align:center;border:none;}
.psc-btn-upgrade{background:var(--purple);color:white;box-shadow:0 4px 14px rgba(124,58,237,.3);}
.psc-btn-upgrade:hover{transform:translateY(-1px);}
.psc-btn-resub{background:var(--orange);color:white;box-shadow:var(--shadow-orange);width:100%;}
.psc-btn-signout{background:var(--surface-3);color:var(--text-2);border:1.5px solid var(--border);}
/* Meal selection */
.meal-select-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);border:1.5px solid var(--border-light);margin-bottom:14px;}
.msc-title{font-family:var(--font-display);font-weight:700;font-size:0.92rem;margin-bottom:4px;display:flex;align-items:center;gap:7px;}
.msc-sub{font-size:0.75rem;color:var(--text-3);margin-bottom:12px;}
.msc-section-label{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-3);margin-bottom:7px;margin-top:10px;}
.msc-food-row{display:flex;flex-direction:column;gap:7px;}
.msc-food-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--radius-sm);border:1.5px solid var(--border-light);background:var(--surface-2);cursor:pointer;transition:all 0.18s;}
.msc-food-item.selected{border-color:var(--orange);background:var(--orange-dim);}
.msc-food-item.selected-green{border-color:#10b981;background:#d1fae5;}
.msc-food-img{width:40px;height:40px;border-radius:8px;object-fit:cover;flex-shrink:0;}
.msc-food-info{flex:1;min-width:0;}
.msc-food-name{font-weight:700;font-size:0.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.msc-food-price{font-size:0.72rem;color:var(--orange);font-weight:700;font-family:var(--font-display);}
.msc-food-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.7rem;transition:all 0.18s;}
.msc-food-item.selected .msc-food-check,.msc-food-item.selected-green .msc-food-check{background:var(--orange);border-color:var(--orange);color:white;}
.msc-food-item.selected-green .msc-food-check{background:#10b981;border-color:#10b981;}
.msc-save-btn{width:100%;padding:12px;background:var(--orange);color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.88rem;cursor:pointer;margin-top:12px;transition:all 0.2s;}
.msc-none-msg{font-size:0.78rem;color:var(--text-3);text-align:center;padding:14px;background:var(--surface-3);border-radius:var(--radius-sm);}
/* VIP badge in admin */
.vip-badge{display:inline-flex;align-items:center;gap:4px;background:var(--purple-dim);color:var(--purple);font-size:0.62rem;font-weight:800;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:0.4px;}
.vip-order-card{background:var(--surface);border-radius:var(--radius-md);padding:13px 14px;border:1.5px solid var(--purple);box-shadow:0 2px 12px rgba(124,58,237,.12);margin-bottom:9px;}
.voc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;}
.voc-name{font-family:var(--font-display);font-weight:700;font-size:0.9rem;}
.voc-plan{font-size:0.72rem;color:var(--text-3);margin-top:1px;}
.voc-items{display:flex;flex-direction:column;gap:5px;margin-bottom:8px;}
.voc-item{display:flex;align-items:center;gap:8px;font-size:0.78rem;}
.voc-item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.voc-item-dot.breakfast{background:#c44d00;}
.voc-item-dot.lunch{background:#166534;}
.voc-item-dot.sameday{background:#10b981;}
.voc-delivery{font-size:0.72rem;color:var(--text-3);display:flex;align-items:center;gap:5px;}


/* ===== UNIFIED LOGIN VIEW ===== */
.login-view-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 20px;background:linear-gradient(150deg,#ff6500 0%,#c94200 55%,#9c3300 100%);}
.login-view-wrap::before{content:'';position:fixed;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,196,34,.12) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.06) 0%,transparent 40%);pointer-events:none;}
.login-card{background:white;border-radius:var(--radius-xl);padding:28px 24px;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.25);position:relative;z-index:2;}
.login-logo{font-family:var(--font-display);font-weight:800;font-size:1.55rem;text-align:center;margin-bottom:4px;color:var(--dark);}
.login-logo span{color:var(--orange);}
.login-tagline{text-align:center;font-size:0.78rem;color:var(--text-3);margin-bottom:22px;}
.login-role-tabs{display:flex;background:var(--surface-3);border-radius:10px;padding:3px;gap:2px;margin-bottom:20px;}
.login-role-tab{flex:1;padding:8px 4px;text-align:center;border-radius:8px;font-weight:700;font-size:0.72rem;cursor:pointer;color:var(--text-3);transition:all 0.2s;font-family:var(--font-display);}
.login-role-tab.active{background:white;color:var(--orange);box-shadow:var(--shadow-sm);}
.login-form{display:none;}.login-form.active{display:block;}
.login-back{display:block;text-align:center;margin-top:14px;font-size:0.78rem;color:rgba(255,255,255,.75);cursor:pointer;text-decoration:none;}
.login-back:hover{color:white;}
/* Rider View */
.rider-view-wrap{min-height:100vh;background:var(--cream);}
.rider-header{background:linear-gradient(135deg,#1a3a1a,#2d5a2d);padding:24px 18px 28px;position:relative;}
.rider-header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:22px;background:var(--cream);border-radius:22px 22px 0 0;}
.rider-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.rider-logo{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:white;}
.rider-logo span{color:#6ee7b7;}
.rider-signout-btn{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);color:white;padding:6px 13px;border-radius:20px;font-size:0.75rem;font-weight:700;cursor:pointer;}
.rider-welcome{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:white;}
.rider-sub{font-size:0.75rem;color:rgba(255,255,255,.6);margin-top:2px;}
.rider-body{padding:16px 16px 60px;}
.scan-card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-md);border:1.5px solid var(--border-light);margin-bottom:14px;}
.scan-card-title{font-family:var(--font-display);font-weight:800;font-size:1rem;margin-bottom:4px;}
.scan-card-sub{font-size:0.76rem;color:var(--text-3);margin-bottom:14px;}
.scan-input-row{display:flex;gap:8px;}
.scan-input{flex:1;padding:13px 14px;border:2px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:1px;text-align:center;outline:none;transition:all 0.18s;}
.scan-input:focus{border-color:var(--success);box-shadow:0 0 0 3px rgba(22,163,74,.12);}
.scan-submit-btn{padding:13px 18px;background:var(--success);color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.9rem;cursor:pointer;transition:all 0.2s;white-space:nowrap;}
.scan-submit-btn:hover{transform:translateY(-1px);}
.scan-result{padding:14px;border-radius:var(--radius-md);margin-top:12px;font-size:0.84rem;}
.scan-result.success{background:var(--success-dim);color:#14532d;border:1px solid #bbf7d0;}
.scan-result.error{background:var(--danger-dim);color:#7f1d1d;border:1px solid #fecaca;}
.rider-stats-row{display:flex;gap:10px;margin-bottom:14px;}
.rider-stat-pill{flex:1;background:var(--surface);border-radius:var(--radius-md);padding:14px;text-align:center;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);}
.rsp-val{font-family:var(--font-display);font-weight:800;font-size:1.6rem;color:#2d5a2d;}
.rsp-lbl{font-size:0.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:0.4px;margin-top:2px;}
.rider-delivery-list{display:flex;flex-direction:column;gap:8px;}
.rider-delivery-item{background:var(--surface);border-radius:var(--radius-md);padding:12px 13px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);}
/* Order tracking in user dashboard */
.order-track-card{background:var(--surface);border-radius:var(--radius-md);padding:13px 14px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);margin-bottom:10px;}
.otc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;}
.otc-ref{font-family:var(--font-display);font-weight:700;font-size:0.86rem;}
.otc-status{font-size:0.68rem;font-weight:700;padding:3px 9px;border-radius:10px;text-transform:uppercase;letter-spacing:0.3px;}
.otc-status.paid{background:var(--blue-dim);color:var(--blue);}
.otc-status.delivered{background:var(--success-dim);color:#166534;}
.otc-code-box{background:var(--surface-3);border-radius:8px;padding:8px 12px;text-align:center;margin:8px 0;overflow:hidden;}
.otc-code{font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:var(--orange);letter-spacing:3px;word-break:break-all;overflow-wrap:anywhere;white-space:normal;}
.otc-code-label{font-size:0.65rem;color:var(--text-3);text-transform:uppercase;letter-spacing:0.5px;margin-top:2px;}
.otc-delivery-info{font-size:0.73rem;color:var(--text-3);}
/* Profile edit section */
.profile-card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);border:1.5px solid var(--border-light);margin-bottom:14px;}
.profile-card-title{font-family:var(--font-display);font-weight:700;font-size:0.92rem;margin-bottom:12px;display:flex;align-items:center;gap:7px;}



/* ===== RIDER TABS ===== */
.rider-tabs{display:flex;background:#111e11;border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:80;}
.rider-tab{flex:1;padding:12px 6px;text-align:center;font-family:var(--font-display);font-weight:700;font-size:0.75rem;color:rgba(255,255,255,.4);cursor:pointer;border-bottom:2.5px solid transparent;transition:all 0.2s;letter-spacing:0.2px;}
.rider-tab.active{color:#6ee7b7;border-bottom-color:#10b981;}
.rider-tab-panel{display:none;padding:14px 14px 80px;background:#0f1a0f;min-height:60vh;}
.rider-tab-panel.active{display:block;}
/* Pickup order card */
.pickup-card{background:#1a2e1a;border-radius:var(--radius-md);padding:14px;margin-bottom:10px;border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:all 0.18s;position:relative;}
.pickup-card:active{transform:scale(.99);}
.pickup-card.assigned{border-color:rgba(251,191,36,.35);background:#1e2a16;}
.pickup-card.mine{border-color:rgba(16,185,129,.35);}
.pc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;}
.pc-num{font-family:var(--font-display);font-weight:800;font-size:1rem;color:white;}
.pc-badge{font-size:0.62rem;font-weight:700;padding:3px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:0.3px;}
.pc-badge.assigned-me{background:rgba(16,185,129,.2);color:#6ee7b7;}
.pc-badge.assigned-other{background:rgba(251,191,36,.2);color:#fbbf24;}
.pc-badge.unassigned{background:rgba(255,255,255,.1);color:rgba(255,255,255,.5);}
.pc-addr{font-size:0.76rem;color:rgba(255,255,255,.55);margin-bottom:8px;display:flex;align-items:center;gap:5px;}
.pc-items{font-size:0.73rem;color:rgba(255,255,255,.4);margin-bottom:10px;line-height:1.45;}
.pc-actions{display:flex;gap:8px;}
.pc-pickup-btn{flex:1;padding:10px;background:#10b981;color:white;border:none;border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:700;font-size:0.82rem;cursor:pointer;transition:all 0.18s;}
.pc-pickup-btn:active{transform:scale(.97);}
.pc-pickup-btn.onway{background:#2563eb;}
.pc-detail-btn{padding:10px 14px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);border:none;border-radius:var(--radius-sm);font-size:0.78rem;font-weight:700;cursor:pointer;}
/* Delivered card */
.delivered-card{background:#1a2e1a;border-radius:var(--radius-md);padding:12px 14px;margin-bottom:8px;border:1px solid rgba(16,185,129,.2);display:flex;align-items:center;gap:11px;}
.dc-check{width:32px;height:32px;border-radius:50%;background:rgba(16,185,129,.2);border:2px solid rgba(16,185,129,.4);display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0;}
.dc-info{flex:1;min-width:0;}
.dc-name{font-family:var(--font-display);font-weight:700;font-size:0.86rem;color:white;}
.dc-addr{font-size:0.72rem;color:rgba(255,255,255,.4);margin-top:1px;}
.dc-earn{font-family:var(--font-display);font-weight:800;font-size:0.88rem;color:#fbbf24;flex-shrink:0;}
/* Order detail modal (rider) */
.rorder-modal{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:400;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.25s;}
.rorder-modal.open{opacity:1;pointer-events:all;}
.rorder-modal-inner{background:#1a2e1a;border-radius:24px 24px 0 0;width:100%;max-width:520px;padding:20px 20px 36px;transform:translateY(40px);transition:transform 0.3s cubic-bezier(.34,1.56,.64,1);max-height:88vh;overflow-y:auto;}
.rorder-modal.open .rorder-modal-inner{transform:translateY(0);}
.rom-handle{width:36px;height:4px;background:rgba(255,255,255,.15);border-radius:2px;margin:0 auto 16px;}
.rom-num{font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:white;margin-bottom:4px;}
.rom-status{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;font-size:0.72rem;font-weight:700;margin-bottom:14px;}
.rom-status.paid{background:rgba(37,99,235,.2);color:#93c5fd;}
.rom-status.onway{background:rgba(16,185,129,.2);color:#6ee7b7;}
.rom-status.delivered{background:rgba(16,185,129,.3);color:#6ee7b7;}
.rom-section{margin-bottom:14px;}
.rom-label{font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:rgba(255,255,255,.35);margin-bottom:7px;}
.rom-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(255,255,255,.05);border-radius:8px;margin-bottom:5px;}
.rom-row-icon{font-size:1rem;flex-shrink:0;}
.rom-row-text{font-size:0.82rem;color:rgba(255,255,255,.8);font-weight:500;}
.rom-item{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;background:rgba(255,255,255,.04);border-radius:8px;margin-bottom:4px;}
.rom-item-name{font-size:0.82rem;color:rgba(255,255,255,.8);}
.rom-item-qty{font-family:var(--font-display);font-weight:700;font-size:0.78rem;color:#6ee7b7;}
.rom-pickup-btn{width:100%;padding:13px;background:#10b981;color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.92rem;cursor:pointer;margin-top:6px;}
.rom-pickup-btn.onway{background:#2563eb;}
.rom-close-btn{width:100%;padding:11px;background:transparent;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.45);border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;margin-top:8px;cursor:pointer;}
/* Admin order assign */
.order-assign-row{display:flex;align-items:center;gap:8px;margin-top:7px;padding-top:7px;border-top:1px solid var(--border-light);}
.order-assign-select{flex:1;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:0.78rem;background:var(--surface-2);color:var(--text);outline:none;}
.order-assign-btn{padding:7px 12px;background:var(--dark);color:white;border:none;border-radius:var(--radius-sm);font-size:0.75rem;font-weight:700;cursor:pointer;white-space:nowrap;}
/* Scan tab empty state */
.scan-empty{text-align:center;padding:28px 16px;color:rgba(255,255,255,.3);font-size:0.82rem;}



/* ===== WALLET SYSTEM ===== */
.wallet-card{background:linear-gradient(135deg,#1e1006,#3a2810);border-radius:var(--radius-lg);padding:20px;margin-bottom:14px;position:relative;overflow:hidden;}
.wallet-card::before{content:'💳';position:absolute;right:16px;top:12px;font-size:2.8rem;opacity:0.12;}
.wc-label{font-size:0.72rem;color:rgba(255,255,255,.5);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:4px;}
.wc-balance{font-family:var(--font-display);font-weight:800;font-size:2.2rem;color:#ffc422;line-height:1;}
.wc-bal-sub{font-size:0.73rem;color:rgba(255,255,255,.45);margin-top:4px;}
.wc-actions{display:flex;gap:9px;margin-top:14px;}
.wc-btn{flex:1;padding:10px 8px;border-radius:var(--radius-sm);border:none;font-family:var(--font-display);font-weight:700;font-size:0.8rem;cursor:pointer;transition:all 0.18s;}
.wc-btn-topup{background:var(--orange);color:white;box-shadow:0 3px 12px rgba(255,101,0,.35);}
.wc-btn-topup:active{transform:scale(.97);}
.wc-btn-history{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.8);}
/* Pay with wallet row in checkout */
.wallet-pay-row{background:linear-gradient(135deg,#fdfaf5,#fff8f0);border:2px solid var(--border);border-radius:var(--radius-md);padding:13px 15px;margin-top:10px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all 0.2s;}
.wallet-pay-row.selected{background:linear-gradient(135deg,#fff3ed,#ffe8d6);}
.wpr-left{display:flex;align-items:center;gap:10px;}
.wpr-icon{font-size:1.4rem;}
.wpr-info{}
.wpr-title{font-family:var(--font-display);font-weight:700;font-size:0.88rem;color:var(--text);}
.wpr-bal{font-size:0.74rem;color:var(--text-3);}
.wpr-bal.enough{color:var(--success);font-weight:600;}
.wpr-bal.low{color:var(--danger);font-weight:600;}
.wpr-radio{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.18s;}
.wallet-pay-row.selected .wpr-radio{background:var(--orange);border-color:var(--orange);}
.wallet-pay-row.selected .wpr-radio::after{content:'';width:8px;height:8px;border-radius:50%;background:white;display:block;}
/* Top-up modal */
.topup-amounts{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0;}
.topup-amt{padding:11px 6px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;text-align:center;font-family:var(--font-display);font-weight:700;font-size:0.9rem;color:var(--text);transition:all 0.18s;}
.topup-amt.selected{border-color:var(--orange);background:var(--orange-dim);color:var(--orange);}
/* Wallet history */
.wallet-tx{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light);}
.wallet-tx:last-child{border-bottom:none;}
.wtx-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0;}
.wtx-icon.credit{background:var(--success-dim);}
.wtx-icon.debit{background:var(--danger-dim);}
.wtx-info{flex:1;min-width:0;}
.wtx-desc{font-weight:600;font-size:0.84rem;}
.wtx-date{font-size:0.7rem;color:var(--text-3);margin-top:1px;}
.wtx-amt{font-family:var(--font-display);font-weight:800;font-size:0.9rem;}
.wtx-amt.credit{color:var(--success);}
.wtx-amt.debit{color:var(--danger);}
/* Admin wallet panel */
.wallet-admin-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border-light);}
.wallet-admin-row:last-child{border-bottom:none;}


/* ===== PUSH NOTIFICATIONS ===== */
.notif-permission-banner{background:linear-gradient(135deg,#ff6500,#c94200);color:white;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;z-index:55;}
.notif-banner-text{font-size:0.8rem;font-weight:600;flex:1;}
.notif-allow-btn{background:white;color:var(--orange);border:none;padding:7px 14px;border-radius:20px;font-weight:700;font-size:0.76rem;cursor:pointer;flex-shrink:0;}
.notif-dismiss-btn{background:none;border:none;color:rgba(255,255,255,.6);font-size:1.1rem;cursor:pointer;padding:2px;flex-shrink:0;}
/* Admin push panel */
.push-composer{background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-md);border:1px solid var(--border-light);margin-bottom:14px;}
.push-composer-title{font-family:var(--font-display);font-weight:700;font-size:0.92rem;margin-bottom:12px;}
.push-preset-row{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px;}
.push-preset{padding:6px 12px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface-2);cursor:pointer;font-size:0.75rem;font-weight:600;color:var(--text-2);transition:all 0.18s;white-space:nowrap;}
.push-preset:hover,.push-preset.active{border-color:var(--orange);background:var(--orange-dim);color:var(--orange);}
.push-history-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light);}
.push-history-item:last-child{border-bottom:none;}
.phi-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px;}
.phi-body{flex:1;min-width:0;}
.phi-title{font-weight:700;font-size:0.84rem;}
.phi-body-text{font-size:0.74rem;color:var(--text-3);margin-top:1px;}
.phi-time{font-size:0.7rem;color:var(--text-3);flex-shrink:0;}

/* ===== ADMIN MOBILE FIXES ===== */
/* Settings rows that have input+button pairs: stack on small screens */
@media(max-width:480px){
  .settings-row{flex-wrap:wrap;gap:8px;}
  .settings-row-info{flex:1 1 100%;}
  .settings-row > div:last-child{width:100%;display:flex;gap:7px;}
  .settings-row > div:last-child input.settings-input{flex:1;}
  .settings-input-row{flex-wrap:wrap;}
  .settings-input-row input.settings-input{flex:1;min-width:0;}
  /* Admin header: tighten text */
  #adminCurrentTab{display:none;}
  /* Stats grid: always 2 col on mobile */
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .insights-grid{grid-template-columns:repeat(2,1fr);}
  /* Form rows: stack on mobile */
  .form-row{grid-template-columns:1fr;}
  /* Price grid 3→2 on tiny */
  .price-grid{grid-template-columns:1fr 1fr;}
  /* Affiliate stats: wrap */
  .affiliate-stats{flex-wrap:wrap;gap:8px;}
  /* Rider admin card */
  .affiliate-card-top{flex-wrap:wrap;gap:8px;}
  /* Order card */
  .order-card-top{flex-wrap:wrap;gap:4px;}
  .order-assign-row{flex-wrap:wrap;}
  .order-assign-select{min-width:0;flex:1;}
  /* Aff admin tabs */
  .aff-admin-tabs{flex-wrap:wrap;}
  /* Admin signout buttons in header */
  .admin-signout{padding:5px 8px;font-size:0.7rem;}
  /* Marketer card */
  .marketer-stats{gap:7px;}
  .marketer-card-top > div:last-child{flex-wrap:wrap;gap:5px;}
}
/* PWA: always prevent text size adjustment + pull-to-refresh */
html,body{touch-action:pan-x pan-y;overscroll-behavior-y:none;-ms-scroll-chaining:none;}
body{-webkit-text-size-adjust:100%;text-size-adjust:100%;}
/* Prevent double-tap zoom on buttons and interactive elements */
button,a,.cust-tab,.day-btn,.food-card,.food-card-sq,.plan-card,.rider-tab,.pickup-card{touch-action:manipulation;}

/* ===== RIDER REDESIGN ===== */
.rider-view-wrap{min-height:100vh;background:#0f1a0f;}
.rider-header{background:linear-gradient(160deg,#0d2b0d 0%,#1a4a1a 100%);padding:20px 18px 36px;position:sticky;top:0;z-index:90;}
.rider-header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:28px;background:#0f1a0f;border-radius:28px 28px 0 0;}
.rider-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.rider-logo{font-family:var(--font-display);font-weight:800;font-size:1.15rem;color:white;letter-spacing:-0.5px;}
.rider-logo span{color:#6ee7b7;}
.rider-header-actions{display:flex;gap:8px;align-items:center;}
.rider-signout-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.8);padding:7px 14px;border-radius:20px;font-size:0.75rem;font-weight:700;cursor:pointer;transition:all 0.18s;}
.rider-profile-btn{background:rgba(110,231,183,.15);border:1px solid rgba(110,231,183,.3);color:#6ee7b7;padding:7px 14px;border-radius:20px;font-size:0.75rem;font-weight:700;cursor:pointer;}
.rider-identity{display:flex;align-items:center;gap:12px;}
.rider-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;color:white;font-family:var(--font-display);flex-shrink:0;}
.rider-welcome{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:white;line-height:1.1;}
.rider-status-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(16,185,129,.2);border:1px solid rgba(16,185,129,.35);color:#6ee7b7;font-size:0.7rem;font-weight:700;padding:3px 10px;border-radius:20px;margin-top:5px;}
.rider-status-dot{width:6px;height:6px;border-radius:50%;background:#10b981;animation:pulse-green 1.5s ease-in-out infinite;}
@keyframes pulse-green{0%,100%{opacity:1;}50%{opacity:.4;}}
.rider-body{padding:16px 16px 80px;background:#0f1a0f;}
/* Stats grid */
.rider-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;}
.rsg-card{background:#1a2e1a;border-radius:var(--radius-md);padding:13px 10px;text-align:center;border:1px solid rgba(255,255,255,.07);}
.rsg-val{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:#6ee7b7;line-height:1;}
.rsg-lbl{font-size:0.62rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:0.5px;margin-top:3px;}
.rsg-card.earnings .rsg-val{color:#fbbf24;}
/* QR Scanner */
.qr-scan-card{background:#1a2e1a;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:14px;border:1px solid rgba(255,255,255,.08);}
.qr-scan-header{padding:14px 16px 0;display:flex;align-items:center;justify-content:space-between;}
.qr-scan-title{font-family:var(--font-display);font-weight:800;font-size:0.95rem;color:white;}
.qr-mode-toggle{display:flex;background:rgba(0,0,0,.3);border-radius:8px;padding:2px;gap:2px;}
.qr-mode-btn{padding:5px 11px;border-radius:6px;border:none;background:transparent;color:rgba(255,255,255,.45);font-size:0.72rem;font-weight:700;cursor:pointer;transition:all 0.18s;}
.qr-mode-btn.active{background:rgba(16,185,129,.25);color:#6ee7b7;}
.qr-video-wrap{position:relative;width:100%;background:#000;overflow:hidden;}
.qr-scan-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.qr-scan-frame{width:180px;height:180px;position:relative;}
.qr-scan-frame::before,.qr-scan-frame::after{content:'';position:absolute;width:36px;height:36px;border-color:#10b981;border-style:solid;border-width:0;}
.qr-scan-frame::before{top:0;left:0;border-top-width:3px;border-left-width:3px;border-radius:4px 0 0 0;}
.qr-scan-frame::after{bottom:0;right:0;border-bottom-width:3px;border-right-width:3px;border-radius:0 0 4px 0;}
.qr-scan-frame-br{position:absolute;bottom:0;left:0;width:36px;height:36px;border-bottom:3px solid #10b981;border-left:3px solid #10b981;border-radius:0 0 0 4px;}
.qr-scan-frame-tl{position:absolute;top:0;right:0;width:36px;height:36px;border-top:3px solid #10b981;border-right:3px solid #10b981;border-radius:0 4px 0 0;}
.qr-scan-line{position:absolute;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,#10b981,transparent);animation:scan-line 2s ease-in-out infinite;}
@keyframes scan-line{0%{top:10%;}100%{top:90%;}}
.qr-scan-status{padding:10px 16px;font-size:0.76rem;color:rgba(255,255,255,.55);text-align:center;background:#111e11;}
.qr-scan-status.scanning{color:#6ee7b7;}
.qr-scan-status.success{background:#0d2a1a;color:#6ee7b7;font-weight:700;}
.qr-scan-status.error{background:#2a0d0d;color:#fca5a5;font-weight:700;}
/* Manual code entry */
.qr-manual-wrap{padding:14px 16px;}
.scan-input-dark{width:100%;padding:14px;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-md);background:#111e11;color:white;font-family:var(--font-display);font-weight:800;font-size:1.3rem;text-transform:uppercase;letter-spacing:3px;text-align:center;outline:none;transition:all 0.18s;}
.scan-input-dark:focus{border-color:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,.15);}
.scan-input-dark::placeholder{color:rgba(255,255,255,.2);font-size:0.9rem;letter-spacing:1px;}
.scan-submit-dark{width:100%;padding:13px;background:#10b981;color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.92rem;cursor:pointer;margin-top:10px;transition:all 0.2s;}
.scan-submit-dark:active{transform:scale(.98);}
/* Delivery list */
.rider-section-label{font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:rgba(255,255,255,.35);margin-bottom:8px;padding:0 2px;}
.rider-order-item{background:#1a2e1a;border-radius:var(--radius-md);padding:13px 14px;margin-bottom:8px;border:1px solid rgba(255,255,255,.07);display:flex;align-items:flex-start;gap:11px;}
.roi-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px;}
.roi-dot.delivered{background:#10b981;}
.roi-dot.pending{background:#fbbf24;animation:pulse-green 1.2s ease-in-out infinite;}
.roi-info{flex:1;min-width:0;}
.roi-name{font-family:var(--font-display);font-weight:700;font-size:0.88rem;color:white;}
.roi-addr{font-size:0.72rem;color:rgba(255,255,255,.45);margin-top:1px;}
.roi-right{text-align:right;flex-shrink:0;}
.roi-code{font-family:var(--font-display);font-weight:700;font-size:0.8rem;color:#6ee7b7;letter-spacing:1px;}
.roi-earn{font-size:0.7rem;color:#fbbf24;font-weight:700;margin-top:2px;}
.roi-status{font-size:0.65rem;font-weight:700;padding:2px 7px;border-radius:6px;margin-top:3px;display:inline-block;}
.roi-status.done{background:rgba(16,185,129,.2);color:#6ee7b7;}
.roi-status.pending{background:rgba(251,191,36,.15);color:#fbbf24;}
/* Rider profile modal */
.rider-modal{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.25s;}
.rider-modal.open{opacity:1;pointer-events:all;}
.rider-modal-inner{background:#1a2e1a;border-radius:24px 24px 0 0;width:100%;max-width:520px;padding:20px 20px 36px;transform:translateY(40px);transition:transform 0.3s cubic-bezier(.34,1.56,.64,1);max-height:90vh;overflow-y:auto;}
.rider-modal.open .rider-modal-inner{transform:translateY(0);}
.rmi-handle{width:36px;height:4px;background:rgba(255,255,255,.15);border-radius:2px;margin:0 auto 18px;}
.rmi-title{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:white;margin-bottom:16px;}
.rmi-label{font-size:0.74rem;font-weight:700;color:rgba(255,255,255,.5);margin-bottom:5px;letter-spacing:0.2px;}
.rmi-input{width:100%;padding:11px 13px;border:1.5px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);background:rgba(0,0,0,.3);color:white;font-family:var(--font-body);font-size:0.9rem;outline:none;margin-bottom:12px;transition:all 0.18s;}
.rmi-input:focus{border-color:#10b981;}
.rmi-save-btn{width:100%;padding:13px;background:#10b981;color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.92rem;cursor:pointer;margin-top:4px;}
/* Admin account panel */
.admin-account-card{background:var(--surface);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-md);border:1.5px solid var(--border-light);margin-bottom:14px;}
.admin-account-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--orange),#c94200);display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:white;font-family:var(--font-display);margin-bottom:12px;}
.admin-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface-2);border-radius:var(--radius-sm);margin-bottom:7px;border:1px solid var(--border-light);}

/* Super-only elements hidden for sub-admins */
.super-only{display:none;}
.is-super .super-only{display:block;}
.is-super .super-only-flex{display:flex;}
/* Admin panels that are super-only: hidden by default, shown only when .is-super parent AND .active */
.admin-panel.super-only{display:none !important;}
.is-super .admin-panel.super-only.active{display:block !important;}

/* Admin Logs panel */
.log-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;align-items:center;}
.log-filter-input{background:var(--surface);border:1.5px solid var(--border-light);border-radius:var(--radius-sm);padding:7px 10px;font-size:0.8rem;color:var(--text);font-family:var(--font-body);}
.log-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-light);}
.log-table{width:100%;border-collapse:collapse;font-size:0.78rem;}
.log-table th{background:var(--surface-2);padding:9px 10px;text-align:left;font-weight:700;font-family:var(--font-display);color:var(--text-2);border-bottom:1.5px solid var(--border-light);white-space:nowrap;}
.log-table td{padding:8px 10px;border-bottom:1px solid var(--border-light);vertical-align:top;color:var(--text);}
.log-table tr:last-child td{border-bottom:none;}
.log-table tr:hover td{background:var(--surface-2);}
.log-badge{display:inline-block;padding:2px 7px;border-radius:20px;font-size:0.7rem;font-weight:700;font-family:var(--font-display);}
.log-badge.login{background:rgba(34,197,94,.15);color:#16a34a;}
.log-badge.edit{background:rgba(59,130,246,.15);color:#2563eb;}
.log-badge.delete{background:rgba(239,68,68,.15);color:#dc2626;}
.log-badge.add{background:rgba(168,85,247,.15);color:#7c3aed;}
.log-badge.setting{background:rgba(245,158,11,.15);color:#d97706;}
.log-badge.other{background:var(--surface-3);color:var(--text-3);}
.log-empty{text-align:center;padding:32px;color:var(--text-3);font-size:0.85rem;}

/* Analytics panel */
.analytics-range-bar{display:flex;gap:7px;flex-wrap:wrap;align-items:center;margin-bottom:16px;}
.analytics-preset{padding:5px 11px;border-radius:20px;font-size:0.75rem;font-weight:700;cursor:pointer;background:var(--surface-2);color:var(--text-3);border:1.5px solid var(--border-light);font-family:var(--font-display);transition:all .18s;}
.analytics-preset.active,.analytics-preset:hover{background:var(--orange-dim);color:var(--orange);border-color:var(--orange);}
.analytics-stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;}
.analytics-stat{background:var(--surface);border-radius:var(--radius-md);padding:14px 12px;border:1.5px solid var(--border-light);box-shadow:var(--shadow-sm);}
.analytics-stat-val{font-family:var(--font-display);font-weight:800;font-size:1.45rem;color:var(--orange);line-height:1;}
.analytics-stat-label{font-size:0.7rem;color:var(--text-3);margin-top:4px;font-weight:600;}
.analytics-stat-sub{font-size:0.7rem;color:var(--text-2);margin-top:2px;}
.analytics-chart-card{background:var(--surface);border-radius:var(--radius-md);padding:14px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);margin-bottom:12px;}
.analytics-chart-title{font-family:var(--font-display);font-weight:700;font-size:0.84rem;margin-bottom:11px;color:var(--text);}
.analytics-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;font-size:0.77rem;}
.analytics-bar-label{min-width:90px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-2);}
.analytics-bar-track{flex:1;background:var(--surface-3);border-radius:4px;height:8px;overflow:hidden;}
.analytics-bar-fill{height:100%;border-radius:4px;background:var(--orange);transition:width .4s;}
.analytics-bar-fill.blue{background:#3b82f6;}
.analytics-bar-fill.green{background:#22c55e;}
.analytics-bar-fill.purple{background:#a855f7;}
.analytics-bar-count{min-width:30px;text-align:right;color:var(--text-3);font-weight:600;}
.analytics-timeline{width:100%;display:flex;align-items:flex-end;gap:3px;height:60px;}
.analytics-timeline-bar{flex:1;border-radius:3px 3px 0 0;background:var(--orange);opacity:.8;min-height:2px;cursor:pointer;transition:opacity .15s;}
.analytics-timeline-bar:hover{opacity:1;}
.analytics-tl-labels{display:flex;justify-content:space-between;font-size:0.62rem;color:var(--text-3);margin-top:4px;}
@media(max-width:480px){.analytics-stat-grid{grid-template-columns:repeat(2,1fr);}}
.ali-info{display:flex;flex-direction:column;}
.ali-name{font-weight:700;font-size:0.84rem;color:var(--text);}
.ali-email{font-size:0.72rem;color:var(--text-3);margin-top:1px;}
/* User profile edit */
.user-profile-form{margin-top:8px;}
.upf-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}


/* ===== FOOD DETAIL MODAL ===== */
.food-detail-overlay{position:fixed;inset:0;background:rgba(22,15,4,.65);z-index:300;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.25s;}
.food-detail-overlay.open{opacity:1;pointer-events:all;backdrop-filter:blur(4px);}
.food-detail-sheet{background:var(--surface);border-radius:28px 28px 0 0;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;transform:translateY(60px);transition:transform 0.32s cubic-bezier(.34,1.56,.64,1);}
.food-detail-overlay.open .food-detail-sheet{transform:translateY(0);}
.food-detail-img-wrap{position:relative;width:100%;height:240px;overflow:hidden;border-radius:28px 28px 0 0;}
.food-detail-img{width:100%;height:100%;object-fit:cover;display:block;}
.food-detail-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.55));}
.food-detail-badge{position:absolute;top:14px;left:14px;}
.food-detail-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.4);border:none;color:white;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.food-detail-body{padding:20px 20px 28px;}
.food-detail-name{font-family:var(--font-display);font-weight:800;font-size:1.35rem;color:var(--text);margin-bottom:5px;line-height:1.15;}
.food-detail-price{font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:var(--orange);margin-bottom:10px;}
.food-detail-desc{font-size:0.86rem;color:var(--text-2);line-height:1.65;margin-bottom:18px;}
.food-detail-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;}
.food-detail-tag{display:inline-flex;align-items:center;gap:5px;background:var(--surface-2);border:1px solid var(--border-light);padding:5px 11px;border-radius:20px;font-size:0.74rem;font-weight:600;color:var(--text-2);}
.food-detail-add-row{display:flex;align-items:center;gap:12px;}
.food-detail-qty{display:flex;align-items:center;gap:10px;background:var(--surface-3);border-radius:24px;padding:4px;}
.fdq-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--orange);color:white;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;}
.fdq-btn:hover{transform:scale(1.1);}
.fdq-btn.minus{background:var(--surface-2);color:var(--text);}
.fdq-num{font-family:var(--font-display);font-weight:800;font-size:1rem;min-width:24px;text-align:center;color:var(--text);}
.food-detail-cta{flex:1;padding:13px;background:var(--orange);color:white;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.95rem;cursor:pointer;box-shadow:var(--shadow-orange);transition:all 0.2s;}
.food-detail-cta:active{transform:scale(.98);}
.food-detail-cta.sameday{background:#10b981;box-shadow:0 4px 14px rgba(16,185,129,.3);}


/* ===== ORDER TRACKING ===== */
.tracking-bar{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 0 4px;position:relative;}
.tracking-bar::before{content:'';position:absolute;top:22px;left:16px;right:16px;height:2px;background:var(--border-light);z-index:0;}
.tracking-bar-fill{position:absolute;top:22px;left:16px;height:2px;background:var(--orange);z-index:1;transition:width 0.5s ease;}
.track-step{display:flex;flex-direction:column;align-items:center;gap:5px;z-index:2;flex:1;cursor:pointer;}
.track-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);background:var(--surface);transition:all 0.3s;display:flex;align-items:center;justify-content:center;}
.track-dot.done{background:var(--orange);border-color:var(--orange);}
.track-dot.done::after{content:'✓';font-size:0.6rem;color:white;font-weight:900;}
.track-dot.active{background:white;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,101,0,.2);}
.track-dot.active::after{content:'';width:8px;height:8px;border-radius:50%;background:var(--orange);display:block;}
.track-dot.delivered{background:#16a34a;border-color:#16a34a;}
.track-dot.delivered::after{content:'✓';font-size:0.6rem;color:white;font-weight:900;}
.track-label{font-size:0.56rem;color:var(--text-3);text-align:center;font-weight:600;letter-spacing:0.2px;line-height:1.2;max-width:52px;}
.track-label.active{color:var(--orange);font-weight:700;}
.track-label.delivered{color:#16a34a;font-weight:700;}
/* Order card status update in admin */
.order-status-select{font-size:0.72rem;padding:4px 8px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer;font-family:var(--font-body);font-weight:600;}
.status-received{background:#dbeafe;color:#1d4ed8;}
.status-preparing{background:#fef3c7;color:#92400e;}
.status-pickup{background:#ede9fe;color:#5b21b6;}
.status-onway{background:#ecfdf5;color:#065f46;}
.status-delivered{background:var(--success-dim);color:#166534;}
.status-paid{background:var(--success-dim);color:#166534;}
/* ── Group Order Styles ── */
.go-card{background:var(--surface);border-radius:var(--radius-md);padding:14px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);margin-bottom:10px;}
.go-title{font-family:var(--font-display);font-weight:800;font-size:1rem;margin-bottom:4px;}
.go-meta{font-size:0.74rem;color:var(--text-3);margin-bottom:10px;}
.go-member-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-light);}
.go-member-row:last-child{border-bottom:none;}
.go-member-avatar{width:32px;height:32px;border-radius:50%;background:var(--orange-dim);color:var(--orange);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:0.85rem;flex-shrink:0;}
.go-member-name{font-weight:700;font-size:0.82rem;}
.go-member-items{font-size:0.75rem;color:var(--text-2);}
.go-share-card{background:linear-gradient(135deg,var(--orange),#c94200);border-radius:var(--radius-md);padding:16px;color:white;margin-bottom:12px;text-align:center;}
.go-share-title{font-family:var(--font-display);font-weight:800;font-size:1rem;margin-bottom:6px;}
.go-share-link{background:rgba(255,255,255,.15);border-radius:var(--radius-sm);padding:8px 12px;font-size:0.74rem;word-break:break-all;margin:8px 0;}
.go-btn{display:block;width:100%;padding:12px;border:none;border-radius:var(--radius-md);font-family:var(--font-display);font-weight:700;font-size:0.88rem;cursor:pointer;margin-top:7px;transition:all 0.18s;}
.go-btn-primary{background:var(--orange);color:white;box-shadow:var(--shadow-orange);}
.go-btn-wa{background:#25D366;color:white;}
.go-btn-secondary{background:var(--surface-3);color:var(--text);border:1.5px solid var(--border);}
.go-status-open{background:#dcfce7;color:#166534;font-size:0.66rem;font-weight:700;padding:2px 8px;border-radius:10px;display:inline-block;}
.go-status-closed{background:#fef2f2;color:#991b1b;font-size:0.66rem;font-weight:700;padding:2px 8px;border-radius:8px;display:inline-block;}
.unpaid-badge{background:#fef2f2;color:#991b1b;font-size:0.62rem;font-weight:700;padding:2px 7px;border-radius:8px;margin-left:4px;}
.mark-paid-btn{font-size:0.7rem;padding:4px 10px;background:#22c55e;color:white;border:none;border-radius:8px;cursor:pointer;font-weight:700;margin-left:6px;}


/* ── Paystack mode badge pulse (test mode warning) ── */
@keyframes pulseBadge {
  0%,100% { opacity:1; }
  50%      { opacity:.6; }
}

/* ── Settings card for Paystack keys ── */
.settings-pw-wrap{position:relative;display:flex;align-items:center;flex:1;}
.pw-toggle-settings-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--text-3);font-size:0.9rem;padding:4px;line-height:1;}

/* ── Account tab — sticky profile icon mode ── */
.cust-tab-account{display:flex;align-items:center;justify-content:center;gap:4px;}
.tab-account-icon svg{display:block;stroke:currentColor;}
.customer-tabs.is-sticky .tab-account-label{display:none!important;}
.customer-tabs.is-sticky .tab-account-icon{display:flex!important;align-items:center;}
/* Slightly narrower account tab when icon-only so other tabs get more space */
.customer-tabs.is-sticky #accountTab{flex:0 0 52px;padding:11px 0;}

/* ── Nav Auth Area (top-right of hero) ── */
.nav-auth-area{display:flex;align-items:center;flex-shrink:0;}
.nav-auth-btn{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,0.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.35);color:#fff;font-size:0.73rem;font-weight:700;padding:7px 12px;border-radius:50px;cursor:pointer;transition:background 0.15s,transform 0.1s;white-space:nowrap;font-family:var(--font-body);letter-spacing:0.1px;}
.nav-auth-btn:hover{background:rgba(255,255,255,0.28);}
.nav-auth-btn:active{transform:scale(0.97);}
.nav-profile-wrap{position:static;}
.nav-profile-btn{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,0.18);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.35);color:#fff;padding:5px 10px 5px 5px;border-radius:50px;cursor:pointer;transition:background 0.15s;font-family:var(--font-body);}
.nav-profile-btn:hover{background:rgba(255,255,255,0.28);}
.nav-avatar{width:28px;height:28px;border-radius:50%;background:var(--yellow);color:var(--dark);font-weight:800;font-size:0.8rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-display);}
.nav-profile-name{font-size:0.75rem;font-weight:700;color:#fff;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nav-caret{stroke:#fff;opacity:0.85;transition:transform 0.2s;}
.nav-profile-menu.open .nav-caret{transform:rotate(180deg);}
.nav-profile-menu{position:absolute;top:calc(100% + 10px);right:16px;min-width:220px;background:#fff;border:1px solid rgba(0,0,0,0.08);border-radius:16px;box-shadow:0 12px 40px rgba(0,0,0,0.14),0 2px 8px rgba(0,0,0,0.06);z-index:10000;overflow:hidden;animation:npm-in 0.18s ease;}
@keyframes npm-in{from{opacity:0;transform:translateY(-8px) scale(0.96);}to{opacity:1;transform:translateY(0) scale(1);}}
.npm-header{padding:16px 16px 14px;background:linear-gradient(135deg,#ff6500 0%,#c94200 100%);position:relative;overflow:hidden;}
.npm-header::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Ccircle cx='30' cy='30' r='30'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") repeat;pointer-events:none;}
.npm-header-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.25);border:2px solid rgba(255,255,255,0.4);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:#fff;font-family:var(--font-display);margin-bottom:8px;}
.npm-name{font-weight:800;font-size:0.92rem;color:#fff;font-family:var(--font-display);}
.npm-email{font-size:0.7rem;color:rgba(255,255,255,0.75);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.npm-items-wrap{padding:6px;}
.npm-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;padding:9px 10px;font-size:0.83rem;color:var(--text);cursor:pointer;font-family:var(--font-body);font-weight:500;transition:background 0.12s,color 0.12s;border-radius:10px;margin:1px 0;}
.npm-item:hover{background:var(--orange-dim);color:var(--orange);}
.npm-item .npm-icon{font-size:1rem;width:22px;text-align:center;flex-shrink:0;}
.npm-divider{height:1px;background:var(--border-light);margin:4px 6px;}
.npm-signout{color:#dc2626!important;}
.npm-signout:hover{background:#fef2f2!important;color:#dc2626!important;}

/* ── Inline countdown banner inside preorder section ── */
.countdown-banner-inline{border-radius:var(--radius-md);margin:0 0 12px 0;font-size:0.78rem;}

