*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--forest:#1a3a2a;--forest-light:#2a5a3a;--cream:#f5f0e8;--cream-dark:#e8e0d0;--gold:#c8a84b;--gold-light:#d4b96a;--text:#2c2c2c;--text-muted:#6b6b6b;--sidebar-width:380px}html,body{height:100%;color:var(--text);font-family:DM Sans,sans-serif}.app{height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--cream);border-right:1px solid var(--cream-dark);z-index:1000;flex-direction:column;flex-shrink:0;display:flex}.sidebar-header{background:var(--forest);color:var(--cream);padding:24px 20px 16px}.sidebar-header h1{margin-bottom:4px;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700;line-height:1.2}.sidebar-header p{opacity:.75;font-size:.8rem}.search-area{border-bottom:1px solid var(--cream-dark);padding:12px 16px}.search-input{border:1px solid var(--cream-dark);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b6b6b' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85zm-5.242.156a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E") 12px no-repeat;border-radius:8px;outline:none;width:100%;padding:10px 14px 10px 36px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.search-input:focus{border-color:var(--gold)}.counter{color:var(--text-muted);padding:8px 16px;font-size:.78rem;font-weight:500}.garden-list{flex:1;padding:0 8px 8px;overflow-y:auto}.garden-item{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:12px;transition:background .15s,transform .1s;display:flex}.garden-item:hover{background:var(--cream-dark)}.garden-item:active{transform:scale(.99)}.garden-item .dot{background:var(--forest-light);border-radius:50%;flex-shrink:0;width:8px;height:8px}.garden-item .name{font-size:.88rem;font-weight:500;line-height:1.3}.garden-item .distance{color:var(--text-muted);flex-shrink:0;margin-left:auto;font-size:.75rem;font-weight:500}#map{flex:1;min-width:0}.loading-overlay{background:var(--cream);z-index:2000;flex-direction:column;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.loading-overlay.hidden{opacity:0;pointer-events:none}.spinner{border:3px solid var(--cream-dark);border-top-color:var(--forest);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.loading-overlay p{color:var(--forest);margin-top:16px;font-family:Playfair Display,serif;font-size:1.1rem}@keyframes spin{to{transform:rotate(360deg)}}.user-location-dot{background:#2979ff;border:2px solid #fff;border-radius:50%;width:14px;height:14px;position:relative;box-shadow:0 0 0 2px #2979ff59}.user-location-pulse{background:#2979ff33;border-radius:50%;animation:2s ease-out infinite location-pulse;position:absolute;inset:-6px}@keyframes location-pulse{0%{opacity:1;transform:scale(.5)}to{opacity:0;transform:scale(2.2)}}.leaflet-popup-content-wrapper{border-radius:10px;font-family:DM Sans,sans-serif;box-shadow:0 4px 20px #00000026}.leaflet-popup-content{margin:14px 16px;line-height:1.4}.popup-name{color:var(--forest);margin-bottom:8px;font-family:Playfair Display,serif;font-size:1rem;font-weight:700}.popup-directions{background:var(--forest);color:#fff;border-radius:6px;padding:6px 14px;font-size:.8rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.popup-directions:hover{background:var(--forest-light)}.mobile-toggle{z-index:1100;background:var(--forest);color:var(--cream);cursor:pointer;border:none;border-radius:8px;width:42px;height:42px;font-size:1.3rem;display:none;position:fixed;top:12px;left:12px;box-shadow:0 2px 8px #0003}@media (width<=768px){.sidebar{height:100%;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #00000026}.sidebar.open{transform:translate(0)}.mobile-toggle{display:block}.mobile-backdrop{z-index:999;background:#0000004d;display:none;position:fixed;inset:0}.mobile-backdrop.visible{display:block}}
