/* ────────────────────────────────────────────────────────────────────
   Power Terminal — Mobile CSS (v3)
   Strategy: tables-to-cards on phone via data-label attributes.
   Tables stay tables on desktop; on phones each <tr> becomes a card.
   ──────────────────────────────────────────────────────────────────── */

/* ── HAMBURGER (hidden on desktop) ────────────────────────────────── */
.pt-hamburger {
  display: none;
  background: transparent;
  border: none;
  padding: 10px 8px;
  cursor: pointer;
  flex-direction: column;
  gap: 4px;
  margin-right: 4px;
}
.pt-hamburger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--ink);
  transition: transform 0.2s, opacity 0.2s;
}
.pt-hamburger.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.pt-hamburger.open span:nth-child(2) { opacity: 0; }
.pt-hamburger.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ── DRAWER ───────────────────────────────────────────────────────── */
.pt-drawer {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: 78%; max-width: 320px;
  background: var(--surf);
  border-right: 1px solid var(--border);
  z-index: 300;
  padding: 24px 22px;
  transform: translateX(-100%);
  transition: transform 0.25s ease-out;
  overflow-y: auto;
}
.pt-drawer.open { transform: translateX(0); box-shadow: 2px 0 12px rgba(0,0,0,0.15); }
.pt-drawer-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 250;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s;
}
.pt-drawer-backdrop.show { opacity: 1; pointer-events: auto; }
.pt-drawer-h {
  font: 700 11px/1 var(--MN);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 18px;
}
.pt-drawer-link {
  display: block;
  padding: 14px 0;
  font: 500 15px/1 'Instrument Sans', sans-serif;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
}
.pt-drawer-link.on { color: var(--green); font-weight: 600; }
.pt-drawer-cta {
  display: block;
  margin-top: 22px;
  padding: 12px 18px;
  background: var(--green);
  color: #fff;
  text-align: center;
  font: 700 10px/1 var(--MN);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
}


