:root{--saffron: #D4740C;--saffron-deep: #B85D00;--saffron-glow: #F5A623;--terracotta: #C4553D;--cream: #FDF8F3;--cream-warm: #F9F1E7;--parchment: #EFE6DB;--brass: #C9A961;--brass-light: #E8D9A8;--charcoal: #2D2A26;--ink: #1A1715;--ink-soft: #5C564F;--ink-muted: #8A847B;--success: #3D8B6E;--success-soft: #E8F5EF;--error: #C4553D;--error-soft: #FCEEE9;--surface-base: var(--cream);--surface-raised: #FFFFFF;--surface-overlay: rgba(255, 255, 255, .95);--surface-sunken: var(--parchment);--border-subtle: rgba(201, 169, 97, .2);--border-default: rgba(201, 169, 97, .35);--border-strong: var(--brass);--shadow-sm: 0 2px 8px rgba(45, 42, 38, .06);--shadow-md: 0 4px 20px rgba(45, 42, 38, .08), 0 2px 8px rgba(201, 169, 97, .06);--shadow-lg: 0 12px 40px rgba(45, 42, 38, .12), 0 4px 16px rgba(201, 169, 97, .08);--shadow-xl: 0 24px 60px rgba(45, 42, 38, .16), 0 8px 24px rgba(201, 169, 97, .1);--shadow-glow: 0 0 40px rgba(212, 116, 12, .15);--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", -apple-system, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-2xl: 36px;--radius-full: 9999px;--max-width: 1280px;--header-height: 72px;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--text-secondary: var(--ink-soft)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}body{font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--ink);background:var(--surface-base);min-height:100vh}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 80% 50% at 20% -10%,rgba(212,116,12,.08),transparent 50%),radial-gradient(ellipse 60% 40% at 80% 10%,rgba(201,169,97,.1),transparent 40%),radial-gradient(circle at 50% 100%,rgba(196,85,61,.05),transparent 40%);pointer-events:none;z-index:0}body:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:0}#root{position:relative;z-index:1}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500;line-height:1.2;color:var(--ink)}h1{font-size:clamp(2.5rem,5vw,3.5rem);letter-spacing:-.02em}h2{font-size:clamp(1.75rem,3vw,2.25rem);letter-spacing:-.015em}h3{font-size:1.25rem;letter-spacing:-.01em}h4{font-size:1.1rem}p{color:var(--ink-soft);max-width:60ch}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--ink-muted)}.text-accent{color:var(--saffron)}.text-success{color:var(--success)}.text-error{color:var(--error)}.app{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}.header{position:sticky;top:0;z-index:100;height:var(--header-height);background:var(--surface-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:var(--space-lg)}.logo{display:flex;align-items:center;gap:var(--space-sm);text-decoration:none}.brand-logo{display:inline-flex;align-items:center;gap:var(--space-sm)}.logo-mark{width:40px;height:40px;background:linear-gradient(135deg,var(--saffron),var(--saffron-deep));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md),inset 0 1px #fff3}.logo-mark svg{width:24px;height:24px;color:#fff}.brand-mark{width:46px;height:46px;border-radius:16px;background:radial-gradient(circle at 30% 24%,rgba(255,255,255,.22),transparent 34%),linear-gradient(145deg,#f3bc4d,var(--saffron),var(--saffron-deep))}.brand-mark-svg{display:block;filter:drop-shadow(0 2px 2px rgba(96,42,0,.2))}.brand-mark .brand-mark-svg{width:32px;height:32px}.logo-text{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--ink);letter-spacing:-.02em}.logo-text span{color:var(--saffron)}.hero-brand .logo-text{font-size:1.15rem}.hero-brand .brand-mark{width:38px;height:38px;border-radius:14px;box-shadow:var(--shadow-sm),inset 0 1px #ffffff2e}.hero-brand .brand-mark .brand-mark-svg{width:28px;height:28px}.nav-tabs{display:flex;gap:var(--space-xs);background:var(--surface-sunken);padding:4px;border-radius:var(--radius-full)}.nav-tab{position:relative;padding:var(--space-sm) var(--space-lg);font-size:.875rem;font-weight:500;color:var(--ink-soft);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:color var(--duration-fast) ease;white-space:nowrap}.nav-tab:hover{color:var(--ink)}.nav-tab.active{color:#fff;background:var(--charcoal);box-shadow:var(--shadow-sm)}.nav-tab-icon{display:none}@media(max-width:640px){.nav-tab span{display:none}.nav-tab-icon{display:block;width:18px;height:18px}}.header-user{display:flex;align-items:center;gap:var(--space-md)}.header-user-name{font-size:.875rem;font-weight:500;color:var(--ink-soft)}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--brass-light),var(--brass));border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:var(--charcoal)}.hero{padding:var(--space-3xl) 0;text-align:center}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--surface-raised);border:1px solid var(--border-default);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;color:var(--saffron-deep);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.hero-badge:before{content:"";width:6px;height:6px;background:var(--saffron);border-radius:50%;animation:pulse 2s ease-in-out infinite}.hero-badge-brand:before{display:none}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.hero h1{margin-bottom:var(--space-md)}.hero h1 em{font-style:italic;color:var(--saffron)}.hero-subtitle{font-size:1.125rem;color:var(--ink-soft);max-width:480px;margin:0 auto var(--space-xl)}.hero-features{display:flex;justify-content:center;gap:var(--space-xl);flex-wrap:wrap}.hero-feature{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;color:var(--ink-soft)}.hero-feature-icon{width:32px;height:32px;background:var(--surface-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--saffron)}.hero-feature-icon svg{width:16px;height:16px}.auth-section{display:flex;justify-content:center;padding:var(--space-2xl) 0 var(--space-3xl)}.auth-card{width:100%;max-width:420px;background:var(--surface-raised);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-lg)}.auth-card-header{text-align:center;margin-bottom:var(--space-xl)}.auth-card-header h2{margin-bottom:var(--space-xs)}.auth-card-header p{margin:0 auto}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.auth-toggle{text-align:center;padding-top:var(--space-md);border-top:1px solid var(--border-subtle);margin-top:var(--space-md)}.auth-toggle button{background:none;border:none;color:var(--saffron);font-weight:500;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.auth-toggle button:hover{color:var(--saffron-deep)}.main{flex:1;padding:var(--space-xl) 0 var(--space-3xl)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.page-title{display:flex;align-items:center;gap:var(--space-md)}.page-title h2{margin:0}.page-title-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--saffron-glow),var(--saffron));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.page-title-icon svg{width:24px;height:24px}.grid{display:grid;gap:var(--space-lg)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card{background:var(--surface-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-lg);box-shadow:var(--shadow-md);transition:box-shadow var(--duration-normal) var(--ease-out-expo),transform var(--duration-normal) var(--ease-out-expo)}.card:hover{box-shadow:var(--shadow-lg)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-lg);gap:var(--space-md)}.card-title{display:flex;align-items:center;gap:var(--space-sm)}.card-title h3{margin:0}.card-title-icon{width:28px;height:28px;background:var(--surface-sunken);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--saffron)}.card-title-icon svg{width:16px;height:16px}.card-body{padding:0}.card-section{padding-top:var(--space-lg);margin-top:var(--space-lg);border-top:1px solid var(--border-subtle)}.card-section-title{font-family:var(--font-display);font-size:1rem;font-weight:500;margin-bottom:var(--space-md);color:var(--ink)}.card-featured{background:linear-gradient(135deg,var(--charcoal) 0%,#3D3A35 100%);border-color:#c9a9614d;color:var(--cream)}.card-featured h3,.card-featured h4{color:var(--cream)}.card-featured p{color:#fdf8f3b3}.card-featured .card-title-icon{background:#d4740c33;color:var(--saffron-glow)}.card-featured .form-label{color:var(--cream)}.menu-week{display:flex;flex-direction:column;gap:var(--space-xl)}.menu-meal-section{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}.menu-meal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);cursor:pointer;-webkit-user-select:none;user-select:none;transition:filter var(--duration-fast) ease}.menu-meal-header:hover{filter:brightness(1.08)}.menu-meal-header.breakfast{background:linear-gradient(135deg,#2d2a26,#3d3620);color:#f5c842}.menu-meal-header.lunch{background:linear-gradient(135deg,#1a2820,#2d3a2a);color:#5bc48a}.menu-meal-header.dinner{background:linear-gradient(135deg,#2d1e1a,#3d2820);color:#e87d5a}.menu-meal-label{font-family:var(--font-display);font-weight:600;font-size:1rem;text-transform:capitalize;letter-spacing:.02em}.menu-meal-header-right{display:flex;align-items:center;gap:var(--space-sm)}.menu-meal-toggle{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a;transition:transform var(--duration-normal) ease}.menu-meal-toggle.expanded{transform:rotate(180deg)}.menu-meal-chevron{display:flex;align-items:center;transition:transform var(--duration-normal) ease}.menu-meal-chevron svg{width:18px;height:18px}.menu-meal-chevron.expanded{transform:rotate(180deg)}.menu-meal-body{display:flex;flex-direction:column;gap:1px;background:var(--border-subtle)}.menu-meal-day{padding:var(--space-md);background:var(--surface-raised)}.menu-meal-day-name{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin-bottom:var(--space-sm)}.day-group{margin-bottom:var(--space-xl)}.day-group-title{padding:10px var(--space-md);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);display:flex;align-items:center;gap:var(--space-sm);border-bottom:1px solid var(--border-subtle);margin:0 var(--space-md)}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg);padding:var(--space-md)}.dish-card{background:#fff;border-radius:var(--radius-xl);padding:var(--space-lg);border:1px solid var(--border-subtle);box-shadow:0 4px 20px #00000005;display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.dish-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0000000f;border-color:var(--saffron-glow)}.dish-card.in-cart{background:#fffbf2;border-color:var(--saffron);box-shadow:0 0 0 2px var(--saffron),var(--shadow-md)}.dish-type-badge{position:absolute;top:16px;right:16px;padding:4px 12px;border-radius:var(--radius-full);font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;z-index:1}.dish-type-badge.veg{background:#e8f5e9;color:#2e7d32;border:1px solid #C8E6C9}.dish-type-badge.non-veg{background:#ffebee;color:#c62828;border:1px solid #FFCDD2}.dish-type-badge.staple{background:#fff8e1;color:#8d6e63;border:1px solid #FFECB3}.dish-type-badge.roti{background:#ffe0b2;color:#8d4e00;border:1px solid #FFCC80}.dish-info{flex:1}.dish-name{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--ink);margin-bottom:6px;line-height:1.25;padding-right:48px}.dish-chef-meta{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:.8rem;font-weight:600;color:var(--ink-soft)}.dish-chef-meta-separator{line-height:1;color:var(--ink-muted)}.dish-desc{font-size:.875rem;color:var(--ink-soft);line-height:1.5;margin-bottom:var(--space-lg);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dish-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:var(--space-md);border-top:1px dashed var(--border-subtle)}.dish-price{font-size:1.25rem;font-weight:800;color:var(--charcoal);letter-spacing:-.02em}.dish-actions{display:flex;align-items:center;gap:12px;background:var(--surface-sunken);padding:4px;border-radius:var(--radius-md)}.qty-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.1);background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s;-webkit-appearance:none;appearance:none;font:inherit}.qty-btn:active{transform:scale(.9)}.qty-btn-symbol{font-size:1.2rem;font-weight:800;line-height:1;color:#111;margin-top:-1px}.qty-number{font-weight:800;font-size:.95rem;min-width:24px;text-align:center;color:var(--charcoal)}.add-main-btn{background:var(--charcoal);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-md);font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-sm)}.add-main-btn:hover{background:#000;transform:translateY(-1px);box-shadow:var(--shadow-md)}.menu-dish-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.menu-dish-name{font-weight:500;color:var(--ink);line-height:1.3}.menu-dish-price{font-weight:600;color:var(--ink-soft);white-space:nowrap;font-size:.875rem}.menu-dish-empty{color:var(--ink-muted);font-style:italic;font-size:.875rem}.menu-dish-selected .menu-dish-name{font-weight:600}.pill-sm{padding:2px var(--space-xs);font-size:.65rem}.quantity-selector-sm{gap:2px}.quantity-selector-sm .quantity-btn{width:26px;height:26px}.quantity-selector-sm .quantity-btn svg{width:14px;height:14px}.quantity-selector-sm .quantity-value{min-width:28px;font-size:.875rem}.form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md)}.form-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--surface-base);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease,background-color var(--duration-fast) ease}.form-input:hover,.form-select:hover,.form-textarea:hover{border-color:var(--border-strong)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--saffron);background:var(--surface-raised);box-shadow:0 0 0 3px #d4740c1f}.form-input::placeholder{color:var(--ink-muted)}.searchable-select{display:grid;gap:8px}.searchable-select-input-compact{min-height:36px;padding-top:8px;padding-bottom:8px}.searchable-select-list{max-height:180px;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--surface-raised)}.searchable-select-option{width:100%;padding:10px 12px;text-align:left;background:transparent;border:none;border-bottom:1px solid var(--border-subtle);color:var(--ink);font-size:.875rem;cursor:pointer}.searchable-select-option:last-child{border-bottom:none}.searchable-select-option:hover,.searchable-select-option.selected{background:var(--surface-sunken)}.searchable-select-empty{padding:10px 12px;color:var(--ink-muted);font-size:.8125rem}.form-select{appearance:none;cursor:pointer;border-width:2px;border-color:#6c6256;background-color:#fff;color:#201a14;font-weight:600;box-shadow:inset 0 0 0 1px #6c625614;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23443b31' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.form-select:hover{border-color:#4f473d;background-color:#fff;box-shadow:inset 0 0 0 1px #4f473d1f}.form-select:focus{border-color:#201a14;background:#fff;box-shadow:0 0 0 4px #201a1424,inset 0 0 0 1px #201a141f}.form-select option{color:#201a14;background:#fff}.form-textarea{min-height:100px;resize:vertical}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-body);font-size:.9375rem;font-weight:600;text-decoration:none;border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--duration-fast) var(--ease-out-expo);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:18px;height:18px}.btn-xs svg{width:12px;height:12px}.btn-primary{background:linear-gradient(135deg,var(--saffron),var(--saffron-deep));color:#fff;box-shadow:var(--shadow-sm),inset 0 1px #ffffff26}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow),inset 0 1px #ffffff26}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--charcoal);color:#fff;box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--ink);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--border-default)}.btn-outline:hover:not(:disabled){background:var(--surface-sunken);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--ink-soft)}.btn-ghost:hover:not(:disabled){background:var(--surface-sunken);color:var(--ink)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:.8125rem}.btn-xs{padding:4px 8px;font-size:.7rem}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:1rem}.btn-block{width:100%}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md);flex-shrink:0}.btn-icon svg{width:18px;height:18px}.btn-sm.btn-icon{width:30px;height:30px}.pill{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-size:.75rem;font-weight:600;border-radius:var(--radius-full);background:var(--surface-sunken);color:var(--ink-soft)}.pill-saffron{background:#d4740c1f;color:var(--saffron-deep)}.pill-brass{background:#c9a96126;color:var(--charcoal)}.pill-success{background:var(--success-soft);color:var(--success)}.pill-error{background:var(--error-soft);color:var(--error)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-xs);font-size:.6875rem;font-weight:700;border-radius:var(--radius-full);background:var(--saffron);color:#fff}.status{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);letter-spacing:.01em}.status:before{content:"";width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-draft{background:#8a847b1f;color:var(--ink-soft)}.status-draft:before{background:var(--ink-muted)}.status-confirmed{background:#c9a96126;color:#8b6914}.status-confirmed:before{background:var(--brass)}.status-preparing{background:#d4740c1f;color:var(--saffron-deep)}.status-preparing:before{background:var(--saffron)}.status-out_for_delivery{background:#3b82f61f;color:#1d4ed8}.status-out_for_delivery:before{background:#3b82f6;animation:pulse 1.5s ease-in-out infinite}.status-delivered{background:var(--success-soft);color:var(--success)}.status-delivered:before{background:var(--success)}.status-failed,.status-cancelled{background:var(--error-soft);color:var(--error)}.status-failed:before,.status-cancelled:before{background:var(--error)}.list{display:flex;flex-direction:column;gap:var(--space-md)}.list-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--surface-sunken);border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--duration-fast) ease}.list-item+.list-item{margin-top:var(--space-sm)}.list>.list-item+.list-item{margin-top:0}.list-item:hover{background:var(--parchment);border-color:var(--border-subtle)}.list-item-icon{width:40px;height:40px;background:var(--surface-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--saffron);flex-shrink:0}.list-item-icon svg{width:20px;height:20px}.list-item-content{flex:1;min-width:0}.list-item-title{font-weight:500;color:var(--ink)}.list-item-subtitle{font-size:.8125rem;color:var(--ink-muted)}.list-item-action{flex-shrink:0}.dish-list-item{align-items:flex-start}.admin-misc-tabs{flex-wrap:wrap}.dish-list-title{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.dish-list-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:var(--space-xs);min-width:0}.dish-list-actions .btn{min-height:34px}.admin-route-item{gap:var(--space-sm)}.admin-route-item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-sm)}.admin-route-item-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.admin-route-delete{min-width:36px;min-height:36px;display:inline-flex;align-items:center;justify-content:center;padding:0}.admin-route-control-row{display:flex;align-items:center;gap:var(--space-sm)}.admin-route-control-label{white-space:nowrap;flex-shrink:0}.admin-route-control-input{flex:1;min-width:0}.admin-route-time-input{max-width:120px}.admin-route-stops-header{margin-bottom:var(--space-sm)}.admin-route-stops-actions{align-items:center}.dish-list-actions .pill,.dish-list-actions .btn{max-width:100%}.dish-edit-row{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.action-menu{position:relative;flex-shrink:0}.action-menu-trigger{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:999px;border:1px solid rgba(0,0,0,.12);background:#ffffffeb;color:var(--ink-soft);cursor:pointer;box-shadow:0 1px 3px #0000000d;transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease,color var(--duration-fast) ease,box-shadow var(--duration-fast) ease,transform var(--duration-fast) ease}.action-menu-trigger:hover{background:var(--surface-raised);border-color:#d4740c59;color:var(--saffron-deep);box-shadow:0 6px 14px #00000014;transform:translateY(-1px)}.action-menu-trigger:focus-visible{outline:none;border-color:#d4740c8c;box-shadow:0 0 0 3px #d4740c24}.action-menu-trigger-dots{display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:900;letter-spacing:.08em;line-height:1;transform:translateY(-1px)}.action-menu-trigger-pill{width:auto;min-width:0;height:40px;padding:0 14px 0 10px;gap:8px;border-color:#d4740c38;background:linear-gradient(180deg,#fffcf5fa,#fbf4e8f5);color:var(--saffron-deep);font-size:.84rem;font-weight:700}.action-menu-trigger-pill:hover{border-color:#d4740c61;background:linear-gradient(180deg,#fff8ecfa,#f9edd7fa)}.action-menu-trigger-pill-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#d4740c1f;color:var(--saffron-deep);flex-shrink:0}.action-menu-trigger-pill-icon svg{width:13px;height:13px}.action-menu-panel{position:absolute;top:calc(100% + 6px);right:0;width:210px;padding:10px;border-radius:var(--radius-lg);border:1px solid rgba(0,0,0,.08);background:var(--surface-raised);box-shadow:0 18px 36px #0000001f;z-index:30;display:flex;flex-direction:column;gap:4px}.action-menu-item{width:100%;display:flex;align-items:center;justify-content:flex-start;padding:10px 12px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--ink);font-family:var(--font-body);font-size:.9rem;font-weight:600;text-align:left;cursor:pointer;transition:background-color var(--duration-fast) ease,color var(--duration-fast) ease}.action-menu-item:hover:not(:disabled){background:#d4740c14;color:var(--saffron-deep)}.action-menu-item:disabled{opacity:.45;cursor:not-allowed}.action-menu-item-danger{color:var(--error)}.action-menu-item-danger:hover:not(:disabled){background:#b4231814;color:#8f1d17}.order-card{display:flex;align-items:stretch;background:var(--surface-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow var(--duration-normal) ease}.order-card:hover{box-shadow:var(--shadow-lg)}.order-card-today-active{border-color:#d4740c73;box-shadow:0 0 0 2px #d4740c2e,var(--shadow-md)}.order-card-today-active .order-card-date{background:linear-gradient(135deg,#5a3d12,var(--saffron-deep))}.delivery-progress-line{color:var(--charcoal);font-size:.82rem;line-height:1.4}.delivery-progress-line strong{font-weight:800}.order-card-date{width:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-md);background:linear-gradient(135deg,var(--charcoal),#3D3A35);color:var(--cream);text-align:center}.order-card-day{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;opacity:.7}.order-card-num{font-family:var(--font-display);font-size:1.75rem;font-weight:600;line-height:1}.order-card-month{font-size:.75rem;opacity:.7}.order-card-body{flex:1;padding:var(--space-md);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.order-card-info h4{margin:0 0 var(--space-xs)}.address-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-md)}.address-card{padding:var(--space-md);background:var(--surface-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) ease}.address-card:hover{background:var(--parchment);border-color:var(--border-default)}.address-card.selected{background:var(--surface-raised);border-color:var(--saffron);box-shadow:0 0 0 3px #d4740c1f}.address-card-label{display:flex;align-items:center;gap:var(--space-xs);font-weight:600;color:var(--ink);margin-bottom:var(--space-xs)}.address-card-label svg{width:14px;height:14px;color:var(--saffron)}.address-card-text{font-size:.8125rem;color:var(--ink);line-height:1.4}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--ink-muted)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-md);background:linear-gradient(135deg,var(--surface-sunken),var(--parchment));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--ink-muted)}.empty-state-icon svg{width:28px;height:28px}.empty-state h4{color:var(--ink);margin-bottom:var(--space-xs)}.toast{position:fixed;bottom:calc(96px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);padding:var(--space-md) var(--space-xl);background:var(--charcoal);color:var(--cream);border-radius:var(--radius-full);font-weight:500;box-shadow:var(--shadow-xl);z-index:1000}.toast-success{background:var(--success)}.toast-error{background:var(--error)}.footer{padding:var(--space-xl) 0;text-align:center;border-top:1px solid var(--border-subtle);margin-top:var(--space-3xl)}.footer-text{font-size:.8125rem;color:var(--ink-muted)}.footer-text span{color:var(--saffron)}@media(max-width:768px){.footer{display:none}}.dish-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md)}.dish-grid .dish-card{padding:var(--space-md);background:var(--surface-sunken);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) ease;text-align:center}.dish-grid .dish-card:hover{background:var(--parchment);border-color:var(--border-default);transform:translateY(-2px)}.dish-grid .dish-card.selected{background:var(--surface-raised);border-color:var(--saffron);box-shadow:0 0 0 3px #d4740c1f}.dish-grid .dish-card-emoji{font-size:2rem;margin-bottom:var(--space-sm)}.dish-grid .dish-card-name{font-weight:600;color:var(--ink);margin-bottom:var(--space-xs)}.dish-grid .dish-card-type{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);margin-bottom:var(--space-sm)}.dish-grid .dish-card-price{font-weight:700;color:var(--saffron)}.quantity-selector{display:inline-flex;align-items:center;gap:var(--space-xs);background:var(--surface-sunken);border-radius:var(--radius-full);padding:2px}.quantity-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--surface-raised);border:none;border-radius:50%;cursor:pointer;color:var(--ink);transition:all var(--duration-fast) ease}.quantity-btn:hover{background:var(--charcoal);color:#fff}.quantity-btn:disabled{opacity:.3;cursor:not-allowed}.quantity-value{min-width:40px;text-align:center;font-weight:600}.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-sm)}.slot-card{padding:var(--space-md);background:var(--surface-raised);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) ease;text-align:center}.slot-card:hover{background:var(--parchment);border-color:var(--border-default)}.slot-card.selected{background:var(--charcoal);border:2px solid var(--saffron);box-shadow:0 0 0 3px #d4740c33;color:#fff}.slot-card-label{font-weight:600;margin-bottom:var(--space-xs);color:var(--ink)}.slot-card.selected .slot-card-label{color:#fff}.slot-card-time{font-size:.8125rem;color:var(--ink-soft)}.slot-card.selected .slot-card-time{color:#fffc}.rider-hero{background:linear-gradient(135deg,var(--charcoal) 0%,#3D3A35 100%);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);color:var(--cream);margin-bottom:var(--space-md);position:relative;overflow:hidden}.rider-hero:before{display:none}.rider-hero h2{color:var(--cream);margin-bottom:var(--space-xs);font-size:1.35rem;line-height:1.1}.rider-hero p{color:#fdf8f3b3;max-width:400px}.rider-stats{display:flex;gap:var(--space-md);margin-top:var(--space-xs)}.rider-stat{text-align:center}.rider-stat-value{font-family:var(--font-display);font-size:1.35rem;font-weight:600;color:var(--saffron-glow);line-height:1.05}.rider-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;opacity:.6}.prep-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg);padding:var(--space-md)}.prep-day-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);overflow:hidden;box-shadow:var(--shadow-sm)}.prep-day-header{background:var(--charcoal);color:#fff;padding:var(--space-md);font-family:var(--font-display);font-weight:600;display:flex;justify-content:space-between;align-items:center}.prep-meals{display:flex;flex-direction:column}.prep-meal-section{padding:var(--space-md)}.prep-meal-section:not(:last-child){border-bottom:1px dashed var(--border-subtle)}.prep-meal-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-xs)}.prep-meal-title.breakfast{color:var(--saffron)}.prep-meal-title.lunch{color:var(--success)}.prep-meal-title.dinner{color:var(--terracotta)}.prep-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0}.prep-item-name{font-weight:500;color:var(--ink)}.prep-item-qty{background:var(--surface-sunken);color:var(--ink);padding:2px 10px;border-radius:var(--radius-full);font-weight:700;font-size:.875rem;border:1px solid var(--border-subtle)}.chef-plan-meals{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-md)}.chef-plan-meal-card{background:#ffffffa6;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md)}.chef-plan-meal-card.breakfast{border-left:4px solid var(--saffron)}.chef-plan-meal-card.lunch{border-left:4px solid var(--success)}.chef-plan-meal-card.dinner{border-left:4px solid var(--terracotta)}.admin-menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg)}.admin-menu-day-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);overflow:hidden;box-shadow:var(--shadow-sm)}.admin-menu-day-header{background:var(--charcoal);color:#fff;padding:var(--space-md);font-family:var(--font-display);font-weight:600;display:flex;justify-content:space-between;align-items:center}.admin-menu-meal-group{padding:var(--space-md)}.admin-menu-meal-group:not(:last-child){border-bottom:1px dashed var(--border-subtle)}.admin-menu-meal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.admin-menu-meal-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:var(--space-xs)}.admin-menu-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);background:var(--surface-sunken);border-radius:var(--radius-md);margin-bottom:var(--space-xs);border:1px solid transparent;transition:all .2s}.admin-menu-item:hover{border-color:var(--border-default);background:var(--parchment)}.admin-menu-item-info{min-width:0;flex:1}.admin-menu-item-name{font-weight:600;font-size:.9rem;display:block}.admin-menu-item-meta{font-size:.75rem;color:var(--ink-muted)}.admin-menu-quick-add{margin-top:var(--space-sm);width:100%;border:1px dashed var(--border-default);background:transparent;color:var(--ink-soft);padding:var(--space-sm);border-radius:var(--radius-md);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.admin-menu-quick-add:hover{background:var(--surface-sunken);border-color:var(--saffron);color:var(--saffron-deep)}.packing-list{background:var(--surface-sunken);border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-md)}.packing-list-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin-bottom:var(--space-sm);display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs);cursor:pointer;-webkit-user-select:none;user-select:none}.packing-list-title:hover{color:var(--saffron-deep)}.packing-list-title svg{width:14px;height:14px}.packing-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(0,0,0,.04)}.packing-item:last-child{border-bottom:none}.packing-item-name{font-size:.9rem;font-weight:500}.packing-item-qty{font-weight:700;color:var(--saffron-deep)}.prep-meal-title svg,.admin-menu-meal-title svg,.admin-menu-quick-add svg,.admin-menu-item-info svg{width:14px;height:14px}.admin-menu-quick-add svg{width:16px;height:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.ml-sm{margin-left:var(--space-sm)}.w-full{width:100%}.text-center{text-align:center}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.bg-light{background:var(--surface-sunken)}.rounded{border-radius:var(--radius-md)}.small{font-size:.875rem}.uppercase{text-transform:uppercase}.tracking-wider{letter-spacing:.05em}.font-bold{font-weight:700}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){:root{--space-lg: 20px;--space-xl: 28px;--space-2xl: 40px;--space-3xl: 56px;--header-height: 60px}.container{padding:0 var(--space-md)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.customer-menu-header{flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:nowrap}.customer-menu-header .page-title{min-width:0;flex:1}.customer-menu-header>.btn{margin-right:6px}.logo-text{font-size:1.25rem}.header-user-name,.header-user .btn span{display:none}.rider-stats{flex-wrap:wrap}.rider-hero{padding:var(--space-sm) var(--space-md)}.order-card-body{flex-direction:column;align-items:flex-start}.toast{max-width:calc(100vw - var(--space-xl))}.card-header{flex-wrap:wrap;gap:var(--space-sm)}.card-section .flex.gap-sm{flex-wrap:wrap}.stop-actions{flex-wrap:wrap;gap:var(--space-xs)}.stop-actions .btn{font-size:.7rem;padding:4px 8px}.assign-row{flex-direction:column;align-items:stretch}.assign-row .btn{width:100%}.order-reassign{flex-wrap:wrap}.admin-route-item-header{flex-direction:column;align-items:stretch}.admin-route-item-actions{width:100%;justify-content:space-between}.admin-route-control-row{flex-direction:column;align-items:stretch}.admin-route-control-label{white-space:normal}.admin-route-control-input,.admin-route-time-input{width:100%;max-width:none}.admin-route-stops-actions{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-route-stops-actions .btn:last-child{grid-column:1 / -1}.dish-list-item{flex-direction:column}.dish-list-item .list-item-content{width:100%}.dish-list-actions{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch}.dish-list-actions .pill,.dish-list-actions .btn{width:100%;justify-content:center;text-align:center}.dish-list-actions .btn{padding:6px 10px;white-space:normal;line-height:1.2}.dish-edit-actions{flex-wrap:wrap}.admin-misc-tabs .btn{flex:1 1 calc(50% - var(--space-xs));min-width:0;justify-content:center}.menu-grid{grid-template-columns:1fr;gap:var(--space-md);padding:var(--space-sm)}.day-group-title{margin:var(--space-md) var(--space-sm) var(--space-sm);padding:8px var(--space-sm);font-size:.75rem}.dish-footer{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.dish-actions-wrapper{width:auto;align-self:flex-end}.dish-actions{width:auto;justify-content:space-between}.add-main-btn{width:auto;justify-content:center;padding:7px 12px;font-size:.8rem;border-radius:var(--radius-sm);gap:6px}.add-main-btn svg{width:14px;height:14px}}@media(max-width:640px){.logo-text{display:none}.ios-install-banner{margin:var(--space-xs) var(--space-sm) 0;padding:8px 10px}.ios-install-banner-text{font-size:.8rem}}.bottom-tabs-wrapper{position:fixed;bottom:0;left:0;right:0;z-index:90;padding:0 var(--space-sm) env(safe-area-inset-bottom,0);background:var(--surface-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border-subtle)}.bottom-tabs{display:flex;justify-content:space-around;align-items:center;max-width:480px;margin:0 auto;height:64px}.bottom-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs) var(--space-md);background:none;border:none;cursor:pointer;color:var(--ink-muted);transition:color var(--duration-fast) ease;position:relative;-webkit-tap-highlight-color:transparent}.bottom-tab:hover{color:var(--ink-soft)}.bottom-tab.active{color:var(--saffron);background:#d4740c1a;border-radius:var(--radius-md)}.bottom-tab.active:before{content:"";position:absolute;top:-1px;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--saffron);border-radius:0 0 3px 3px}.bottom-tab-icon{width:24px;height:24px;position:relative}.bottom-tab-icon svg{width:24px;height:24px}.bottom-tab-badge{position:absolute;top:-4px;right:-8px;min-width:16px;height:16px;padding:0 4px;font-size:.625rem;font-weight:700;background:var(--saffron);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;line-height:1}.bottom-tab-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.ios-install-banner{margin:var(--space-sm) auto 0;max-width:980px;background:#d4740c14;border:1px solid var(--border-default);color:var(--ink-soft);border-radius:var(--radius-md);padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.ios-install-banner-text{font-size:.875rem;font-weight:500}.ios-install-banner-close{border:none;background:transparent;color:var(--ink-soft);font-size:1.1rem;line-height:1;cursor:pointer;padding:2px 4px}.cart-bar-wrapper{position:fixed;bottom:calc(84px + env(safe-area-inset-bottom,0px));left:0;right:0;z-index:91;display:flex;justify-content:center;padding:0 var(--space-md);pointer-events:none}.cart-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);width:100%;max-width:480px;padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--charcoal) 0%,#3D3A35 100%);border:1px solid rgba(201,169,97,.4);border-radius:var(--radius-full);color:var(--cream);cursor:pointer;pointer-events:auto;box-shadow:var(--shadow-xl);transition:transform var(--duration-fast) ease;-webkit-tap-highlight-color:transparent}.cart-bar:hover{transform:scale(1.01)}.cart-bar:active{transform:scale(.99)}.cart-bar-left{display:flex;align-items:center;gap:var(--space-sm)}.cart-bar-icon{width:24px;height:24px;position:relative}.cart-bar-icon svg{width:24px;height:24px;color:var(--saffron-glow)}.cart-bar-icon .bottom-tab-badge{top:-6px;right:-10px}.cart-bar-text{font-weight:600;font-size:.9375rem}.cart-bar-total{font-weight:700;font-size:1rem;color:var(--saffron-glow)}.cart-sheet-overlay{position:fixed;inset:0;padding-bottom:calc(88px + env(safe-area-inset-bottom,0px));box-sizing:border-box;background:#1a171580;z-index:95;display:flex;align-items:flex-end;justify-content:center;-webkit-tap-highlight-color:transparent}.cart-sheet{width:100%;max-height:85vh;background:var(--surface-raised);border-radius:var(--radius-xl) var(--radius-xl) 0 0;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);overflow:hidden}.cart-sheet-handle{display:flex;justify-content:center;padding:var(--space-sm) 0 0}.cart-sheet-handle:after{content:"";width:36px;height:4px;background:var(--border-default);border-radius:var(--radius-full)}.cart-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-subtle)}.cart-sheet-header h3{margin:0;font-family:var(--font-display)}.cart-sheet-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--surface-sunken);border:none;border-radius:var(--radius-full);cursor:pointer;color:var(--ink-soft);font-size:1.25rem;line-height:1;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}.cart-sheet-close:hover{background:var(--parchment);color:var(--ink)}.cart-sheet-body{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.cart-sheet-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle);background:var(--surface-raised)}.admin-order-drawer-overlay{position:fixed;inset:0;background:#1a171573;z-index:96;display:flex;justify-content:flex-end;align-items:stretch}.admin-order-drawer{width:min(560px,100vw);background:var(--surface-raised);border-left:1px solid var(--border-subtle);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;height:100%}.admin-order-drawer-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-subtle)}.admin-order-drawer-header h3{margin:0;font-family:var(--font-display)}.admin-order-drawer-body{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.admin-order-drawer-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle);background:var(--surface-raised)}.customer-content{padding-bottom:90px;overflow-x:clip}.customer-content.menu-active{padding-bottom:118px}.customer-content.has-cart{padding-bottom:160px}.customer-content.menu-active.has-cart{padding-bottom:188px}.admin-content,.rider-content{padding-bottom:90px}@media(min-width:769px){.cart-sheet-overlay{align-items:center;padding-bottom:0}.cart-sheet{max-width:600px;max-height:85vh;border-radius:var(--radius-xl);margin:var(--space-lg);border:1px solid var(--border-subtle)}.cart-sheet-handle{display:none}.bottom-tabs-wrapper{border-radius:var(--radius-xl) var(--radius-xl) 0 0}}@media(max-width:768px){.day-nav{margin-left:calc(var(--space-md) * -1);margin-right:calc(var(--space-md) * -1);padding-left:var(--space-md);padding-right:var(--space-md)}.admin-unrouted-banner{padding:10px 12px!important;align-items:flex-start!important}.admin-unrouted-banner .btn{width:100%;justify-content:center}.admin-unrouted-banner-spacer{height:84px!important}.admin-sticky-panel{position:static!important;top:auto!important}.admin-dashboard-content .card{padding:var(--space-md);border-radius:var(--radius-lg)}.admin-dashboard-content .card-header{flex-direction:column;align-items:stretch;margin-bottom:var(--space-md)}.admin-dashboard-content .card-header>.flex,.admin-dashboard-content .card-header>button.btn{width:100%;flex-wrap:wrap;justify-content:flex-start}.admin-dashboard-content .card-title{min-width:0}.admin-dashboard-content .card-title h3,.admin-dashboard-content .page-title h2{line-height:1.15}.admin-dashboard-content .form-row{grid-template-columns:1fr;gap:var(--space-sm)}.admin-dashboard-content .list-item{flex-direction:column;align-items:stretch}.admin-dashboard-content .list-item .flex.gap-sm,.admin-dashboard-content .list-item .flex.items-center,.admin-dashboard-content .list-item .flex.flex-col{width:100%;justify-content:flex-start;flex-wrap:wrap}.admin-dashboard-content .list-item .action-menu{margin-left:auto}.admin-dashboard-content .admin-route-item{padding:var(--space-sm)}.admin-dashboard-content .admin-route-item .list-item-title,.admin-dashboard-content .admin-route-item .list-item-subtitle{overflow-wrap:anywhere}.admin-dashboard-content .btn{max-width:100%}.admin-order-drawer-overlay{justify-content:center;align-items:flex-end}.admin-order-drawer{width:100%;max-height:88vh;border-left:none;border-top:1px solid var(--border-subtle);border-radius:var(--radius-xl) var(--radius-xl) 0 0}}@media(max-width:480px){.container{padding:0 var(--space-sm)}.hero-features{flex-direction:column;align-items:flex-start}.card{padding:var(--space-md);border-radius:var(--radius-lg)}.admin-route-stops-actions{grid-template-columns:1fr}.admin-route-stops-actions .btn:last-child{grid-column:auto}.auth-card{padding:var(--space-md)}.order-card{flex-direction:column}.order-card-date{width:100%;flex-direction:row;gap:var(--space-sm);padding:var(--space-sm) var(--space-md)}.order-card-num{font-size:1.25rem}.delivery-progress-line{font-size:.85rem}.toast{left:var(--space-md);right:var(--space-md);bottom:calc(78px + env(safe-area-inset-bottom,0));transform:none;max-width:none;text-align:center}.dish-edit-row{grid-template-columns:1fr}}.day-nav{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);overflow-x:auto;scrollbar-width:none;background:var(--surface-overlay);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-subtle);position:sticky;top:calc(var(--header-height) - 1px);z-index:10;margin:0 calc(var(--space-lg) * -1) var(--space-lg)}.day-nav::-webkit-scrollbar{display:none}.day-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:60px;height:60px;border-radius:var(--radius-md);background:var(--surface-sunken);color:var(--ink-soft);cursor:pointer;transition:all var(--duration-fast) ease;flex-shrink:0;border:1px solid transparent}.day-nav-item:hover{background:var(--parchment);color:var(--ink)}.day-nav-item.active{background:var(--charcoal);color:#fff;box-shadow:var(--shadow-md);border-color:var(--saffron)}.day-nav-day{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px}.day-nav-num{font-family:var(--font-display);font-size:1.1rem;font-weight:700;line-height:1}.day-select-header{display:flex;align-items:center;gap:var(--space-sm);position:sticky;top:calc(var(--header-height) + var(--customer-day-nav-offset, 74px));z-index:9;background:var(--surface-sunken);box-shadow:0 2px 8px #0000000f}.day-select-actions{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.day-select-pill{flex-shrink:0}.day-select-btn{min-height:38px}.customer-meal-header{border-left:4px solid var(--border-strong);border:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,#322f2a,#23201d);box-shadow:inset 0 1px #ffffff0f,0 2px 8px #0000001f}.customer-meal-header.breakfast{border-left-color:#5bc48a;border-top:2px solid #5BC48A}.customer-meal-header.lunch{border-left-color:#e87d5a;border-top:2px solid #E87D5A;border-top-style:double}.customer-meal-header.dinner{border-left-color:#f5c842;border-top:2px dashed #F5C842}.customer-meal-header .pill-brass{background:#fff;color:#000;border:1px solid rgba(0,0,0,.12);font-weight:700}.dish-card.meal-breakfast{border-top:3px solid #5BC48A}.dish-card.meal-lunch{border-top:3px solid #E87D5A}.dish-card.meal-dinner{border-top:3px solid #F5C842}.meal-badge.breakfast{border-color:#5bc48a}.meal-badge.lunch{border-color:#e87d5a}.meal-badge.dinner{border-color:#f5c842}.dish-card-dietary{display:flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.dish-card-dietary.veg{color:#2e7d32}.dish-card-dietary.non-veg{color:#c62828}.dish-card-dietary.staple{color:#8d6e63}.dish-card-dietary svg{width:14px;height:14px}.customer-dish-list{display:flex;flex-direction:column;gap:14px}.customer-dish-group{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;background:#ffffffd1}.customer-dish-group-title{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--surface-sunken);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}.customer-dish-group-items{display:flex;flex-direction:column}.customer-dish-row{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-top:1px solid rgba(0,0,0,.05)}.customer-dish-group-items .customer-dish-row:first-child{border-top:0}.customer-dish-row.in-cart{background:#fffbf2}.customer-dish-row-main{min-width:0;flex:1}.customer-dish-row-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.customer-dish-row-name{font-family:var(--font-body);font-size:1rem;font-weight:700;line-height:1.25;color:var(--charcoal)}.customer-dish-row-price{font-size:1rem;font-weight:800;color:var(--saffron);white-space:nowrap}.customer-dish-row-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;font-size:.75rem;font-weight:600;color:var(--ink-muted)}.customer-dish-row-meta span:before{content:"•";margin-right:8px}.customer-dish-row-meta span:first-child:before{content:"";margin-right:0}.customer-dish-row-desc{margin-top:5px;font-size:.8rem;line-height:1.4;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.customer-dish-row-actions{flex-shrink:0;display:flex;align-items:center}.customer-dish-add-btn{min-height:40px;padding:0 14px}.cart-summary-row{display:flex;justify-content:space-between;padding:4px 0;font-size:.9rem}.cart-summary-row.total{border-top:1px solid var(--border-subtle);margin-top:8px;padding-top:12px;font-weight:700;font-size:1.1rem;color:var(--ink)}.allocated-slot-badge{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--success-soft);color:var(--success);border-radius:var(--radius-md);font-size:.85rem;font-weight:600;border:1px solid rgba(61,139,110,.2)}.allocated-slot-badge svg{width:16px;height:16px}.tour-focus-ring{position:relative;box-shadow:0 0 0 3px #fffffff5,0 0 0 8px #d47b002e,0 18px 40px #11182724}.tour-focus-ring:before{content:"";position:absolute;inset:-4px;border-radius:inherit;background:linear-gradient(90deg,#d47b002e,#d47b00fa,#d47b002e) 0 0 / 220% 3px no-repeat,linear-gradient(180deg,#d47b002e,#d47b00fa,#d47b002e) 100% 0 / 3px 220% no-repeat,linear-gradient(270deg,#d47b002e,#d47b00fa,#d47b002e) 100% 100% / 220% 3px no-repeat,linear-gradient(0deg,#d47b002e,#d47b00fa,#d47b002e) 0 100% / 3px 220% no-repeat;animation:tourFocusFlow 2.2s linear infinite}@keyframes tourFocusFlow{0%{background-position:0 0,100% 0,100% 100%,0 100%}to{background-position:100% 0,100% 100%,0 100%,0 0}}@media(max-width:768px){.day-select-header{top:calc(var(--header-height) + var(--customer-day-nav-offset, 74px));display:grid;grid-template-columns:1fr auto;align-items:center;gap:var(--space-sm)}.day-select-title{width:auto;justify-content:flex-start}.day-select-pill{justify-self:end;align-self:center;margin:0}.day-select-actions{grid-column:1 / -1;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm);align-items:stretch}.day-select-btn{width:100%;min-height:42px;font-size:.85rem;justify-content:center}}
