/* ===========================================================
   Workshare Performance module
   =========================================================== */

:root {
  --ws-navy: #0f2a44;
  --ws-blue: #1d4ed8;
  --ws-blue-soft: #38bdf8;
  --ws-red: #ef4444;
  --ws-red-soft: #fca5a5;
  --ws-green: #16a34a;
  --ws-green-soft: #86efac;
  --ws-bg: #f3f6fa;
}

/* ---- Landing page ---- */
.workshare-landing-body {
  margin: 0;
  background: #0a1d34;
  min-height: 100vh;
  color: #fff;
}

.workshare-landing-shell {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
}

.workshare-landing-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, rgba(15, 42, 68, 0.85), rgba(28, 75, 124, 0.7) 40%, rgba(45, 110, 170, 0.45) 75%, rgba(15, 42, 68, 0.6)),
    linear-gradient(180deg, #0f2a44 0%, #1a3a5c 100%);
  filter: saturate(1.05);
  z-index: 0;
}

.workshare-landing-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  padding: 24px 44px 48px 44px;
}

/* KBR logo + Reporting Hub back button float to the top-right corner so
   they stay put while the controls + nav link sit lower in the viewport. */
.workshare-kbr-logo {
  position: absolute;
  top: 26px;
  right: 44px;
  display: flex;
  align-items: center;
  gap: 14px;
}
/* .workshare-back-btn used to override the standard .back-to-modules-btn
   with a solid-white pill; the back button now inherits the translucent
   white-on-dark treatment used on Cost / Survey / every other module
   page. The class stays on the element as a no-op hook in case any
   page-specific positioning needs to attach later. */

.workshare-landing-top {
  /* Push the dropdown row down ~14vh so it lands roughly a fifth of the
     way into the page instead of pinned at the very top. */
  margin-top: 14vh;
}

.workshare-landing-controls {
  display: flex;
  gap: 22px;
  align-items: flex-end;
  flex-wrap: wrap;
}

.workshare-control {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.workshare-control label {
  font-size: 13px;
  font-weight: 600;
  color: #cbd5e1;
  letter-spacing: 0.2px;
}

.workshare-control select {
  min-width: 220px;
  padding: 8px 12px;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,0.25);
  background: rgba(255,255,255,0.96);
  color: #0f172a;
  font-size: 14px;
  font-weight: 500;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}

.workshare-kbr-logo .kbr-logo {
  color: #fff;
  font-weight: 700;
  font-size: 30px;
  letter-spacing: 0.5px;
}

.workshare-kbr-logo .kbr-logo .dot {
  background: #22d3ee;
}

.workshare-landing-nav {
  margin-top: 28px;
}

/* "Overview" link styled as an outlined pill so it reads as a clickable
   button against the dark backdrop instead of an invisible underline. */
.workshare-nav-link {
  display: inline-block;
  padding: 10px 36px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.55);
  border-radius: 6px;
  color: #fff;
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0.5px;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.1s ease;
}

.workshare-nav-link:hover:not(.disabled) {
  background: rgba(255,255,255,0.2);
  border-color: #fff;
  color: #fff;
}

.workshare-nav-link:active:not(.disabled) {
  transform: translateY(1px);
}

.workshare-nav-link.disabled {
  color: rgba(255,255,255,0.45);
  border-color: rgba(255,255,255,0.2);
  background: transparent;
  cursor: not-allowed;
}

.workshare-landing-title {
  margin-top: auto;
  margin-left: auto;
  text-align: right;
  padding-bottom: 56px;
  padding-right: 20px;
}
/* KBR logo pinned to the top-LEFT corner, on the same line as the
   Reporting Hub back button (top-right at top:26px). Height is capped so
   it sits level with the button rather than towering over it. */
.workshare-corner-logo {
  position: absolute;
  top: 22px;
  left: 44px;
  height: clamp(28px, 3vw, 40px);
  width: auto;
  z-index: 2;
}

.workshare-landing-title h1 {
  font-size: 64px;
  line-height: 1.05;
  font-weight: 700;
  color: #fff;
  margin: 0;
  letter-spacing: -0.5px;
}

