:root{--bg: #131316;--surface: #1c1c21;--border: #2a2a32;--border-hi: #3a3a46;--text: #ece8e0;--text-dim: #7a7880;--text-faint:#3e3c46;--accent: #e8a23a;--accent-hi: #f5b84a;--danger: #e05c5c;--add: #4caf82;--add-bg: rgba(76,175,130,.12)}*{box-sizing:border-box;margin:0;padding:0}body{display:flex;height:100vh;overflow:hidden;font-family:DM Sans,sans-serif;background:var(--bg)}#map{flex:1;height:100vh;filter:saturate(.85) brightness(.97)}.panel{width:300px;flex-shrink:0;height:100vh;background:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:1000}.panel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");background-size:180px;pointer-events:none;opacity:.6;z-index:0}.panel>*{position:relative;z-index:1}.panel-header{display:flex;align-items:center;gap:12px;padding:22px 18px 18px;border-bottom:1px solid var(--border)}.header-text{flex:1}.share-btn{flex-shrink:0;width:30px;height:30px;border-radius:7px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s,background .15s}.share-btn:hover{color:var(--accent);border-color:var(--accent);background:#e8a23a14}.share-btn.copied{color:var(--add);border-color:var(--add);background:var(--add-bg)}.logo-mark{font-size:22px;color:var(--accent);line-height:1;animation:pulse-mark 4s ease-in-out infinite}@keyframes pulse-mark{0%,to{opacity:1}50%{opacity:.55}}.app-title{font-family:Playfair Display,Georgia,serif;font-weight:600;font-size:18px;color:var(--text);letter-spacing:.02em;line-height:1.1}.app-sub{font-size:10px;font-weight:300;color:var(--text-dim);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}.search-area{padding:14px 18px;border-bottom:1px solid var(--border)}.search-row{display:flex;align-items:center;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .2s}.search-row:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #e8a23a1f}#search-input{flex:1;padding:10px 14px;background:transparent;border:none;outline:none;font-family:DM Sans,sans-serif;font-size:13px;font-weight:400;color:var(--text);min-width:0}#search-input::placeholder{color:var(--text-dim)}.clear-btn{padding:0 10px;height:38px;background:none;border:none;border-left:1px solid var(--border);color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s}.clear-btn:hover{color:var(--danger)}.clear-btn.hidden{display:none}#search-btn{padding:0 14px;height:38px;background:none;border:none;border-left:1px solid var(--border);color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}#search-btn:hover{color:var(--accent);background:#e8a23a14}.results-list{list-style:none;overflow-y:auto;border-bottom:1px solid var(--border);max-height:260px}.results-list.hidden{display:none}.results-list li{display:flex;align-items:center;gap:8px;padding:9px 18px;border-bottom:1px solid var(--border);transition:background .12s;animation:slide-in .15s ease both}.results-list li:last-child{border-bottom:none}.results-list li:hover{background:var(--surface)}@keyframes slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.result-name{flex:1;cursor:pointer;font-size:12.5px;font-weight:400;color:var(--text-dim);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;line-height:1.4;transition:color .12s}.results-list li:hover .result-name{color:var(--text)}.add-btn{flex-shrink:0;width:22px;height:22px;border-radius:5px;border:1px solid var(--add);background:var(--add-bg);color:var(--add);font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,transform .1s}.add-btn:hover:not(:disabled){background:var(--add);color:#fff;transform:scale(1.1)}.add-btn.added{border-color:var(--text-faint);background:transparent;color:var(--text-faint);cursor:default}.no-results{padding:12px 18px;font-size:12.5px;color:var(--text-dim);font-style:italic}.results-list li.result-active{background:#e8a23a14;border-left:2px solid var(--accent);padding-left:16px}.results-list li.result-active .result-name{color:var(--text)}.search-tooltip{font-family:DM Sans,sans-serif!important;font-size:12px!important;background:#131316!important;border:1px solid #2a2a32!important;color:#ece8e0!important;border-radius:6px!important;padding:5px 10px!important;box-shadow:0 4px 12px #00000059!important}.saved-section{display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0}.section-label{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);flex-shrink:0}.place-count{background:var(--surface);border:1px solid var(--border);color:var(--accent);font-size:10px;font-family:DM Sans,sans-serif;font-weight:500;padding:1px 7px;border-radius:20px;min-width:22px;text-align:center}.places-list{list-style:none;overflow-y:auto;flex:1}.places-list li{display:flex;align-items:center;padding:9px 18px;border-bottom:1px solid var(--border);gap:10px;transition:background .12s;animation:slide-in .18s ease both}.places-list li:last-child{border-bottom:none}.places-list li:hover{background:var(--surface)}.place-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.place-name{flex:1;cursor:pointer;font-size:12.5px;font-weight:400;color:var(--text-dim);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:color .12s}.places-list li:hover .place-name{color:var(--text)}.remove-btn{flex-shrink:0;background:none;border:none;color:var(--text-faint);font-size:16px;line-height:1;cursor:pointer;padding:2px 4px;border-radius:4px;transition:color .15s}.remove-btn:hover{color:var(--danger)}.empty-msg{font-size:12px;color:var(--text-faint);padding:16px 18px;line-height:1.6}.results-list::-webkit-scrollbar,.places-list::-webkit-scrollbar{width:4px}.results-list::-webkit-scrollbar-track,.places-list::-webkit-scrollbar-track{background:transparent}.results-list::-webkit-scrollbar-thumb,.places-list::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:2px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(0);background:#1c1c21;border:1px solid #2a2a32;color:#ece8e0;font-family:DM Sans,sans-serif;font-size:13px;padding:10px 18px;border-radius:8px;box-shadow:0 4px 20px #0006;z-index:9999;transition:opacity .3s,transform .3s;white-space:nowrap}.toast.hidden{opacity:0;pointer-events:none;transform:translate(-50%) translateY(8px)}.leaflet-popup-content-wrapper{border-radius:8px!important;font-family:DM Sans,sans-serif!important;font-size:12.5px!important;box-shadow:0 8px 24px #00000040!important}
