*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e}.app{width:100%;height:100%;position:relative}.poi-marker-icon{background:transparent!important;border:none!important}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1a1a2e;color:#e0e0e0;z-index:1000;gap:16px;font-size:1.1rem}.loading-spinner{width:40px;height:40px;border:4px solid #333;border-top-color:#e0b44a;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:absolute;top:16px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:8px;font-size:14px;z-index:10000;cursor:pointer;animation:slideDown .3s ease}.toast-error{background:#ef4444;color:#fff}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#1e1e2e;border:1px solid #333;border-radius:12px;padding:28px;width:90%;max-width:420px;color:#e0e0e0;box-shadow:0 8px 32px #00000080}.modal-form{max-width:520px;max-height:90vh;overflow-y:auto}.modal h2{font-size:1.3rem;font-weight:600;margin-bottom:4px;color:#f0f0f0}.modal-subtitle{font-size:.85rem;color:#888;margin-bottom:20px}.modal-input{width:100%;padding:10px 14px;background:#2a2a3e;border:1px solid #444;border-radius:8px;color:#e0e0e0;font-size:14px;outline:none;transition:border-color .2s}.modal-input:focus{border-color:#e0b44a}.modal-textarea{width:100%;padding:10px 14px;background:#2a2a3e;border:1px solid #444;border-radius:8px;color:#e0e0e0;font-size:14px;resize:vertical;outline:none;font-family:inherit;transition:border-color .2s}.modal-textarea:focus{border-color:#e0b44a}.modal-error{color:#ef4444;font-size:13px;margin-top:8px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.btn{padding:9px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#e0b44a;color:#1a1a2e}.btn-primary:hover:not(:disabled){background:#c9a13d}.btn-cancel{background:#333;color:#ccc}.btn-cancel:hover{background:#444}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:#aaa;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}.type-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;background:#2a2a3e;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s}.type-option:hover{background:#333}.type-option.selected{border-color:#e0b44a;background:#2a2a3e}.type-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.type-label{font-size:11px;color:#ccc;text-align:center}.modal-file-input{width:100%;padding:8px;color:#aaa;font-size:13px}.modal-file-input::file-selector-button{padding:6px 14px;background:#333;border:1px solid #555;border-radius:6px;color:#ddd;cursor:pointer;font-size:13px;margin-right:10px}.image-previews{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.image-preview{position:relative;width:80px;height:80px;border-radius:6px;overflow:hidden;border:1px solid #444}.image-preview img{width:100%;height:100%;object-fit:cover}.image-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;background:#000000b3;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1}.poi-popup{min-width:200px;max-width:300px}.poi-popup-title{margin:0 0 4px;font-size:16px;font-weight:600}.poi-popup-type{font-size:12px;color:#888;display:block;margin-bottom:8px}.poi-popup-text{font-size:14px;line-height:1.5;margin-bottom:8px;white-space:pre-wrap;color:#333}.poi-popup-image{width:100%;max-height:200px;object-fit:cover;border-radius:6px;margin-bottom:6px}.poi-popup-actions{display:flex;gap:8px;margin-top:10px}.poi-popup-btn{flex:1;padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:opacity .2s}.poi-popup-btn.edit{background:#3b82f6;color:#fff}.poi-popup-btn.delete{background:#ef4444;color:#fff}.poi-popup-btn:hover{opacity:.85}.leaflet-popup-content-wrapper{border-radius:10px!important;box-shadow:0 4px 16px #0000004d!important}.leaflet-popup-content{margin:12px 14px!important}.leaflet-popup-tip{box-shadow:none!important}
