/* Sabea Broker Portal — Ad ROI page styles. Scoped under .roi-* and #panel-ad-roi.
   Reuses brand vars (--navy, --gold, --mu) defined globally in index.html. */

#panel-ad-roi { padding: 4px 2px; }

.roi-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 16px; flex-wrap: wrap; margin-bottom: 18px;
}
.roi-head h1 { margin: 0 0 4px; font-size: 22px; font-weight: 700; color: var(--navy); }
.roi-sub { font-size: 13px; color: var(--mu); margin: 0; }

.roi-controls { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.roi-periods { display: inline-flex; border: 1px solid #e2e6ee; border-radius: 8px; overflow: hidden; }
.roi-period {
  padding: 7px 12px; font-size: 13px; background: #fff; color: var(--mu);
  border: 0; border-right: 1px solid #e2e6ee; cursor: pointer;
}
.roi-period:last-child { border-right: 0; }
.roi-period:hover { color: var(--navy); }
.roi-period.active { background: var(--navy); color: #fff; }

.roi-comm {
  font-size: 12px; color: var(--mu); display: inline-flex; align-items: center; gap: 6px;
}
.roi-comm input {
  width: 64px; padding: 6px 8px; font-size: 13px; border: 1px solid #e2e6ee;
  border-radius: 8px; color: var(--navy);
}
.roi-refresh {
  padding: 7px 12px; font-size: 13px; background: #fff; color: var(--navy);
  border: 1px solid #e2e6ee; border-radius: 8px; cursor: pointer;
}
.roi-refresh:hover { border-color: var(--gold); }
.roi-hide { font-size: 12px; color: var(--mu); display: inline-flex; align-items: center; gap: 6px; cursor: pointer; white-space: nowrap; }
.roi-hide input { cursor: pointer; margin: 0; }
.roi-hidden-note td { font-size: 11px !important; }

.roi-warn {
  background: #fff8e6; border: 1px solid #f3e2a8; color: #7a5c00;
  padding: 12px 14px; border-radius: 10px; font-size: 13px; margin-bottom: 16px;
}
.roi-warn code { background: #fff1cc; padding: 1px 5px; border-radius: 4px; font-size: 12px; }
.roi-warn-how { display: block; margin-top: 4px; color: #8a6d1f; }
.roi-error { color: #b00020; font-size: 14px; padding: 16px 0; }
.roi-empty { padding: 40px 0; text-align: center; color: var(--mu); font-size: 14px; }

.roi-tiles { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.roi-tile {
  flex: 1 1 130px; background: #fff; border: 1px solid #eef1f6; border-radius: 12px;
  padding: 14px 16px; display: flex; flex-direction: column; gap: 4px;
}
.roi-tile-v { font-size: 20px; font-weight: 700; color: var(--navy); }
.roi-tile-l { font-size: 12px; color: var(--mu); }
.roi-tile-pos { border-color: #bfe3c8; background: #f3fbf5; }
.roi-tile-pos .roi-tile-v { color: #1d7a3a; }
.roi-tile-neg { border-color: #f0c4c4; background: #fdf4f4; }
.roi-tile-neg .roi-tile-v { color: #b00020; }

.roi-table-wrap { overflow-x: auto; }
.roi-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 760px; }
.roi-table th, .roi-table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid #eef1f6; }
.roi-table th { font-size: 11px; text-transform: uppercase; letter-spacing: .04em; color: var(--mu); font-weight: 600; }
.roi-table td.num, .roi-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.roi-name { white-space: nowrap; }
.roi-cname { font-weight: 700; color: var(--navy); }
.roi-csub { display: block; font-size: 11px; color: var(--mu); }
.roi-table tr.roi-camp td { background: #fafbfe; border-bottom: 1px solid #e7ebf3; }
.roi-table tr.roi-ad td { font-size: 12px; color: #475; }
.roi-ad-name { padding-left: 26px !important; position: relative; color: var(--mu); }
.roi-ad-name::before { content: "↳"; position: absolute; left: 12px; color: #c2c9d6; }
.roi-muted { font-style: italic; }
.roi-table tr.roi-total td { border-top: 2px solid #e2e6ee; border-bottom: 0; font-weight: 700; color: var(--navy); }
.roi-pos { color: #1d7a3a; }
.roi-neg { color: #b00020; }

.roi-foot { margin-top: 16px; font-size: 12px; color: var(--mu); line-height: 1.5; }

/* On/off toggle pills — drive Meta ad/campaign status straight from the dashboard. */
.roi-toggle {
  display: inline-block; vertical-align: middle; margin-right: 8px;
  min-width: 34px; padding: 2px 9px; font-size: 11px; font-weight: 700;
  line-height: 1.5; border-radius: 999px; border: 1px solid transparent;
  cursor: pointer; letter-spacing: .02em;
}
.roi-toggle.on  { background: #e6f7ec; color: #137a3a; border-color: #a8e0bd; }
.roi-toggle.off { background: #f0f1f5; color: #8a8f9c; border-color: #dde0e8; }
.roi-toggle:hover:not(:disabled) { filter: brightness(0.97); }
.roi-toggle:disabled { opacity: .55; cursor: default; }
.roi-ad-name .roi-toggle { margin-right: 6px; }

/* Editable manual-metric cells (e.g. Instagram-boost spend/CPC entered by hand). */
.roi-medit {
  width: 78px; padding: 4px 7px; font-size: 12px; text-align: right;
  border: 1px solid #d7dbe6; border-radius: 6px; color: var(--navy);
  background: #fffdf4; font-variant-numeric: tabular-nums; font-family: inherit;
}
.roi-medit::placeholder { color: var(--mu); }
.roi-medit:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 2px rgba(201,168,76,.25); background: #fff; }
/* Manual channel toggled "off" — dim the row as a visibility cue, but keep inputs usable. */
.roi-camp-off td { opacity: .5; }
.roi-camp-off .roi-medit { opacity: 1; }
.roi-mtoggle { cursor: pointer; }
