*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--yellow:#FFD700;--yellow-dark:#E6C200;--black:#1A1A1A;--black-light:#2A2A2A;--grey-100:#F3F4F6;--grey-200:#E5E7EB;--grey-300:#9CA3AF;--grey-400:#6B7280;--grey-500:#4B5563;--grey-600:#374151;--white:#FFF}
html,body{height:100%;width:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--black);color:var(--white);-webkit-tap-highlight-color:transparent;user-select:none}
#app{height:100%;width:100%;display:flex;flex-direction:column;position:relative}
#header{background:var(--black);border-bottom:2px solid var(--yellow);z-index:1000;flex-shrink:0}
#headerTop{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 4px}
#headerTop h1{font-size:20px;font-weight:800;color:var(--yellow);letter-spacing:.5px}
#recordCount{font-size:11px;color:var(--grey-300);white-space:nowrap}
#headerSearch{display:flex;align-items:center;gap:4px;padding:4px 16px 10px;position:relative}
#headerSearch input{flex:1;padding:12px 36px 12px 16px;border-radius:8px;border:1px solid var(--grey-600);background:var(--black-light);color:var(--white);font-size:17px;outline:none;transition:border-color .2s;text-align:center;letter-spacing:3px;font-weight:600}
#headerSearch input:focus{border-color:var(--yellow)}
#headerSearch input::placeholder{color:var(--grey-500)}
.searchClearBtn{position:absolute;right:20px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--grey-500);font-size:20px;cursor:pointer;padding:4px 6px;line-height:1;display:none}
.searchClearBtn.show{display:block}.searchClearBtn:active{color:var(--grey-300)}
.filterError{font-size:12px;color:#EF4444;padding:6px 0 2px;display:none}
.filterError.show{display:block}
#map{flex:1;width:100%;z-index:1}
#loadingBar{position:fixed;top:0;left:0;right:0;z-index:9999;display:none;align-items:center;gap:10px;background:rgba(26,26,26,.95);padding:6px 16px;backdrop-filter:blur(4px)}
#loadingBar.show{display:flex}
.loading-bar-track{flex:1;height:6px;border-radius:3px;background:var(--grey-600);overflow:hidden}
.loading-bar-fill{height:100%;width:0;border-radius:3px;background:var(--yellow);transition:width .3s}
.loading-text{font-size:11px;color:var(--grey-300);white-space:nowrap;flex-shrink:0}
#navBar{display:flex;background:var(--black);border-top:1px solid var(--grey-600);z-index:1000;padding-bottom:env(safe-area-inset-bottom,0)}
.navBtn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5px 0 7px;background:transparent;border:none;color:var(--grey-400);font-size:10px;cursor:pointer;transition:color .2s;-webkit-tap-highlight-color:transparent;outline:none}
.navBtn svg{margin-bottom:1px}.navBtn.active{color:var(--yellow)}.navBtn:active{opacity:.7}

#filterPanel{position:fixed;bottom:0;left:0;right:0;max-height:75vh;background:var(--black-light);border-top:2px solid var(--yellow);border-radius:16px 16px 0 0;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);z-index:2000;overflow-y:auto}
#filterPanel.open{transform:translateY(0)}
#filterHeader{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px;border-bottom:1px solid var(--grey-600);position:sticky;top:0;background:var(--black-light);z-index:1}
#filterHeader span{font-size:18px;font-weight:600;color:var(--yellow)}
#filterClose,#infoClose{background:none;border:none;color:var(--grey-300);font-size:28px;cursor:pointer;padding:0 4px;line-height:1}
#filterBody{padding:16px 20px 24px}
.filterGroup{margin-bottom:16px}
.filterGroup label{display:block;font-size:12px;color:var(--grey-400);margin-bottom:5px;font-weight:500}
.filterGroup select,.filterGroup input[type="text"]{width:100%;padding:11px 14px;border-radius:8px;border:1px solid var(--grey-600);background:var(--black);color:var(--white);font-size:15px;outline:none;transition:border-color .2s;-webkit-appearance:none}
.filterGroup select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239CA3AF' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.filterGroup select:focus,.filterGroup input[type="text"]:focus{border-color:var(--yellow)}
.filterGroup select option{background:var(--black);color:var(--white)}
#concelhoTags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
.concelhoTag{display:inline-flex;align-items:center;gap:3px;padding:4px 8px;background:var(--yellow);color:var(--black);font-size:12px;font-weight:600;border-radius:4px}
.concelhoTag button{background:none;border:none;color:var(--black);font-size:14px;cursor:pointer;padding:0 2px;line-height:1;opacity:.7}
.concelhoTag button:active{opacity:1}
#concelhoAutocomplete{position:relative}
#concelhoSuggestions{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--black);border:1px solid var(--grey-600);border-top:none;border-radius:0 0 8px 8px;z-index:10;display:none}
#concelhoSuggestions.show{display:block}
.concelhoSuggestion{padding:10px 14px;font-size:14px;color:var(--grey-300);cursor:pointer;border-bottom:1px solid var(--grey-600)}
.concelhoSuggestion:last-child{border-bottom:none}
.concelhoSuggestion:hover,.concelhoSuggestion.highlighted{background:var(--grey-600);color:var(--white)}
#filterActions{display:flex;gap:12px;margin-top:8px}

