@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_Fallback_f367f3;src:local("Arial");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0.00%;size-adjust:107.06%}.__className_f367f3{font-family:__Inter_f367f3,__Inter_Fallback_f367f3;font-style:normal}.__variable_f367f3{--font-inter:"__Inter_f367f3","__Inter_Fallback_f367f3"}:root{--primary:#0f4c81;--primary-hover:#0d3d6a;--primary-light:#1a6bb5;--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--accent:#f97316;--accent-hover:#ea6c0d;--accent-light:#fed7aa;--success:#10b981;--success-bg:#d1fae5;--success-text:#065f46;--warning:#f59e0b;--warning-bg:#fef3c7;--warning-text:#92400e;--danger:#ef4444;--danger-bg:#fee2e2;--danger-text:#991b1b;--info:#3b82f6;--info-bg:#dbeafe;--info-text:#1e40af;--purple:#8b5cf6;--purple-bg:#ede9fe;--purple-text:#5b21b6;--gray-25:#fcfcfd;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--header-height:60px;--panel-width:400px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-xs:0 1px 2px 0 rgba(0,0,0,.05);--shadow-sm:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--shadow-2xl:0 25px 50px -12px rgba(0,0,0,.25);--shadow-panel:0 0 0 1px rgba(0,0,0,.05),0 20px 50px -12px rgba(0,0,0,.2);--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease;--transition-panel:350ms cubic-bezier(0.32,0.72,0,1)}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif);-moz-osx-font-smoothing:grayscale;overflow:hidden}button{font-family:inherit;cursor:pointer}img{max-width:100%}.app-shell{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden}.map-area{position:relative;flex:1 1;overflow:hidden}.app-header{position:relative;z-index:900;gap:12px;padding:0 20px;height:var(--header-height);background:var(--primary);box-shadow:0 1px 0 rgba(0,0,0,.15),var(--shadow-md)}.app-header,.header-logo{display:flex;align-items:center;flex-shrink:0}.header-logo{gap:10px;text-decoration:none;color:#fff}.header-logo-icon{width:34px;height:34px;background:hsla(0,0%,100%,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}.header-logo-text{display:flex;flex-direction:column;line-height:1.2}.header-logo-text strong{font-size:15px;font-weight:700;letter-spacing:-.3px}.header-logo-text span{font-size:10px;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.header-spacer{flex:1 1}.header-stats{display:flex;align-items:center;gap:4px;padding:5px 12px;background:hsla(0,0%,100%,.1);border-radius:var(--radius-full);font-size:12px;color:hsla(0,0%,100%,.85)}.header-stats-dot{width:6px;height:6px;border-radius:50%;background:#10b981;flex-shrink:0}.header-nav{gap:8px}.header-btn,.header-nav{display:flex;align-items:center}.header-btn{gap:6px;padding:6px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;border:none;cursor:pointer;transition:all var(--transition-fast);color:hsla(0,0%,100%,.85);background:transparent;text-decoration:none;white-space:nowrap}.header-btn:hover{background:hsla(0,0%,100%,.12);color:#fff}.header-btn-primary{background:hsla(0,0%,100%,.15);color:#fff;border:1px solid hsla(0,0%,100%,.2)}.header-btn-primary:hover{background:hsla(0,0%,100%,.25)}.header-btn-accent{background:var(--accent);color:#fff;border:none}.header-btn-accent:hover{background:var(--accent-hover)}.header-user{gap:8px;padding:4px 10px;border-radius:var(--radius-full);background:hsla(0,0%,100%,.1);font-size:13px}.header-avatar,.header-user{display:flex;align-items:center;color:#fff}.header-avatar{width:26px;height:26px;border-radius:50%;background:hsla(0,0%,100%,.25);justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.filter-bar{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:800;gap:8px;pointer-events:none}.filter-bar,.filter-bar-inner{display:flex;align-items:center}.filter-bar-inner{gap:6px;padding:6px 8px;background:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-lg);pointer-events:all;max-width:calc(100vw - 120px);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.filter-bar-inner::-webkit-scrollbar{display:none}.filter-chip{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-full);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all var(--transition-fast);white-space:nowrap;background:transparent;color:var(--gray-600)}.filter-chip:hover{background:var(--gray-100);color:var(--gray-900)}.filter-chip.active{background:var(--primary);color:#fff}.filter-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.filter-divider{width:1px;height:20px;background:var(--gray-200);flex-shrink:0}.status-filters{position:absolute;top:60px;left:50%;transform:translateX(-50%);z-index:800;display:flex;gap:6px;pointer-events:none}.status-tab{display:flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:500;cursor:pointer;border:none;transition:all var(--transition-fast);white-space:nowrap;box-shadow:var(--shadow-sm);background:hsla(0,0%,100%,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--gray-700);pointer-events:all}.status-tab:hover{opacity:.85}.status-tab.active{color:#fff}.fab{position:absolute;bottom:28px;right:20px;z-index:800;gap:10px;padding:14px 20px;border-radius:var(--radius-full);background:var(--accent);font-size:15px;font-weight:700;box-shadow:0 4px 14px rgba(249,115,22,.5),var(--shadow-lg);transition:all var(--transition-base);letter-spacing:.2px}.fab:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(249,115,22,.6),var(--shadow-xl)}.fab:active{transform:translateY(0)}.fab-icon{width:24px;height:24px;border-radius:50%;background:hsla(0,0%,100%,.25);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;line-height:1}.map-crosshair{z-index:750}.map-crosshair svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.detail-panel{position:absolute;top:0;right:0;bottom:0;width:var(--panel-width);background:#fff;box-shadow:var(--shadow-panel);z-index:800;display:flex;flex-direction:column;transform:translateX(100%);transition:transform var(--transition-panel);overflow:hidden;border-left:1px solid var(--gray-200)}.detail-panel.open{transform:translateX(0)}.detail-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--gray-100);flex-shrink:0;gap:12px}.detail-panel-header-left{flex:1 1;min-width:0}.detail-panel-close{width:32px;height:32px;border-radius:50%;background:var(--gray-100);border:none;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;color:var(--gray-500);flex-shrink:0;transition:all var(--transition-fast)}.detail-panel-close:hover{background:var(--gray-200);color:var(--gray-900)}.detail-panel-body{flex:1 1;overflow-y:auto;padding:0}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.category-tag{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;background:var(--gray-100);border-radius:var(--radius-full);font-size:12px;color:var(--gray-600);font-weight:500}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-gap:8px;gap:8px;padding:16px 20px}.gallery-item{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;background:var(--gray-100)}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.gallery-item:hover img{transform:scale(1.05)}.gallery-item-overlay{position:absolute;inset:0;background:transparent;transition:background var(--transition-fast);display:flex;align-items:center;justify-content:center}.gallery-item:hover .gallery-item-overlay{background:rgba(0,0,0,.2)}.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-md)}.lightbox-close{position:absolute;top:20px;right:20px;background:hsla(0,0%,100%,.1);border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.lightbox-close:hover{background:hsla(0,0%,100%,.2)}.timeline{padding:16px 20px}.timeline-title{font-size:13px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.timeline-item{display:flex;gap:12px;position:relative;padding-bottom:20px}.timeline-item:last-child{padding-bottom:0}.timeline-item:not(:last-child):before{content:"";position:absolute;left:7px;top:20px;bottom:0;width:2px;background:var(--gray-200)}.timeline-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;margin-top:2px;border:2px solid #fff;box-shadow:0 0 0 2px currentColor}.timeline-content{flex:1 1;min-width:0}.timeline-status{font-size:13px;font-weight:600;color:var(--gray-800);margin-bottom:2px}.timeline-meta{font-size:12px;color:var(--gray-500)}.timeline-comment{margin-top:6px;padding:8px 10px;background:var(--gray-50);border-radius:var(--radius-sm);font-size:12px;color:var(--gray-600);border-left:3px solid var(--gray-300)}.detail-section{padding:16px 20px;border-bottom:1px solid var(--gray-100)}.detail-section:last-child{border-bottom:none}.detail-meta{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--gray-500);margin-top:6px}.detail-description{font-size:15px;line-height:1.6;color:var(--gray-800);margin-bottom:8px}.detail-address{display:flex;align-items:flex-start;gap:6px;font-size:13px;color:var(--gray-600);padding:8px 12px;background:var(--gray-50);border-radius:var(--radius-sm);margin-top:8px}.detail-coords{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.detail-coord-tag{font-size:11px;color:var(--gray-400);background:var(--gray-100);padding:2px 8px;border-radius:var(--radius-full);font-family:monospace}.modal-overlay{background:rgba(15,23,42,.6);align-items:center;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.modal-sheet{background:#fff;width:100%;max-width:560px;max-height:calc(100vh - 32px);border-radius:16px;display:flex;flex-direction:column;animation:dialogIn .2s cubic-bezier(.34,1.56,.64,1);overflow:hidden;box-shadow:0 25px 60px rgba(0,0,0,.25)}@keyframes dialogIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (max-width:640px){.modal-overlay{align-items:flex-end;padding:0}.modal-sheet{max-height:92dvh;border-radius:20px 20px 0 0;animation:slideUpSheet .3s cubic-bezier(.32,.72,0,1)}}.modal-handle{width:36px;height:4px;background:var(--gray-300);border-radius:2px;margin:12px auto 0;flex-shrink:0;display:none}@media (max-width:640px){.modal-handle{display:block}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0;flex-shrink:0}.modal-title{font-size:17px;font-weight:700;color:var(--gray-900)}.modal-close{width:30px;height:30px;border-radius:50%;background:var(--gray-100);border:none;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;color:var(--gray-500);transition:all var(--transition-fast)}.modal-close:hover{background:var(--gray-200);color:var(--gray-900)}.modal-body{flex:1 1;overflow-y:auto;padding:20px;min-height:0}.modal-footer{padding:12px 20px 16px;display:flex;gap:10px;border-top:1px solid var(--gray-100);flex-shrink:0;background:#fff}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;margin-top:8px}@media (max-width:400px){.category-grid{grid-template-columns:repeat(2,1fr)}}.category-card{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius-md);border:2px solid var(--gray-200);cursor:pointer;transition:all var(--transition-fast);background:#fff;font-size:13px;font-weight:500;color:var(--gray-700)}.category-card:hover{border-color:var(--primary-200);background:var(--primary-50)}.category-card.selected{border-color:var(--primary);background:var(--primary-50);color:var(--primary)}.category-card-icon{font-size:18px;flex-shrink:0}.category-card-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-left:auto}.photo-upload-area{display:flex;flex-direction:column;gap:8px}.photo-upload-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;border:2px dashed var(--gray-300);border-radius:var(--radius-md);cursor:pointer;color:var(--gray-500);font-size:13px;font-weight:500;background:var(--gray-50);transition:all var(--transition-fast)}.photo-upload-btn:hover{border-color:var(--primary);background:var(--primary-50);color:var(--primary)}.photo-upload-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));grid-gap:8px;gap:8px}.photo-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--gray-100)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-thumb-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;background:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.form-label{display:block;font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:6px}.form-label span{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);font-size:14px;font-family:inherit;color:var(--gray-900);background:#fff;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,76,129,.1)}.form-input::placeholder,.form-textarea::placeholder{color:var(--gray-400)}.form-textarea{min-height:96px;resize:vertical;line-height:1.5}.form-hint{font-size:12px;color:var(--gray-400);margin-top:4px}.btn{border-radius:var(--radius-md);font-family:inherit;transition:all var(--transition-base);white-space:nowrap;line-height:1.4}.btn:disabled{transform:none!important}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(15,76,129,.3)}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(249,115,22,.4)}.btn-ghost{background:transparent;color:var(--gray-600);border:1.5px solid var(--gray-200)}.btn-ghost:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-900)}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-sm{padding:6px 14px;font-size:12px}.btn-lg{padding:13px 28px;font-size:15px}.btn-full{width:100%}.alert{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:var(--radius-md);font-size:13px;line-height:1.5;margin-bottom:16px}.alert-error{background:var(--danger-bg);color:var(--danger-text);border:1px solid #fca5a5}.alert-success{background:var(--success-bg);color:var(--success-text);border:1px solid #6ee7b7}.alert-info{background:var(--info-bg);color:var(--info-text);border:1px solid #93c5fd}.auth-shell{min-height:100vh}.auth-shell,.auth-visual{display:flex;overflow:hidden}.auth-visual{flex:1 1;background:linear-gradient(135deg,var(--primary) 0,#1a5795 40%,#0d3a6e 100%);flex-direction:column;align-items:center;justify-content:center;padding:48px;position:relative}.auth-visual:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.auth-visual-content{position:relative;z-index:1;text-align:center;color:#fff;max-width:400px}.auth-visual-logo{font-size:52px;margin-bottom:16px}.auth-visual h2{font-size:28px;font-weight:800;margin-bottom:12px;letter-spacing:-.5px}.auth-visual p{font-size:15px;opacity:.8;line-height:1.6;margin-bottom:32px}.auth-stats{display:flex;gap:24px;justify-content:center}.auth-stat{text-align:center}.auth-stat-number{font-size:24px;font-weight:800}.auth-stat-label{font-size:11px;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.auth-form-area{width:420px;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff;overflow-y:auto;flex-shrink:0}.auth-form-inner{width:100%;max-width:340px}.auth-logo{gap:10px;margin-bottom:32px;text-decoration:none;color:var(--primary)}.auth-logo,.auth-logo-icon{display:flex;align-items:center}.auth-logo-icon{width:40px;height:40px;background:var(--primary);border-radius:10px;justify-content:center;font-size:20px}.auth-logo-text strong{display:block;font-size:18px;font-weight:800}.auth-logo-text span{display:block;font-size:11px;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px}.auth-heading{font-size:22px;font-weight:800;color:var(--gray-900);margin-bottom:4px}.auth-subheading{font-size:14px;color:var(--gray-500);margin-bottom:28px}.citizen-page{min-height:100vh;background:var(--gray-50)}.citizen-header{background:var(--primary);color:#fff;padding:0 24px;height:var(--header-height);display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-md)}.citizen-body{max-width:900px;margin:0 auto;padding:28px 20px}.citizen-hero{background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);border-radius:var(--radius-xl);padding:28px 32px;color:#fff;display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;overflow:hidden;position:relative}.citizen-hero:after{content:"📍";position:absolute;right:24px;bottom:-10px;font-size:80px;opacity:.1}.citizen-hero h2{font-size:22px;font-weight:800;margin-bottom:4px}.citizen-hero p{font-size:14px;opacity:.8}.citizen-issue-list{display:flex;flex-direction:column;gap:12px}.citizen-issue-card{background:#fff;border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-xs);border:1px solid var(--gray-200);display:flex;align-items:flex-start;gap:14px;text-decoration:none;color:inherit;transition:all var(--transition-base);cursor:pointer}.citizen-issue-card:hover{box-shadow:var(--shadow-md);border-color:var(--gray-300);transform:translateY(-1px)}.citizen-issue-category-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}.citizen-issue-content{flex:1 1;min-width:0}.citizen-issue-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:4px}.citizen-issue-title{font-size:14px;font-weight:600;color:var(--gray-900)}.citizen-issue-desc,.citizen-issue-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.citizen-issue-desc{font-size:13px;color:var(--gray-500);margin-bottom:8px}.citizen-issue-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.citizen-empty{text-align:center;padding:64px 24px;color:var(--gray-400)}.citizen-empty-icon{font-size:48px;margin-bottom:16px;display:block}.citizen-empty h3{font-size:18px;color:var(--gray-700);margin-bottom:8px}.admin-sidebar{display:flex;flex-direction:column}.admin-sidebar-logo{padding:0 20px 24px;display:flex;align-items:center;gap:10px;border-bottom:1px solid hsla(0,0%,100%,.08);margin-bottom:8px}.admin-sidebar-logo span{font-size:15px;font-weight:700;color:#fff}.admin-sidebar a{display:flex;align-items:center;gap:10px;padding:11px 20px;color:hsla(0,0%,100%,.55);transition:all var(--transition-fast)}.admin-sidebar a.active,.admin-sidebar a:hover{background:hsla(0,0%,100%,.08)}.admin-main{padding:28px;background:var(--gray-50)}.admin-page-title{font-size:22px;font-weight:800;color:var(--gray-900);margin-bottom:24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:14px;gap:14px;margin-bottom:28px}.stat-card{border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);border:1px solid var(--gray-200);display:flex;flex-direction:column;gap:6px}.stat-card-number{font-size:32px;font-weight:800;color:var(--gray-900);line-height:1.2}.stat-card-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);font-weight:600}.stat-card-change{font-size:12px;color:var(--success);font-weight:500}.table-wrapper{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);overflow:hidden;box-shadow:var(--shadow-xs)}.data-table th{padding:12px 14px;font-size:11px;letter-spacing:.5px;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.data-table td{padding:12px 14px;border-bottom:1px solid var(--gray-100);font-size:13px;color:var(--gray-700)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--gray-50)}.leaflet-control-attribution{font-size:10px!important;opacity:.7}.leaflet-container{font-family:var(--font-inter,-apple-system,sans-serif)!important}.map-marker-pin{position:relative;display:flex;align-items:center;justify-content:center}.marker-cluster-small{background-color:rgba(15,76,129,.15)!important}.marker-cluster-small div{background-color:rgba(15,76,129,.75)!important;color:#fff!important;font-weight:700}.marker-cluster-medium{background-color:rgba(249,115,22,.15)!important}.marker-cluster-medium div{background-color:rgba(249,115,22,.75)!important;color:#fff!important;font-weight:700}.marker-cluster-large{background-color:rgba(239,68,68,.15)!important}.marker-cluster-large div{background-color:rgba(239,68,68,.75)!important;color:#fff!important;font-weight:700}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}@media (max-width:768px){body{overflow:auto}.app-shell{position:relative;height:auto}.map-area{height:100vh}.auth-visual{display:none}.auth-form-area{width:100%;padding:32px 20px}.admin-sidebar{display:none}.admin-main{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.detail-panel{top:auto;right:0;bottom:0;left:0;width:100%;max-height:75vh;border-left:none;border-top:1px solid var(--gray-200);border-radius:20px 20px 0 0;transform:translateY(100%)}.detail-panel.open{transform:translateY(0)}.fab{bottom:20px;right:16px;padding:12px 16px;font-size:13px}.header-btn span+span,.header-logo-text span,.header-stats{display:none}.filter-bar{top:8px;max-width:calc(100vw - 100px)}.status-filters{top:50px;overflow-x:auto;scrollbar-width:none;width:100%;left:0;transform:none;padding:0 12px}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:400px 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes pulse-ring{0%{transform:scale(1);opacity:.8}70%{transform:scale(2);opacity:0}to{transform:scale(2);opacity:0}}.marker-selected:before{content:"";position:absolute;inset:0;border-radius:50%;background:currentColor;animation:pulse-ring 1.5s ease-out infinite}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--gray-900);background:var(--gray-50);-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:14px;font-weight:600;color:var(--gray-700);margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--gray-300);border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,64,175,.1)}.form-group textarea{min-height:100px;resize:vertical}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:20px}.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.badge-open{background:#fef3c7;color:#92400e}.badge-analyzing{background:#dbeafe;color:#1e40af}.badge-in_progress{background:#e0e7ff;color:#4338ca}.badge-resolved{background:#d1fae5;color:#065f46}.badge-rejected{background:#fee2e2;color:#991b1b}.navbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--primary);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar h1{font-size:20px;font-weight:700}.navbar-links{display:flex;gap:16px;align-items:center}.navbar-links a,.navbar-links button{color:#fff;background:none;border:none;font-size:14px;cursor:pointer;opacity:.9}.navbar-links a:hover,.navbar-links button:hover{opacity:1}.map-container{width:100%;height:calc(100vh - 56px);position:relative}.map-crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:999;pointer-events:none;font-size:32px;color:var(--danger);text-shadow:0 0 4px #fff}.fab{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:var(--danger);color:#fff;border:none;font-size:28px;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:1000;display:flex;align-items:center;justify-content:center;transition:transform .2s}.fab:hover{transform:scale(1.1)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;display:flex;align-items:flex-end;justify-content:center}.modal-content{background:#fff;width:100%;max-width:500px;max-height:85vh;border-radius:16px 16px 0 0;padding:24px;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-content h2{margin-bottom:16px;font-size:18px}.issue-detail-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;max-height:50vh;border-radius:16px 16px 0 0;box-shadow:0 -4px 12px rgba(0,0,0,.15);z-index:1500;padding:20px;overflow-y:auto;animation:slideUp .3s ease}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 4px 24px rgba(0,0,0,.1)}.auth-card h1{text-align:center;color:var(--primary);margin-bottom:8px}.auth-card p{text-align:center;color:var(--gray-500);margin-bottom:24px;font-size:14px}.error-msg{background:#fee2e2;color:#991b1b;padding:10px;border-radius:8px;font-size:13px;margin-bottom:16px}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:240px;background:var(--gray-900);color:#fff;padding:20px 0;flex-shrink:0}.admin-sidebar h2{padding:0 20px;font-size:18px;margin-bottom:24px;color:var(--primary-light)}.admin-sidebar a{display:block;padding:12px 20px;color:var(--gray-300);font-size:14px;transition:background .2s}.admin-sidebar a.active,.admin-sidebar a:hover{background:hsla(0,0%,100%,.1);color:#fff}.admin-main{flex:1 1;padding:24px;overflow-x:auto}.admin-main h1{font-size:24px;margin-bottom:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:16px;gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.1);text-align:center}.stat-card .number{font-size:36px;font-weight:700;color:var(--primary)}.stat-card .label{font-size:13px;color:var(--gray-500);margin-top:4px}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1)}.data-table th{background:var(--gray-100);padding:12px 16px;text-align:left;font-size:12px;text-transform:uppercase;color:var(--gray-500);font-weight:600}.data-table td{padding:12px 16px;border-top:1px solid var(--gray-200);font-size:14px}.data-table tr:hover{background:var(--gray-50)}.photo-upload-preview{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.photo-upload-preview img{width:80px;height:80px;object-fit:cover;border-radius:8px;border:2px solid var(--gray-200)}@media (max-width:768px){.admin-sidebar{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}}