/* ====================================================================
   HandyConvert â€” Trades / Engineering surface  (v3, "pharma lab" look)
   Sky-blue accent palette on white. True 0px corners. Soft hairline
   borders (#E0F2FE / sky-100), with sky-blue (#0284C7) reserved for
   action / focus / result emphasis. Designed so each tool fits a
   single viewport on a typical 13"â€“15" laptop screen.
   ==================================================================== */

/* v3 pharma-lab design tokens. Originally scoped to [data-category="trades"];
   promoted to :root on 2026-06-06 so the same sky-blue palette + 0-radius
   geometry applies to every page on the site (cooking, finance, dimensions,
   info pages — and trades). Trades-specific page layouts below (main,
   .container, .page-head) remain scoped to [data-category="trades"]. */
:root {
  /* Surfaces (all white) */
  --bg:              #FFFFFF;
  --surface:         #FFFFFF;
  --surface-tint:    #F0F9FF;   /* sky-50 â€” subtle wash on result panel */

  /* Borders â€” soft sky-blue hairlines */
  --border:          #E0F2FE;   /* sky-100 */
  --border-mid:      #BAE6FD;   /* sky-200 */
  --border-strong:   #7DD3FC;   /* sky-300 */

  /* Text â€” near-black, slate gray */
  --text:            #0F172A;   /* slate-900 */
  --text-muted:      #475569;   /* slate-600 */
  --text-subtle:     #94A3B8;   /* slate-400 */

  /* Accent â€” sky-blue */
  --accent:          #0284C7;   /* sky-600 */
  --accent-strong:   #0369A1;   /* sky-700 */
  --accent-light:    #38BDF8;   /* sky-400 */
  --accent-soft:     #F0F9FF;   /* sky-50 */
  --on-accent:       #FFFFFF;

  /* Status */
  --ok:              #16A34A;
  --warn:            #EAB308;
  --danger:          #DC2626;

  /* Geometry â€” square, period */
  --radius:          0;
  --radius-sm:       0;
  --radius-md:       0;

  --shadow:          none;
  --font-mono:       'IBM Plex Mono', ui-monospace, SFMono-Regular,
                     'Menlo', 'Consolas', monospace;
}

/* ---- Page-level container ---------------------------------------- */
[data-category="trades"] main { padding: 0; }
[data-category="trades"] .container {
  max-width: 1100px;          /* wider so side-by-side fits well */
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
}

/* ---- Page head â€” calm, lab-document tone ------------------------- */
[data-category="trades"] .page-head {
  padding: 20px 0 14px;
  margin: 0 0 16px;
  border-bottom: 1px solid var(--border);
}
[data-category="trades"] .page-head h1 {
  font: 500 22px/1.2 var(--font);
  letter-spacing: -0.01em;
  color: var(--text);
  margin: 0;
}
[data-category="trades"] .page-head .subhead {
  font: 400 13.5px/1.4 var(--font);
  color: var(--text-muted);
  margin: 4px 0 0;
}
[data-category="trades"] .page-head--compact { padding: 14px 0 10px; margin: 0 0 12px; }
[data-category="trades"] .page-head--compact h1 { font-size: 20px; }

/* ---- Headings on the page --------------------------------------- */
[data-category="trades"] h2 {
  font: 600 16px/1.2 var(--font);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 12px;
}
[data-category="trades"] h3 {
  font: 600 14px/1.3 var(--font);
  color: var(--text);
  margin: 12px 0 6px;
}
[data-category="trades"] section + section { margin-top: 24px; }

/* ====================================================================
   SECTION-LABEL CHIP
   A small kicker label (e.g. "INPUTS", "ANSWER") that sits at the
   top of a panel as a colored tab.
   ==================================================================== */
.v3-label {
  display: inline-block;
  background: var(--accent);
  color: var(--on-accent);
  font: 600 10px/1 var(--font);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 5px 10px;
  margin: 0 0 12px;
}

/* ====================================================================
   THE TOOL â€” side-by-side INPUTS | ANSWER on desktop, stacked on mobile
   ==================================================================== */
