/* ============================================================
   TGRU theme — bespoke light, developer/API-DOCS public stylesheet.
   Self-contained: does NOT load the shared app.css, so the admin
   palette is untouched. Public marketing pages only.
   System font stacks only — no external fonts/styles (strict CSP).
   Reads like a dev tool (Stripe/Twilio docs), not a marketing page.
   ============================================================ */
:root{
  --bg:#f8fafc; --bg2:#f1f5f9; --surface:#ffffff; --surface2:#f8fafc;
  --border:#e2e8f0; --border2:#cbd5e1;
  --txt:#0f172a; --muted:#64748b; --faint:#94a3b8;
  --teal:#0d9488; --teal2:#14b8a6; --emerald:#10b981;
  --ink:#0b1220;
  --ok:#0d9488; --warn:#d97706; --pend:#2563eb; --part:#db2777;
  --radius:14px; --maxw:1180px;
  --sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body.tg{
  background:var(--bg); color:var(--txt); font-family:var(--sans);
  line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.tg a{color:inherit;text-decoration:none}
.tg img{max-width:100%}
.dx-wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.dx-accent{color:var(--teal)}
.dx-mono{font-family:var(--mono)}
.dx-c-teal{color:var(--teal)}

/* ---- code-token colors (shared by every dark code surface) ---- */
.dx-c-mut{color:#64748b}.dx-c-cmd{color:var(--teal2)}.dx-c-str{color:#6ee7b7}
.dx-c-prop{color:#7dd3fc}.dx-c-val{color:#fbbf24}

/* ====================================================================
   BUTTONS
   ==================================================================== */
.dx-btn{
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  padding:9px 17px;border-radius:8px;font-weight:600;font-size:14.5px;
  background:var(--teal);color:#fff;border:1px solid var(--teal);cursor:pointer;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
  transition:transform .15s,box-shadow .15s,background .15s,border-color .15s;
  white-space:nowrap;
}
.dx-btn:hover{transform:translateY(-1px);background:var(--teal2);border-color:var(--teal2);box-shadow:0 8px 20px -8px rgba(13,148,136,.55)}
.dx-btn-lg{padding:13px 24px;font-size:15.5px;border-radius:9px}
.dx-btn-sm{padding:7px 14px;font-size:13.5px}
.dx-ghost{background:var(--surface);color:var(--txt);border:1px solid var(--border2);box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-ghost:hover{background:var(--surface);border-color:var(--teal);color:var(--teal);box-shadow:0 1px 2px rgba(15,23,42,.04)}

/* ====================================================================
   HEADER — docs-style, sticky, border-bottom
   ==================================================================== */
.dx-top{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.dx-top-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;height:58px;
  display:flex;align-items:center;gap:22px}
.dx-logo{display:inline-flex;align-items:center;gap:9px}
.dx-logo-name{font-family:var(--mono);font-weight:700;font-size:16px;letter-spacing:-.02em;color:var(--txt)}
.dx-ver{font-family:var(--mono);font-size:10.5px;font-weight:600;color:var(--teal);
  background:rgba(13,148,136,.1);border:1px solid rgba(13,148,136,.22);
  padding:1px 6px;border-radius:5px;line-height:1.4}
.dx-nav{margin-left:14px;display:flex;align-items:center;gap:22px;flex:1}
.dx-nav-link{color:var(--muted);font-size:14px;font-weight:500;transition:color .15s}
.dx-nav-link:hover{color:var(--txt)}
.dx-nav-actions{margin-left:auto;display:flex;align-items:center;gap:12px}
.dx-search{display:inline-flex;align-items:center;gap:8px;
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  padding:6px 9px 6px 11px;color:var(--faint);font-size:13px;cursor:text}
.dx-search-ico{font-size:14px;line-height:1}
.dx-search-label{color:var(--muted)}
.dx-kbd{font-family:var(--mono);font-size:10.5px;color:var(--muted);
  background:var(--surface);border:1px solid var(--border2);border-bottom-width:2px;
  border-radius:5px;padding:1px 5px;line-height:1.5}
.dx-nav-signin{color:var(--muted);font-size:14px;font-weight:500;transition:color .15s}
.dx-nav-signin:hover{color:var(--txt)}
.dx-burger{display:none;margin-left:auto;background:none;border:0;cursor:pointer;
  flex-direction:column;gap:5px;padding:6px}
.dx-burger span{width:22px;height:2px;background:var(--txt);border-radius:2px;transition:.2s}

/* ====================================================================
   HERO — split: copy left, CSS-only tabbed code card right
   ==================================================================== */
.dx-hero{position:relative;padding:74px 0 60px;overflow:hidden}
.dx-grid-bg{position:absolute;inset:0;
  background-image:linear-gradient(rgba(15,23,42,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.04) 1px,transparent 1px);
  background-size:38px 38px;
  mask-image:radial-gradient(ellipse 78% 62% at 30% 22%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 78% 62% at 30% 22%,#000,transparent 80%);
  pointer-events:none}
.dx-hero-inner{position:relative;display:grid;grid-template-columns:1.02fr .98fr;gap:46px;align-items:center}
.dx-eyebrow{display:inline-block;font-family:var(--mono);font-size:12px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--teal);
  background:rgba(13,148,136,.07);border:1px solid rgba(13,148,136,.2);
  padding:5px 11px;border-radius:7px;margin-bottom:18px}
.dx-hero-copy h1{font-size:clamp(31px,4.6vw,50px);line-height:1.08;letter-spacing:-.03em;margin:0;font-weight:800}
.dx-lede{color:var(--muted);font-size:17.5px;max-width:540px;margin:18px 0 26px}
.dx-hero-cta{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:24px}
.dx-inline-cmd{display:block;font-family:var(--mono);font-size:13px;color:var(--txt);
  background:var(--surface);border:1px solid var(--border);border-radius:9px;
  padding:11px 14px;overflow:auto;white-space:pre;
  box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-inline-cmd .dx-c-str{color:var(--teal)}

/* ---- tabbed code card (radio + :checked, pure CSS) ---- */
.dx-codecard{background:var(--ink);border:1px solid #1e293b;border-radius:var(--radius);
  overflow:hidden;box-shadow:0 30px 60px -28px rgba(15,23,42,.4),0 2px 6px rgba(15,23,42,.08)}
.dx-codecard-chrome{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#111a2b;border-bottom:1px solid #1e293b}
.dx-dot{width:11px;height:11px;border-radius:50%;background:#334155}
.dx-dot:nth-child(1){background:#ff5f57}.dx-dot:nth-child(2){background:#febc2e}.dx-dot:nth-child(3){background:#28c840}
.dx-chrome-title{margin-left:8px;color:#94a3b8;font-size:12px;font-family:var(--mono)}
.dx-tabs{position:relative}
.dx-tab-radio{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.dx-tablist{display:flex;gap:2px;padding:8px 10px 0;background:#0d1626;border-bottom:1px solid #1e293b}
.dx-tablabel{font-family:var(--mono);font-size:12px;color:#64748b;padding:7px 13px;cursor:pointer;
  border:1px solid transparent;border-bottom:0;border-radius:7px 7px 0 0;transition:color .15s,background .15s;
  margin-bottom:-1px}
.dx-tablabel:hover{color:#cbd5e1}
.dx-tabpanel{margin:0;padding:20px 22px;overflow:auto;font-family:var(--mono);
  font-size:13px;line-height:1.75;color:#cbd5e1;white-space:pre;display:none}
/* :checked → light the matching label + show its panel */
#dx-lang-curl:checked~.dx-tablist label[for="dx-lang-curl"],
#dx-lang-py:checked~.dx-tablist label[for="dx-lang-py"],
#dx-lang-node:checked~.dx-tablist label[for="dx-lang-node"]{
  color:#e2e8f0;background:var(--ink);border-color:#1e293b}
#dx-lang-curl:checked~.dx-panel-curl,
#dx-lang-py:checked~.dx-panel-py,
#dx-lang-node:checked~.dx-panel-node{display:block}
.dx-codecard-foot{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;
  border-top:1px solid #1e293b;background:#111a2b;color:#64748b;font-size:12px}
.dx-live{display:inline-flex;align-items:center;gap:6px;color:var(--emerald)}

/* ---- shared green pulse ---- */
.dx-pulse{width:8px;height:8px;border-radius:50%;background:var(--emerald);flex:0 0 auto;
  box-shadow:0 0 0 0 rgba(16,185,129,.5);animation:dxpulse 2.2s infinite}
@keyframes dxpulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.5)}70%{box-shadow:0 0 0 7px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}

/* ====================================================================
   SECTIONS — left-aligned docs section heads
   ==================================================================== */
.dx-section{padding:58px 24px}
.dx-shead{margin:0 0 28px;max-width:760px}
.dx-shead h2{font-size:clamp(23px,3vw,32px);line-height:1.14;letter-spacing:-.02em;margin:8px 0 0;font-weight:800}

/* ---- 2. endpoints (devtool list) ---- */
.dx-endpoints{display:flex;flex-direction:column;gap:0;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-ep{display:grid;grid-template-columns:64px 190px 1fr;align-items:center;gap:16px;
  padding:15px 20px;border-top:1px solid var(--border);transition:background .15s}
.dx-ep:first-child{border-top:0}
.dx-ep:hover{background:var(--bg2)}
.dx-method{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.04em;
  text-align:center;padding:3px 0;border-radius:6px}
.dx-m-get{color:#0369a1;background:rgba(2,132,199,.1);border:1px solid rgba(2,132,199,.2)}
.dx-m-post{color:var(--teal);background:rgba(13,148,136,.1);border:1px solid rgba(13,148,136,.22)}
.dx-path{font-family:var(--mono);font-size:14px;font-weight:600;color:var(--txt)}
.dx-ep-desc{color:var(--muted);font-size:14.5px}

/* ---- 3. quickstart (numbered steps + mono snippets) ---- */
.dx-quick{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.dx-qstep{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;transition:border-color .18s,box-shadow .18s}
.dx-qstep:hover{border-color:var(--border2);box-shadow:0 12px 30px -22px rgba(15,23,42,.35)}
.dx-qnum{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--teal);
  display:inline-block;padding:3px 9px;border:1px solid var(--border);border-radius:7px;background:var(--bg2)}
.dx-qstep h3{font-size:16px;margin:13px 0 7px;font-weight:700;letter-spacing:-.01em}
.dx-qstep p{color:var(--muted);font-size:14px;margin:0 0 14px}
.dx-snip{margin:0;background:var(--ink);border:1px solid #1e293b;border-radius:9px;
  padding:12px 14px;overflow:auto;font-family:var(--mono);font-size:12.5px;line-height:1.65;
  color:#cbd5e1;white-space:pre}

/* ---- 4. status board (4 tiles) ---- */
.dx-board{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.dx-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;display:flex;flex-direction:column;gap:8px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);transition:border-color .18s,box-shadow .18s}
.dx-tile:hover{border-color:var(--teal);box-shadow:0 14px 34px -24px rgba(13,148,136,.4)}
.dx-tile-top{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}
.dx-tile-state{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--emerald)}
.dx-tile-fig{font-size:12.5px;color:var(--faint)}

/* ---- 5. built for developers (4-card grid) ---- */
.dx-feat{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.dx-fcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;transition:transform .18s,border-color .18s,box-shadow .18s}
.dx-fcard:hover{transform:translateY(-3px);border-color:var(--teal);box-shadow:0 18px 40px -24px rgba(13,148,136,.45)}
.dx-feat-mark{display:inline-flex;align-items:center;justify-content:center;
  min-width:38px;height:38px;padding:0 9px;border-radius:10px;margin-bottom:13px;
  font-size:14px;font-weight:700;color:var(--teal);
  background:rgba(13,148,136,.08);border:1px solid rgba(13,148,136,.2)}
.dx-fcard h3{font-size:15px;margin:0 0 7px;font-weight:700;letter-spacing:-.01em}
.dx-fcard p{color:var(--muted);font-size:13.5px;margin:0;line-height:1.55}

/* ---- 6. CTA ---- */
.dx-cta{display:grid;grid-template-columns:.9fr 1.1fr;gap:32px;align-items:center;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:38px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-cta-copy h2{font-size:clamp(24px,3vw,32px);line-height:1.12;letter-spacing:-.02em;margin:0 0 12px;font-weight:800}
.dx-cta-copy p{color:var(--muted);font-size:16px;margin:0 0 20px;max-width:380px}
.dx-cta-code{margin:0;background:var(--ink);border:1px solid #1e293b;border-radius:var(--radius);
  padding:20px 22px;overflow:auto;font-family:var(--mono);font-size:13px;line-height:1.7;
  color:#cbd5e1;white-space:pre;
  box-shadow:0 24px 50px -34px rgba(15,23,42,.4)}

/* ====================================================================
   FOOTER — developer-docs style
   ==================================================================== */
.dx-foot{border-top:1px solid var(--border);background:var(--surface);padding:50px 24px 26px}
.dx-foot-inner{max-width:var(--maxw);margin:0 auto}
.dx-foot-top{display:grid;grid-template-columns:1.5fr 2.5fr;gap:40px}
.dx-logo-foot{margin-bottom:14px}
.dx-foot-tag{color:var(--muted);font-size:13.5px;max-width:300px;margin:0 0 16px;line-height:1.55}
.dx-foot-status{display:inline-flex;align-items:center;gap:8px;color:var(--emerald);font-size:13px}
.dx-foot-status .dx-mono{color:var(--muted)}
.dx-foot-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.dx-foot-col h4{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--faint);
  margin:0 0 13px;font-family:var(--mono);font-weight:600}
.dx-foot-col a{display:block;color:var(--muted);font-size:13.5px;margin-bottom:9px;transition:color .15s}
.dx-foot-col a:hover{color:var(--teal)}
.dx-foot-base{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  margin-top:36px;padding-top:20px;border-top:1px solid var(--border);
  color:var(--faint);font-size:12.5px}
.dx-foot-base-r{color:var(--faint)}

/* ====================================================================
   SCROLL REVEAL (progressive — content shows without JS)
   ==================================================================== */
.has-js .reveal,.has-js .reveal-group>*{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.has-js .reveal.in,.has-js .reveal-group.in>*{opacity:1;transform:none}
.has-js .reveal-group.in>*:nth-child(2){transition-delay:.07s}
.has-js .reveal-group.in>*:nth-child(3){transition-delay:.14s}
.has-js .reveal-group.in>*:nth-child(4){transition-delay:.21s}
.has-js .reveal-group.in>*:nth-child(5){transition-delay:.28s}
.has-js .reveal-group.in>*:nth-child(6){transition-delay:.35s}

/* ====================================================================
   RESPONSIVE  (≤900px — working mobile nav)
   ==================================================================== */
@media(max-width:900px){
  .dx-burger{display:flex}
  .dx-nav{position:fixed;inset:58px 0 auto;margin:0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(255,255,255,.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);
    box-shadow:0 18px 30px -22px rgba(15,23,42,.4);
    padding:8px 24px 18px;transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s}
  .dx-nav.open{transform:none;opacity:1;pointer-events:auto}
  .dx-nav-link{padding:13px 0;border-bottom:1px solid var(--border)}
  .dx-nav-actions{margin:14px 0 0;flex-direction:column;align-items:stretch;gap:10px}
  .dx-search{justify-content:flex-start}
  .dx-nav-signin{padding:6px 0}
  .dx-nav-actions .dx-btn{text-align:center}

  .dx-hero-inner{grid-template-columns:1fr;gap:34px}
  .dx-codecard{order:2}
  .dx-quick,.dx-feat{grid-template-columns:1fr 1fr}
  .dx-board{grid-template-columns:1fr 1fr}
  .dx-cta{grid-template-columns:1fr;gap:24px;padding:28px}
  .dx-ep{grid-template-columns:60px 1fr;gap:10px 14px}
  .dx-ep-desc{grid-column:1 / -1;margin-top:2px}
  .dx-foot-top{grid-template-columns:1fr;gap:30px}
  .dx-foot-cols{grid-template-columns:1fr 1fr;gap:24px}
}
@media(max-width:560px){
  .dx-quick,.dx-feat,.dx-board{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .has-js .reveal,.has-js .reveal-group>*{opacity:1;transform:none;transition:none}
  .dx-pulse{animation:none}
  .dx-btn:hover,.dx-fcard:hover,.dx-tile:hover,.dx-qstep:hover{transform:none}
}

/* ====================================================================
   SERVICES — developer/docs data table with a mono filter toolbar
   (utility page: /services). Owned by the tgru theme.
   ==================================================================== */
.dx-svc-head{padding-bottom:18px}
.dx-svc-head .dx-shead{margin-bottom:14px}
.dx-svc-head h1{font-size:clamp(28px,4vw,42px);line-height:1.1;letter-spacing:-.03em;margin:6px 0 0;font-weight:800}
.dx-svc-head .dx-lede{margin:14px 0 18px}
.dx-svc-auth{display:inline-flex;align-items:center;gap:9px;font-size:13.5px;color:var(--muted);
  background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 14px;
  box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-svc-auth b{color:var(--txt)}

/* ---- filter toolbar ---- */
.dx-svc-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:14px 16px;margin-bottom:22px;
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-svc-search{display:flex;align-items:center;gap:9px;flex:1;min-width:220px;
  background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:0 12px;cursor:text}
.dx-svc-search-ico{font-size:15px;color:var(--faint);line-height:1}
.dx-svc-search input{flex:1;border:0;background:none;outline:none;color:var(--txt);
  font-family:var(--mono);font-size:13.5px;padding:11px 0}
.dx-svc-search input::placeholder{color:var(--faint)}
.dx-svc-select-wrap{display:inline-flex;align-items:center;gap:7px;
  background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:0 11px}
.dx-svc-select-wrap select{border:0;background:none;outline:none;color:var(--txt);
  font-family:var(--mono);font-size:13.5px;padding:11px 4px 11px 0;cursor:pointer}
.dx-svc-count{margin-left:auto;color:var(--faint);font-size:12.5px;white-space:nowrap}

/* ---- catalog groups + table ---- */
.dx-svc-catalog{padding-bottom:54px;display:flex;flex-direction:column;gap:30px}
.dx-svc-group-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:0 0 11px}
.dx-svc-group-head h2{font-size:16px;font-weight:700;letter-spacing:-.01em;margin:0;color:var(--txt)}
.dx-svc-grp-count{color:var(--faint);font-size:12px}
.dx-svc-table-wrap{overflow-x:auto;background:var(--surface);border:1px solid var(--border);
  border-radius:12px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-svc-table{width:100%;border-collapse:collapse;font-size:14px}
.dx-svc-table thead th{text-align:left;font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.04em;color:var(--faint);text-transform:lowercase;
  padding:11px 16px;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface2)}
.dx-svc-table tbody td{padding:13px 16px;border-top:1px solid var(--border);color:var(--txt);vertical-align:middle}
.dx-svc-table tbody tr:first-child td{border-top:0}
.dx-svc-table tbody tr:hover{background:var(--bg2)}
.dx-svc-num{text-align:right;white-space:nowrap}
.dx-svc-c-id{width:74px}
.dx-svc-c-act{width:1%;white-space:nowrap;text-align:right}
.dx-svc-c-id code{font-size:12.5px}
.dx-svc-name{font-weight:600;letter-spacing:-.01em}
.dx-tag{display:inline-block;font-family:var(--mono);font-size:11px;font-weight:600;color:var(--teal);
  background:rgba(13,148,136,.08);border:1px solid rgba(13,148,136,.2);
  padding:2px 8px;border-radius:6px;line-height:1.5;white-space:nowrap}
.dx-svc-empty{padding:40px 18px;text-align:center;color:var(--faint);font-size:14px;
  background:var(--surface);border:1px dashed var(--border2);border-radius:12px}

/* ====================================================================
   API REFERENCE — endpoints list + per-endpoint try-it disclosure
   (utility page: /api). Owned by the tgru theme. The .fs-toc / .fs-sec
   hooks are layout-neutral here (admin-api-tab.js only reads them).
   ==================================================================== */
.dx-api{display:grid;grid-template-columns:230px 1fr;gap:40px;align-items:start;
  padding-top:40px;padding-bottom:60px}
.dx-api-toc{position:sticky;top:78px;display:flex;flex-direction:column;gap:1px;
  max-height:calc(100vh - 100px);overflow:auto}
.dx-api-toc-title{font-size:11px;letter-spacing:.06em;margin:0 0 8px;padding:0 10px}
.dx-api-toc a{display:block;padding:6px 10px;border-radius:7px;color:var(--muted);
  font-size:13px;border-left:2px solid transparent;transition:color .15s,background .15s,border-color .15s}
.dx-api-toc a:hover{color:var(--txt);background:var(--bg2)}
.dx-api-toc a.active{color:var(--teal);background:rgba(13,148,136,.07);border-left-color:var(--teal);font-weight:600}

.dx-api-body{min-width:0;display:flex;flex-direction:column;gap:26px}
.dx-api-header h1{font-size:clamp(26px,3.4vw,38px);line-height:1.1;letter-spacing:-.03em;margin:6px 0 0;font-weight:800}
.dx-api-header .dx-lede{margin:14px 0 0}
.dx-api-header code{font-family:var(--mono);font-size:.86em;color:var(--teal);
  background:rgba(13,148,136,.08);border:1px solid rgba(13,148,136,.18);padding:1px 5px;border-radius:5px}

/* ---- endpoint block ---- */
.dx-ep-block{scroll-margin-top:80px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px 22px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.dx-ep-head{display:flex;align-items:center;gap:11px;flex-wrap:wrap}
.dx-ep-head .dx-method{min-width:54px}
.dx-m-get.dx-method,.dx-method.dx-m-get{color:#0369a1;background:rgba(2,132,199,.1);border:1px solid rgba(2,132,199,.2)}
.dx-ep-head .dx-path{font-size:13.5px;color:var(--txt);overflow:auto}
.dx-ep-head .dx-path .dx-accent{color:var(--teal)}
.dx-ep-title{font-size:17px;font-weight:700;letter-spacing:-.01em;margin:13px 0 4px}
.dx-ep-lede{color:var(--muted);font-size:14px;margin:8px 0 0;line-height:1.55}
.dx-ep-lede code,.dx-api-note code{font-family:var(--mono);font-size:.86em;color:var(--teal);
  background:rgba(13,148,136,.08);border:1px solid rgba(13,148,136,.18);padding:1px 5px;border-radius:5px}

/* ---- params table ---- */
.dx-api-tbl{width:100%;border-collapse:collapse;font-size:13.5px;margin-top:14px}
.dx-api-tbl thead th{text-align:left;font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.04em;color:var(--faint);text-transform:lowercase;
  padding:9px 12px;border-bottom:1px solid var(--border);background:var(--surface2)}
.dx-api-tbl td{padding:10px 12px;border-top:1px solid var(--border);color:var(--muted);vertical-align:top}
.dx-api-tbl tbody tr:first-child td{border-top:0}
.dx-api-tbl td:first-child{color:var(--txt);font-weight:600;width:200px;white-space:nowrap}
.dx-api-tbl td code{font-family:var(--mono);font-size:.9em;color:var(--teal)}
.dx-api-tbl tr.dx-opt td:first-child{font-weight:500}
.dx-opt-tag{font-family:var(--mono);font-size:10px;font-weight:600;color:var(--warn);
  background:rgba(217,119,6,.08);border:1px solid rgba(217,119,6,.2);
  padding:0 5px;border-radius:5px;margin-left:6px;text-transform:uppercase;letter-spacing:.04em}
.dx-api-note{font-size:13px;line-height:1.55;margin:13px 0 0}
.dx-api-note a{color:var(--teal)}

/* ---- try-it disclosure (CSS-only <details>) ---- */
.dx-tryit{margin-top:14px;border:1px solid #1e293b;border-radius:10px;overflow:hidden;background:var(--ink)}
.dx-tryit-sum{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;
  color:#cbd5e1;font-size:12px;list-style:none;user-select:none;background:#111a2b;border-bottom:1px solid transparent}
.dx-tryit-sum::-webkit-details-marker{display:none}
.dx-tryit[open] .dx-tryit-sum{border-bottom-color:#1e293b}
.dx-tryit-sum:hover{color:#e2e8f0}
.dx-tryit .dx-snip{margin:0;border:0;border-radius:0;box-shadow:none}

/* ====================================================================
   AUTH — terminal-panel sign-in / sign-up / forgot (light bg).
   Owned by the tgru theme; consistent across the three pages.
   ==================================================================== */
body.tg.auth{display:flex;flex-direction:column;min-height:100vh}
body.tg.auth .dx-foot{margin-top:auto}
.dx-auth{position:relative;padding:64px 24px 72px;overflow:hidden}
.dx-auth-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  max-width:var(--maxw);margin:0 auto}
.dx-auth-rail .dx-mono{display:inline-block;margin-bottom:14px}
.dx-auth-h1{font-size:clamp(26px,3.4vw,40px);line-height:1.1;letter-spacing:-.03em;margin:0;font-weight:800}
.dx-auth-rail .dx-lede{margin:16px 0 22px;font-size:16px}
.dx-auth-snip{max-width:440px}

/* ---- terminal card ---- */
.dx-term{background:var(--ink);border:1px solid #1e293b;border-radius:var(--radius);overflow:hidden;
  box-shadow:0 30px 60px -28px rgba(15,23,42,.45),0 2px 6px rgba(15,23,42,.08);max-width:440px;width:100%;justify-self:end}
.dx-term-chrome{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#111a2b;border-bottom:1px solid #1e293b}
.dx-term-title{margin-left:8px;color:#94a3b8;font-size:12px}
.dx-term-body{padding:22px 22px 24px}
.dx-term-line{color:#cbd5e1;font-size:13px;margin:0 0 18px}
.dx-term-line .dx-c-mut{color:#64748b;margin-right:6px}

.dx-auth-form{display:flex;flex-direction:column;gap:15px}
.dx-field{display:flex;flex-direction:column;gap:6px}
.dx-field-label{font-size:12px;color:#94a3b8;letter-spacing:.02em}
.dx-field-label .dx-c-mut{color:#64748b}
.dx-input{width:100%;background:#0d1626;border:1px solid #1e293b;border-radius:9px;
  color:#e2e8f0;font-size:14px;padding:11px 13px;outline:none;
  transition:border-color .15s,box-shadow .15s}
.dx-input::placeholder{color:#475569}
.dx-input:focus{border-color:var(--teal2);box-shadow:0 0 0 3px rgba(20,184,166,.18)}
.dx-auth-submit{width:100%;justify-content:center;margin-top:4px}

.dx-alert{font-size:12.5px;line-height:1.5;border-radius:9px;padding:10px 12px}
.dx-alert-err{color:#fda4af;background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.28)}
.dx-alert-ok{color:#6ee7b7;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.28)}

.dx-auth-links{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;
  margin-top:6px;font-size:12.5px;color:#64748b}
.dx-auth-links a{color:var(--teal2)}
.dx-auth-links a:hover{color:#5eead4}
.dx-auth-alt{color:#64748b}

/* ====================================================================
   RESPONSIVE (utility + auth pages) — ≤900px
   ==================================================================== */
@media(max-width:900px){
  .dx-api{grid-template-columns:1fr;gap:22px}
  .dx-api-toc{position:static;flex-direction:row;flex-wrap:wrap;gap:4px;max-height:none;
    padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px}
  .dx-api-toc-title{flex-basis:100%;margin-bottom:4px}
  .dx-api-toc a{border-left:0;border-bottom:2px solid transparent}
  .dx-api-toc a.active{border-left:0;border-bottom-color:var(--teal)}

  .dx-auth-grid{grid-template-columns:1fr;gap:30px}
  .dx-auth-rail{order:2}
  .dx-term{order:1;justify-self:stretch;max-width:none}
  .dx-svc-count{margin-left:0;flex-basis:100%}
}
@media(max-width:560px){
  .dx-api-tbl td:first-child{width:auto}
  .dx-auth{padding:40px 18px 52px}
}
@media(prefers-reduced-motion:reduce){
  .dx-svc-table tbody tr:hover,.dx-api-toc a:hover{transition:none}
}
