/* ============================================================================
   COMPONENTS — riusabili (field, btn, pill, table, dialog base, ...)
   ============================================================================ */


  .field{display:flex;flex-direction:column;gap:4px;}
  .field label{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
  .field input, .field select{
    border:none;border-bottom:1px solid var(--ink);background:transparent;
    padding:6px 2px;font-family:var(--font-mono);font-size:13px;color:var(--ink);outline:none;
  }
  .field input:focus, .field select:focus{border-bottom-color:var(--accent);}
  /* Active-filter highlight: applied by JS when a field's value differs from default.
     Provides a visible cue without being noisy — accent underline + label color tint. */
  .field.has-value label{color:var(--accent);font-weight:600;}
  .field.has-value input,
  .field.has-value select{
    border-bottom-color:var(--accent);
    background:color-mix(in srgb, var(--accent) 5%, transparent);
    padding-left:4px;
  }

  /* Bonds table */
  .table-wrap{border:1px solid var(--ink);background:var(--table-bg);max-height:520px;overflow:auto;}
  .pill{display:inline-block;padding:1px 6px;font-size:10px;border:1px solid var(--ink);border-radius:2px;font-family:var(--font-mono);letter-spacing:.05em;}
  .btn-tranche{
    padding:4px 9px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
    border:1px solid var(--ink);background:transparent;cursor:pointer;color:var(--ink);
    transition:all .12s;white-space:nowrap;
  }
  .btn-tranche:hover{background:var(--ink);color:var(--paper);}
  .btn-lookup{
    padding:4px 7px;font-family:var(--font-mono);font-size:10px;
    border:1px solid var(--accent-2);background:transparent;cursor:pointer;color:var(--accent-2);
    transition:all .12s;white-space:nowrap;
    display:none; /* shown only when priceHistory is available */
  }
  .btn-lookup.visible{display:inline-block;}
  .btn-lookup:hover{background:var(--accent-2);color:#fff;}
  .btn-rem-tranche{
    padding:4px 8px;border:none;background:transparent;cursor:pointer;
    color:var(--neg);font-size:16px;line-height:1;flex-shrink:0;
  }
  .btn-rem-tranche:hover{color:#fff;background:var(--neg);}

  .panel{border:1px solid var(--ink);background:#fff;}
  .panel-head{
    border-bottom:1px solid var(--ink);padding:10px 14px;display:flex;justify-content:space-between;align-items:center;
    background:var(--paper-2);
  }
  .panel-head h3{margin:0;font-weight:500;font-size:15px;letter-spacing:.01em;}
  .panel-head .sub{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
  .panel-body{padding:14px;}
  .btn-mini{padding:5px 10px !important;font-size:9.5px !important;}
  .btn-link{
    background:transparent;border:none;color:var(--accent);
    font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
    cursor:pointer;padding:4px 0;border-bottom:1px solid var(--accent);
    transition:color .15s;
  }
  .btn-link:hover{color:var(--ink);border-bottom-color:var(--ink);}
  .btn-link.dismiss{
    color:var(--muted);border-bottom:none;font-size:18px;line-height:1;padding:0 6px;letter-spacing:0;
  }
  .btn-link.dismiss:hover{color:var(--neg);}
  .btn{
    border:1px solid var(--ink);background:var(--ink);color:var(--paper);
    padding:10px 18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
    cursor:pointer;transition:all .15s;
  }
  .btn:hover{background:var(--accent);border-color:var(--accent);}
  .btn.ghost{background:transparent;color:var(--ink);}
  .btn.ghost:hover{background:var(--ink);color:var(--paper);}
  .btn:disabled{opacity:.4;cursor:not-allowed;}

  .empty{padding:24px;text-align:center;color:var(--muted);font-style:italic;border:1px dashed var(--ink);}

  /* Run-button tint for §05 */
  .btn--build{
    background:var(--accent-2);
    border-color:var(--accent-2);
  }
  .btn--build:hover{
    background:color-mix(in srgb, var(--accent-2) 85%, var(--ink));
  }

  /* Scrollbar */
  ::-webkit-scrollbar{width:10px;height:10px;}
  ::-webkit-scrollbar-track{background:var(--paper);}
  ::-webkit-scrollbar-thumb{background:var(--ink);}

