*, *::before, *::after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a1628;--surface:#0f2035;--surface2:#162d4a;--border:#1e3a5f;--text:#e8edf2;--text2:#7a94b0;--accent:#00b4d8;--accent2:#0077b6;--danger:#ef4444;--warning:#f59e0b;--success:#22c55e;--critical:#dc2626;--radius:10px}body{font-family:'Inter', -apple-system, sans-serif;background:var(--bg);color:var(--text);height:100vh;width:100vw;overflow:hidden}a{color:var(--accent);text-decoration:none}/* === TOP BAR === */.topbar{position:fixed;top:0;left:0;right:0;height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:1000}.topbar-brand{display:flex;align-items:center;gap:10px}.topbar-brand .logo{font-size:1.4rem;font-weight:800;color:var(--accent);letter-spacing:-0.5px}.topbar-brand .logo span{color:var(--text)}.topbar-brand .tagline{font-size:0.65rem;color:var(--text2);text-transform:uppercase;letter-spacing:1px}.topbar-actions{display:flex;align-items:center;gap:6px;flex-shrink:1;overflow:visible}/* === MAP === */#map{position:fixed;top:56px;left:0;right:0;bottom:0;z-index:1}/* === BUTTONS === */.btn{border:none;border-radius:8px;padding:10px 18px;font-size:0.85rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent2)}.btn-ghost{background:var(--surface2);border:1px solid var(--border);color:var(--text)}.btn-ghost:hover{border-color:var(--accent)}.btn-sm{padding:10px 16px;font-size:0.85rem;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.btn-danger{background:var(--danger);color:#fff}.btn-full{width:100%;justify-content:center}/* === PANELS === */.panel{position:fixed;background:var(--surface);border:1px solid var(--border);border-radius:12px;z-index:900;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,0.5)}.panel-right{top:64px;right:8px;bottom:8px;width:380px;max-width:calc(100vw - 16px)}.panel-header{padding:16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--surface);z-index:10}.panel-header h2{font-size:1rem;font-weight:700}.panel-close{background:none;border:none;color:var(--text2);font-size:1.3rem;cursor:pointer}.panel-close:hover{color:var(--text)}.panel-body{padding:16px}/* === REPORT FORM === */.form-group{margin-bottom:14px}.form-group label{display:block;font-size:0.7rem;color:var(--text2);text-transform:uppercase;letter-spacing:0.5px;font-weight:600;margin-bottom:4px}.form-group input, .form-group textarea, .form-group select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:0.9rem;color:var(--text);outline:none;font-family:inherit}.form-group input:focus, .form-group textarea:focus, .form-group select:focus{border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:80px}.form-group select option{background:var(--surface2)}/* Category selector */.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.category-btn{background:var(--surface2);border:2px solid var(--border);border-radius:8px;padding:10px 8px;text-align:center;cursor:pointer;font-size:0.75rem;color:var(--text2);font-weight:500;transition:all 0.15s;font-family:inherit}.category-btn:hover{border-color:var(--accent);color:var(--text)}.category-btn.active{border-color:var(--accent);background:rgba(0,180,216,0.1);color:var(--accent)}.category-btn .icon{font-size:1.2rem;display:block;margin-bottom:2px}/* Severity pills */.severity-row{display:flex;gap:6px}.severity-btn{flex:1;background:var(--surface2);border:2px solid var(--border);border-radius:6px;padding:8px;text-align:center;cursor:pointer;font-size:0.7rem;font-weight:600;color:var(--text2);text-transform:uppercase;font-family:inherit;transition:all 0.15s}.severity-btn:hover{border-color:var(--text2)}.severity-btn.active[data-sev="low"]{border-color:var(--success);color:var(--success);background:rgba(34,197,94,0.1)}.severity-btn.active[data-sev="medium"]{border-color:var(--warning);color:var(--warning);background:rgba(245,158,11,0.1)}.severity-btn.active[data-sev="high"]{border-color:#f97316;color:#f97316;background:rgba(249,115,22,0.1)}.severity-btn.active[data-sev="critical"]{border-color:var(--critical);color:var(--critical);background:rgba(220,38,38,0.1)}/* Coords display */.coords{background:var(--surface2);border-radius:8px;padding:10px 12px;font-family:'Courier New', monospace;font-size:0.85rem;color:var(--accent);text-align:center;letter-spacing:0.5px}.coords .label{font-size:0.65rem;color:var(--text2);font-family:'Inter', sans-serif}/* Photo upload */.photo-upload{border:2px dashed var(--border);border-radius:8px;padding:20px;text-align:center;cursor:pointer;color:var(--text2);font-size:0.8rem;transition:all 0.15s}.photo-upload:hover{border-color:var(--accent);color:var(--accent)}.photo-upload .icon{font-size:1.5rem;margin-bottom:4px}.photo-preview{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.photo-preview img{width:60px;height:60px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}/* === HAZARD DETAIL === */.hazard-detail-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.hazard-icon{font-size:2rem}.hazard-title{font-size:1.1rem;font-weight:700}.hazard-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.badge{padding:3px 10px;border-radius:20px;font-size:0.65rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}.badge-category{background:var(--surface2);border:1px solid var(--border);color:var(--text2)}.badge-low{background:rgba(34,197,94,0.15);color:var(--success);border:1px solid var(--success)}.badge-medium{background:rgba(245,158,11,0.15);color:var(--warning);border:1px solid var(--warning)}.badge-high{background:rgba(249,115,22,0.15);color:#f97316;border:1px solid #f97316}.badge-critical{background:rgba(220,38,38,0.15);color:var(--critical);border:1px solid var(--critical)}.badge-source-noaa{background:rgba(0,119,182,0.2);color:#90cdf4;border:1px solid var(--accent2)}.badge-source-user{background:rgba(0,180,216,0.15);color:var(--accent);border:1px solid var(--accent)}.badge-confirmed{background:rgba(34,197,94,0.15);color:var(--success);border:1px solid var(--success)}.badge-active{background:rgba(245,158,11,0.15);color:var(--warning);border:1px solid var(--warning)}.badge-resolved{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.hazard-desc{font-size:0.85rem;color:var(--text);line-height:1.6;margin-bottom:16px}.vote-buttons{display:flex;gap:8px;margin-bottom:16px}.vote-btn{flex:1;padding:12px;border-radius:8px;border:2px solid var(--border);background:var(--surface2);color:var(--text);font-size:0.85rem;font-weight:600;cursor:pointer;text-align:center;font-family:inherit;transition:all 0.15s}.vote-btn:hover{border-color:var(--text2)}.vote-btn.confirm:hover{border-color:var(--success);color:var(--success)}.vote-btn.deny:hover{border-color:var(--danger);color:var(--danger)}.hazard-photos{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.hazard-photos img{width:100px;height:80px;object-fit:cover;border-radius:8px;border:1px solid var(--border);cursor:pointer}.hazard-photos img:hover{border-color:var(--accent)}/* === LOCATE BUTTON === */.locate-btn{position:fixed;bottom:160px;right:12px;z-index:500;width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--border);color:var(--text2);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;box-shadow:0 4px 12px rgba(0,0,0,0.4)}.locate-btn:hover{border-color:var(--accent);color:var(--accent)}.locate-btn.locating{animation:pulse-locate 1s infinite}@keyframes pulse-locate{0%,100%{opacity:1}50%{opacity:0.5}}.user-location-dot{width:16px;height:16px;background:#4285f4;border:3px solid #fff;border-radius:50%;box-shadow:0 0 8px rgba(66,133,244,0.6)}/* === MAP CONTROLS === */.top-left-controls{position:fixed;top:68px;left:50%;transform:translateX(-50%);display:flex;gap:6px;justify-content:center;align-items:center;z-index:500}.top-left-controls .filter-bar{position:static;top:auto;left:auto}.top-btn{background:var(--surface) !important;border:1px solid var(--border) !important;backdrop-filter:blur(8px);font-size:0.8rem !important;font-weight:600 !important;padding:10px 16px !important;min-height:44px !important;min-width:110px !important;justify-content:center !important;border-radius:8px !important;white-space:nowrap !important;display:inline-flex !important;align-items:center !important;gap:6px !important;transition:all 0.15s !important;color:#ffffff !important}.top-btn:hover{border-color:var(--accent) !important}.map-controls{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:500}.map-ctrl-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 16px;min-width:90px;min-height:56px;color:var(--text);font-family:inherit;cursor:pointer;transition:background 0.15s, border-color 0.15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.map-ctrl-btn:active{background:var(--surface2);border-color:var(--accent)}.map-ctrl-btn.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.mc-icon{font-size:1.2rem;line-height:1;pointer-events:none;display:flex;align-items:center;justify-content:center;height:24px}.mc-icon svg{flex-shrink:0}.mc-label{font-size:0.7rem;font-weight:600;letter-spacing:0.02em;white-space:nowrap;pointer-events:none}.filter-bar{position:relative;z-index:500}.filter-toggle{min-height:44px;min-width:110px;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 16px;font-size:0.8rem;color:#ffffff;cursor:pointer;font-family:inherit;font-weight:600;display:flex;align-items:center;gap:6px;white-space:nowrap;transition:all 0.15s}.filter-toggle:hover{border-color:var(--accent)}.filter-dropdown{display:none;position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px;min-width:200px;max-height:calc(100vh - 140px);overflow-y:auto;box-shadow:0 8px 24px rgba(0,0,0,0.5);flex-direction:column;gap:4px}.filter-dropdown.open{display:flex}.filter-btn{background:none;border:1px solid transparent;border-radius:6px;padding:8px 10px;font-size:0.8rem;color:var(--text2);cursor:pointer;font-family:inherit;font-weight:500;display:flex;align-items:center;gap:8px;white-space:nowrap;transition:all 0.15s;text-align:left}.filter-btn:hover{background:var(--surface2);color:var(--text)}.filter-btn.active{color:var(--accent)}.filter-btn .check{width:16px;text-align:center;font-size:0.7rem}.filter-btn .check::before{content:''}.filter-btn.active .check::before{content:'✓';color:var(--accent)}/* === AUTH === */.auth-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.7);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:400px;width:100%;text-align:center}.auth-card{position:relative}.auth-close{position:absolute;top:10px;right:14px;background:none;border:none;color:var(--text2);font-size:1.6rem;cursor:pointer;line-height:1;padding:4px 8px}.auth-close:hover{color:var(--text1)}.auth-card h2{font-size:1.3rem;margin-bottom:4px}.auth-card .sub{color:var(--text2);font-size:0.85rem;margin-bottom:20px}.auth-error{color:var(--danger);font-size:0.8rem;margin-bottom:10px;min-height:20px}.auth-links{margin-top:14px;font-size:0.8rem}.auth-links a{color:var(--text2);margin:0 8px}.auth-links a:hover{color:var(--accent)}/* === TOAST === */.toast{position:fixed;top:70px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--accent);border-radius:8px;padding:10px 20px;font-size:0.85rem;color:var(--text);z-index:3000;animation:fadeInUp 0.3s}@keyframes fadeInUp{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}/* === MOBILE === */@media (max-width:768px){.panel-right{top:auto !important;bottom:0 !important;left:0 !important;right:0 !important;width:100% !important;max-width:100% !important;height:auto !important;max-height:75vh !important;min-height:200px;border-radius:16px 16px 0 0}.filter-bar{top:64px;left:4px}.topbar-brand .tagline{display:none}.topbar-actions{gap:4px}.topbar-actions .btn-sm{padding:8px 12px;font-size:0.8rem;min-height:44px}.map-controls{bottom:12px;gap:8px;width:100%;padding:0 12px}.map-ctrl-btn{flex:1;min-width:0;padding:10px 8px}.top-left-controls{top:64px}.leaflet-top.leaflet-right{top:56px !important}}/* === ADMIN === */.admin-container{margin-top:56px;padding:16px;max-width:1200px;margin-left:auto;margin-right:auto;height:calc(100vh - 56px);overflow-y:auto}.admin-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:8px}.admin-tab{background:none;border:none;color:var(--text2);font-family:inherit;font-size:0.85rem;font-weight:600;padding:8px 16px;cursor:pointer;border-radius:6px;transition:all 0.15s}.admin-tab:hover{background:var(--surface2);color:var(--text)}.admin-tab.active{background:var(--accent);color:#fff}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(140px, 1fr));gap:10px;margin-bottom:20px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;text-align:center}.stat-card.accent{border-color:var(--accent)}.stat-card.highlight{border-color:var(--warning)}.stat-val{font-size:1.5rem;font-weight:800;color:var(--text)}.stat-card.accent .stat-val{color:var(--accent)}.stat-card.highlight .stat-val{color:var(--warning)}.stat-label{font-size:0.65rem;color:var(--text2);text-transform:uppercase;letter-spacing:0.5px;margin-top:4px;font-weight:600}.admin-section{margin-bottom:24px}.admin-section h3{font-size:0.9rem;margin-bottom:10px;color:var(--text)}.cat-bars{display:flex;flex-direction:column;gap:6px}.cat-bar-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--surface);border-radius:6px;font-size:0.85rem}.cat-bar-val{font-weight:700;color:var(--accent)}.admin-search-bar{display:flex;gap:8px;margin-bottom:12px}.admin-search-bar input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:0.85rem;color:var(--text);outline:none;font-family:inherit}.admin-search-bar input:focus{border-color:var(--accent)}.admin-table-wrap{overflow-x:auto;margin-bottom:12px}.admin-table{width:100%;border-collapse:collapse;font-size:0.8rem}.admin-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--border);color:var(--text2);font-size:0.7rem;text-transform:uppercase;letter-spacing:0.5px;font-weight:600}.admin-table td{padding:8px 10px;border-bottom:1px solid var(--border)}.admin-table tr:hover td{background:var(--surface2)}.admin-pagination{display:flex;gap:8px;justify-content:center;margin-top:12px}.admin-error{background:rgba(239,68,68,0.1);border:1px solid var(--danger);border-radius:8px;padding:16px;color:var(--danger);text-align:center}.user-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.user-detail-badges{display:flex;gap:6px}.activity-columns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.activity-col h3{font-size:0.85rem;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.activity-item{padding:8px 0;border-bottom:1px solid var(--border);font-size:0.8rem}@media (max-width:768px){.stat-grid{grid-template-columns:repeat(2, 1fr)}.activity-columns{grid-template-columns:1fr}.admin-container{padding:10px}}/* Leaflet overrides */.leaflet-popup-content-wrapper{background:var(--surface) !important;color:var(--text) !important;border:1px solid var(--border) !important;border-radius:10px !important;box-shadow:0 4px 16px rgba(0,0,0,0.4) !important}.leaflet-popup-content{font-family:'Inter', sans-serif !important;font-size:0.85rem !important}.leaflet-popup-tip{background:var(--surface) !important}.leaflet-control-zoom{margin-top:80px !important}.leaflet-top.leaflet-right{top:50px !important}.leaflet-control-zoom a{background:var(--surface) !important;color:var(--text) !important;border-color:var(--border) !important}.leaflet-control-attribution{display:none !important}/* === MY STUFF PANEL === */.mystuff-tabs{display:flex;gap:4px;margin-bottom:14px}.mystuff-tab{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px;text-align:center;font-size:0.8rem;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit;transition:all 0.15s}.mystuff-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.mystuff-tab:hover:not(.active){border-color:var(--accent);color:var(--text)}.mystuff-item{display:flex;align-items:center;justify-content:space-between;padding:10px 8px;border-bottom:1px solid var(--border);gap:8px}.mystuff-item:last-child{border-bottom:none}.mystuff-item-main{display:flex;align-items:center;gap:10px;flex:1;cursor:pointer;min-width:0}.mystuff-item-info{min-width:0}.mystuff-item-name{font-size:0.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mystuff-item-sub{font-size:0.7rem;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mystuff-item-actions{display:flex;gap:4px;flex-shrink:0}.mystuff-empty{text-align:center;color:var(--text2);font-size:0.85rem;padding:30px 10px}.color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.wp-icon-small{font-size:1.1rem;flex-shrink:0}.wp-category-header{font-size:0.7rem;color:var(--text2);text-transform:uppercase;letter-spacing:0.5px;font-weight:600;padding:10px 8px 4px}.btn-icon{background:none;border:1px solid var(--border);border-radius:6px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.8rem;transition:all 0.15s}.btn-icon:hover{border-color:var(--accent)}.btn-icon-danger:hover{border-color:var(--danger)}/* === TRAIL RECORDER BAR === */.trail-recorder-bar{position:fixed;bottom:60px;left:50%;transform:translateX(-50%);background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:8px 14px;display:flex;align-items:center;gap:12px;z-index:600;box-shadow:0 4px 20px rgba(0,0,0,0.5)}.trail-rec-info{display:flex;flex-direction:column;gap:2px}.trail-rec-info span{font-size:0.75rem;color:var(--text2);font-family:'Courier New', monospace}.trail-rec-info span:first-child{font-size:1rem;font-weight:700;color:var(--accent)}.trail-rec-buttons{display:flex;gap:6px}.trail-rec-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:0.8rem;cursor:pointer;font-family:inherit;color:var(--text);font-weight:600;transition:all 0.15s}.trail-rec-btn:hover{border-color:var(--accent)}.trail-rec-btn.rec{border-color:var(--danger);color:var(--danger)}.trail-rec-btn.rec:hover{background:var(--danger);color:#fff}.trail-rec-btn.stop{border-color:var(--warning);color:var(--warning)}.trail-rec-btn.close{padding:8px;color:var(--text2)}/* === COLOR PICKER === */.color-picker-row{display:flex;gap:6px;flex-wrap:wrap}.color-pick{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);cursor:pointer;transition:all 0.15s}.color-pick:hover, .color-pick.active{border-color:#fff;transform:scale(1.15)}/* === ICON PICKER === */.icon-picker-row{display:flex;gap:6px;flex-wrap:wrap}.icon-pick, .icon-pick-sm{width:36px;height:36px;border-radius:8px;border:2px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:all 0.15s}.icon-pick-sm{width:30px;height:30px;font-size:0.9rem}.icon-pick:hover, .icon-pick.active, .icon-pick-sm:hover, .icon-pick-sm.active{border-color:var(--accent)}/* === WAYPOINT MARKERS === */.waypoint-marker{background:none !important;border:none !important}.wp-icon{width:30px;height:30px;background:var(--surface);border:2px solid var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 2px 8px rgba(0,0,0,0.4)}/* === COORDS DISPLAY === */.coords-display{text-align:center;padding:4px 0}/* ============================================================ LANDING PAGE ============================================================ */.landing{height:100vh;overflow-y:auto;overflow-x:hidden;background:var(--bg);scroll-behavior:smooth}.landing-nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:rgba(10,22,40,0.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav-logo{height:32px}.landing-nav-actions{display:flex;gap:8px}/* Hero */.landing-hero{display:flex;align-items:center;justify-content:center;min-height:70vh;padding:40px 24px;text-align:center;background:radial-gradient(ellipse at 50% 0%, rgba(0,180,216,0.12) 0%, transparent 70%)}@media (max-width:600px){.landing-hero{min-height:auto;padding:60px 20px 40px}}.landing-hero-inner{max-width:700px}.landing-badge{display:inline-block;padding:6px 16px;border-radius:20px;font-size:0.8rem;font-weight:600;color:var(--accent);background:rgba(0,180,216,0.1);border:1px solid rgba(0,180,216,0.25);margin-bottom:24px}.landing-title{font-size:clamp(3rem, 10vw, 5rem);font-weight:800;color:var(--accent);letter-spacing:-2px;line-height:1;margin-bottom:12px}.landing-title span{color:var(--text)}.landing-title-new{font-size:clamp(2.2rem, 8vw, 4rem);font-weight:800;color:#fff;letter-spacing:-1px;line-height:1.1;margin-bottom:16px}.landing-title-row{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:4px}.landing-logo-icon{height:clamp(60px, 12vw, 90px);border-radius:16px}.landing-slogan{font-size:clamp(1.2rem, 4vw, 1.6rem);font-weight:600;color:var(--text2);font-style:italic;letter-spacing:0.5px;margin-bottom:16px}.landing-tagline-new{font-size:clamp(1rem, 3vw, 1.3rem);font-weight:400;color:var(--text2);max-width:500px;margin:0 auto 24px;line-height:1.5}.landing-proof{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;margin-bottom:32px}.proof-item{font-size:0.85rem;font-weight:600;color:var(--accent)}.proof-divider{color:var(--text2);font-size:0.7rem}.landing-cta-sub{font-size:0.8rem;color:var(--text2);margin-top:12px}.landing-danger{padding:60px 24px;text-align:center;background:linear-gradient(to bottom, rgba(255,60,60,0.04), transparent)}.landing-danger-inner{max-width:600px;margin:0 auto}.landing-danger-text{font-size:1rem;color:var(--text2);line-height:1.7}.landing-danger em{color:#ff6b6b;font-style:italic}.feature-grid-3{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));gap:16px;max-width:900px;margin:0 auto}.landing-more-features{padding:60px 24px;max-width:700px;margin:0 auto}.more-features-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));gap:10px}.more-feature{display:flex;align-items:center;gap:8px;font-size:0.9rem;font-weight:500;color:var(--text2);padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.more-feature span{font-size:1.1rem}@media (max-width:600px){.landing-proof{flex-direction:column;gap:4px}.proof-divider{display:none}.more-features-grid{grid-template-columns:1fr 1fr;gap:8px}.more-feature{font-size:0.8rem;padding:8px 10px}.landing-more-features{padding:40px 20px}.landing-danger{padding:40px 20px}.feature-grid-3{gap:12px}}.landing-tagline{font-size:clamp(1.1rem, 3vw, 1.5rem);font-weight:600;color:var(--text);margin-bottom:12px}.landing-subtitle{font-size:1rem;color:var(--text2);max-width:540px;margin:0 auto 32px;line-height:1.6}.landing-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn-lg{padding:14px 28px;font-size:1rem;border-radius:10px}/* Features */.landing-features{padding:80px 24px;max-width:1100px;margin:0 auto}.landing-section-title{text-align:center;font-size:1.6rem;font-weight:800;margin-bottom:40px;color:var(--text)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));gap:16px}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;opacity:0;transform:translateY(20px);transition:opacity 0.5s, transform 0.5s, border-color 0.2s}.feature-card.visible{opacity:1;transform:translateY(0)}.feature-card:hover{border-color:var(--accent)}.feature-icon{font-size:2rem;margin-bottom:10px}.feature-card h3{font-size:1rem;font-weight:700;margin-bottom:6px}.feature-card p{font-size:0.85rem;color:var(--text2);line-height:1.5}/* How it works */.landing-how{padding:80px 24px;max-width:900px;margin:0 auto}.how-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));gap:24px}.how-step{text-align:center;opacity:0;transform:translateY(20px);transition:opacity 0.5s, transform 0.5s}.how-step.visible{opacity:1;transform:translateY(0)}.how-num{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;font-size:1.3rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.how-step h3{font-size:1rem;font-weight:700;margin-bottom:6px}.how-step p{font-size:0.85rem;color:var(--text2);line-height:1.5}/* OSS callout */.landing-oss{padding:80px 24px;background:linear-gradient(to bottom, transparent, rgba(0,180,216,0.05))}.landing-oss-inner{max-width:600px;margin:0 auto;text-align:center;opacity:0;transform:translateY(20px);transition:opacity 0.5s, transform 0.5s}.landing-oss-inner.visible{opacity:1;transform:translateY(0)}.landing-oss h2{font-size:1.5rem;font-weight:800;margin-bottom:12px}.landing-oss p{font-size:1rem;color:var(--text2);line-height:1.6}/* Mark My Spot */.mark-my-spot{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);z-index:600;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 18px;text-align:center;box-shadow:0 6px 24px rgba(0,0,0,0.4);animation:mmsSlideUp 0.3s ease;transition:opacity 0.3s}.mark-my-spot.mms-fade{opacity:0}@keyframes mmsSlideUp{from{transform:translateX(-50%) translateY(20px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}.mms-title{font-weight:700;font-size:0.95rem;margin-bottom:8px}.mms-buttons{display:flex;gap:8px;justify-content:center}/* Contact */.landing-contact{padding:60px 20px;text-align:center}.landing-contact-inner{max-width:1100px;margin:0 auto}.landing-contact h2{font-size:1.5rem;font-weight:800;margin-bottom:8px}.landing-contact .form-group{margin-bottom:14px}.landing-contact label{display:block;font-size:0.8rem;font-weight:600;margin-bottom:4px}/* First-time tour */.tour-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,0.6);display:flex;align-items:flex-end;justify-content:center;padding:20px;animation:fadeIn 0.3s}.tour-card{background:var(--surface, #0f2035);border:1px solid var(--border, #1e3a5f);border-radius:16px;padding:24px;max-width:360px;width:100%;margin-bottom:80px;box-shadow:0 8px 32px rgba(0,0,0,0.5);animation:slideUp 0.3s ease}@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.tour-text{font-size:0.95rem;line-height:1.6;color:var(--text, #e0e6ed);margin-bottom:16px}.tour-nav{display:flex;align-items:center;justify-content:space-between}.tour-btns{display:flex;gap:8px}.tour-highlight{position:relative;z-index:10000;box-shadow:0 0 0 4px var(--accent, #00d4aa), 0 0 20px rgba(0,212,170,0.4);border-radius:12px;animation:tourPulse 1.5s ease infinite}@keyframes tourPulse{0%, 100%{box-shadow:0 0 0 4px var(--accent, #00d4aa), 0 0 20px rgba(0,212,170,0.4)}50%{box-shadow:0 0 0 6px var(--accent, #00d4aa), 0 0 30px rgba(0,212,170,0.6)}}.tour-dots{display:flex;gap:6px}.tour-dot{width:8px;height:8px;border-radius:50%;background:var(--border, #1e3a5f)}.tour-dot.active{background:var(--accent, #00d4aa)}/* Footer */.landing-footer{border-top:1px solid var(--border);padding:24px}.landing-footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.landing-footer p{font-size:0.75rem;color:var(--text2)}@media (max-width:600px){.landing-footer-inner{flex-direction:column;gap:8px;text-align:center}}/* ============================================================ HELP PANEL ============================================================ */.help-section{border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden}.help-section-header{width:100%;background:var(--surface2);border:none;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-family:inherit;font-size:0.9rem;font-weight:700;color:var(--text);transition:background 0.15s}.help-section-header:hover{background:var(--border)}.help-chevron{font-size:0.7rem;color:var(--text2);transition:transform 0.25s}.help-section.open .help-chevron{transform:rotate(90deg)}.help-section-body{max-height:0;overflow:hidden;transition:max-height 0.3s ease}.help-section.open .help-section-body{max-height:2000px}.help-item{padding:10px 14px;border-top:1px solid var(--border)}.help-q{font-size:0.85rem;font-weight:600;color:var(--accent);margin-bottom:4px}.help-a{font-size:0.8rem;color:var(--text2);line-height:1.5}.help-a code{background:var(--surface2);padding:1px 5px;border-radius:4px;font-size:0.78rem;color:var(--accent)}/* Hazard tooltip popup */.hazard-tooltip-popup .maplibregl-popup-content{background:#1a2a44;color:#ffffff;font-size:13px;font-weight:500;padding:8px 12px;border-radius:8px;border:1px solid #2a3a54;box-shadow:0 4px 12px rgba(0,0,0,0.5)}.hazard-tooltip-popup .maplibregl-popup-content strong{color:#ffffff;font-weight:700}.hazard-tooltip-popup .maplibregl-popup-tip{border-top-color:#1a2a44}/* Export/Import tabs */.tab-btn{flex:1;padding:10px;background:transparent;border:none;color:var(--text2);font-size:0.85rem;font-weight:600;cursor:pointer;transition:all 0.15s}.tab-btn.active{color:var(--accent);border-bottom:2px solid var(--accent)}.tab-btn:hover:not(.active){color:var(--text1);background:rgba(255,255,255,0.03)}@keyframes spin{to{transform:rotate(360deg)}}/* Icon Set Picker (test only) */#iconPicker{position:fixed;bottom:80px;right:10px;z-index:9999;background:rgba(15,32,53,0.95);border:1px solid #1e3a5f;border-radius:12px;padding:10px;backdrop-filter:blur(10px);display:flex;flex-direction:column;gap:6px}.icon-set-btn{background:var(--surface2, #162d4a);border:2px solid var(--border, #1e3a5f);color:#e0e6ed;padding:8px 14px;border-radius:8px;font-size:0.8rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s}.icon-set-btn:hover{border-color:#00d4aa}.icon-set-btn.active{border-color:#00d4aa;background:rgba(0,212,170,0.15);color:#00d4aa}/* === PASSWORD STRENGTH INDICATOR === */.pass-strength{margin-top:8px;padding:0 4px}/* === SCROLL HINT === */.scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);font-size:1.5rem;color:rgba(255, 255, 255, 0.7);cursor:pointer;animation:bounce 2s infinite, fadeOut 3s forwards}@keyframes bounce{0%, 20%, 50%, 80%, 100%{transform:translateX(-50%) translateY(0)}40%{transform:translateX(-50%) translateY(-10px)}60%{transform:translateX(-50%) translateY(-5px)}}@keyframes fadeOut{0%{opacity:1}80%{opacity:1}100%{opacity:0}}/* === MOBILE TOPBAR HAMBURGER === */.topbar-menu-toggle{display:none;background:none;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1.3rem;width:40px;height:40px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}@media (max-width:768px){.topbar-menu-toggle{display:flex}.topbar-actions{display:none;position:absolute;top:55px;right:0;background:var(--surface);border:1px solid var(--border);border-radius:0 0 12px 12px;padding:10px 14px;flex-direction:column;gap:6px;min-width:180px;box-shadow:0 8px 24px rgba(0,0,0,0.4);z-index:1001}.topbar-actions.mobile-open{display:flex}.topbar-actions .btn-sm{width:100%;text-align:center;justify-content:center}.topbar-actions span[style]{text-align:center;padding:4px 0}}/* === LANDING NAV MOBILE HAMBURGER === */.landing-menu-toggle{display:none;background:none;border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1.3rem;width:40px;height:40px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}@media (max-width:768px){.landing-menu-toggle{display:flex}.landing-nav-actions{display:none;position:absolute;top:100%;right:0;background:rgba(10,22,40,0.95);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:0 0 12px 12px;padding:10px 14px;flex-direction:column;gap:6px;min-width:180px;box-shadow:0 8px 24px rgba(0,0,0,0.4);z-index:101}.landing-nav-actions.mobile-open{display:flex}.landing-nav-actions .btn-sm{width:100%;text-align:center;justify-content:center}.landing-nav{position:relative}}/* === Landing auth buttons below CTA === */.landing-auth-btns{display:flex;gap:12px;justify-content:center;margin-top:16px}.landing-auth-btns .btn-sm{min-width:100px}


