:root{--primary:#e94e1b;--primary-light:#ff784e;--primary-dark:#b93814;--primary-gradient:linear-gradient(135deg, #e94e1b 0%, #ff8a5b 100%);--secondary:#004e64;--secondary-light:#006680;--accent:#25a18e;--accent-light:#2fc4ab;--success:#10b981;--success-light:#d1fae5;--error:#ef4444;--error-light:#fee2e2;--warning:#f59e0b;--warning-light:#fef3c7;--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-200:#e5e5e5;--gray-300:#d4d4d4;--gray-400:#a3a3a3;--gray-500:#737373;--gray-600:#525252;--gray-700:#404040;--gray-800:#262626;--gray-900:#171717;--background:#fafafa;--surface:#ffffff;--surface-elevated:#ffffff;--text-primary:#171717;--text-secondary:#525252;--text-muted:#a3a3a3;--border:#e5e5e5;--divider:#f5f5f5;--shadow-xs:0 1px 2px rgba(0, 0, 0, 0.05);--shadow-sm:0 1px 3px rgba(0, 0, 0, 0.1), 0 1px 2px rgba(0, 0, 0, 0.06);--shadow-md:0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);--shadow-lg:0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);--shadow-xl:0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);--shadow-2xl:0 25px 50px -12px rgba(0, 0, 0, 0.25);--shadow-inner:inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--font-sans:-apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto,
    Oxygen, Ubuntu, sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--transition-fast:150ms cubic-bezier(0.4, 0, 0.2, 1);--transition-base:200ms cubic-bezier(0.4, 0, 0.2, 1);--transition-slow:300ms cubic-bezier(0.4, 0, 0.2, 1);--transition-spring:500ms cubic-bezier(0.34, 1.56, 0.64, 1);--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-modal-backdrop:400;--z-modal:500;--z-popover:600;--z-tooltip:700;--z-toast:800;--safe-top:env(safe-area-inset-top, 0px);--safe-bottom:env(safe-area-inset-bottom, 0px);--safe-left:env(safe-area-inset-left, 0px);--safe-right:env(safe-area-inset-right, 0px);--header-height:64px;--bottom-nav-height:64px;--container-max:1200px}[data-lucide]{width:24px;height:24px;stroke-width:2;display:inline-block;vertical-align:middle;flex-shrink:0}.icon-xs{width:14px;height:14px}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.icon-lg{width:28px;height:28px}.icon-xl{width:48px;height:48px}.icon-2xl{width:80px;height:80px}.icon-spin{animation:icon-spin 1s linear infinite}@keyframes icon-spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-meta{margin-bottom:var(--space-4)}.vendor-action-bar{margin-top:var(--space-2)}.icon-star-filled{fill:var(--warning);stroke:var(--warning)}.icon-star-empty{fill:none;stroke:var(--gray-300)}.icon-street-food{color:#ff6b35}.icon-vegetables{color:#25a18e}.icon-fruits{color:#e74c3c}.icon-snacks{color:#f39c12}.icon-beverages{color:#3498db}.icon-success{color:var(--success)}.icon-error{color:var(--error)}.icon-warning{color:var(--warning)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--background);color:var(--text-primary);line-height:1.5;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;overflow-x:hidden;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-bottom))}html,body{touch-action:manipulation;-ms-touch-action:manipulation}*{-webkit-user-select:none;-webkit-touch-callout:none;user-select:none}#add-map{width:100%;height:360px}input,textarea{-webkit-user-select:text;user-select:text}@media(min-width:768px){body{padding-bottom:0}}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:0 0}input,select,textarea{font-family:inherit;font-size:16px}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--space-4)}.header{position:sticky;top:0;z-index:var(--z-sticky);background:var(--surface);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(255,255,255,.95);padding-top:var(--safe-top)}.header.header-hero{position:absolute;top:0;left:0;right:0;background:0 0;border-bottom:none;backdrop-filter:none;-webkit-backdrop-filter:none;z-index:var(--z-sticky)}.header-content{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 var(--space-3);max-width:var(--max-width);margin:0 auto}.header-brand-hero{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;flex:1;min-width:0}.header-logo-hero{width:36px;height:36px;border-radius:var(--radius-md);flex-shrink:0;box-shadow:var(--shadow-md)}.header-title-hero{font-size:var(--font-size-lg);font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions-hero{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.header-btn-hero{width:44px;height:44px;border-radius:var(--radius-full);background:rgba(255,255,255,.15);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:#fff;transition:all var(--transition-fast)}.header-btn-hero:hover{background:rgba(255,255,255,.25);transform:scale(1.05);color:#fff}.header-btn-hero:active{transform:scale(.95)}.header-btn-hero-primary{background:var(--primary);border-color:var(--primary)}.header-btn-hero-primary:hover{background:var(--primary-light);border-color:var(--primary-light)}.header-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);color:var(--text-primary);transition:all var(--transition-fast);margin-right:var(--space-2);flex-shrink:0}.header-back:hover{background:var(--gray-100)}.header-back:active{transform:scale(.95);background:var(--gray-200)}.header-brand{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;flex:1;min-width:0}.header-logo{width:32px;height:32px;border-radius:var(--radius-md);flex-shrink:0}.header-title{font-size:var(--font-size-lg);font-weight:700;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.header-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);color:var(--text-secondary);transition:all var(--transition-fast)}.header-btn:hover{background:var(--gray-100);color:var(--text-primary)}.header-btn:active{transform:scale(.95)}.header-btn-primary{background:var(--primary-gradient);color:#fff}.header-btn-primary:hover{opacity:.9;color:#fff;background:var(--primary-gradient)}.header .container{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);gap:var(--space-4)}.logo{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;flex-shrink:0}.logo img{width:32px;height:32px;border-radius:var(--radius-md)}.logo-text{font-size:var(--font-size-lg);font-weight:700;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{display:flex;align-items:center;gap:var(--space-2)}.nav-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);transition:all var(--transition-fast)}.nav-link:hover{background:var(--gray-100);color:var(--text-primary)}.nav-link:active{transform:scale(.97)}.nav-link.btn-primary{background:var(--primary-gradient);color:#fff;padding:var(--space-2)var(--space-4)}.nav-link.btn-primary:hover{opacity:.9;background:var(--primary-gradient)}.btn-text{background:0 0;color:var(--text-secondary)}.btn-text:hover{color:var(--error);background:var(--error-light)}.user-greeting{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-3);background:var(--gray-100);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.user-greeting svg{color:var(--primary)}@media(max-width:640px){.nav-link:not(.btn-primary){display:none}.user-greeting{display:none}.header-title{font-size:var(--font-size-base)}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:var(--z-fixed);background:var(--surface);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);box-shadow:0 -4px 20px rgba(0,0,0,8%)}@media(max-width:767px){.bottom-nav{display:block}}.bottom-nav-items{display:flex;justify-content:space-around;align-items:center;height:var(--bottom-nav-height);padding:0 var(--space-2)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);border-radius:var(--radius-md);color:var(--text-muted);font-size:var(--font-size-xs);font-weight:500;transition:all var(--transition-fast);min-width:64px;-webkit-tap-highlight-color:transparent}.bottom-nav-item:active{transform:scale(.95)}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item.active svg{transform:scale(1.1)}.bottom-nav-item svg{transition:transform var(--transition-spring)}.fab{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--safe-bottom) + var(--space-4));right:var(--space-4);z-index:var(--z-fixed);width:56px;height:56px;border-radius:var(--radius-full);background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg),0 4px 14px rgba(255,107,53,.4);transition:all var(--transition-base)}.fab:hover{transform:scale(1.05);box-shadow:var(--shadow-xl),0 6px 20px rgba(255,107,53,.5)}.fab:active{transform:scale(.95)}@media(min-width:768px){.fab{display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3)var(--space-5);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 2px 8px rgba(255,107,53,.3)}.btn-primary:hover{box-shadow:0 4px 12px rgba(255,107,53,.4)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:2px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);background:rgba(255,107,53,5%)}.btn-ghost{background:0 0;color:var(--text-secondary)}.btn-ghost:hover{background:var(--gray-100);color:var(--text-primary)}.btn-large{padding:var(--space-4)var(--space-6);font-size:var(--font-size-lg);border-radius:var(--radius-lg)}.btn-small{padding:var(--space-2)var(--space-3);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn-block{width:100%}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius-full)}.btn-upvote,.btn-share,.btn-directions{background:var(--surface);border:1.5px solid var(--border);padding:var(--space-3)var(--space-4);border-radius:var(--radius-md);font-weight:500;color:var(--text-secondary)}.btn-upvote:hover{border-color:var(--primary);color:var(--primary);background:rgba(255,107,53,5%)}.btn-upvote.voted{background:linear-gradient( 135deg,rgba(255,107,53,.1),rgba(255,138,92,.1) );border-color:var(--primary);color:var(--primary)}.hero{background:var(--primary-gradient);padding:calc(var(--header-height) + var(--safe-top) + var(--space-6))0 var(--space-10);position:relative;overflow:hidden}.hero::before{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient( circle,rgba(255,255,255,.1) 0%,transparent 60% );pointer-events:none}.hero .container{position:relative;z-index:1}.hero h1{color:#fff;font-size:var(--font-size-3xl);font-weight:700;text-align:center;margin-bottom:var(--space-2);letter-spacing:-.02em}.hero p{color:rgba(255,255,255,.9);font-size:var(--font-size-base);text-align:center;margin-bottom:var(--space-6);max-width:500px;margin-left:auto;margin-right:auto}@media(min-width:768px){.hero{padding:calc(var(--header-height) + var(--safe-top) + var(--space-10))0 var(--space-16)}.hero h1{font-size:var(--font-size-4xl)}.hero p{font-size:var(--font-size-lg)}}.search-bar{display:flex;align-items:center;max-width:480px;margin:0 auto;background:#fff;border-radius:50px;box-shadow:0 4px 24px rgba(0,0,0,.12);padding:var(--space-1);padding-left:var(--space-4)}.search-bar-icon{width:20px;height:20px;color:var(--text-muted);flex-shrink:0}.search-bar input{flex:1;border:none;background:0 0;padding:var(--space-3);font-size:var(--font-size-base);outline:none;min-width:0}.search-bar input::placeholder{color:var(--text-muted)}.search-bar-btn{width:44px;height:44px;border:none;border-radius:50%;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.search-bar-btn:hover{background:var(--primary-dark,#e55a2b);transform:scale(1.05)}.search-bar-btn.active{background:var(--success,#25a18e)}.search-bar-btn.loading i{animation:spin 1s linear infinite}.search-bar-btn i{width:20px;height:20px}.radius-bar{display:none;align-items:center;justify-content:center;gap:var(--space-3);margin-top:var(--space-3);padding:var(--space-2)var(--space-4);background:rgba(255,255,255,.95);border-radius:50px;max-width:400px;margin-left:auto;margin-right:auto;animation:fadeSlideUp .25s ease-out}.radius-bar.show{display:flex}@keyframes fadeSlideUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.radius-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.radius-options{display:flex;gap:var(--space-1)}.radius-opt{padding:var(--space-1)var(--space-3);border:none;border-radius:50px;background:0 0;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .15s ease}.radius-opt:hover{background:rgba(255,107,53,.1);color:var(--primary)}.radius-opt.active{background:var(--primary);color:#fff}.radius-close{width:28px;height:28px;border:none;border-radius:50%;background:var(--background);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.radius-close:hover{background:var(--border);color:var(--text-primary)}.radius-close i{width:16px;height:16px}.load-more-container{display:flex;justify-content:center;padding:var(--space-4)0}.load-more-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3)var(--space-6);background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease}.load-more-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.load-more-btn:active{transform:scale(.98)}.load-more-btn .load-more-spinner{display:none;padding:0}.load-more-btn.htmx-request .load-more-text{display:none}.load-more-btn.htmx-request .load-more-spinner{display:flex}.load-more-spinner{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-6)var(--space-4);color:var(--text-muted);font-size:var(--font-size-sm)}.load-more-spinner .icon-spin,.spinning{animation:spin 1s linear infinite}.filters{background:var(--surface);padding:var(--space-3)0;padding-top:calc(var(--space-3) + var(--safe-top));border-bottom:1px solid var(--border);position:sticky;top:0;z-index:var(--z-sticky)}.filters-header{display:flex;align-items:center;margin-bottom:var(--space-3);opacity:0;max-height:0;overflow:hidden;transform:translateY(-10px);transition:opacity var(--transition-base),max-height var(--transition-base),transform var(--transition-base),margin var(--transition-base);margin-bottom:0}.filters.is-stuck .filters-header{opacity:1;max-height:50px;transform:translateY(0);margin-bottom:var(--space-3)}.filters-brand{display:flex;align-items:center;gap:var(--space-2);text-decoration:none}.filters-logo{width:32px;height:32px;border-radius:var(--radius-sm)}.filters-title{font-size:var(--font-size-lg);font-weight:700;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.filter-chips{display:flex;gap:var(--space-2);overflow-x:auto;padding:var(--space-1)0;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.filter-chips::-webkit-scrollbar{display:none}.chip{flex-shrink:0;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);background:var(--gray-100);border:2px solid transparent;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);scroll-snap-align:start;-webkit-tap-highlight-color:transparent}.chip:hover{background:var(--gray-200)}.chip:active{transform:scale(.97)}.chip.active{background:var(--primary-gradient);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(255,107,53,.3)}.chip.active svg{stroke:#fff}.chip svg{flex-shrink:0;transition:stroke var(--transition-fast)}.map-section{padding:var(--space-5)0;background:var(--gray-50)}.map-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.map-header h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin:0}.map-header h2 svg{color:var(--primary)}#map,#add-map,#detail-map{height:320px;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),0 0 0 1px rgba(0,0,0,5%);overflow:hidden;position:relative;z-index:1;isolation:isolate;background:linear-gradient(135deg,#f5f5f5 0%,#e8e8e8 100%)}#detail-map{height:220px}#add-map{height:300px;cursor:crosshair}#add-map .gm-style{cursor:crosshair!important}.map-instruction{position:absolute;bottom:var(--space-3);left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);background:rgba(0,0,0,.7);backdrop-filter:blur(8px);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:#fff;pointer-events:none;z-index:5;transition:opacity .3s ease}.map-instruction.hidden{opacity:0}@media(max-width:640px){#map{height:280px;border-radius:var(--radius-lg)}#add-map{height:260px}.map-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.map-header h2{font-size:var(--font-size-base)}.map-vendor-count{top:var(--space-2);left:var(--space-2);padding:var(--space-1)var(--space-2);font-size:var(--font-size-xs)}.custom-map-controls{margin:var(--space-2)!important}.map-control-btn{width:36px;height:36px}.vendor-popup{min-width:180px;max-width:240px;padding:12px 14px}}.map-control-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}#map,#add-map,#detail-map{transition:box-shadow .3s ease}.map-legend{position:absolute;bottom:var(--space-3);left:var(--space-3);display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2)var(--space-3);background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);font-size:11px;max-width:200px;z-index:5}.map-legend-item{display:flex;align-items:center;gap:4px;color:var(--text-secondary)}.map-legend-dot{width:10px;height:10px;border-radius:50%}@media(max-width:640px){.map-legend{display:none}}@media(min-width:768px){#map{height:420px}#detail-map{height:280px}}.map-loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fafafa 0%,#f0f0f0 100%);z-index:10;transition:opacity .3s ease}.map-loader.fade-out{opacity:0;pointer-events:none}.map-loader-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);color:var(--text-muted);font-size:var(--font-size-sm)}.map-loader-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.map-error{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);background:var(--gray-50);color:var(--text-muted)}.map-error svg{color:var(--gray-400)}.map-error p{margin:0;font-size:var(--font-size-sm)}.custom-map-controls{margin:var(--space-3)!important}.zoom-controls{display:flex;flex-direction:column;gap:2px;background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.recenter-control{margin-top:var(--space-2)!important}.map-control-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--surface);border:none;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast)}.map-control-btn:hover{background:var(--gray-100);color:var(--text-primary)}.map-control-btn:active{transform:scale(.95)}.recenter-btn{border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.recenter-btn.has-location{color:var(--primary)}.recenter-btn.has-location:hover{background:rgba(255,107,53,.1)}.map-vendor-count{position:absolute;top:var(--space-3);left:var(--space-3);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-3);background:var(--surface);border-radius:var(--radius-full);box-shadow:var(--shadow-md);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);opacity:0;transform:translateY(-10px);transition:all .3s ease;z-index:5}.map-vendor-count.show{opacity:1;transform:translateY(0)}.map-vendor-count svg{color:var(--primary)}.custom-marker{background:0 0!important;border:none!important}.marker-icon{width:40px;height:40px;border-radius:50% 50% 50% 0;cursor:pointer;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:transform var(--transition-spring)}.marker-icon:hover{transform:rotate(-45deg)scale(1.1)}.marker-icon svg{transform:rotate(45deg)}.user-marker{background:0 0;border:none}.user-location-pulse{width:20px;height:20px;background:var(--primary);border:3px solid #fff;border-radius:50%;box-shadow:var(--shadow-md);position:relative}.user-location-pulse::after{content:"";position:absolute;top:-3px;left:-3px;right:-3px;bottom:-3px;border:2px solid var(--primary);border-radius:50%;animation:pulse-ring 1.5s infinite}@keyframes pulse-ring{0%{transform:scale(1);opacity:1}100%{transform:scale(2.5);opacity:0}}.map-popup{min-width:160px}.map-popup h3{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--space-1);color:var(--text-primary)}.popup-category{color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-1)}.popup-rating{display:flex;align-items:center;gap:var(--space-1);font-weight:600;font-size:var(--font-size-sm)}.popup-distance{color:var(--primary);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--space-1)}.popup-link{display:inline-block;margin-top:var(--space-2);color:var(--primary);font-weight:600;font-size:var(--font-size-sm)}.gm-style .gm-style-iw-c{border-radius:16px!important;box-shadow:0 6px 24px rgba(0,0,0,.18)!important;padding:0!important}.gm-style .gm-style-iw-d{overflow:hidden!important;padding:0!important}.gm-style .gm-style-iw-tc::after{background:#fff!important}.gm-style-iw button[aria-label=Close]{top:8px!important;right:8px!important;width:26px!important;height:26px!important;background:#f5f5f5!important;border-radius:50%!important;opacity:1!important;display:flex!important;align-items:center!important;justify-content:center!important}.gm-style-iw button[aria-label=Close]:hover{background:#e5e5e5!important}.gm-style-iw button[aria-label=Close] span{margin:0!important}.vendor-popup{padding:14px 16px;min-width:200px;max-width:260px;font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,sans-serif}.popup-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.popup-category{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;color:#fff;text-transform:capitalize;letter-spacing:.3px}.popup-rating{font-size:12px;font-weight:700;color:#f59e0b;margin-left:auto}.popup-verified{color:#25a18e;font-size:14px;font-weight:700}.popup-title{display:block;font-size:16px;font-weight:700;color:#171717;text-decoration:none;margin-bottom:8px;line-height:1.35;transition:color .15s ease}.popup-title:hover{color:#e94e1b}.popup-specialties{font-size:12px;color:#737373;margin-bottom:6px;line-height:1.4}.popup-meta{font-size:12px;color:#525252;line-height:1.4}.leaflet-popup-content-wrapper{border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-xl)!important;padding:var(--space-3)var(--space-4)!important;background:var(--surface)!important}.leaflet-popup-content{margin:0!important;line-height:1.5}.leaflet-popup-close-button{top:10px!important;right:10px!important;color:var(--text-muted)!important;font-size:20px!important;width:24px!important;height:24px!important}.leaflet-popup-close-button:hover{color:var(--text-primary)!important}.leaflet-popup-tip-container{margin-top:-1px}.leaflet-popup-tip{box-shadow:var(--shadow-md)!important;background:var(--surface)!important}.vendors-section{padding:var(--space-6)0}.vendors-section h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-5);color:var(--text-primary)}.vendors-section h2 svg{color:var(--warning)}.vendor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-5)}@media(max-width:640px){.vendor-grid{grid-template-columns:1fr;gap:var(--space-4)}}.vendor-card{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent}.vendor-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}.vendor-card:active{transform:scale(.98)}.vendor-image{height:180px;position:relative;background:linear-gradient(135deg,var(--gray-100),var(--gray-50));overflow:hidden}.vendor-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.vendor-card:hover .vendor-image img{transform:scale(1.05)}.vendor-main-image .placeholder-image{background:0 0}.vendor-main-image .placeholder-image svg{width:96px;height:96px;stroke-width:1.5;opacity:.85;color:var(--primary)}@media(min-width:768px){.vendor-main-image{border-right:1px solid var(--border)}}.placeholder-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient( 135deg,rgba(255,107,53,8%),rgba(255,138,92,5%) );color:var(--primary)}.placeholder-image svg{opacity:.6}.placeholder-image.large{height:250px}.placeholder-image.large svg{width:80px;height:80px}.verified-badge{position:absolute;top:var(--space-3);right:var(--space-3);display:inline-flex;align-items:center;gap:var(--space-1);background:var(--success);color:#fff;padding:var(--space-1)var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;box-shadow:var(--shadow-sm)}.verified-badge.large{position:static;padding:var(--space-2)var(--space-3);font-size:var(--font-size-sm)}.vendor-info{padding:var(--space-4)}.vendor-name{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-1);color:var(--text-primary);line-height:1.3}.vendor-category{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--space-2)}.vendor-category svg{opacity:.7}.vendor-address,.vendor-timings{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--space-1);line-height:1.4}.vendor-address svg,.vendor-timings svg{flex-shrink:0;margin-top:2px}.vendor-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--divider)}.rating{display:flex;align-items:center;gap:var(--space-1)}.stars{display:flex;align-items:center;gap:var(--space-1);color:var(--warning);font-weight:600;font-size:var(--font-size-sm)}.review-count{color:var(--text-muted);font-size:var(--font-size-sm)}.no-rating{color:var(--text-muted);font-size:var(--font-size-sm)}.upvote-btn{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--gray-100);border:none;padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.upvote-btn:hover{background:rgba(255,107,53,.1);color:var(--primary)}.upvote-btn:active{transform:scale(.95)}.upvote-btn.voted{background:rgba(255,107,53,.15);color:var(--primary);cursor:default}.upvote-btn.voted:hover{background:rgba(255,107,53,.15);transform:none}.upvote-btn:disabled{cursor:not-allowed;opacity:.8}.back-link{display:inline-flex;align-items:center;gap:var(--space-2);margin:var(--space-4)0;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:color var(--transition-fast)}.back-link:hover{color:var(--primary)}.vendor-detail{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-6);box-shadow:var(--shadow-sm);border:1px solid var(--border)}@media(max-width:767px){.vendor-detail{margin-bottom:calc( var(--space-6) + var(--bottom-nav-height) + var(--space-4) )}}@media(min-width:768px){.vendor-detail{padding:var(--space-8)}}.vendor-header{display:grid;grid-template-columns:1fr;gap:var(--space-6);margin-bottom:var(--space-6)}@media(min-width:768px){.vendor-header{grid-template-columns:280px 1fr}}.vendor-main-image{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);height:300px;width:280px}@media(min-width:768px){.vendor-main-image{height:300px;width:280px}}.vendor-main-image img{width:100%;height:100%;object-fit:cover}.vendor-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-2)}.vendor-title-row h1{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary)}@media(min-width:768px){.vendor-title-row h1{font-size:var(--font-size-3xl)}}.vendor-category-tag{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--font-size-base);margin-bottom:var(--space-3)}.vendor-rating-large{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4)}.stars-large{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.vendor-description{color:var(--text-secondary);font-size:var(--font-size-base);line-height:1.7;margin-bottom:var(--space-5)}.vendor-meta{display:flex;flex-direction:column;gap:var(--space-3)}.vendor-meta p{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--font-size-base);color:var(--text-secondary)}.vendor-meta p svg{flex-shrink:0;margin-top:2px;color:var(--primary)}.vendor-meta strong{color:var(--text-primary)}.added-by{color:var(--text-muted);font-size:var(--font-size-sm);font-style:italic}.specialties{margin:var(--space-5)0}.specialties strong{display:block;margin-bottom:var(--space-2);color:var(--text-primary)}.specialty-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.specialty-tag{background:var(--gray-100);padding:var(--space-2)var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary)}.vendor-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-5)}.vendor-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);margin:var(--space-5)0}@media(min-width:640px){.vendor-stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);transition:all var(--transition-fast)}.stat-card:hover{border-color:var(--primary);background:rgba(255,107,53,3%)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.upvotes{background:linear-gradient( 135deg,rgba(255,107,53,.15),rgba(255,138,92,.1) );color:var(--primary)}.stat-icon.reviews{background:linear-gradient( 135deg,rgba(37,161,142,.15),rgba(47,196,171,.1) );color:var(--accent)}.stat-icon.rating{background:linear-gradient( 135deg,rgba(245,158,11,.15),rgba(251,191,36,.1) );color:var(--warning)}.stat-icon.community{background:linear-gradient( 135deg,rgba(0,78,100,.15),rgba(0,102,128,.1) );color:var(--secondary)}.stat-content{display:flex;flex-direction:column;gap:var(--space-1)}.stat-value{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary);line-height:1}.stat-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500}.vendor-additional-details{margin:var(--space-6)0;padding-top:var(--space-6);border-top:1px solid var(--border)}.vendor-additional-details h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-5);color:var(--text-primary)}.details-grid{display:grid;grid-template-columns:1fr;gap:var(--space-3)}@media(min-width:640px){.details-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.details-grid{grid-template-columns:repeat(3,1fr)}}.detail-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--border)}.detail-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--surface);color:var(--primary);border:1px solid var(--border)}.detail-icon.verified{background:var(--success-light);color:var(--success);border-color:var(--success)}.detail-icon.unverified{background:var(--warning-light);color:var(--warning);border-color:var(--warning)}.detail-icon.category-icon{background:linear-gradient( 135deg,rgba(255,107,53,.1),rgba(255,138,92,5%) );color:var(--primary)}.detail-content{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.detail-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500;word-break:break-word}.detail-value.coordinates{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;color:var(--primary);transition:color var(--transition-fast)}.detail-value.coordinates:hover{color:var(--primary-dark)}.detail-value.coordinates svg{flex-shrink:0;opacity:.7}.detail-value.verified-text{color:var(--success)}.detail-value.pending-text{color:var(--warning)}.rating-distribution{display:flex;flex-direction:column;gap:var(--space-5);background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5)}@media(min-width:640px){.rating-distribution{flex-direction:row;align-items:flex-start}}.rating-summary{text-align:center;padding-right:0;border-right:none;padding-bottom:var(--space-4);border-bottom:1px solid var(--border)}@media(min-width:640px){.rating-summary{padding-right:var(--space-6);border-right:1px solid var(--border);padding-bottom:0;border-bottom:none;min-width:140px}}.rating-big{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.rating-number{font-size:3rem;font-weight:700;color:var(--text-primary);line-height:1}.rating-stars-big{display:flex;gap:2px}.total-reviews{font-size:var(--font-size-sm);color:var(--text-muted)}.rating-bars{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.rating-bar-row{display:flex;align-items:center;gap:var(--space-2)}.star-label{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);width:12px;text-align:right}.rating-bar-track{flex:1;height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.rating-bar-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:var(--radius-full);width:0;transition:width .5s ease}.rating-count{font-size:var(--font-size-sm);color:var(--text-muted);min-width:24px;text-align:right}.vendor-map-section{margin:var(--space-6)0}.vendor-map-section h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-4)}.reviews-section{margin-top:var(--space-6)}.reviews-section h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-5)}.review-form-container{background:var(--gray-50);padding:var(--space-5);border-radius:var(--radius-lg);margin-bottom:var(--space-5);border:1px solid var(--border)}.review-form-container h3{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--space-4)}.star-rating{display:flex;flex-direction:row-reverse;justify-content:flex-end;gap:var(--space-1)}.star-rating input{display:none}.star-rating label{cursor:pointer;transition:color var(--transition-fast),filter var(--transition-fast)}.star-rating label svg{fill:var(--gray-300);stroke:var(--gray-300)}.star-rating label:hover svg,.star-rating label:hover~label svg{fill:var(--warning);stroke:var(--warning)}.star-rating input:checked~label svg{fill:var(--warning);stroke:var(--warning)}.review-card{background:var(--gray-50);padding:var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-3);border:1px solid var(--border);transition:all var(--transition-fast)}.review-card.new-review{animation:slideInUp .4s var(--transition-spring)}@keyframes slideInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.review-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.reviewer-name{font-weight:600;color:var(--text-primary)}.review-rating{display:flex;gap:2px}.review-comment{color:var(--text-secondary);font-size:var(--font-size-base);line-height:1.6;margin-bottom:var(--space-2)}.review-date{font-size:var(--font-size-xs);color:var(--text-muted)}.no-reviews{text-align:center;padding:var(--space-8);color:var(--text-muted)}.add-vendor-page{max-width:700px;margin:0 auto;padding:var(--space-6)0}.add-vendor-page h1{display:flex;align-items:center;justify-content:center;gap:var(--space-2);font-size:var(--font-size-2xl);text-align:center;margin-bottom:var(--space-2)}.subtitle{text-align:center;color:var(--text-secondary);margin-bottom:var(--space-6)}.vendor-form{background:var(--surface);padding:var(--space-5);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);border:1px solid var(--border)}@media(min-width:768px){.vendor-form{padding:var(--space-8)}}.form-section{margin-bottom:var(--space-6)}.form-section h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:2px solid var(--primary)}.form-group{margin-bottom:var(--space-5)}.form-group label{display:block;margin-bottom:var(--space-2);font-weight:500;font-size:var(--font-size-sm);color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-3)var(--space-4);border:2px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--surface);color:var(--text-primary);transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(255,107,53,.1)}.form-group textarea{resize:vertical;min-height:100px}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23737373' stroke-width='2'%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;background-size:18px;padding-right:44px}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.input-with-icon input{padding-left:var(--space-12)}.help-text{color:var(--text-muted);font-size:var(--font-size-sm);margin-bottom:var(--space-3)}.location-actions{margin-bottom:var(--space-4)}.form-actions{text-align:center;margin-top:var(--space-6)}.auth-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - var(--header-height) - 200px);min-height:calc(100dvh - var(--header-height) - 200px);padding:var(--space-6)var(--space-4)}.auth-card{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-lg);width:100%;max-width:420px;border:1px solid var(--border)}.auth-header{text-align:center;margin-bottom:var(--space-6)}.auth-icon{margin-bottom:var(--space-4);color:var(--primary)}.auth-header h1{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-2)}.auth-header p{color:var(--text-secondary)}.auth-footer{text-align:center;margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border)}.auth-footer p{color:var(--text-secondary)}.auth-footer a{color:var(--primary);font-weight:600}.alert{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4);animation:slideInUp .3s ease}.alert svg{flex-shrink:0}.alert-success{background:var(--success-light);color:#065f46;border:1px solid #a7f3d0}.alert-error{background:var(--error-light);color:#991b1b;border:1px solid #fecaca}.alert-warning{background:var(--warning-light);color:#92400e;border:1px solid #fde68a}.login-prompt{background:linear-gradient( 135deg,rgba(255,107,53,8%),rgba(255,138,92,5%) );border:2px solid var(--primary);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;margin-top:var(--space-6);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.login-prompt svg{color:var(--primary)}.login-prompt p{margin:0;color:var(--text-secondary)}.login-prompt a{color:var(--primary);font-weight:600}.empty-state{text-align:center;padding:var(--space-12)var(--space-4)}.empty-icon{margin-bottom:var(--space-4);color:var(--text-muted)}.empty-state h3{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-2)}.empty-state p{color:var(--text-muted);margin-bottom:var(--space-5)}.error-message{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-6);color:var(--error);font-weight:500}.error-page{text-align:center;padding:var(--space-16)var(--space-4)}.error-page .error-icon{font-size:5rem;margin-bottom:var(--space-4)}.error-page h1{font-size:var(--font-size-3xl);margin-bottom:var(--space-2)}.error-page p{color:var(--text-secondary);margin-bottom:var(--space-6)}.legal-page{padding:var(--space-4)0 var(--space-8);max-width:720px;margin:0 auto}.legal-page h2{font-size:var(--font-size-lg);margin-top:var(--space-6);margin-bottom:var(--space-2);color:var(--text-primary)}.legal-page p{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-3)}.legal-page ul{color:var(--text-secondary);padding-left:var(--space-6);margin-bottom:var(--space-3)}.legal-page li{margin-bottom:var(--space-2);line-height:1.6}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-8);color:var(--text-muted)}.spinner{animation:spin 1s linear infinite}@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton{background:linear-gradient( 90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75% );background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.toast{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--safe-bottom) + var(--space-4));left:50%;transform:translateX(-50%)translateY(100px);background:var(--gray-900);color:#fff;padding:var(--space-3)var(--space-5);border-radius:var(--radius-full);box-shadow:var(--shadow-xl);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);z-index:var(--z-toast);display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:500;max-width:calc(100vw - var(--space-8))}@media(min-width:768px){.toast{bottom:var(--space-6)}}.toast.show{transform:translateX(-50%)translateY(0);opacity:1}.dialog-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);opacity:0;transition:opacity var(--transition-base)}.dialog-backdrop.show{opacity:1}.custom-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)scale(.9);background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);z-index:var(--z-modal);width:calc(100% - var(--space-8));max-width:360px;opacity:0;transition:all var(--transition-base);overflow:hidden}.custom-dialog.show{opacity:1;transform:translate(-50%,-50%)scale(1)}.dialog-content{padding:var(--space-6);text-align:center}.dialog-icon{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4)}.dialog-icon.info{background:linear-gradient(135deg,rgba(52,152,219,.15),rgba(52,152,219,5%));color:#3498db}.dialog-icon.warning{background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(245,158,11,5%));color:var(--warning)}.dialog-icon.error{background:linear-gradient(135deg,rgba(239,68,68,.15),rgba(239,68,68,5%));color:var(--error)}.dialog-icon.confirm{background:linear-gradient(135deg,rgba(255,107,53,.15),rgba(255,107,53,5%));color:var(--primary)}.dialog-icon svg{width:28px;height:28px;stroke-width:2}.dialog-title{font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.dialog-message{font-size:var(--font-size-base);color:var(--text-secondary);line-height:1.6}.dialog-actions{display:flex;gap:var(--space-3);padding:var(--space-4)var(--space-6);background:var(--gray-50);border-top:1px solid var(--border)}.dialog-actions.single{justify-content:center}.dialog-btn{flex:1;padding:var(--space-3)var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:none}.dialog-btn:active{transform:scale(.97)}.dialog-btn-cancel{background:var(--surface);color:var(--text-secondary);border:1.5px solid var(--border)}.dialog-btn-cancel:hover{background:var(--gray-100);color:var(--text-primary)}.dialog-btn-confirm{background:var(--primary-gradient);color:#fff;box-shadow:0 2px 8px rgba(255,107,53,.3)}.dialog-btn-confirm:hover{box-shadow:0 4px 12px rgba(255,107,53,.4)}.dialog-btn-confirm.danger{background:linear-gradient(135deg,var(--error) 0%,#dc2626 100%);box-shadow:0 2px 8px rgba(239,68,68,.3)}.dialog-btn-confirm.danger:hover{box-shadow:0 4px 12px rgba(239,68,68,.4)}.install-banner{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--safe-bottom));left:0;right:0;background:var(--surface);padding:var(--space-4);display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--space-4);box-shadow:0 -4px 20px rgba(0,0,0,.1);z-index:var(--z-fixed);animation:slideUp .3s ease}@media(min-width:768px){.install-banner{bottom:0}}@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}.install-banner p{display:flex;align-items:center;gap:var(--space-2);margin:0;font-weight:500}.install-actions{display:flex;gap:var(--space-2)}.footer{background:#1a1a2e;color:#a0a0a0;padding:var(--space-10)0 var(--space-6);margin-top:auto}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-8);padding-bottom:var(--space-8);border-bottom:1px solid rgba(255,255,255,.1)}.footer-brand{max-width:280px}.footer-logo{display:inline-flex;align-items:center;gap:var(--space-2);text-decoration:none;margin-bottom:var(--space-3)}.footer-logo img{width:36px;height:36px;border-radius:var(--radius-md)}.footer-logo span{font-size:var(--font-size-xl);font-weight:700;color:#fff}.footer-desc{font-size:var(--font-size-sm);line-height:1.6;color:#8a8a8a;margin:0}.footer-links h4{color:#fff;font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.5px}.footer-links ul{list-style:none;padding:0;margin:0}.footer-links li{margin-bottom:var(--space-2)}.footer-links a{color:#8a8a8a;text-decoration:none;font-size:var(--font-size-sm);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--primary)}.footer-social{display:flex;gap:var(--space-3)}.footer-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:rgba(255,255,255,.1);border-radius:var(--radius-full);color:#8a8a8a;transition:all var(--transition-fast)}.footer-social a:hover{background:var(--primary);color:#fff}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-6)}.footer-tagline{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:#8a8a8a;margin:0}.footer-tagline a{color:var(--primary);font-weight:500;text-decoration:none}.footer-tagline a:hover{text-decoration:underline}.footer-heart{color:var(--primary)}.footer-copyright{font-size:var(--font-size-xs);color:#666;margin:0}@media(max-width:768px){.footer{display:none}}body.offline::before{content:"You are offline";position:fixed;top:calc(var(--header-height) + var(--safe-top));left:0;right:0;background:var(--warning);color:#fff;text-align:center;padding:var(--space-2);font-size:var(--font-size-sm);font-weight:500;z-index:var(--z-toast);animation:slideDown .3s ease}@keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.text-primary{color:var(--primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.mb-0{margin-bottom:0}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mt-0{margin-top:0}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}@media(max-width:767px){.main{padding-bottom:var(--space-4)}.footer{padding-bottom:calc( var(--space-8) + var(--bottom-nav-height) + var(--safe-bottom) )}}@media print{.header,.bottom-nav,.fab,.install-banner{display:none!important}body{padding-bottom:0}}.header-btn-admin{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.header-btn-admin:hover{opacity:.9;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.admin-dashboard{padding:var(--space-6)0}.admin-title{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-6);text-align:center}.admin-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}@media(min-width:768px){.admin-stats-grid{grid-template-columns:repeat(4,1fr)}}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);transition:all var(--transition-fast)}.admin-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-icon.users{background:linear-gradient( 135deg,rgba(99,102,241,.15),rgba(139,92,246,.1) );color:#6366f1}.admin-stat-icon.vendors{background:linear-gradient( 135deg,rgba(255,107,53,.15),rgba(255,138,92,.1) );color:var(--primary)}.admin-stat-icon.verified{background:linear-gradient( 135deg,rgba(16,185,129,.15),rgba(52,211,153,.1) );color:var(--success)}.admin-stat-icon.suspended{background:linear-gradient( 135deg,rgba(239,68,68,.15),rgba(248,113,113,.1) );color:var(--error)}.admin-stat-content{display:flex;flex-direction:column;gap:var(--space-1)}.admin-stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);line-height:1}.admin-stat-label{font-size:var(--font-size-sm);color:var(--text-muted)}.admin-actions-grid{display:flex;flex-direction:column;gap:var(--space-4)}.admin-action-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);text-decoration:none;transition:all var(--transition-fast)}.admin-action-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.admin-action-icon{width:56px;height:56px;background:linear-gradient( 135deg,rgba(255,107,53,.1),rgba(255,138,92,5%) );border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.admin-action-content{flex:1}.admin-action-content h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-1);color:var(--text-primary)}.admin-action-content p{font-size:var(--font-size-sm);color:var(--text-muted);margin:0}.admin-action-card>svg{color:var(--text-muted);flex-shrink:0}.admin-page{padding:var(--space-6)0}.admin-page-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-6)}@media(min-width:768px){.admin-page-header{flex-direction:row;align-items:center;justify-content:space-between}}.admin-page-header h1{font-size:var(--font-size-xl);font-weight:700;margin:0}.admin-search-form{display:flex;gap:var(--space-2)}.admin-search-form input{flex:1;min-width:200px;padding:var(--space-2)var(--space-3);border:2px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.admin-search-form input:focus{outline:none;border-color:var(--primary)}.admin-select{padding:var(--space-2)var(--space-3);border:2px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--surface);cursor:pointer}.admin-select:focus{outline:none;border-color:var(--primary)}.admin-table-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.admin-table{width:100%;border-collapse:collapse}.admin-table th,.admin-table td{padding:var(--space-3)var(--space-4);text-align:left;border-bottom:1px solid var(--border)}.admin-table th{background:var(--gray-50);font-weight:600;font-size:var(--font-size-sm);color:var(--text-secondary)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover{background:var(--gray-50)}.admin-address{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-vendor-link{color:var(--primary);font-weight:500}.admin-vendor-link:hover{text-decoration:underline}.admin-rating{display:inline-flex;align-items:center;gap:var(--space-1);font-weight:600}.admin-empty{text-align:center;color:var(--text-muted);padding:var(--space-8)!important}.admin-error{background:var(--error-light);color:#991b1b;padding:var(--space-4);border-radius:var(--radius-md);text-align:center}.admin-badge{display:inline-flex;align-items:center;padding:var(--space-1)var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600}.admin-badge-admin{background:linear-gradient( 135deg,rgba(99,102,241,.15),rgba(139,92,246,.1) );color:#6366f1}.admin-badge-user{background:var(--gray-100);color:var(--text-secondary)}.admin-badge-active{background:var(--success-light);color:#065f46}.admin-badge-suspended{background:var(--error-light);color:#991b1b}.admin-badge-verified{background:var(--success-light);color:#065f46}.admin-badge-pending{background:var(--warning-light);color:#92400e}.admin-protected{color:var(--text-muted);font-size:var(--font-size-xs);font-style:italic}.admin-actions-cell{display:flex;gap:var(--space-2);flex-wrap:wrap}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}.admin-controls{margin-top:var(--space-5);padding:var(--space-4);background:linear-gradient( 135deg,rgba(99,102,241,8%),rgba(139,92,246,4%) );border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-lg)}.admin-controls h4{font-size:var(--font-size-sm);font-weight:600;color:#6366f1;margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.admin-control-buttons{display:flex;flex-wrap:wrap;gap:var(--space-3)}.btn-delete-review{background:0 0;border:none;padding:var(--space-1);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);margin-left:auto}.btn-delete-review:hover{background:var(--error-light);color:var(--error)}.form-page{max-width:700px;margin:0 auto;padding:var(--space-6)0}.form-page h1{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-6);text-align:center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.form-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}@media(max-width:768px){.admin-table-container{overflow-x:auto}.admin-table{min-width:600px}.admin-table th,.admin-table td{padding:var(--space-2)var(--space-3);font-size:var(--font-size-sm)}}.vendor-detail-page{padding-bottom:0;background:var(--gray-50)}.vendor-hero{position:relative;height:320px;overflow:hidden}@media(min-width:768px){.vendor-hero{height:400px}}.hero-image-container{position:absolute;inset:0}.hero-image{width:100%;height:100%;object-fit:cover}.hero-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3)}.hero-gradient{position:absolute;inset:0;background:linear-gradient( to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.4) 50%,rgba(0,0,0,.2) 100% );pointer-events:none}.vendor-hero-header{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);padding-top:calc(var(--space-3) + var(--safe-top));z-index:10}.hero-back-btn,.hero-action-btn{width:44px;height:44px;border-radius:var(--radius-full);background:rgba(255,255,255,.15);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:#fff;transition:all var(--transition-fast)}.hero-back-btn:hover,.hero-action-btn:hover{background:rgba(255,255,255,.25);transform:scale(1.05)}.hero-back-btn:active,.hero-action-btn:active{transform:scale(.95)}.hero-header-actions{display:flex;gap:var(--space-2)}.hero-content{position:absolute;bottom:0;left:0;right:0;padding:var(--space-5);z-index:5}.hero-category-badge{display:inline-flex;align-items:center;gap:var(--space-1);background:rgba(255,255,255,.15);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.hero-title{font-size:var(--font-size-2xl);font-weight:800;color:#fff;margin-bottom:var(--space-2);text-shadow:0 2px 10px rgba(0,0,0,.3);line-height:1.2}@media(min-width:768px){.hero-title{font-size:var(--font-size-4xl)}}.hero-meta{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.hero-verified{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--success);color:#fff;padding:var(--space-1)var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.vendor-image .hero-verified{position:absolute;top:var(--space-2);right:var(--space-2);z-index:2}.hero-rating{display:inline-flex;align-items:center;gap:var(--space-1);color:#fff;font-size:var(--font-size-sm);font-weight:600}.hero-rating-count{opacity:.7;font-weight:400}.vendor-content{position:relative;margin-top:-24px;padding:0 var(--space-4);padding-bottom:calc(var(--bottom-nav-height) + var(--safe-bottom) + var(--space-6));max-width:800px;margin-left:auto;margin-right:auto}@media(min-width:768px){.vendor-content{padding-bottom:var(--space-8)}}.quick-stats-bar{display:flex;align-items:center;justify-content:center;gap:var(--space-4);background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-4)var(--space-5);box-shadow:var(--shadow-lg);margin-bottom:var(--space-4)}.quick-stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);flex:1}.quick-stat-value{font-size:var(--font-size-xl);font-weight:800;color:var(--text-primary);line-height:1}.quick-stat-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.quick-stat-divider{width:1px;height:32px;background:var(--border)}.vendor-action-bar{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.action-btn-wrapper{flex:1}.action-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-3)var(--space-2);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:var(--font-size-xs);font-weight:600;color:var(--text-secondary);transition:all var(--transition-fast);width:100%}.action-btn:hover{border-color:var(--primary);color:var(--primary);background:rgba(233,78,27,5%)}.action-btn:active{transform:scale(.97)}.action-btn-upvote{background:var(--primary-gradient);border-color:transparent;color:#fff}.action-btn-upvote:hover{opacity:.9;color:#fff;background:var(--primary-gradient);border-color:transparent}.action-btn-voted{background:var(--gray-100);border-color:var(--border);color:var(--text-muted);cursor:not-allowed}.action-btn-directions{color:var(--secondary)}.action-btn-directions:hover{border-color:var(--secondary);color:var(--secondary);background:rgba(0,78,100,5%)}.info-card,.location-card,.reviews-card,.details-card,.admin-card{background:var(--surface);border-radius:var(--radius-xl);padding:var(--space-5);margin-bottom:var(--space-4);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-header h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin:0}.vendor-description-text{font-size:var(--font-size-base);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-5)}.info-items{display:flex;flex-direction:column;gap:var(--space-3)}.info-item{display:flex;align-items:flex-start;gap:var(--space-3)}.info-icon{width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,rgba(233,78,27,.1) 0%,rgba(255,138,91,5%) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary)}.info-text{display:flex;flex-direction:column;gap:2px;min-width:0}.info-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500;word-break:break-word}.specialties-section{margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--border)}.specialties-label{display:block;font-size:var(--font-size-xs);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.specialties-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.specialty-chip{display:inline-flex;align-items:center;padding:var(--space-2)var(--space-3);background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600}.location-map{width:100%;height:200px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-3)}@media(min-width:768px){.location-map{height:280px}}.location-address{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--text-secondary);padding:var(--space-3);background:var(--gray-50);border-radius:var(--radius-md)}.location-address svg{color:var(--primary);flex-shrink:0}.copy-coords-btn{width:36px;height:36px;border-radius:var(--radius-md);background:var(--gray-100);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all var(--transition-fast)}.copy-coords-btn:hover{background:var(--gray-200);color:var(--text-primary)}.reviews-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 var(--space-2);background:var(--primary);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;margin-left:var(--space-2)}.rating-overview{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background:var(--gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}@media(min-width:480px){.rating-overview{flex-direction:row;align-items:center}}.rating-score{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding-right:var(--space-5);border-right:none;padding-bottom:var(--space-4);border-bottom:1px solid var(--border)}@media(min-width:480px){.rating-score{padding-bottom:0;border-bottom:none;border-right:1px solid var(--border);min-width:100px}}.rating-score-value{font-size:3rem;font-weight:800;color:var(--text-primary);line-height:1}.rating-score-stars{display:flex;gap:2px}.rating-score-total{font-size:var(--font-size-xs);color:var(--text-muted)}.rating-breakdown{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}@media(min-width:480px){.rating-breakdown{padding-left:var(--space-5)}}.rating-row{display:flex;align-items:center;gap:var(--space-2)}.rating-row-label{width:12px;font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-align:right}.rating-row-bar{flex:1;height:6px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.rating-row-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:var(--radius-full);width:0;transition:width .5s ease}.rating-row-count{width:20px;font-size:var(--font-size-xs);color:var(--text-muted);text-align:right}.review-form-section{padding:var(--space-5);background:var(--gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-5);border:1px solid var(--border)}.review-form-section h3{font-size:var(--font-size-base);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-4)}.star-rating-input{margin-bottom:var(--space-4)}.star-rating-label{display:block;font-size:var(--font-size-xs);color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.review-textarea-wrapper{margin-bottom:var(--space-4)}.review-textarea-wrapper textarea{width:100%;padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--font-size-base);resize:vertical;min-height:80px;transition:border-color var(--transition-fast)}.review-textarea-wrapper textarea:focus{outline:none;border-color:var(--primary)}.submit-review-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-5);background:var(--primary-gradient);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;transition:all var(--transition-fast)}.submit-review-btn:hover{opacity:.9;transform:translateY(-1px)}.submit-review-btn:active{transform:translateY(0)}.login-prompt-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6);background:var(--gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-5);text-align:center}.login-prompt-card svg{color:var(--text-muted)}.login-prompt-card p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.login-prompt-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);background:var(--primary-gradient);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;transition:all var(--transition-fast)}.login-prompt-btn:hover{opacity:.9}.reviews-list{display:flex;flex-direction:column;gap:var(--space-3)}.review-item{padding:var(--space-4);background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all var(--transition-fast)}.review-item:hover{border-color:var(--gray-300)}.review-item.new-review{animation:slideInUp .4s ease}.review-item-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.reviewer-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-base);font-weight:700;text-transform:uppercase;flex-shrink:0}.reviewer-info{flex:1;min-width:0}.reviewer-info .reviewer-name{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary)}.reviewer-info .review-date{display:block;font-size:var(--font-size-xs);color:var(--text-muted)}.review-item-rating{display:flex;gap:1px}.review-delete-btn{width:32px;height:32px;border-radius:var(--radius-md);background:0 0;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.review-delete-btn:hover{background:var(--error-light);color:var(--error)}.review-item-text{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6;margin:0}.no-reviews-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-8);text-align:center}.no-reviews-state svg{color:var(--text-muted);opacity:.5}.no-reviews-state p{font-size:var(--font-size-base);font-weight:600;color:var(--text-secondary);margin:0}.no-reviews-state span{font-size:var(--font-size-sm);color:var(--text-muted)}.details-list{display:flex;flex-direction:column}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3)0;border-bottom:1px solid var(--border)}.detail-row:last-child{border-bottom:none}.detail-row-label{font-size:var(--font-size-sm);color:var(--text-muted)}.detail-row-value{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-1)}.detail-row-value.status-verified{color:var(--success)}.detail-row-value.status-pending{color:var(--warning)}.detail-coords{cursor:pointer;color:var(--primary);transition:color var(--transition-fast)}.detail-coords:hover{color:var(--primary-dark)}.admin-card{background:linear-gradient(135deg,rgba(0,78,100,5%) 0%,rgba(0,102,128,2%) 100%);border-color:var(--secondary)}.admin-card .card-header h2{color:var(--secondary)}.admin-actions{display:flex;flex-direction:column;gap:var(--space-3)}@media(min-width:480px){.admin-actions{flex-direction:row}}.admin-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600;transition:all var(--transition-fast);text-decoration:none}.admin-btn-success{background:var(--success);color:#fff}.admin-btn-success:hover{background:#0ea572}.admin-btn-warning{background:var(--warning);color:#fff}.admin-btn-warning:hover{background:#e68f00}.admin-btn-edit{background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--border)}.admin-btn-edit:hover{background:var(--gray-200);color:var(--text-primary)}.image-upload-area{position:relative;width:100%;border-radius:var(--radius-lg);overflow:hidden}.upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-8);background:var(--gray-50);border:2px dashed var(--gray-300);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.upload-placeholder:hover{border-color:var(--primary);background:rgba(233,78,27,5%)}.upload-placeholder svg{color:var(--gray-400)}.upload-placeholder span{color:var(--text-secondary);font-size:var(--font-size-sm)}.upload-hint{color:var(--text-muted)!important;font-size:var(--font-size-xs)!important}.image-preview{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden}.image-preview img{width:100%;height:100%;object-fit:cover}.remove-image-btn{position:absolute;top:var(--space-2);right:var(--space-2);width:32px;height:32px;border-radius:var(--radius-full);background:rgba(0,0,0,.6);color:#fff;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);border:none;cursor:pointer}.remove-image-btn:hover{background:var(--error);transform:scale(1.1)}.upload-progress{padding:var(--space-4);text-align:center;background:var(--gray-50);border-radius:var(--radius-lg)}.progress-bar{height:4px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-2)}.progress-fill{height:100%;background:var(--primary-gradient);border-radius:var(--radius-full);transition:width .3s ease;width:0%}.progress-text{font-size:var(--font-size-sm);color:var(--text-secondary)}.review-images-section{margin-top:var(--space-4);margin-bottom:var(--space-4)}.review-images-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-2)}.review-images-upload{display:flex;gap:var(--space-2);flex-wrap:wrap}.add-image-btn{width:64px;height:64px;border:2px dashed var(--gray-300);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);color:var(--gray-400);background:0 0}.add-image-btn:hover{border-color:var(--primary);color:var(--primary)}.review-image-preview{position:relative;width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden}.review-image-preview img{width:100%;height:100%;object-fit:cover}.review-image-preview .remove-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:var(--radius-full);background:rgba(0,0,0,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;border:none;cursor:pointer;padding:0}.review-image-preview .remove-btn:hover{background:var(--error)}.review-image-preview.uploading{display:flex;align-items:center;justify-content:center;background:var(--gray-100)}.upload-spinner{width:24px;height:24px;border:2px solid var(--gray-300);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.review-images-hint{display:block;margin-top:var(--space-1);font-size:var(--font-size-xs);color:var(--text-muted)}.review-images{display:flex;gap:var(--space-2);margin-top:var(--space-3);overflow-x:auto;padding-bottom:var(--space-2)}.review-image-thumb{width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;cursor:pointer}.review-image-thumb img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-fast)}.review-image-thumb:hover img{transform:scale(1.05)}.gallery-counter{position:absolute;bottom:30px;right:var(--space-4);padding:var(--space-2)var(--space-3);background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border-radius:var(--radius-full);color:#fff;font-size:var(--font-size-sm);font-weight:600;display:flex;align-items:center;gap:var(--space-2);cursor:pointer;z-index:10;transition:all var(--transition-fast)}.gallery-counter:hover{background:rgba(0,0,0,.8)}#gallery-main-image{cursor:pointer}.gallery-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;align-items:center;justify-content:center}.gallery-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95)}.gallery-content{position:relative;z-index:1;width:100%;max-width:1e3px;height:100%;max-height:100vh;display:flex;flex-direction:column;padding:var(--space-4)}.gallery-close{position:absolute;top:var(--space-4);right:var(--space-4);width:44px;height:44px;border-radius:var(--radius-full);background:rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;z-index:10;transition:all var(--transition-fast);border:none;cursor:pointer}.gallery-close:hover{background:rgba(255,255,255,.2)}.gallery-main-view{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding:var(--space-8)0}.gallery-main-view img{max-width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius-md)}.gallery-caption{margin-top:var(--space-3);color:rgba(255,255,255,.7);font-size:var(--font-size-sm);text-align:center}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:var(--radius-full);background:rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);border:none;cursor:pointer}.gallery-nav:hover{background:rgba(255,255,255,.2)}.gallery-prev{left:var(--space-4)}.gallery-next{right:var(--space-4)}.gallery-thumbnails{display:flex;gap:var(--space-2);justify-content:center;padding:var(--space-4)0;overflow-x:auto}.gallery-thumb{width:60px;height:60px;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;opacity:.5;transition:all var(--transition-fast);flex-shrink:0}.gallery-thumb.active{opacity:1;outline:2px solid var(--primary);outline-offset:2px}.gallery-thumb:hover{opacity:.8}.gallery-thumb img{width:100%;height:100%;object-fit:cover}.gallery-counter-modal{color:rgba(255,255,255,.7);text-align:center;font-size:var(--font-size-sm)}@media(max-width:768px){.gallery-nav{width:40px;height:40px}.gallery-prev{left:var(--space-2)}.gallery-next{right:var(--space-2)}.gallery-thumbnails{padding:var(--space-2)0}.gallery-thumb{width:50px;height:50px}}.image-management-section{margin-top:var(--space-6);padding-top:var(--space-6);border-top:2px solid var(--border)}.image-management-section h2{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-4)}.current-images{margin-bottom:var(--space-5)}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-3)}.image-card{position:relative;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-100);border:2px solid transparent;transition:all var(--transition-fast)}.image-card:hover{border-color:var(--primary)}.image-card img{width:100%;height:100%;object-fit:cover}.image-card.main-image{border-color:var(--primary)}.image-badge{position:absolute;top:var(--space-2);left:var(--space-2);padding:2px 8px;background:var(--primary);color:#fff;font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-sm)}.image-actions{position:absolute;bottom:0;left:0;right:0;padding:var(--space-2);background:linear-gradient(to top,rgba(0,0,0,.7),transparent);display:flex;justify-content:flex-end;gap:var(--space-1);opacity:0;transition:opacity var(--transition-fast)}.image-card:hover .image-actions{opacity:1}.image-action-btn{width:28px;height:28px;border-radius:var(--radius-sm);background:rgba(255,255,255,.9);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all var(--transition-fast)}.image-action-btn:hover{transform:scale(1.1)}.image-action-btn.set-main-btn:hover{background:var(--warning);color:#fff}.image-action-btn.delete-btn:hover{background:var(--error);color:#fff}.no-images-text{color:var(--text-muted);font-size:var(--font-size-sm);text-align:center;padding:var(--space-6);background:var(--gray-50);border-radius:var(--radius-lg);border:2px dashed var(--gray-300)}.add-image-section{margin-top:var(--space-5);padding-top:var(--space-5);border-top:1px solid var(--border)}.add-image-section h3{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3)}.add-image-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-3);padding:var(--space-3);background:var(--gray-50);border-radius:var(--radius-md)}.set-as-main-checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--text-secondary);cursor:pointer}.set-as-main-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}