/* Territory Forge Operations Dashboard (#38) */
:root {
  --bg: #0b0e11;
  --panel: #141a21;
  --panel2: #1a222c;
  --border: #2a3544;
  --text: #e8edf2;
  --muted: #8b97a8;
  --accent: #3d8bfd;
  --ok: #2ea043;
  --warn: #d29922;
  --err: #f85149;
  --nav-w: 210px;
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; background: var(--bg); color: var(--text); font: 13px/1.35 system-ui, sans-serif; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.app { display: grid; grid-template-rows: 42px 1fr; grid-template-columns: var(--nav-w) 1fr; min-height: 100vh; }
.topbar { grid-column: 1 / -1; display: flex; align-items: center; gap: 1rem; padding: 0 1rem; background: var(--panel); border-bottom: 1px solid var(--border); font-size: 12px; }
.topbar .brand { font-weight: 700; letter-spacing: .02em; }
.topbar .pill { padding: 2px 8px; border-radius: 999px; border: 1px solid var(--border); color: var(--muted); }
.topbar .pill.ok { color: var(--ok); border-color: #1f4d2b; }
.topbar .pill.warn { color: var(--warn); }
.topbar .spacer { flex: 1; }
.sidebar { background: var(--panel); border-right: 1px solid var(--border); padding: .5rem 0; overflow: auto; }
.sidebar a { display: block; padding: .45rem 1rem; color: var(--muted); border-left: 3px solid transparent; }
.sidebar a.active, .sidebar a:hover { color: var(--text); background: var(--panel2); border-left-color: var(--accent); text-decoration: none; }
.main { padding: .75rem 1rem; overflow: auto; }
h1 { margin: 0 0 .75rem; font-size: 1.15rem; }
h2 { margin: 0 0 .5rem; font-size: .95rem; }
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: .5rem; margin-bottom: .75rem; }
.card { background: var(--panel); border: 1px solid var(--border); border-radius: 4px; padding: .55rem .65rem; }
.card .label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .04em; }
.card .value { font-size: 1.25rem; font-weight: 700; margin-top: .15rem; word-break: break-all; }
.card .sub { color: var(--muted); font-size: 11px; margin-top: .2rem; }
.toolbar { display: flex; flex-wrap: wrap; gap: .35rem; margin-bottom: .75rem; align-items: center; }
button, .btn { background: var(--accent); color: #fff; border: 1px solid #2f6fcc; border-radius: 4px; padding: .35rem .65rem; font-weight: 600; cursor: pointer; font-size: 12px; }
button.secondary, .btn.secondary { background: var(--panel2); color: var(--text); border-color: var(--border); }
button:disabled { opacity: .45; cursor: not-allowed; }
input, select { background: #0d1117; color: var(--text); border: 1px solid var(--border); border-radius: 4px; padding: .35rem .5rem; font-size: 12px; }
table.data { width: 100%; border-collapse: collapse; background: var(--panel); border: 1px solid var(--border); }
table.data th, table.data td { border-bottom: 1px solid var(--border); padding: .35rem .5rem; text-align: left; vertical-align: top; }
table.data th { background: var(--panel2); color: var(--muted); font-size: 11px; text-transform: uppercase; position: sticky; top: 0; }
table.data tr:hover td { background: #121820; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
@media (max-width: 960px) { .grid2 { grid-template-columns: 1fr; } .app { grid-template-columns: 1fr; } .sidebar { display: none; } }
.ops-menu-btn {
  display: none;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--panel2);
  color: var(--text);
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  place-items: center;
  flex: 0 0 auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  position: relative;
  z-index: 60;
}

.ops-mobile-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.15s ease, visibility 0s linear 0.15s;
}

.ops-mobile-drawer {
  position: fixed;
  top: var(--ops-mobile-nav-top, 42px);
  left: 0;
  right: 0;
  bottom: auto;
  width: auto;
  max-height: min(75dvh, 520px);
  z-index: 9999;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0s linear 0.15s;
}

.ops-mobile-drawer.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity 0.15s ease, transform 0.15s ease;
}

.ops-mobile-drawer-backdrop.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 0.15s ease;
}

.ops-mobile-drawer-backdrop.is-open.is-arming {
  pointer-events: none;
}

.ops-mobile-drawer-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.75rem 0.85rem;
  border-bottom: 1px solid var(--border);
  background: var(--panel2);
}

.ops-mobile-drawer-close {
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--muted);
  font-size: 1.35rem;
  line-height: 1;
  cursor: pointer;
}

.ops-mobile-drawer-body {
  padding: 0.5rem 0;
  overflow: auto;
  flex: 1;
}