/* ════════════════════════════════════════════════════════════════
   MOBILE: width ≤ 768px
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* ── Page shell: tighter padding ────────────────────────────── */
  .pt-page { padding: 0 14px 60px; }
  .pt-head { padding: 26px 0 20px; margin-bottom: 20px; }

  /* ── Nav: show hamburger, hide horizontal links ─────────────── */
  .pt-hamburger { display: flex; }
  .pt-nav-bar { padding: 0 14px; height: 48px; }
  .pt-nav-bar > .pt-nl,
  .pt-nav-bar > .pt-cta { display: none; }
  .pt-logo { margin-right: auto; }
  .pt-word { font-size: 10px; }
  .pt-mark { width: 22px; height: 22px; }

  /* ── Typography ─────────────────────────────────────────────── */
  .pt-h1 { font-size: 30px; line-height: 1.1; }
  .pt-sub { font-size: 14px; line-height: 1.6; }
  .ci-feature-h { font-size: 24px; line-height: 1.2; }
  .ci-sect-h { font-size: 20px; line-height: 1.2; }

  /* ── Homepage hero ──────────────────────────────────────────── */
  .ci-feature-inner { display: block; }
  .ci-feature-inner > * { margin-bottom: 22px; }
  .ci-feature-left { max-width: 100%; }
  .pt-hero-stats { grid-template-columns: 1fr; gap: 8px; }

  /* ── Homepage tile-grid-mini (the capture index zone tiles) ─ */
  .ci-tile-grid-mini { grid-template-columns: 1fr 1fr; gap: 1px; }
  .ci-tile-mini { padding: 12px; }
  .ci-tile-mini-ratio { font-size: 22px; }
  .ci-tile-mini-zone { font-size: 9px; }
  .ci-tile-mini-gap, .ci-tile-mini-meta { font-size: 9px; }

  /* ── Controls bar (date pickers) ────────────────────────────── */
  .pt-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    padding: 14px;
  }
  .pt-controls .ctrl-col { width: 100%; padding: 0; }
  .pt-controls .ctrl-sep { display: none; }
  .rp { flex-wrap: wrap; gap: 4px; }
  .rp-btn { padding: 8px 12px; font-size: 10px; }
  .pt-sel, select { width: 100%; max-width: 100%; }

  /* ── KPI row: 2x2 ──────────────────────────────────────────── */
  .pt-kpis { grid-template-columns: 1fr 1fr; gap: 1px; margin-bottom: 18px; }
  .pt-kpis .kpi { padding: 14px; }
  .kv { font-size: 22px; }
  .kl { font-size: 8px; }
  .ks { font-size: 9px; }

  /* ── Card grids: single column ──────────────────────────────── */
  .co-grid, .fl-grid, .ci-tiles {
    grid-template-columns: 1fr !important;
    gap: 1px;
  }
  .co-card, .fl-card, .ci-tile { padding: 16px; }
  .ci-tile-ratio { font-size: 26px; }

  /* ── Chart heights ──────────────────────────────────────────── */
  .cc-body, .ci-chart-frame { height: 260px; }
  canvas { max-width: 100%; }

  /* ── Capture index methodology ──────────────────────────────── */
  .ci-meth { display: block; }
  .ci-meth-row { display: block; margin-bottom: 22px; }
  .ci-meth-l { font-size: 9px; margin-bottom: 6px; }
  .ci-meth-b { font-size: 13px; line-height: 1.55; }
  .formula { font-size: 11px; word-break: break-word; }

  /* ── Chart fuel toggle wraps ────────────────────────────────── */
  .ci-chart-controls { flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
  .ci-chart-controls button { font-size: 9px; padding: 8px 10px; }

  /* ── Homepage tool cards stack ──────────────────────────────── */
  .tool-grid { grid-template-columns: 1fr; gap: 1px; }
  .tool-card { padding: 22px; }

  /* ── Plant detail page ──────────────────────────────────────── */
  .panel-tabs { flex-wrap: wrap; gap: 4px; }
  .panel-tab { font-size: 10px; padding: 8px 12px; }
  .meta-chip { font-size: 10px; padding: 6px 10px; }

  /* ── Request Access button full-width ───────────────────────── */
  .req-access-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 14px;
  }

  /* ── Tape smaller ───────────────────────────────────────────── */
  .tape, .tick { font-size: 8px; }

  /* ── Touch targets ──────────────────────────────────────────── */
  button, .pt-sel, select, .rp-btn { min-height: 38px; }


  /* ════════════════════════════════════════════════════════════
     TABLES → CARDS conversion on mobile.

     Every <td> in the JS-rendered tables now has a data-label="..."
     attribute. On mobile we hide the <thead> (column headers no
     longer make sense in a stacked layout) and turn each <tr> into
     a card by setting display:block. Each <td> shows its column
     label via a ::before pseudo-element on the left, and its value
     on the right.

     This applies to: plants.html main table, companies.html asset
     drilldown, capture-index.html full index, plant.html Top Days.
     ════════════════════════════════════════════════════════════ */

  /* The tables we want to convert. Excludes any layout-only or
     decorative tables — only data tables with data-label cells. */
  .pt-t,
  .asset-table,
  #ci-table,
  #top-days-tbl {
    display: block;
    width: 100%;
    border-collapse: separate;
  }
  .pt-t thead,
  .asset-table thead,
  #ci-table thead,
  #top-days-tbl thead {
    display: none;
  }
  .pt-t tbody,
  .asset-table tbody,
  #ci-table tbody,
  #top-days-tbl tbody {
    display: block;
  }
  .pt-t tr,
  .asset-table tr,
  #ci-table tr,
  #top-days-tbl tr {
    display: block;
    background: var(--surf);
    border: 1px solid var(--border);
    border-radius: 4px;
    margin-bottom: 8px;
    padding: 10px 14px;
  }
  .pt-t tr:hover td,
  .asset-table tr:hover td {
    background: transparent;
  }
  .pt-t td,
  .asset-table td,
  #ci-table td,
  #top-days-tbl td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: none;
    padding: 6px 0;
    text-align: right;
    font-size: 12px;
    color: var(--ink);
  }
  /* The label column on the left of each row, via ::before */
  .pt-t td::before,
  .asset-table td::before,
  #ci-table td::before,
  #top-days-tbl td::before {
    content: attr(data-label);
    font: 700 9px/1 var(--MN);
    letter-spacing: 0.10em;
    text-transform: uppercase;
    color: var(--muted);
    margin-right: 14px;
    flex: 0 0 auto;
  }
  /* Cells without data-label (shouldn't happen, but safe fallback) */
  .pt-t td:not([data-label])::before,
  .asset-table td:not([data-label])::before,
  #ci-table td:not([data-label])::before,
  #top-days-tbl td:not([data-label])::before {
    content: '';
    margin-right: 0;
  }

  /* The fuel-badge / link cells need a bit of allowance because they
     contain inline elements. */
  .pt-t td a, .asset-table td a { word-break: break-word; }

  /* Capture index: the "Zone" cell has a nested <span class="ci-zone-name">
     and a wind-type subtitle. Stack it cleanly. */
  #ci-table .ci-wind-type {
    margin-left: 0;
    margin-top: 4px;
  }
  /* Capture index section headers (Solar / Wind) — keep them visible */
  #ci-table tr.ci-fuel-head {
    background: transparent;
    border: none;
    padding: 16px 0 8px;
    margin-bottom: 0;
  }
  #ci-table tr.ci-fuel-head td {
    display: block;
    text-align: left;
    font: 700 10px/1 var(--MN);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--green);
    padding: 0;
  }
  #ci-table tr.ci-fuel-head td::before { content: ''; }

  /* Wrap any over-long tables in horizontal-scroll fallback as last resort,
     but only the OUTER container — never the table itself. */
  .pt-tw, .asset-section, .ci-table-wrap {
    overflow-x: visible;  /* don't force scroll, cards have their own width */
  }

  /* Footer */
  .ft { padding: 24px 18px; flex-direction: column; gap: 8px; align-items: flex-start; font-size: 9px; }
}


/* ── Tiny phones (≤ 380px) ───────────────────────────────────── */
@media (max-width: 380px) {
  .pt-h1 { font-size: 26px; }
  .ci-feature-h { font-size: 21px; }
  .pt-kpis { grid-template-columns: 1fr; }
  .ci-tile-grid-mini { grid-template-columns: 1fr; }
}