.workshare-landing-title .thin {
  font-weight: 300;
}

/* ---- Overview page ---- */
.workshare-report-body {
  background: var(--ws-bg);
}

.workshare-shell {
  background: var(--ws-bg);
}

/* Toolbar aligns with cards: shell already pads 24px; this 20px pulls the
   content in another 20px so the home icon + KBR logo line up exactly with
   the left/right card edges in the body below. */
.workshare-toolbar {
  background: #fff;
  border-bottom: 1px solid var(--kbr-border);
  padding: 12px 20px 12px 20px;
  margin-bottom: 12px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.workshare-toolbar .schedule-tab-nav .home-btn,
.workshare-toolbar .schedule-tab-nav .tab-link {
  color: var(--ws-navy);
}

.workshare-toolbar .schedule-tab-nav .tab-link.active {
  color: var(--ws-blue);
  border-bottom: 2px solid var(--ws-blue);
}

.workshare-report-logo { text-align: right; }

.workshare-report-logo .kbr-logo {
  font-size: 22px;
  font-weight: 700;
  color: var(--ws-navy);
}

.workshare-report-logo .report-tag {
  color: var(--kbr-text-muted);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  text-transform: none;
  margin-top: 2px;
}

.workshare-body { padding: 4px 20px 20px 20px; }

.workshare-grid {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 20px;
}

/* Target Rates left rail */
.workshare-target-rates {
  background: #fff;
  border: 1px solid var(--kbr-border);
  border-radius: var(--kbr-radius);
  padding: 22px 14px;
  display: flex;
  flex-direction: column;
  gap: 26px;
  align-items: center;
  height: fit-content;
  box-shadow: var(--kbr-shadow-sm);
}

.target-rate-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.target-rate-icon {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  border: 2.5px solid currentColor;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
}

.target-rate-icon.ho      { color: var(--ws-navy); }
.target-rate-icon.blended { color: var(--ws-green); }
.target-rate-icon.coc     { color: var(--ws-red); }

.target-rate-label {
  font-size: 13px;
  color: var(--kbr-text-muted);
  font-weight: 600;
  text-align: center;
}

.target-rate-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--ws-navy);
  text-align: center;
}

/* Right side stacks the two rows of cards */
.workshare-main {
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-width: 0;
}

.workshare-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px;
}

.workshare-row.charts-row .card-panel {
  padding: 14px 16px;
  box-shadow: var(--kbr-shadow-sm);
}

.workshare-chart-panel h5 {
  font-size: 15px;
  font-weight: 700;
  color: var(--ws-navy);
  margin: 0 0 6px 0;
  text-align: center;
}

.workshare-chart-panel .chart-subtitle {
  font-size: 11px;
  font-weight: 500;
  color: var(--kbr-text-muted);
}

.workshare-chart-panel .chart-box { height: 260px; }

/* KPI cards (bottom row) */
.workshare-kpi-card {
  background: #fff;
  border: 1px solid var(--kbr-border);
  border-radius: var(--kbr-radius);
  padding: 16px 20px 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: var(--kbr-shadow-sm);
}

.workshare-kpi-card h5 {
  background: #1a4a7a;
  color: #fff;
  margin: -16px -20px 0 -20px;
  padding: 12px 16px;
  border-radius: var(--kbr-radius) var(--kbr-radius) 0 0;
  font-size: 15px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.2px;
}

.kpi-totals {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  text-align: center;
  padding-top: 4px;
}

.kpi-total .t-label {
  font-size: 13px;
  color: var(--kbr-text-muted);
  font-weight: 600;
  letter-spacing: 0.2px;
}

.kpi-total .t-value {
  font-size: 26px;
  font-weight: 700;
  color: var(--ws-navy);
  line-height: 1.1;
  margin-top: 2px;
}

.kpi-cols-header {
  display: grid;
  grid-template-columns: 100px 1fr 1fr;
  font-size: 13px;
  font-weight: 600;
  color: var(--kbr-text-muted);
  border-bottom: 1px solid var(--kbr-border);
  padding-bottom: 4px;
}

