:root{--color-primary: #1e3a5f;--color-primary-light: #2c5282;--color-clear-bg: #d4edda;--color-clear-text: #155724;--color-clear-btn: #28a745;--color-not-clear-bg: #f8d7da;--color-not-clear-text: #721c24;--color-not-clear-btn: #dc3545;--color-not-clear-btn-hover: #c82333;--color-unknown-bg: #e2e3e5;--color-unknown-text: #383d41;--color-unknown-btn: #6c757d;--color-bg: #f5f5f5;--color-surface: white;--color-text: #333;--color-text-muted: #666;--color-text-faint: #888;--color-border: #eee;--color-section-bg: #f8f9fa;--color-overlay: rgba(0, 0, 0, .5);--color-inapp-start: #ff6b35;--color-inapp-end: #f7931e;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--space-3xl: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-pill: 20px;--radius-card: 24px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 2px 8px rgba(0, 0, 0, .2);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .3);--shadow-overlay: 0 8px 32px rgba(0, 0, 0, .2);--z-header: 1000;--z-banner: 2000;--z-modal: 2000;--z-overlay: 9999;--z-toast: 3000}[data-theme=dark]{--color-primary: #4a90d9;--color-primary-light: #5ba3ec;--color-bg: #1a1a2e;--color-surface: #16213e;--color-text: #e0e0e0;--color-text-muted: #a0a0a0;--color-text-faint: #777;--color-border: #2a2a4a;--color-section-bg: #1f1f3a;--color-overlay: rgba(0, 0, 0, .7);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .5);--shadow-overlay: 0 8px 32px rgba(0, 0, 0, .5)}[data-theme=dark] .header{background:linear-gradient(135deg,#0d1b2a,#1b2838)}[data-theme=dark] .filter-btn{background:var(--color-section-bg);color:var(--color-text-muted);border-color:var(--color-border)}[data-theme=dark] .filter-btn.active{color:#fff}[data-theme=dark] .modal{background:var(--color-surface);color:var(--color-text)}[data-theme=dark] .bottom-nav{background:var(--color-surface);border-top-color:var(--color-border)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text)}.header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;padding:var(--space-lg);text-align:center;position:sticky;top:0;z-index:var(--z-header);box-shadow:var(--shadow-md)}.header-inner{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.header-brand{text-decoration:none;color:#fff}.header h1{font-size:1.5rem;margin-bottom:var(--space-xs)}.header p{font-size:.85rem;opacity:.9}.header-signin{padding:var(--space-sm) var(--space-lg);background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;text-decoration:none;white-space:nowrap}.header-signin:hover{background:#ffffff4d}.header-user{position:relative}.header-user-btn{display:flex;align-items:center;gap:var(--space-sm);padding:6px var(--space-md);background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-pill);color:#fff;cursor:pointer;font-size:.85rem;font-family:var(--font-family);transition:background .2s}.header-user-btn:hover{background:#ffffff40}.header-avatar{width:28px;height:28px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}.header-email{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-dropdown{display:none;position:absolute;top:calc(100% + var(--space-sm));right:0;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);min-width:180px;z-index:calc(var(--z-header) + 1);overflow:hidden}.header-dropdown.open{display:block}.header-dropdown a,.header-dropdown button{display:block;width:100%;padding:var(--space-md) var(--space-lg);text-align:left;text-decoration:none;color:var(--color-text);font-size:.9rem;font-family:var(--font-family);background:none;border:none;cursor:pointer;transition:background .15s}.header-dropdown a:hover,.header-dropdown button:hover{background:var(--color-section-bg)}.header-dropdown .dropdown-divider{height:1px;background:var(--color-border);padding:0}@media (max-width: 420px){.header-email{display:none}}#map{height:45vh;min-height:300px;width:100%}.section{background:var(--color-surface);margin:var(--space-md);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.section-header{background:var(--color-section-bg);padding:var(--space-md) var(--space-lg);font-weight:600;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.nearby-list{max-height:200px;overflow-y:auto}.hydrant-item{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background .2s}.hydrant-item:hover{background:var(--color-section-bg)}.hydrant-item:last-child{border-bottom:none}.hydrant-info{flex:1}.hydrant-address{font-weight:500;margin-bottom:2px}.hydrant-distance{font-size:.8rem;color:var(--color-text-muted)}.status-badge{padding:var(--space-xs) 10px;border-radius:var(--radius-pill);font-size:.75rem;font-weight:600;text-transform:uppercase}.status-clear{background:var(--color-clear-bg);color:var(--color-clear-text)}.status-not_clear{background:var(--color-not-clear-bg);color:var(--color-not-clear-text)}.status-unknown{background:var(--color-unknown-bg);color:var(--color-unknown-text)}.dashboard{padding:var(--space-lg)}.dashboard-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.town-tabs{display:flex;gap:var(--space-sm);flex-wrap:wrap}.town-select{display:none;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:.85rem;font-family:var(--font-family);background:var(--color-surface);color:var(--color-text);cursor:pointer}.stats-total{margin-left:auto;font-size:.8rem;color:var(--color-text-muted);font-weight:500}@media (max-width: 480px){.town-tabs{display:none}.town-select{display:block;flex:1}}.town-tab{padding:var(--space-sm) var(--space-lg);border:none;border-radius:var(--radius-pill);background:var(--color-unknown-bg);cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.town-tab.active{background:var(--color-primary);color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.stat-card{text-align:center;padding:var(--space-lg) var(--space-sm);border-radius:var(--radius-lg)}.stat-card.clear{background:var(--color-clear-bg)}.stat-card.not-clear{background:var(--color-not-clear-bg)}.stat-card.unknown{background:var(--color-unknown-bg)}.donut-chart{display:block;margin:0 auto var(--space-sm)}.donut-bg{opacity:.3}.donut-ring{stroke-dashoffset:213.6;transition:stroke-dashoffset .8s ease-out}.donut-ring.donut-animate{stroke-dashoffset:attr(stroke-dashoffset)}.donut-text{font-size:14px;font-weight:700;fill:var(--color-text)}.stat-value{font-size:1.6rem;font-weight:700}.stat-label{font-size:.7rem;text-transform:uppercase;opacity:.8;margin-top:var(--space-xs)}.stat-bar{height:4px;background:#0000001a;border-radius:2px;margin-top:var(--space-sm);overflow:hidden}.stat-bar-fill{height:100%;border-radius:2px;transition:width .6s ease-out}.stat-bar-clear{background:var(--color-clear-btn)}.stat-bar-not-clear{background:var(--color-not-clear-btn)}.stat-bar-unknown{background:var(--color-unknown-btn)}.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-overlay);z-index:var(--z-modal);justify-content:center;align-items:center}.modal-overlay.active{display:flex}.modal{background:var(--color-surface);border-radius:var(--radius-2xl);width:90%;max-width:400px;padding:var(--space-2xl);text-align:center}.modal h2{margin-bottom:var(--space-sm)}.modal-address{color:var(--color-text-muted);margin-bottom:var(--space-xl)}.modal-question{font-size:1.1rem;margin-bottom:var(--space-xl);font-weight:500}.modal-buttons{display:flex;flex-direction:column;gap:10px}.modal-btn{padding:14px;border:none;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;cursor:pointer;transition:transform .1s,opacity .2s}.modal-btn:active{transform:scale(.98)}.modal-btn.yes{background:var(--color-clear-btn);color:#fff}.modal-btn.no{background:var(--color-not-clear-btn);color:#fff}.modal-btn.unknown{background:var(--color-unknown-btn);color:#fff}.modal-btn.cancel{background:transparent;color:var(--color-text-muted);margin-top:var(--space-sm)}.modal-photo{margin-bottom:var(--space-lg)}.modal-photo-label{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;color:var(--color-text-muted);font-size:.9rem;transition:border-color .2s,color .2s}.modal-photo-label:hover{border-color:var(--color-primary);color:var(--color-primary)}.modal-photo-icon{font-size:1.2rem}.modal-photo-preview{position:relative;display:inline-block;max-width:100%}.modal-photo-preview img{max-width:100%;max-height:160px;border-radius:var(--radius-lg);object-fit:cover}.modal-photo-remove{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;border:none;background:var(--color-not-clear-btn);color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.loading{text-align:center;padding:var(--space-xl);color:var(--color-text-muted)}.locate-btn{background:var(--color-primary);color:#fff;border:none;padding:var(--space-md) var(--space-md);border-radius:var(--radius-md);font-size:.8rem;cursor:pointer}.custom-marker{background:transparent;border:none}.leaflet-popup-content{text-align:center}.popup-btn{margin-top:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.9rem}.footer{text-align:center;padding:var(--space-xl);color:var(--color-text-muted);font-size:.8rem}.reset-btn{background:var(--color-not-clear-btn);color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;margin-top:var(--space-lg)}.reset-btn:hover{background:var(--color-not-clear-btn-hover)}.connection-status{position:fixed;bottom:var(--space-lg);left:var(--space-lg);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-pill);font-size:.75rem;font-weight:600;z-index:var(--z-header)}.connection-status.connected{background:var(--color-clear-bg);color:var(--color-clear-text)}.connection-status.disconnected{background:var(--color-not-clear-bg);color:var(--color-not-clear-text)}.inapp-banner{background:linear-gradient(135deg,var(--color-inapp-start) 0%,var(--color-inapp-end) 100%);color:#fff;padding:var(--space-lg);text-align:center;position:fixed;top:0;left:0;right:0;z-index:var(--z-banner);box-shadow:var(--shadow-lg)}.inapp-banner h3{margin-bottom:var(--space-sm);font-size:1.1rem}.inapp-banner p{font-size:.9rem;margin-bottom:var(--space-md);opacity:.95}.inapp-banner-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.inapp-btn{padding:10px var(--space-xl);border-radius:var(--radius-lg);font-weight:600;font-size:.9rem;cursor:pointer;border:none;transition:transform .1s}.inapp-btn:active{transform:scale(.97)}.inapp-btn-primary{background:#fff;color:var(--color-inapp-start)}.inapp-btn-secondary{background:#fff3;color:#fff}body.inapp-banner-visible .header{top:140px}@media (min-width: 500px){body.inapp-banner-visible .header{top:120px}}.welcome-gate-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:var(--z-overlay);display:flex;justify-content:center;align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#1e3a5f66}.welcome-gate-card{position:relative;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-card);padding:var(--space-3xl) 40px;text-align:center;box-shadow:var(--shadow-overlay);border:1px solid rgba(255,255,255,.3);max-width:460px;width:90%}.welcome-gate-logo{width:80px;height:80px;margin:0 auto var(--space-xl)}.welcome-gate-title{font-size:2.2rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--space-sm);letter-spacing:-.5px}.welcome-gate-subtitle{font-size:1rem;color:#555;line-height:1.5;margin-bottom:var(--space-lg)}.welcome-gate-question{font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-xl)}.welcome-gate-buttons{display:flex;flex-direction:column;gap:var(--space-md)}.welcome-gate-btn{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border:2px solid var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface);cursor:pointer;transition:border-color .2s,box-shadow .2s;text-align:left;font-family:var(--font-family)}.welcome-gate-btn:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.welcome-gate-btn-icon{font-size:2rem;flex-shrink:0}.welcome-gate-btn-label{display:block;font-weight:700;font-size:1rem;color:var(--color-primary)}.welcome-gate-btn-desc{display:block;font-size:.8rem;color:var(--color-text-muted);margin-top:2px}.welcome-gate-btn-muni{border-color:var(--color-primary);background:#1e3a5f08}.welcome-gate-btn-muni:hover{background:#1e3a5f14}.map-controls{display:flex;gap:6px;padding:var(--space-sm) var(--space-md);background:var(--color-section-bg);border-bottom:1px solid var(--color-border)}.filter-btn{padding:6px 14px;border:2px solid transparent;border-radius:var(--radius-pill);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;opacity:.4}.filter-btn.active{opacity:1}.filter-all{background:var(--color-primary);color:#fff}.filter-clear{background:var(--color-clear-bg);color:var(--color-clear-text);border-color:var(--color-clear-btn)}.filter-not-clear{background:var(--color-not-clear-bg);color:var(--color-not-clear-text);border-color:var(--color-not-clear-btn)}.filter-unknown{background:var(--color-unknown-bg);color:var(--color-unknown-text);border-color:var(--color-unknown-btn)}.auth-page{display:flex;justify-content:center;align-items:flex-start;padding:var(--space-3xl) var(--space-lg);min-height:60vh}.auth-card{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);padding:var(--space-3xl) var(--space-2xl);width:100%;max-width:380px;text-align:center}.auth-title{color:var(--color-primary);font-size:1.6rem;margin-bottom:var(--space-2xl)}.auth-subtitle{color:var(--color-text-muted);font-size:.85rem;margin-top:calc(-1 * var(--space-lg));margin-bottom:var(--space-2xl);line-height:1.4}.auth-form{display:flex;flex-direction:column;gap:var(--space-lg);text-align:left}.auth-field label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}.auth-field input{width:100%;padding:var(--space-md) var(--space-lg);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:1rem;font-family:var(--font-family);transition:border-color .2s}.auth-field input:focus{outline:none;border-color:var(--color-primary)}.auth-error{background:var(--color-not-clear-bg);color:var(--color-not-clear-text);padding:var(--space-md);border-radius:var(--radius-md);font-size:.85rem;text-align:center}.auth-success{background:var(--color-clear-bg);color:var(--color-clear-text);padding:var(--space-md);border-radius:var(--radius-md);font-size:.85rem;text-align:center}.auth-submit{width:100%;padding:14px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s;font-family:var(--font-family)}.auth-submit:hover{opacity:.9}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-alt{margin-top:var(--space-xl);font-size:.85rem;color:var(--color-text-muted)}.auth-alt a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-alt a:hover{text-decoration:underline}.auth-back{display:inline-block;margin-top:var(--space-md);font-size:.8rem;color:var(--color-text-faint);text-decoration:none}.auth-back:hover{color:var(--color-primary)}.profile-card{max-width:440px}.profile-avatar-large{width:64px;height:64px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:1.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-sm)}.profile-avatar-large .avatar-img,.avatar-img{border-radius:50%;object-fit:cover}.avatar-picker{margin-bottom:var(--space-lg);text-align:center}.avatar-picker-label{font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.avatar-preset-grid{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-md)}.avatar-preset-btn{width:52px;height:52px;border-radius:50%;border:2px solid transparent;background:none;cursor:pointer;padding:0;transition:border-color .2s,transform .1s;overflow:hidden}.avatar-preset-btn img{border-radius:50%;display:block}.avatar-preset-btn:hover{border-color:var(--color-primary-light);transform:scale(1.1)}.avatar-preset-btn.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary)}.avatar-upload-row{display:flex;gap:var(--space-sm);justify-content:center;align-items:center}.avatar-upload-btn{display:inline-block;padding:var(--space-xs) var(--space-md);font-size:.8rem;color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:background .2s}.avatar-upload-btn:hover{background:var(--color-primary);color:#fff}.avatar-remove-btn{padding:var(--space-xs) var(--space-md);font-size:.8rem;color:var(--color-not-clear-text);border:1px solid var(--color-not-clear-btn);border-radius:var(--radius-md);background:none;cursor:pointer}.avatar-remove-btn:hover{background:var(--color-not-clear-btn);color:#fff}.profile-email{color:var(--color-text-muted);font-size:.85rem;margin-bottom:var(--space-2xl)}.profile-toggle-row{display:flex;align-items:center;justify-content:space-between}.profile-toggle-label{font-size:.85rem;font-weight:600;color:var(--color-text)}.profile-switch{position:relative;width:44px;height:24px;flex-shrink:0}.profile-switch input{opacity:0;width:0;height:0}.profile-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#ccc;border-radius:24px;cursor:pointer;transition:background .2s}.profile-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}.profile-switch input:checked+.profile-slider{background:var(--color-clear-btn)}.profile-switch input:checked+.profile-slider:before{transform:translate(20px)}.profile-toggle-hint{font-size:.75rem;color:var(--color-text-faint);margin-top:calc(-1 * var(--space-sm))}.profile-loading{color:var(--color-text-muted);padding:var(--space-2xl) 0}.profile-section{margin-top:var(--space-2xl);padding-top:var(--space-2xl);border-top:1px solid var(--color-border);text-align:left}.profile-section-title{font-size:.95rem;color:var(--color-primary);margin-bottom:var(--space-md)}.profile-history-empty{color:var(--color-text-muted);font-size:.85rem;text-align:center;padding:var(--space-xl) 0}.profile-history{display:flex;flex-direction:column;gap:var(--space-sm)}.profile-history-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--color-section-bg);border-radius:var(--radius-md);font-size:.85rem}.profile-history-status{font-weight:600}.profile-status-clear{color:var(--color-clear-text)}.profile-status-not-clear{color:var(--color-not-clear-text)}.profile-status-unknown{color:var(--color-unknown-text)}.profile-history-date{color:var(--color-text-muted);font-size:.8rem}.admin-card{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);padding:var(--space-3xl) var(--space-2xl);width:100%;max-width:600px;text-align:center}.admin-municipality{color:var(--color-text-muted);font-size:.9rem;margin-bottom:var(--space-2xl)}.admin-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-2xl)}.admin-stat-card{background:var(--color-section-bg);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-lg)}.admin-stat-value{font-size:2rem;font-weight:700;color:var(--color-primary)}.admin-stat-pending .admin-stat-value{color:var(--color-not-clear-btn)}.admin-stat-label{font-size:.8rem;color:var(--color-text-muted);margin-top:var(--space-xs)}.admin-section{text-align:left;margin-top:var(--space-lg)}.admin-section-title{font-size:.95rem;color:var(--color-primary);margin-bottom:var(--space-md)}.admin-activity-list{display:flex;flex-direction:column;gap:var(--space-sm)}.admin-activity-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--color-section-bg);border-radius:var(--radius-md);font-size:.85rem}.admin-activity-info{display:flex;align-items:center;gap:var(--space-sm)}.admin-activity-hydrant{color:var(--color-text-muted);font-size:.8rem}.admin-activity-date{color:var(--color-text-faint);font-size:.75rem;white-space:nowrap}.admin-verified-badge{background:var(--color-clear-bg);color:var(--color-clear-text);font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm)}.admin-empty{color:var(--color-text-muted);text-align:center;padding:var(--space-xl) 0;font-size:.85rem}.admin-stat-clear .admin-stat-value{color:var(--color-clear-text)}.admin-stat-notclear .admin-stat-value{color:var(--color-not-clear-btn)}.admin-reporters-list{display:flex;flex-direction:column;gap:var(--space-xs)}.admin-reporter-row{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-section-bg);border-radius:var(--radius-md);font-size:.85rem}.admin-reporter-rank{width:24px;height:24px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}.admin-reporter-name{flex:1;font-weight:500}.admin-reporter-count{color:var(--color-text-muted);font-size:.8rem;white-space:nowrap}.admin-suspicious-badge{background:var(--color-not-clear-bg);color:var(--color-not-clear-text);font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);white-space:nowrap}.admin-export-btn{width:100%;padding:var(--space-md) var(--space-lg);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-lg);font-size:.9rem;font-weight:600;cursor:pointer;font-family:var(--font-family);transition:opacity .2s}.admin-export-btn:hover{opacity:.9}.admin-export-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 420px){.admin-stats-grid{grid-template-columns:1fr}}.admin-nav-links{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-xl);margin-bottom:var(--space-lg)}.admin-nav-link{display:block;padding:var(--space-md) var(--space-lg);background:var(--color-primary);color:#fff;border-radius:var(--radius-lg);text-decoration:none;font-weight:600;font-size:.9rem;transition:opacity .2s}.admin-nav-link:hover{opacity:.9}.invite-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-2xl);max-width:560px;margin:0 auto;box-shadow:0 1px 3px #0000001a}.invite-generate{display:flex;gap:var(--space-sm);margin-bottom:var(--space-xl);align-items:flex-end}.invite-generate select{flex:1;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem;background:var(--color-surface);color:var(--color-text)}.invite-generate-btn{padding:var(--space-sm) var(--space-lg);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;cursor:pointer;white-space:nowrap;transition:opacity .2s}.invite-generate-btn:hover{opacity:.9}.invite-generate-btn:disabled{opacity:.5;cursor:not-allowed}.invite-list{display:flex;flex-direction:column;gap:var(--space-sm)}.invite-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-section-bg)}.invite-item-used{opacity:.6}.invite-item-expired{opacity:.5}.invite-code-value{font-family:SF Mono,Fira Code,monospace;font-size:1rem;font-weight:700;color:var(--color-primary);letter-spacing:.05em}.invite-meta{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.invite-role-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;text-transform:uppercase}.invite-role-admin{background:#fff3cd;color:#856404}.invite-role-public{background:#d4edda;color:#155724}.invite-status{font-size:.75rem;color:var(--color-text-muted)}.invite-actions{display:flex;gap:var(--space-xs)}.invite-copy-btn{padding:var(--space-xs) var(--space-sm);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:opacity .2s}.invite-copy-btn:hover{opacity:.9}.invite-empty{text-align:center;color:var(--color-text-muted);padding:var(--space-xl) 0;font-size:.9rem}.invite-section-title{font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-md)}.join-code-input{font-family:SF Mono,Fira Code,monospace;font-size:1.2rem;text-align:center;letter-spacing:.1em;text-transform:uppercase}.join-success{text-align:center;padding:var(--space-xl) 0}.join-success-icon{font-size:3rem;margin-bottom:var(--space-md)}.join-success-title{font-size:1.2rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--space-sm)}.join-success-detail{color:var(--color-text-muted);font-size:.9rem}.verify-card{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);padding:var(--space-3xl) var(--space-2xl);width:100%;max-width:640px;text-align:center}.verify-subtitle{color:var(--color-text-muted);font-size:.85rem;margin-bottom:var(--space-xl)}.verify-item{text-align:left;background:var(--color-section-bg);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);transition:opacity .5s,transform .5s}.verify-item-approved{opacity:0;transform:translate(100%)}.verify-item-rejected{opacity:0;transform:translate(-100%)}.verify-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}.verify-hydrant{font-weight:600;font-size:.9rem}.verify-date{color:var(--color-text-faint);font-size:.75rem;margin-left:auto;white-space:nowrap}.verify-photo{margin-bottom:var(--space-md)}.verify-photo img{max-width:100%;max-height:200px;border-radius:var(--radius-md);object-fit:cover}.verify-details{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.verify-detail{font-size:.8rem;color:var(--color-text-muted)}.verify-detail-label{font-weight:600;color:var(--color-text)}.verify-ua{word-break:break-all;font-size:.7rem}.verify-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.verify-btn{padding:var(--space-sm) var(--space-lg);border:none;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;font-family:var(--font-family);transition:opacity .2s}.verify-btn:hover{opacity:.9}.verify-btn:disabled{opacity:.5;cursor:not-allowed}.verify-btn-approve{background:var(--color-clear-bg);color:var(--color-clear-text)}.verify-btn-reject{background:var(--color-not-clear-bg);color:var(--color-not-clear-text)}.import-card{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);padding:var(--space-3xl) var(--space-2xl);width:100%;max-width:640px;text-align:center}.import-instructions{text-align:left;background:var(--color-section-bg);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);font-size:.85rem;color:var(--color-text-muted);line-height:1.6}.import-instructions code{background:#0000000f;padding:1px 5px;border-radius:var(--radius-sm);font-size:.8rem}.import-upload-area{border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--space-3xl) var(--space-xl);cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:var(--space-xl)}.import-upload-area:hover,.import-upload-area.drag-over{border-color:var(--color-primary);background:#1e3a5f08}.import-upload-label{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);cursor:pointer;color:var(--color-text-muted);font-size:.9rem}.import-upload-icon{font-size:2rem}.import-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.import-count{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.import-table-wrap{overflow-x:auto;margin-bottom:var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.import-table{width:100%;border-collapse:collapse;font-size:.8rem;text-align:left}.import-table th{background:var(--color-section-bg);padding:var(--space-sm) var(--space-md);font-weight:600;border-bottom:1px solid var(--color-border);white-space:nowrap}.import-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-table tr:last-child td{border-bottom:none}.import-actions{display:flex;gap:var(--space-md);justify-content:flex-end}.import-btn-cancel{padding:12px var(--space-xl);background:none;border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:.9rem;font-weight:600;cursor:pointer;color:var(--color-text-muted);font-family:var(--font-family);transition:border-color .2s}.import-btn-cancel:hover{border-color:var(--color-text-muted)}.import-actions .auth-submit{width:auto;padding:12px var(--space-2xl)}.leaderboard-card{background:var(--color-surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);padding:var(--space-3xl) var(--space-2xl);width:100%;max-width:520px;text-align:center}.leaderboard-subtitle{color:var(--color-text-muted);font-size:.85rem;margin-top:calc(-1 * var(--space-lg));margin-bottom:var(--space-xl)}.leaderboard-filter{margin-bottom:var(--space-lg)}.leaderboard-select{width:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:.9rem;font-family:var(--font-family);background:var(--color-surface);color:var(--color-text);cursor:pointer}.leaderboard-select:focus{outline:none;border-color:var(--color-primary)}.leaderboard-list{text-align:left}.leaderboard-empty{color:var(--color-text-muted);font-size:.85rem;text-align:center;padding:var(--space-2xl) 0}.leaderboard-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-lg);transition:background .15s}.leaderboard-row:hover{background:var(--color-section-bg)}.leaderboard-gold{background:#ffd70014}.leaderboard-silver{background:#c0c0c014}.leaderboard-bronze{background:#cd7f3214}.leaderboard-rank{width:28px;height:28px;border-radius:50%;background:var(--color-section-bg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--color-text-muted);flex-shrink:0}.leaderboard-gold .leaderboard-rank{background:gold;color:#7a6200}.leaderboard-silver .leaderboard-rank{background:silver;color:#555}.leaderboard-bronze .leaderboard-rank{background:#cd7f32;color:#fff}.leaderboard-avatar{flex-shrink:0}.leaderboard-avatar .avatar-img{border-radius:50%;object-fit:cover}.leaderboard-avatar .header-avatar{border-radius:50%;background:var(--color-primary);color:#fff}.leaderboard-info{flex:1;min-width:0}.leaderboard-name{display:block;font-weight:600;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-muni{display:block;font-size:.75rem;color:var(--color-text-muted)}.leaderboard-stats{display:flex;gap:var(--space-md);flex-shrink:0;text-align:center}.leaderboard-reports,.leaderboard-verified{display:flex;flex-direction:column;align-items:center;font-size:.95rem;font-weight:700;min-width:36px}.leaderboard-reports:after{content:"reports";font-size:.6rem;font-weight:400;color:var(--color-text-muted);text-transform:uppercase}.leaderboard-verified:after{content:"verified";font-size:.6rem;font-weight:400;color:var(--color-clear-text);text-transform:uppercase}.leaderboard-verified{color:var(--color-clear-text)}.popup-content{text-align:center;min-width:160px}.popup-content .popup-address{font-weight:600;font-size:.95rem;margin-bottom:6px}.popup-content .popup-town{font-size:.75rem;color:var(--color-text-faint);margin-bottom:var(--space-sm)}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top:1px solid var(--color-border);z-index:var(--z-header);padding:var(--space-xs) 0;padding-bottom:env(safe-area-inset-bottom,0)}@media (max-width: 768px){.bottom-nav{display:flex;justify-content:space-around;align-items:center}body{padding-bottom:64px}.connection-status{bottom:72px!important}}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-sm) var(--space-md);min-width:64px;min-height:44px;color:var(--color-text-muted);text-decoration:none;font-size:.65rem;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.bottom-nav-item svg{width:22px;height:22px}.bottom-nav-item.active,.bottom-nav-item:hover{color:var(--color-primary)}@media (max-width: 480px){.filter-btn{min-height:44px;min-width:44px;padding:10px 12px;font-size:.75rem}.modal-btn{min-height:48px;padding:14px}.locate-btn,.popup-btn{min-height:44px;padding:var(--space-md) var(--space-lg)}.header{padding:var(--space-md)}.header h1{font-size:1.2rem}.header p{font-size:.75rem}#map{height:50vh}.section{margin:var(--space-sm);border-radius:var(--radius-lg)}.section-header{padding:var(--space-sm) var(--space-md);font-size:.85rem}.dashboard{padding:var(--space-md)}.stats-grid{gap:var(--space-sm)}.stat-value{font-size:1.3rem}.auth-page{padding:var(--space-xl) var(--space-md)}.auth-card,.profile-card{padding:var(--space-2xl) var(--space-lg);border-radius:var(--radius-xl)}.auth-title{font-size:1.3rem}.footer{padding:var(--space-lg) var(--space-md)}.map-controls{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding:var(--space-sm)}.map-controls::-webkit-scrollbar{display:none}.hydrant-item{min-height:48px;padding:var(--space-md)}}@media (max-width: 375px){.header h1{font-size:1rem}.stats-grid{grid-template-columns:1fr 1fr 1fr;gap:var(--space-xs)}.stat-card{padding:var(--space-md) var(--space-xs)}.stat-value{font-size:1.1rem}.stat-label{font-size:.6rem}.donut-chart{width:60px;height:60px}.auth-card,.profile-card{padding:var(--space-xl) var(--space-md)}}.toast-container{position:fixed;top:80px;right:16px;z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none}.toast{background:var(--color-surface);color:var(--color-text);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:.85rem;font-family:var(--font-family);display:flex;align-items:center;gap:var(--space-sm);pointer-events:auto;animation:toast-in .3s ease forwards;max-width:340px;border-left:4px solid var(--color-primary)}.toast.toast-success{border-left-color:var(--color-clear-btn)}.toast.toast-error{border-left-color:var(--color-not-clear-btn)}.toast.toast-out{animation:toast-out .3s ease forwards}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}.skeleton{background:linear-gradient(90deg,var(--color-section-bg) 25%,var(--color-border) 50%,var(--color-section-bg) 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-line{height:14px;margin-bottom:var(--space-sm)}.skeleton-line:last-child{width:60%}.skeleton-circle{width:40px;height:40px;border-radius:50%;flex-shrink:0}.skeleton-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md)}.skeleton-row .skeleton-lines{flex:1}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}#page-content{animation:page-fade-in .25s ease}@keyframes page-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.theme-toggle{background:none;border:2px solid rgba(255,255,255,.3);border-radius:var(--radius-lg);color:#fff;cursor:pointer;padding:6px 8px;font-size:1.1rem;line-height:1;transition:border-color .2s,background .2s;display:flex;align-items:center}.theme-toggle:hover{border-color:#fff9;background:#ffffff1a}
