:root{
  --green:#1f7a3a;
  --green-dark:#155628;
  --orange:#f15a24;
  --dark:#3f464a;
  --bg:#f4f7f5;
  --card:#ffffff;
  --text:#17231d;
  --muted:#64736a;
  --line:#dce6df;
  --blue:#1d70d8;
  --amber:#f08a1a;
  --red:#d0342c;
  --gray:#77808a;
  --shadow:0 8px 24px rgba(15,35,25,.08);
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
}

.app-header{
  background:#fff;
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow);
  padding:16px 20px;
  display:grid;
  grid-template-columns:280px 1fr 250px;
  align-items:center;
  gap:20px;
}

.logos{
  display:flex;
  align-items:center;
  gap:16px;
}
.logo-dunex{
  max-width:170px;
  height:auto;
}
.logo-gmao{
  max-width:88px;
  height:auto;
}

.header-title{
  border-left:1px solid var(--line);
  padding-left:20px;
}
.portal-name{
  color:var(--green);
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  font-size:.86rem;
}
h1{
  margin:.15rem 0;
  font-size:1.55rem;
}
.header-title p{
  margin:0;
  color:var(--muted);
  font-weight:600;
}

.sync-box{
  justify-self:end;
  text-align:right;
  background:#f8fbf9;
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px 14px;
  min-width:225px;
}
.sync-box span{
  display:block;
  color:var(--muted);
  font-size:.86rem;
  margin-bottom:3px;
}
.sync-box strong{
  color:var(--green-dark);
  font-size:1rem;
}

.page{
  width:min(1220px,100%);
  margin:0 auto;
  padding:18px;
}

.kpis{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-bottom:14px;
}
.kpi{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  box-shadow:var(--shadow);
}
.kpi .label{
  color:var(--muted);
  font-weight:700;
  font-size:.9rem;
}
.kpi .value{
  font-size:1.9rem;
  font-weight:950;
  margin-top:2px;
}

.tools{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:12px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
  box-shadow:var(--shadow);
}

.search-wrap{
  grid-column:1/-1;
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:14px;
  padding:0 12px;
}
.search-wrap input{
  border:0;
  outline:0;
  width:100%;
  padding:13px 0;
  font-size:1rem;
}

.segmented{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.segmented button{
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  padding:10px 13px;
  font-weight:800;
  color:#26342b;
  cursor:pointer;
}
.segmented button.active{
  background:var(--green);
  color:#fff;
  border-color:var(--green);
}

.status-filter{
  justify-content:flex-end;
}

.legend{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:12px;
  padding:12px 4px;
  color:#334238;
  font-weight:700;
  font-size:.92rem;
}
.legend span{
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.dot{
  width:11px;
  height:11px;
  border-radius:50%;
  display:inline-block;
}
.dot.prevu{background:var(--blue)}
.dot.encours{background:var(--amber)}
.dot.retard{background:var(--red)}
.dot.reporte{background:var(--gray)}

.cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.card{
  position:relative;
  background:#fff;
  border:1px solid var(--line);
  border-left:8px solid var(--blue);
  border-radius:18px;
  padding:15px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card::after{
  content:"";
  position:absolute;
  inset:0;
  opacity:.08;
  pointer-events:none;
}
.card.PREVU{border-left-color:var(--blue)}
.card.PREVU::after{background:var(--blue)}
.card.EN-COURS{border-left-color:var(--amber)}
.card.EN-COURS::after{background:var(--amber)}
.card.RETARD{border-left-color:var(--red)}
.card.RETARD::after{background:var(--red)}
.card.REPORTE{border-left-color:var(--gray)}
.card.REPORTE::after{background:var(--gray)}

.card-content{
  position:relative;
  z-index:1;
}
.card-head{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:flex-start;
}
.immat{
  font-size:1.35rem;
  font-weight:950;
  letter-spacing:.04em;
}
.badge{
  border-radius:999px;
  padding:6px 10px;
  color:#fff;
  font-size:.78rem;
  font-weight:900;
  white-space:nowrap;
}
.badge.PREVU{background:var(--blue)}
.badge.EN-COURS{background:var(--amber)}
.badge.RETARD{background:var(--red)}
.badge.REPORTE{background:var(--gray)}

.operation{
  margin:7px 0 11px;
  font-weight:850;
  font-size:1.05rem;
}

.info{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:9px;
}
.item{
  display:flex;
  align-items:flex-start;
  gap:8px;
  min-width:0;
}
.icon{
  width:22px;
  text-align:center;
}
.item strong{
  display:block;
  color:var(--muted);
  font-size:.78rem;
  line-height:1.1;
}
.item span{
  display:block;
  font-weight:750;
  overflow-wrap:anywhere;
}
.notes{
  margin-top:12px;
  padding-top:10px;
  border-top:1px dashed var(--line);
  color:#334238;
  font-size:.92rem;
}
.empty{
  grid-column:1/-1;
  background:#fff;
  border:1px dashed var(--line);
  border-radius:18px;
  padding:32px;
  text-align:center;
  color:var(--muted);
  font-weight:700;
}
.footer{
  margin-top:16px;
  padding:18px;
  background:#fff;
  border-top:1px solid var(--line);
  color:var(--muted);
  text-align:center;
  line-height:1.7;
}
.footer strong{color:var(--green-dark);}

@media (max-width:980px){
  .app-header{
    grid-template-columns:1fr;
    gap:10px;
  }
  .header-title{
    border-left:0;
    padding-left:0;
  }
  .sync-box{
    justify-self:stretch;
    text-align:left;
  }
  .kpis{
    grid-template-columns:repeat(2,1fr);
  }
  .tools{
    grid-template-columns:1fr;
  }
  .status-filter{
    justify-content:flex-start;
  }
  .cards{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:640px){
  .app-header{
    padding:13px;
  }
  .logos{
    justify-content:space-between;
  }
  .logo-dunex{
    max-width:145px;
  }
  .logo-gmao{
    max-width:75px;
  }
  h1{
    font-size:1.3rem;
  }
  .page{
    padding:12px;
  }
  .kpis{
    grid-template-columns:repeat(2,1fr);
    gap:9px;
  }
  .kpi{
    padding:11px;
  }
  .kpi .value{
    font-size:1.55rem;
  }
  .segmented button{
    flex:1 1 auto;
  }
  .legend{
    justify-content:flex-start;
  }
  .cards{
    grid-template-columns:1fr;
  }
  .info{
    grid-template-columns:1fr 1fr;
  }
  .footer{
    text-align:center;
  }
}