.ops-mobile-drawer-section {
  padding: 0.65rem 1rem 0.35rem;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.ops-mobile-drawer-body a {
  display: block;
  padding: 0.55rem 1rem;
  color: var(--muted);
  text-decoration: none;
  border-left: 3px solid transparent;
}

.ops-mobile-drawer-body a:hover,
.ops-mobile-drawer-body a.active {
  color: var(--text);
  background: var(--panel2);
  border-left-color: var(--accent);
  text-decoration: none;
}

body.ops-mobile-nav-open {
  overflow: hidden;
}

/* Narrow viewports: hamburger nav replaces sidebar */
@media (max-width: 1180px) {
  .ops-menu-btn { display: inline-grid !important; }
  .sidebar { display: none !important; }
  .app { grid-template-columns: 1fr !important; }
  .topbar {
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0.35rem 0.65rem;
    min-height: 42px;
  }
  .topbar .pill.hide-mobile { display: none; }
  .topbar .spacer { flex: 1; min-width: 0.5rem; }
  .topbar form button { padding: 0.3rem 0.5rem; }
}

/* Wide desktop: hide mobile chrome */
@media (min-width: 1181px) {
  .ops-menu-btn { display: none !important; }
  .ops-mobile-drawer:not(.is-open),
  .ops-mobile-drawer-backdrop:not(.is-open) {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}
.unit-card { background: var(--panel); border: 1px solid var(--border); border-radius: 4px; padding: .65rem; margin-bottom: .5rem; }
.unit-card header { display: flex; justify-content: space-between; font-weight: 700; margin-bottom: .35rem; }
.meta { color: var(--muted); font-size: 12px; }
pre.dump { background: #0d1117; border: 1px solid var(--border); border-radius: 4px; padding: .65rem; overflow: auto; max-height: 420px; font: 11px/1.35 ui-monospace, monospace; white-space: pre-wrap; word-break: break-word; }
.flash { background: #2d1f00; border: 1px solid var(--warn); color: #ffe8a3; padding: .5rem .65rem; border-radius: 4px; margin-bottom: .75rem; }
.flash.ok { background: #0f2d1a; border-color: var(--ok); color: #b7f5c8; }
.login-wrap { min-height: 100vh; display: grid; place-items: center; }
.login-box { width: 320px; background: var(--panel); border: 1px solid var(--border); border-radius: 6px; padding: 1rem; display: grid; gap: .65rem; }
.login-box h1 { margin: 0; }
.err { color: var(--err); }
.tree { font-family: ui-monospace, monospace; font-size: 12px; }
.badge { display: inline-block; padding: 1px 6px; border-radius: 3px; background: var(--panel2); border: 1px solid var(--border); font-size: 11px; }
.badge.ok { color: var(--ok); }
.hourglass-steps { background: var(--panel); border: 1px solid var(--border); border-radius: 4px; padding: .65rem .85rem; margin: .75rem 0; font-size: 12px; }
.table-scroll { display: block; max-height: 24rem; overflow: auto; }
.hourglass-steps code { background: #0d1117; padding: 1px 4px; border-radius: 3px; }
.logo-mark { width: 56px; height: 56px; border-radius: 12px; background: linear-gradient(135deg, #3d8bfd, #1f6fcc); display: grid; place-items: center; font-weight: 800; font-size: 1.25rem; margin: 0 auto; }
.login-box .btn.oauth { display: block; text-align: center; text-decoration: none; }
.login-box .btn.oauth.google { background: #fff; color: #333; border-color: #ccc; }
.login-box .btn.oauth.yahoo { background: #6001d2; border-color: #4b01a8; }
.login-fallback { margin-top: .5rem; color: var(--muted); font-size: 12px; }
.setup-steps { background: var(--panel); border: 1px solid var(--border); border-radius: 4px; padding: .75rem 1.25rem; }
.setup-steps li { margin: .5rem 0; }
.setup-steps li.done strong { color: var(--ok); }
.mapping-suggest-block { margin: 1rem 0 1.25rem; }
.mapping-suggest-row td { vertical-align: top; }
.badge.likely { background: #1a3d2a; color: var(--ok); border: 1px solid #2ea043; padding: 2px 6px; border-radius: 4px; font-size: 11px; }
.badge.possible { background: #3d3018; color: var(--warn); border: 1px solid var(--warn); padding: 2px 6px; border-radius: 4px; font-size: 11px; }
.form-row label { display: flex; flex-direction: column; gap: .25rem; font-size: 12px; color: var(--muted); }
.form-row select { min-width: 220px; }
.form-row { display: flex; flex-wrap: wrap; gap: .35rem; align-items: center; margin: .35rem 0; }
.form-inline { display: inline-flex; gap: .25rem; align-items: center; }
.session-panel { background: var(--panel); border: 1px solid var(--border); border-radius: 6px; padding: .85rem; margin-bottom: 1rem; }
.session-accordion { background: var(--panel); border: 1px solid var(--border); border-radius: 6px; margin-bottom: .75rem; }
.session-accordion > summary { list-style: none; cursor: pointer; padding: .75rem .85rem; display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.session-accordion > summary::-webkit-details-marker { display: none; }
.session-accordion[open] > summary { border-bottom: 1px solid var(--border); }
.session-title { font-weight: 700; }
.session-accordion-body { padding: .75rem .85rem .85rem; }
.session-accordion-meta { margin-bottom: .65rem; }
.session-panel-header { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: .75rem; }
.session-panel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; }
.session-section { background: var(--panel2); border: 1px solid var(--border); border-radius: 4px; padding: .65rem; }
.session-section h3 { margin: 0 0 .5rem; font-size: 13px; }
.session-leadership { grid-column: 1 / -1; }
.session-people-table { width: 100%; font-size: 12px; }
.session-leader-transfer select { min-width: 240px; }
button.secondary.warn { border-color: var(--warn); color: #ffe8a3; }
@media (max-width: 960px) { .session-panel-grid { grid-template-columns: 1fr; } }