.v3-tool {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 0;
}
@media (min-width: 760px) {
  .v3-tool {
    grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.15fr);
    gap: 0;
    border: 1px solid var(--border);
  }
  .v3-tool > .v3-panel + .v3-panel {
    border-left: 1px solid var(--border);
  }
}

.v3-panel {
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 16px 18px 18px;
}
@media (min-width: 760px) {
  .v3-panel { border: 0; }
}
.v3-panel--answer {
  background: var(--surface-tint);   /* very pale sky wash */
  display: flex;
  flex-direction: column;
}
/* The answer's inner content div (rendered from <template x-if="result">)
   becomes a flex column that fills the remaining panel height â€” so the
   readouts + actions block can pin itself to the bottom regardless of how
   tall the inputs column is. */
.v3-panel--answer > div:not(.v3-empty) {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.v3-panel--answer > div:not(.v3-empty) > .v3-readouts {
  margin-top: auto;
}

/* ====================================================================
   INPUTS â€” labels above fields, vertical stacking inside the panel
   ==================================================================== */
.v3-field { margin: 0 0 12px; }
.v3-field:last-child { margin-bottom: 0; }

.v3-field__label {
  display: block;
  font: 600 10px/1 var(--font);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 6px;
}
.v3-field__hint {
  display: block;
  font: 400 12px/1.4 var(--font);
  color: var(--text-subtle);
  margin: 8px 0 0;
}

.v3-input {
  width: 100%;
  height: 40px;
  padding: 0 12px;
  background: var(--bg);
  color: var(--text);
  border: 1px solid var(--border-mid);
  border-radius: 0;
  font: 500 16px/1.4 var(--font-mono);
  font-variant-numeric: tabular-nums;
  transition: border-color 80ms ease;
}
/* Native number-input spinner arrows are left ON site-wide.
   Sliders are added below each number input as an alternative;
   users can pick whichever interaction model they prefer.
   (Removed the spinner-hiding rule on 2026-06-08.) */

.v3-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent);
}

/* ---- Operator picker â€” joined row of 4 buttons -------------------- */
.v3-ops {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--border-mid);
}
.v3-op {
  appearance: none;
  background: var(--bg);
  border: 0;
  border-right: 1px solid var(--border-mid);
  height: 40px;
  font: 500 16px/1 var(--font-mono);
  color: var(--text-muted);
  cursor: pointer;
  transition: background 80ms ease, color 80ms ease;
}
.v3-op:last-child { border-right: 0; }
.v3-op:hover { color: var(--accent); background: var(--accent-soft); }
.v3-op[aria-pressed="true"] {
  background: var(--accent);
  color: var(--on-accent);
}

/* ====================================================================
   ANSWER PANEL
   ==================================================================== */
.v3-equation {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px 10px;
  background: var(--bg);
  border: 1px solid var(--border-strong);
  padding: 14px 16px;
  font: 500 22px/1.2 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text);
  margin: 0 0 10px;
}
.v3-equation__op { color: var(--accent); }
.v3-equation__eq { color: var(--text-subtle); }
.v3-equation__r { color: var(--accent-strong); font-weight: 700; }

/* --------------------------------------------------------------------
   Roof-pitch gable visualization â€” inline SVG inside the answer panel.
   The ridge point's y-coordinate is reactively bound to pitch; CSS
   transitions on the SVG geometry attributes (y2, cy, y) tween smoothly
   in Chromium 96+, Firefox 88+, Safari 16+. Older browsers snap â€” fine.
   -------------------------------------------------------------------- */
