:root{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-glass: rgba(26, 29, 39, .85);--bg-glass-hover: rgba(30, 34, 48, .92);--border-glass: rgba(255, 255, 255, .08);--border-active: rgba(255, 255, 255, .15);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #6366f1;--accent-glow: rgba(99, 102, 241, .3);--success: #22c55e;--warning: #eab308;--danger: #ef4444;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 4px 16px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5);--transition: .2s cubic-bezier(.4, 0, .2, 1);--font: "Inter", -apple-system, sans-serif;--header-h: 56px;--sidebar-w: 360px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}input,textarea,button,select{font-family:inherit;font-size:inherit}button{cursor:pointer;border:none;background:none;color:inherit}a{color:inherit;text-decoration:none}#app{position:relative;width:100%;height:100vh}#map{position:absolute;top:0;right:0;bottom:0;left:0;top:var(--header-h);z-index:1}#header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 16px;gap:12px;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px) saturate(1.4);backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--border-glass)}.header-left,.header-right{display:flex;align-items:center;gap:10px}.header-center{flex:1;max-width:420px}.logo{display:flex;align-items:center;gap:8px}.logo-icon{font-size:22px}.logo h1{font-size:18px;font-weight:700;letter-spacing:-.3px;background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.search-bar{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-lg);padding:0 14px;height:38px;transition:var(--transition)}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-bar svg{width:16px;height:16px;color:var(--text-muted);flex-shrink:0}.search-bar input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:13px}.search-bar input::placeholder{color:var(--text-muted)}.report-count{display:flex;align-items:baseline;gap:5px;padding:0 8px}.count-number{font-size:18px;font-weight:700;color:var(--accent)}.count-label{font-size:12px;color:var(--text-muted)}.icon-btn{width:38px;height:38px;display:grid;place-items:center;border-radius:var(--radius-sm);transition:var(--transition)}.icon-btn svg{width:20px;height:20px}.icon-btn:hover{background:#ffffff14}.icon-btn.active{background:var(--accent-glow);color:var(--accent)}.icon-btn-sm{width:32px;height:32px}.icon-btn-sm svg{width:16px;height:16px}.sidebar{position:fixed;top:var(--header-h);left:0;bottom:0;width:var(--sidebar-w);z-index:50;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px) saturate(1.4);backdrop-filter:blur(20px) saturate(1.4);border-right:1px solid var(--border-glass);display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:49;background:#00000080;opacity:0;pointer-events:none;transition:opacity .3s}.sidebar-overlay.active{opacity:1;pointer-events:auto}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid var(--border-glass)}.sidebar-header h2{font-size:15px;font-weight:600}.sidebar-section{padding:16px;border-bottom:1px solid var(--border-glass)}.sidebar-section:last-child{flex:1;overflow-y:auto;border-bottom:none}.section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:12px}.filter-group{margin-bottom:14px}.filter-group label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.category-filters{display:flex;flex-wrap:wrap;gap:6px}.cat-chip{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid var(--border-glass);cursor:pointer;transition:var(--transition);-webkit-user-select:none;user-select:none}.cat-chip:hover{border-color:var(--border-active)}.cat-chip.active{border-color:var(--cat-color, var(--accent));background:var(--cat-bg, var(--accent-glow))}.cat-chip .dot{width:8px;height:8px;border-radius:50%}.date-filters{display:flex;gap:8px}.date-filters input{flex:1;background:var(--bg-primary);border:1px solid var(--border-glass);border-radius:var(--radius-sm);padding:8px 10px;color:var(--text-primary);font-size:13px;outline:none;transition:var(--transition)}.date-filters input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.date-filters input::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.5;cursor:pointer}.report-list{display:flex;flex-direction:column;gap:8px}.report-card{background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-md);padding:12px;cursor:pointer;transition:var(--transition)}.report-card:hover{border-color:var(--border-active);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.report-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.report-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.report-card-title{font-size:13px;font-weight:600;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.report-card-meta{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--text-muted)}.report-card-meta .upvotes{display:flex;align-items:center;gap:3px}.fab{position:fixed;bottom:28px;right:28px;z-index:60;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:grid;place-items:center;box-shadow:0 4px 20px #6366f166;transition:var(--transition);animation:fab-pulse 2s infinite}.fab svg{width:24px;height:24px}.fab:hover{transform:scale(1.1);box-shadow:0 6px 28px #6366f180}.fab.placing{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 20px #22c55e66;animation:none}@keyframes fab-pulse{0%,to{box-shadow:0 4px 20px #6366f166}50%{box-shadow:0 4px 28px #6366f199}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;place-items:center;padding:20px;opacity:0;transition:opacity .25s}.modal-overlay.visible{display:grid;opacity:1}.modal{width:100%;max-width:480px;max-height:90vh;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);animation:modal-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modal-in{0%{transform:scale(.92) translateY(16px);opacity:0}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 0}.modal-header h2{font-size:18px;font-weight:700}.modal-body{padding:16px 20px 20px;display:flex;flex-direction:column;gap:14px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.form-field input,.form-field textarea{background:var(--bg-primary);border:1px solid var(--border-glass);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text-primary);font-size:14px;outline:none;transition:var(--transition);resize:vertical}.form-field input:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-muted)}.location-display{flex-direction:row!important;align-items:center;gap:8px!important;background:var(--bg-primary);border:1px solid var(--border-glass);border-radius:var(--radius-sm);padding:10px 12px;font-size:13px;color:var(--text-secondary)}.location-display svg{color:var(--accent);flex-shrink:0}.location-display.set{border-color:var(--success);color:var(--text-primary)}.location-display.set svg{color:var(--success)}.category-selector{display:flex;flex-wrap:wrap;gap:6px}.cat-option{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid var(--border-glass);cursor:pointer;transition:var(--transition)}.cat-option:hover{border-color:var(--border-active)}.cat-option.selected{border-color:var(--cat-color);background:var(--cat-bg);color:#fff}.cat-option .dot{width:8px;height:8px;border-radius:50%}.image-upload{border:2px dashed var(--border-glass);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);overflow:hidden}.image-upload:hover{border-color:var(--accent)}.image-upload.drag-over{border-color:var(--accent);background:var(--accent-glow)}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;color:var(--text-muted);font-size:13px}.image-preview{width:100%;max-height:200px;object-fit:cover;display:block}.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:var(--radius-md);font-weight:600;font-size:14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;transition:var(--transition);border:none}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #6366f166}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:300;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 20px;border-radius:var(--radius-md);background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-glass);box-shadow:var(--shadow-md);font-size:13px;font-weight:500;pointer-events:auto;animation:toast-in .35s cubic-bezier(.34,1.56,.64,1);min-width:260px}.toast.success{border-color:#22c55e4d}.toast.success .toast-icon{color:var(--success)}.toast.error{border-color:#ef44444d}.toast.error .toast-icon{color:var(--danger)}.toast.info{border-color:#6366f14d}.toast.info .toast-icon{color:var(--accent)}.toast-icon{width:18px;height:18px;flex-shrink:0}.toast.removing{animation:toast-out .3s forwards}@keyframes toast-in{0%{transform:translateY(20px);opacity:0}}@keyframes toast-out{to{transform:translateY(20px);opacity:0}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:var(--bg-primary);display:grid;place-items:center;transition:opacity .4s}.loading-overlay.hidden{opacity:0;pointer-events:none}.loader{display:flex;flex-direction:column;align-items:center;gap:16px}.loader span{font-size:14px;color:var(--text-muted)}.loader-ring{width:40px;height:40px;border-radius:50%;border:3px solid var(--border-glass);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mapboxgl-popup-content{background:var(--bg-secondary)!important;border:1px solid var(--border-glass)!important;border-radius:var(--radius-md)!important;padding:0!important;box-shadow:var(--shadow-lg)!important;color:var(--text-primary)!important;max-width:300px!important}.mapboxgl-popup-tip{border-top-color:var(--bg-secondary)!important}.mapboxgl-popup-close-button{color:var(--text-muted)!important;font-size:18px!important;right:8px!important;top:8px!important}.popup-content{padding:14px}.popup-img{width:100%;height:140px;object-fit:cover;border-radius:var(--radius-md) var(--radius-md) 0 0}.popup-category{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;margin-bottom:6px}.popup-title{font-size:14px;font-weight:600;margin-bottom:4px}.popup-desc{font-size:12px;color:var(--text-secondary);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.popup-footer{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--text-muted)}.popup-upvote{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;border:1px solid var(--border-glass);font-size:12px;font-weight:500;cursor:pointer;transition:var(--transition)}.popup-upvote:hover{border-color:var(--accent);color:var(--accent)}.crosshair-cursor{cursor:crosshair!important}@media (max-width: 640px){:root{--sidebar-w: 100%}.header-center,.report-count{display:none}.fab{bottom:20px;right:20px;width:50px;height:50px}.modal{max-height:85vh}}@media (min-width: 1024px){.sidebar{transform:translate(0)}#map{left:var(--sidebar-w)}.sidebar-overlay,#sidebar-toggle,.sidebar-header button{display:none}}
