:root{--primary:#1a73e8;--primary-hover:#1557b0;--surface:#fff;--bg-color:#f8f9fa;--text-main:#202124;--text-muted:#5f6368;--border:#dadce0;--star:#fbbc04;--danger:#d93025;--shadow-sm:0 1px 2px 0 #3c40434d, 0 1px 3px 1px #3c404326;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d}*{box-sizing:border-box;margin:0;padding:0}body,html{width:100%;height:100%;color:var(--text-main);background:var(--bg-color);-webkit-tap-highlight-color:transparent;font-family:Inter,sans-serif;overflow:hidden}#map-container{z-index:1;position:absolute;inset:0}#map{width:100%;height:100%}.leaflet-control-zoom{display:none}@media (width>=768px){.leaflet-control-zoom{display:block;margin-top:80px!important}}#floating-header{z-index:1000;pointer-events:none;justify-content:center;display:flex;position:absolute;top:16px;left:16px;right:16px}.search-box{background:var(--surface);box-shadow:var(--shadow-sm);pointer-events:auto;border-radius:24px;align-items:center;width:100%;max-width:400px;padding:8px 16px;display:flex}.search-icon{margin-right:12px;font-size:18px}#search-input{background:0 0;border:none;outline:none;flex:1;font-family:Inter,sans-serif;font-size:16px}.avatar-placeholder{cursor:pointer;border:1px solid var(--border);background:#e8eaed;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;margin-left:12px;display:flex;overflow:hidden}.avatar-placeholder img{object-fit:cover;width:100%;height:100%}.fab{background:var(--surface);width:56px;height:56px;color:var(--primary);box-shadow:var(--shadow-sm);cursor:pointer;z-index:1000;border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s,background .2s;display:flex;position:absolute;bottom:120px;right:16px}.fab:active{background:#f1f3f4;transform:scale(.95)}.fab.hidden{display:none!important}.bottom-sheet{background:var(--surface);z-index:1000;border-radius:24px 24px 0 0;flex-direction:column;height:60vh;transition:transform .3s cubic-bezier(.2,.8,.2,1);display:flex;position:absolute;bottom:0;left:0;right:0;transform:translateY(calc(100% - 80px));box-shadow:0 -4px 16px #0000001a}@media (width>=768px){.bottom-sheet{border-radius:16px;width:400px;height:auto;top:80px;bottom:24px;left:24px;transform:none!important}.fab{bottom:24px;right:24px}}.sheet-handle{cursor:grab;justify-content:center;align-items:center;width:100%;height:24px;display:flex}.sheet-handle:after{content:"";background:#dadce0;border-radius:4px;width:40px;height:4px}.sheet-content{flex:1;padding:0 16px 16px;overflow-y:auto}.sheet-title{font-size:1.25rem;font-weight:600}.note-list{flex-direction:column;gap:12px;display:flex}.note-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;gap:8px;padding:16px;transition:box-shadow .2s,transform .2s;display:flex;box-shadow:0 1px 2px #0000000d}.note-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.note-header{justify-content:space-between;align-items:flex-start;display:flex}.note-title{color:var(--primary);font-size:1.1rem;font-weight:600}.note-rating{color:var(--star);white-space:nowrap;font-size:.9rem;font-weight:600}.note-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;display:-webkit-box;overflow:hidden}.note-image{object-fit:cover;border-radius:8px;width:100%;height:150px;margin-top:4px}.action-buttons{gap:8px;margin-top:8px;display:flex}.nav-btn{color:#1a73e8;background:#f1f3f4;border-radius:16px;align-items:center;gap:4px;padding:6px 12px;font-size:.8rem;font-weight:500;text-decoration:none;display:flex}.hidden{display:none!important}#modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);width:90%;max-width:400px;box-shadow:var(--shadow-lg);border-radius:16px;flex-direction:column;gap:16px;padding:24px;display:flex}.modal-title{margin-bottom:4px;font-size:1.5rem;font-weight:600}.modal-subtitle{color:var(--text-muted);margin-bottom:8px;font-size:.9rem}.form-group{flex-direction:column;gap:8px;display:flex}.input-field{border:1px solid var(--border);background:#f8f9fa;border-radius:8px;width:100%;padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,background .2s}.input-field:focus{border-color:var(--primary);background:var(--surface);outline:none}.textarea{resize:vertical;min-height:80px}.modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.btn-primary,.btn-secondary,.auth-btn,.btn-text{cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-family:inherit;font-size:.95rem;font-weight:500;transition:background .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{color:var(--text-main);background:#f1f3f4}.btn-secondary:hover{background:#e8eaed}.btn-text{color:var(--text-muted);background:0 0}.btn-text:hover{background:#f1f3f4}.auth-btn.google{color:#3c4043;border:1px solid var(--border);background:#fff;justify-content:center;align-items:center;gap:8px;display:flex}.auth-btn.google:hover{background:#f8f9fa}.image-upload-label{border:1px dashed var(--primary);color:var(--primary);cursor:pointer;background:#f1f3f4;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-weight:500;transition:background .2s;display:flex}.image-upload-label:hover{background:#e8eaed}.upload-icon{font-size:1.2rem}.form-group.row{flex-direction:row;justify-content:space-between;align-items:center}.toggle-label{cursor:pointer;justify-content:space-between;align-items:center;width:100%;font-weight:500;display:flex}.toggle-label input{opacity:0;width:0;height:0}.toggle-switch{background-color:#ccc;border-radius:24px;width:44px;height:24px;transition:all .4s;position:relative}.toggle-switch:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.toggle-switch{background-color:var(--primary)}input:checked+.toggle-switch:before{transform:translate(20px)}#pin-selector-ui{z-index:1000;pointer-events:none;flex-direction:column;align-items:center;gap:12px;display:flex;position:absolute;top:80px;left:50%;transform:translate(-50%)}.pin-toast{background:var(--surface);color:var(--text-main);box-shadow:var(--shadow-sm);border-radius:20px;padding:10px 20px;font-size:.95rem;font-weight:500}.pin-actions{pointer-events:auto;gap:8px;display:flex}#center-crosshair{z-index:999;pointer-events:none;position:absolute;top:50%;left:50%}#toast-container{z-index:3000;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{color:#fff;box-shadow:var(--shadow-md);opacity:0;background:#323232;border-radius:8px;padding:12px 24px;font-size:.9rem;animation:.3s forwards toast-in;transform:translateY(20px)}@keyframes toast-in{to{opacity:1;transform:translateY(0)}}.toast.hiding{animation:.3s forwards toast-out}@keyframes toast-out{to{opacity:0;transform:translateY(20px)}}.image-carousel::-webkit-scrollbar{height:6px}.image-carousel::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:4px}.carousel-image{object-fit:cover;border-radius:8px;flex-shrink:0;height:120px}.review-card{background:#f8f9fa;border-radius:8px;flex-direction:column;gap:6px;padding:12px;display:flex}.review-header{align-items:center;gap:8px;display:flex}.review-avatar{object-fit:cover;border-radius:50%;width:24px;height:24px}.review-name{font-size:.9rem;font-weight:600}.review-date{color:var(--text-muted);margin-left:auto;font-size:.8rem}