.v3-roof-viz {
  background: var(--accent-soft, #F0F9FF);
  border: 1px solid var(--border);
  padding: 12px 14px 6px;
  margin: 0 0 12px;
}
.v3-roof-viz svg:not(.v3-gizmo-svg) {
  display: block;
  width: 100%;
  height: auto;
  max-width: 440px;
  margin: 0 auto;
  overflow: visible;
}
.v3-roof-viz line,
.v3-roof-viz circle,
.v3-roof-viz text,
.v3-roof-viz path {
  transition: x1 360ms cubic-bezier(.4,0,.2,1),
              y1 360ms cubic-bezier(.4,0,.2,1),
              x2 360ms cubic-bezier(.4,0,.2,1),
              y2 360ms cubic-bezier(.4,0,.2,1),
              cx 360ms cubic-bezier(.4,0,.2,1),
              cy 360ms cubic-bezier(.4,0,.2,1),
              x  360ms cubic-bezier(.4,0,.2,1),
              y  360ms cubic-bezier(.4,0,.2,1),
              d  360ms cubic-bezier(.4,0,.2,1);
}
.v3-roof-viz__ground { stroke: #94a3b8; stroke-width: 1.25; }
.v3-roof-viz__wall   { fill: #fff; stroke: #cbd5e1; stroke-width: 1.25; }
.v3-roof-viz__rafter {
  stroke: var(--accent, #0284C7);
  stroke-width: 2.5;
  stroke-linecap: square;
  fill: none;
}
.v3-roof-viz__rise,
.v3-roof-viz__run {
  stroke: #94a3b8;
  stroke-width: 1;
  stroke-dasharray: 3 3;
}
.v3-roof-viz__ridge {
  fill: var(--accent-strong, #0369a1);
  stroke: #fff;
  stroke-width: 1.5;
}
.v3-roof-viz__angle-arc {
  stroke: var(--accent, #0284C7);
  stroke-width: 1.25;
  fill: none;
}
/* --- Interactive 3D house faces (z-sorted, painter's algorithm) --- */
.v3-roof-viz--interactive { position: relative; }
.v3-roof-viz__svg { display: block; }
.v3-roof-viz__face {
  stroke: #94a3b8;
  stroke-width: 1.25;
  stroke-linejoin: miter;
}
.v3-roof-viz__face--wall-front,
.v3-roof-viz__face--wall-back  { fill: #ffffff; }
.v3-roof-viz__face--wall-right,
.v3-roof-viz__face--wall-left  { fill: #f1f5f9; }
.v3-roof-viz__face--roof-right,
.v3-roof-viz__face--roof-left  {
  fill: #7dd3fc; fill-opacity: 0.75;
  stroke: var(--accent-strong, #0369a1);
  stroke-width: 1.5;
}
.v3-roof-viz__reset {
  position: absolute;
  top: 10px; right: 10px;
  background: #ffffff;
  border: 1px solid var(--border, #E0F2FE);
  color: var(--accent-strong, #0369a1);
  font: 600 10.5px/1 var(--font);
  letter-spacing: 0.04em;
  padding: 6px 9px;
  cursor: pointer;
  text-transform: uppercase;
}
.v3-roof-viz__reset:hover { background: var(--accent-soft, #F0F9FF); }
.v3-roof-viz__reset:focus-visible {
  outline: 2px solid var(--accent, #0284C7); outline-offset: 1px;
}
.v3-roof-viz__reset:disabled {
  opacity: 0.35; cursor: not-allowed;
}
.v3-roof-viz__tools {
  position: absolute;
  top: 10px; right: 10px;
  display: flex; gap: 6px;
}
.v3-roof-viz__tools .v3-roof-viz__reset {
  position: static;
}

/* --- XYZ axis gizmo (shared between roof + board-feet diagrams).
       Lives in its own absolutely-positioned SVG in the bottom-left of
       the figure, clear of the main diagram. Three colored axes (X red,
       Y green, Z blue) with clickable handles that snap the view along
       that axis. --- */
.v3-gizmo-svg {
  position: absolute;
  bottom: 32px;        /* clears the figcaption */
  left: 10px;
  width: 60px;
  height: 60px;
  overflow: visible;
  background: #ffffff;
  border: 1px solid var(--border, #E0F2FE);
  padding: 2px;
}
.v3-gizmo__axis {
  stroke-width: 2; fill: none; stroke-linecap: round;
}
.v3-gizmo__axis--x { stroke: #ef4444; }   /* red */
.v3-gizmo__axis--y { stroke: #22c55e; }   /* green */
.v3-gizmo__axis--z { stroke: #3b82f6; }   /* blue */
.v3-gizmo__handle {
  cursor: pointer; stroke: #ffffff; stroke-width: 1.5;
  transition: r 120ms ease;
}
.v3-gizmo__handle--x { fill: #ef4444; }
.v3-gizmo__handle--y { fill: #22c55e; }
.v3-gizmo__handle--z { fill: #3b82f6; }
.v3-gizmo__handle:hover { r: 10; stroke: #facc15; stroke-width: 2; }
.v3-gizmo__label {
  font: 700 9px var(--font-mono);
  fill: #ffffff;
  pointer-events: none;
  user-select: none;
}

/* --- Range slider (sky-blue thumb, hairline track) --- */
.v3-range {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 4px;
  background: #cbd5e1; outline: none; cursor: pointer;
  margin: 8px 0 2px;
}
.v3-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px;
  background: var(--accent, #0284C7);
  border: 2px solid #ffffff;
  cursor: pointer;
  box-shadow: 0 0 0 1px var(--accent-strong, #0369a1);
}
.v3-range::-moz-range-thumb {
  width: 18px; height: 18px;
  background: var(--accent, #0284C7);
  border: 2px solid #ffffff;
  cursor: pointer;
  box-shadow: 0 0 0 1px var(--accent-strong, #0369a1);
}
.v3-roof-viz__pitch-label {
  font: 700 11px/1 var(--font-mono);
  fill: var(--accent-strong, #0369a1);
}
.v3-roof-viz__small-label {
  font: 600 9.5px/1 var(--font-mono);
  fill: #475569;
  letter-spacing: 0.04em;
}
.v3-roof-viz__caption {
  display: block;
  text-align: center;
  font: 500 11px/1.3 var(--font);
  color: var(--text-subtle);
  margin-top: 6px;
}

/* --------------------------------------------------------------------
   Generic animated-diagram base â€” shared by Board Feet, Lumber, AWG,
   kVA, Pipe Size, Drain Slope. Same transition rules + look as the
   roof-pitch viz, generalized so each calculator just inlines an SVG.
   -------------------------------------------------------------------- */
.v3-diagram {
  background: var(--accent-soft, #F0F9FF);
  border: 1px solid var(--border);
  padding: 12px 14px 6px;
  margin: 0 0 12px;
}
.v3-diagram svg:not(.v3-gizmo-svg) {
  display: block;
  width: 100%;
  height: auto;
  max-width: 440px;
  margin: 0 auto;
  overflow: visible;
}
.v3-diagram line,
.v3-diagram circle,
.v3-diagram rect,
.v3-diagram text,
.v3-diagram path,
.v3-diagram polygon,
.v3-diagram polyline {
  transition: x 360ms cubic-bezier(.4,0,.2,1),
              y 360ms cubic-bezier(.4,0,.2,1),
              x1 360ms cubic-bezier(.4,0,.2,1), y1 360ms cubic-bezier(.4,0,.2,1),
              x2 360ms cubic-bezier(.4,0,.2,1), y2 360ms cubic-bezier(.4,0,.2,1),
              cx 360ms cubic-bezier(.4,0,.2,1), cy 360ms cubic-bezier(.4,0,.2,1),
              r  360ms cubic-bezier(.4,0,.2,1),
              width  360ms cubic-bezier(.4,0,.2,1),
              height 360ms cubic-bezier(.4,0,.2,1),
              d 360ms cubic-bezier(.4,0,.2,1);
}
.v3-diagram__caption {
  display: block;
  text-align: center;
  font: 500 11px/1.3 var(--font);
  color: var(--text-subtle);
  margin-top: 6px;
}
.v3-diagram__label {
  font: 600 10px/1 var(--font-mono); fill: #475569; letter-spacing: 0.04em;
}
.v3-diagram__label-strong {
  font: 700 11px/1 var(--font-mono); fill: var(--accent-strong);
}
.v3-diagram__small {
  font: 600 9.5px/1 var(--font-mono); fill: #64748b; letter-spacing: 0.02em;
}
.v3-diagram__fill-solid {
  fill: var(--accent); stroke: var(--accent-strong); stroke-width: 1.25;
}
.v3-diagram__fill-soft {
  fill: var(--accent-light); fill-opacity: 0.20;
  stroke: var(--accent); stroke-width: 1.25;
}
.v3-diagram__outline-dashed {
  fill: none; stroke: #94a3b8; stroke-width: 1.25; stroke-dasharray: 4 3;
}
.v3-diagram__guide {
  stroke: #94a3b8; stroke-width: 1; stroke-dasharray: 3 3; fill: none;
}
.v3-diagram__vector {
  stroke: var(--accent); stroke-width: 2; fill: none; stroke-linecap: square;
}
.v3-diagram__vector-strong {
  stroke: var(--accent-strong); stroke-width: 2.75; fill: none; stroke-linecap: square;
}
.v3-diagram__arc {
  stroke: var(--accent); stroke-width: 1.25; fill: none;
}
.v3-diagram__hole {
  fill: #fff; stroke: var(--accent-strong); stroke-width: 1.25;
}
/* 3D box faces â€” conventional light-medium-dark shading.
   Polygon fills snap on attribute change; outline strokes provide the
   wireframe feel. Interactive: drag to rotate the box. */
.v3-diagram--interactive { position: relative; }
.v3-diagram__svg { display: block; }
.v3-diagram__face {
  stroke: var(--accent-strong, #0369a1);
  stroke-width: 1;
  stroke-linejoin: miter;
}
.v3-diagram__face--top    { fill: #BAE6FD; }  /* sky-200 light */
.v3-diagram__face--bottom { fill: #0284C7; }  /* sky-600 darkest */
.v3-diagram__face--front  { fill: #7DD3FC; }  /* sky-300 medium */
.v3-diagram__face--back   { fill: #7DD3FC; }
.v3-diagram__face--right  { fill: #38BDF8; }  /* sky-400 shaded */
.v3-diagram__face--left   { fill: #38BDF8; }
.v3-diagram__reset {
  position: absolute;
  top: 10px; right: 10px;
  background: #ffffff;
  border: 1px solid var(--border, #E0F2FE);
  color: var(--accent-strong, #0369a1);
  font: 600 10.5px/1 var(--font);
  letter-spacing: 0.04em;
  padding: 6px 9px;
  cursor: pointer;
  text-transform: uppercase;
}
.v3-diagram__reset:hover { background: var(--accent-soft, #F0F9FF); }
.v3-diagram__reset:focus-visible {
  outline: 2px solid var(--accent, #0284C7); outline-offset: 1px;
}
.v3-diagram__reset:disabled {
  opacity: 0.35; cursor: not-allowed;
}
.v3-diagram__tools {
  position: absolute;
  top: 10px; right: 10px;
  display: flex; gap: 6px;
}
.v3-diagram__tools .v3-diagram__reset {
  position: static;
}

/* Detail readouts â€” three small panels in a row */
.v3-readouts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--border);
  background: var(--bg);
  margin: 0 0 12px;
}
.v3-readout {
  padding: 10px 12px;
  border-right: 1px solid var(--border);
}
.v3-readout:last-child { border-right: 0; }
.v3-readout__label {
  display: block;
  font: 600 9.5px/1 var(--font);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-subtle);
  margin: 0 0 4px;
}
.v3-readout__value {
  display: block;
  font: 500 15px/1.2 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--text);
  margin: 0;
}

/* ---- Empty state when no result --------------------------------- */
.v3-empty {
  background: var(--bg);
  border: 1px dashed var(--border-mid);
  padding: 24px 16px;
  text-align: center;
  font: 400 13px/1.4 var(--font);
  color: var(--text-subtle);
}

/* ====================================================================
   ACTIONS
   ==================================================================== */
.v3-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.v3-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  border: 1px solid var(--accent);
  color: var(--accent);
  height: 34px;
  padding: 0 14px;
  font: 600 12px/1 var(--font);
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 80ms ease, color 80ms ease;
}
.v3-btn:hover {
  background: var(--accent);
  color: var(--on-accent);
}
.v3-btn--primary {
  background: var(--accent);
  color: var(--on-accent);
}
.v3-btn--primary:hover { background: var(--accent-strong); border-color: var(--accent-strong); }

/* ====================================================================
   HOW-TO DISCLOSURE â€” collapsed by default, slim
   ==================================================================== */
[data-category="trades"] details.v3-help {
  border: 1px solid var(--border);
  background: var(--bg);
  margin: 0 0 14px;
}
[data-category="trades"] details.v3-help > summary {
  list-style: none;
  cursor: pointer;
  padding: 8px 14px;
  font: 600 10.5px/1 var(--font);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
[data-category="trades"] details.v3-help > summary::-webkit-details-marker { display: none; }
[data-category="trades"] details.v3-help > summary:hover { color: var(--accent); }
[data-category="trades"] details.v3-help[open] > summary {
  border-bottom: 1px solid var(--border);
  background: var(--surface-tint);
  color: var(--accent);
}
[data-category="trades"] details.v3-help .v3-help__caret {
  font-family: var(--font-mono);
  font-size: 11px;
  transition: transform 150ms ease;
}
[data-category="trades"] details.v3-help[open] .v3-help__caret { transform: rotate(180deg); }
[data-category="trades"] details.v3-help .v3-help__body { padding: 12px 14px 14px; }
[data-category="trades"] details.v3-help p {
  margin: 0 0 8px;
  font: 400 13.5px/1.55 var(--font);
  color: var(--text-muted);
}
[data-category="trades"] details.v3-help ol {
  margin: 0;
  padding-left: 22px;
  font: 400 13.5px/1.6 var(--font);
  color: var(--text-muted);
}
[data-category="trades"] details.v3-help li { padding: 3px 0; }
[data-category="trades"] details.v3-help strong { color: var(--text); font-weight: 600; }

/* ====================================================================
   PROSE (below-fold sections)
   ==================================================================== */
.v3-prose {
  max-width: 720px;
  margin: 32px 0 0;
}
.v3-prose p,
.v3-prose li {
  font: 400 14.5px/1.7 var(--font);
  color: var(--text-muted);
  margin: 0 0 10px;
}

.v3-stamp {
  display: inline-block;
  font: 500 11px/1.4 var(--font-mono);
  color: var(--text-subtle);
  margin: 6px 0 0;
}

/* ====================================================================
   REFERENCE TABLE
   ==================================================================== */
.v3-ref-wrap { overflow-x: auto; margin: 0 0 12px; }
.v3-ref {
  width: 100%;
  border-collapse: collapse;
  font: 500 13.5px/1.4 var(--font-mono);
  font-variant-numeric: tabular-nums;
}
.v3-ref th,
.v3-ref td {
  padding: 6px 12px;
  text-align: right;
  border-bottom: 1px solid var(--border);
}
.v3-ref th {
  font-weight: 600;
  color: var(--text-subtle);
  text-transform: uppercase;
  font-size: 10px;
  letter-spacing: 0.1em;
  border-bottom: 1px solid var(--border-mid);
}
.v3-ref th:first-child,
.v3-ref td:first-child { text-align: left; }

/* ====================================================================
   FAQ â€” light hairline rule between questions
   ==================================================================== */
[data-category="trades"] details.v3-q {
  border-top: 1px solid var(--border);
  padding: 10px 0;
}
[data-category="trades"] details.v3-q:last-of-type { border-bottom: 1px solid var(--border); }
[data-category="trades"] details.v3-q > summary {
  cursor: pointer;
  font: 500 14.5px/1.3 var(--font);
  list-style: none;
  padding: 4px 24px 4px 0;
  position: relative;
  color: var(--text);
}
[data-category="trades"] details.v3-q > summary::-webkit-details-marker { display: none; }
[data-category="trades"] details.v3-q > summary::after {
  content: "+";
  position: absolute;
  right: 0; top: 4px;
  font-family: var(--font-mono);
  color: var(--accent);
}
[data-category="trades"] details.v3-q[open] > summary::after { content: "âˆ’"; }
[data-category="trades"] details.v3-q > div p {
  padding: 6px 0 4px;
  font: 400 14px/1.6 var(--font);
  color: var(--text-muted);
}

/* ====================================================================
   TOAST
   ==================================================================== */
.v3-toast {
  position: fixed;
  left: 50%; bottom: 24px;
  transform: translateX(-50%);
  background: var(--text);
  color: var(--bg);
  padding: 10px 16px;
  font: 500 13px/1 var(--font);
  z-index: 1000;
}
