/* Extracted from:
 * - monitor_empresas_publicas/monitor/app/www/estilos.css
 * - monitor_empresas_publicas/monitor/app/R/data.R
 *
 * `--opp-light-blue` matches the reference CSS surface color (`#E2E9F1`).
 * Plot palettes use the R-side `light_blue` value (`#1B9E77`) in `R/plot_theme.R`.
 */

:root{
  --opp-blue:#25418E;
  --opp-dark-blue:#162755;
  --opp-light-blue:#E2E9F1;
  --opp-gold:#DAAA00;
  --opp-border:#d8e0ea;
}

body{
  background:var(--opp-light-blue);
  color:var(--opp-dark-blue);
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

.container-fluid{
  padding-left:0;
  padding-right:0;
}

.opp-login-shell{
  background:var(--opp-light-blue);
}

.opp-login-card,
.opp-kpi-card,
.opp-panel{
  border-radius:.5rem;
  box-shadow:none;
}

.opp-login-card,
.opp-panel{
  border:1px solid #e5e5e5;
}

.opp-login-kicker{
  color:var(--opp-gold);
}

.opp-top-strip{
  height:9px;
  background:#bfd6bc;
}

.opp-dashboard-nav > .tabbable > .nav-tabs{
  margin:0;
  padding:0 18px;
  border-bottom:none;
  background:var(--opp-dark-blue);
}

.opp-dashboard-nav > .tabbable > .nav-tabs > li{
  margin-bottom:0;
  position:relative;
}

.opp-dashboard-nav > .tabbable > .nav-tabs > li > a{
  margin-right:0;
  padding:18px 14px 17px;
  border:none !important;
  border-radius:0;
  background:transparent !important;
  color:#fff !important;
  font-weight:600;
  line-height:1.35;
}

.opp-dashboard-nav > .tabbable > .nav-tabs > li > a:hover,
.opp-dashboard-nav > .tabbable > .nav-tabs > li > a:focus{
  background:transparent !important;
  color:#fff !important;
}

.opp-dashboard-nav > .tabbable > .nav-tabs > li.active > a,
.opp-dashboard-nav > .tabbable > .nav-tabs > li.active > a:hover,
.opp-dashboard-nav > .tabbable > .nav-tabs > li.active > a:focus{
  color:#fff !important;
  border:none !important;
  background:transparent !important;
  font-weight:700;
  box-shadow:none;
}

.opp-dashboard-nav > .tabbable > .nav-tabs > li.active::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  bottom:0;
  height:3px;
  background:var(--opp-gold);
}

.opp-dashboard-nav > .tabbable > .tab-content{
  border:none;
}

.opp-kpi-card{
  min-height:122px;
  margin-bottom:16px;
  border:1px solid var(--opp-border);
  border-left:4px solid var(--opp-blue);
  background-color:#fff;
}

.opp-sidebar-stack{
  padding-right:8px;
}

.section-soft{
  background-color:var(--opp-light-blue);
}

.opp-page-wrap{
  padding:20px 16px;
}

.opp-dashboard-card{
  padding:12px 12px 4px;
  border:1px solid #d8d8d8;
  border-radius:12px;
  background:#f8f8f8;
}

.opp-dashboard-header{
  margin:0 4px 16px;
  padding:0 0 14px;
  border-bottom:1px solid #ddd;
}

.opp-dashboard-header h1{
  margin:0;
  font-size:26px;
  font-weight:500;
  color:#17233f;
}

.opp-dashboard-header-copy{
  margin-top:6px;
  color:#55657f;
}

.opp-main-panel{
  min-height:620px;
}

.opp-main-panel .nav-pills{
  margin-bottom:18px;
}

.opp-main-panel .nav-pills > li > a{
  border-radius:4px;
  color:var(--opp-blue);
}

.opp-main-panel .nav-pills > li.active > a,
.opp-main-panel .nav-pills > li.active > a:hover,
.opp-main-panel .nav-pills > li.active > a:focus{
  background:var(--opp-blue);
}

.opp-main-panel .table{
  margin-top:8px;
}

.btn-primary{
  background-color:var(--opp-blue);
  border-color:var(--opp-blue);
}

.btn-primary:hover,
.btn-primary:focus{
  filter:brightness(.95);
  background-color:var(--opp-blue);
  border-color:var(--opp-blue);
}

.shiny-input-radiogroup label,
.control-label,
.opp-panel-title,
.opp-login-card h1,
.opp-kpi-value .shiny-text-output{
  color:var(--opp-dark-blue);
}

.portfolio-tab-wrap{
  padding-top:20px;
}

.portfolio-shell{
  width:100%;
}

.portfolio-header{
  margin:0 4px 18px;
  padding:0 0 14px;
  border-bottom:1px solid var(--opp-border);
}

.portfolio-header h1{
  margin:0;
  font-size:30px;
  font-weight:700;
  color:var(--opp-dark-blue);
}