/* Waypoint hover tooltip */
.waypoint-marker{position:relative;overflow:visible!important}
.wp-tooltip{position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:rgba(15,32,53,0.95);color:#e8edf2;padding:4px 10px;border-radius:6px;font-size:0.75rem;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity 0.15s;z-index:9999;margin-bottom:4px;border:1px solid rgba(30,58,95,0.8);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.waypoint-marker:hover .wp-tooltip{opacity:1}

/* Hover tooltips (universal) */
[data-tip]{position:relative}
[data-tip]::after{content:attr(data-tip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:rgba(15,32,53,0.95);color:#e8edf2;padding:4px 10px;border-radius:6px;font-size:0.7rem;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity 0.15s;z-index:9999;margin-bottom:4px;border:1px solid rgba(30,58,95,0.8);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
[data-tip]:hover::after{opacity:1}

/* Waypoint/trail visibility toggle */
.wp-vis-toggle{background:none!important;border:none!important;padding:2px 4px!important;font-size:1rem;cursor:pointer;opacity:0.7;transition:opacity 0.15s}
.wp-vis-toggle:hover{opacity:1}

/* Speed HUD */
.speed-hud{position:fixed;bottom:160px;right:12px;z-index:800;background:rgba(10,20,40,0.85);border:1px solid rgba(0,212,170,0.4);border-radius:12px;padding:8px 14px;text-align:center;backdrop-filter:blur(8px);pointer-events:none;min-width:60px}
.speed-hud #speedVal{font-size:1.8rem;font-weight:800;color:#00d4aa;line-height:1}
.speed-hud #speedUnit{display:block;font-size:0.75rem;color:rgba(255,255,255,0.6);margin-top:2px;line-height:1.2}
.speed-hud .speed-mph{font-size:0.65rem;opacity:0.7}

/* Fix: push MapLibre zoom/nav controls above bottom bar on mobile */
.maplibregl-ctrl-bottom-right{bottom:90px !important;right:8px !important}
@media (max-width:768px){.maplibregl-ctrl-bottom-right{bottom:85px !important;right:8px !important}.locate-btn{bottom:145px !important}.speed-hud{bottom:195px !important}}

/* Hide MapLibre info/attribution button */
.maplibregl-ctrl-attrib,.maplibregl-ctrl-logo{display:none !important}

/* Ensure locate btn and speed HUD stay above MapLibre controls */
.locate-btn{z-index:800 !important}

/* Fix: data-tip was overriding position:fixed on locate btn */
.locate-btn{position:fixed !important;bottom:220px !important}

/* Hide username on desktop topbar */
@media (min-width:769px){.topbar-actions span[style*="font-size:0.8rem"]{display:none}}

/* Move speed HUD above follow button on mobile */
.speed-hud{position:fixed !important;bottom:275px !important}

/* Larger, white close button on panels (mobile) */
.panel-close{font-size:2rem !important;color:#fff !important;padding:8px 12px !important;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
