:root{
  --green-dark:#06441f;
  --green:#006b3f;
  --green-soft:#eaf6e8;
  --za:#8dc63f;
  --text:#003b21;
  --muted:#52705c;
  --line:#d8eadc;
  --bg:#f4faf4;
  --yellow:#f2b300;
  --red:#ef3340;
  --ok:#16a34a;
}

*{box-sizing:border-box}

html,body{
  margin:0;
  min-height:100%;
  background:var(--bg);
  color:var(--text);
  font-family:Arial,Helvetica,sans-serif;
  font-size:14px;
}

body{
  overflow-x:hidden;
}

a{color:inherit}

.app-shell{
  display:grid;
  grid-template-columns:260px 1fr;
  min-height:100vh;
}

.sidebar{
  position:fixed;
  left:0;
  top:0;
  bottom:0;
  width:260px;
  background:linear-gradient(180deg,#073f20,#075b2d);
  color:#fff;
  padding:22px 18px;
  display:flex;
  flex-direction:column;
  gap:24px;
}

.brand-card{
  text-align:center;
  padding:18px 12px 22px;
  border-bottom:1px solid rgba(255,255,255,.22);
}

.brand-leaf{
  color:var(--za);
  font-size:56px;
  line-height:1;
}

.brand-main{
  font-weight:900;
  font-size:38px;
  line-height:.9;
  letter-spacing:-.05em;
}

.brand-main span{
  color:var(--za);
}

.brand-sub{
  color:var(--za);
  font-weight:800;
  font-size:18px;
  margin-top:2px;
}

.brand-title{
  font-weight:900;
  margin-top:14px;
  line-height:1.2;
}

.side-menu{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.side-menu a{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  color:#fff;
  font-weight:900;
  padding:14px 16px;
  border-radius:14px;
}

.side-menu a span{
  width:18px;
  opacity:.9;
}

.side-menu a.active{
  background:rgba(141,198,63,.22);
  border:1px solid rgba(141,198,63,.35);
  box-shadow:inset 4px 0 0 var(--za);
}

.side-footer{
  margin-top:auto;
  border-top:1px solid rgba(255,255,255,.22);
  padding-top:16px;
  color:#d9f0d8;
  font-size:12px;
  font-weight:800;
}

.za-small{
  margin-bottom:10px;
  font-weight:900;
}

.main{
  margin-left:260px;
  padding:24px 24px 40px;
  max-width:calc(100vw - 260px);
}

.page-head{
  display:grid;
  grid-template-columns:1fr 460px 96px;
  gap:14px;
  align-items:start;
  margin-bottom:14px;
}

.page-head h1{
  margin:0 0 4px;
  font-size:24px;
  line-height:1.08;
  font-weight:900;
  letter-spacing:-.035em;
}

.page-head p{
  margin:0;
  font-weight:900;
  color:#426249;
}

.top-selector{
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:16px;
  padding:10px 14px;
  box-shadow:0 8px 22px rgba(0,55,25,.05);
}

.top-selector label,
.updated-box span{
  display:block;
  text-transform:uppercase;
  font-size:10px;
  letter-spacing:.04em;
  color:#607866;
  font-weight:900;
}

.top-selector select{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  font-weight:900;
  color:var(--text);
  font-size:15px;
  margin:2px 0;
}

.top-selector small{
  color:#426249;
  font-weight:800;
  font-size:11px;
}

.updated-box{
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  text-align:center;
  box-shadow:0 8px 22px rgba(0,55,25,.05);
}

.updated-box strong{
  font-size:12px;
  display:block;
  margin-top:4px;
}

.dashboard-grid{
  display:grid;
  grid-template-columns:minmax(560px,1.02fr) minmax(520px,1fr);
  gap:16px;
  align-items:start;
}

.map-card,
.current-card,
.forecast-panel,
.timeline-panel,
.detail-panel,
.info-grid article,
.recommend-card{
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:0 8px 22px rgba(0,55,25,.05);
}

.map-card{
  padding:14px;
}

.panel-title-row,
.current-title-row,
.forecast-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}

.panel-title-row h2,
.current-title-row h2,
.forecast-title-row h2,
.timeline-panel h2,
.detail-panel h2{
  font-size:17px;
  line-height:1.15;
  margin:0;
  font-weight:900;
}

.panel-title-row span,
.current-title-row a,
.forecast-title-row span{
  color:#426249;
  font-size:11px;
  font-weight:900;
  text-decoration:none;
}

.map-searchbar{
  display:grid;
  grid-template-columns:1fr 110px;
  gap:10px;
  margin-bottom:10px;
}

.map-searchbar input{
  height:42px;
  border:1px solid var(--line);
  border-radius:12px;
  padding:0 16px;
  font-size:15px;
  font-weight:800;
  color:var(--text);
  outline:0;
}

.map-searchbar button,
.map-actions button,
.info-grid a{
  border:0;
  background:var(--green);
  color:#fff;
  height:42px;
  border-radius:12px;
  padding:0 18px;
  font-weight:900;
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
}

.map-actions{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:12px;
  flex-wrap:wrap;
}

.map-actions button{
  height:34px;
  color:var(--text);
  background:#fff;
  border:1px solid var(--line);
  padding:0 14px;
  font-size:12px;
}

.map-actions small{
  color:#426249;
  font-weight:800;
  font-size:11px;
}

#rsvMap{
  height:320px;
  width:100%;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,55,25,.16);
  background:#e8efe8;
}

.map-legend{
  display:flex;
  gap:16px;
  align-items:center;
  margin-top:8px;
  padding:8px 10px;
  border:1px solid var(--line);
  border-radius:12px;
  color:#426249;
  font-size:11px;
  font-weight:900;
}

.dot{
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:99px;
  margin-right:5px;
}