.portfolio-subcopy{
  margin:8px 0 0;
  max-width:760px;
  font-size:15px;
  line-height:1.5;
  color:#55657f;
}

.portfolio-toolbar{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  gap:14px 18px;
  margin:0 4px 16px;
  padding:16px 18px;
}

.portfolio-toolbar .form-group,
.portfolio-toolbar .shiny-input-container{
  margin-bottom:0;
}

.portfolio-toolbar .control-label{
  margin-bottom:6px;
}

.portfolio-filter-field{
  flex:1 1 180px;
  min-width:160px;
}

.portfolio-filter-field-moneda{
  flex:1 1 220px;
}

.portfolio-filter-field-moneda .radio{
  margin-top:0;
}

.portfolio-filter-field-moneda .radio-inline{
  margin-right:14px;
}

.portfolio-filter-actions{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:12px;
}

.portfolio-toolbar-note{
  font-size:13px;
  color:#55657f;
}

.portfolio-apply-button{
  min-width:108px;
  border-radius:10px;
}

.portfolio-status-banner{
  margin:0 4px 16px;
}

.portfolio-status-empty{
  padding:12px 14px;
  border:1px solid var(--opp-border);
  border-radius:10px;
  background:rgba(226,233,241,.6);
  color:#55657f;
  font-weight:600;
}

.portfolio-kpi-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:16px;
  margin:0 4px 16px;
}

.portfolio-kpi-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:14px;
  min-height:148px;
  margin-bottom:0;
  padding:18px 20px;
}

.portfolio-kpi-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.portfolio-kpi-label{
  margin:0;
  font-size:14px;
  font-weight:600;
  line-height:1.4;
  color:var(--opp-dark-blue);
}

.portfolio-currency-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:44px;
  padding:4px 10px;
  border-radius:999px;
  background:rgba(37,65,142,.1);
  color:var(--opp-blue);
  font-size:12px;
  font-weight:700;
  letter-spacing:.06em;
}

.portfolio-currency-badge .shiny-text-output,
.portfolio-kpi-number .shiny-text-output{
  display:inline;
}

.portfolio-kpi-number{
  font-size:40px;
  font-weight:700;
  line-height:1;
  color:var(--opp-dark-blue);
}

.portfolio-main-grid{
  display:grid;
  grid-template-columns:minmax(0, .72fr) minmax(0, 1.48fr);
  gap:16px;
  margin:0 4px 4px;
}

.portfolio-panel{
  display:flex;
  flex-direction:column;
  min-height:520px;
  margin-bottom:0;
  padding:18px 18px 16px;
}

.portfolio-section-title{
  margin-bottom:12px;
  font-size:20px;
  font-weight:700;
  color:var(--opp-dark-blue);
}

.portfolio-panel-body{
  flex:1;
  min-height:0;
}

.portfolio-chart-body{
  display:flex;
  align-items:stretch;
}

.portfolio-chart-body .shiny-plot-output{
  width:100%;
}

.portfolio-table-body{
  overflow:auto;
}

.portfolio-project-table{
  width:100%;
  margin:0;
  table-layout:fixed;
}

.portfolio-project-table > thead > tr > th{
  font-size:13px;
  font-weight:700;
  color:var(--opp-dark-blue);
  white-space:nowrap;
}

.portfolio-project-table > tbody > tr > td{
  font-size:12px;
  color:var(--opp-dark-blue);
  vertical-align:middle;
}

.portfolio-col-number{
  text-align:right;
  white-space:nowrap;
}

.portfolio-col-date{
  text-align:center;
  white-space:nowrap;
}

.portfolio-ellipsis{
  display:block;
  max-width:180px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.portfolio-empty-state{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:320px;
  padding:18px;
  text-align:center;
  color:#55657f;
  font-weight:600;
}

.portfolio-panel-body .recalculating{
  position:relative;
  opacity:.48;
}

.portfolio-panel-body .recalculating::after{
  content:"Cargando…";
  position:absolute;
  top:10px;
  right:12px;
  font-size:13px;
  font-weight:600;
  color:#55657f;
}

@media (max-width: 1199px){
  .portfolio-kpi-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .portfolio-main-grid{
    grid-template-columns:1fr;
  }

  .portfolio-panel{
    min-height:420px;
  }
}

@media (max-width: 767px){
  .portfolio-header h1{
    font-size:26px;
  }

  .portfolio-toolbar{
    padding:14px;
  }

  .portfolio-filter-field,
  .portfolio-filter-field-moneda{
    flex:1 1 100%;
    min-width:0;
  }

  .portfolio-filter-actions{
    width:100%;
    margin-left:0;
    justify-content:space-between;
    flex-wrap:wrap;
  }

  .portfolio-kpi-grid{
    grid-template-columns:1fr;
  }

  .portfolio-kpi-number{
    font-size:34px;
  }

  .portfolio-ellipsis{
    max-width:180px;
  }
}