.kpi-cols-header .col-ho { grid-column: 2; text-align: center; }
.kpi-cols-header .col-coc { grid-column: 3; text-align: center; }

.kpi-metric-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.metric-row {
  display: grid;
  grid-template-columns: 100px 1fr 1fr;
  gap: 10px;
  align-items: center;
  font-size: 13px;
}

.metric-label {
  font-weight: 600;
  color: var(--ws-navy);
}

.metric-bar-cell {
  display: flex;
  align-items: center;
  gap: 8px;
}

.bar-track {
  flex: 1;
  height: 18px;
  background: #eef2f6;
  border-radius: 3px;
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.25s ease;
}

.bar-value {
  font-size: 12px;
  font-weight: 700;
  color: var(--ws-navy);
  min-width: 40px;
  text-align: right;
}

/* Row tinting per the design — Target=navy, Cum to Date=red,
   To Go=green-soft, EAC=green. The bar color follows the row. */
.metric-row.row-target .bar-fill     { background: var(--ws-navy); }
.metric-row.row-cumtodate .bar-fill  { background: var(--ws-red); }
.metric-row.row-togo .bar-fill       { background: var(--ws-green-soft); }
.metric-row.row-eac .bar-fill        { background: var(--ws-green); }

/* Footer aligns with toolbar + cards via the same 20px horizontal pad */
.workshare-footer {
  background: #fff;
  border-top: 1px solid var(--kbr-border);
  padding: 10px 20px;
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  box-shadow: 0 -1px 2px rgba(15, 23, 42, 0.04);
}

.workshare-footer .footer-item {
  display: flex;
  align-items: center;
  gap: 4px;
}

.workshare-footer .footer-label {
  color: var(--kbr-text-muted);
  font-weight: 600;
}

.workshare-footer .footer-value {
  color: var(--ws-navy);
  font-weight: 700;
}

/* Responsive — stack everything on tablets and phones */
@media (max-width: 1399px) {
  .workshare-landing-title h1 { font-size: 56px; }
}

@media (max-width: 1199px) {
  .workshare-row { grid-template-columns: 1fr 1fr; }
  .workshare-landing-title h1 { font-size: 52px; }
  .workshare-landing-content { padding: 24px 32px 40px 32px; }
  .workshare-kbr-logo { right: 32px; }
}

@media (max-width: 991px) {
  /* Overview — collapse left rail to a horizontal strip, stack chart row */
  .workshare-grid { grid-template-columns: 1fr; }
  .workshare-target-rates {
    flex-direction: row;
    justify-content: space-around;
    padding: 16px 22px;
  }
  .workshare-row { grid-template-columns: 1fr; }
  .workshare-chart-panel .chart-box { height: 280px; }
  .kpi-total .t-value { font-size: 24px; }

  /* Landing — title smaller and centered on tablets */
  .workshare-landing-title h1 { font-size: 44px; }
  .workshare-landing-title { padding-right: 0; padding-bottom: 40px; }
  .workshare-landing-top { margin-top: 10vh; }
  .workshare-control select { min-width: 0; width: 100%; }
}

@media (max-width: 767px) {
  .workshare-landing-content { padding: 20px 24px 32px 24px; }
  .workshare-kbr-logo { right: 24px; top: 20px; }
  .workshare-landing-controls { flex-direction: column; align-items: stretch; gap: 12px; width: 100%; }
  .workshare-control { width: 100%; }
  .workshare-nav-link { display: block; text-align: center; }
  .workshare-landing-title h1 { font-size: 38px; }
}

@media (max-width: 575px) {
  .workshare-landing-title h1 { font-size: 32px; }
  .workshare-landing-top { margin-top: 8vh; }
  /* Overview — KPI cards stack and target rates wrap */
  .workshare-target-rates { flex-wrap: wrap; gap: 18px; }
  .workshare-kpi-card h5 { font-size: 14px; }
  .kpi-total .t-value { font-size: 22px; }
  .target-rate-value { font-size: 20px; }
  .target-rate-icon { width: 50px; height: 50px; font-size: 24px; }
}

