.reports-map-container{position:relative;width:100%;height:100%;border-radius:12px;overflow:hidden;background:#f5f5f5}.map-controls{position:absolute;top:16px;left:16px;z-index:10;background:#fff;border-radius:8px;padding:12px;box-shadow:0 2px 8px #00000026}.control-group{display:flex;gap:8px;align-items:center}.control-btn{width:40px;height:40px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.control-btn:hover{background:#f3f4f6;box-shadow:0 2px 4px #0000001a}.filter-select{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;font-size:13px;cursor:pointer;transition:all .2s ease;font-family:inherit}.filter-select:hover{border-color:#d1d5db}.filter-select:focus{outline:none;border-color:#1e88e5;box-shadow:0 0 0 3px #1e88e51a}.stats-box{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.stat-item{display:flex;flex-direction:column;align-items:center;padding:8px;background:#f9fafb;border-radius:6px;font-size:12px}.stat-label{color:#6b7280;font-weight:500;margin-bottom:4px}.stat-value{font-size:16px;font-weight:700;color:#1f2937}.stat-item.alta .stat-value{color:#ef4444}.stat-item.media .stat-value{color:#f59e0b}.stat-item.baja .stat-value{color:#10b981}.map-info-window{padding:12px;font-family:inherit;min-width:250px}.info-header{display:flex;gap:8px;margin-bottom:8px;align-items:center}.info-category,.info-priority{font-size:10px;font-weight:600;padding:4px 8px;border-radius:4px;color:#fff;text-transform:uppercase;letter-spacing:.5px}.info-category.category-vias{background:#ef4444}.info-category.category-servicios{background:#f59e0b}.info-category.category-seguridad{background:#ec4899}.info-category.category-ambiente{background:#10b981}.info-category.category-salud{background:#06b6d4}.info-category.category-otros{background:#6b7280}.info-priority.priority-alta{background:#ef4444;margin-left:auto}.info-priority.priority-media{background:#f59e0b;margin-left:auto}.info-priority.priority-baja{background:#10b981;margin-left:auto}.map-info-window h3{margin:0 0 8px;font-size:14px;font-weight:600;color:#1f2937;line-height:1.4}.info-location{margin:4px 0;font-size:12px;color:#6b7280}.info-description{margin:8px 0;font-size:12px;color:#4b5563;line-height:1.4}.info-stats{display:flex;gap:12px;margin:8px 0;font-size:12px;color:#6b7280}.info-button{width:100%;padding:8px 12px;margin-top:8px;background:linear-gradient(135deg,#1e88e5,#1565c0);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.info-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1e88e54d}.info-button:active{transform:translateY(0)}.map-legend{position:absolute;bottom:16px;right:16px;background:#fff;border-radius:8px;padding:12px;box-shadow:0 2px 8px #00000026;z-index:10;max-width:200px}.map-legend h4{margin:0 0 8px;font-size:12px;font-weight:600;color:#1f2937;text-transform:uppercase;letter-spacing:.5px}.legend-items{display:flex;flex-direction:column;gap:6px}.legend-item{display:flex;gap:8px;align-items:center;font-size:12px;color:#4b5563}.legend-color{width:12px;height:12px;border-radius:50%;border:1px solid rgba(0,0,0,.1)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:#6b7280}.error-state{display:flex;align-items:center;justify-content:center;height:100%;padding:20px;color:#dc2626;text-align:center;font-size:14px}@media (max-width: 768px){.map-controls{top:8px;left:8px}.stats-box{grid-template-columns:repeat(4,1fr);gap:4px}.stat-item{padding:4px;font-size:10px}.stat-value{font-size:14px}.map-legend{bottom:8px;right:8px;padding:8px}.control-group{flex-direction:column}.filter-select{width:100%}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{position:relative;padding:16px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.header-tags{display:flex;gap:8px;flex-wrap:wrap;flex:1}.modal-category,.modal-priority,.modal-status{font-size:11px;font-weight:600;padding:6px 10px;border-radius:6px;color:#fff;text-transform:uppercase;letter-spacing:.5px}.modal-category.category-vias{background:#ef4444}.modal-category.category-servicios{background:#f59e0b}.modal-category.category-seguridad{background:#ec4899}.modal-category.category-ambiente{background:#10b981}.modal-category.category-salud{background:#06b6d4}.modal-category.category-otros{background:#6b7280}.modal-priority.priority-alta{background:#ef4444}.modal-priority.priority-media{background:#f59e0b}.modal-priority.priority-baja{background:#10b981}.modal-status.status-pendiente{background:#ef4444}.modal-status.status-en_proceso{background:#f59e0b}.modal-status.status-resuelto{background:#10b981}.modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-close:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:24px}.modal-image{margin-bottom:20px;border-radius:8px;overflow:hidden;max-height:300px}.modal-image img{width:100%;height:100%;object-fit:cover}.modal-title{margin:0 0 8px;font-size:20px;font-weight:700;color:#1f2937;line-height:1.4}.modal-location{margin:0 0 12px;font-size:14px;color:#6b7280}.modal-description{margin:0 0 20px;font-size:14px;color:#4b5563;line-height:1.6}.modal-info{background:#f9fafb;border-radius:8px;padding:16px;margin-bottom:20px}.info-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px}.info-item:last-child{margin-bottom:0}.info-label{color:#6b7280;font-weight:500}.info-value{color:#1f2937;font-weight:600}.edit-form{display:flex;flex-direction:column;gap:12px}.edit-input,.edit-textarea,.edit-select{padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-family:inherit;transition:all .2s ease}.edit-input:focus,.edit-textarea:focus,.edit-select:focus{outline:none;border-color:#1e88e5;box-shadow:0 0 0 3px #1e88e51a}.edit-textarea{min-height:100px;resize:vertical}.edit-actions{display:flex;gap:8px}.btn-primary,.btn-danger,.btn-cancel,.btn-save,.btn-comment{padding:10px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background:linear-gradient(135deg,#1e88e5,#1565c0);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1e88e54d}.btn-danger{background:#fee2e2;color:#dc2626}.btn-danger:hover{background:#fee2e2;color:#991b1b}.btn-cancel{background:#f3f4f6;color:#6b7280}.btn-cancel:hover{background:#e5e7eb}.btn-save{background:linear-gradient(135deg,#1e88e5,#1565c0);color:#fff;flex:1}.btn-save:hover{transform:translateY(-2px)}.modal-actions{display:flex;gap:8px}.modal-actions button{flex:1}.modal-comments{border-top:1px solid #e5e7eb;padding:16px 24px 24px}.modal-comments h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#1f2937}.comment-input-group{display:flex;gap:8px}.comment-input{flex:1;padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-family:inherit;transition:all .2s ease}.comment-input:focus{outline:none;border-color:#1e88e5;box-shadow:0 0 0 3px #1e88e51a}.btn-comment{background:linear-gradient(135deg,#1e88e5,#1565c0);color:#fff}.btn-comment:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #1e88e54d}.btn-comment:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.modal-overlay{padding:0}.modal-content{border-radius:12px 12px 0 0;max-height:100vh}.modal-body{padding:16px}.modal-title{font-size:18px}.header-tags{flex-wrap:wrap}.modal-actions,.comment-input-group{flex-direction:column}.btn-comment{width:100%}}.reports-map-view{position:relative;width:100%;height:100vh;display:flex;flex-direction:column;background:#f5f5f5;overflow:hidden}.reports-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px;box-shadow:0 2px 4px #0000000d;z-index:5}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.reports-header h1{margin:0;font-size:24px;font-weight:700;color:#1f2937}.btn-create{padding:10px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-create:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.header-search{display:flex;gap:12px;align-items:center}.search-input{flex:1;max-width:400px;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-family:inherit;transition:all .2s ease}.search-input:focus{outline:none;border-color:#1e88e5;box-shadow:0 0 0 3px #1e88e51a}.report-stats{display:flex;gap:8px}.stat-badge{padding:6px 12px;background:#f3f4f6;color:#6b7280;border-radius:6px;font-size:12px;font-weight:600}.reports-map-container{flex:1;position:relative;overflow:hidden;min-height:400px;width:100%}.reports-sidebar{position:fixed;bottom:0;left:0;right:0;max-width:100%;background:#fff;border-top:1px solid #e5e7eb;padding:16px;max-height:30vh;overflow-y:auto;z-index:8;box-shadow:0 -2px 8px #0000001a}.reports-sidebar h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#1f2937}.reports-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;overflow-y:auto;max-height:calc(30vh - 40px)}.report-item{padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.report-item:hover{background:#fff;border-color:#d1d5db;box-shadow:0 4px 12px #0000001a}.report-item.active{background:#fff;border-color:#1e88e5;box-shadow:0 0 0 2px #1e88e533}.report-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:8px}.report-item-header h4{margin:0;font-size:13px;font-weight:600;color:#1f2937;line-height:1.4;flex:1}.priority-badge{font-size:10px;font-weight:700;padding:4px 8px;border-radius:4px;color:#fff;text-transform:uppercase;white-space:nowrap}.priority-badge.priority-alta{background:#ef4444}.priority-badge.priority-media{background:#f59e0b}.priority-badge.priority-baja{background:#10b981}.report-item-location{margin:0 0 8px;font-size:12px;color:#6b7280}.report-item-meta{display:flex;gap:8px;align-items:center;font-size:11px}.category-badge{padding:3px 8px;border-radius:4px;font-weight:600;text-transform:uppercase;color:#fff}.category-badge.category-vias{background:#ef4444}.category-badge.category-servicios{background:#f59e0b}.category-badge.category-seguridad{background:#ec4899}.category-badge.category-ambiente{background:#10b981}.category-badge.category-salud{background:#06b6d4}.category-badge.category-otros{background:#6b7280}.vote-count{color:#6b7280;margin-left:auto}.empty-state{padding:20px;text-align:center;color:#9ca3af;font-size:13px}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px}.loading-state p,.error-state p{color:#6b7280;font-size:14px;margin:0}.error-state p{color:#dc2626}.spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#1e88e5;border-radius:50%;animation:spin .8s linear infinite}.btn-retry{padding:10px 16px;background:linear-gradient(135deg,#1e88e5,#1565c0);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-retry:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1e88e54d}@media (max-width: 1024px){.header-top{flex-direction:column;align-items:flex-start;gap:12px}.header-search{width:100%;flex-direction:column}.search-input{max-width:100%}.reports-sidebar{max-height:25vh}.reports-list{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (max-width: 768px){.reports-map-view{height:calc(100vh - 60px)}.reports-header{padding:12px}.reports-header h1{font-size:18px}.header-top{flex-direction:column;align-items:flex-start}.btn-create{width:100%}.header-search{width:100%;flex-direction:column;gap:8px}.search-input{max-width:100%;width:100%}.reports-sidebar{max-height:35vh;padding:12px}.reports-list{grid-template-columns:1fr}}:root{--color-primary: #2563EB;--color-primary-light: #3B82F6;--color-primary-dark: #1E40AF;--color-bg-main: #F5F3EE;--color-bg-card: #FFFFFF;--color-bg-overlay: rgba(0, 0, 0, .4);--color-text-primary: #1F2937;--color-text-secondary: #6B7280;--color-text-light: #FFFFFF;--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #3B82F6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-main);color:var(--color-text-primary);overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none}.app-container{max-width:428px;min-height:100vh;margin:0 auto;background-color:var(--color-bg-main);position:relative;box-shadow:var(--shadow-xl)}.home-screen{width:100%;height:100vh;position:relative;overflow:hidden}.home-background{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat}.home-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,#2f52334d,#1e3a21b3)}.home-content{position:relative;z-index:10;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-xl);text-align:center}.home-logo{margin-bottom:0;margin-top:var(--spacing-lg);animation:fadeInDown 1.2s ease-out;display:flex;justify-content:center;align-items:center}.home-logo img{width:380px;max-width:90vw;height:auto;filter:drop-shadow(0 8px 24px rgba(0,0,0,.6))}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.home-title{font-size:48px;font-weight:700;color:var(--color-text-light);margin-bottom:var(--spacing-md);text-shadow:2px 2px 8px rgba(0,0,0,.3);line-height:1.2}.home-subtitle{font-size:17px;color:var(--color-text-light);margin-top:0;margin-bottom:var(--spacing-xl);text-shadow:1px 1px 6px rgba(0,0,0,.4);max-width:360px;font-weight:300;line-height:1.6;letter-spacing:.3px;position:relative;transform:translateY(-70px)}.home-navigation{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);margin-top:auto;padding-bottom:80px}.go-button{padding:14px 36px;border-radius:var(--radius-full);background-color:var(--color-text-light);color:var(--color-primary-dark);font-size:16px;font-weight:600;box-shadow:0 6px 20px #0000004d;transition:all .3s ease;letter-spacing:.5px}.go-button:hover{transform:translateY(-3px);box-shadow:0 10px 28px #0006;background-color:#fff}.go-button:active{transform:translateY(-1px);box-shadow:0 5px 14px #0000004d}.discover-screen{min-height:100vh;padding:var(--spacing-lg) var(--spacing-md);padding-bottom:100px}.discover-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.discover-header h2{font-size:32px;font-weight:700;color:var(--color-text-primary)}.header-icons{display:flex;gap:var(--spacing-sm)}.icon-button{width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-bg-card);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:all .2s ease}.icon-button:hover{box-shadow:var(--shadow-md);transform:scale(1.05)}.icon-button svg{stroke-width:2}.icon-button.emergency-btn{width:60px;height:60px;background:linear-gradient(135deg,#1e88e5,#1565c0);box-shadow:none}.icon-button.emergency-btn svg{width:36px;height:36px}.icon-button.emergency-btn:hover{box-shadow:none;transform:scale(1.1)}@keyframes pulse-emergency{0%,to{box-shadow:none}50%{box-shadow:none}}.category-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);overflow-x:auto;padding-bottom:var(--spacing-sm);scrollbar-width:none}.category-tabs::-webkit-scrollbar{display:none}.tab{padding:10px 20px;border-radius:var(--radius-full);background-color:var(--color-bg-card);color:var(--color-text-secondary);font-size:14px;font-weight:500;white-space:nowrap;transition:all .3s ease;box-shadow:var(--shadow-sm)}.tab.active{background-color:var(--color-primary);color:var(--color-text-light);box-shadow:var(--shadow-md)}.tab:hover{transform:translateY(-2px)}.reports-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.report-card{background-color:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);cursor:pointer;transition:all .3s ease}.report-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-image{width:100%;height:180px;background-size:cover;background-position:center;position:relative}.priority-badge,.status-badge{position:absolute;padding:4px 12px;border-radius:var(--radius-full);font-size:11px;font-weight:600;color:var(--color-text-light);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.priority-badge{top:8px;right:8px}.priority-badge.alta{background-color:#ef4444e6}.priority-badge.media{background-color:#f59e0be6}.priority-badge.baja{background-color:#10b981e6}.status-badge{bottom:8px;left:8px;font-size:10px}.status-badge.pendiente{background-color:#ef4444e6}.status-badge.en_proceso{background-color:#f59e0be6}.status-badge.resuelto{background-color:#10b981e6}.card-content{padding:var(--spacing-md)}.card-content h3{font-size:14px;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.location{font-size:12px;color:var(--color-text-secondary);display:flex;align-items:center;gap:4px;margin-bottom:var(--spacing-sm)}.card-footer{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--color-text-secondary)}.votes,.comments{display:flex;align-items:center;gap:4px}.top-section{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.section-header h3{font-size:20px;font-weight:700}.more-button{font-size:24px;color:var(--color-text-secondary);padding:0 var(--spacing-sm)}.top-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.top-item{display:flex;gap:var(--spacing-md);background-color:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s ease}.top-item:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.top-item img{width:60px;height:60px;border-radius:var(--radius-sm);object-fit:cover}.top-info h4{font-size:16px;font-weight:600;margin-bottom:4px}.top-info p{font-size:13px;color:var(--color-text-secondary);margin-bottom:4px}.report-count{font-size:12px;color:var(--color-primary);font-weight:500}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);max-width:428px;width:100%;background-color:var(--color-bg-card);border-top:1px solid #E5E7EB;display:flex;justify-content:space-around;padding:var(--spacing-md) var(--spacing-lg);box-shadow:0 -4px 6px -1px #0000001a;z-index:100}.nav-item{width:48px;height:48px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all .2s ease}.nav-item.active{background-color:var(--color-primary);color:var(--color-text-light)}.nav-item:not(.active):hover{background-color:var(--color-bg-main)}.loading-state,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;min-height:300px}.spinner{width:40px;height:40px;border:4px solid var(--color-bg-main);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}@keyframes spin{to{transform:rotate(360deg)}}.error-state p{color:var(--color-error);margin-bottom:var(--spacing-md)}.empty-state p{color:var(--color-text-secondary)}.detail-screen{min-height:100vh;background-color:var(--color-bg-main);padding-bottom:var(--spacing-xl)}.detail-header{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;padding:var(--spacing-lg);z-index:50}.back-button,.favorite-button{width:48px;height:48px;border-radius:var(--radius-full);background-color:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:all .2s ease}.back-button:hover,.favorite-button:hover{transform:scale(1.05)}.detail-image-container{position:relative;width:100%;height:450px}.detail-main-image{width:100%;height:100%;background-size:cover;background-position:center;position:relative}.image-overlay{position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(to top,var(--color-bg-main),transparent)}.image-gallery{position:absolute;right:var(--spacing-lg);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:var(--spacing-sm)}.thumbnail{width:60px;height:60px;border-radius:var(--radius-md);background-size:cover;background-position:center;border:3px solid transparent;opacity:.6;transition:all .2s ease}.thumbnail.active{border-color:var(--color-text-light);opacity:1;box-shadow:var(--shadow-lg)}.detail-content{background-color:var(--color-bg-main);border-radius:var(--radius-xl) var(--radius-xl) 0 0;margin-top:-30px;padding:var(--spacing-xl) var(--spacing-lg);position:relative;z-index:10}.detail-title-section h1{font-size:28px;font-weight:700;margin-bottom:var(--spacing-sm)}.detail-location{display:flex;align-items:center;gap:6px;color:var(--color-text-secondary);font-size:14px;margin-bottom:var(--spacing-lg)}.detail-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.metric{text-align:center;padding:var(--spacing-md);background-color:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.metric-label{display:block;font-size:12px;color:var(--color-text-secondary);margin-bottom:4px}.metric-value{display:block;font-size:18px;font-weight:700}.detail-description{margin-bottom:var(--spacing-xl)}.detail-description h3{font-size:20px;font-weight:700;margin-bottom:var(--spacing-md)}.detail-description p{line-height:1.6;color:var(--color-text-secondary)}.detail-info{background-color:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-sm)}.info-row{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-bg-main)}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;color:var(--color-text-secondary)}.info-value{font-size:14px;font-weight:600;color:var(--color-text-primary)}.detail-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.vote-button{width:100%;padding:var(--spacing-lg);border-radius:var(--radius-full);background-color:var(--color-primary);color:var(--color-text-light);font-size:16px;font-weight:600;box-shadow:var(--shadow-md);transition:all .3s ease}.vote-button:hover:not(:disabled){background-color:var(--color-primary-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.vote-button:disabled{opacity:.6;cursor:not-allowed}.vote-button.voted{background-color:var(--color-success)}.action-button{width:100%;padding:var(--spacing-md);border-radius:var(--radius-full);font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all .2s ease}.action-button.secondary{background-color:var(--color-bg-card);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.action-button.secondary:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.home-header{position:absolute;top:0;left:0;right:0;display:flex;justify-content:flex-end;padding:var(--spacing-lg);z-index:20}.login-button-minimal{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background-color:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--color-text-light);border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.login-button-minimal:hover{background-color:#ffffff40;border-color:#fff6;transform:scale(1.05)}.login-button-minimal:active{transform:scale(.95)}.login-button-minimal svg{stroke-width:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.auth-screen{min-height:100vh;background:linear-gradient(135deg,#3b82f6,#1e40af);display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);position:relative}.auth-container{width:100%;max-width:400px;background-color:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:var(--spacing-xl);box-shadow:0 25px 50px -12px #00000040;border:1px solid rgba(255,255,255,.3);position:relative}.auth-header{margin-bottom:var(--spacing-lg)}.back-button-simple{width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-bg-main);display:flex;align-items:center;justify-content:center;transition:all .2s ease}.back-button-simple:hover{background-color:var(--color-primary);color:var(--color-text-light)}.back-button-simple svg{stroke:currentColor}.auth-branding{text-align:center;margin-bottom:var(--spacing-xl)}.auth-logo-container{margin:0 auto var(--spacing-md);display:flex;align-items:center;justify-content:center}.auth-logo-image{width:180px;max-width:80%;height:auto;filter:brightness(0) saturate(100%) invert(21%) sepia(98%) saturate(3059%) hue-rotate(221deg) brightness(94%) contrast(91%);-webkit-filter:brightness(0) saturate(100%) invert(21%) sepia(98%) saturate(3059%) hue-rotate(221deg) brightness(94%) contrast(91%) drop-shadow(0 4px 16px rgba(30,64,175,.4))}.auth-title{font-size:28px;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.auth-subtitle{font-size:14px;color:var(--color-text-secondary)}.auth-form,.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.input-wrapper{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);stroke-width:2;pointer-events:none}.form-input{width:100%;padding:14px 14px 14px 44px;border:2px solid #E5E7EB;border-radius:var(--radius-md);font-size:14px;color:var(--color-text-primary);background-color:var(--color-bg-main);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-bg-card)}.form-input.error{border-color:var(--color-error)}.form-input:disabled{opacity:.6;cursor:not-allowed}.password-wrapper{position:relative}.toggle-password-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);background:none;cursor:pointer;transition:all .2s ease;border-radius:var(--radius-sm)}.toggle-password-btn:hover:not(:disabled){color:var(--color-primary);background-color:#2563eb1a}.toggle-password-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{display:block;margin-top:var(--spacing-xs);font-size:12px;color:var(--color-error);font-weight:500}.form-footer{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-md)}.link-button{font-size:13px;color:var(--color-text-secondary);text-decoration:none;transition:color .2s ease}.link-button:hover{color:var(--color-primary);text-decoration:underline}.link-button.highlight{color:var(--color-primary);font-weight:600}.link-button.small{font-size:12px}.terms-text{font-size:12px;color:var(--color-text-secondary);line-height:1.4}.auth-button{width:100%;padding:14px var(--spacing-lg);border-radius:var(--radius-full);font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all .3s ease;margin-bottom:var(--spacing-sm)}.auth-button.primary{background-color:var(--color-primary);color:var(--color-text-light);box-shadow:var(--shadow-md)}.auth-button.primary:hover:not(:disabled){background-color:var(--color-primary-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.auth-button.secondary{background-color:var(--color-bg-main);color:var(--color-text-primary);border:2px solid #E5E7EB}.auth-button.secondary:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.button-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-text-light);border-radius:var(--radius-full);animation:spin .8s linear infinite}.auth-switch{text-align:center;padding-top:var(--spacing-md);border-top:1px solid #E5E7EB}.auth-switch p{font-size:14px;color:var(--color-text-secondary)}.create-report-screen{min-height:100vh;background:linear-gradient(180deg,#dbeafe,#eff6ff);padding:var(--spacing-lg) var(--spacing-md);padding-bottom:100px}.create-report-container{max-width:600px;margin:0 auto}.create-report-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl)}.create-report-title{font-size:24px;font-weight:700;color:var(--color-primary-dark)}.create-report-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-section{background-color:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 4px 12px #0000000d;border:1px solid rgba(255,255,255,.5)}.form-label-create{display:block;font-size:14px;font-weight:600;color:var(--color-primary-dark);margin-bottom:var(--spacing-sm)}.form-input-create,.form-textarea-create{width:100%;padding:14px 16px;border:2px solid #E0E7FF;border-radius:var(--radius-md);font-size:15px;color:var(--color-text-primary);background-color:#fff;transition:all .3s ease}.form-input-create:focus,.form-textarea-create:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-input-create.error,.form-textarea-create.error{border-color:var(--color-error)}.form-textarea-create{resize:vertical;min-height:100px;font-family:inherit}.category-pills,.priority-pills{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.pill{padding:10px 18px;border-radius:var(--radius-full);border:2px solid #E0E7FF;background-color:#fff;color:var(--color-text-secondary);font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .3s ease;cursor:pointer}.pill:hover:not(:disabled){border-color:var(--color-primary-light);background-color:#f0f9ff}.pill.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-color:var(--color-primary);color:#fff;box-shadow:0 4px 12px #2563eb4d}.pill-icon{font-size:16px}.pill.priority-baja.active{background:linear-gradient(135deg,#10b981,#34d399);border-color:#10b981}.pill.priority-media.active{background:linear-gradient(135deg,#f59e0b,#fbbf24);border-color:#f59e0b}.pill.priority-alta.active{background:linear-gradient(135deg,#ef4444,#f87171);border-color:#ef4444}.image-upload-area{margin-top:var(--spacing-sm)}.image-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);border:2px dashed #C7D2FE;border-radius:var(--radius-lg);background-color:#f8faff;cursor:pointer;transition:all .3s ease}.image-upload-label:hover{border-color:var(--color-primary);background-color:#eff6ff}.image-upload-label svg{color:var(--color-primary-light);margin-bottom:var(--spacing-sm)}.image-upload-label p{font-size:15px;font-weight:600;color:var(--color-primary-dark);margin-bottom:4px}.image-upload-label span{font-size:12px;color:var(--color-text-secondary)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}.btn-cancel,.btn-submit{flex:1;padding:16px;border-radius:var(--radius-full);font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all .3s ease}.btn-cancel{background-color:#fff;color:var(--color-text-secondary);border:2px solid #E5E7EB}.btn-cancel:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.btn-submit{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border:none;box-shadow:0 6px 20px #2563eb4d}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #2563eb66}.btn-submit:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.create-report-section{margin:var(--spacing-xl) 0;display:flex;justify-content:center}.create-report-button{width:100%;max-width:300px;padding:18px var(--spacing-lg);border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);box-shadow:0 8px 24px #2563eb66;transition:all .3s ease}.create-report-button:hover{transform:translateY(-3px);box-shadow:0 12px 32px #2563eb80}.create-report-button:active{transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66}.create-report-button svg{transition:transform .3s ease}.create-report-button:hover svg{transform:rotate(90deg)}.map-view-container{margin:var(--spacing-md) 0}.map-location-label{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--color-text-secondary);font-size:14px;font-weight:500}.map-location-label svg{color:var(--color-primary);stroke-width:2}.detail-map-section{margin:var(--spacing-lg) 0}.map-selector-container{margin:var(--spacing-md) 0}.map-instructions{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;padding:16px;background:linear-gradient(135deg,#dbeafe,#eff6ff);border-radius:var(--radius-md);border-left:4px solid var(--color-primary)}.map-instructions p{margin:0;font-size:14px;color:var(--color-text-primary);font-weight:500}.use-location-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:14px;font-weight:600;transition:all .3s ease;align-self:flex-start}.use-location-button:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.use-location-button svg{stroke-width:2}.selected-location-info{display:flex;align-items:flex-start;gap:10px;margin-top:12px;padding:12px 16px;background:#fffffff2;border:1px solid #E5E7EB;border-radius:var(--radius-md);font-size:14px;color:var(--color-text-primary);line-height:1.5}.selected-location-info svg{color:var(--color-primary);stroke-width:2;flex-shrink:0;margin-top:2px}.location-display{display:flex;align-items:center;gap:12px;padding:16px 20px;background:linear-gradient(135deg,#dbeafe,#eff6ff);border:2px solid var(--color-primary-light);border-radius:var(--radius-md);margin-top:-8px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.location-display svg{color:var(--color-primary);stroke-width:2.5;flex-shrink:0}.location-display span{flex:1;font-size:14px;font-weight:600;color:var(--color-text-primary);line-height:1.5}.location-loading{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f3f4f6;border:2px dashed #D1D5DB;border-radius:var(--radius-md);color:var(--color-text-secondary)}.location-loading span{font-size:14px;font-weight:500}.spinner-small{width:20px;height:20px;border:3px solid #E5E7EB;border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.location-error{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#fee2e2;border:2px solid #FCA5A5;border-radius:var(--radius-md);color:var(--color-error)}.location-error svg{flex-shrink:0;stroke-width:2}.location-error span{font-size:14px;font-weight:500;line-height:1.5}.map-loading,.map-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:var(--radius-md);text-align:center;min-height:300px}.map-loading p,.map-error p{margin-top:12px;color:var(--color-text-secondary);font-size:14px;font-weight:500}.map-error{background:linear-gradient(135deg,#fef2f2,#fee2e2)}.map-error p:first-child{font-size:16px;font-weight:600;color:var(--color-error)}.map-error-detail{font-size:13px!important;color:var(--color-text-secondary)!important;font-weight:400!important}.explore-screen{min-height:100vh;background:linear-gradient(180deg,#eff6ff,#f5f3ee);padding-bottom:80px}.explore-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-md);background:#fff;border-bottom:1px solid #E5E7EB}.explore-header h2{font-size:24px;font-weight:700;color:var(--color-text-primary);margin:0}.filter-button{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-md);color:#fff;transition:all .3s ease}.filter-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #2563eb4d}.filter-button svg{stroke-width:2}.filter-badge{position:absolute;top:-6px;right:-6px;background:var(--color-error);color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.search-section{padding:var(--spacing-md);background:#fff;border-bottom:1px solid #E5E7EB}.search-bar{position:relative;display:flex;align-items:center;gap:12px;background:#f3f4f6;border:2px solid transparent;border-radius:var(--radius-md);padding:12px 16px;transition:all .3s ease}.search-bar:focus-within{background:#fff;border-color:var(--color-primary);box-shadow:0 0 0 4px #2563eb1a}.search-bar svg{color:var(--color-text-secondary);stroke-width:2;flex-shrink:0}.search-input{flex:1;border:none;background:transparent;font-size:15px;color:var(--color-text-primary);outline:none}.search-input::placeholder{color:var(--color-text-secondary)}.clear-search{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-text-secondary);border-radius:50%;color:#fff;transition:all .2s ease}.clear-search:hover{background:var(--color-error);transform:scale(1.1)}.clear-search svg{color:#fff;stroke-width:2.5}.advanced-filters{padding:var(--spacing-md);background:#fff;border-bottom:1px solid #E5E7EB;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-20px)}to{opacity:1;max-height:1000px;transform:translateY(0)}}.filter-group{margin-bottom:var(--spacing-md)}.filter-group:last-child{margin-bottom:0}.filter-label{display:block;font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.filter-pills{display:flex;flex-wrap:wrap;gap:8px}.filter-pill{padding:8px 16px;background:#f3f4f6;border:2px solid transparent;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--color-text-secondary);transition:all .3s ease;cursor:pointer}.filter-pill:hover{background:#e5e7eb;transform:translateY(-2px)}.filter-pill.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-color:var(--color-primary);color:#fff;font-weight:600}.filter-pill.priority-alta.active{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444}.filter-pill.priority-media.active{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b}.filter-pill.priority-baja.active{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981}.filter-pill.status-pendiente.active{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#ef4444}.filter-pill.status-en_proceso.active{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b}.filter-pill.status-resuelto.active{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981}.clear-filters-button{width:100%;margin-top:var(--spacing-md);padding:12px;background:#fff;border:2px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:14px;font-weight:600;transition:all .3s ease}.clear-filters-button:hover{background:var(--color-error);color:#fff;transform:translateY(-2px)}.active-filters-summary{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:var(--spacing-md);background:linear-gradient(135deg,#dbeafe,#eff6ff);border-bottom:1px solid #BFDBFE}.results-count{font-size:13px;font-weight:700;color:var(--color-primary);padding:6px 12px;background:#fff;border-radius:var(--radius-full);white-space:nowrap}.active-filter-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:1px solid var(--color-primary-light);border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--color-text-primary)}.active-filter-chip button{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:var(--color-text-secondary);border-radius:50%;color:#fff;font-size:12px;font-weight:700;transition:all .2s ease}.active-filter-chip button:hover{background:var(--color-error);transform:scale(1.15)}.explore-results{padding:var(--spacing-md);min-height:400px}.explore-results .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;min-height:400px}.explore-results .empty-state svg{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);opacity:.5}.explore-results .empty-state h3{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.explore-results .empty-state p{font-size:15px;color:var(--color-text-secondary);margin:0 0 var(--spacing-md) 0}.clear-all-button{padding:12px 24px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border-radius:var(--radius-md);font-size:14px;font-weight:600;transition:all .3s ease}.clear-all-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #2563eb4d}.profile-screen{min-height:100vh;background:linear-gradient(180deg,#eff6ff,#f5f3ee);padding-bottom:80px}.profile-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-md);background:#fff;border-bottom:1px solid #E5E7EB}.profile-header h2{font-size:24px;font-weight:700;color:var(--color-text-primary);margin:0}.settings-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#f3f4f6;border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all .3s ease}.settings-button:hover{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;transform:rotate(90deg)}.settings-button svg{stroke-width:2}.profile-content{padding:var(--spacing-md)}.profile-user-card{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-md);text-align:center}.user-avatar{width:100px;height:100px;margin:0 auto var(--spacing-md)}.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:4px solid var(--color-primary-light)}.avatar-initials{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:#fff;border:4px solid white;box-shadow:0 4px 12px #2563eb4d}.user-info{margin-bottom:var(--spacing-md)}.user-name{font-size:22px;font-weight:700;color:var(--color-text-primary);margin:0 0 4px}.user-email{font-size:14px;color:var(--color-text-secondary);margin:0 0 8px}.user-location{display:flex;align-items:center;justify-content:center;gap:4px;font-size:13px;color:var(--color-text-secondary);margin:0}.user-location svg{color:var(--color-primary);stroke-width:2}.edit-profile-button{width:100%;padding:12px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;border-radius:var(--radius-md);font-size:15px;font-weight:600;transition:all .3s ease}.edit-profile-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #2563eb4d}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:var(--spacing-md)}.stat-card{background:#fff;border-radius:var(--radius-md);padding:16px 12px;text-align:center;box-shadow:var(--shadow-sm);transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-card.highlight{background:linear-gradient(135deg,#dbeafe,#eff6ff);border:2px solid var(--color-primary-light)}.stat-value{font-size:24px;font-weight:700;color:var(--color-primary);margin-bottom:4px}.stat-card.highlight .stat-value{color:var(--color-primary-dark)}.stat-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.profile-section{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-sm)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-header h3{font-size:18px;font-weight:700;color:var(--color-text-primary);margin:0}.section-count{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;font-size:13px;font-weight:700;padding:4px 12px;border-radius:var(--radius-full)}.section-header.collapsible{width:100%;display:flex;justify-content:space-between;align-items:center;padding:0;background:transparent;cursor:pointer;transition:all .3s ease}.section-header.collapsible:hover{opacity:.7}.section-title-group{display:flex;align-items:center;gap:12px}.chevron-toggle{transition:transform .3s ease;color:var(--color-text-secondary);stroke-width:2.5}.chevron-toggle.open{transform:rotate(180deg)}.section-title-simple{font-size:18px;font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.my-reports-filters{display:flex;gap:8px;margin-bottom:var(--spacing-md);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.my-reports-filters::-webkit-scrollbar{display:none}.filter-tab{padding:8px 16px;background:#f3f4f6;border:2px solid transparent;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap;transition:all .3s ease}.filter-tab:hover{background:#e5e7eb}.filter-tab.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-color:var(--color-primary);color:#fff;font-weight:600}.my-reports-list{display:flex;flex-direction:column;gap:12px}.my-report-item{display:flex;gap:12px;align-items:center;padding:12px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease}.my-report-item:hover{background:#fff;border-color:var(--color-primary-light);box-shadow:0 4px 12px #2563eb1a;transform:translate(4px)}.my-report-image{width:80px;height:80px;border-radius:var(--radius-md);background-size:cover;background-position:center;position:relative;flex-shrink:0}.my-report-info{flex:1;min-width:0}.my-report-info h4{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-location{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--color-text-secondary);margin:0 0 8px}.report-location svg{stroke-width:2;flex-shrink:0}.report-meta{display:flex;gap:12px}.meta-item{font-size:12px;color:var(--color-text-secondary);font-weight:500}.chevron-icon{color:var(--color-text-secondary);stroke-width:2;flex-shrink:0}.voted-reports-list{display:flex;flex-direction:column;gap:8px;margin-top:var(--spacing-md);animation:slideDown .3s ease}.voted-report-item{display:flex;gap:12px;align-items:center;padding:10px;background:#f9fafb;border-radius:var(--radius-md);cursor:pointer;transition:all .3s ease}.voted-report-item:hover{background:#fff;box-shadow:0 2px 8px #0000000d}.voted-report-image{width:50px;height:50px;border-radius:var(--radius-sm);background-size:cover;background-position:center;flex-shrink:0}.voted-report-info{flex:1;min-width:0}.voted-report-info h4{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voted-report-info p{font-size:12px;color:var(--color-text-secondary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.priority-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.priority-dot.alta{background:var(--color-error)}.priority-dot.media{background:var(--color-warning)}.priority-dot.baja{background:var(--color-success)}.account-options{display:flex;flex-direction:column;gap:8px}.option-button{display:flex;align-items:center;gap:12px;padding:14px 12px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:var(--radius-md);color:var(--color-text-primary);font-size:15px;font-weight:500;transition:all .3s ease;cursor:pointer}.option-button:hover{background:#fff;border-color:var(--color-primary-light);transform:translate(4px)}.option-button svg{color:var(--color-primary);stroke-width:2;flex-shrink:0}.option-button span{flex:1}.chevron-right{color:var(--color-text-secondary);stroke-width:2.5;flex-shrink:0}.logout-button{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;background:#fff;border:2px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:15px;font-weight:600;transition:all .3s ease}.logout-button:hover{background:var(--color-error);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.logout-button svg{stroke-width:2}.empty-state-small{padding:var(--spacing-lg);text-align:center}.empty-state-small p{font-size:14px;color:var(--color-text-secondary);margin:0}.emergency-screen{min-height:100vh;background-color:var(--color-bg-main);padding-bottom:var(--spacing-xl)}.emergency-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background-color:var(--color-bg-card);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg)}.emergency-header h1{font-size:24px;font-weight:700;color:var(--color-text-primary);flex:1;text-align:center;margin-right:40px}.location-info-banner{display:flex;align-items:center;gap:8px;padding:12px var(--spacing-md);background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0369a1;font-size:13px;margin:var(--spacing-md);border-radius:var(--radius-md);border-left:4px solid #0284C7}.location-info-banner svg{flex-shrink:0}.emergency-content{padding:0 var(--spacing-md)}.sites-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.site-card{background-color:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all .3s ease}.site-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.site-info{padding:var(--spacing-lg)}.site-info h3{font-size:18px;font-weight:700;margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.site-title{font-size:18px;font-weight:700;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.site-category-badge{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.site-type-badge{position:static;padding:6px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:600;color:var(--color-text-light);display:inline-block;width:fit-content}.site-type-badge.hospital{background-color:#ef4444e6}.site-type-badge.police{background-color:#2563ebe6}.site-type-badge.fire{background-color:#f59e0be6}.site-type-badge.policia{background-color:#2563ebe6}.site-type-badge.bomberos{background-color:#f59e0be6}.site-type-badge.cruz-roja{background-color:#ef4444e6}.site-type-badge.defensa{background-color:#10b981e6}.site-type-badge.transito{background-color:#8b5cf6e6}.site-type-badge.epm{background-color:#06b6d4e6}.site-type-badge.default{background-color:#6b7280e6}.site-address,.site-distance,.site-description,.site-phone{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.site-distance{display:flex;align-items:center;gap:6px;font-size:13px;color:#0284c7;font-weight:500;margin-bottom:var(--spacing-sm)}.site-description{display:block;font-size:13px;line-height:1.5;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid #E5E7EB}.site-phone{font-size:13px;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.site-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.action-btn{padding:var(--spacing-md);border-radius:var(--radius-md);font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);transition:all .2s ease;box-shadow:var(--shadow-sm)}.action-btn.call{background-color:var(--color-success);color:var(--color-text-light)}.action-btn.call:hover{background-color:#059669;transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-btn.directions{background-color:var(--color-primary);color:var(--color-text-light)}.action-btn.directions:hover{background-color:var(--color-primary-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.retry-button{padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-full);background-color:var(--color-primary);color:var(--color-text-light);font-size:14px;font-weight:600;margin-top:var(--spacing-md);transition:all .2s ease}.retry-button:hover{background-color:var(--color-primary-light);transform:translateY(-2px)}@media (max-width: 375px){.home-logo img{width:300px}.home-subtitle{font-size:15px;max-width:90%}.go-button{padding:12px 32px;font-size:15px}.reports-grid{grid-template-columns:1fr}.auth-container{padding:var(--spacing-lg)}}
