:root{--bg: #f9fafb;--surface: #ffffff;--surface2: #f3f4f6;--surface-muted: #f4f6f5;--border: #e5e7eb;--text: #111827;--muted: #6b7280;--teal: #2fae9b;--teal-dark: #008c7f;--teal-deep: #007063;--teal-footer: #0a5c52;--yellow: #f4d34a;--yellow-deep: #c9890a;--amber: #ffa537;--accent: var(--teal);--accent-hover: var(--teal-dark);--success: #48bb78;--error: #ef4444;--radius: 12px;--radius-lg: 16px;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--line-height: 1.35;--line-height-tight: 1.2;--page-pad: .75rem;--page-pad-x: .875rem;--card-pad: .875rem;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow: 0 4px 24px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .06)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Poppins,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:var(--line-height);min-height:100vh;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{line-height:var(--line-height-tight)}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer;border:none;border-radius:var(--radius);padding:.625rem 1rem;font-weight:600;font-size:.9rem;transition:background .15s,transform .1s,box-shadow .15s}button:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff;width:100%;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--accent-hover)}.btn-cta{background:linear-gradient(to right,var(--yellow),#f59e0b);color:#111827;width:100%;font-weight:700;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.btn-cta:hover{background:linear-gradient(to right,#fde68a,#f59e0b)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface2);border-color:#d1d5db}.btn-link{background:none;color:var(--accent);padding:.5rem 0;width:100%;font-weight:500;box-shadow:none}.btn-link:hover:not(:disabled){color:var(--accent-hover);text-decoration:underline}.btn-link:disabled{color:var(--muted);cursor:not-allowed}input,select,textarea{font-family:inherit;font-size:.9375rem;padding:.625rem .875rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface2);color:var(--text);width:100%;line-height:var(--line-height-tight)}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:0;border-color:var(--accent);background:var(--surface)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--card-pad);box-shadow:var(--shadow-sm)}.layout{max-width:1200px;margin:0 auto;padding:var(--page-pad)}.nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0;margin-bottom:var(--space-lg);border-bottom:1px solid var(--border)}.nav-brand{font-size:1.125rem;font-weight:700;background:linear-gradient(to right,var(--teal),var(--yellow-deep));-webkit-background-clip:text;background-clip:text;color:transparent}.nav-links{display:flex;gap:1rem;align-items:center}.form-group{margin-bottom:var(--space-md)}.form-group label{display:block;margin-bottom:.25rem;font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.phone-input-row{display:flex;gap:.5rem}.phone-input-row .phone-country-code{width:4.75rem;flex-shrink:0;text-align:center}.phone-input-row .phone-number{flex:1;min-width:0}.error-msg{color:var(--error);font-size:.875rem;margin-top:.5rem}.success-msg{color:var(--success);font-size:.875rem;margin-top:.5rem}.grid{display:grid;gap:var(--space-md)}@media(min-width:640px){.grid-2{grid-template-columns:repeat(2,1fr)}}.badge{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;background:var(--surface2);color:var(--muted)}.badge-active{background:#48bb7826;color:var(--success)}.pill-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem 1rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(to right,#fff4c6,#e6f7f4,#dff6ff);border:1px solid var(--yellow);color:var(--text);box-shadow:var(--shadow-sm)}.brand-gradient{background:linear-gradient(to right,var(--teal),var(--yellow-deep));-webkit-background-clip:text;background-clip:text;color:transparent}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(180deg,var(--surface-muted) 0%,var(--bg) 100%)}.login-card{width:100%;max-width:400px}.login-card h1{font-size:1.5rem;font-weight:800;margin-bottom:var(--space-xs)}.login-card p{color:var(--muted);margin-bottom:var(--space-lg);line-height:var(--line-height)}.menu-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--border)}.menu-item:last-child{border-bottom:none}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.stat-card{text-align:center}.stat-card .value{font-size:2rem;font-weight:800;color:var(--accent)}.stat-card .label{font-size:.8rem;color:var(--muted)}.tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap}.tab{padding:.5rem 1rem;background:var(--surface2);border-radius:var(--radius);color:var(--muted);font-size:.875rem;border:1px solid var(--border)}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.listing-disclaimer{margin-top:2rem;padding:1rem;font-size:.8125rem;color:var(--muted);border-top:1px solid var(--border);line-height:1.5}.listing-terms-body{font-size:.8125rem;color:var(--muted);line-height:1.5}.listing-terms-body ul{margin:.35rem 0 0 1.1rem;padding:0}.listing-terms-check{display:flex;align-items:flex-start;gap:.5rem;margin-top:.75rem;font-size:.875rem;cursor:pointer}.btn-sm{padding:.35rem .625rem;font-size:.8rem;width:auto;border-radius:10px}.user-shell{min-height:100vh;display:flex;flex-direction:column;max-width:1200px;margin:0 auto;background:var(--bg)}.user-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--page-pad-x);background:#ffffffbf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.4);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:40}.user-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.user-greeting{font-size:.875rem;font-weight:600;color:var(--muted);white-space:nowrap}@media(max-width:480px){.user-greeting{display:none}}.user-main{flex:1;padding:var(--page-pad) var(--page-pad-x);padding-bottom:4.25rem}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);padding:.3rem 0;max-width:1200px;margin:0 auto;box-shadow:0 -2px 12px #0000000d;z-index:40}.bottom-nav-link{flex:1;text-align:center;padding:.35rem;color:var(--muted);font-size:.75rem;font-weight:600;line-height:var(--line-height-tight)}.bottom-nav-link.active{color:var(--accent)}.hub-grid{display:grid;gap:var(--space-md)}@media(min-width:640px){.hub-grid{grid-template-columns:repeat(2,1fr)}}.hub-card{display:block;transition:border-color .15s,box-shadow .15s,transform .15s}.hub-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.hub-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xs)}.hub-card h2{font-size:1.1rem;font-weight:700}.hub-card p{font-size:.875rem;color:var(--muted);line-height:var(--line-height)}.page-intro{margin-bottom:var(--space-md)}.page-intro h1{font-size:1.25rem;margin-bottom:var(--space-xs)}.page-intro p{color:var(--muted);font-size:.875rem;line-height:var(--line-height)}.page-title{font-size:1.25rem;margin-bottom:var(--space-sm)}.section-title{font-size:1rem;font-weight:700;color:var(--text);margin:var(--space-md) 0 var(--space-sm);line-height:var(--line-height-tight)}.page-header-row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md)}.page-header-row h1{font-size:1.25rem;margin-bottom:.125rem}.page-header-row p{font-size:.875rem;line-height:var(--line-height)}.re-hero{margin:calc(-1 * var(--page-pad)) calc(-1 * var(--page-pad-x)) var(--space-lg);padding:1.5rem var(--page-pad-x);background:linear-gradient(135deg,var(--teal-deep) 0%,var(--teal) 55%,#00bca6 100%);color:#fff;border-radius:0 0 var(--radius-lg) var(--radius-lg)}.re-hero h1{font-size:clamp(1.5rem,5vw,2.125rem);font-weight:800;line-height:1.1;margin:var(--space-sm) 0}.re-hero-sub{font-size:.875rem;color:#ffffffeb;max-width:28rem;line-height:var(--line-height)}.re-hero .brand-gradient{background:linear-gradient(to right,var(--yellow),#fde68a);-webkit-background-clip:text;background-clip:text;color:transparent}.re-page-intro{margin-bottom:var(--space-md)}.re-page-intro h1{font-size:1.25rem;font-weight:800;margin-bottom:var(--space-xs)}.re-page-intro p{color:var(--muted)}.listing-toolbar{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.listing-toolbar-group{display:flex;flex-direction:column;gap:var(--space-xs)}.listing-toolbar-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.broker-profile-card{margin:var(--space-sm) 0 var(--space-md);padding:var(--space-sm)}.broker-profile-row{display:flex;gap:var(--space-sm);align-items:center}.broker-avatar-btn{border:none;padding:0;background:none;cursor:pointer;border-radius:999px}.broker-avatar{width:4rem;height:4rem;border-radius:999px;object-fit:cover;display:block}.broker-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:var(--teal);color:#fff;font-weight:700;font-size:1.25rem}.admin-sidebar-profile .broker-profile-card{background:#ffffff0f;border-color:#ffffff1f}.admin-sidebar-profile strong,.admin-sidebar-profile p{color:#ffffffeb}.admin-sidebar-profile p{opacity:.8}.filter-chips{display:flex;flex-wrap:wrap;gap:.5rem}.filter-chip{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:999px;padding:.35rem .75rem;font-size:.8125rem;cursor:pointer}.filter-chip.active{border-color:var(--teal);background:color-mix(in srgb,var(--teal) 12%,var(--surface));color:var(--teal-deep);font-weight:600}.discovery-grid{display:grid;gap:var(--space-md)}@media(min-width:640px){.discovery-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:960px){.discovery-grid{grid-template-columns:repeat(3,1fr)}}.discovery-card{display:block;padding:0;overflow:hidden;transition:box-shadow .2s,transform .2s}.discovery-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.discovery-image{width:100%;height:132px;object-fit:cover;display:block}.discovery-image-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e6f7f4,#fff4c6);font-size:2rem;font-weight:700;color:var(--teal)}.discovery-card-body{padding:var(--space-md)}.discovery-card-body h3{font-size:.975rem;font-weight:700;color:var(--text);line-height:var(--line-height-tight)}.discovery-tags{font-size:.75rem;font-weight:600;color:var(--teal);margin-top:.125rem}.discovery-meta{font-size:.75rem;color:var(--muted);margin-top:.125rem;line-height:var(--line-height)}.webview-page{display:flex;flex-direction:column;height:calc(100vh - 8rem);margin:-1rem}.webview-header{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-bottom:1px solid var(--border);flex-wrap:wrap;background:var(--surface)}.webview-header h1{font-size:1.1rem}.webview-subtitle{font-size:.8rem;color:var(--muted)}.webview-back{font-size:.875rem;white-space:nowrap}.webview-frame{flex:1;width:100%;border:none;background:#fff;min-height:0}.webview-footer{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem;border-top:1px solid var(--border);background:var(--surface);text-align:center}.webview-footer p{margin:0;font-size:.8rem;color:var(--muted)}.restaurant-menu-page{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:5rem}.restaurant-menu-hero h1{margin-bottom:.25rem}.restaurant-menu-tagline{color:var(--muted);margin:.25rem 0}.restaurant-menu-address{font-size:.875rem;color:var(--muted)}.restaurant-menu-list ul{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.75rem}.restaurant-menu-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:.875rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.restaurant-menu-item p{margin:.25rem 0 0;font-size:.85rem;color:var(--muted)}.restaurant-menu-cta{display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.restaurant-menu-note{font-size:.8rem;color:var(--muted);text-align:center;margin:0}.admin-shell{display:flex;min-height:100vh}.admin-sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:var(--space-lg) var(--space-md)}.admin-sidebar-brand{font-weight:800;background:linear-gradient(to right,var(--teal),var(--yellow-deep));-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:var(--space-lg);font-size:.95rem}.admin-sidebar-nav{display:flex;flex-direction:column;gap:.25rem;flex:1}.admin-nav-link{padding:.45rem .625rem;border-radius:var(--radius);color:var(--muted);font-size:.85rem;line-height:var(--line-height-tight)}.admin-nav-link.active{background:#2fae9b1f;color:var(--teal-deep);font-weight:600}.admin-sidebar-footer{display:flex;flex-direction:column;gap:.75rem;font-size:.85rem}.admin-user-email{color:var(--muted);word-break:break-all}.admin-main{flex:1;padding:var(--space-lg);overflow:auto;background:var(--bg)}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem;background:var(--surface);border-radius:var(--radius);overflow:hidden}.admin-table th,.admin-table td{text-align:left;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border);line-height:var(--line-height-tight)}.admin-table th{color:var(--muted);font-weight:600;background:var(--surface2)}.admin-table-actions{display:flex;gap:.5rem;white-space:nowrap}.truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-pill{white-space:nowrap;margin-top:.25rem}.category-chips{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-md)}.chip{padding:.4rem .85rem;border-radius:999px;background:var(--surface);color:var(--muted);font-size:.85rem;font-weight:600;border:1px solid var(--border)}.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.segmented{display:inline-flex;gap:.25rem;padding:.25rem;background:var(--surface2);border-radius:var(--radius);border:1px solid var(--border)}.segmented button{width:auto;padding:.5rem 1rem;background:transparent;color:var(--muted);font-size:.875rem;box-shadow:none}.segmented button.active{background:var(--accent);color:#fff}.grocery-product-card{padding:0;overflow:hidden}.grocery-price{margin-top:.35rem;font-weight:700;color:var(--teal-deep)}.grocery-unit{font-weight:500;color:var(--muted);font-size:.85rem}.cart-line{display:grid;gap:var(--space-sm)}.cart-line-actions{display:flex;gap:.5rem;align-items:center}.qty-input{width:4rem;padding:.5rem}.slot-list{display:flex;flex-direction:column;gap:.5rem}.slot-option{display:flex;gap:.5rem;align-items:center;font-size:.9rem;cursor:pointer}.slot-option input{width:auto}@media(max-width:480px){:root{--page-pad: .625rem;--page-pad-x: .75rem;--card-pad: .75rem}.user-main{padding-bottom:3.75rem}.re-hero{padding:1.125rem var(--page-pad-x)}.discovery-image{height:120px}}@media(max-width:768px){.admin-shell{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border)}.admin-sidebar-nav{flex-direction:row;flex-wrap:wrap}}