.btn-primary{flex:1;padding:13px;border:none;border-radius:10px;background:var(--yellow);color:var(--black);font-size:15px;font-weight:700;cursor:pointer;transition:background .15s;text-align:center}
.btn-primary:active{background:var(--yellow-dark)}
.btn-secondary{flex:1;padding:13px;border:1px solid var(--grey-600);border-radius:10px;background:transparent;color:var(--grey-300);font-size:15px;font-weight:500;cursor:pointer;transition:background .15s;text-align:center}
.btn-secondary:active{background:var(--grey-600)}
.btn-secondary-sm{width:100%;padding:10px;border:1px solid var(--grey-600);border-radius:8px;background:var(--black);color:var(--grey-300);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s;text-align:center}
.btn-secondary-sm:active{background:var(--grey-600)}
.btn-navigate{display:block;width:100%;padding:13px;margin-top:12px;border:none;border-radius:10px;background:var(--yellow);color:var(--black);font-size:14px;font-weight:700;cursor:pointer;transition:background .15s;text-align:center}
.btn-navigate:active{background:var(--yellow-dark)}

#filterOverlay,#infoOverlay,#bottomModalOverlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1999;display:none}
#filterOverlay.show,#infoOverlay.show{display:block}
#bottomModalOverlay.show{display:block}

#infoPanel{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:360px;background:var(--black-light);border-left:2px solid var(--yellow);transform:translateX(100%);transition:transform .3s ease;z-index:2000;overflow-y:auto}
#infoPanel.open{transform:translateX(0)}
#infoHeader{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px;border-bottom:1px solid var(--grey-600);position:sticky;top:0;background:var(--black-light);z-index:1}
#infoHeader span{font-size:18px;font-weight:600;color:var(--yellow)}
#infoBody{padding:16px 20px 24px}
#infoBody h3{font-size:14px;color:var(--yellow);margin:14px 0 6px}
#infoBody p{font-size:12px;color:var(--grey-400);line-height:1.4;margin-bottom:4px}
.legendItem{display:flex;align-items:center;gap:10px;margin-bottom:6px;font-size:13px;color:var(--grey-300)}
.legendIcon{width:16px;height:16px;border-radius:3px;flex-shrink:0}
.legend-tri{width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:16px solid var(--yellow);background:none;border-radius:0}
.legend-green{background:#10B981}.legend-yellow{background:#FCD34D}.legend-orange{background:#FB923C}.legend-red{background:#EF4444}.legend-darkred{background:#991B1B}
#lastUpdateText{font-size:12px;color:var(--grey-400);margin-top:4px}

.leaflet-control-zoom a{background:var(--white)!important;color:var(--black)!important;border-color:var(--grey-200)!important}

#bottomModal{position:fixed;bottom:0;left:0;right:0;background:var(--black-light);border-top:2px solid var(--yellow);border-radius:16px 16px 0 0;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);z-index:3000;padding-bottom:env(safe-area-inset-bottom,0);max-height:70vh;overflow:hidden;display:flex;flex-direction:column}
#bottomModal.open{transform:translateY(0)}

.modal-handle{width:40px;height:4px;border-radius:2px;background:var(--grey-600);margin:10px auto 6px;flex-shrink:0}
.modal-cabecalho{padding:4px 20px 8px;flex-shrink:0}
.modal-codigo{font-size:18px;font-weight:700;color:var(--yellow);display:block}
.modal-concelho{font-size:13px;color:var(--grey-400);margin-top:2px;display:block}

.modal-tabs{display:flex;gap:0;padding:0 16px;flex-shrink:0;border-bottom:1px solid var(--grey-600)}
.modal-tab{flex:1;padding:10px 8px;background:none;border:none;border-bottom:3px solid transparent;color:var(--grey-400);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent}
.modal-tab.active{color:var(--yellow);border-bottom-color:var(--yellow)}
.modal-tab:active{opacity:.7}

.modal-corpo{padding:16px 20px 20px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}

.modal-card{background:var(--black);border-radius:12px;padding:12px 16px;margin-bottom:12px;border:1px solid var(--grey-600)}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--grey-600);font-size:13px;gap:12px}
.info-row:last-child{border-bottom:none}
.info-label{color:var(--grey-400);font-weight:500;flex-shrink:0}
.info-val{color:var(--white);font-weight:600;text-align:right}

