:root{--bg-color:#f6f8fb;--surface-color:#fff;--primary-color:#0038b8;--primary-hover:#002882;--gold-accent:#d4af37;--text-dark:#0f172a;--text-light:#64748b;--border-color:#e2e8f0;--header-bg:#fff;--sidebar-bg:#fff;--map-bg:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-hover:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--radius-md:.75rem;--radius-lg:1rem;--radius-full:9999px;--header-height:72px;--sidebar-width:420px;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--type-restaurant:#0038b8;--type-grocery:#1062b9;--type-delivery:#4a90e2;--type-bakery:#d4af37;--type-cafe:#8a6c22;--badge-restaurant-bg:#0038b81a;--badge-grocery-bg:#1062b91a;--badge-delivery-bg:#4a90e21a;--badge-bakery-bg:#d4af371a;--badge-cafe-bg:#8a6c221a}[data-theme=dark]{--bg-color:#0b1120;--surface-color:#162032;--primary-color:#3b82f6;--primary-hover:#60a5fa;--gold-accent:#facc15;--text-dark:#f8fafc;--text-light:#cbd5e1;--border-color:#334155;--header-bg:#162032;--sidebar-bg:#162032;--map-bg:#0f172a;--shadow-sm:0 1px 2px 0 #0000004d;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0006;--shadow-lg:0 10px 15px -3px #0006, 0 4px 6px -4px #0006;--shadow-hover:0 20px 25px -5px #00000080, 0 8px 10px -6px #00000080;--type-restaurant:#93c5fd;--type-grocery:#93c5fd;--type-delivery:#bfdbfe;--type-bakery:#fde047;--type-cafe:#fde047;--badge-restaurant-bg:#60a5fa40;--badge-grocery-bg:#60a5fa40;--badge-delivery-bg:#93c5fd40;--badge-bakery-bg:#facc1540;--badge-cafe-bg:#eab30840}*{box-sizing:border-box;margin:0;padding:0}html{width:100%;max-width:100vw;overflow:hidden}body{background-color:var(--bg-color);color:var(--text-dark);-webkit-font-smoothing:antialiased;width:100%;max-width:100vw;height:100dvh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;overflow:hidden}h1,h2,h3,h4,h5,h6,.card-title,.modal-header h2,.logo-area h1{letter-spacing:-.02em;font-family:Outfit,system-ui,-apple-system,sans-serif}.logo-area{align-items:center;gap:.75rem;display:flex}.logo-area h1{letter-spacing:-.025em;color:var(--primary-color);font-size:1.25rem;font-weight:800}.app-container{width:100%;max-width:100vw;height:100dvh;display:block;position:relative;overflow:hidden}.nav-rail{background:var(--sidebar-bg);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-lg);z-index:1002;border:1px solid #fff6;flex-direction:column;align-items:center;gap:1rem;width:4rem;height:calc(100dvh - 2rem);padding:1rem 0;display:flex;position:absolute;top:1rem;left:1rem;box-shadow:0 10px 40px #0000001a}[data-theme=dark] .nav-rail{border:1px solid #ffffff0d;box-shadow:0 10px 40px #00000080}.nav-btn{color:var(--text-light);border-radius:var(--radius-md);cursor:pointer;width:3rem;height:3rem;transition:all var(--transition-fast);background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;display:flex}.nav-btn span{font-size:.65rem;font-weight:600}.nav-btn:hover{color:var(--primary-color);background:#0038b80d}.nav-btn.active{color:var(--primary-color);background:#0038b81a}[data-theme=dark] .nav-btn:hover,[data-theme=dark] .nav-btn.active{color:var(--primary-color);background:#3b82f626}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-lg);z-index:1001;height:calc(100dvh - 2rem);transition:transform var(--transition-normal);border:1px solid #fff6;flex-direction:column;display:flex;position:absolute;top:1rem;left:5.75rem;overflow:hidden;box-shadow:0 10px 40px #0000001a}[data-theme=dark] .sidebar{border:1px solid #ffffff0d;box-shadow:0 10px 40px #00000080}.sidebar-header{border-bottom:1px solid var(--border-color);flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.search-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:var(--text-light);pointer-events:none;position:absolute;left:1rem}.search-input{background:var(--bg-color);border-radius:var(--radius-md);width:100%;color:var(--text-dark);transition:all var(--transition-fast);border:1px solid #0000;padding:.75rem 2.5rem .75rem 2.75rem;font-size:.875rem}.search-input:focus{background:var(--surface-color);border-color:var(--primary-color);outline:none;box-shadow:0 0 0 4px #0038b81a}.clear-search-btn{color:var(--text-light);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.25rem;display:flex;position:absolute;right:.75rem}.clear-search-btn:hover{background:var(--border-color);color:var(--text-dark)}.filters-scroll{margin:0 -1.25rem;padding:0 1.25rem}.filters{flex-wrap:wrap;gap:.5rem;padding-bottom:2px;display:flex}.filter-btn{white-space:nowrap;border-radius:var(--radius-full);background:var(--bg-color);color:var(--text-light);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;padding:.5rem 1.25rem;font-size:.8125rem;font-weight:600;box-shadow:0 2px 5px #00000005}.filter-btn:hover{color:var(--primary-color);background:#0038b80d}.filter-btn.active{background:var(--primary-color);color:#fff;border-color:#0000}.secondary-filters{align-items:center;gap:.75rem;display:flex}.kosher-select{border-radius:var(--radius-md);border:1px solid var(--border-color);cursor:pointer;background:var(--bg-color);min-width:0;color:var(--text-dark);text-overflow:ellipsis;appearance:none;transition:all var(--transition-fast);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='%23d4af37' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:16px;flex:1;padding:.5rem 2rem .5rem .75rem;font-size:.8125rem;font-weight:500;overflow:hidden}.kosher-select:focus{border-color:var(--gold-accent);outline:none;box-shadow:0 0 0 3px #d4af3733}.theme-toggle-btn{background:var(--bg-color);border:1px solid var(--border-color);color:var(--text-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:.5rem;display:flex}.theme-toggle-btn:hover{color:var(--text-dark);border-color:var(--text-light)}.sun-icon{display:none}.moon-icon{display:block}[data-theme=dark] .sun-icon{display:block!important}[data-theme=dark] .moon-icon{display:none!important}.sidebar-content{flex:1;padding:1.25rem;overflow-y:auto}.view-container{display:none}.view-container.active{display:block}.card-list{flex-direction:column;gap:.75rem;display:flex}.card{background:var(--surface-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);border:1px solid #0000;position:relative;overflow:hidden;box-shadow:0 4px 15px #00000008}.card:hover{border-color:#d4af374d;transform:translateY(-2px)scale(1.02);box-shadow:0 8px 30px #0038b814}.card-content{padding:.875rem 1rem .875rem 1.25rem}.card-header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.card-title{color:var(--text-dark);font-size:.9375rem;font-weight:700;line-height:1.3}.card-rating{color:#f59e0b;border-radius:var(--radius-full);white-space:nowrap;background:#f59e0b1a;flex-shrink:0;align-items:center;gap:.25rem;padding:.15rem .5rem;font-size:.75rem;font-weight:700;display:inline-flex}.card-body{flex-direction:column;gap:.5rem;display:flex}.card-description,.popup-description{color:var(--text-light);-webkit-line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;margin-bottom:.25rem;font-size:.8125rem;line-height:1.4;display:-webkit-box;overflow:hidden}.popup-description{-webkit-line-clamp:3}.card-details{flex-direction:column;gap:.25rem;display:flex}.card-detail-row{color:var(--text-light);align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.card-detail-row svg{opacity:.6;flex-shrink:0}.badge{border-radius:var(--radius-full);text-transform:uppercase;padding:.2rem .5rem;font-size:.6875rem;font-weight:700}.badge.Restaurant{background:var(--badge-restaurant-bg);color:var(--type-restaurant)}.badge.Grocery{background:var(--badge-grocery-bg);color:var(--type-grocery)}.badge.Delivery{background:var(--badge-delivery-bg);color:var(--type-delivery)}.badge.Bakery{background:var(--badge-bakery-bg);color:var(--type-bakery)}.badge.Cafe{background:var(--badge-cafe-bg);color:var(--type-cafe)}.card-meta{color:var(--text-light);align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.card-cert{color:var(--gold-accent);border:1px dashed var(--gold-accent);text-transform:uppercase;letter-spacing:.02em;background:#d4af3714;border-radius:4px;align-items:center;gap:.35rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:700;display:inline-flex}.card-cert svg{opacity:1;flex-shrink:0}.card-cert-row{padding:.125rem 0}.card-actions{border-top:1px solid var(--border-color);background:var(--bg-color);gap:.5rem;padding:.625rem 1rem .625rem 1.25rem;display:flex}.card-action-btn{border-radius:var(--radius-full);transition:all var(--transition-fast);color:var(--primary-color);background:var(--surface-color);border:1px solid var(--border-color);align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:600;text-decoration:none;display:inline-flex}.card-action-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.map-area{background:var(--map-bg);z-index:1;position:absolute;inset:0}[data-theme=dark] .maplibregl-canvas{filter:brightness(.6)saturate(1.3)contrast(1.1)}.map-marker{cursor:pointer;width:26px;height:34px;position:absolute}.map-marker:before{content:"";background:var(--primary-color);border:2.5px solid #fff;border-radius:50% 50% 50% 0;width:26px;height:26px;transition:box-shadow .2s;position:absolute;top:0;left:0;transform:rotate(-45deg);box-shadow:0 2px 6px #4f46e566}.map-marker:after{content:"";background:#fff;border-radius:50%;width:8px;height:8px;position:absolute;top:6.5px;left:9px}.map-marker:hover:before{box-shadow:0 4px 14px #4f46e599}.maplibregl-popup-content{background:var(--surface-color);color:var(--text-dark);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:1rem}.maplibregl-popup-anchor-bottom .maplibregl-popup-tip{border-top-color:var(--surface-color)}.maplibregl-popup-anchor-top .maplibregl-popup-tip{border-bottom-color:var(--surface-color)}.maplibregl-popup-anchor-left .maplibregl-popup-tip{border-right-color:var(--surface-color)}.maplibregl-popup-anchor-right .maplibregl-popup-tip{border-left-color:var(--surface-color)}.maplibregl-popup-close-button{color:var(--text-light);padding:.25rem .5rem;font-size:1.25rem}.maplibregl-popup-close-button:hover{color:var(--text-dark);background:0 0}#map{width:100%;height:100%}.mobile-only{display:none}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;opacity:0;visibility:hidden;transition:all var(--transition-normal);background:#0f172a99;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;visibility:visible}.modal{background:var(--surface-color);border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:var(--shadow-lg);transition:all var(--transition-normal);overflow:visible;transform:translateY(20px)}.modal-overlay.open .modal{transform:translateY(0)}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;padding:1.5rem;display:flex}.modal-body{padding:1.5rem}.btn-primary{background:var(--primary-color);color:#fff;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-normal);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px)}.close-btn{color:var(--text-light);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:1.5rem;line-height:1}.close-btn:hover{color:var(--text-dark)}.modal-desc{margin-bottom:1.5rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-dark);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.form-group input,.form-group select{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-color);width:100%;color:var(--text-dark);transition:border-color var(--transition-fast);outline:none;padding:.625rem .75rem;font-family:inherit;font-size:.875rem}.form-group select{appearance:none;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='%23d4af37' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:16px;padding-right:2.5rem}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #0038b81a}.w-full{justify-content:center;width:100%}@media (width<=768px){.submit-text{display:none}.header h1{white-space:nowrap;text-overflow:ellipsis;font-size:1.25rem;overflow:hidden}.sidebar{z-index:2000;border:none;border-radius:0;width:100%;height:calc(100dvh - 4rem);position:absolute;top:0;left:0;transform:translate(0)}.fab-btn{display:none}.sidebar.hidden{pointer-events:none;transform:translate(-100%)}.nav-rail{z-index:2005;border:none;border-top:1px solid #fff3;border-radius:0;flex-direction:row;justify-content:space-around;width:100%;height:4rem;padding:0;top:auto;bottom:0;left:0}.nav-btn{border-radius:0;width:100%;height:100%}.sidebar-content{padding-bottom:2rem}.map-area{width:100%}.mobile-only{display:flex}}.notification-area{z-index:99999;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:2rem;right:2rem}.notification{background:var(--surface-color);color:var(--text-dark);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border-left:4px solid var(--primary-color);pointer-events:auto;min-width:300px;animation:slideInUp var(--transition-normal);align-items:center;gap:.75rem;padding:1rem 1.5rem;font-weight:600;display:flex}.notification.fading{animation:fadeOut var(--transition-normal) forwards}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}.notification.error{border-left-color:#ef4444}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.spinner{width:1.25rem;height:1.25rem;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.leaflet-popup-content-wrapper{border-radius:var(--radius-md);padding:0;overflow:hidden}.leaflet-popup-content{margin:0}.popup-inner{padding:1rem}.popup-title{margin-bottom:.25rem;font-weight:700}.custom-select-wrapper{-webkit-user-select:none;user-select:none;width:100%;position:relative}.custom-select-trigger{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-color);width:100%;color:var(--text-dark);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-overflow:ellipsis;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='%23d4af37' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:16px;align-items:center;min-height:2.5rem;padding:.625rem 2.5rem .625rem .75rem;font-family:inherit;font-size:.875rem;display:flex;overflow:hidden}.custom-select-trigger:focus,.custom-select-wrapper.open .custom-select-trigger{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #0038b81a}.sidebar .custom-select-trigger{background-position:right .5rem center;min-height:2rem;padding:.5rem 2rem .5rem .75rem;font-size:.8125rem;font-weight:500}.sidebar .custom-select-trigger:focus,.sidebar .custom-select-wrapper.open .custom-select-trigger{border-color:var(--gold-accent);box-shadow:0 0 0 3px #d4af3733}.custom-options{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:99999;opacity:0;visibility:hidden;pointer-events:none;max-height:250px;transition:all var(--transition-fast);position:absolute;top:calc(100% + .25rem);left:0;right:0;overflow-y:auto;transform:translateY(-5px)}.custom-select-wrapper.open .custom-options{opacity:1;visibility:visible;pointer-events:all;transform:translateY(0)}.custom-option{color:var(--text-dark);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);padding:.625rem 1rem;font-size:.875rem}.custom-option:hover{color:var(--primary-color);background:#0038b80d}.custom-option.selected{color:var(--primary-color);background:#d4af371a;font-weight:600}.custom-select-wrapper.open-upwards .custom-options{top:auto;bottom:calc(100% + .25rem);transform:translateY(5px)}.custom-select-wrapper.open-upwards.open .custom-options{transform:translateY(0)}.custom-select-search{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-color);width:calc(100% - 1rem);color:var(--text-dark);box-sizing:border-box;transition:border-color var(--transition-fast);outline:none;margin:.5rem;padding:.5rem;font-family:inherit;font-size:.8125rem}.custom-select-search:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #0038b81a}.maplibregl-ctrl-bottom-right{bottom:1.5rem;right:1.5rem}@media (width<=768px){.maplibregl-ctrl-bottom-right{bottom:5.5rem;right:1rem}}