.dot.real{background:#5dc945}
.dot.selected{background:#f2b300}
.dot.user{background:#7e63b8}
.dot.elevado{background:#dc2626}
.dot.moderado{background:#f59e0b}
.dot.baixo{background:#5dc945}

.right-stack{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.current-card{
  padding:14px;
}

.current-title-row a{
  background:#fff;
  border:1px solid var(--line);
  border-radius:99px;
  padding:8px 12px;
  color:var(--text);
}

.risk-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  margin-bottom:14px;
}
@media(max-width:680px){
  .risk-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }
}

.risk-card{
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  padding:10px 12px;
  min-height:0;
}

.risk-card.moderado{border-color:#f5c86a;background:#fffaf0}
.risk-card.elevado{border-color:#ffb2b2;background:#fff6f4}

.risk-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  margin-bottom:10px;
}

.risk-top h3{
  margin:0;
  font-size:15px;
  font-weight:900;
}

.risk-top strong{
  color:#fff;
  border-radius:99px;
  padding:5px 9px;
  font-size:10px;
  line-height:1;
  text-transform:uppercase;
}

.risk-card.baixo .risk-top strong{background:var(--ok)}
.risk-card.moderado .risk-top strong{background:var(--yellow)}
.risk-card.elevado .risk-top strong{background:var(--red)}

.risk-card p{
  margin:0 0 14px;
  font-size:12px;
  line-height:1.25;
  font-weight:800;
}

.bars{
  display:grid;
  grid-template-columns:repeat(10,1fr);
  gap:5px;
  margin-top:auto;
}

.bars i{
  display:block;
  height:6px;
  border-radius:99px;
  background:#dce8df;
}

.risk-card.baixo .bars i.on{background:var(--ok)}
.risk-card.moderado .bars i.on{background:var(--yellow)}
.risk-card.elevado .bars i.on{background:var(--red)}

.metrics-row{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding-bottom:6px;
}

.metrics-row div{
  flex:0 0 auto;
  min-width:92px;
  min-height:52px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  padding:8px 10px;
}

.metrics-row span{
  display:block;
  font-size:9px;
  text-transform:uppercase;
  color:#607866;
  font-weight:900;
  margin-bottom:5px;
}

.metrics-row b{
  font-size:14px;
  font-weight:900;
}

.info-grid{
  display:grid;
  grid-template-columns:1.35fr 1fr;
  gap:12px;
}

.info-grid article,
.recommend-card{
  padding:14px;
}

.info-grid h3,
.recommend-card h3{
  margin:0 0 8px;
  font-size:15px;
}

.info-grid p,
.recommend-card p{
  margin:4px 0;
  font-size:12px;
  line-height:1.3;
  font-weight:800;
}

.info-grid a{
  margin-top:12px;
  height:36px;
  font-size:12px;
}

.forecast-panel{
  margin-top:16px;
  padding:14px;
}

.legend-risk{
  display:flex;
  gap:16px;
  font-size:11px;
  font-weight:900;
  color:#426249;
}

.legend-risk i{
  display:inline-block;
  width:18px;
  height:4px;
  border-radius:99px;
  margin-right:5px;
  vertical-align:middle;
}

.legend-risk .baixo{background:var(--ok)}
.legend-risk .moderado{background:var(--yellow)}
.legend-risk .elevado{background:var(--red)}

.forecast-strip{
  display:grid;
  grid-template-columns:repeat(10,minmax(112px,1fr));
  gap:10px;
}

.day-card{
  border:1px solid var(--line);
  border-radius:15px;
  background:#fff;
  min-height:172px;
  padding:12px 10px;
}

.day-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:6px;
  min-height:36px;
  margin-bottom:6px;
}

.day-title{
  font-size:13px;
  line-height:1.1;
  font-weight:900;
  color:var(--text);
}

.day-date{
  font-size:10.5px;
  font-weight:800;
  color:#426249;
  margin-top:4px;
}

.weather-symbol{
  position:relative;
  width:30px;
  height:30px;
  flex:0 0 30px;
  overflow:hidden;
}

.weather-symbol .sun{
  position:absolute;
  width:16px;
  height:16px;
  border-radius:99px;
  background:#ffc52e;
  right:2px;
  top:1px;
  box-shadow:0 0 0 4px rgba(255,197,46,.18);
}

.weather-symbol .cloud{
  position:absolute;
  width:24px;
  height:12px;
  border-radius:99px;
  background:#dff1f8;
  border:1px solid #9ab7c2;
  left:1px;
  top:12px;
}

.weather-symbol .rain{
  display:none;
  position:absolute;
  left:8px;
  top:23px;
  width:14px;
  height:7px;
  background:repeating-linear-gradient(90deg,#2693ff 0 2px,transparent 2px 5px);
  transform:skewX(-15deg);
}

.weather-symbol.chuva .rain,
.weather-symbol.aguaceiro .rain{
  display:block;
}

.day-values{
  font-size:11.5px;
  line-height:1.22;
  font-weight:900;
  margin-bottom:8px;
}

.day-values b,
.day-values span{
  display:block;
  margin:2px 0;
}

.mini-risks{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.mini-risks div{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:6px;
  font-size:10.5px;
  font-weight:900;
}

.mini-risks strong{
  color:#fff;
  border-radius:99px;
  padding:4px 7px;
  font-size:9px;
  line-height:1;
  text-transform:uppercase;
}

.level-baixo{background:var(--ok)}
.level-moderado{background:var(--yellow)}
.level-elevado{background:var(--red)}

.timeline-panel,
.detail-panel{
  margin-top:16px;
  padding:14px;
}

.timeline-placeholder{
  margin-top:12px;
  border:1px dashed var(--line);
  border-radius:14px;
  padding:20px;
  color:#426249;
  font-weight:800;
}

.detail-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:12px;
}

.detail-grid article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
}

.detail-grid h3{
  margin:0 0 8px;
}

.detail-grid p{
  margin:4px 0;
  font-weight:800;
}

@media(max-width:1350px){
  .dashboard-grid{
    grid-template-columns:1fr;
  }

  .forecast-strip{
    display:flex;
    overflow-x:auto;
    gap:10px;
    padding-bottom:8px;
  }

  .day-card{
    flex:0 0 126px;
  }
}

@media(max-width:900px){
  .app-shell{
    display:block;
  }

  .sidebar{
    display:none;
  }

  .main{
    margin-left:0;
    max-width:none;
    padding:16px;
  }

  .page-head{
    grid-template-columns:1fr;
  }

  .risk-grid,
  .info-grid,
  .detail-grid{
    grid-template-columns:1fr;
  }
}

/* ============================================================
   RSVPro PHP - AJUSTE FINAL POS SCREENSHOT
   Objetivo: aproximar do tecnico.html antigo.
   Só corrige largura, topo, grelha e cartões.
   ============================================================ */

/* O conteúdo deve ocupar a largura disponível depois da sidebar */
.app-shell {
  grid-template-columns: 260px minmax(0, 1fr) !important;
  width: 100vw !important;
}

.main {
  margin-left: 260px !important;
  width: calc(100vw - 260px) !important;
  max-width: none !important;
  padding: 24px 24px 40px 24px !important;
  overflow-x: hidden !important;
}

/* Cabeçalho como o técnico antigo: título à esquerda, seletor no topo direito */
.page-head {
  display: grid !important;
  grid-template-columns: minmax(620px, 1fr) 460px 110px !important;
  gap: 14px !important;
  align-items: start !important;
  margin-bottom: 14px !important;
  width: 100% !important;
}

.page-head > div:first-child {
  min-width: 0 !important;
  max-width: none !important;
}

.page-head h1 {
  white-space: nowrap !important;
  font-size: 24px !important;
  line-height: 1.08 !important;
  margin: 0 0 4px 0 !important;
  letter-spacing: -0.035em !important;
}

.page-head p {
  margin: 0 !important;
  font-size: 13px !important;
  line-height: 1.1 !important;
}

/* Seletor e caixa atualizado no mesmo estilo da referência */
.top-selector {
  min-width: 0 !important;
  height: 64px !important;
  padding: 10px 14px !important;
}

.updated-box {
  width: 110px !important;
  min-width: 110px !important;
  height: 64px !important;
  padding: 12px 8px !important;
}

/* Topo: mapa à esquerda e situação atual à direita */
.dashboard-grid {
  display: grid !important;
  grid-template-columns: minmax(620px, 1.03fr) minmax(560px, 1fr) !important;
  gap: 16px !important;
  align-items: start !important;
  width: 100% !important;
}

/* Mapa com proporção igual à referência */
.map-card {
  min-width: 0 !important;
  padding: 14px !important;
}

#rsvMap {
  height: 320px !important;
  min-height: 320px !important;
  max-height: 320px !important;
}

/* A pesquisa não deve cortar de forma feia */
.map-searchbar {
  grid-template-columns: minmax(0, 1fr) 110px !important;
}

.map-searchbar input {
  min-width: 0 !important;
}

/* Coluna direita */
.right-stack {
  min-width: 0 !important;
  gap: 14px !important;
}

/* Situação atual: 4 cartões em linha */
.risk-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.risk-card {
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 14px !important;
}

.risk-top {
  align-items: flex-start !important;
}

.risk-top h3 {
  font-size: 15px !important;
  line-height: 1.1 !important;
  word-break: normal !important;
}

.risk-card p {
  font-size: 12px !important;
  line-height: 1.22 !important;
}

/* Métricas observadas horizontais */
.metrics-row {
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  gap: 8px !important;
}

.metrics-row div {
  min-width: 92px !important;
}

/* Avisos e recomendação */
.info-grid {
  display: grid !important;
  grid-template-columns: 1.35fr 1fr !important;
  gap: 12px !important;
}

.recommend-card {
  width: 100% !important;
}

/* Previsão: largura total por baixo do topo */
.forecast-panel {
  width: 100% !important;
  max-width: none !important;
  margin-top: 16px !important;
  padding: 14px !important;
}

.forecast-title-row {
  align-items: center !important;
  margin-bottom: 12px !important;
}

.forecast-title-row h2 {
  font-size: 17px !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
}

/* 10 cartões visíveis em linha, como no técnico antigo */
.forecast-strip {
  display: grid !important;
  grid-template-columns: repeat(10, minmax(112px, 1fr)) !important;
  gap: 10px !important;
  align-items: stretch !important;
  overflow: visible !important;
  padding: 0 !important;
}

.day-card {
  min-width: 0 !important;
  min-height: 172px !important;
  height: auto !important;
  padding: 12px 10px !important;
  overflow: hidden !important;
}

.day-head {
  min-height: 34px !important;
  margin-bottom: 6px !important;
}

.day-title {
  font-size: 13px !important;
  line-height: 1.1 !important;
}

.day-date {
  font-size: 10.5px !important;
  line-height: 1.1 !important;
  margin-top: 4px !important;
}

/* Ícones dentro dos cartões */
.weather-symbol {
  width: 30px !important;
  height: 30px !important;
  min-width: 30px !important;
  max-width: 30px !important;
  overflow: hidden !important;
}

/* Informação do dia compacta */
.day-values {
  font-size: 11.2px !important;
  line-height: 1.18 !important;
  margin-bottom: 8px !important;
}

.mini-risks div {
  font-size: 10.5px !important;
  line-height: 1.1 !important;
}

.mini-risks strong {
  font-size: 9px !important;
  padding: 4px 6px !important;
}

/* Timeline logo por baixo dos cartões */
.timeline-panel {
  width: 100% !important;
  max-width: none !important;
  margin-top: 16px !important;
}

/* Ajuste para larguras intermédias: evitar espremer */
@media (max-width: 1450px) {
  .page-head {
    grid-template-columns: minmax(430px, 1fr) 420px 105px !important;
  }

  .dashboard-grid {
    grid-template-columns: minmax(520px, 1fr) minmax(500px, 1fr) !important;
  }

  .forecast-strip {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 10px !important;
    padding-bottom: 8px !important;
  }

  .day-card {
    flex: 0 0 126px !important;
    width: 126px !important;
    min-width: 126px !important;
    max-width: 126px !important;
  }
}

/* Mobile / janelas pequenas */
@media (max-width: 1100px) {
  .main {
    margin-left: 0 !important;
    width: 100vw !important;
    max-width: none !important;
    padding: 16px !important;
  }

  .sidebar {
    display: none !important;
  }

  .page-head {
    grid-template-columns: 1fr !important;
  }

  .page-head h1 {
    white-space: normal !important;
  }

  .dashboard-grid,
  .risk-grid,
  .info-grid {
    grid-template-columns: 1fr !important;
  }
}

/* FIM RSVPro PHP - AJUSTE FINAL POS SCREENSHOT */

/* ============================================================
   RSVPro PHP - FIX DADOS LOGO TITULO TEXTOS
   ============================================================ */

/* Título como referência: numa linha quando há largura */
.page-head {
  grid-template-columns: minmax(660px, 1fr) minmax(430px, 460px) 110px !important;
  align-items: start !important;
}

.page-head h1 {
  white-space: nowrap !important;
  font-size: 24px !important;
  line-height: 1.08 !important;
  max-width: none !important;
}

/* Logo correto por imagem */
.brand-card {
  padding: 18px 12px 22px !important;
}

.brand-logo-img {
  display: block !important;
  width: 155px !important;
  max-width: 92% !important;
  height: auto !important;
  margin: 0 auto 12px auto !important;
  object-fit: contain !important;
}

.brand-leaf {
  font-size: 44px !important;
}

.brand-main {
  font-size: 36px !important;
}

/* Texto da estação não rebenta contentor */
.top-selector {
  overflow: hidden !important;
  min-width: 0 !important;
}

.top-selector select {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: 14px !important;
}

.top-selector small {
  display: block !important;
  width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* Atualizado mais compacto, sem ISO enorme */
.updated-box strong {
  font-size: 12px !important;
  line-height: 1.15 !important;
  word-break: normal !important;
}

/* Mapa / direita mais próximos da referência */
.dashboard-grid {
  grid-template-columns: minmax(620px, 1.03fr) minmax(560px, 1fr) !important;
}

.map-card,
.current-card {
  min-width: 0 !important;
}

#rsvMap {
  height: 320px !important;
  min-height: 320px !important;
  max-height: 320px !important;
}

/* Cards de risco: evitar Black Rot quebrar feio */
.risk-top h3 {
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
}

.risk-card {
  min-width: 0 !important;
}

/* Métricas ligadas mas compactas */
.metrics-row div {
  min-width: 92px !important;
}

.metrics-row b {
  white-space: nowrap !important;
}

/* Previsão mantém 10 dias como técnico antigo */
.forecast-strip {
  grid-template-columns: repeat(10, minmax(112px, 1fr)) !important;
}

.day-card {
  min-height: 172px !important;
}

/* Em largura insuficiente, scroll em vez de esmagar */
@media (max-width: 1450px) {
  .page-head {
    grid-template-columns: minmax(420px, 1fr) minmax(390px, 430px) 105px !important;
  }

  .forecast-strip {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 10px !important;
    padding-bottom: 8px !important;
  }

  .day-card {
    flex: 0 0 126px !important;
    min-width: 126px !important;
    max-width: 126px !important;
  }
}

@media (max-width: 1150px) {
  .page-head {
    grid-template-columns: 1fr !important;
  }

  .page-head h1 {
    white-space: normal !important;
  }
}

/* FIM RSVPro PHP - FIX DADOS LOGO TITULO TEXTOS */

/* ============================================================
   RSVPro PHP - LOGO REAL RSVPRO
   ============================================================ */

.brand-card {
  text-align: center !important;
  padding: 18px 12px 22px !important;
  border-bottom: 1px solid rgba(255,255,255,.22) !important;
}

.brand-logo-img-real {
  display: block !important;
  width: 170px !important;
  max-width: 94% !important;
  height: auto !important;
  margin: 0 auto 12px auto !important;
  object-fit: contain !important;
}

.brand-title {
  color: #ffffff !important;
  font-size: 14px !important;
  line-height: 1.18 !important;
  font-weight: 900 !important;
  margin-top: 10px !important;
}

/* esconder restos do logo textual improvisado */
.brand-logo-text,
.brand-leaf-mark,
.brand-rsv,
.brand-za,
.brand-leaf,
.brand-main,
.brand-sub,
.brand-logo-img {
  display: none !important;
}

/* FIM RSVPro PHP - LOGO REAL RSVPRO */

/* ============================================================
   RSVPro PHP - HEADER FINAL COMPACTO
   ============================================================ */

.main {
  margin-left: 260px !important;
  width: calc(100vw - 260px) !important;
  max-width: none !important;
  padding: 20px 22px 40px 22px !important;
  overflow-x: hidden !important;
}

/* Título menor + selector mais largo + atualizado compacto */
.page-head {
  display: grid !important;
  grid-template-columns: minmax(390px, 1fr) minmax(520px, 590px) 118px !important;
  gap: 14px !important;
  align-items: start !important;
  width: 100% !important;
  margin-bottom: 14px !important;
}

.page-head > div:first-child {
  min-width: 0 !important;
}

.page-head h1 {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 20px !important;
  line-height: 1.06 !important;
  margin: 0 0 5px 0 !important;
  letter-spacing: -0.035em !important;
  font-weight: 900 !important;
  color: #003b21 !important;
}

.page-head p {
  margin: 0 !important;
  font-size: 12.5px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  color: #426249 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Selector com largura suficiente */
.top-selector {
  width: 100% !important;
  max-width: 590px !important;
  min-width: 0 !important;
  height: 64px !important;
  padding: 10px 14px !important;
  overflow: hidden !important;
}

.top-selector label {
  display: block !important;
  font-size: 10px !important;
  line-height: 1 !important;
  margin: 0 0 3px 0 !important;
  letter-spacing: .045em !important;
}

.top-selector select {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  height: 21px !important;
  line-height: 21px !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  padding-right: 30px !important;
}

.top-selector small {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: 11px !important;
  line-height: 1.15 !important;
  margin-top: 2px !important;
}

/* Atualizado curto: 16/05 14:02 */
.updated-box {
  width: 118px !important;
  min-width: 118px !important;
  max-width: 118px !important;
  height: 64px !important;
  padding: 11px 8px !important;
  overflow: hidden !important;
}

.updated-box span {
  font-size: 9.5px !important;
  line-height: 1 !important;
  letter-spacing: .04em !important;
}

.updated-box strong {
  display: block !important;
  font-size: 12.5px !important;
  line-height: 1.12 !important;
  margin-top: 6px !important;
  white-space: nowrap !important;
  word-break: normal !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* A grelha abaixo continua alinhada */
.dashboard-grid {
  grid-template-columns: minmax(620px, 1.03fr) minmax(560px, 1fr) !important;
  gap: 16px !important;
}

/* Ajuste para largura intermédia */
@media (max-width: 1500px) {
  .page-head {
    grid-template-columns: minmax(300px, 1fr) minmax(470px, 540px) 112px !important;
  }

  .page-head h1 {
    font-size: 19px !important;
  }

  .top-selector {
    max-width: 540px !important;
  }

  .updated-box {
    width: 112px !important;
    min-width: 112px !important;
    max-width: 112px !important;
  }

  .updated-box strong {
    font-size: 12px !important;
  }
}

@media (max-width: 1200px) {
  .page-head {
    grid-template-columns: 1fr !important;
  }

  .page-head h1,
  .page-head p {
    white-space: normal !important;
  }

  .top-selector,
  .updated-box {
    width: 100% !important;
    max-width: none !important;
  }
}

/* FIM RSVPro PHP - HEADER FINAL COMPACTO */

/* ============================================================
   RSVPro PHP - TIMELINE PRO HTML ANTIGO
   Inspirado na timeline técnica antiga: grelha, tabs, gráfico e tabela.
   ============================================================ */

.rsv-timeline-pro {
  margin-top: 16px !important;
  padding: 14px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.97) !important;
  border: 1px solid #d8eadc !important;
  box-shadow: 0 8px 22px rgba(0,55,25,.05) !important;
  overflow: hidden !important;
}

.rsv-timeline-pro-head {
  margin-bottom: 12px !important;
}

.rsv-timeline-pro-head h2 {
  margin: 0 0 4px 0 !important;
  color: #003b21 !important;
  font-size: 18px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
}

.rsv-timeline-pro-head p {
  margin: 0 !important;
  color: #52705c !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.rsv-timeline-loading {
  border: 1px dashed #d8eadc !important;
  border-radius: 14px !important;
  padding: 18px !important;
  color: #52705c !important;
  font-weight: 900 !important;
  background: #f8fcf8 !important;
}

.rsv-timeline-toolbar {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 10px !important;
  flex-wrap: wrap !important;
}

.rsv-timeline-tabs {
  display: inline-flex !important;
  gap: 6px !important;
  padding: 5px !important;
  border-radius: 999px !important;
  border: 1px solid #d8eadc !important;
  background: #f8fcf8 !important;
}

.rsv-timeline-tabs button {
  border: 0 !important;
  background: transparent !important;
  color: #003b21 !important;
  border-radius: 999px !important;
  padding: 9px 16px !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
}

.rsv-timeline-tabs button.active {
  color: #ffffff !important;
  background: #006b3f !important;
  box-shadow: 0 4px 12px rgba(0,107,63,.18) !important;
}

.rsv-timeline-hint {
  font-size: 11px !important;
  color: #6b7f70 !important;
  font-weight: 900 !important;
}

.rsv-timeline-legend {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  border: 1px solid #d8eadc !important;
  background: #ffffff !important;
  border-radius: 999px !important;
  padding: 8px 12px !important;
  margin-bottom: 10px !important;
  font-size: 11px !important;
  color: #426249 !important;
  font-weight: 900 !important;
}

.rsv-timeline-legend b {
  color: #003b21 !important;
}

.rsv-timeline-legend i {
  display: inline-block !important;
  width: 22px !important;
  height: 6px !important;
  border-radius: 999px !important;
  margin-right: 5px !important;
  vertical-align: middle !important;
}

.rsv-timeline-legend .lg-baixo { background: #16a34a !important; }
.rsv-timeline-legend .lg-moderado { background: #f2b300 !important; }
.rsv-timeline-legend .lg-elevado { background: #ef3340 !important; }
.rsv-timeline-legend .lg-condicao { background: #b8e2ef !important; }
.rsv-timeline-legend .lg-evento { background: #f4cd72 !important; }
.rsv-timeline-legend .lg-critico { background: #e99a22 !important; }
.rsv-timeline-legend .lg-susc { background: #ef3340 !important; }
.rsv-timeline-legend .lg-naosusc { background: #16a34a !important; }

.rsv-timeline-scroll {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  border: 1px solid #e2efe4 !important;
  border-radius: 16px !important;
  background: #ffffff !important;
  /* scroll fluido em mobile */
  -webkit-overflow-scrolling: touch !important;
  scroll-behavior: smooth !important;
  overscroll-behavior-x: contain !important;
}

.rsv-timeline-grid {
  min-width: max-content !important;
}

.rsv-row {
  display: grid !important;
  grid-template-columns: 190px repeat(var(--tl-days), 52px) !important;
  border-bottom: 1px solid #e2efe4 !important;
}

.rsv-row:last-child {
  border-bottom: 0 !important;
}

.rsv-row-label {
  position: sticky !important;
  left: 0 !important;
  z-index: 3 !important;
  background: #ffffff !important;
  border-right: 1px solid #d8eadc !important;
  padding: 9px 10px !important;
  color: #003b21 !important;
  font-weight: 900 !important;
  font-size: 12px !important;
  display: flex !important;
  align-items: center !important;
}

.rsv-row-label.section {
  font-size: 14px !important;
  background: #f8fcf8 !important;
  color: #006b3f !important;
}

.rsv-cell {
  min-height: 36px !important;
  border-right: 1px solid #edf5ef !important;
  padding: 5px 4px !important;
  text-align: center !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
}

.rsv-cell:last-child {
  border-right: 0 !important;
}

.rsv-cell.today {
  background: rgba(141,198,63,.22) !important;
  box-shadow: inset 0 0 0 2px rgba(141,198,63,.55) !important;
}

.rsv-cell.future {
  background: rgba(240,247,255,.65) !important;
}

.rsv-day-head {
  min-height: 48px !important;
  flex-direction: column !important;
  gap: 2px !important;
  color: #003b21 !important;
  font-weight: 900 !important;
}

.rsv-day-head b {
  font-size: 11px !important;
  line-height: 1 !important;
}

.rsv-day-head span {
  font-size: 9px !important;
  line-height: 1 !important;
  color: #52705c !important;
}

.rsv-pill {
  display: inline-block !important;
  width: 26px !important;
  height: 8px !important;
  border-radius: 999px !important;
  background: #edf3ef !important;
  border: 1px solid #e0ece4 !important;
}

.rsv-pill.baixo { background: #16a34a !important; border-color: #16a34a !important; }
.rsv-pill.moderado { background: #f2b300 !important; border-color: #f2b300 !important; }
.rsv-pill.elevado { background: #ef3340 !important; border-color: #ef3340 !important; }
.rsv-pill.condicao { background: #b8e2ef !important; border-color: #b8e2ef !important; }
.rsv-pill.evento { background: #f4cd72 !important; border-color: #f4cd72 !important; }
.rsv-pill.critico { background: #e99a22 !important; border-color: #e99a22 !important; }

.rsv-subrow .rsv-row-label {
  padding-left: 18px !important;
  font-size: 11px !important;
}

.rsv-climate-chart-row {
  display: grid !important;
  grid-template-columns: 190px minmax(900px, 1fr) !important;
  border-bottom: 1px solid #e2efe4 !important;
}

.rsv-chart-legend {
  position: sticky !important;
  left: 0 !important;
  z-index: 3 !important;
  background: #ffffff !important;
  border-right: 1px solid #d8eadc !important;
  padding: 14px 12px !important;
  color: #003b21 !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.rsv-chart-legend h3 {
  margin: 0 0 12px 0 !important;
  font-size: 14px !important;
  color: #006b3f !important;
}

.rsv-chart-legend span {
  display: block !important;
  margin: 8px 0 !important;
}

.rsv-chart-legend i {
  display: inline-block !important;
  width: 22px !important;
  height: 4px !important;
  border-radius: 999px !important;
  margin-right: 8px !important;
  vertical-align: middle !important;
}

.rsv-chart-legend .tmax { background: #ef3340 !important; }
.rsv-chart-legend .tmed { background: #006b3f !important; }
.rsv-chart-legend .tmin { background: #1f6d99 !important; }
.rsv-chart-legend .c24 { background: #6eb8e6 !important; height: 10px !important; width: 10px !important; }
.rsv-chart-legend .c3 { background: #bfdff0 !important; height: 10px !important; width: 10px !important; }
.rsv-chart-legend .leaf { background: #86b96a !important; height: 10px !important; width: 10px !important; }

.rsv-chart-box {
  background: linear-gradient(90deg, #fff 0%, #fff 70%, rgba(240,247,255,.7) 70%, rgba(240,247,255,.7) 100%) !important;
  padding: 0 !important;
}

.rsv-tl-svg {
  width: 100% !important;
  min-width: 900px !important;
  height: 280px !important;
  display: block !important;
}

.rsv-tl-svg .grid {
  stroke: #e8f1ea !important;
  stroke-width: 1 !important;
}

.rsv-tl-svg .axis {
  stroke: #d8eadc !important;
  stroke-width: 2 !important;
}

.rsv-tl-svg .tmax {
  fill: none !important;
  stroke: #ef3340 !important;
  stroke-width: 3 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.rsv-tl-svg .tmed {
  fill: none !important;
  stroke: #006b3f !important;
  stroke-width: 3 !important;
  stroke-dasharray: 6 4 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.rsv-tl-svg .tmin {
  fill: none !important;
  stroke: #1f6d99 !important;
  stroke-width: 3 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.rsv-tl-svg .bar24 { fill: rgba(80,160,220,.55) !important; }
.rsv-tl-svg .bar3 { fill: rgba(180,220,240,.75) !important; }
.rsv-tl-svg .barleaf { fill: rgba(120,170,90,.75) !important; }

.rsv-tl-svg .today-band {
  fill: rgba(141,198,63,.22) !important;
  stroke: rgba(141,198,63,.5) !important;
  stroke-width: 2 !important;
}

.rsv-tl-svg .future-band {
  fill: rgba(240,247,255,.65) !important;
}

.rsv-tl-svg .xlabel {
  fill: #52705c !important;
  font-size: 10px !important;
  font-weight: 900 !important;
}

.rsv-table-title {
  padding: 10px !important;
  color: #006b3f !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  border-bottom: 1px solid #e2efe4 !important;
}

.rsv-climate-table .rsv-row-label {
  font-size: 11px !important;
}

.rsv-climate-table .rsv-cell {
  min-height: 32px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  color: #17324d !important;
  white-space: nowrap !important;
}

.rsv-empty-timeline {
  padding: 20px !important;
  border: 1px dashed #d8eadc !important;
  border-radius: 16px !important;
  background: #f8fcf8 !important;
  color: #52705c !important;
  font-weight: 900 !important;
}

@media (max-width: 760px) {
  .rsv-timeline-toolbar {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .rsv-timeline-tabs {
    width: 100% !important;
    overflow-x: auto !important;
  }

  .rsv-row {
    grid-template-columns: 145px repeat(var(--tl-days), 48px) !important;
  }

  .rsv-climate-chart-row {
    grid-template-columns: 145px minmax(820px, 1fr) !important;
  }

  .rsv-row-label,
  .rsv-chart-legend {
    width: 145px !important;
  }
}

/* FIM RSVPro PHP - TIMELINE PRO HTML ANTIGO */

/* ============================================================
   RSVPro PHP - TIMELINE PRO COMPORTAMENTO TABS
   Síntese mostra só 3 doenças.
   Cada doença abre as condições respetivas.
   ============================================================ */

.rsv-timeline-pro[data-tab="sintese"] .tl-detail {
  display: none !important;
}

.rsv-timeline-pro[data-tab="mildio"] .tl-row-sintese,
.rsv-timeline-pro[data-tab="oidio"] .tl-row-sintese,
.rsv-timeline-pro[data-tab="blackrot"] .tl-row-sintese,
.rsv-timeline-pro[data-tab="lobesia"] .tl-row-sintese {
  display: none !important;
}

/* Lobesia tab */
.rsv-timeline-pro[data-tab="lobesia"] .tl-row-lobesia {
  display: grid !important;
}
.rsv-timeline-pro[data-tab="lobesia"] .tl-detail {
  display: none !important;
}
.rsv-timeline-pro[data-tab="lobesia"] .tl-detail-lobesia {
  display: block !important;
}

.rsv-timeline-pro[data-tab="mildio"] .tl-row-mildio,
.rsv-timeline-pro[data-tab="oidio"] .tl-row-oidio,
.rsv-timeline-pro[data-tab="blackrot"] .tl-row-blackrot {
  display: grid !important;
}

.rsv-timeline-pro[data-tab="mildio"] .tl-detail {
  display: none !important;
}

.rsv-timeline-pro[data-tab="mildio"] .tl-detail-mildio {
  display: grid !important;
}

.rsv-timeline-pro[data-tab="oidio"] .tl-detail {
  display: none !important;
}

.rsv-timeline-pro[data-tab="oidio"] .tl-detail-oidio {
  display: grid !important;
}

.rsv-timeline-pro[data-tab="blackrot"] .tl-detail {
  display: none !important;
}

.rsv-timeline-pro[data-tab="blackrot"] .tl-detail-blackrot {
  display: grid !important;
}

/* Em cada doença, deixa clara a linha principal */
.rsv-timeline-pro[data-tab="mildio"] .tl-row-mildio .rsv-row-label,
.rsv-timeline-pro[data-tab="oidio"] .tl-row-oidio .rsv-row-label,
.rsv-timeline-pro[data-tab="blackrot"] .tl-row-blackrot .rsv-row-label {
  background: #eef8ed !important;
  color: #006b3f !important;
}

/* separadores com feedback visual */
.rsv-timeline-tabs button {
  transition: background .16s ease, color .16s ease, transform .16s ease !important;
}

.rsv-timeline-tabs button:hover {
  transform: translateY(-1px) !important;
}

.rsv-subrow .rsv-row-label {
  color: #003b21 !important;
  background: #fbfdfb !important;
}

/* eventos vazios discretos */
.rsv-pill:not(.baixo):not(.moderado):not(.elevado):not(.condicao):not(.evento):not(.critico) {
  background: #ffffff !important;
  border: 1px solid #dcebe0 !important;
}

/* FIM RSVPro PHP - TIMELINE PRO COMPORTAMENTO TABS */

/* ============================================================
   RSVPro PHP - TIMELINE LEITURA MELHORADA
   Remove ruído visual, melhora gráfico/tabela e leitura por coluna.
   ============================================================ */

/* A timeline fica mais limpa e menos pesada */
.rsv-timeline-pro {
  background: #ffffff !important;
}

/* Cabeçalho dos dias mais claro */
.rsv-day-head {
  min-height: 46px !important;
  background: #fbfdfb !important;
}

.rsv-day-head b {
  font-size: 11px !important;
  line-height: 1.05 !important;
  color: #003b21 !important;
}

.rsv-day-head span {
  font-size: 8.5px !important;
  letter-spacing: .025em !important;
  color: #6b7f70 !important;
}

/* O dia atual continua marcado, mas sem esmagar a leitura */
.rsv-cell.today {
  background: rgba(141,198,63,.18) !important;
  box-shadow: inset 0 0 0 2px rgba(141,198,63,.50) !important;
}

.rsv-cell.future {
  background: rgba(245,250,255,.72) !important;
}

/* Hover vertical: seguir o dia de cima a baixo */
.rsv-cell.rsv-col-hover {
  background: rgba(141,198,63,.18) !important;
  box-shadow: inset 0 0 0 2px rgba(0,107,63,.22) !important;
  z-index: 2 !important;
}

/* Labels à esquerda mais limpos */
.rsv-row-label {
  font-size: 11.5px !important;
  line-height: 1.15 !important;
}

.rsv-subrow .rsv-row-label {
  color: #21472f !important;
  font-size: 11px !important;
  font-weight: 850 !important;
  background: #fbfdfb !important;
}

/* A linha principal da doença deve ser mais forte que as sublinhas */
.tl-main-row .rsv-row-label {
  color: #003b21 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  background: #ffffff !important;
}

/* Pill de doença: ligeiramente mais largo e legível */
.rsv-pill {
  width: 28px !important;
  height: 8px !important;
  border-radius: 999px !important;
}

/* Eventos vazios ficam quase invisíveis, mas ainda alinhados */
.rsv-pill:not(.baixo):not(.moderado):not(.elevado):not(.condicao):not(.evento):not(.critico) {
  background: #ffffff !important;
  border: 1px solid #e5f0e8 !important;
}

/* Legenda menos comprida visualmente */
.rsv-timeline-legend {
  border-radius: 14px !important;
  padding: 8px 10px !important;
  gap: 10px !important;
  font-size: 10.5px !important;
}

.rsv-timeline-legend i {
  width: 20px !important;
  height: 5px !important;
}

/* Gráfico: mais respirável, com fundo mais subtil */
.rsv-climate-chart-row {
  background: #ffffff !important;
  border-top: 1px solid #e2efe4 !important;
  border-bottom: 1px solid #e2efe4 !important;
}

.rsv-chart-legend {
  background: #ffffff !important;
  padding: 16px 12px !important;
}

.rsv-chart-legend h3 {
  font-size: 14px !important;
  margin-bottom: 14px !important;
}

.rsv-chart-legend span {
  margin: 9px 0 !important;
  color: #21472f !important;
}

/* Fundo do gráfico mais limpo */
.rsv-chart-box {
  background:
    linear-gradient(90deg, #ffffff 0%, #ffffff 68%, rgba(245,250,255,.82) 68%, rgba(245,250,255,.82) 100%) !important;
}

/* SVG mais alto e linhas mais elegantes */
.rsv-tl-svg {
  height: 305px !important;
}

.rsv-tl-svg .grid {
  stroke: #edf5ef !important;
  stroke-width: 1 !important;
}

.rsv-tl-svg .axis {
  stroke: #d8eadc !important;
  stroke-width: 1.5 !important;
}

.rsv-tl-svg .tmax {
  stroke: #ef3340 !important;
  stroke-width: 3.2 !important;
}

.rsv-tl-svg .tmed {
  stroke: #006b3f !important;
  stroke-width: 2.7 !important;
  stroke-dasharray: 7 4 !important;
}

.rsv-tl-svg .tmin {
  stroke: #1f6d99 !important;
  stroke-width: 2.7 !important;
}

.rsv-tl-svg .bar24 {
  fill: rgba(80,160,220,.50) !important;
}

.rsv-tl-svg .bar3 {
  fill: rgba(180,220,240,.58) !important;
}

.rsv-tl-svg .barleaf {
  fill: rgba(120,170,90,.70) !important;
}

.rsv-tl-svg .today-band {
  fill: rgba(141,198,63,.18) !important;
  stroke: rgba(141,198,63,.38) !important;
}

.rsv-tl-svg .future-band {
  fill: rgba(245,250,255,.72) !important;
}

.rsv-tl-svg .xlabel {
  fill: #52705c !important;
  font-size: 10px !important;
}

/* Tabela climática: melhorar leitura horizontal */
.rsv-table-title {
  padding: 12px 10px !important;
  background: #fbfdfb !important;
  color: #006b3f !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

.rsv-climate-table .rsv-row:nth-child(odd) .rsv-cell,
.rsv-climate-table .rsv-row:nth-child(odd) .rsv-row-label {
  background-color: #fbfdfb !important;
}

.rsv-climate-table .rsv-row:nth-child(even) .rsv-cell,
.rsv-climate-table .rsv-row:nth-child(even) .rsv-row-label {
  background-color: #ffffff !important;
}

.rsv-climate-table .rsv-cell {
  min-height: 31px !important;
  font-size: 10.5px !important;
  color: #17324d !important;
  font-weight: 800 !important;
}

.rsv-climate-table .rsv-row-label {
  color: #003b21 !important;
  font-weight: 900 !important;
}

/* Em tabela, hover também fica evidente */
.rsv-climate-table .rsv-cell.rsv-col-hover {
  background: rgba(141,198,63,.20) !important;
}

/* Separador ativo mais claro */
.rsv-timeline-tabs button.active {
  background: #006b3f !important;
  color: #ffffff !important;
  box-shadow: 0 6px 14px rgba(0,107,63,.18) !important;
}

/* FIM RSVPro PHP - TIMELINE LEITURA MELHORADA */

/* ============================================================
   RSVPro PHP - TIMELINE PRO POLISH FINAL
   Alinhamento, tipografia, números tabulares e leitura de produto.
   ============================================================ */

.rsv-timeline-pro {
  --tl-label-w: 210px;
  --tl-day-w: 58px;
  --tl-border: #e2efe4;
  --tl-border-strong: #d4e7d8;
  --tl-bg-soft: #f8fcf8;
  --tl-green: #006b3f;
  --tl-text: #003b21;
  --tl-muted: #52705c;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}

/* Área geral mais limpa e premium */
.rsv-timeline-pro {
  background:
    linear-gradient(180deg, rgba(248,252,248,.96), rgba(255,255,255,.98) 120px),
    #fff !important;
  border-radius: 20px !important;
  border-color: var(--tl-border-strong) !important;
}

/* Cabeçalho */
.rsv-timeline-pro-head {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 2px 2px 4px !important;
}

.rsv-timeline-pro-head h2 {
  font-size: 18px !important;
  letter-spacing: -0.025em !important;
}

.rsv-timeline-pro-head p {
  font-size: 11.5px !important;
  color: var(--tl-muted) !important;
}

/* Separadores */
.rsv-timeline-toolbar {
  margin: 12px 0 10px !important;
}

.rsv-timeline-tabs {
  background: #ffffff !important;
  border: 1px solid var(--tl-border-strong) !important;
  box-shadow: 0 6px 16px rgba(0,55,25,.045) !important;
}

.rsv-timeline-tabs button {
  height: 34px !important;
  padding: 0 15px !important;
  font-size: 11.5px !important;
  letter-spacing: -0.01em !important;
}

.rsv-timeline-tabs button.active {
  background: var(--tl-green) !important;
}

/* Legenda compacta, sem dominar o ecrã */
.rsv-timeline-legend {
  border-radius: 14px !important;
  background: #ffffff !important;
  border: 1px solid var(--tl-border) !important;
  box-shadow: none !important;
  padding: 7px 10px !important;
  gap: 11px !important;
  font-size: 10.5px !important;
  line-height: 1.1 !important;
}

.rsv-timeline-legend b {
  font-size: 10.5px !important;
}

.rsv-timeline-legend i {
  width: 22px !important;
  height: 5px !important;
  margin-right: 5px !important;
}

/* Scroll principal com cantos e sombra discreta */
.rsv-timeline-scroll {
  border: 1px solid var(--tl-border-strong) !important;
  border-radius: 18px !important;
  background: #fff !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8) !important;
}

/* A grelha inteira usa as mesmas larguras */
.rsv-timeline-grid {
  min-width: max-content !important;
}

.rsv-row {
  display: grid !important;
  grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
  border-bottom: 1px solid var(--tl-border) !important;
  min-width: max-content !important;
}

/* Coluna esquerda fixa, sempre igual */
.rsv-row-label {
  position: sticky !important;
  left: 0 !important;
  z-index: 6 !important;
  width: var(--tl-label-w) !important;
  min-width: var(--tl-label-w) !important;
  max-width: var(--tl-label-w) !important;
  background: #ffffff !important;
  border-right: 1px solid var(--tl-border-strong) !important;
  padding: 0 12px !important;
  min-height: 34px !important;
  display: flex !important;
  align-items: center !important;
  color: var(--tl-text) !important;
  font-size: 11.5px !important;
  line-height: 1.1 !important;
  font-weight: 850 !important;
  letter-spacing: -0.01em !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* Células: todas iguais */
.rsv-cell {
  width: var(--tl-day-w) !important;
  min-width: var(--tl-day-w) !important;
  max-width: var(--tl-day-w) !important;
  min-height: 34px !important;
  padding: 0 !important;
  border-right: 1px solid #eef5f0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 750 !important;
  color: #17324d !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.rsv-row:last-child {
  border-bottom: 0 !important;
}

/* Cabeçalho dos dias */
.rsv-day-head {
  min-height: 50px !important;
  flex-direction: column !important;
  gap: 3px !important;
  background: #ffffff !important;
  position: relative !important;
  z-index: 2 !important;
}

.rsv-day-head b {
  font-size: 11px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  color: var(--tl-text) !important;
}

.rsv-day-head span {
  display: inline-flex !important;
  min-height: 12px !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 8px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .035em !important;
  color: #6b7f70 !important;
}

/* Hoje e previsão mais elegantes */
.rsv-cell.today {
  background: rgba(141,198,63,.18) !important;
  box-shadow:
    inset 0 0 0 2px rgba(141,198,63,.55),
    inset 0 999px 0 rgba(141,198,63,.04) !important;
}

.rsv-cell.future {
  background: rgba(245,250,255,.76) !important;
}

.rsv-cell.rsv-col-hover {
  background: rgba(141,198,63,.21) !important;
  box-shadow:
    inset 0 0 0 2px rgba(0,107,63,.24),
    inset 0 999px 0 rgba(141,198,63,.06) !important;
}

/* Linhas principais das doenças */
.tl-main-row .rsv-row-label {
  font-size: 12px !important;
  font-weight: 900 !important;
  background: #ffffff !important;
}

.tl-main-row .rsv-cell {
  min-height: 38px !important;
}

/* Sublinha técnica */
.rsv-subrow .rsv-row-label {
  padding-left: 18px !important;
  background: #fbfdfb !important;
  color: #21472f !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

.rsv-subrow .rsv-cell {
  min-height: 32px !important;
}

/* Pills alinhados e consistentes */
.rsv-pill {
  display: inline-block !important;
  width: 28px !important;
  min-width: 28px !important;
  max-width: 28px !important;
  height: 7px !important;
  min-height: 7px !important;
  max-height: 7px !important;
  border-radius: 999px !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}

/* Eventos vazios discretos */
.rsv-pill:not(.baixo):not(.moderado):not(.elevado):not(.condicao):not(.evento):not(.critico) {
  background: #fff !important;
  border: 1px solid #e1eee5 !important;
}

/* Cores limpas */
.rsv-pill.baixo,
.level-baixo {
  background: #16a34a !important;
}

.rsv-pill.moderado,
.level-moderado {
  background: #f2b300 !important;
}

.rsv-pill.elevado,
.level-elevado {
  background: #ef3340 !important;
}

.rsv-pill.condicao {
  background: #b8e2ef !important;
  border-color: #b8e2ef !important;
}

.rsv-pill.evento {
  background: #f4cd72 !important;
  border-color: #f4cd72 !important;
}

.rsv-pill.critico {
  background: #e99a22 !important;
  border-color: #e99a22 !important;
}

/* Gráfico climático: mesma coluna esquerda, chart respirável */
.rsv-climate-chart-row {
  display: grid !important;
  grid-template-columns: var(--tl-label-w) minmax(calc(var(--tl-days) * var(--tl-day-w)), 980px) !important;
  min-width: max-content !important;
  border-top: 1px solid var(--tl-border-strong) !important;
  border-bottom: 1px solid var(--tl-border-strong) !important;
  background: #ffffff !important;
}

.rsv-chart-legend {
  position: sticky !important;
  left: 0 !important;
  z-index: 6 !important;
  width: var(--tl-label-w) !important;
  min-width: var(--tl-label-w) !important;
  max-width: var(--tl-label-w) !important;
  background: #ffffff !important;
  border-right: 1px solid var(--tl-border-strong) !important;
  padding: 16px 14px !important;
}

.rsv-chart-legend h3 {
  margin: 0 0 13px 0 !important;
  color: var(--tl-green) !important;
  font-size: 14px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
}

.rsv-chart-legend span {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  margin: 9px 0 !important;
  color: #21472f !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
}

.rsv-chart-legend i {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

.rsv-chart-box {
  min-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  background:
    linear-gradient(90deg, transparent 0, transparent calc(100% - 31%),
      rgba(245,250,255,.76) calc(100% - 31%), rgba(245,250,255,.76) 100%),
    #ffffff !important;
}

/* SVG: consistente e elegante */
.rsv-tl-svg {
  display: block !important;
  width: 100% !important;
  min-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  height: 305px !important;
}

.rsv-tl-svg .grid {
  stroke: #eef5f0 !important;
  stroke-width: 1 !important;
}

.rsv-tl-svg .axis {
  stroke: #d8eadc !important;
  stroke-width: 1.5 !important;
}

.rsv-tl-svg .tmax {
  stroke: #ef3340 !important;
  stroke-width: 3.2 !important;
}

.rsv-tl-svg .tmed {
  stroke: #006b3f !important;
  stroke-width: 2.8 !important;
  stroke-dasharray: 7 4 !important;
}

.rsv-tl-svg .tmin {
  stroke: #1f6d99 !important;
  stroke-width: 2.8 !important;
}

.rsv-tl-svg .bar24 {
  fill: rgba(80,160,220,.52) !important;
}

.rsv-tl-svg .bar3 {
  fill: rgba(180,220,240,.58) !important;
}

.rsv-tl-svg .barleaf {
  fill: rgba(120,170,90,.72) !important;
}

.rsv-tl-svg .today-band {
  fill: rgba(141,198,63,.18) !important;
  stroke: rgba(141,198,63,.36) !important;
}

.rsv-tl-svg .future-band {
  fill: rgba(245,250,255,.76) !important;
}

.rsv-tl-svg .xlabel {
  fill: #52705c !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  font-variant-numeric: tabular-nums !important;
}

/* Tabela climática alinhada com a timeline */
.rsv-table-title {
  position: sticky !important;
  left: 0 !important;
  z-index: 6 !important;
  width: var(--tl-label-w) !important;
  min-width: var(--tl-label-w) !important;
  max-width: var(--tl-label-w) !important;
  padding: 12px 14px !important;
  background: #fbfdfb !important;
  color: var(--tl-green) !important;
  font-size: 14px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  border-right: 1px solid var(--tl-border-strong) !important;
  border-bottom: 1px solid var(--tl-border) !important;
}

/* Corrigir a tabela: mesmo grid da timeline */
.rsv-climate-table .rsv-row {
  grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
}

.rsv-climate-table .rsv-row-label {
  font-size: 11px !important;
  font-weight: 900 !important;
  color: var(--tl-text) !important;
  background: #ffffff !important;
}

.rsv-climate-table .rsv-cell {
  min-height: 31px !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
  font-weight: 750 !important;
  color: #17324d !important;
  white-space: nowrap !important;
  letter-spacing: -0.015em !important;
}

/* Zebra na tabela, mas sem estragar hoje/futuro */
.rsv-climate-table .rsv-row:nth-child(odd) .rsv-row-label,
.rsv-climate-table .rsv-row:nth-child(odd) .rsv-cell:not(.today):not(.future):not(.rsv-col-hover) {
  background: #fbfdfb !important;
}

.rsv-climate-table .rsv-row:nth-child(even) .rsv-row-label,
.rsv-climate-table .rsv-row:nth-child(even) .rsv-cell:not(.today):not(.future):not(.rsv-col-hover) {
  background: #ffffff !important;
}

/* Valores climáticos mais legíveis */
.rsv-climate-table .rsv-cell {
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

/* Scrollbar mais discreta */
.rsv-timeline-scroll::-webkit-scrollbar {
  height: 10px !important;
}

.rsv-timeline-scroll::-webkit-scrollbar-track {
  background: #f1f7f2 !important;
  border-radius: 999px !important;
}

.rsv-timeline-scroll::-webkit-scrollbar-thumb {
  background: #b9d7bf !important;
  border-radius: 999px !important;
  border: 2px solid #f1f7f2 !important;
}

.rsv-timeline-scroll::-webkit-scrollbar-thumb:hover {
  background: #8fc69b !important;
}

/* Em ecrãs pequenos, reduzir ligeiramente a largura das colunas */
@media (max-width: 900px) {
  .rsv-timeline-pro {
    --tl-label-w: 160px;
    --tl-day-w: 54px;
  }

  .rsv-row-label,
  .rsv-chart-legend,
  .rsv-table-title {
    width: var(--tl-label-w) !important;
    min-width: var(--tl-label-w) !important;
    max-width: var(--tl-label-w) !important;
  }

  .rsv-row {
    grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
  }

  .rsv-cell {
    width: var(--tl-day-w) !important;
    min-width: var(--tl-day-w) !important;
    max-width: var(--tl-day-w) !important;
  }
}

/* FIM RSVPro PHP - TIMELINE PRO POLISH FINAL */

/* ============================================================
   RSVPro PHP - TIMELINE UX PLUS FINAL
   Dias na tabela + drag horizontal + tooltip de gráfico + visual premium.
   ============================================================ */

/* Menos barras visíveis, mais interação por arrasto */
.rsv-timeline-scroll,
.rsv-modern-dayrail {
  cursor: grab !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(0,107,63,.25) transparent !important;
}

.rsv-timeline-scroll.is-dragging,
.rsv-modern-dayrail.is-dragging {
  cursor: grabbing !important;
  user-select: none !important;
}

.rsv-timeline-scroll::-webkit-scrollbar,
.rsv-modern-dayrail::-webkit-scrollbar {
  height: 7px !important;
}

.rsv-timeline-scroll::-webkit-scrollbar-track,
.rsv-modern-dayrail::-webkit-scrollbar-track {
  background: transparent !important;
}

.rsv-timeline-scroll::-webkit-scrollbar-thumb,
.rsv-modern-dayrail::-webkit-scrollbar-thumb {
  background: rgba(0,107,63,.22) !important;
  border-radius: 999px !important;
  border: 0 !important;
}

.rsv-timeline-scroll:hover::-webkit-scrollbar-thumb,
.rsv-modern-dayrail:hover::-webkit-scrollbar-thumb {
  background: rgba(0,107,63,.42) !important;
}

/* Cabeçalho de dias antes da tabela climática */
.rsv-climate-day-header {
  display: grid !important;
  grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
  min-width: max-content !important;
  border-top: 1px solid var(--tl-line) !important;
  border-bottom: 1px solid var(--tl-line) !important;
  background: #ffffff !important;
}

.rsv-climate-day-header .rsv-row-label {
  background: #f8fcf8 !important;
  color: #006b3f !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}

.rsv-climate-day-header .rsv-cell {
  min-height: 46px !important;
  background: #ffffff !important;
}

.rsv-climate-day-header .rsv-cell.today {
  background: rgba(141,198,63,.18) !important;
}

.rsv-climate-day-header .rsv-cell.future {
  background: rgba(245,250,255,.78) !important;
}

/* Título da tabela passa a ter subtítulo */
.rsv-table-title {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 3px !important;
}

.rsv-table-title span {
  display: block !important;
  color: #006b3f !important;
  font-size: 13.5px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.rsv-table-title small {
  display: block !important;
  color: #6b7f70 !important;
  font-size: 10px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
}

/* Gráfico mais moderno */
.rsv-climate-chart-row {
  border-top: 1px solid #dbeadd !important;
  border-bottom: 1px solid #dbeadd !important;
  background: #ffffff !important;
}

.rsv-chart-box {
  position: relative !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 18% 18%, rgba(141,198,63,.09), transparent 32%),
    linear-gradient(90deg, transparent 0, transparent 68%, rgba(245,250,255,.86) 68%, rgba(245,250,255,.86) 100%),
    linear-gradient(180deg,#ffffff 0%,#fbfdfb 100%) !important;
}

/* Tirar labels do eixo X do gráfico: já existem dias acima e na tabela */
.rsv-tl-svg .xlabel {
  display: none !important;
}

/* Linhas do gráfico mais suaves e modernas */
.rsv-tl-svg .tmax {
  stroke: #ef3340 !important;
  stroke-width: 3.4 !important;
  filter: drop-shadow(0 2px 2px rgba(239,51,64,.12)) !important;
}

.rsv-tl-svg .tmed {
  stroke: #006b3f !important;
  stroke-width: 3 !important;
  stroke-dasharray: 7 5 !important;
  filter: drop-shadow(0 2px 2px rgba(0,107,63,.10)) !important;
}

.rsv-tl-svg .tmin {
  stroke: #1f6d99 !important;
  stroke-width: 3 !important;
  filter: drop-shadow(0 2px 2px rgba(31,109,153,.10)) !important;
}

.rsv-tl-svg .bar24,
.rsv-tl-svg .bar3,
.rsv-tl-svg .barleaf {
  opacity: .86 !important;
}

/* Cursor vertical no gráfico */
.rsv-chart-cursor-modern {
  stroke: rgba(0,59,33,.42) !important;
  stroke-width: 2 !important;
  stroke-dasharray: 5 5 !important;
  pointer-events: none !important;
}

/* Tooltip moderno no gráfico */
.rsv-chart-tooltip-modern {
  position: absolute !important;
  z-index: 30 !important;
  width: 176px !important;
  padding: 11px 12px !important;
  border-radius: 14px !important;
  background: rgba(0,59,33,.94) !important;
  color: #ffffff !important;
  box-shadow: 0 16px 36px rgba(0,55,25,.28) !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transform: translateY(4px) scale(.98) !important;
  transition: opacity .12s ease, transform .12s ease !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.rsv-chart-tooltip-modern.show {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
}

.rsv-chart-tooltip-modern b {
  display: inline-block !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  margin-right: 6px !important;
}

.rsv-chart-tooltip-modern > span {
  display: inline-block !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 9px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
}

.rsv-chart-tooltip-modern div {
  display: flex !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin-top: 6px !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
}

.rsv-chart-tooltip-modern strong {
  color: rgba(255,255,255,.72) !important;
  font-weight: 800 !important;
}

.rsv-chart-tooltip-modern em {
  font-style: normal !important;
  font-weight: 900 !important;
  color: #ffffff !important;
}

/* Melhor foco quando se clica numa data */
.rsv-cell.rsv-col-focus {
  background: rgba(141,198,63,.25) !important;
  box-shadow: inset 0 0 0 2px rgba(0,107,63,.35) !important;
}

/* A tabela ganha mais leitura por colunas */
.rsv-climate-table .rsv-cell.rsv-col-focus,
.rsv-climate-table .rsv-cell.rsv-col-hover {
  background: rgba(141,198,63,.24) !important;
}

/* Para não parecer Excel antigo */
.rsv-climate-table .rsv-row {
  border-bottom: 1px solid rgba(226,239,228,.72) !important;
}

.rsv-climate-table .rsv-cell {
  font-size: 10.4px !important;
  font-weight: 760 !important;
}

.rsv-climate-table .rsv-row-label {
  color: #003b21 !important;
}

/* Pequena instrução visual */
.rsv-timeline-hint::before {
  content: "arraste com o rato · roda para deslocar · ";
  font-weight: 800 !important;
  color: #6b7f70 !important;
}

/* FIM RSVPro PHP - TIMELINE UX PLUS FINAL */

/* ============================================================
   RSVPro PHP - WHEEL FIX TIMELINE
   Roda normal: scroll vertical da página.
   Shift + roda ou arrastar: deslocamento horizontal da timeline.
   ============================================================ */

.rsv-timeline-hint::before {
  content: "arraste com o rato · Shift+roda para deslocar · " !important;
  font-weight: 800 !important;
  color: #6b7f70 !important;
}

/* A timeline continua arrastável, mas já não prende a roda normal */
.rsv-timeline-scroll,
.rsv-modern-dayrail {
  overscroll-behavior-x: contain !important;
  overscroll-behavior-y: auto !important;
}

/* FIM RSVPro PHP - WHEEL FIX TIMELINE */

/* ============================================================
   RSVPro PHP - FINAL SCROLL TODAY CSS
   Roda normal = scroll vertical.
   Arrastar com rato = scroll horizontal da timeline.
   Dia ATUAL = hoje real.
   ============================================================ */

/* Remover a régua de dias extra abaixo da legenda */
.rsv-modern-dayrail {
  display: none !important;
}

/* Texto de ajuda correto */
.rsv-timeline-hint {
  font-size: 0 !important;
}

.rsv-timeline-hint::before {
  content: "Arraste horizontalmente com o rato" !important;
  font-size: 10.5px !important;
  font-weight: 900 !important;
  color: #6b7f70 !important;
}

/* Timeline arrastável, mas roda normal fica vertical */
.rsv-timeline-scroll {
  cursor: grab !important;
  overscroll-behavior-x: contain !important;
  overscroll-behavior-y: auto !important;
}

.rsv-timeline-scroll.is-dragging {
  cursor: grabbing !important;
  user-select: none !important;
}

/* Barra discreta: existe, mas não domina */
.rsv-timeline-scroll::-webkit-scrollbar {
  height: 7px !important;
}

.rsv-timeline-scroll::-webkit-scrollbar-track {
  background: transparent !important;
}

.rsv-timeline-scroll::-webkit-scrollbar-thumb {
  background: rgba(0,107,63,.24) !important;
  border-radius: 999px !important;
}

.rsv-timeline-scroll:hover::-webkit-scrollbar-thumb {
  background: rgba(0,107,63,.45) !important;
}

/* Dia atual real mais evidente */
.rsv-cell.today {
  background: rgba(141,198,63,.22) !important;
  box-shadow: inset 0 0 0 2px rgba(141,198,63,.72) !important;
}

.rsv-day-head.today b {
  color: #003b21 !important;
}

.rsv-day-head.today span {
  color: #006b3f !important;
  font-weight: 900 !important;
}

/* FIM RSVPro PHP - FINAL SCROLL TODAY CSS */

/* ============================================================
   RSVPro PHP - REMOVE DAYRAIL FINAL
   Remove a barra extra de dias abaixo da legenda.
   Mantém apenas:
   - dias no cabeçalho da timeline
   - dias no cabeçalho da tabela climática
   ============================================================ */

.rsv-modern-dayrail {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
}

/* FIM RSVPro PHP - REMOVE DAYRAIL FINAL */

/* ============================================================
   RSVPro PHP - ALIGNED MODERN CHART CSS
   Todas as colunas usam a mesma largura.
   O gráfico é reconstruído com a mesma métrica visual.
   ============================================================ */

.rsv-timeline-pro {
  --tl-label-w: 220px !important;
  --tl-day-w: 64px !important;
  --tl-line: #dcebe0;
  --tl-line-soft: #edf5ef;
  --tl-green: #006b3f;
  --tl-dark: #003b21;
  --tl-muted: #5b7364;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

/* Remover definitivamente régua extra */
.rsv-modern-dayrail {
  display: none !important;
}

/* Grelha e tabela: largura única */
.rsv-row,
.rsv-climate-day-header,
.rsv-climate-table .rsv-row {
  display: grid !important;
  grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
  min-width: max-content !important;
}

.rsv-row-label,
.rsv-chart-legend,
.rsv-table-title,
.rsv-climate-day-header .rsv-row-label {
  width: var(--tl-label-w) !important;
  min-width: var(--tl-label-w) !important;
  max-width: var(--tl-label-w) !important;
  box-sizing: border-box !important;
}

.rsv-cell,
.rsv-climate-day-header .rsv-cell,
.rsv-climate-table .rsv-cell {
  width: var(--tl-day-w) !important;
  min-width: var(--tl-day-w) !important;
  max-width: var(--tl-day-w) !important;
  box-sizing: border-box !important;
}

/* Células mais calibradas */
.rsv-cell {
  padding: 0 !important;
  border-right: 1px solid #edf5ef !important;
  font-size: 10.6px !important;
  line-height: 1 !important;
  font-weight: 780 !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.rsv-day-head {
  min-height: 50px !important;
}

.rsv-day-head b {
  font-size: 10.8px !important;
  font-weight: 900 !important;
}

.rsv-day-head span {
  font-size: 8px !important;
  font-weight: 900 !important;
}

/* Hoje alinhado e claro em todas as linhas */
.rsv-cell.today {
  background: rgba(141,198,63,.22) !important;
  box-shadow: inset 0 0 0 2px rgba(141,198,63,.70) !important;
}

.rsv-cell.future {
  background: rgba(245,250,255,.78) !important;
}

.rsv-cell.rsv-col-focus,
.rsv-cell.rsv-col-hover {
  background: rgba(141,198,63,.25) !important;
  box-shadow: inset 0 0 0 2px rgba(0,107,63,.32) !important;
}

/* Gráfico novo: ocupa exatamente a largura dos dias */
.rsv-climate-chart-row {
  display: grid !important;
  grid-template-columns: var(--tl-label-w) calc(var(--tl-days) * var(--tl-day-w)) !important;
  min-width: max-content !important;
  border-top: 1px solid var(--tl-line) !important;
  border-bottom: 1px solid var(--tl-line) !important;
  background: #ffffff !important;
}

.rsv-chart-legend {
  position: sticky !important;
  left: 0 !important;
  z-index: 7 !important;
  background: #ffffff !important;
  border-right: 1px solid var(--tl-line) !important;
  padding: 18px 14px !important;
}

.rsv-chart-legend h3 {
  color: var(--tl-green) !important;
  font-size: 13.5px !important;
  line-height: 1.1 !important;
  margin: 0 0 14px 0 !important;
}

.rsv-chart-legend span {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 9px 0 !important;
  font-size: 10.6px !important;
  line-height: 1 !important;
  font-weight: 850 !important;
  color: #244a31 !important;
}

/* Palco do gráfico */
.rsv-chart-box {
  width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  min-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  max-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  background: #ffffff !important;
  overflow: visible !important;
  position: relative !important;
}

.rsv-modern-chart-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 12px 14px 0 14px !important;
  pointer-events: none !important;
}

.rsv-modern-chart-head b {
  display: block !important;
  color: var(--tl-dark) !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.rsv-modern-chart-head span {
  display: block !important;
  color: var(--tl-muted) !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  margin-top: 4px !important;
}

.rsv-modern-chart-head small {
  color: var(--tl-muted) !important;
  font-size: 10px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
}

.rsv-modern-chart-stage {
  position: relative !important;
  width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  min-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  height: 310px !important;
  overflow: hidden !important;
  background:
    radial-gradient(circle at 12% 12%, rgba(141,198,63,.10), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #fbfdfb 100%) !important;
}

.rsv-modern-chart-svg {
  display: block !important;
  width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  min-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  height: 310px !important;
}

.rsv-modern-chart-bg {
  fill: transparent !important;
}

.rsv-modern-grid {
  stroke: #edf5ef !important;
  stroke-width: 1 !important;
}

.rsv-modern-future-band {
  fill: rgba(245,250,255,.78) !important;
}

.rsv-modern-today-band {
  fill: rgba(141,198,63,.20) !important;
  stroke: rgba(141,198,63,.52) !important;
  stroke-width: 2 !important;
}

.rsv-modern-bar {
  filter: url(#rsvSoftShadow) !important;
}

.rsv-modern-bar-24 {
  fill: url(#rsvGradRain) !important;
}

.rsv-modern-bar-3 {
  fill: url(#rsvGradRain3) !important;
}

.rsv-modern-bar-leaf {
  fill: url(#rsvGradLeaf) !important;
}

.rsv-modern-line {
  fill: none !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  filter: url(#rsvSoftShadow) !important;
}

.rsv-modern-line-max {
  stroke: url(#rsvGradTmax) !important;
  stroke-width: 3.4 !important;
}

.rsv-modern-line-med {
  stroke: url(#rsvGradTmed) !important;
  stroke-width: 3 !important;
  stroke-dasharray: 8 5 !important;
}

.rsv-modern-line-min {
  stroke: url(#rsvGradTmin) !important;
  stroke-width: 3 !important;
}

.rsv-modern-point {
  stroke: #ffffff !important;
  stroke-width: 2 !important;
  filter: url(#rsvSoftShadow) !important;
}

.rsv-modern-point.max {
  fill: #ef3340 !important;
}

.rsv-modern-point.med {
  fill: #006b3f !important;
}

.rsv-modern-point.min {
  fill: #1f6d99 !important;
}

.rsv-modern-chart-cursor {
  stroke: rgba(0,59,33,.40) !important;
  stroke-width: 2 !important;
  stroke-dasharray: 5 5 !important;
  pointer-events: none !important;
}

/* Tooltip moderna do novo gráfico */
.rsv-modern-chart-tip {
  position: absolute !important;
  z-index: 40 !important;
  width: 190px !important;
  padding: 12px 13px !important;
  border-radius: 15px !important;
  background: rgba(0,59,33,.96) !important;
  color: #ffffff !important;
  box-shadow: 0 18px 42px rgba(0,55,25,.30) !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transform: translateY(4px) scale(.98) !important;
  transition: opacity .12s ease, transform .12s ease !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
}

.rsv-modern-chart-tip.show {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
}

.rsv-modern-chart-tip .tip-title {
  display: flex !important;
  align-items: baseline !important;
  gap: 7px !important;
  margin-bottom: 8px !important;
}

.rsv-modern-chart-tip .tip-title b {
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.rsv-modern-chart-tip .tip-title span {
  color: rgba(255,255,255,.72) !important;
  font-size: 9px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
}

.rsv-modern-chart-tip div:not(.tip-title) {
  display: flex !important;
  justify-content: space-between !important;
  gap: 10px !important;
  margin-top: 6px !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
}

.rsv-modern-chart-tip span {
  color: rgba(255,255,255,.72) !important;
  font-weight: 800 !important;
}

.rsv-modern-chart-tip strong {
  color: #ffffff !important;
  font-weight: 900 !important;
}

/* Esconder restos do SVG antigo se ainda ficarem */
.rsv-tl-svg {
  display: none !important;
}

/* Tabela climática alinhada */
.rsv-climate-day-header {
  grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
}

.rsv-climate-table .rsv-row {
  grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
}

.rsv-climate-table .rsv-cell {
  font-size: 10.3px !important;
  font-weight: 760 !important;
  letter-spacing: -0.015em !important;
  white-space: nowrap !important;
}

/* Em ecrã menor, mantém igual mas reduz ligeiramente */
@media (max-width: 900px) {
  .rsv-timeline-pro {
    --tl-label-w: 170px !important;
    --tl-day-w: 58px !important;
  }
}

/* FIM RSVPro PHP - ALIGNED MODERN CHART CSS */

/* ============================================================
   RSVPro PHP - GRAPH ALIGNMENT HARD FIX
   Faz o gráfico bater exatamente com as colunas da timeline/tabela.
   ============================================================ */

.rsv-timeline-pro {
  --tl-label-w: 220px !important;
  --tl-day-w: 64px !important;
}

/* Todas as linhas usam a mesma geometria */
.rsv-row,
.rsv-climate-day-header,
.rsv-climate-table .rsv-row {
  grid-template-columns: var(--tl-label-w) repeat(var(--tl-days), var(--tl-day-w)) !important;
}

/* Coluna esquerda igual em todos os blocos */
.rsv-row-label,
.rsv-chart-legend,
.rsv-table-title,
.rsv-climate-day-header .rsv-row-label {
  width: var(--tl-label-w) !important;
  min-width: var(--tl-label-w) !important;
  max-width: var(--tl-label-w) !important;
  box-sizing: border-box !important;
}

/* Cada dia tem exatamente a mesma largura */
.rsv-cell,
.rsv-climate-day-header .rsv-cell,
.rsv-climate-table .rsv-cell {
  width: var(--tl-day-w) !important;
  min-width: var(--tl-day-w) !important;
  max-width: var(--tl-day-w) !important;
  box-sizing: border-box !important;
}

/* A linha do gráfico usa a mesma primeira coluna + a mesma largura de dias */
.rsv-climate-chart-row {
  display: grid !important;
  grid-template-columns: var(--tl-label-w) calc(var(--tl-days) * var(--tl-day-w)) !important;
  min-width: max-content !important;
}

/* O palco do gráfico começa exatamente onde começa a primeira coluna de dia */
.rsv-chart-box,
.rsv-modern-chart-stage,
.rsv-modern-chart-svg {
  width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  min-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  max-width: calc(var(--tl-days) * var(--tl-day-w)) !important;
  margin: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
}

/* O cabeçalho interno do gráfico não pode deslocar o SVG */
.rsv-modern-chart-head {
  padding-left: 12px !important;
  padding-right: 12px !important;
  box-sizing: border-box !important;
}

/* O SVG antigo nunca deve ocupar espaço */
.rsv-tl-svg {
  display: none !important;
}

/* Título colapsável da tabela climática */
.rsv-table-title {
  padding: 7px 0 7px var(--tl-label-w, 210px);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: #52705c;
  border-top: 1px solid #e2efe4;
  background: #f6faf6;
  min-width: max-content;
  user-select: none;
}
.rsv-table-title:hover {
  background: #eef5ee;
}

/* Painel Lobesia — fora do scroll, largura de página */
.tl-detail-lobesia {
  width: 100%;
  box-sizing: border-box;
  background: #fff;
  border-top: 2px solid #d8eadc;
  margin-top: 4px;
}
.tl-detail-lobesia svg {
  display: block;
  width: 100%;
  height: auto;
}
/* Secções exteriores ao scroll */
.rsv-clima-exterior {
  margin-top: 4px;
}
.rsv-section-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 14px;
  background: #f6faf6;
  border-top: 1px solid #e2efe4;
  cursor: pointer;
  user-select: none;
  font-size: 12px;
}
.rsv-section-toggle:hover {
  background: #edf5ed;
}
.rsv-toggle-arrow {
  color: #52705c;
  font-size: 11px;
}
.rsv-section-body {
  display: block;
}

/* A faixa do dia atual deve ter o mesmo aspeto em timeline, gráfico e tabela */
.rsv-cell.today {
  background: rgba(141,198,63,.22) !important;
  box-shadow: inset 0 0 0 2px rgba(141,198,63,.70) !important;
}

/* FIM RSVPro PHP - GRAPH ALIGNMENT HARD FIX */

/* ============================================================
   RSVPro PHP - CLIMATE TABLE TITLE INLINE
   O título da tabela climática passa para a primeira célula da linha dos dias.
   ============================================================ */

.rsv-climate-title-inline {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
  gap: 3px !important;
  background: #f8fcf8 !important;
  color: #006b3f !important;
  padding: 0 14px !important;
}

.rsv-climate-title-inline span {
  display: block !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  color: #006b3f !important;
}

.rsv-climate-title-inline small {
  display: block !important;
  font-size: 10px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  color: #6b7f70 !important;
}

/* Remove a linha separada antiga da tabela climática */
.rsv-table-title {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* Garante que a linha dos dias da tabela fica com a mesma altura do cabeçalho principal */
.rsv-climate-day-header .rsv-cell,
.rsv-climate-day-header .rsv-row-label {
  min-height: 50px !important;
}

/* FIM RSVPro PHP - CLIMATE TABLE TITLE INLINE */

/* ============================================================
   RSVPro PHP - TIMELINE CLEAN READABILITY CSS
   Remove camadas repetidas e mantém leitura simples.
   ============================================================ */

/* Garantir que blocos premium/repetidos não aparecem */
.rsv-premium-diagnosis,
.rsv-modern-insights,
.rsv-column-reader,
.rsv-modern-dayrail {
  display: none !important;
}

/* Separadores simples, sem scores/bolhas */
.rsv-timeline-tabs button em {
  display: none !important;
}

/* Leitura rápida discreta */
.rsv-simple-reader {
  margin: 8px 0 8px !important;
  padding: 9px 12px !important;
  border: 1px solid #dcebe0 !important;
  border-radius: 14px !important;
  background: #f8fcf8 !important;
  color: #52705c !important;
  font-size: 11px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}

.rsv-simple-reader span {
  color: #006b3f !important;
  font-weight: 900 !important;
}

/* A interpretação por separador fica, mas compacta */
.rsv-tab-interpretation {
  margin: 8px 0 6px !important;
  padding: 9px 11px !important;
  border-radius: 13px !important;
  background: #ffffff !important;
  border: 1px solid #dcebe0 !important;
}

.rsv-tab-interpretation b {
  color: #006b3f !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}

.rsv-tab-interpretation span {
  color: #52705c !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

/* Timeline sem bloco enorme no topo */
.rsv-timeline-pro {
  padding-top: 15px !important;
}

/* FIM RSVPro PHP - TIMELINE CLEAN READABILITY CSS */

/* ============================================================
   RSVPro PHP - TECHNICAL REPORT CSS
   Relatório técnico automático depois da timeline.
   ============================================================ */

.rsv-technical-report-auto {
  margin-top: 16px !important;
  padding: 16px !important;
  border-radius: 22px !important;
  border: 1px solid #dcebe0 !important;
  background:
    radial-gradient(circle at top left, rgba(141,198,63,.16), transparent 280px),
    linear-gradient(180deg, #ffffff 0%, #f8fcf8 100%) !important;
  box-shadow: 0 12px 34px rgba(0,55,25,.07) !important;
}

.rsv-report-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 14px !important;
}

.rsv-report-head h2 {
  margin: 0 0 4px 0 !important;
  color: #003b21 !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  letter-spacing: -.03em !important;
}

.rsv-report-head p {
  margin: 0 !important;
  color: #52705c !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}

.rsv-report-badge {
  flex: 0 0 auto !important;
  border-radius: 999px !important;
  padding: 8px 12px !important;
  color: #ffffff !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  background: #006b3f !important;
}

.rsv-report-badge.baixo { background: #16a34a !important; }
.rsv-report-badge.moderado { background: #f2b300 !important; }
.rsv-report-badge.elevado { background: #ef3340 !important; }
.rsv-report-badge.neutro { background: #7d8b98 !important; }

.rsv-report-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.rsv-report-card {
  border: 1px solid #dcebe0 !important;
  border-radius: 17px !important;
  background: rgba(255,255,255,.92) !important;
  padding: 13px 14px !important;
  box-shadow: 0 8px 20px rgba(0,55,25,.045) !important;
  min-width: 0 !important;
}

.rsv-report-card.wide {
  grid-column: span 2 !important;
}

.rsv-report-card span {
  display: block !important;
  color: #006b3f !important;
  font-size: 10px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .045em !important;
  margin-bottom: 8px !important;
}

.rsv-report-card p {
  margin: 0 !important;
  color: #17324d !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
  font-weight: 760 !important;
}

.rsv-report-card ul,
.rsv-report-card ol {
  margin: 0 !important;
  padding-left: 18px !important;
  color: #17324d !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
  font-weight: 760 !important;
}

.rsv-report-card li {
  margin: 3px 0 !important;
}

.rsv-report-card b {
  color: #003b21 !important;
  font-weight: 900 !important;
}

.rsv-report-card.actions {
  background:
    linear-gradient(90deg, rgba(141,198,63,.10), rgba(255,255,255,.92)),
    #ffffff !important;
}

.rsv-report-card.note {
  background: #f8fcf8 !important;
}

.rsv-report-card.disease {
  position: relative !important;
  overflow: hidden !important;
}

.rsv-report-card.disease::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 4px !important;
  background: #8dc63f !important;
}

@media (max-width: 1200px) {
  .rsv-report-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .rsv-report-card.wide {
    grid-column: span 2 !important;
  }
}

@media (max-width: 760px) {
  .rsv-report-head {
    flex-direction: column !important;
  }

  .rsv-report-grid {
    grid-template-columns: 1fr !important;
  }

  .rsv-report-card.wide {
    grid-column: span 1 !important;
  }
}

/* FIM RSVPro PHP - TECHNICAL REPORT CSS */

/* ============================================================
   RSVPro PHP - REPORT CLEAN FINAL
   Esconde detalhe técnico/fontes e alinha doenças no relatório.
   ============================================================ */

/* Esconder blocos que não interessam ao utilizador final */
#detalhe,
.detail-panel,
.sources-panel,
.fontes-panel,
#fontes,
[data-section="fontes"],
[data-section="detalhe"] {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

/* Relatório: grelha mais lógica */
.rsv-report-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  align-items: stretch !important;
}

/* Linha 1 */
.rsv-report-grid > article:nth-of-type(1) {
  grid-column: 1 / span 2 !important;
  grid-row: 1 !important;
}

.rsv-report-grid > article:nth-of-type(2) {
  grid-column: 3 !important;
  grid-row: 1 !important;
}

/* Linha 2: fatores ocupa uma linha limpa */
.rsv-report-grid > article:nth-of-type(3) {
  grid-column: 1 / span 3 !important;
  grid-row: 2 !important;
}

/* Linha 3: doenças alinhadas */
.rsv-report-grid > article:nth-of-type(4),
.rsv-report-grid > article:nth-of-type(5),
.rsv-report-grid > article:nth-of-type(6) {
  grid-row: 3 !important;
  min-height: 170px !important;
}

.rsv-report-grid > article:nth-of-type(4) {
  grid-column: 1 !important;
}

.rsv-report-grid > article:nth-of-type(5) {
  grid-column: 2 !important;
}

.rsv-report-grid > article:nth-of-type(6) {
  grid-column: 3 !important;
}

/* Linha 4 */
.rsv-report-grid > article:nth-of-type(7) {
  grid-column: 1 / span 2 !important;
  grid-row: 4 !important;
}

.rsv-report-grid > article:nth-of-type(8) {
  grid-column: 3 !important;
  grid-row: 4 !important;
}

/* Doenças com aspeto igual e mais bonito */
.rsv-report-card.disease {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  min-height: 170px !important;
  background:
    linear-gradient(180deg, rgba(248,252,248,.95), rgba(255,255,255,.95)),
    #ffffff !important;
}

.rsv-report-card.disease span {
  margin-bottom: 9px !important;
}

.rsv-report-card.disease p {
  flex: 1 !important;
}

/* Dar um detalhe visual diferente às 3 doenças */
.rsv-report-grid > article:nth-of-type(4)::before {
  background: #ef3340 !important;
}

.rsv-report-grid > article:nth-of-type(5)::before {
  background: #f2b300 !important;
}

.rsv-report-grid > article:nth-of-type(6)::before {
  background: #8dc63f !important;
}

/* Remover espaço morto no fim da página */
.rsv-technical-report-auto {
  margin-bottom: 18px !important;
}

/* Responsivo */
@media (max-width: 1200px) {
  .rsv-report-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .rsv-report-grid > article:nth-of-type(1),
  .rsv-report-grid > article:nth-of-type(3),
  .rsv-report-grid > article:nth-of-type(7) {
    grid-column: 1 / span 2 !important;
  }

  .rsv-report-grid > article:nth-of-type(2),
  .rsv-report-grid > article:nth-of-type(4),
  .rsv-report-grid > article:nth-of-type(5),
  .rsv-report-grid > article:nth-of-type(6),
  .rsv-report-grid > article:nth-of-type(8) {
    grid-column: auto !important;
    grid-row: auto !important;
  }
}

@media (max-width: 760px) {
  .rsv-report-grid {
    grid-template-columns: 1fr !important;
  }

  .rsv-report-grid > article {
    grid-column: 1 !important;
    grid-row: auto !important;
  }
}

/* FIM RSVPro PHP - REPORT CLEAN FINAL */

/* ============================================================
   RSVPro PHP - MAP CLICK OLDSTYLE CSS
   Clique no mapa -> devolve 5 estações próximas.
   ============================================================ */

#rsvMap.rsv-map-old-click-ready {
  cursor: crosshair !important;
}

#rsvMapPointPanel,
.rsv-geo-panel,
.rsv-map-point-panel,
.rsv-geo-inline-note {
  display: none !important;
}

.rsv-map-nearest-old {
  margin-top: 10px !important;
  border: 1px solid #dcebe0 !important;
  border-radius: 18px !important;
  background: #ffffff !important;
  box-shadow: 0 8px 22px rgba(0,55,25,.045) !important;
  overflow: hidden !important;
}

.rsv-map-nearest-old .empty {
  padding: 13px 14px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  background: #f8fcf8 !important;
}

.rsv-map-nearest-old .empty.warn {
  background: #fff8e8 !important;
}

.rsv-map-nearest-old .empty b {
  color: #003b21 !important;
  font-size: 13px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
}

.rsv-map-nearest-old .empty span {
  color: #52705c !important;
  font-size: 11.5px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}

.rsv-map-nearest-old .head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 12px !important;
  padding: 13px 14px !important;
  border-bottom: 1px solid #e6f1e9 !important;
  background: #f8fcf8 !important;
}

.rsv-map-nearest-old .head span {
  display: block !important;
  color: #52705c !important;
  text-transform: uppercase !important;
  font-size: 9.5px !important;
  line-height: 1 !important;
  letter-spacing: .045em !important;
  font-weight: 900 !important;
  margin-bottom: 5px !important;
}

.rsv-map-nearest-old .head b {
  display: block !important;
  color: #003b21 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  font-variant-numeric: tabular-nums !important;
}

.rsv-map-nearest-old .head small {
  flex: 0 0 auto !important;
  color: #006b3f !important;
  background: #e9f7df !important;
  border-radius: 999px !important;
  padding: 7px 10px !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.rsv-map-nearest-old .cards {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 8px !important;
  padding: 10px !important;
}

.rsv-map-nearest-old article {
  border: 1px solid #dcebe0 !important;
  border-radius: 15px !important;
  background: #ffffff !important;
  padding: 10px !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 24px minmax(0,1fr) !important;
  gap: 7px !important;
  align-items: start !important;
}

.rsv-map-nearest-old article i {
  width: 24px !important;
  height: 24px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #e9f7df !important;
  color: #006b3f !important;
  font-style: normal !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.rsv-map-nearest-old article b {
  display: block !important;
  color: #003b21 !important;
  font-size: 11.5px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.rsv-map-nearest-old article span {
  display: block !important;
  color: #52705c !important;
  font-size: 10.3px !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
  margin-top: 3px !important;
}

.rsv-map-nearest-old p {
  margin: 0 !important;
  padding: 10px 14px 12px !important;
  border-top: 1px solid #e6f1e9 !important;
  color: #52705c !important;
  font-size: 10.7px !important;
  line-height: 1.35 !important;
  font-weight: 800 !important;
  background: #fbfdfb !important;
}

@media (max-width: 1300px) {
  .rsv-map-nearest-old .cards {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .rsv-map-nearest-old .head {
    flex-direction: column !important;
  }

  .rsv-map-nearest-old .cards {
    grid-template-columns: 1fr !important;
  }
}

/* FIM RSVPro PHP - MAP CLICK OLDSTYLE CSS */

/* RSVPRO_PHP_POINT_REAL_BLOCKS_CSS_V5_START */

/* esconder restos de versões anteriores */
#rsvpro-geo-click-panel,
.rsvpro-geo-click-panel,
.rsvpro-ponto-forecast-line {
  display: none !important;
}

/* apenas popup do ponto */
.rsvpro-point-popup .leaflet-popup-content-wrapper {
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(23, 50, 77, 0.18);
}

.rsvpro-point-popup .leaflet-popup-content {
  margin: 11px 13px;
  min-width: 225px;
}

.rsvpro-map-popup {
  color: #17324d;
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.3;
}

.rsvpro-map-popup-title {
  font-size: 14px;
  font-weight: 800;
  margin-bottom: 4px;
}

.rsvpro-map-popup-line {
  font-size: 12px;
  margin: 2px 0;
}

.rsvpro-map-popup-small {
  font-size: 11px;
  color: #667785;
  margin-top: 5px;
}

.rsvpro-map-popup-error {
  color: #b00020;
  font-size: 12px;
  font-weight: 700;
}

.rsvpro-map-popup-risks {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-top: 6px;
}

.rsvpro-map-popup-risks span {
  display: inline-block;
  padding: 3px 7px;
  border-radius: 999px;
  font-size: 12px;
  border: 1px solid #dbe5dc;
}

.rsvpro-map-popup-risks span.baixo {
  background: rgba(34, 164, 71, 0.12);
  border-color: rgba(34, 164, 71, 0.30);
}

.rsvpro-map-popup-risks span.moderado {
  background: rgba(240, 180, 0, 0.15);
  border-color: rgba(240, 180, 0, 0.35);
}

.rsvpro-map-popup-risks span.elevado {
  background: rgba(229, 57, 53, 0.12);
  border-color: rgba(229, 57, 53, 0.32);
}

/* RSVPRO_PHP_POINT_REAL_BLOCKS_CSS_V5_END */

/* RSVPRO_REMOVE_OLD_MENU_GUARD_V1_START */

/*
  Guarda residual: se alguma página ainda trouxer restos de menu antigo
  dentro do conteúdo, não aparece. A remoção principal é feita no PHP.
  Este bloco não mexe em larguras nem centra/descentra a página.
*/
.rsvpro-observadores-portado > header,
.rsvpro-observadores-portado > nav,
.rsvpro-observadores-portado > aside,
.rsvpro-observadores-portado > .header,
.rsvpro-observadores-portado > .navbar,
.rsvpro-observadores-portado > .topbar,
.rsvpro-observadores-portado > .menu,
.rsvpro-observadores-portado > .main-menu,
.rsvpro-observadores-portado > .menu-principal,
.rsvpro-observadores-portado > .mobile-header,
.rsvpro-observadores-portado > .bottom-nav,
[data-rsvpro-page="observadores"] > header,
[data-rsvpro-page="observadores"] > nav,
[data-rsvpro-page="observadores"] > aside,
[data-rsvpro-page="observadores"] > .header,
[data-rsvpro-page="observadores"] > .navbar,
[data-rsvpro-page="observadores"] > .topbar,
[data-rsvpro-page="observadores"] > .menu,
[data-rsvpro-page="observadores"] > .main-menu,
[data-rsvpro-page="observadores"] > .menu-principal,
[data-rsvpro-page="observadores"] > .mobile-header,
[data-rsvpro-page="observadores"] > .bottom-nav {
  display: none !important;
}

/* RSVPRO_REMOVE_OLD_MENU_GUARD_V1_END */

/* RSVPRO_PATCH_FINAL_SIDEBAR_APPSHELL_V11_START */

/*
  PATCH FINAL SIDEBAR/APPSHELL
  Diagnóstico real:
    .rsvphp-main > .app-shell > .main

  A sidebar está correta.
  O espaço vinha do .app-shell herdado/centrado.
*/

:root {
  --rsv-sidebar-w: 204px;
  --rsv-green-1: #0d5f2d;
  --rsv-green-2: #094822;
  --rsv-green-3: #063719;
  --rsv-blue: #17324d;
}

/* SIDEBAR */
.rsvphp-sidebar {
  position: fixed !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: var(--rsv-sidebar-w) !important;
  z-index: 2000 !important;
  overflow-y: auto !important;

  background:
    radial-gradient(circle at 20% 0%, rgba(141,198,63,0.25), transparent 34%),
    linear-gradient(180deg, var(--rsv-green-1) 0%, var(--rsv-green-2) 54%, var(--rsv-green-3) 100%) !important;

  color: #ffffff !important;
  border-right: 0 !important;
  box-shadow: 4px 0 16px rgba(6,55,25,0.24) !important;
}

/* LOGO */
.rsvphp-brand {
  min-height: 104px !important;
  padding: 16px 12px 13px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px !important;
  text-align: center !important;
  color: #ffffff !important;
  text-decoration: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.16) !important;
  background: linear-gradient(180deg, rgba(0,0,0,0.14), rgba(0,0,0,0.04)) !important;
}

.rsvphp-logo-img {
  display: block !important;
  width: 78% !important;
  max-width: 78% !important;
  min-width: 150px !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
}

.rsvphp-brand-copy {
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  line-height: 1.08 !important;
}

.rsvphp-brand-copy strong {
  color: #ffffff !important;
  font-size: 12.5px !important;
  font-weight: 900 !important;
}

.rsvphp-brand-copy small {
  margin-top: 2px !important;
  color: rgba(255,255,255,0.78) !important;
  font-size: 10px !important;
  font-weight: 850 !important;
  letter-spacing: .055em !important;
  text-transform: uppercase !important;
}

/* MENU */
.rsvphp-nav {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  padding: 13px 9px !important;
}

.rsvphp-nav-link {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  min-height: 40px !important;
  padding: 9px 10px !important;
  border-radius: 15px !important;
  color: rgba(255,255,255,0.94) !important;
  text-decoration: none !important;
  font-weight: 850 !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  background: rgba(255,255,255,0.075) !important;
  transition: background .16s ease, transform .16s ease, border-color .16s ease !important;
}

.rsvphp-nav-link:hover {
  transform: translateX(2px) !important;
  background: rgba(255,255,255,0.15) !important;
  border-color: rgba(255,255,255,0.25) !important;
}

.rsvphp-nav-link.active {
  background: #ffffff !important;
  color: var(--rsv-blue) !important;
  border-color: #ffffff !important;
  box-shadow: 0 10px 22px rgba(0,0,0,0.20) !important;
}

.rsvphp-nav-icon {
  width: 23px !important;
  min-width: 23px !important;
  height: 23px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,0.16) !important;
  color: #ffffff !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.rsvphp-nav-link.active .rsvphp-nav-icon {
  background: rgba(13,95,45,0.12) !important;
  color: var(--rsv-green-1) !important;
}

.rsvphp-nav-label {
  white-space: nowrap !important;
}

/* rsv-shell layout — dados.php usa rsv-main--dados */
.rsv-main--dados {
  padding: 0 !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
}

.rsv-main--dados > .app-shell {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 14px 24px 8px !important;
  box-sizing: border-box !important;
}

.rsv-main--dados > .app-shell > .main {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  box-sizing: border-box !important;
}

.rsv-main--dados > .app-shell > .main > .page-head:first-child {
  margin-top: 0 !important;
}

/* Legado — mantido por precaução mas já não usado */
.rsvphp-main {
  position: relative !important;
  padding: 0 !important;
  min-width: 0 !important;
  min-height: 100vh !important;
  box-sizing: border-box !important;
}

/* Conteúdo usa a largura disponível */
.rsvphp-main .dashboard-grid,
.rsvphp-main .forecast-panel,
.rsvphp-main .timeline-panel,
.rsvphp-main .rsv-timeline-pro {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

/* Qualquer barra antiga residual não ocupa espaço */
aside.sidebar,
.sidebar:not(.rsvphp-sidebar),
.side-menu:not(.rsvphp-nav) {
  display: none !important;
  width: 0 !important;
  min-width: 0 !important;
  max-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  position: absolute !important;
  left: -9999px !important;
}

/* Mobile */
@media (max-width: 820px) {
  .rsvphp-sidebar {
    position: sticky !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    box-shadow: none !important;
  }

  .rsvphp-main {
    margin-left: 0 !important;
    width: 100% !important;
  }

  .rsvphp-main > .app-shell {
    padding: 0 !important;
  }

  .rsvphp-logo-img {
    width: 145px !important;
    max-width: 145px !important;
    min-width: 0 !important;
  }

  .rsvphp-brand {
    min-height: 58px !important;
    padding: 9px 10px !important;
    flex-direction: row !important;
    align-items: center !important;
    text-align: left !important;
  }

  .rsvphp-nav {
    flex-direction: row !important;
    overflow-x: auto !important;
    gap: 6px !important;
    padding: 7px 8px 9px !important;
  }

  .rsvphp-nav-link {
    flex: 0 0 auto !important;
    min-height: 34px !important;
    padding: 7px 10px !important;
    font-size: 13px !important;
  }
}

/* RSVPRO_PATCH_FINAL_SIDEBAR_APPSHELL_V11_END */

/* RSVPRO_PUBLIC_OBS_ALERTAS_START */
.rsv-public-page{
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:22px;
  color:#17324d;
}
.rsv-public-page *{box-sizing:border-box;}
.rsv-public-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:22px;
  align-items:center;
  padding:24px;
  border:1px solid rgba(23,50,77,.10);
  border-radius:24px;
  background:radial-gradient(circle at top right, rgba(141,198,63,.22), transparent 36%), linear-gradient(135deg,#fff 0%,#f4faf1 100%);
  box-shadow:0 18px 45px rgba(23,50,77,.08);
  margin-bottom:18px;
}
.rsv-alertas-hero{
  background:radial-gradient(circle at top right, rgba(229,57,53,.13), transparent 34%), linear-gradient(135deg,#fff 0%,#f7fbf4 100%);
}
.rsv-public-hero h1{
  margin:6px 0 10px;
  font-size:clamp(1.75rem,3vw,2.55rem);
  line-height:1.05;
  letter-spacing:-.035em;
  color:#17324d;
}
.rsv-public-hero p{
  margin:0;
  max-width:850px;
  color:#496276;
  font-size:1rem;
  line-height:1.55;
}
.rsv-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:#4c8d2b;
  font-weight:800;
  font-size:.78rem;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.rsv-hero-actions,.rsv-photo-actions,.rsv-form-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.rsv-hero-actions{justify-content:flex-end;}
.rsv-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 16px;
  border-radius:999px;
  text-decoration:none;
  font-weight:800;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,background .15s ease;
}
.rsv-btn:hover{transform:translateY(-1px);text-decoration:none;}
.rsv-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.rsv-btn-primary{background:#17324d;color:#fff;box-shadow:0 12px 26px rgba(23,50,77,.18);}
.rsv-btn-secondary{background:#fff;color:#17324d;border-color:rgba(23,50,77,.16);}
.rsv-full-btn{width:100%;margin-top:14px;}
.rsv-stat-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:18px 0;
}
.rsv-stat-card{
  padding:18px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(23,50,77,.10);
  box-shadow:0 12px 30px rgba(23,50,77,.06);
}
.rsv-stat-card span{display:block;color:#607384;font-weight:800;font-size:.82rem;}
.rsv-stat-card strong{display:block;margin:7px 0 4px;color:#17324d;font-size:2rem;line-height:1;letter-spacing:-.04em;}
.rsv-stat-card small{color:#768899;}
.rsv-stat-alert{border-color:rgba(240,180,0,.32);background:linear-gradient(180deg,#fff,#fffaf0);}
.rsv-stat-danger{border-color:rgba(229,57,53,.26);background:linear-gradient(180deg,#fff,#fff4f3);}
.rsv-panel{
  background:#fff;
  border:1px solid rgba(23,50,77,.10);
  border-radius:24px;
  box-shadow:0 12px 34px rgba(23,50,77,.06);
  padding:18px;
}
.rsv-panel-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:14px;
}
.rsv-panel-head h2,.rsv-public-message h2{
  margin:4px 0 0;
  color:#17324d;
  line-height:1.15;
  letter-spacing:-.025em;
}
.rsv-soft-pill{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 10px;
  border-radius:999px;
  background:#eef6ea;
  color:#376f20;
  font-size:.8rem;
  font-weight:800;
  white-space:nowrap;
}
.rsv-public-map{
  position:relative;
  min-height:430px;
  overflow:hidden;
  border-radius:20px;
  border:1px solid rgba(23,50,77,.10);
  background:#eef4ea;
}
.rsv-map-fallback{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:#607384;
  font-weight:800;
  text-align:center;
  padding:20px;
}
.rsv-observer-layout{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);
  gap:16px;
  align-items:start;
}
.rsv-observer-form{display:grid;gap:18px;}
.rsv-form-block{
  padding:14px;
  border-radius:20px;
  background:#fbfdf8;
  border:1px solid rgba(141,198,63,.22);
}
.rsv-label,.rsv-full-label span,.rsv-form-grid label span,.rsv-alert-filters label span{
  display:block;
  margin-bottom:8px;
  color:#17324d;
  font-weight:900;
  font-size:.9rem;
}
.rsv-help{
  display:block;
  margin-top:8px;
  color:#697b8c;
  line-height:1.35;
}
.rsv-photo-preview{
  margin-top:12px;
  min-height:170px;
  display:grid;
  place-items:center;
  overflow:hidden;
  border-radius:18px;
  border:1px dashed rgba(23,50,77,.22);
  background:#fff;
  color:#607384;
  font-weight:800;
  text-align:center;
}
.rsv-photo-preview img{
  width:100%;
  height:260px;
  object-fit:cover;
  display:block;
}
.rsv-location-status{
  margin:12px 0;
  padding:10px 12px;
  border-radius:14px;
  background:#eef6ea;
  color:#376f20;
  font-weight:800;
}
.rsv-observer-map{min-height:360px;}
.rsv-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.rsv-input{
  width:100%;
  min-height:42px;
  border-radius:14px;
  border:1px solid rgba(23,50,77,.18);
  background:#fff;
  color:#17324d;
  padding:9px 12px;
  outline:none;
  font:inherit;
}
.rsv-input:focus{border-color:#8dc63f;box-shadow:0 0 0 4px rgba(141,198,63,.18);}
.rsv-textarea{resize:vertical;min-height:110px;}
.rsv-consent{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:10px;
  align-items:start;
  padding:14px;
  border-radius:18px;
  background:#f7fbf4;
  border:1px solid rgba(141,198,63,.28);
  color:#496276;
  line-height:1.4;
}
.rsv-consent input{margin-top:3px;}
.rsv-form-errors{
  padding:12px 14px;
  border-radius:16px;
  background:#fff1f0;
  color:#9a1f1a;
  border:1px solid #ffc7c2;
  font-weight:800;
}
.rsv-observer-result{
  padding:14px;
  border-radius:18px;
  background:#eef6ea;
  border:1px solid rgba(141,198,63,.35);
  color:#17324d;
}
.rsv-observer-result pre{
  white-space:pre-wrap;
  margin:10px 0 0;
  padding:12px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(23,50,77,.10);
}
.rsv-info-list{display:grid;gap:12px;}
.rsv-info-list div{
  padding:12px;
  border-radius:18px;
  background:#f7fbf4;
  border:1px solid rgba(141,198,63,.24);
}
.rsv-info-list strong{display:block;color:#17324d;margin-bottom:4px;}
.rsv-info-list span{display:block;color:#5f7181;line-height:1.35;}
.rsv-observer-warning{
  margin-top:16px;
  padding:14px;
  border-radius:18px;
  background:#fffaf0;
  border:1px solid rgba(240,180,0,.35);
  color:#614700;
}
.rsv-observer-warning strong{display:block;margin-bottom:4px;color:#17324d;}
.rsv-public-message{margin:18px 0;border-left:6px solid #8dc63f;}
.rsv-public-message p{margin:8px 0 0;color:#526579;line-height:1.55;}
.rsv-alert-filters{
  display:grid;
  grid-template-columns:220px 220px minmax(260px,1fr);
  gap:12px;
  align-items:end;
}
.rsv-alert-list{display:grid;gap:12px;margin:18px 0;}
.rsv-alert-card{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:center;
  padding:18px;
  border-radius:22px;
  background:#fff;
  border:1px solid rgba(23,50,77,.10);
  box-shadow:0 12px 30px rgba(23,50,77,.06);
}
.rsv-alert-card.rsv-alert-elevado{border-color:rgba(229,57,53,.32);background:linear-gradient(180deg,#fff,#fff6f5);}
.rsv-alert-card.rsv-alert-moderado{border-color:rgba(240,180,0,.35);background:linear-gradient(180deg,#fff,#fffaf0);}
.rsv-alert-title{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.rsv-alert-title h2{margin:0;color:#17324d;line-height:1.15;}
.rsv-alert-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  padding:6px 10px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.rsv-alert-badge-elevado{background:#e53935;color:#fff;}
.rsv-alert-badge-moderado{background:#f0b400;color:#17324d;}
.rsv-alert-main p{margin:0 0 10px;color:#526579;line-height:1.48;}
.rsv-alert-meta{display:flex;flex-wrap:wrap;gap:8px 14px;color:#697b8c;font-size:.9rem;}
.rsv-alert-actions{display:flex;justify-content:flex-end;}
.rsv-data-note{display:flex;align-items:center;gap:8px;color:#526579;margin-top:18px;}
.rsv-empty-state{text-align:center;padding:28px;}
.rsv-empty-state h2{margin:0 0 8px;}
.rsv-empty-state p{margin:0;color:#607384;}
@media (max-width:980px){
  .rsv-public-page{padding:14px;}
  .rsv-public-hero,.rsv-observer-layout,.rsv-alert-card{grid-template-columns:1fr;}
  .rsv-hero-actions,.rsv-alert-actions{justify-content:flex-start;}
  .rsv-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .rsv-alert-filters{grid-template-columns:1fr;}
}
@media (max-width:620px){
  .rsv-public-hero{padding:18px;border-radius:20px;}
  .rsv-stat-grid,.rsv-form-grid{grid-template-columns:1fr;}
  .rsv-public-map,.rsv-observer-map{min-height:330px;}
  .rsv-panel-head{flex-direction:column;}
  .rsv-data-note{align-items:flex-start;flex-direction:column;}
}
/* RSVPRO_PUBLIC_OBS_ALERTAS_END */

/* RSVPRO_PUBLIC_PAGES_DADOS_LAYOUT_START */
/*
  Alinhamento visual das páginas públicas novas com dados.php.
  Não mexe no header, menu, dados.php, JSONs, motor, SQL, pipeline ou FTP.
*/

.rsv-public-page.rsv-dados-compatible-page{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:16px 18px 28px 8px !important;
  color:#17324d;
}

.rsv-public-page.rsv-dados-compatible-page > section:first-child{
  margin-top:0 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero{
  margin:0 0 14px 0 !important;
  padding:18px 20px !important;
  border-radius:18px !important;
  border:1px solid rgba(23,50,77,.10) !important;
  background:linear-gradient(135deg,#ffffff 0%,#f7fbf4 100%) !important;
  box-shadow:0 8px 24px rgba(23,50,77,.06) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero h1{
  margin:4px 0 8px 0 !important;
  font-size:clamp(1.55rem,2.2vw,2.15rem) !important;
  letter-spacing:-.025em !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero p{
  max-width:920px !important;
  font-size:.96rem !important;
  line-height:1.48 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-grid{
  margin:14px 0 !important;
  gap:12px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card,
.rsv-public-page.rsv-dados-compatible-page .rsv-panel,
.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card,
.rsv-public-page.rsv-dados-compatible-page .rsv-form-block,
.rsv-public-page.rsv-dados-compatible-page .rsv-info-list div{
  border-radius:16px !important;
  box-shadow:0 6px 20px rgba(23,50,77,.055) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel{
  padding:16px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel-head{
  margin-bottom:12px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel-head h2{
  font-size:1.18rem !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-eyebrow{
  color:#4c8d2b !important;
  font-size:.74rem !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn{
  min-height:38px !important;
  padding:8px 14px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-layout{
  grid-template-columns:minmax(0,1.45fr) minmax(300px,.55fr) !important;
  gap:14px !important;
  align-items:start !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-map,
.rsv-public-page.rsv-dados-compatible-page .rsv-public-map{
  border-radius:16px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-list{
  margin:14px 0 !important;
  gap:10px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card{
  padding:15px 16px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-title{
  margin-bottom:6px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-main p{
  margin-bottom:8px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-message{
  margin:14px 0 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-input{
  min-height:39px !important;
  border-radius:12px !important;
}

main.rsv-public-page.rsv-dados-compatible-page{
  margin-left:0 !important;
  justify-self:start !important;
  align-self:start !important;
}

body .rsv-public-page.rsv-dados-compatible-page{
  justify-self:start !important;
  align-self:start !important;
}

@media (max-width:980px){
  .rsv-public-page.rsv-dados-compatible-page{
    padding:12px !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-public-hero,
  .rsv-public-page.rsv-dados-compatible-page .rsv-observer-layout,
  .rsv-public-page.rsv-dados-compatible-page .rsv-alert-card{
    grid-template-columns:1fr !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-hero-actions,
  .rsv-public-page.rsv-dados-compatible-page .rsv-alert-actions{
    justify-content:flex-start !important;
  }
}

@media (max-width:620px){
  .rsv-public-page.rsv-dados-compatible-page{
    padding:10px !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-public-hero{
    padding:15px !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-stat-grid,
  .rsv-public-page.rsv-dados-compatible-page .rsv-form-grid{
    grid-template-columns:1fr !important;
  }
}
/* RSVPRO_PUBLIC_PAGES_DADOS_LAYOUT_END */

/* RSVPRO_PUBLIC_PAGES_VISUAL_DADOS_START */
/*
  RSVPro PHP - linha gráfica compatível com dados.php
  Aplicado apenas às páginas públicas novas:
  observadores.php e alertas.php, via .rsv-dados-compatible-page
*/

.rsv-public-page.rsv-dados-compatible-page{
  --rsv-azul:#17324d;
  --rsv-azul-2:#214866;
  --rsv-verde:#8dc63f;
  --rsv-verde-2:#4c8d2b;
  --rsv-fundo:#f4f8f1;
  --rsv-card:#ffffff;
  --rsv-borda:#dbe7d4;
  --rsv-texto:#17324d;
  --rsv-muted:#607384;
  --rsv-amarelo:#f0b400;
  --rsv-vermelho:#e53935;

  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:14px 18px 28px 8px !important;
  color:var(--rsv-texto) !important;
  background:transparent !important;
}

/* HERO no estilo operacional, menos “landing page” e mais painel RSVPro */
.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  gap:14px !important;
  align-items:center !important;
  margin:0 0 14px 0 !important;
  padding:16px 18px !important;
  border-radius:16px !important;
  border:1px solid var(--rsv-borda) !important;
  background:
    linear-gradient(90deg, rgba(23,50,77,.97) 0%, rgba(23,50,77,.92) 42%, rgba(76,141,43,.92) 100%) !important;
  color:#fff !important;
  box-shadow:0 8px 22px rgba(23,50,77,.11) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero h1{
  margin:4px 0 7px 0 !important;
  color:#fff !important;
  font-size:clamp(1.45rem,2.15vw,2rem) !important;
  line-height:1.08 !important;
  letter-spacing:-.025em !important;
  font-weight:900 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero p{
  max-width:980px !important;
  margin:0 !important;
  color:rgba(255,255,255,.88) !important;
  font-size:.95rem !important;
  line-height:1.45 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero .rsv-eyebrow{
  color:#dff4c3 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero .rsv-btn-primary{
  background:#fff !important;
  color:var(--rsv-azul) !important;
  border-color:#fff !important;
  box-shadow:none !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero .rsv-btn-secondary{
  background:rgba(255,255,255,.12) !important;
  color:#fff !important;
  border-color:rgba(255,255,255,.36) !important;
}

/* Tipografia e etiquetas */
.rsv-public-page.rsv-dados-compatible-page .rsv-eyebrow{
  color:var(--rsv-verde-2) !important;
  font-size:.72rem !important;
  letter-spacing:.08em !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
}

.rsv-public-page.rsv-dados-compatible-page h2{
  color:var(--rsv-azul) !important;
  font-weight:900 !important;
}

/* Cartões de métricas no estilo da página de dados */
.rsv-public-page.rsv-dados-compatible-page .rsv-stat-grid{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:10px !important;
  margin:12px 0 14px 0 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card{
  min-height:96px !important;
  padding:14px 15px !important;
  border-radius:14px !important;
  background:var(--rsv-card) !important;
  border:1px solid var(--rsv-borda) !important;
  box-shadow:0 4px 14px rgba(23,50,77,.055) !important;
  position:relative !important;
  overflow:hidden !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card::before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  bottom:0 !important;
  width:5px !important;
  background:var(--rsv-verde) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card.rsv-stat-alert::before{
  background:var(--rsv-amarelo) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card.rsv-stat-danger::before{
  background:var(--rsv-vermelho) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card span{
  color:var(--rsv-muted) !important;
  font-size:.78rem !important;
  font-weight:900 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card strong{
  color:var(--rsv-azul) !important;
  font-size:1.85rem !important;
  margin:6px 0 3px !important;
  font-weight:900 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card small{
  color:#7a8b9a !important;
}

/* Painéis */
.rsv-public-page.rsv-dados-compatible-page .rsv-panel,
.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card,
.rsv-public-page.rsv-dados-compatible-page .rsv-form-block,
.rsv-public-page.rsv-dados-compatible-page .rsv-info-list div{
  background:#fff !important;
  border:1px solid var(--rsv-borda) !important;
  border-radius:14px !important;
  box-shadow:0 4px 16px rgba(23,50,77,.055) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel{
  padding:15px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel-head{
  margin-bottom:11px !important;
  padding-bottom:9px !important;
  border-bottom:1px solid rgba(219,231,212,.72) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel-head h2{
  margin-top:3px !important;
  font-size:1.12rem !important;
  letter-spacing:-.015em !important;
}

/* Botões RSVPro */
.rsv-public-page.rsv-dados-compatible-page .rsv-btn{
  min-height:38px !important;
  padding:8px 14px !important;
  border-radius:12px !important;
  font-weight:900 !important;
  box-shadow:none !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn-primary{
  background:var(--rsv-azul) !important;
  color:#fff !important;
  border-color:var(--rsv-azul) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn-primary:hover{
  background:#0f253a !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn-secondary{
  background:#f8fbf5 !important;
  color:var(--rsv-azul) !important;
  border-color:var(--rsv-borda) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-soft-pill{
  min-height:28px !important;
  padding:5px 9px !important;
  border-radius:999px !important;
  background:#eef6e7 !important;
  color:#376f20 !important;
  border:1px solid rgba(141,198,63,.32) !important;
  font-size:.76rem !important;
  font-weight:900 !important;
}

/* Formulário observadores */
.rsv-public-page.rsv-dados-compatible-page .rsv-observer-layout{
  grid-template-columns:minmax(0,1.5fr) minmax(300px,.5fr) !important;
  gap:12px !important;
  align-items:start !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-form{
  gap:13px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-form-block{
  padding:13px !important;
  background:#fbfdf8 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-label,
.rsv-public-page.rsv-dados-compatible-page .rsv-full-label span,
.rsv-public-page.rsv-dados-compatible-page .rsv-form-grid label span,
.rsv-public-page.rsv-dados-compatible-page .rsv-alert-filters label span{
  color:var(--rsv-azul) !important;
  font-size:.84rem !important;
  font-weight:900 !important;
  margin-bottom:6px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-input{
  min-height:39px !important;
  border-radius:10px !important;
  border:1px solid #ccd9c5 !important;
  background:#fff !important;
  color:var(--rsv-azul) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-input:focus{
  border-color:var(--rsv-verde) !important;
  box-shadow:0 0 0 3px rgba(141,198,63,.18) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-photo-preview{
  border-radius:12px !important;
  min-height:145px !important;
  background:#fff !important;
  border:1px dashed #b7c8ae !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-photo-preview img{
  height:220px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-location-status{
  border-radius:10px !important;
  background:#eef6e7 !important;
  border:1px solid rgba(141,198,63,.32) !important;
  color:#376f20 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-consent{
  border-radius:12px !important;
  background:#fbfdf8 !important;
  border:1px solid var(--rsv-borda) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-warning{
  border-radius:12px !important;
  background:#fff8df !important;
  border:1px solid rgba(240,180,0,.38) !important;
}

/* Mapas */
.rsv-public-page.rsv-dados-compatible-page .rsv-public-map,
.rsv-public-page.rsv-dados-compatible-page .rsv-observer-map{
  border-radius:14px !important;
  border:1px solid var(--rsv-borda) !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.55) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-map{
  min-height:335px !important;
}

/* Alertas */
.rsv-public-page.rsv-dados-compatible-page .rsv-alert-filters{
  grid-template-columns:210px 210px minmax(260px,1fr) !important;
  gap:10px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-list{
  margin:12px 0 !important;
  gap:10px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card{
  padding:14px 15px !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  border-left:6px solid var(--rsv-amarelo) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card.rsv-alert-elevado{
  background:#fff8f7 !important;
  border-color:#f3c8c5 !important;
  border-left-color:var(--rsv-vermelho) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card.rsv-alert-moderado{
  background:#fffaf0 !important;
  border-color:#f3df9a !important;
  border-left-color:var(--rsv-amarelo) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-title{
  margin-bottom:6px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-title h2{
  font-size:1.08rem !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-badge{
  min-height:26px !important;
  padding:5px 9px !important;
  border-radius:999px !important;
  font-size:.72rem !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-badge-elevado{
  background:var(--rsv-vermelho) !important;
  color:#fff !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-badge-moderado{
  background:var(--rsv-amarelo) !important;
  color:var(--rsv-azul) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-main p{
  color:#526579 !important;
  line-height:1.43 !important;
  margin-bottom:8px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-meta{
  color:#687b8a !important;
  font-size:.86rem !important;
}

/* Mensagem pública */
.rsv-public-page.rsv-dados-compatible-page .rsv-public-message{
  margin:12px 0 !important;
  border-left:6px solid var(--rsv-verde) !important;
  background:#fff !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-data-note{
  border-radius:14px !important;
  background:#fbfdf8 !important;
}

/* Alinhamento junto à sidebar */
main.rsv-public-page.rsv-dados-compatible-page{
  margin-left:0 !important;
  justify-self:start !important;
  align-self:start !important;
}

body .rsv-public-page.rsv-dados-compatible-page{
  justify-self:start !important;
  align-self:start !important;
}

/* Responsivo */
@media (max-width:980px){
  .rsv-public-page.rsv-dados-compatible-page{
    padding:12px !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-public-hero,
  .rsv-public-page.rsv-dados-compatible-page .rsv-observer-layout,
  .rsv-public-page.rsv-dados-compatible-page .rsv-alert-card{
    grid-template-columns:1fr !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-hero-actions,
  .rsv-public-page.rsv-dados-compatible-page .rsv-alert-actions{
    justify-content:flex-start !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-stat-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-alert-filters{
    grid-template-columns:1fr !important;
  }
}

@media (max-width:620px){
  .rsv-public-page.rsv-dados-compatible-page{
    padding:10px !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-public-hero{
    padding:14px !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-stat-grid,
  .rsv-public-page.rsv-dados-compatible-page .rsv-form-grid{
    grid-template-columns:1fr !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-observer-map{
    min-height:300px !important;
  }
}
/* RSVPRO_PUBLIC_PAGES_VISUAL_DADOS_END */

/* RSVPRO_PUBLIC_GREEN_VISUAL_START */
/*
  RSVPro PHP - visual verde funcional para Observadores e Alertas.
  Mantém a linha visual da barra verde escura e da página dados.
  Só afeta páginas com .rsv-dados-compatible-page.
*/

.rsv-public-page.rsv-dados-compatible-page{
  --rsv-dark:#064520;
  --rsv-dark-2:#0b5a2b;
  --rsv-green:#8dc63f;
  --rsv-green-soft:#eef8e8;
  --rsv-border:#d7e7d4;
  --rsv-bg:#f5faf1;
  --rsv-card:#ffffff;
  --rsv-text:#07351f;
  --rsv-muted:#536b5c;
  --rsv-warn:#f0b400;
  --rsv-danger:#d93b32;

  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:16px 18px 28px 10px !important;
  color:var(--rsv-text) !important;
  background:linear-gradient(180deg,#f8fbf4 0%,#ffffff 38%) !important;
}

/* A página deve parecer painel funcional, não landing page */
.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  gap:14px !important;
  align-items:start !important;
  margin:0 0 12px 0 !important;
  padding:0 0 10px 0 !important;
  border:0 !important;
  border-bottom:1px solid var(--rsv-border) !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  color:var(--rsv-text) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero h1{
  margin:0 0 4px 0 !important;
  color:var(--rsv-text) !important;
  font-size:clamp(1.45rem,2vw,2rem) !important;
  line-height:1.08 !important;
  letter-spacing:-.025em !important;
  font-weight:900 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero p{
  max-width:980px !important;
  margin:0 !important;
  color:var(--rsv-muted) !important;
  font-size:.95rem !important;
  line-height:1.38 !important;
  font-weight:700 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-hero .rsv-eyebrow{
  color:var(--rsv-dark-2) !important;
  background:#fff !important;
  border:1px solid var(--rsv-border) !important;
  border-radius:999px !important;
  padding:7px 10px !important;
  font-size:.68rem !important;
  letter-spacing:.05em !important;
  align-self:start !important;
}

/* Botões como na imagem: verde principal e branco com borda */
.rsv-public-page.rsv-dados-compatible-page .rsv-btn{
  min-height:38px !important;
  padding:8px 14px !important;
  border-radius:10px !important;
  font-weight:900 !important;
  box-shadow:none !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn-primary{
  background:var(--rsv-dark-2) !important;
  color:#fff !important;
  border:1px solid var(--rsv-dark-2) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn-primary:hover{
  background:var(--rsv-dark) !important;
  color:#fff !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn-secondary{
  background:#fff !important;
  color:var(--rsv-dark-2) !important;
  border:1px solid #bdd8b9 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-btn-secondary:hover{
  background:var(--rsv-green-soft) !important;
}

/* Painéis brancos suaves, como formulário da imagem */
.rsv-public-page.rsv-dados-compatible-page .rsv-panel,
.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card,
.rsv-public-page.rsv-dados-compatible-page .rsv-form-block,
.rsv-public-page.rsv-dados-compatible-page .rsv-info-list div{
  background:rgba(255,255,255,.96) !important;
  border:1px solid var(--rsv-border) !important;
  border-radius:16px !important;
  box-shadow:0 8px 24px rgba(7,53,31,.07) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel{
  padding:16px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel-head{
  margin-bottom:12px !important;
  padding-bottom:8px !important;
  border-bottom:1px solid rgba(215,231,212,.85) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-panel-head h2{
  margin:0 !important;
  font-size:1.08rem !important;
  color:var(--rsv-text) !important;
  font-weight:900 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-eyebrow{
  color:var(--rsv-dark-2) !important;
  font-size:.72rem !important;
  font-weight:900 !important;
  letter-spacing:.06em !important;
}

/* Layout observadores igual ao aspeto da imagem */
.rsv-public-page.rsv-dados-compatible-page .rsv-observer-layout{
  grid-template-columns:minmax(0,1.18fr) minmax(360px,.82fr) !important;
  gap:14px !important;
  align-items:start !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-form{
  gap:12px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-form-block{
  padding:13px !important;
  background:#fff !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-label,
.rsv-public-page.rsv-dados-compatible-page .rsv-full-label span,
.rsv-public-page.rsv-dados-compatible-page .rsv-form-grid label span,
.rsv-public-page.rsv-dados-compatible-page .rsv-alert-filters label span{
  color:#476454 !important;
  font-size:.74rem !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
  letter-spacing:.04em !important;
  margin-bottom:6px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-input{
  min-height:40px !important;
  border-radius:12px !important;
  border:1px solid #cadfca !important;
  background:#fff !important;
  color:var(--rsv-text) !important;
  font-weight:800 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-input:focus{
  border-color:var(--rsv-green) !important;
  box-shadow:0 0 0 3px rgba(141,198,63,.18) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-textarea{
  min-height:105px !important;
}

/* Foto */
.rsv-public-page.rsv-dados-compatible-page .rsv-photo-preview{
  margin-top:10px !important;
  min-height:132px !important;
  border-radius:14px !important;
  background:#fff !important;
  border:1px dashed #aacdac !important;
  color:var(--rsv-muted) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-photo-preview img{
  height:210px !important;
  object-fit:cover !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-help{
  color:#6f806f !important;
  font-weight:700 !important;
}

/* Localização */
.rsv-public-page.rsv-dados-compatible-page .rsv-location-status{
  margin:10px 0 !important;
  padding:9px 11px !important;
  border-radius:12px !important;
  background:#fff7e0 !important;
  color:#6d4d00 !important;
  border:1px solid #f2d081 !important;
  font-weight:900 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-public-map,
.rsv-public-page.rsv-dados-compatible-page .rsv-observer-map{
  border-radius:14px !important;
  border:1px solid var(--rsv-border) !important;
  background:#eef8e8 !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.55) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-map{
  min-height:320px !important;
}

/* Consentimento e avisos */
.rsv-public-page.rsv-dados-compatible-page .rsv-consent{
  border-radius:14px !important;
  background:#f9fcf7 !important;
  border:1px solid var(--rsv-border) !important;
  color:var(--rsv-text) !important;
  font-weight:800 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-warning{
  border-radius:14px !important;
  background:#fff7e0 !important;
  border:1px solid #f2d081 !important;
  color:#6d4d00 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-observer-warning strong{
  color:var(--rsv-text) !important;
}

/* Nota lateral: cards pequenos */
.rsv-public-page.rsv-dados-compatible-page .rsv-info-list{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:10px !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-info-list div{
  padding:12px !important;
  box-shadow:none !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-info-list strong{
  color:#476454 !important;
  font-size:.7rem !important;
  text-transform:uppercase !important;
  letter-spacing:.04em !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-info-list span{
  color:var(--rsv-text) !important;
  font-weight:900 !important;
}

/* Alertas: mesma linha visual, risco destacado */
.rsv-public-page.rsv-dados-compatible-page .rsv-stat-grid{
  gap:10px !important;
  margin:12px 0 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card{
  border-radius:14px !important;
  background:#fff !important;
  border:1px solid var(--rsv-border) !important;
  box-shadow:0 6px 18px rgba(7,53,31,.06) !important;
  position:relative !important;
  overflow:hidden !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card::before{
  content:"" !important;
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  bottom:0 !important;
  width:5px !important;
  background:var(--rsv-green) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card.rsv-stat-alert::before{
  background:var(--rsv-warn) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card.rsv-stat-danger::before{
  background:var(--rsv-danger) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card span{
  color:#476454 !important;
  font-size:.72rem !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-stat-card strong{
  color:var(--rsv-text) !important;
  font-weight:900 !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card{
  border-left:6px solid var(--rsv-warn) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card.rsv-alert-elevado{
  background:#fff7f6 !important;
  border-color:#f0c2bf !important;
  border-left-color:var(--rsv-danger) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-card.rsv-alert-moderado{
  background:#fffaf0 !important;
  border-color:#eedb98 !important;
  border-left-color:var(--rsv-warn) !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-badge-elevado{
  background:var(--rsv-danger) !important;
  color:#fff !important;
}

.rsv-public-page.rsv-dados-compatible-page .rsv-alert-badge-moderado{
  background:var(--rsv-warn) !important;
  color:var(--rsv-text) !important;
}

/* Mensagem pública */
.rsv-public-page.rsv-dados-compatible-page .rsv-public-message{
  border-left:6px solid var(--rsv-green) !important;
  background:#fff !important;
}

/* Alinhamento junto à sidebar */
main.rsv-public-page.rsv-dados-compatible-page{
  margin-left:0 !important;
  justify-self:start !important;
  align-self:start !important;
}

/* Responsivo */
@media (max-width:980px){
  .rsv-public-page.rsv-dados-compatible-page{
    padding:12px !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-public-hero,
  .rsv-public-page.rsv-dados-compatible-page .rsv-observer-layout,
  .rsv-public-page.rsv-dados-compatible-page .rsv-alert-card{
    grid-template-columns:1fr !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-hero-actions,
  .rsv-public-page.rsv-dados-compatible-page .rsv-alert-actions{
    justify-content:flex-start !important;
  }

  .rsv-public-page.rsv-dados-compatible-page .rsv-info-list,
  .rsv-public-page.rsv-dados-compatible-page .rsv-stat-grid,
  .rsv-public-page.rsv-dados-compatible-page .rsv-form-grid{
    grid-template-columns:1fr !important;
  }
}
/* RSVPRO_PUBLIC_GREEN_VISUAL_END */

/* RSVPRO_ALERTAS_DASHBOARD_V2_START */
/*
  RSVPro - Alertas Dashboard V2
  Linha gráfica igual à página dados/alertas pública:
  verde escuro, cartões suaves, mapa + tabela no lado esquerdo.
*/

.za-alertas-dashboard{
  --za-dark:#063f20;
  --za-dark-2:#075429;
  --za-green:#8dc63f;
  --za-green-soft:#eef8e7;
  --za-bg:#f4faed;
  --za-card:#ffffff;
  --za-border:#d7e8d2;
  --za-text:#062f1a;
  --za-muted:#536c5d;
  --za-red:#ef3340;
  --za-yellow:#f4b400;
  --za-blue:#2b8fff;

  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:18px 20px 34px 18px !important;
  color:var(--za-text) !important;
  background:linear-gradient(135deg,#f8fbf2 0%,#eef7e6 42%,#ffffff 100%) !important;
}

.za-alertas-titlebar{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  margin:0 0 16px 0;
}

.za-alertas-titlebar h1{
  margin:0;
  color:var(--za-text);
  font-size:clamp(1.55rem,2.2vw,2.2rem);
  line-height:1.05;
  letter-spacing:-.035em;
  font-weight:950;
}

.za-alertas-titlebar p{
  margin:5px 0 0;
  color:#466153;
  font-size:.96rem;
  font-weight:850;
}

.za-alertas-date-pills{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.za-date-pill{
  min-width:136px;
  padding:10px 14px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--za-border);
  box-shadow:0 6px 18px rgba(6,63,32,.07);
}

.za-date-pill span{
  display:block;
  color:#62796a;
  font-size:.68rem;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.za-date-pill strong{
  display:block;
  color:var(--za-text);
  font-size:.95rem;
  margin-top:2px;
  font-weight:950;
}

.za-alertas-top-grid{
  display:grid;
  grid-template-columns:minmax(0,1.65fr) minmax(340px,.85fr);
  gap:14px;
  margin-bottom:14px;
}

.za-alertas-hero-card,
.za-alertas-priority-card,
.za-alertas-map-table-card,
.za-side-card,
.za-alert-stat{
  background:rgba(255,255,255,.96);
  border:1px solid var(--za-border);
  border-radius:18px;
  box-shadow:0 10px 26px rgba(6,63,32,.075);
}

.za-alertas-hero-card{
  padding:28px 28px 24px;
}

.za-priority-pill{
  display:inline-flex;
  align-items:center;
  width:max-content;
  padding:7px 13px;
  border-radius:999px;
  background:var(--za-red);
  color:#fff;
  font-size:.76rem;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.04em;
  margin-bottom:16px;
}

.za-alertas-hero-card h2{
  margin:0;
  color:var(--za-text);
  font-size:clamp(2.3rem,4vw,3.55rem);
  line-height:.96;
  letter-spacing:-.055em;
  font-weight:950;
}

.za-alertas-hero-card p{
  margin:16px 0 0;
  color:#395849;
  max-width:900px;
  font-weight:850;
  font-size:1.02rem;
  line-height:1.45;
}

.za-alertas-hero-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:20px;
}

.za-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 18px;
  border-radius:11px;
  font-weight:950;
  text-decoration:none;
  border:1px solid transparent;
  cursor:pointer;
  font-size:.92rem;
}

.za-btn-primary{
  background:var(--za-dark-2);
  color:#fff;
  box-shadow:0 8px 18px rgba(6,63,32,.14);
}

.za-btn-secondary{
  background:#fff;
  color:var(--za-dark-2);
  border-color:#bad8b7;
}

.za-alertas-priority-card{
  padding:16px;
  display:grid;
  gap:12px;
}

.za-alertas-priority-card div{
  padding:14px;
  border:1px solid #dfece0;
  border-radius:14px;
  background:#fff;
}

.za-alertas-priority-card strong{
  display:block;
  color:var(--za-text);
  font-size:.98rem;
  font-weight:950;
  margin-bottom:4px;
}

.za-alertas-priority-card span{
  display:block;
  color:#4f6a5b;
  font-weight:850;
  line-height:1.35;
}

.za-alertas-stat-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin-bottom:14px;
}

.za-alert-stat{
  position:relative;
  min-height:118px;
  padding:16px;
}

.za-alert-stat .za-dot{
  position:absolute;
  right:16px;
  top:18px;
  width:12px;
  height:12px;
  border-radius:50%;
}

.za-dot-red{background:var(--za-red);}
.za-dot-yellow{background:var(--za-yellow);}
.za-dot-green{background:#13a15a;}

.za-alert-stat span{
  display:block;
  color:var(--za-text);
  font-size:.95rem;
  font-weight:950;
  margin-bottom:8px;
}

.za-alert-stat strong{
  display:block;
  color:var(--za-text);
  font-size:2.1rem;
  font-weight:950;
  line-height:1;
  margin-bottom:8px;
}

.za-alert-stat small{
  display:block;
  color:#4f6a5b;
  font-weight:850;
  line-height:1.35;
}

.za-alertas-main-grid{
  display:grid;
  grid-template-columns:minmax(620px,1.25fr) minmax(360px,.75fr);
  gap:14px;
  align-items:start;
}

.za-alertas-map-table-card,
.za-side-card{
  padding:16px;
}

.za-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
}

.za-card-head h2{
  margin:0;
  color:var(--za-text);
  font-size:1.08rem;
  font-weight:950;
}

.za-card-head p,
.za-card-head span{
  margin:3px 0 0;
  color:#607568;
  font-size:.78rem;
  font-weight:900;
}

.za-alertas-map{
  position:relative;
  height:320px;
  overflow:hidden;
  border-radius:14px;
  border:1px solid #cfe1ca;
  background:#dfeede;
}

.za-map-loading{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  font-weight:950;
  color:#4f6a5b;
}

.za-map-legend{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:center;
  margin:10px 0 12px;
  color:#4f6a5b;
  font-size:.76rem;
  font-weight:950;
}

.za-map-legend span{
  display:inline-flex;
  align-items:center;
  gap:5px;
}

.za-legend-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  display:inline-block;
}

.za-red{background:var(--za-red);}
.za-yellow{background:var(--za-yellow);}
.za-green{background:#13a15a;}
.za-blue{background:var(--za-blue);}

.za-alertas-table-wrap{
  overflow:auto;
  border-radius:14px;
  border:1px solid #dfece0;
  background:#fff;
}

.za-alertas-table{
  width:100%;
  border-collapse:collapse;
  min-width:760px;
}

.za-alertas-table th{
  text-align:left;
  padding:10px 12px;
  color:var(--za-text);
  font-size:.72rem;
  font-weight:950;
  text-transform:uppercase;
  background:#f8fbf5;
  border-bottom:1px solid #dfece0;
}

.za-alertas-table td{
  padding:10px 12px;
  border-bottom:1px solid #edf3ea;
  color:var(--za-text);
  font-size:.84rem;
  font-weight:850;
  vertical-align:middle;
}

.za-alertas-table tr:last-child td{
  border-bottom:0;
}

.za-station-name strong{
  display:block;
  color:var(--za-text);
  font-weight:950;
}

.za-station-name span{
  display:block;
  color:#607568;
  font-size:.75rem;
  margin-top:1px;
}

.za-risk-pill{
  display:inline-flex;
  min-width:68px;
  justify-content:center;
  padding:4px 8px;
  border-radius:999px;
  font-size:.62rem;
  font-weight:950;
  text-transform:uppercase;
}

.za-risk-elevado{background:var(--za-red);color:#fff;}
.za-risk-moderado{background:var(--za-yellow);color:var(--za-text);}
.za-risk-baixo{background:#13a15a;color:#fff;}
.za-risk-sem-dados{background:#e8eee6;color:#607568;}

.za-open-buttons{
  display:flex;
  gap:6px;
}

.za-mini-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 8px;
  border-radius:8px;
  border:1px solid #bad8b7;
  color:var(--za-dark-2);
  background:#fff;
  text-decoration:none;
  font-size:.7rem;
  font-weight:950;
  white-space:nowrap;
}

.za-alertas-side{
  display:grid;
  gap:14px;
}

.za-alertas-filters{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  margin-bottom:12px;
}

.za-alertas-filters input,
.za-alertas-filters select{
  width:100%;
  min-height:40px;
  border-radius:11px;
  border:1px solid #cfe1ca;
  background:#fff;
  color:var(--za-text);
  font-weight:900;
  padding:8px 12px;
  outline:none;
}

.za-alertas-filters input:focus,
.za-alertas-filters select:focus{
  border-color:var(--za-green);
  box-shadow:0 0 0 3px rgba(141,198,63,.18);
}

.za-alertas-side-list{
  display:grid;
  gap:8px;
  max-height:460px;
  overflow:auto;
  padding-right:4px;
}

.za-side-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
  padding:10px 11px;
  border:1px solid #dfece0;
  border-radius:12px;
  background:#fff;
}

.za-side-row strong{
  display:block;
  color:var(--za-text);
  font-size:.86rem;
  font-weight:950;
}

.za-side-row span{
  display:block;
  color:#607568;
  font-size:.72rem;
  margin-top:2px;
  font-weight:850;
}

.za-side-badges{
  display:flex;
  gap:4px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.za-mini-empty{
  padding:16px;
  border-radius:12px;
  border:1px dashed #cfe1ca;
  background:#fff;
  color:#607568;
  font-weight:900;
}

.za-actions-card{
  background:#fff !important;
}

.za-action-list{
  display:grid;
  gap:10px;
}

.za-action-list div{
  display:grid;
  grid-template-columns:34px 1fr;
  column-gap:10px;
  align-items:start;
  padding:12px;
  border:1px solid #dfece0;
  border-radius:13px;
  background:#fff;
}

.za-action-list i{
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:var(--za-green-soft);
  color:var(--za-dark-2);
  font-style:normal;
  font-weight:950;
}

.za-action-list strong{
  display:block;
  color:var(--za-text);
  font-weight:950;
  margin-bottom:3px;
}

.za-action-list span{
  display:block;
  color:#4f6a5b;
  font-size:.82rem;
  font-weight:850;
  line-height:1.35;
  grid-column:2;
}

@media (max-width:1180px){
  .za-alertas-top-grid,
  .za-alertas-main-grid{
    grid-template-columns:1fr;
  }

  .za-alertas-main-grid{
    display:flex;
    flex-direction:column;
  }

  .za-alertas-map-table-card{
    order:1;
  }

  .za-alertas-side{
    order:2;
  }
}

@media (max-width:760px){
  .za-alertas-dashboard{
    padding:12px !important;
  }

  .za-alertas-titlebar{
    flex-direction:column;
  }

  .za-alertas-date-pills{
    width:100%;
    justify-content:flex-start;
  }

  .za-date-pill{
    flex:1;
  }

  .za-alertas-stat-grid{
    grid-template-columns:1fr 1fr;
  }

  .za-alertas-hero-card h2{
    font-size:2.2rem;
  }

  .za-alertas-map{
    height:280px;
  }
}

@media (max-width:520px){
  .za-alertas-stat-grid{
    grid-template-columns:1fr;
  }

  .za-alertas-hero-actions{
    flex-direction:column;
  }

  .za-btn{
    width:100%;
  }
}
/* RSVPRO_ALERTAS_DASHBOARD_V2_END */


/* RSVPRO_EMERGENCY_MOBILE_CSS_START */
/* RSVPro PHP - emergency mobile app shell */
:root{
  --rsv-e-green:#075429;
  --rsv-e-dark:#063f20;
  --rsv-e-lime:#8dc63f;
  --rsv-e-bg:#f4faed;
  --rsv-e-top:64px;
  --rsv-e-bottom:76px;
}

#rsvEmergencyTopbar,
#rsvEmergencyBottomNav{
  display:none;
}

@media (max-width:820px){

  html,
  body{
    width:100% !important;
    max-width:100% !important;
    overflow-x:hidden !important;
    background:var(--rsv-e-bg) !important;
  }

  body.rsv-emergency-mobile-ready{
    padding-top:calc(var(--rsv-e-top) + env(safe-area-inset-top,0px)) !important;
    padding-bottom:calc(var(--rsv-e-bottom) + env(safe-area-inset-bottom,0px)) !important;
  }

  .rsv-kill-on-mobile{
    display:none !important;
    visibility:hidden !important;
    width:0 !important;
    min-width:0 !important;
    max-width:0 !important;
    height:0 !important;
    min-height:0 !important;
    overflow:hidden !important;
  }

  body :is(aside,nav,header,div,section)[class*="sidebar"]:not(#rsvEmergencyTopbar):not(#rsvEmergencyBottomNav):not(.rsv-shell):not(.rsv-main),
  body :is(aside,nav,header,div,section)[class*="side"]:not(#rsvEmergencyTopbar):not(#rsvEmergencyBottomNav):not(.rsv-shell):not(.rsv-main),
  body :is(aside,nav,header,div,section)[id*="sidebar"]:not(#rsvEmergencyTopbar):not(#rsvEmergencyBottomNav):not(.rsv-shell):not(.rsv-main),
  body :is(aside,nav,header,div,section)[id*="side"]:not(#rsvEmergencyTopbar):not(#rsvEmergencyBottomNav):not(.rsv-shell):not(.rsv-main){
    display:none !important;
  }

  body :is(aside,nav,header,div,section):has(a[href*="dados.php"]):has(a[href*="observadores.php"]):not(main *):not(#rsvEmergencyTopbar):not(#rsvEmergencyBottomNav):not(.rsv-shell):not(.rsv-main):not(.rsv-main--dados):not(.rsv-mobile-app-bottom):not(.rsv-mobile-app-topbar){
    display:none !important;
  }

  #rsvEmergencyTopbar{
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:2147483000;
    height:calc(var(--rsv-e-top) + env(safe-area-inset-top,0px));
    padding-top:env(safe-area-inset-top,0px);
    display:flex !important;
    align-items:center;
    background:linear-gradient(135deg,#075429,#063f20);
    box-shadow:0 10px 24px rgba(4,38,19,.22);
  }

  .rsv-emergency-brand{
    width:100%;
    min-width:0;
    display:flex;
    align-items:center;
    gap:10px;
    padding:8px 14px;
    color:#fff;
    text-decoration:none;
  }

  .rsv-emergency-brand img{
    width:112px;
    max-height:38px;
    object-fit:contain;
    flex:0 0 auto;
  }

  .rsv-emergency-brand span{
    min-width:0;
    display:block;
  }

  .rsv-emergency-brand b{
    display:block;
    font-size:.95rem;
    line-height:1;
    font-weight:950;
  }

  .rsv-emergency-brand small{
    display:block;
    margin-top:3px;
    font-size:.68rem;
    line-height:1;
    color:rgba(255,255,255,.76);
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  #rsvEmergencyBottomNav{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    z-index:2147483000;
    height:calc(var(--rsv-e-bottom) + env(safe-area-inset-bottom,0px));
    padding:7px 8px calc(7px + env(safe-area-inset-bottom,0px));
    display:grid !important;
    grid-template-columns:repeat(4,1fr);
    gap:7px;
    background:rgba(255,255,255,.97);
    border-top:1px solid rgba(6,63,32,.12);
    box-shadow:0 -12px 26px rgba(4,38,19,.16);
  }

  .rsv-emergency-navitem{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    min-width:0;
    min-height:58px;
    gap:3px;
    border-radius:17px;
    text-decoration:none;
    color:#627568;
    font-weight:950;
    font-size:.68rem;
    line-height:1;
    border:1px solid transparent;
  }

  .rsv-emergency-navitem.active{
    color:#07351f;
    background:rgba(141,198,63,.28);
    border-color:rgba(141,198,63,.38);
  }

  .rsv-emergency-icon{
    display:grid;
    place-items:center;
    width:26px;
    height:26px;
  }

  .rsv-emergency-icon svg{
    width:24px;
    height:24px;
    display:block;
    fill:currentColor;
  }

  .rsv-emergency-label{
    display:block;
    max-width:100%;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  body.rsv-emergency-mobile-ready main,
  body.rsv-emergency-mobile-ready .main,
  body.rsv-emergency-mobile-ready .main-content,
  body.rsv-emergency-mobile-ready .page-content,
  body.rsv-emergency-mobile-ready .content,
  body.rsv-emergency-mobile-ready .content-area,
  body.rsv-emergency-mobile-ready .app-main,
  body.rsv-emergency-mobile-ready .rsv-main{
    width:100% !important;
    max-width:100% !important;
    margin:0 !important;
    padding-left:10px !important;
    padding-right:10px !important;
    box-sizing:border-box !important;
  }

  body.rsv-emergency-mobile-ready .app-shell,
  body.rsv-emergency-mobile-ready .rsv-shell,
  body.rsv-emergency-mobile-ready .layout,
  body.rsv-emergency-mobile-ready .page-layout,
  body.rsv-emergency-mobile-ready .dashboard-layout,
  body.rsv-emergency-mobile-ready .php-layout,
  body.rsv-emergency-mobile-ready .app-layout,
  body.rsv-emergency-mobile-ready [class*="layout"]{
    display:block !important;
    grid-template-columns:1fr !important;
    width:100% !important;
    max-width:100% !important;
    margin:0 !important;
  }

  main[data-rsv-page],
  .za-access-page,
  .za-alertas-clean,
  .za-page,
  .rsv-public-page{
    width:100% !important;
    max-width:100% !important;
    padding:10px !important;
    margin:0 !important;
    border-radius:0 !important;
  }

  .za-access-hero,
  .za-alertas-clean-top,
  .za-main-clean,
  .za-highlight,
  .za-app-card,
  .za-grid-3,
  .za-grid-4,
  .za-process,
  .za-stat-grid-clean,
  .main-grid,
  .content-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
  }

  .za-card,
  .za-card-clean,
  .za-link-card,
  .za-app-card,
  .za-logo-card,
  .za-panel-clean,
  .za-priority-clean,
  .za-stat-clean,
  .risk-card,
  .day-card,
  .map-card,
  .current-card,
  .recommend-card{
    border-radius:16px !important;
  }

  a,
  button,
  input,
  select,
  textarea{
    font-size:16px !important;
  }

  button,
  .za-btn,
  .za-btn-clean,
  .rsv-btn,
  .rsv-obs-map-toggle{
    min-height:42px !important;
    padding-top:8px !important;
    padding-bottom:8px !important;
  }

  .za-btn,
  .za-btn-clean,
  .rsv-btn{
    width:auto !important;
    max-width:100% !important;
  }

  .za-actions,
  .za-contact-actions{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:8px !important;
  }

  .za-map-clean,
  #ahMap{
    height:280px !important;
    min-height:280px !important;
  }

  .leaflet-container{
    touch-action:pan-x pan-y;
  }

  .za-table-wrap-clean,
  .table-responsive,
  [class*="table-wrap"],
  .rsv-timeline-pro{
    max-width:100% !important;
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch;
  }
}

@media (max-width:390px){
  .rsv-emergency-brand img{width:96px;}
  .rsv-emergency-brand b{font-size:.88rem;}
  .rsv-emergency-brand small{font-size:.62rem;}
  .rsv-emergency-navitem{font-size:.61rem;}
}
/* RSVPRO_EMERGENCY_MOBILE_CSS_END */

/* ================================================================
   RSVPro Design System v2 — Consistência visual dados.php
   Unifica a linguagem visual com as páginas agr
   ================================================================ */

/* Fonte Manrope (disponível via rsvpro-layout.css) */
body,
.page-head h1, .page-head p,
.risk-card, .day-card, .metrics-row,
.top-selector, .updated-box,
.panel-title-row h2, .current-title-row h2,
.forecast-title-row h2, .rsv-timeline-pro-head h2,
.info-grid, .recommend-card {
  font-family: 'Manrope', Arial, Helvetica, sans-serif !important;
}

/* ── Cards base ───────────────────────────────────────── */
.map-card,
.current-card,
.forecast-panel,
.timeline-panel,
.detail-panel,
.info-grid article,
.recommend-card {
  border: 1.5px solid #d7e8d2 !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 18px rgba(6,63,32,.07) !important;
}

/* ── Títulos de secção ────────────────────────────────── */
.panel-title-row h2,
.current-title-row h2,
.forecast-title-row h2,
.rsv-timeline-pro-head h2,
.detail-panel h2 {
  font-size: 1rem !important;
  font-weight: 900 !important;
  letter-spacing: -.03em !important;
  color: #062f1a !important;
}
.panel-title-row span {
  font-size: .7rem !important;
  font-weight: 900 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
  color: #536c5d !important;
}

/* ── Cartões de risco ─────────────────────────────────── */
.risk-card {
  min-height: 0 !important;
  border: 1.5px solid #d7e8d2 !important;
  border-top-width: 3px !important;
  border-radius: 14px !important;
  padding: 14px 14px 12px !important;
  background: #fff !important;
}
.risk-card.baixo    { border-top-color: #16a34a !important; }
.risk-card.moderado { border-top-color: #d97706 !important; border-color: #fde68a !important; background: #fffbeb !important; }
.risk-card.elevado  { border-top-color: #dc2626 !important; border-color: #fecaca !important; background: #fff5f5 !important; }

.risk-top h3 {
  font-size: .88rem !important;
  font-weight: 900 !important;
  color: #062f1a !important;
  letter-spacing: -.02em !important;
}
.risk-top strong {
  font-size: .65rem !important;
  font-weight: 900 !important;
  padding: 3px 9px !important;
  letter-spacing: .04em !important;
  border-radius: 99px !important;
}
.risk-card p {
  font-size: .75rem !important;
  color: #536c5d !important;
  line-height: 1.3 !important;
  margin: 0 0 10px !important;
}
.bars { gap: 4px !important; }
.bars i { height: 4px !important; }

/* ── Métricas observadas ─────────────────────────────── */
.metrics-row div {
  border: 1.5px solid #d7e8d2 !important;
  border-radius: 10px !important;
  min-width: 82px !important;
  padding: 7px 9px !important;
}
.metrics-row span {
  font-size: .6rem !important;
  color: #536c5d !important;
  letter-spacing: .04em !important;
}
.metrics-row b {
  font-size: .82rem !important;
  color: #062f1a !important;
}

/* ── Cartões de previsão ─────────────────────────────── */
.day-card {
  min-height: 0 !important;
  border: 1.5px solid #d7e8d2 !important;
  border-radius: 12px !important;
  padding: 10px 9px 12px !important;
  background: #fff !important;
}
.day-card.today {
  border-color: #86efac !important;
  background: #f0fdf4 !important;
}
.day-title {
  font-size: .78rem !important;
  font-weight: 900 !important;
  color: #062f1a !important;
  letter-spacing: -.01em !important;
}
.day-date {
  font-size: .66rem !important;
  color: #536c5d !important;
  font-weight: 700 !important;
  margin-top: 2px !important;
}
.day-values {
  font-size: .7rem !important;
  color: #374151 !important;
  margin-bottom: 6px !important;
  line-height: 1.3 !important;
}
.day-values b {
  font-size: .78rem !important;
  font-weight: 900 !important;
  color: #062f1a !important;
  display: block !important;
  margin-bottom: 2px !important;
}
.mini-risks div {
  font-size: .68rem !important;
  color: #374151 !important;
  font-weight: 800 !important;
}
.mini-risks strong {
  font-size: .62rem !important;
  padding: 2px 7px !important;
  font-weight: 900 !important;
  border-radius: 99px !important;
}
.forecast-strip { gap: 8px !important; }
.legend-risk { font-size: .72rem !important; }
.legend-risk i { width: 12px !important; height: 3px !important; }

/* ── Secções inferiores ──────────────────────────────── */
.info-grid h3, .recommend-card h3 {
  font-size: .88rem !important;
  font-weight: 900 !important;
  color: #062f1a !important;
  letter-spacing: -.02em !important;
  margin: 0 0 6px !important;
}
.info-grid p, .recommend-card p {
  font-size: .78rem !important;
  color: #374151 !important;
  line-height: 1.35 !important;
}
.info-grid a {
  background: #075429 !important;
  border-radius: 10px !important;
  font-size: .75rem !important;
  font-weight: 900 !important;
  height: 34px !important;
  margin-top: 10px !important;
}

/* ── Mapa e controlos ────────────────────────────────── */
#rsvMap {
  border: 1.5px solid #d7e8d2 !important;
  border-radius: 12px !important;
}
.map-legend {
  border: 1.5px solid #d7e8d2 !important;
  border-radius: 10px !important;
  font-size: .7rem !important;
}
.map-searchbar button {
  background: #075429 !important;
  border-radius: 10px !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}
.map-actions button {
  font-size: .75rem !important;
  font-weight: 900 !important;
  border-radius: 9px !important;
  border: 1.5px solid #d7e8d2 !important;
  color: #062f1a !important;
  background: #fff !important;
}
.map-actions button:hover { background: #f0fdf4 !important; }
.map-actions small { font-size: .68rem !important; color: #536c5d !important; }

/* ── Mobile ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .risk-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }
  .forecast-strip {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
    gap: 8px !important;
    padding-bottom: 10px !important;
  }
  .day-card {
    flex: 0 0 130px !important;
    scroll-snap-align: start !important;
  }
  .metrics-row {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding-bottom: 6px !important;
  }
}

@media (max-width: 600px) {
  .risk-grid { grid-template-columns: 1fr !important; }
  .info-grid { grid-template-columns: 1fr !important; }
  .day-card  { flex: 0 0 118px !important; }
  .risk-card { border-top-width: 4px !important; }
}

/* FIM RSVPro Design System v2 */

/* ============================================================
   RSVPro PHP - DADOS MOBILE FIX
   Corrige grelha do relatório técnico (especificidade nth-of-type)
   e melhora layout mobile da página dados.php.
   Apenas max-width:860px — desktop intacto.
   ============================================================ */

@media (max-width: 860px) {

  /* --- Relatório técnico: corrigir colunas implícitas ---
     Os nth-of-type no base CSS têm especificidade (0,2,0).
     A regra genérica .rsv-report-grid > article tem (0,1,1)
     e perde mesmo com !important dentro da media query.
     Solução: repetir os seletores nth-of-type no breakpoint. */
  .rsv-report-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .rsv-report-grid > article:nth-of-type(1),
  .rsv-report-grid > article:nth-of-type(2),
  .rsv-report-grid > article:nth-of-type(3),
  .rsv-report-grid > article:nth-of-type(4),
  .rsv-report-grid > article:nth-of-type(5),
  .rsv-report-grid > article:nth-of-type(6),
  .rsv-report-grid > article:nth-of-type(7),
  .rsv-report-grid > article:nth-of-type(8) {
    grid-column: 1 !important;
    grid-row: auto !important;
    min-height: auto !important;
    width: 100% !important;
  }

  /* --- Mapa: altura reduzida para libertar espaço --- */
  #rsvMap {
    height: 260px !important;
    min-height: 260px !important;
    max-height: 260px !important;
  }

  /* --- Dashboard: coluna única --- */
  .dashboard-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  /* --- Previsão: scroll horizontal compacto --- */
  .forecast-panel {
    padding: 14px 12px !important;
  }

  .forecast-strip {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-snap-type: x mandatory !important;
    gap: 8px !important;
    padding-bottom: 8px !important;
  }

  .day-card {
    flex: 0 0 108px !important;
    min-width: 108px !important;
    max-width: 108px !important;
    min-height: auto !important;
    scroll-snap-align: start !important;
    padding: 10px 8px !important;
  }

  .day-title { font-size: 12px !important; }
  .day-date  { font-size: 10px !important; }
  .day-values { font-size: 11px !important; }

  /* --- Timeline: etiquetas mais compactas --- */
  .rsv-row {
    grid-template-columns: 110px repeat(var(--tl-days), 44px) !important;
  }

  .rsv-climate-chart-row {
    grid-template-columns: 110px minmax(760px, 1fr) !important;
  }

  .rsv-row-label,
  .rsv-chart-legend {
    width: 110px !important;
    min-width: 110px !important;
    font-size: 11px !important;
    padding: 6px 6px !important;
  }

  /* --- Métricas: wrap 2 colunas --- */
  .metrics-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    overflow: visible !important;
  }

  .metrics-row div {
    min-width: 0 !important;
  }

  /* --- Secções de risco: 1 coluna --- */
  .risk-grid {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* --- Info grid: 1 coluna --- */
  .info-grid {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* --- Relatório: cabeçalho compacto --- */
  .rsv-report-head {
    flex-direction: column !important;
    gap: 8px !important;
  }

  .rsv-report-badge {
    align-self: flex-start !important;
  }
}