.risco-badge{display:inline-block;padding:4px 12px;border-radius:20px;color:#fff;font-size:12px;font-weight:700;margin-bottom:10px}
.risco-nota{font-size:12px;color:var(--grey-300);margin-bottom:10px;padding:6px 10px;background:rgba(255,255,255,.05);border-radius:6px}

.equip-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}
.equip-item{display:flex;align-items:center;gap:6px;padding:5px 0;font-size:13px;color:var(--grey-300);cursor:pointer}
.equip-item input[type="checkbox"]{accent-color:var(--yellow);width:16px;height:16px}
.equip-item.disabled{opacity:.4}
.equip-input{flex:1;padding:6px 10px;border-radius:6px;border:1px solid var(--grey-600);background:var(--black);color:var(--white);font-size:13px;outline:none;margin-left:4px}
.equip-input:focus{border-color:var(--yellow)}

.fotos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.foto-card{border-radius:8px;overflow:hidden;border:1px solid var(--grey-600);background:var(--black)}
.foto-img-wrap{position:relative;aspect-ratio:1;overflow:hidden}
.foto-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;cursor:pointer}
.foto-del{position:absolute;top:3px;right:3px;width:20px;height:20px;border:none;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;font-size:11px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.foto-card:hover .foto-del,.foto-card:active .foto-del{opacity:1}
.foto-legenda{font-size:10px;color:var(--grey-300);padding:4px 6px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.foto-equip{display:flex;flex-wrap:wrap;gap:2px;padding:2px 4px 4px}
.equip-tag{font-size:8px;padding:1px 4px;border-radius:3px;background:var(--yellow);color:var(--black);font-weight:600}

.notas-timeline{padding:0;margin-bottom:12px}
.nota-card{background:var(--black);border:1px solid var(--grey-600);border-radius:10px;padding:10px 14px;margin-bottom:8px}
.nota-texto{font-size:13px;color:var(--white);line-height:1.4;margin-bottom:4px;word-break:break-word}
.nota-meta{font-size:11px;color:var(--grey-400)}
.nota-del{background:none;border:none;color:#EF4444;font-size:11px;cursor:pointer;padding:4px 0 0;display:inline-block}
.nota-input-wrap{padding-top:4px}
.nota-textarea{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--grey-600);background:var(--black);color:var(--white);font-size:13px;outline:none;resize:vertical;min-height:52px;font-family:inherit;transition:border-color .2s}
.nota-textarea:focus{border-color:var(--yellow)}

.galeria-overlay{position:fixed;inset:0;background:rgba(0,0,0,.94);z-index:9999;display:flex;align-items:center;justify-content:center}
.galeria-img{max-width:95%;max-height:80%;object-fit:contain;border-radius:6px}
.galeria-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;font-size:26px;padding:14px 10px;cursor:pointer;border-radius:8px;transition:background .2s}
.galeria-nav:active{background:rgba(255,255,255,.25)}
.galeria-prev{left:10px}.galeria-next{right:10px}
.galeria-close{position:absolute;top:10px;right:14px;background:none;border:none;color:#fff;font-size:30px;cursor:pointer;padding:8px;line-height:1;opacity:.7}
.galeria-close:active{opacity:1}
.galeria-caption{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);color:#fff;padding:6px 16px;border-radius:6px;font-size:14px;font-weight:500;max-width:85%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.perfil-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9998;display:flex;align-items:center;justify-content:center;padding:20px}
.perfil-box{background:var(--black-light);border:2px solid var(--yellow);border-radius:16px;padding:24px 20px;width:100%;max-width:380px}
.perfil-box h2{color:var(--yellow);font-size:20px;margin-bottom:4px;text-align:center}
.perfil-campo{margin-bottom:12px}
.perfil-campo label{display:block;font-size:12px;color:var(--grey-400);margin-bottom:4px;font-weight:500}
.perfil-campo input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--grey-600);background:var(--black);color:var(--white);font-size:15px;outline:none;transition:border-color .2s}
.perfil-campo input:focus{border-color:var(--yellow)}

@media(min-width:768px){
  #headerTop{padding:12px 24px 4px}#headerTop h1{font-size:24px}
  #headerSearch{padding:4px 24px 12px}
  #filterPanel{max-width:400px;left:auto;right:16px;bottom:16px;border-radius:16px;max-height:80vh;transform:translateX(150%)}
  #filterPanel.open{transform:translateX(0)}
  #infoPanel{top:56px;bottom:0}
  .navBtn{padding:7px 0 9px;font-size:11px}
  #bottomModal{max-width:480px;left:50%;transform:translate(-50%,100%)}
  #bottomModal.open{transform:translate(-50%,0)}
}
