.essentials-map-page{max-width:1400px;margin:0 auto;padding:20px}.essentials-header{text-align:center;margin-bottom:24px}.essentials-header .header-icon{width:64px;height:64px;margin:0 auto 16px;background:linear-gradient(135deg,#28a745,#20c997);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff}.essentials-header h1{font-family:Playfair Display,Georgia,serif;font-size:2.5rem;font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.essentials-header .subtitle{color:var(--color-text-body);font-size:1.1rem;margin:0}.essentials-toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.filter-btn,.locate-btn,.clear-filters-btn{display:flex;align-items:center;gap:8px;padding:12px 18px;border-radius:10px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.filter-btn{background:#fff;border:2px solid #e0e0e0;color:var(--color-text-body);position:relative}.filter-btn:hover,.filter-btn.active{border-color:#28a745;color:#28a745}.filter-btn .filter-count{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#28a745;color:#fff;border-radius:50%;font-size:.75rem;display:flex;align-items:center;justify-content:center}.locate-btn{background:#fff;border:2px solid #e0e0e0;color:var(--color-text-body)}.locate-btn:hover,.locate-btn.active{background:#e3f2fd;border-color:#2196f3;color:#2196f3}.locate-btn:disabled{opacity:.6;cursor:not-allowed}.clear-filters-btn{background:none;border:none;color:#dc3545;padding:12px}.clear-filters-btn:hover{text-decoration:underline}.filter-panel{background:var(--color-bg-section);border-radius:12px;padding:16px;margin-bottom:20px}.filter-grid{display:flex;flex-wrap:wrap;gap:10px}.filter-chip{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#fff;border:2px solid #e0e0e0;border-radius:24px;font-size:.9rem;cursor:pointer;transition:all .2s;color:var(--color-text-body)}.filter-chip:hover{border-color:var(--chip-color);color:var(--chip-color)}.filter-chip.active{background:var(--chip-color);border-color:var(--chip-color);color:#fff}.loading-state,.error-state{text-align:center;padding:60px 20px;color:var(--color-text-body)}.spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#28a745;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.error-state button{margin-top:12px;padding:10px 24px;background:#28a745;color:#fff;border:none;border-radius:8px;cursor:pointer}.essentials-content{display:grid;grid-template-columns:1fr 380px;gap:20px;min-height:600px}.map-container{border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000001a}.essentials-map{width:100%;height:600px}.essential-popup{min-width:200px}.essential-popup .popup-category{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;color:#fff;margin-bottom:8px}.essential-popup h4{margin:0 0 8px;font-size:1rem;color:var(--color-text-primary)}.essential-popup .popup-address{margin:0 0 4px;font-size:.85rem;color:var(--color-text-body)}.essential-popup .popup-hours{display:flex;align-items:center;gap:4px;margin:0 0 4px;font-size:.85rem;color:#28a745}.essential-popup .popup-notes{margin:0 0 8px;font-size:.8rem;color:var(--color-text-muted);font-style:italic}.essential-popup .popup-actions{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid #eee}.essential-popup .popup-action{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#f0f0f0;border-radius:6px;font-size:.8rem;color:#333;text-decoration:none;transition:background .2s}.essential-popup .popup-action:hover{background:#e0e0e0}.user-popup{text-align:center;padding:4px}.essentials-list{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;overflow:hidden}.essentials-list h3{padding:16px 20px;margin:0;font-size:1rem;color:var(--color-text-primary);border-bottom:1px solid #f0f0f0;background:#fafafa}.list-items{max-height:552px;overflow-y:auto}.essential-item{display:flex;align-items:flex-start;gap:14px;padding:16px 20px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .2s}.essential-item:hover,.essential-item.selected{background:var(--color-bg-section)}.essential-item.selected{border-left:3px solid #28a745}.essential-item .item-icon{flex-shrink:0;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.essential-item .item-content{flex:1;min-width:0}.essential-item h4{margin:0 0 4px;font-size:.95rem;color:var(--color-text-primary);font-weight:500}.essential-item .item-category{margin:0 0 4px;font-size:.8rem;color:var(--color-text-muted)}.essential-item .item-address{margin:0 0 4px;font-size:.85rem;color:var(--color-text-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.essential-item .item-hours{display:flex;align-items:center;gap:4px;margin:0;font-size:.8rem;color:#28a745}.essential-item .item-distance{flex-shrink:0;padding:4px 10px;background:#e3f2fd;border-radius:12px;font-size:.8rem;font-weight:600;color:#1976d2}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#999;text-align:center}.empty-state svg{margin-bottom:16px;color:#ccc}@media(max-width:992px){.essentials-content{grid-template-columns:1fr}.essentials-list{order:-1}.list-items{max-height:300px}.essentials-map{height:400px}}@media(max-width:600px){.essentials-map-page{padding:16px}.essentials-header h1{font-size:1.75rem}.essentials-toolbar{flex-direction:column}.filter-btn,.locate-btn{width:100%;justify-content:center}.filter-grid{justify-content:center}.essentials-map{height:350px}}
