/* ===== APP CSS ===== */
    :root {
      --ink: #0d0d0d;
      --paper: #f5f0e8;
      --paper-dark: #ede7d5;
      --paper-mid: #e8e2d4;
      --accent: #c0392b;
      --accent2: #2c3e6b;
      --green: #1d8a50;
      --yellow: #a07800;
      --muted: #7a7260;
      --border: #ccc5b0;
      --white: #fff;
      --mono: 'DM Mono', monospace;
      --body: 'DM Sans', sans-serif;
      --display: 'Playfair Display', serif;
      --r: 4px
    }

    * {
      box-sizing: border-box;
      margin: 0;
      padding: 0
    }

    #view-app {
      font-family: var(--body);
      background: var(--paper);
      color: var(--ink);
      height: 100vh;
      display: flex;
      flex-direction: column;
      overflow: hidden
    }

    /* ── HEADER ── */
    #view-app header {
      background: var(--ink);
      color: var(--paper);
      padding: 10px 20px;
      display: flex;
      align-items: center;
      gap: 11px;
      border-bottom: 3px solid var(--accent);
      flex-shrink: 0
    }

    .logo {
      width: 32px;
      height: 32px;
      display: grid;
      place-items: center;
      flex-shrink: 0;
      position: relative;
    }
    .logo svg { width: 100%; height: 100%; }

    #view-app header h1 {
      font-family: var(--display);
      font-size: 1.08rem;
      font-weight: 600
    }

    #view-app header p {
      font-size: .65rem;
      color: #aaa09a;
      font-family: var(--mono);
      letter-spacing: .04em;
      margin-top: 1px
    }

    .hright {
      margin-left: auto;
      display: flex;
      align-items: center;
      gap: 8px
    }

    .hbadge {
      background: var(--accent2);
      color: #a8c0f0;
      font-family: var(--mono);
      font-size: .58rem;
      padding: 3px 8px;
      border-radius: 2px;
      letter-spacing: .07em
    }

    /* Language toggle */
    .lang-toggle {
      display: flex;
      border: 1px solid #333;
      border-radius: var(--r);
      overflow: hidden
    }

    .lang-btn {
      background: transparent;
      border: none;
      color: #888;
      font-family: var(--mono);
      font-size: .6rem;
      padding: 3px 8px;
      cursor: pointer;
      transition: all .15s;
      letter-spacing: .04em
    }

    .lang-btn.active {
      background: var(--accent2);
      color: #fff
    }

    /* ── STEP BAR ── */
    .steps-bar {
      background: var(--paper-dark);
      border-bottom: 1px solid var(--border);
      padding: 0 18px;
      display: flex;
      align-items: stretch;
      flex-shrink: 0
    }

    .stab {
      display: flex;
      align-items: center;
      gap: 6px;
      padding: 8px 13px;
      cursor: pointer;
      border-bottom: 2px solid transparent;
      transition: color .2s, background .2s, border-color .2s;
      font-family: var(--mono);
      font-size: .65rem;
      color: var(--muted);
      position: relative;
      user-select: none
    }

    .stab:hover {
      color: var(--ink);
      background: var(--paper-mid)
    }

    .stab:active {
      background: var(--paper)
    }

    .stab.active {
      color: var(--ink);
      border-bottom-color: var(--accent);
      background: var(--white)
    }

    .stab.done {
      color: var(--green)
    }

    .snum {
      width: 18px;
      height: 18px;
      border-radius: 50%;
      border: 1.5px solid currentColor;
      display: grid;
      place-items: center;
      font-size: .56rem;
      font-weight: 700;
      flex-shrink: 0
    }

    .stab.active .snum {
      background: var(--accent);
      border-color: var(--accent);
      color: #fff
    }

    .stab.done .snum {
      background: var(--green);
      border-color: var(--green);
      color: #fff
    }

    .sdot {
      width: 5px;
      height: 5px;
      border-radius: 50%;
      background: var(--accent);
      position: absolute;
      top: 5px;
      right: 4px;
      display: none
    }

    .sdot.on {
      display: block
    }

    .ssep {
      width: 1px;
      background: var(--border);
      margin: 7px 0;
      flex-shrink: 0
    }

    #formatterMode {
      display: flex;
      flex-direction: column;
      flex: 1;
      min-height: 0;
      overflow: hidden
    }

    #linkerMode {
      flex: 1;
      overflow-y: auto;
      min-height: 0
    }

    /* ── WORKSPACE ── */
    .workspace {
      display: grid;
      grid-template-columns: 650px 1fr;
      flex: 1;
      overflow: hidden;
      min-height: 0
    }

    /* ── LEFT PANEL ── */
    .left {
      display: flex;
      flex-direction: column;
      border-right: 1px solid var(--border);
      overflow: hidden;
      min-height: 0
    }

    .spanel {
      display: none;
      flex: 1;
      flex-direction: column;
      overflow: hidden;
      min-height: 0
    }

    .spanel.active {
      display: flex
    }

    /* THE KEY FIX: each step's scroll area fills and scrolls independently */
    .scroll {
      flex: 1;
      overflow-y: auto;
      overflow-x: hidden;
      padding: 13px 14px;
      display: flex;
      flex-direction: column;
      gap: 9px;
      min-height: 0
    }

    /* ── DROPZONE ── */
    .kernit-dropzone {
      border: 2px dashed var(--border);
      text-align: center;
      cursor: pointer;
      transition: border-color .25s, background .25s, transform .25s, box-shadow .25s;
      background: var(--white);
    }

    .kernit-dropzone:active {
      transform: translateY(0);
      box-shadow: none;
    }

    .dz {
      border-radius: 10px;
      padding: 24px 14px;
      background: var(--white);
      flex-shrink: 0
    }

    .dz:hover {
      border-color: var(--accent2);
      background: #eef1f8;
      transform: translateY(-1px);
      box-shadow: 0 4px 12px rgba(44,62,107,.06)
    }

    .dz.drag {
      border-color: var(--accent2);
      background: rgba(26,86,219,.04);
      border-style: solid;
      transform: scale(1.01);
      box-shadow: 0 0 0 4px rgba(44,62,107,.06)
    }

    .dz.ok {
      border-color: var(--green);
      background: #f0faf4;
      border-style: solid
    }

    .dz-icon {
      font-size: 1.7rem;
      opacity: .22;
      margin-bottom: 6px
    }

    .dz h3 {
      font-family: var(--display);
      font-size: .85rem;
      margin-bottom: 3px
    }

    .dz p {
      font-family: var(--mono);
      font-size: .64rem;
      color: var(--muted);
      line-height: 1.4
    }

    .dz .fmts {
      font-size: .58rem;
      margin-top: 5px;
      color: #b0a890
    }

    .fok {
      display: none;
      align-items: center;
      gap: 6px;
      background: #27ae6015;
      border: 1px solid #27ae6030;
      border-radius: var(--r);
      padding: 6px 10px;
      margin-top: 6px
    }

    .fok.on {
      display: flex
    }

    .fok span {
      font-family: var(--mono);
      font-size: .64rem;
      color: var(--green);
      flex: 1
    }

    /* ── DET CARD ── */
    .det-card {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r);
      overflow: hidden;
      flex-shrink: 0
    }

    .dch {
      padding: 8px 12px;
      background: var(--paper-dark);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      gap: 7px
    }

    .dch h3 {
      font-family: var(--display);
      font-size: .8rem;
      font-weight: 600;
      flex: 1
    }

    .cbadge {
      font-family: var(--mono);
      font-size: .57rem;
      padding: 2px 7px;
      border-radius: 10px;
      font-weight: 600
    }

    .cbadge.hi {
      background: #d4f0e0;
      color: #1a7a40
    }

    .cbadge.md {
      background: #fef3cd;
      color: #856404
    }

    .cbadge.lo {
      background: #fde8e8;
      color: #842029
    }

    .dcb {
      padding: 10px 12px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 6px
    }

    .df label {
      font-family: var(--mono);
      font-size: .56rem;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--muted);
      display: block;
      margin-bottom: 3px
    }

    .df input,
    .df select {
      width: 100%;
      background: var(--paper);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 4px 7px;
      font-family: var(--mono);
      font-size: .67rem;
      color: var(--ink);
      outline: none;
      transition: border-color .15s
    }

    .df input:focus,
    .df select:focus {
      border-color: var(--accent2)
    }

    .df.full {
      grid-column: 1/-1
    }

    .use-preset-btn {
      margin: 0 12px 10px;
      width: calc(100% - 24px);
      background: var(--accent2);
      color: #fff;
      border: none;
      border-radius: var(--r);
      padding: 7px;
      font-family: var(--mono);
      font-size: .64rem;
      cursor: pointer;
      transition: all .15s;
      letter-spacing: .04em
    }

    .use-preset-btn:hover {
      background: #1e2f57
    }

    /* ── STRUCT FIELDS ── */
    .sf {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r);
      overflow: hidden;
      flex-shrink: 0
    }

    .sfh {
      padding: 7px 11px;
      background: var(--paper-dark);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      gap: 5px;
      cursor: pointer
    }

    .sfh h4 {
      font-family: var(--mono);
      font-size: .75rem;
      font-weight: 500;
      flex: 1;
      letter-spacing: .04em
    }

    .sfc {
      font-size: .64rem;
      font-family: var(--mono);
      padding: 1px 7px;
      border-radius: 10px
    }

    .sfc.g {
      background: #d4f0e0;
      color: #1a7a40
    }

    .sfc.y {
      background: #fef3cd;
      color: #856404
    }

    .sfc.r {
      background: #fde8e8;
      color: #842029
    }

    .sfb {
      padding: 8px 11px
    }

    .sfb input,
    .sfb textarea {
      width: 100%;
      background: var(--paper);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 5px 8px;
      font-family: var(--mono);
      font-size: .78rem;
      color: var(--ink);
      outline: none;
      resize: vertical;
      line-height: 1.55;
      transition: border-color .2s, box-shadow .2s
    }

    .sfb input:focus,
    .sfb textarea:focus {
      border-color: var(--accent2);
      box-shadow: 0 0 0 3px rgba(44,62,107,.06)
    }

    .sfb input:hover,
    .sfb textarea:hover {
      border-color: rgba(204,197,176,.8)
    }

    .sfhint {
      font-family: var(--mono);
      font-size: .66rem;
      color: var(--muted);
      margin-top: 3px
    }

    /* ── SECTION ITEMS ── */
    .seclist {
      display: flex;
      flex-direction: column;
      gap: 5px;
      flex-shrink: 0
    }

    .si {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r);
      overflow: hidden
    }

    .sih {
      padding: 6px 9px;
      background: var(--paper-dark);
      display: flex;
      align-items: center;
      gap: 5px;
      cursor: pointer
    }

    .sinum {
      font-family: var(--mono);
      font-size: .66rem;
      color: var(--muted);
      width: 17px;
      flex-shrink: 0
    }

    .sih input {
      flex: 1;
      background: transparent;
      border: none;
      font-family: var(--mono);
      font-size: .76rem;
      color: var(--ink);
      outline: none;
      font-weight: 500
    }

    .sih input:focus {
      background: var(--paper);
      border-radius: 2px;
      padding: 0 3px
    }

    .sib {
      padding: 7px 9px;
      display: none
    }

    .sib.open {
      display: block
    }

    .sib textarea {
      width: 100%;
      background: var(--paper);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 6px 8px;
      font-family: var(--mono);
      font-size: .76rem;
      color: var(--ink);
      outline: none;
      resize: vertical;
      min-height: 70px;
      line-height: 1.55;
      transition: border-color .2s, box-shadow .2s
    }

    .sib textarea:focus {
      border-color: var(--accent2);
      box-shadow: 0 0 0 3px rgba(44,62,107,.06)
    }

    .sib textarea:hover {
      border-color: rgba(204,197,176,.8)
    }

    .sa {
      display: flex;
      gap: 4px;
      align-items: center
    }

    .ib {
      background: none;
      border: none;
      cursor: pointer;
      padding: 2px 4px;
      border-radius: 2px;
      font-size: .7rem;
      color: var(--muted);
      transition: all .15s;
      line-height: 1
    }

    .ib:hover {
      background: var(--paper-mid);
      color: var(--ink)
    }

    .ib.del:hover {
      color: var(--accent);
      background: #fde8e8
    }

    .addbtn {
      width: 100%;
      background: var(--paper);
      border: 1px dashed var(--border);
      border-radius: var(--r);
      padding: 6px;
      font-family: var(--mono);
      font-size: .73rem;
      color: var(--muted);
      cursor: pointer;
      transition: all .15s;
      text-align: center;
      flex-shrink: 0
    }

    .addbtn:hover {
      border-color: var(--accent2);
      color: var(--accent2);
      background: var(--white)
    }

    /* ── REF ROWS ── */
    .refrow {
      display: flex;
      gap: 4px;
      align-items: center;
      flex-shrink: 0
    }

    .refnum {
      font-family: var(--mono);
      font-size: .6rem;
      color: var(--muted);
      width: 20px;
      flex-shrink: 0;
      text-align: right
    }

    .refrow input {
      flex: 1;
      background: var(--paper);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 4px 7px;
      font-family: var(--mono);
      font-size: .64rem;
      color: var(--ink);
      outline: none;
      transition: border-color .15s
    }

    .refrow input:focus {
      border-color: var(--accent2)
    }

    /* ── TEMPLATE GRID ── */
    .tgrid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 6px;
      flex-shrink: 0;
      overflow: visible
    }

    .tc {
      border: 1.5px solid var(--border);
      background: var(--paper);
      border-radius: var(--r);
      padding: 7px 6px;
      cursor: pointer;
      transition: border-color .2s, background .2s, transform .2s, box-shadow .2s;
      position: relative
    }

    .tc:hover {
      border-color: var(--accent2);
      background: #eef1f8;
      transform: translateY(-2px);
      box-shadow: 0 4px 12px rgba(44,62,107,.1);
      z-index: 10
    }

    .tc:active {
      transform: translateY(0);
      box-shadow: none
    }

    .tc.on {
      border-color: var(--accent);
      background: #fef5f4;
      box-shadow: 0 0 0 3px rgba(192,57,43,.1)
    }

    .tc.on::before {
      content: '✓';
      position: absolute;
      top: 4px;
      right: 5px;
      font-size: .57rem;
      color: #fff;
      font-weight: 700;
      background: var(--accent);
      width: 14px;
      height: 14px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      line-height: 1
    }

    .tc.custom-card {
      border-color: var(--accent2);
      background: #eef3ff
    }

    .tc.custom-card.on {
      border-color: var(--accent);
      background: #fef5f4
    }

    .tn {
      font-family: var(--mono);
      font-size: .64rem;
      font-weight: 600;
      letter-spacing: .01em
    }

    .ts {
      font-family: var(--mono);
      font-size: .52rem;
      color: var(--muted);
      margin-top: 2px;
      letter-spacing: .03em
    }

    .tp {
      margin-top: 4px;
      display: flex;
      flex-direction: column;
      gap: 2px
    }

    .ln {
      height: 2px;
      background: var(--border);
      border-radius: 1px
    }

    .ln.h {
      height: 4px;
      width: 55%;
      background: #bbb
    }

    .ln.m {
      width: 75%
    }

    .ln.s {
      width: 40%
    }

    .twoc {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 3px;
      margin-top: 2px
    }

    .tcb {
      display: flex;
      flex-direction: column;
      gap: 2px
    }

    .tc-del {
      position: absolute;
      bottom: 4px;
      right: 4px;
      background: none;
      border: none;
      cursor: pointer;
      font-size: .6rem;
      color: #bbb;
      line-height: 1;
      padding: 1px;
      border-radius: 2px;
      transition: all .15s
    }

    .tc-del:hover {
      color: var(--accent);
      background: #fde8e8
    }

    /* ── Preset tooltip ── */
    .tc .tc-tooltip {
      display: none; position: absolute; top: calc(100% + 8px); left: 50%;
      transform: translateX(-50%); z-index: 50;
      background: var(--ink); color: var(--paper); border-radius: 6px;
      padding: 8px 10px; font-family: var(--mono); font-size: .48rem;
      line-height: 1.6; white-space: nowrap; pointer-events: none;
      box-shadow: 0 4px 16px rgba(0,0,0,.2);
    }
    .tc .tc-tooltip::before {
      content: ''; position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
      border: 5px solid transparent; border-bottom-color: var(--ink);
    }
    .tc:hover .tc-tooltip { display: block; }

    /* Saved presets section label */
    .sec-divider {
      font-family: var(--mono);
      font-size: .57rem;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--muted);
      display: flex;
      align-items: center;
      gap: 6px;
      flex-shrink: 0
    }

    .sec-divider span {
      flex: 1;
      height: 1px;
      background: var(--border);
      display: block
    }

    /* ── WARNINGS ── */
    .wbanner {
      background: #fef9e7;
      border: 1px solid #f0d060;
      border-radius: var(--r);
      padding: 9px 12px;
      display: none;
      flex-shrink: 0
    }

    .wbanner.on {
      display: block
    }

    .wbanner h4 {
      font-family: var(--mono);
      font-size: .64rem;
      font-weight: 600;
      color: var(--yellow);
      margin-bottom: 5px
    }

    .wi {
      font-family: var(--mono);
      font-size: .61rem;
      color: #6b5800;
      margin-bottom: 4px;
      padding-left: 13px;
      position: relative;
      line-height: 1.4
    }

    .wi::before {
      content: '⚠';
      position: absolute;
      left: 0;
      font-size: .57rem
    }

    .wack {
      width: 100%;
      margin-top: 7px;
      background: var(--yellow);
      color: #fff;
      border: none;
      border-radius: var(--r);
      padding: 5px;
      font-family: var(--mono);
      font-size: .62rem;
      cursor: pointer;
      transition: all .15s
    }

    .wack:hover {
      background: #7a5c00
    }

    /* ── DEEP COMPLIANCE DETAIL ROWS ── */
    .chk-group {
      margin-top: 6px;
    }

    .chk-group-label {
      font-family: var(--mono);
      font-size: .55rem;
      letter-spacing: .09em;
      text-transform: uppercase;
      color: var(--muted);
      margin: 6px 0 3px;
      border-bottom: 1px solid var(--border);
      padding-bottom: 2px;
    }

    .chk-row {
      display: flex;
      gap: 6px;
      align-items: flex-start;
      padding: 4px 6px;
      border-radius: 3px;
      margin-bottom: 2px;
    }

    .chk-row.pass {
      background: #f0faf4;
    }

    .chk-row.fail {
      background: #fdf2f2;
    }

    .chk-row.warn {
      background: #fefce8;
    }

    .chk-icon {
      flex-shrink: 0;
      font-size: .7rem;
      margin-top: 1px;
      font-family: var(--mono);
      font-weight: 700;
    }

    .chk-icon.pass {
      color: var(--green);
    }

    .chk-icon.fail {
      color: var(--accent);
    }

    .chk-icon.warn {
      color: var(--yellow);
    }

    .chk-label {
      font-family: var(--mono);
      font-size: .61rem;
      font-weight: 600;
    }

    .chk-label.pass {
      color: var(--green);
    }

    .chk-label.fail {
      color: var(--accent);
    }

    .chk-label.warn {
      color: var(--yellow);
    }

    .chk-detail {
      font-family: var(--mono);
      font-size: .57rem;
      color: var(--muted);
      margin-top: 1px;
      line-height: 1.4;
    }

    /* ── WRITING QUALITY PANEL ── */
    .wq-meter {
      display: flex;
      align-items: center;
      gap: 7px;
      margin-bottom: 3px;
    }

    .wq-label {
      font-family: var(--mono);
      font-size: .59rem;
      color: var(--muted);
      width: 90px;
      flex-shrink: 0;
    }

    .wq-bar-wrap {
      flex: 1;
      height: 6px;
      background: var(--paper-dark);
      border-radius: 3px;
      overflow: hidden;
    }

    .wq-bar-fill {
      height: 100%;
      border-radius: 3px;
      transition: width .4s;
    }

    .wq-val {
      font-family: var(--mono);
      font-size: .59rem;
      width: 28px;
      text-align: right;
      flex-shrink: 0;
    }

    .wq-issues {
      display: flex;
      flex-direction: column;
      gap: 3px;
      margin-top: 6px;
    }

    .wq-issue {
      font-family: var(--mono);
      font-size: .58rem;
      color: #5a4500;
      background: #fefce8;
      border: 1px solid #f0d060;
      border-radius: 3px;
      padding: 4px 7px;
      line-height: 1.45;
    }

    .wq-issue.good {
      color: #1a5c34;
      background: #f0faf4;
      border-color: #90d4a8;
    }

    .wq-score-row {
      display: flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 8px;
    }

    .wq-score-circle {
      width: 38px;
      height: 38px;
      border-radius: 50%;
      flex-shrink: 0;
      display: grid;
      place-items: center;
      font-family: var(--display);
      font-size: .95rem;
      font-weight: 700;
      color: #fff;
    }

    .wq-score-desc {
      font-family: var(--mono);
      font-size: .6rem;
      color: var(--muted);
      line-height: 1.5;
    }

    /* ── JOURNAL RECOMMENDER ── */
    .jrec-row {
      display: flex;
      align-items: center;
      gap: 8px;
      padding: 5px 7px;
      border-radius: 3px;
      margin-bottom: 3px;
      background: var(--white);
      border: 1px solid var(--border);
      cursor: pointer;
      transition: border-color .15s;
    }

    .jrec-row:hover {
      border-color: var(--accent2);
    }

    .jrec-rank {
      font-family: var(--mono);
      font-size: .58rem;
      font-weight: 700;
      color: var(--muted);
      width: 14px;
      flex-shrink: 0;
      text-align: center;
    }

    .jrec-name {
      font-family: var(--mono);
      font-size: .62rem;
      font-weight: 600;
      color: var(--ink);
      flex: 1;
    }

    .jrec-sub {
      font-family: var(--mono);
      font-size: .55rem;
      color: var(--muted);
      margin-top: 1px;
    }

    .jrec-bar-wrap {
      width: 48px;
      height: 5px;
      background: var(--paper-dark);
      border-radius: 3px;
      overflow: hidden;
      flex-shrink: 0;
    }

    .jrec-bar-fill {
      height: 100%;
      border-radius: 3px;
    }

    .jrec-pct {
      font-family: var(--mono);
      font-size: .58rem;
      width: 30px;
      text-align: right;
      flex-shrink: 0;
    }

    /* ── SECTION LEVEL INDENTATION ── */
    .mi-sec-wrap[data-level="subsection"] {
      margin-left: 14px;
      border-left: 2px solid #c8e0f8;
    }

    .mi-sec-wrap[data-level="subsubsection"] {
      margin-left: 28px;
      border-left: 2px solid #d4eac0;
    }

    .mi-sec-wrap[data-level="subsubsubsection"] {
      margin-left: 42px;
      border-left: 2px solid #f5d8a0;
    }

    .mi-sec-wrap[data-level="subsection"] .mi-sec-hdr {
      background: #edf5fd;
    }

    .mi-sec-wrap[data-level="subsubsection"] .mi-sec-hdr {
      background: #f0f9ea;
    }

    .mi-sec-wrap[data-level="subsubsubsection"] .mi-sec-hdr {
      background: #fef9ed;
    }

    .mi-sec-hdr {
      padding: 5px 8px;
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      gap: 5px;
      background: var(--paper-dark);
    }

    .mi-sec-level-badge {
      font-family: var(--mono);
      font-size: .52rem;
      padding: 1px 5px;
      border-radius: 2px;
      color: #fff;
      flex-shrink: 0;
      letter-spacing: .04em;
    }

    .badge-sec {
      background: var(--accent2);
    }

    .badge-sub {
      background: #2980b9;
    }

    .badge-subsub {
      background: #27ae60;
    }

    .badge-subsubsub {
      background: #e67e22;
    }

    /* ── LATEX PREVIEW PANEL ── */
    .latex-panel {
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      width: 420px;
      background: #1a1a2e;
      color: #e8e8f0;
      display: flex;
      flex-direction: column;
      z-index: 50;
      border-left: 2px solid #333;
      transform: translateX(100%);
      transition: transform .25s ease;
    }

    .latex-panel.open {
      transform: translateX(0);
    }

    .latex-pbar {
      padding: 8px 12px;
      background: #0d0d1f;
      border-bottom: 1px solid #333;
      display: flex;
      align-items: center;
      gap: 8px;
      flex-shrink: 0;
    }

    .latex-pbar h3 {
      font-family: var(--mono);
      font-size: .7rem;
      color: #a0a8d0;
      flex: 1;
      letter-spacing: .06em;
    }

    .latex-pbtn {
      background: #2c2c50;
      border: 1px solid #444;
      color: #a0a8d0;
      font-family: var(--mono);
      font-size: .57rem;
      padding: 3px 8px;
      border-radius: 3px;
      cursor: pointer;
      transition: all .15s;
    }

    .latex-pbtn:hover {
      background: #3c3c70;
      color: #fff;
    }
    .latex-pbtn .cost-tag { font-size: .46rem; opacity: .7; margin-left: 2px; }

    .latex-code {
      flex: 1;
      overflow-y: auto;
      padding: 12px 14px;
      font-family: var(--mono);
      font-size: .62rem;
      line-height: 1.7;
      white-space: pre;
      tab-size: 2;
    }

    /* Syntax coloring classes (injected via JS) */
    .ltx-cmd {
      color: #e06c75;
    }

    /* \commands */
    .ltx-arg {
      color: #98c379;
    }

    /* {arguments} */
    .ltx-opt {
      color: #d19a66;
    }

    /* [options] */
    .ltx-cmt {
      color: #5c6370;
      font-style: italic;
    }

    /* % comments */
    .ltx-env {
      color: #c678dd;
    }

    /* begin/end */
    .ltx-math {
      color: #56b6c2;
    }

    /* $math$ */

    /* ── TABLE DESIGNER MODAL ── */
    .tbl-modal-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .55);
      z-index: 200;
      display: none;
      align-items: center;
      justify-content: center;
    }

    .tbl-modal-overlay.open {
      display: flex;
    }

    .tbl-modal {
      background: var(--paper);
      border-radius: 6px;
      width: 680px;
      max-width: 96vw;
      max-height: 90vh;
      display: flex;
      flex-direction: column;
      box-shadow: 0 8px 40px rgba(0, 0, 0, .35);
      overflow: hidden;
    }

    .tbl-mhdr {
      padding: 10px 14px;
      background: var(--ink);
      color: var(--paper);
      display: flex;
      align-items: center;
      gap: 8px;
      flex-shrink: 0;
    }

    .tbl-mhdr h3 {
      font-family: var(--display);
      font-size: .9rem;
      flex: 1;
    }

    .tbl-mhdr button {
      background: none;
      border: none;
      color: #aaa;
      cursor: pointer;
      font-size: .9rem;
    }

    .tbl-mbody {
      flex: 1;
      overflow-y: auto;
      padding: 12px 14px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .tbl-mfoot {
      padding: 8px 14px;
      background: var(--paper-dark);
      border-top: 1px solid var(--border);
      display: flex;
      gap: 6px;
      align-items: center;
      flex-shrink: 0;
    }

    .tbl-config {
      display: flex;
      gap: 8px;
      align-items: center;
      flex-wrap: wrap;
    }

    .tbl-config label {
      font-family: var(--mono);
      font-size: .59rem;
      color: var(--muted);
    }

    .tbl-config input[type=number],
    .tbl-config select {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 3px 6px;
      font-family: var(--mono);
      font-size: .62rem;
      color: var(--ink);
      outline: none;
      width: 55px;
    }

    .tbl-config select {
      width: auto;
    }

    .tbl-style-chips {
      display: flex;
      gap: 5px;
      flex-wrap: wrap;
    }

    .tbl-style-chip {
      font-family: var(--mono);
      font-size: .57rem;
      padding: 3px 9px;
      border-radius: 10px;
      border: 1.5px solid var(--border);
      cursor: pointer;
      background: var(--white);
      color: var(--muted);
      transition: all .15s;
    }

    .tbl-style-chip.active {
      border-color: var(--accent2);
      background: var(--accent2);
      color: #fff;
    }

    .tbl-grid-wrap {
      overflow: auto;
    }

    .tbl-grid {
      border-collapse: collapse;
      width: 100%;
    }

    .tbl-grid td {
      border: 1px solid var(--border);
      padding: 0;
      min-width: 70px;
    }

    .tbl-grid td input {
      width: 100%;
      padding: 5px 7px;
      border: none;
      outline: none;
      font-family: var(--mono);
      font-size: .64rem;
      background: transparent;
      color: var(--ink);
    }

    .tbl-grid tr:first-child td {
      background: var(--paper-dark);
    }

    .tbl-grid tr:first-child td input {
      font-weight: 600;
    }

    .tbl-preview-label {
      font-family: var(--mono);
      font-size: .57rem;
      color: var(--muted);
      letter-spacing: .07em;
      text-transform: uppercase;
      margin-bottom: 4px;
    }

    .tbl-latex-preview {
      background: #1a1a2e;
      color: #e8e8f0;
      padding: 8px 11px;
      font-family: var(--mono);
      font-size: .6rem;
      line-height: 1.6;
      border-radius: 4px;
      white-space: pre;
      overflow-x: auto;
      max-height: 120px;
    }

    .tbl-insert-btn {
      background: var(--accent2);
      color: #fff;
      border: none;
      border-radius: var(--r);
      padding: 7px 16px;
      font-family: var(--mono);
      font-size: .63rem;
      cursor: pointer;
      transition: all .15s;
      margin-left: auto;
    }

    .tbl-insert-btn:hover {
      background: #1e2f57;
    }

    /* ── FORMAT BAR ── */
    .fbar {
      padding: 10px 14px;
      background: var(--ink);
      display: flex;
      gap: 6px;
      align-items: center;
      flex-shrink: 0
    }

    .navbtn {
      background: transparent;
      border: 1px solid #444;
      color: #777;
      border-radius: var(--r);
      padding: 8px 10px;
      font-family: var(--mono);
      font-size: .63rem;
      cursor: pointer;
      transition: all .15s
    }

    .navbtn:hover {
      background: #222;
      color: var(--paper)
    }

    .navbtn:disabled {
      opacity: .28;
      cursor: not-allowed
    }

    .fmtbtn {
      flex: 1;
      background: var(--accent);
      color: #fff;
      border: none;
      border-radius: var(--r);
      padding: 9px 12px;
      font-family: var(--display);
      font-size: .83rem;
      font-weight: 600;
      cursor: pointer;
      transition: all .15s;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 6px
    }

    .fmtbtn:hover {
      background: #a93226
    }

    .fmtbtn:disabled {
      opacity: .5;
      cursor: wait
    }

    .spin {
      width: 11px;
      height: 11px;
      border: 2px solid rgba(255, 255, 255, .3);
      border-top-color: #fff;
      border-radius: 50%;
      animation: sp .7s linear infinite;
      display: none
    }

    @keyframes sp {
      to {
        transform: rotate(360deg)
      }
    }

    /* ── RIGHT ── */
    .right {
      display: flex;
      flex-direction: column;
      overflow: hidden;
      background: var(--white)
    }

    .obar {
      padding: 7px 14px;
      background: var(--paper-dark);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      gap: 6px;
      flex-shrink: 0
    }

    .obar h2 {
      font-family: var(--display);
      font-size: .87rem;
      font-weight: 600;
      flex: 1
    }

    .bsm {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: 6px;
      padding: 5px 11px;
      font-family: var(--mono);
      font-size: .59rem;
      cursor: pointer;
      color: var(--ink);
      transition: background .2s, color .2s, border-color .2s, transform .2s, box-shadow .2s
    }

    .bsm:hover {
      background: var(--ink);
      color: var(--paper);
      border-color: var(--ink);
      transform: translateY(-1px);
      box-shadow: 0 3px 10px rgba(13,13,13,.12)
    }

    .bsm:active { transform: translateY(0); box-shadow: none }

    .bsm.p {
      background: var(--accent2);
      color: #fff;
      border-color: var(--accent2)
    }

    .bsm.p:hover {
      background: #1e2f57;
      box-shadow: 0 3px 10px rgba(44,62,107,.2)
    }

    .bsm.g {
      background: #27ae60;
      color: #fff;
      border-color: #27ae60
    }

    .bsm.g:hover {
      background: #1e8c4a;
      box-shadow: 0 3px 10px rgba(39,174,96,.2)
    }

    .bsm:disabled {
      opacity: .33;
      cursor: not-allowed;
      pointer-events: none;
      transform: none;
      box-shadow: none
    }
    .bsm .cost-tag {
      font-size: .48rem; opacity: .75; margin-left: 2px;
    }
    .beta-tag {
      display: inline-block;
      font-size: .42rem;
      font-weight: 700;
      font-family: var(--mono);
      background: #ede7ff;
      color: #5b21b6;
      border: 1px solid #c4b5fd;
      border-radius: 3px;
      padding: 1px 4px;
      vertical-align: middle;
      line-height: 1.4;
      letter-spacing: .03em;
      margin-left: 3px;
    }

    .pbar {
      display: none;
      height: 3px;
      background: var(--border);
      overflow: hidden;
      flex-shrink: 0
    }

    .pfill {
      height: 100%;
      background: var(--accent);
      width: 40%;
      animation: psl 1s ease-in-out infinite
    }

    @keyframes psl {
      0% {
        transform: translateX(-150%)
      }

      100% {
        transform: translateX(350%)
      }
    }

    .owrap {
      flex: 1;
      overflow: hidden;
      display: flex;
      flex-direction: column;
      min-height: 0
    }

    #pf {
      flex: 1;
      border: none;
      display: none
    }

    .plc {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      height: 100%;
      gap: 12px;
      padding: 40px;
      text-align: center
    }

    .plc .bi {
      font-size: 2.8rem;
      opacity: .12
    }

    .plc h3 {
      font-family: var(--display);
      font-size: .88rem;
      color: var(--ink);
      opacity: .3
    }

    .plc p {
      font-family: var(--mono);
      font-size: .64rem;
      color: var(--muted);
      max-width: 280px;
      line-height: 1.55
    }

    /* ── MODAL ── */
    .overlay {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .48);
      z-index: 100;
      display: none;
      align-items: center;
      justify-content: center;
      backdrop-filter: blur(2px)
    }

    .overlay.on {
      display: flex
    }

    .modal {
      background: var(--white);
      border-radius: 6px;
      width: 500px;
      max-width: 92vw;
      box-shadow: 0 8px 40px rgba(0, 0, 0, .2);
      overflow: hidden
    }

    .mhdr {
      padding: 12px 16px;
      background: var(--paper-dark);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      gap: 8px
    }

    .mhdr h3 {
      font-family: var(--display);
      font-size: .92rem;
      font-weight: 600;
      flex: 1
    }

    .mbody {
      padding: 14px 16px
    }

    .mbody p {
      font-family: var(--body);
      font-size: .78rem;
      color: var(--muted);
      line-height: 1.55;
      margin-bottom: 10px
    }

    .mcand {
      background: var(--paper);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 9px 12px;
      font-family: var(--mono);
      font-size: .68rem;
      color: var(--ink);
      line-height: 1.55;
      margin-bottom: 12px;
      max-height: 110px;
      overflow-y: auto
    }

    .mfoot {
      padding: 10px 16px;
      border-top: 1px solid var(--border);
      display: flex;
      gap: 7px;
      justify-content: flex-end
    }

    .mbtn {
      padding: 6px 14px;
      border-radius: var(--r);
      font-family: var(--mono);
      font-size: .65rem;
      cursor: pointer;
      border: none;
      transition: all .15s
    }

    .mbtn.yes {
      background: var(--green);
      color: #fff
    }

    .mbtn.yes:hover {
      background: #166d3e
    }

    .mbtn.no {
      background: var(--paper);
      border: 1px solid var(--border);
      color: var(--ink)
    }

    .mbtn.no:hover {
      background: var(--paper-dark)
    }

    .mbtn.skip {
      background: transparent;
      color: var(--muted);
      border: none;
      text-decoration: underline;
      font-size: .63rem
    }

    .mbtn.skip:hover {
      color: var(--ink)
    }

    /* ── INLINE WARN ── */
    .iwarn {
      background: #fff8e1;
      border: 1px solid #ffe082;
      border-radius: var(--r);
      padding: 9px 12px;
      display: none;
      flex-shrink: 0
    }

    .iwarn.on {
      display: block
    }

    .iwarn p {
      font-family: var(--mono);
      font-size: .63rem;
      color: #6b5800;
      line-height: 1.45;
      margin-bottom: 7px
    }

    .icandidate {
      background: var(--white);
      border: 1px solid #ffe082;
      border-radius: 3px;
      padding: 6px 9px;
      font-family: var(--mono);
      font-size: .63rem;
      color: var(--ink);
      margin-bottom: 7px;
      max-height: 75px;
      overflow-y: auto;
      line-height: 1.45
    }

    .ibtns {
      display: flex;
      gap: 5px
    }

    .ibtn {
      padding: 3px 10px;
      border-radius: var(--r);
      font-family: var(--mono);
      font-size: .61rem;
      cursor: pointer;
      border: none;
      transition: all .15s
    }

    .ibtn.y {
      background: var(--green);
      color: #fff
    }

    .ibtn.n {
      background: var(--paper);
      border: 1px solid var(--border);
      color: var(--ink)
    }

    .ibtn.s {
      background: transparent;
      color: var(--muted);
      border: 1px solid var(--border)
    }

    /* ── TOAST ── */
    .toast-container {
      position: fixed;
      bottom: 15px;
      right: 15px;
      z-index: 200;
      display: flex;
      flex-direction: column-reverse;
      gap: 6px;
      pointer-events: none;
    }
    .toast {
      background: var(--ink);
      color: var(--paper);
      padding: 7px 13px;
      border-radius: var(--r);
      font-family: var(--mono);
      font-size: .65rem;
      border-left: 3px solid var(--accent);
      opacity: 0;
      transform: translateY(8px);
      transition: all .2s;
      pointer-events: none;
      max-width: 270px
    }

    .toast.on {
      opacity: 1;
      transform: translateY(0)
    }

    .toast.ok {
      border-left-color: #27ae60
    }

    .toast.warn {
      border-left-color: var(--yellow)
    }

    /* ── CUSTOMIZE PANEL ── */
    .cust-panel {
      background: var(--white);
      border: 1px solid var(--border);
      border-radius: var(--r);
      overflow: hidden;
      flex-shrink: 0
    }

    .cust-hdr {
      padding: 8px 12px;
      background: var(--paper-dark);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      gap: 7px;
      cursor: pointer;
      user-select: none
    }

    .cust-hdr h4 {
      font-family: var(--mono);
      font-size: .64rem;
      font-weight: 600;
      flex: 1;
      letter-spacing: .04em
    }

    .cust-hdr .ctag {
      font-family: var(--mono);
      font-size: .56rem;
      background: var(--accent2);
      color: #a8c0f0;
      padding: 1px 6px;
      border-radius: 3px;
      letter-spacing: .04em
    }

    .cust-body {
      padding: 10px 12px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 7px
    }

    .cust-body.open {
      display: grid
    }

    .cust-body {
      display: none
    }

    .cf-section-label {
      font-family: var(--mono);
      font-size: .52rem;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--accent2);
      font-weight: 700;
      padding: 5px 0 2px;
      border-bottom: 1px solid var(--border);
      margin-top: 3px;
    }

    .cf label {
      font-family: var(--mono);
      font-size: .56rem;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--muted);
      display: block;
      margin-bottom: 3px
    }

    .cf input,
    .cf select {
      width: 100%;
      background: var(--paper);
      border: 1px solid var(--border);
      border-radius: var(--r);
      padding: 4px 7px;
      font-family: var(--mono);
      font-size: .67rem;
      color: var(--ink);
      outline: none;
      transition: border-color .2s, box-shadow .2s
    }

    .cf input:focus,
    .cf select:focus {
      border-color: var(--accent2);
      box-shadow: 0 0 0 3px rgba(44,62,107,.06)
    }

    .cf input:hover,
    .cf select:hover {
      border-color: rgba(204,197,176,.8)
    }

    .cf.full {
      grid-column: 1/-1
    }

    .hdg-tabs {
      display: flex;
      gap: 0;
      margin-bottom: 6px;
      border-bottom: 1.5px solid var(--border);
    }
    .hdg-tab {
      font-family: var(--mono);
      font-size: .6rem;
      font-weight: 600;
      letter-spacing: .06em;
      padding: 4px 14px 3px;
      cursor: pointer;
      color: var(--muted);
      border-bottom: 2px solid transparent;
      margin-bottom: -1.5px;
      transition: color .15s, border-color .15s;
      background: none;
      border-top: none;
      border-left: none;
      border-right: none;
    }
    .hdg-tab.active {
      color: var(--accent2);
      border-bottom-color: var(--accent2);
    }
    .hdg-pane { display: none }
    .hdg-pane.active { display: grid; grid-template-columns: 1fr 1fr; gap: 7px }

    .cust-actions {
      grid-column: 1/-1;
      display: flex;
      gap: 5px;
      margin-top: 3px
    }

    /* Margin unit toggle buttons */
    .margin-unit-btn {
      flex: 1;
      padding: 3px 0;
      border: 1px solid var(--border);
      background: var(--paper);
      font-family: var(--mono);
      font-size: .6rem;
      color: var(--muted);
      border-radius: var(--r);
      cursor: pointer;
      transition: all .15s;
    }

    .margin-unit-btn.active {
      background: var(--accent2);
      color: #fff;
      border-color: var(--accent2);
    }

    /* Abstract style chips */
    .abs-style-chips {
      display: flex;
      gap: 4px;
      flex-wrap: wrap;
      margin-top: 2px;
    }

    .abs-chip {
      font-family: var(--mono);
      font-size: .57rem;
      padding: 3px 8px;
      border-radius: 10px;
      border: 1.5px solid var(--border);
      cursor: pointer;
      background: var(--white);
      color: var(--muted);
      transition: all .15s;
      white-space: nowrap;
    }

    .abs-chip.active {
      border-color: var(--accent2);
      background: var(--accent2);
      color: #fff;
    }

    .cust-save {
      flex: 1;
      background: var(--accent2);
      color: #fff;
      border: none;
      border-radius: 6px;
      padding: 5px 9px;
      font-family: var(--mono);
      font-size: .62rem;
      cursor: pointer;
      transition: background .2s, transform .2s, box-shadow .2s
    }

    .cust-save:hover {
      background: #1e2f57;
      transform: translateY(-1px);
      box-shadow: 0 3px 10px rgba(44,62,107,.2)
    }

    .cust-save:active { transform: translateY(0); box-shadow: none }

    .cust-reset {
      background: var(--paper);
      border: 1px solid var(--border);
      color: var(--muted);
      border-radius: 6px;
      padding: 5px 9px;
      font-family: var(--mono);
      font-size: .62rem;
      cursor: pointer;
      transition: background .2s, color .2s, border-color .2s
    }

    .cust-reset:hover {
      background: var(--paper-dark);
      color: var(--ink);
      border-color: rgba(204,197,176,.8)
    }

    /* ── REF ROW WITH CONFIDENCE ── */
    .refrow {
      display: flex;
      gap: 4px;
      align-items: flex-start;
      flex-shrink: 0
    }

    .ref-wrap {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: 3px
    }

    .ref-conf {
      display: flex;
      align-items: center;
      gap: 5px
    }

    .rci {
      font-family: var(--mono);
      font-size: .55rem;
      padding: 1px 6px;
      border-radius: 8px;
      white-space: nowrap;
      flex-shrink: 0
    }

    .rci.g {
      background: #d4f0e0;
      color: #1a7a40
    }

    .rci.y {
      background: #fef3cd;
      color: #856404
    }

    .rci.r {
      background: #fde8e8;
      color: #842029
    }

    .rci.beta {
      background: #ede7ff;
      color: #5b21b6
    }

    .ref-fmt {
      font-family: var(--mono);
      font-size: .58rem;
      color: var(--muted);
      font-style: italic;
      flex: 1;
      overflow: hidden;
      white-space: nowrap;
      text-overflow: ellipsis
    }

    /* ── BETA FLAG ── */
    .beta-flag {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      background: #ede7ff;
      border: 1px solid #c4b5fd;
      border-radius: var(--r);
      padding: 5px 9px;
      font-family: var(--mono);
      font-size: .6rem;
      color: #5b21b6;
      line-height: 1.4;
      flex-shrink: 0
    }

    .beta-flag strong {
      font-weight: 700
    }

    /* ── TABLE in preview ── */
    .tbl-wrap {
      overflow-x: auto;
      margin: 6px 0
    }

    .tbl-wrap table {
      border-collapse: collapse;
      width: 100%;
      font-size: inherit
    }

    .tbl-wrap td,
    .tbl-wrap th {
      border: 1px solid #ccc;
      padding: 4px 7px;
      text-align: left;
      vertical-align: top;
      line-height: 1.4
    }

    .tbl-wrap th {
      background: #f5f5f5;
      font-weight: 600
    }

    ::-webkit-scrollbar {
      width: 4px
    }

    ::-webkit-scrollbar-track {
      background: transparent
    }

    ::-webkit-scrollbar-thumb {
      background: var(--border);
      border-radius: 10px
    }

    /* Tier-locked gating */
    .tier-locked {
      position: relative;
      pointer-events: none;
      opacity: 0.45;
      user-select: none;
    }
    .tier-locked::after {
      content: '\1F512';
      position: absolute;
      top: 2px; right: 4px;
      font-size: 11px;
      pointer-events: auto;
      cursor: pointer;
      opacity: 0.7;
    }
    .tc.tier-locked::after { top: 6px; right: 6px; }
    button.bsm.tier-locked { pointer-events: auto; cursor: pointer; }
    button.bsm.tier-locked::after { position: static; margin-left: 4px; }
    #sampleDropMenu.show { display:block !important; }
    #sampleDropMenu button:hover { background:var(--paper-mid) !important; }

    /* ── Mode Toggle (Formatter / Linker) ── */
    .mode-toggle {
      display: flex; border: 1px solid var(--border); border-radius: var(--r);
      overflow: hidden; flex-shrink: 0;
    }
    .mode-btn {
      background: var(--paper-mid); color: var(--muted); border: none;
      font-family: var(--mono); font-size: .6rem; padding: 5px 12px;
      cursor: pointer; letter-spacing: .03em; transition: all .15s;
    }
    .mode-btn.active { background: var(--ink); color: var(--paper); }
    .mode-btn:hover:not(.active) { background: var(--paper-dark); }

    /* ── Linker Workspace ── */
    .linker-wrap {
      max-width: 520px; margin: 24px auto; padding: 0 16px;
      font-family: var(--mono); font-size: .64rem;
    }
    /* Drop zone */
    .xref-dropzone {
      border-radius: 12px;
      padding: 48px 24px;
    }
    .xref-dropzone:hover {
      border-color: var(--accent2); background: rgba(26,86,219,.04);
      transform: translateY(-2px); box-shadow: 0 6px 20px rgba(44,62,107,.08);
    }
    .xref-dropzone.drag {
      border-color: var(--accent2); background: rgba(26,86,219,.06);
      border-style: solid; transform: scale(1.01);
      box-shadow: 0 0 0 4px rgba(44,62,107,.08);
    }
    .xref-dropzone h3 {
      font-family: var(--display); font-size: .9rem; color: var(--ink);
      margin: 0 0 5px; font-weight: 700;
    }
    .xref-dropzone p { font-size: .6rem; color: var(--muted); margin: 0; line-height: 1.5; }
    /* Settings — compact inline row, no boxes */
    .xref-settings {
      margin-top: 20px; display: flex; flex-direction: column; gap: 0;
      border: 1px solid var(--border); border-radius: 8px;
      background: var(--white); overflow: hidden;
    }
    .xref-panel {
      margin: 0; border: none; border-radius: 0;
      background: transparent; overflow: hidden;
      border-bottom: 1px solid var(--border);
    }
    .xref-panel:last-child { border-bottom: none; }
    .xref-panel-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 10px 14px;
      cursor: pointer;
      user-select: none;
    }
    .xref-panel-head:hover { background: var(--paper); }
    .xref-panel-label {
      font-size: .6rem; font-weight: 700; color: var(--ink);
    }
    .xref-badge {
      background: var(--accent2); color: #fff;
      border-radius: 10px; padding: 1px 7px;
      font-size: .48rem; font-weight: 600;
      display: none;
    }
    .xref-badge.visible { display: inline; }
    .xref-chevron {
      font-size: .75rem; color: var(--muted);
      transition: transform .2s;
      display: inline-block;
    }
    .xref-panel.open .xref-chevron { transform: rotate(90deg); }
    .xref-panel-right {
      display: flex; align-items: center; gap: 8px;
    }
    .xref-panel.open .xref-panel-head { border-bottom: 1px solid var(--border); }
    .xref-row {
      display: flex; align-items: center; justify-content: space-between;
      padding: 10px 14px; border-bottom: none; gap: 12px;
    }
    .xref-row:last-child { border-bottom: none; }
    .xref-body {
      max-height: 0;
      overflow: hidden;
      transition: max-height .25s ease;
    }
    .xref-panel.open .xref-body {
      max-height: 2000px;
    }
    .xref-body .xref-row {
      padding-left: 22px;
    }
    .xref-row.xref-bulk-row {
      border-bottom: 1px dashed rgba(204,197,176,.8);
      background: rgba(247,243,231,.55);
      padding-right: 14px;
    }
    .xref-row.xref-bulk-row label {
      font-size: .5rem;
      letter-spacing: .05em;
      text-transform: uppercase;
      color: var(--muted);
      font-weight: 700;
    }
    .xref-row.xref-bulk-row select {
      min-width: 210px;
    }
    .xref-row label {
      font-size: .6rem; color: var(--ink); font-weight: 600;
      display: flex; flex-direction: column; gap: 1px; flex: 1; min-width: 0;
    }
    .xref-row .xr-hint {
      font-size: .48rem; color: var(--muted); margin-left: 0;
      font-weight: 400; display: block;
    }
    .xref-row select {
      background: var(--paper); border: 1px solid var(--border); border-radius: 6px;
      font-family: var(--mono); font-size: .58rem; color: var(--ink);
      padding: 6px 10px; flex-shrink: 0; cursor: pointer;
      transition: border-color .2s, box-shadow .2s;
    }
    .xref-row select:hover { border-color: var(--accent2); }
    .xref-row select:focus { border-color: var(--accent2); box-shadow: 0 0 0 3px rgba(44,62,107,.08); outline: none; }
    .xref-row input[type="color"] {
      width: 32px; height: 24px; padding: 0; border: 1px solid var(--border);
      border-radius: 6px; cursor: pointer; background: none;
    }
    /* Process button */
    .xref-process-bar { display: flex; justify-content: center; margin-top: 18px; }
    .xref-btn {
      background: var(--accent2); color: #fff; border: none; border-radius: 8px;
      font-family: var(--mono); font-size: .68rem; padding: 11px 44px; cursor: pointer;
      letter-spacing: .04em; font-weight: 700;
      transition: background .2s, transform .2s, box-shadow .2s;
      box-shadow: 0 2px 8px rgba(44,62,107,.2);
    }
    .xref-btn:hover { background: #1e2f57; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(44,62,107,.25); }
    .xref-btn:active { transform: translateY(0); box-shadow: 0 1px 4px rgba(44,62,107,.2); }
    .xref-btn:disabled { opacity: .25; cursor: default; transform: none; box-shadow: none; }
    .xref-btn.outline {
      background: none; color: var(--ink); border: 1px solid var(--border); font-weight: 500;
      padding: 4px 10px; font-size: .58rem; box-shadow: none;
    }
    .xref-btn.outline:hover { background: var(--paper-mid); transform: none; box-shadow: none; }
    /* File list */
    .xref-file-list { list-style: none; padding: 0; margin: 14px 0 0; }
    .xref-batch-actions {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin: 10px 0 0;
      padding: 10px 12px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--paper);
    }
    .xref-batch-copy {
      display: grid;
      gap: 2px;
      min-width: 0;
    }
    .xref-batch-title {
      font-family: var(--mono);
      font-size: .6rem;
      font-weight: 700;
      letter-spacing: 0;
      color: var(--ink);
    }
    .xref-batch-meta {
      font-family: var(--mono);
      font-size: .54rem;
      letter-spacing: 0;
      color: var(--muted);
    }
    .xref-batch-actions .xref-btn.outline {
      flex-shrink: 0;
      padding: 7px 12px;
      font-size: .56rem;
    }
    .xref-file-item {
      display: flex; align-items: center; gap: 8px; padding: 10px 14px;
      border: 1px solid var(--border); border-radius: 8px; margin-bottom: 6px;
      background: var(--white); font-size: .64rem;
      transition: box-shadow .2s, border-color .2s;
    }
    .xref-file-item:hover { box-shadow: 0 3px 12px rgba(0,0,0,.06); border-color: rgba(204,197,176,.7); }
    .xref-file-item .fname { flex: 1; font-weight: 600; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .xref-file-item .fstats { color: var(--muted); font-size: .56rem; letter-spacing: .02em; }
    .xref-file-item .fstatus {
      font-size: .52rem; padding: 3px 10px; border-radius: 10px;
      font-weight: 700; letter-spacing: .03em;
    }
    .xref-file-item .fstatus.queued { background: var(--paper-mid); color: var(--muted); }
    .xref-file-item .fstatus.processing,
    .xref-file-item .fstatus.scanning { background: #fef3c7; color: #92400e; }
    .xref-file-item .fstatus.needs-review { background: rgba(44,62,107,.12); color: var(--accent2); }
    .xref-file-item .fstatus.applying { background: rgba(200,122,45,.16); color: #8a4d17; }
    .xref-file-item .fstatus.done { background: #d1fae5; color: #065f46; }
    .xref-file-item .fstatus.error { background: #fee2e2; color: #991b1b; }
    .xref-file-item .xf-rm {
      background: none; border: none; cursor: pointer; color: var(--muted);
      font-size: .64rem; padding: 2px 4px; border-radius: 3px; line-height: 1;
      transition: color .15s, background .15s;
    }
    .xref-file-item .xf-rm:hover { color: #991b1b; background: #fee2e2; }
    .xref-progress { width: 100%; height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; margin-top: 6px; }
    .xref-progress-bar { height: 100%; background: var(--accent2); border-radius: 2px; transition: width .2s ease; width: 0; }
    .xref-progress-label { font-size: .48rem; color: var(--muted); margin-top: 2px; }
    .xref-file-item.processing-active { flex-wrap: wrap; }
    .xref-file-item .xref-progress-wrap { width: 100%; }
    .xref-actions { display: flex; gap: 8px; justify-content: center; margin-top: 14px; }
    @media (max-width: 640px) {
      .xref-batch-actions {
        align-items: stretch;
        flex-direction: column;
      }
      .xref-batch-actions .xref-btn.outline {
        width: 100%;
      }
    }
    .xref-review-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(33, 27, 16, .24);
      opacity: 0;
      pointer-events: none;
      transition: opacity .22s ease;
      z-index: 44;
    }
    .xref-review-backdrop.open {
      opacity: 1;
      pointer-events: auto;
    }
    .xref-review-drawer {
      position: fixed;
      top: 0;
      right: 0;
      bottom: 0;
      width: min(460px, 92vw);
      background: var(--paper);
      border-left: 1px solid var(--border);
      box-shadow: -16px 0 40px rgba(35, 31, 24, .12);
      display: flex;
      flex-direction: column;
      transform: translateX(100%);
      transition: transform .25s ease;
      z-index: 45;
    }
    .xref-review-drawer.open {
      transform: translateX(0);
    }
    .xref-review-bar {
      padding: 14px 18px 12px;
      border-bottom: 1px solid var(--border);
      background: linear-gradient(180deg, var(--paper) 0%, var(--paper-mid) 100%);
      display: flex;
      align-items: flex-start;
      gap: 12px;
    }
    .xref-review-bar-copy {
      flex: 1;
      min-width: 0;
    }
    .xref-review-kicker {
      font-family: var(--mono);
      font-size: .5rem;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: var(--accent2);
      margin-bottom: 4px;
    }
    .xref-review-title {
      font-family: var(--display);
      font-size: 1.1rem;
      line-height: 1.05;
      color: var(--ink);
    }
    .xref-review-subtitle {
      margin-top: 5px;
      font-size: .6rem;
      color: var(--muted);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
    .xref-review-close {
      background: none;
      border: 1px solid var(--border);
      border-radius: 999px;
      width: 32px;
      height: 32px;
      font-size: .8rem;
      color: var(--muted);
      cursor: pointer;
      flex-shrink: 0;
    }
    .xref-review-close:hover {
      color: var(--ink);
      background: var(--paper-mid);
    }
    .xref-review-body {
      flex: 1;
      overflow-y: auto;
      padding: 16px 18px 22px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }
    .xref-review-empty {
      border: 1px dashed var(--border);
      border-radius: 10px;
      padding: 18px 16px;
      background: var(--white);
      color: var(--muted);
      font-size: .64rem;
      line-height: 1.6;
    }
    .xref-review-metrics {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
    }
    .xref-review-metric {
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--white);
      padding: 10px 11px;
    }
    .xref-review-metric-label {
      font-family: var(--mono);
      font-size: .46rem;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--muted);
      margin-bottom: 5px;
    }
    .xref-review-metric-value {
      font-family: var(--display);
      font-size: 1rem;
      color: var(--ink);
      line-height: 1;
    }
    .xref-review-note {
      border: 1px solid rgba(44,62,107,.18);
      border-radius: 8px;
      background: rgba(44,62,107,.06);
      color: var(--ink);
      padding: 10px 12px;
      margin-top: 10px;
      font-size: .58rem;
      line-height: 1.55;
    }
    .xref-review-section {
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--white);
      overflow: hidden;
    }
    .xref-review-section-head {
      padding: 10px 12px;
      border-bottom: 1px solid var(--border);
      background: var(--paper-mid);
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 8px;
    }
    .xref-review-section-head strong {
      font-size: .62rem;
      color: var(--ink);
    }
    .xref-review-section-head span {
      font-family: var(--mono);
      font-size: .48rem;
      color: var(--muted);
    }
    .xref-review-filterbar {
      display: flex;
      align-items: flex-start;
      flex-direction: column;
      gap: 8px;
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--white);
      padding: 10px 12px;
    }
    .xref-review-tabs {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
    }
    .xref-review-tab {
      border: 1px solid var(--border);
      background: var(--paper);
      color: var(--muted);
      border-radius: 8px;
      padding: 5px 10px;
      font-family: var(--mono);
      font-size: .5rem;
      letter-spacing: .05em;
      text-transform: uppercase;
    }
    .xref-review-tabmeta {
      font-family: var(--mono);
      font-size: .5rem;
      color: var(--muted);
      line-height: 1.45;
    }
    .xref-resolver-toolbar {
      margin: 10px 12px 0;
      padding: 10px;
      border: 1px solid var(--border);
      border-radius: 10px;
      background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(248,246,239,.92));
      display: flex;
      flex-direction: column;
      gap: 9px;
    }
    .xref-resolver-filterbar {
      border: 0;
      border-radius: 0;
      background: transparent;
      padding: 0;
      align-items: center;
      flex-direction: row;
      justify-content: space-between;
      gap: 10px;
    }
    .xref-resolver-filterbar .xref-review-tabs {
      gap: 6px;
    }
    .xref-resolver-filterbar .xref-review-tabmeta {
      border: 1px solid rgba(204,197,176,.7);
      border-radius: 999px;
      padding: 2px 9px;
      background: rgba(247,243,231,.8);
      line-height: 1.2;
      white-space: nowrap;
    }
    .xref-resolver-bulk {
      border-top: 1px dashed rgba(204,197,176,.7);
      padding-top: 8px;
      display: grid;
      grid-template-columns: auto minmax(190px, 1fr) auto;
      align-items: center;
      gap: 9px;
    }
    .xref-resolver-bulk .xref-review-muted {
      font-size: .46rem;
      letter-spacing: .06em;
      text-transform: uppercase;
      white-space: nowrap;
    }
    .xref-resolver-bulk .xref-review-select {
      width: 100%;
      min-width: 0;
    }
    .xref-resolver-bulk .xref-review-tab {
      padding: 6px 10px;
      white-space: nowrap;
    }
    .xref-resolver-apply-summary {
      margin-top: 2px;
      font-size: .5rem;
      line-height: 1.45;
    }
    .xref-resolver-panel {
      border: 1px solid var(--border);
      border-radius: 8px;
      background: var(--white);
      padding: 16px;
      display: flex;
      flex-direction: column;
      align-items: stretch;
      gap: 14px;
    }
    .xref-resolver-copy {
      min-width: 0;
      display: flex;
      flex-direction: column;
      gap: 5px;
    }
    .xref-resolver-kicker {
      font-family: var(--mono);
      font-size: .48rem;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--accent2);
    }
    .xref-resolver-title {
      font-weight: 700;
      font-size: .72rem;
      color: var(--ink);
      line-height: 1.3;
    }
    .xref-resolver-text {
      color: var(--muted);
      font-size: .56rem;
      line-height: 1.55;
    }
    .xref-resolver-actions {
      display: flex;
      justify-content: flex-start;
      padding-top: 12px;
      border-top: 1px solid rgba(204,197,176,.55);
    }
    .xref-resolver-actions .xref-btn {
      padding: 8px 16px;
      font-size: .56rem;
      line-height: 1.2;
      box-shadow: 0 2px 8px rgba(44,62,107,.16);
    }
    .xref-resolver-panel-loading {
      align-items: stretch;
      flex-direction: column;
      gap: 12px;
    }
    .xref-resolver-meta {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
      font-family: var(--mono);
      font-size: .52rem;
      color: var(--muted);
    }
    .xref-review-tab.active {
      background: rgba(44,62,107,.08);
      color: var(--accent2);
      border-color: rgba(44,62,107,.22);
    }
    .xref-review-progress {
      height: 4px;
      background: var(--border);
      border-radius: 2px;
      overflow: hidden;
      width: 100%;
    }
    .xref-review-progress-bar {
      height: 100%;
      background: var(--accent);
      transition: width .3s ease;
    }
    .xref-review-progress-bar-anim {
      width: 40%;
      animation: xref-review-progress-slide 1.8s ease-in-out infinite;
    }
    @keyframes xref-review-progress-slide {
      0%   { margin-left: -40%; }
      50%  { margin-left: 100%; }
      100% { margin-left: 100%; }
    }
    .bib-style-card {
      position: relative;
      overflow: hidden;
      background:
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(246,243,236,.88)),
        var(--white, #fff);
      border: 1px solid rgba(162,146,102,.38);
      border-radius: 18px;
      padding: 18px;
      margin: 0 0 16px 0;
      box-shadow: 0 18px 44px -32px rgba(54,46,28,.42);
    }
    .bib-style-card::before {
      content: "";
      position: absolute;
      inset: 0 0 auto 0;
      height: 3px;
      background: linear-gradient(90deg, #111, rgba(162,146,102,.75), transparent);
      opacity: .7;
    }
    .bib-style-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 14px;
      margin-bottom: 12px;
    }
    .bib-style-card h4 {
      margin: 0;
      font-size: 16px;
      letter-spacing: -.02em;
      line-height: 1.1;
    }
    .bib-style-eyebrow {
      margin: 0 0 6px 0;
      font-size: 10px;
      line-height: 1;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: rgba(37,37,35,.54);
      font-weight: 700;
    }
    .bib-style-state {
      flex: 0 0 auto;
      border: 1px solid rgba(37,37,35,.12);
      background: rgba(255,255,255,.78);
      border-radius: 999px;
      padding: 5px 9px;
      font-size: 11px;
      line-height: 1;
      color: rgba(37,37,35,.72);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
    }
    .bib-style-card p.bib-style-copy {
      margin: 0 0 12px 0;
      color: rgba(24,24,22,.72);
      font-size: 13px;
      line-height: 1.45;
    }
    .bib-style-preview {
      font-family: var(--ui-mono, monospace);
      font-size: 12px;
      line-height: 1.42;
      background:
        linear-gradient(180deg, rgba(255,255,255,.94), rgba(249,248,244,.92));
      border: 1px solid rgba(37,37,35,.12);
      border-left: 4px solid rgba(37,37,35,.82);
      border-radius: 12px;
      padding: 12px 14px;
      margin: 0 0 12px 0;
      white-space: pre-wrap;
      color: rgba(20,20,18,.9);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
    }
    .bib-style-preview em {
      color: rgba(37,37,35,.56);
      font-style: normal;
    }
    .bib-style-actions {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 4px 0 0;
      flex-wrap: wrap;
    }
    .bib-style-apply {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-height: 30px;
      color: rgba(24,24,22,.86);
      font-size: 13px;
      cursor: pointer;
      user-select: none;
    }
    .bib-style-apply input {
      width: 16px;
      height: 16px;
      accent-color: #111;
    }
    .bib-style-alt-toggle {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      background: rgba(17,17,17,.92);
      border: 1px solid rgba(17,17,17,.12);
      border-radius: 999px;
      color: #fff;
      cursor: pointer;
      font-size: 12px;
      line-height: 1;
      padding: 8px 11px;
      transition: transform .18s cubic-bezier(.16,1,.3,1), background .18s ease, box-shadow .18s ease;
      box-shadow: 0 8px 22px -18px rgba(0,0,0,.65);
    }
    .bib-style-alt-toggle:hover {
      background: #2a2925;
      transform: translateY(-1px);
    }
    .bib-style-alt-toggle:active {
      transform: translateY(0) scale(.98);
    }
    .bib-style-alt-toggle::after {
      content: "";
      width: 6px;
      height: 6px;
      border-right: 1.5px solid currentColor;
      border-bottom: 1.5px solid currentColor;
      transform: translateY(-1px) rotate(45deg);
      transition: transform .18s cubic-bezier(.16,1,.3,1);
    }
    .bib-style-alt-toggle[aria-expanded="true"]::after {
      transform: translateY(2px) rotate(225deg);
    }
    .bib-style-alt-list {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
      gap: 8px;
      margin-top: 14px;
      padding-top: 14px;
      border-top: 1px solid rgba(37,37,35,.1);
      animation: bibStyleListIn .22s cubic-bezier(.16,1,.3,1);
    }
    .bib-style-alt-list[hidden] {
      display: none;
    }
    .bib-style-alt-btn,
    .bib-style-upload-own {
      width: 100%;
      border: 1px solid rgba(37,37,35,.14);
      border-radius: 11px;
      background: rgba(255,255,255,.76);
      color: rgba(24,24,22,.86);
      cursor: pointer;
      font-size: 12px;
      line-height: 1.25;
      text-align: left;
      padding: 9px 10px;
      transition: transform .16s cubic-bezier(.16,1,.3,1), border-color .16s ease, background .16s ease, box-shadow .16s ease;
    }
    .bib-style-alt-btn:hover,
    .bib-style-upload-own:hover {
      transform: translateY(-1px);
      border-color: rgba(37,37,35,.38);
      background: #fff;
      box-shadow: 0 10px 28px -24px rgba(0,0,0,.55);
    }
    .bib-style-alt-btn:active,
    .bib-style-upload-own:active {
      transform: translateY(0) scale(.99);
    }
    .bib-style-alt-btn.is-active {
      background: #111;
      border-color: #111;
      color: #fff;
    }
    .bib-style-upload-own {
      border-style: dashed;
      color: rgba(24,24,22,.7);
    }
    @keyframes bibStyleListIn {
      from { opacity: 0; transform: translateY(-4px); }
      to { opacity: 1; transform: translateY(0); }
    }
    @media (max-width: 640px) {
      .bib-style-card { padding: 15px; border-radius: 15px; }
      .bib-style-head { flex-direction: column; gap: 8px; }
      .bib-style-actions { align-items: stretch; }
      .bib-style-alt-toggle { width: 100%; justify-content: center; }
      .bib-style-alt-list { grid-template-columns: 1fr; }
    }
    .xref-review-list {
      display: flex;
      flex-direction: column;
    }
    .xref-review-row {
      padding: 12px;
      border-bottom: 1px solid rgba(204,197,176,.55);
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .xref-review-row:last-child {
      border-bottom: none;
    }
    .xref-review-row-top {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 12px;
    }
    .xref-review-source {
      font-size: .66rem;
      font-weight: 600;
      color: var(--ink);
      line-height: 1.45;
    }
    .xref-ref-diffs {
      margin-top: 8px;
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .xref-ref-diff-heading {
      font-family: var(--mono);
      font-size: .48rem;
      letter-spacing: .05em;
      text-transform: uppercase;
      color: var(--accent2);
    }
    .xref-ref-diff {
      border-left: 2px solid rgba(44,62,107,.22);
      padding-left: 8px;
      color: var(--muted);
      font-size: .56rem;
      line-height: 1.45;
    }
    .xref-ref-diff strong {
      color: var(--ink);
      font-family: var(--mono);
      font-size: .5rem;
      letter-spacing: .04em;
      text-transform: uppercase;
    }
    .xref-ref-diff-values {
      color: var(--muted);
    }
    .xref-ref-diff-arrow {
      color: var(--accent2);
      font-weight: 700;
      padding: 0 4px;
    }
    .xref-ref-diff-note {
      margin-top: 2px;
      color: var(--muted);
      opacity: .9;
    }
    .xref-ref-status-line {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      margin-top: 5px;
    }
    .xref-ref-status-label {
      display: inline-flex;
      align-items: center;
      border: 1px solid rgba(44,62,107,.18);
      border-radius: 8px;
      padding: 3px 7px;
      font-family: var(--mono);
      font-size: .48rem;
      letter-spacing: .04em;
      text-transform: uppercase;
      color: var(--accent2);
      background: rgba(44,62,107,.05);
    }
    .xref-ref-status-label.status-new {
      border-color: rgba(52,120,90,.26);
      color: #2e6f52;
      background: rgba(52,120,90,.08);
    }
    .xref-ref-status-label.status-page {
      border-color: rgba(0,119,189,.24);
      color: var(--accent);
      background: rgba(0,119,189,.07);
    }
    .xref-ref-status-label.status-existing {
      border-color: rgba(44,62,107,.20);
      color: var(--accent2);
      background: rgba(44,62,107,.07);
    }
    .xref-ref-status-label.status-unresolved {
      border-color: rgba(133,124,107,.28);
      color: var(--muted);
      background: rgba(133,124,107,.08);
    }
    .xref-ref-status-label.status-ready {
      border-color: rgba(52,120,90,.26);
      color: #2e6f52;
      background: rgba(52,120,90,.08);
    }
    .xref-ref-status-label.status-link-only {
      border-color: rgba(0,119,189,.24);
      color: var(--accent);
      background: rgba(0,119,189,.07);
    }
    .xref-ref-status-label.status-needs-review {
      border-color: rgba(160,99,35,.28);
      color: #8a5a1f;
      background: rgba(160,99,35,.08);
    }
    .xref-ref-status-label.status-blocked {
      border-color: rgba(176,64,58,.30);
      color: var(--danger);
      background: rgba(176,64,58,.08);
    }
    .xref-citation-status-copy {
      align-self: center;
      color: var(--muted);
      font-size: .52rem;
      line-height: 1.35;
    }
    .xref-review-affected {
      margin-top: 8px;
      border-left: 2px solid rgba(44,62,107,.18);
      padding-left: 8px;
      display: flex;
      flex-direction: column;
      gap: 4px;
    }
    .xref-review-affected-heading {
      font-family: var(--mono);
      font-size: .48rem;
      letter-spacing: .05em;
      text-transform: uppercase;
      color: var(--accent2);
    }
    .xref-review-affected-row {
      color: var(--muted);
      font-size: .56rem;
      line-height: 1.45;
    }
    .xref-review-affected-shape {
      color: var(--ink);
      font-family: var(--mono);
      font-size: .5rem;
      letter-spacing: .04em;
      text-transform: uppercase;
    }
    .xref-review-approve-sync {
      margin-top: 8px;
      display: flex;
      align-items: center;
      gap: 8px;
      color: var(--ink);
      font-family: var(--mono);
      font-size: .52rem;
      line-height: 1.3;
    }
    .xref-review-approve-sync input {
      width: 14px;
      height: 14px;
      accent-color: var(--accent2);
    }
    .xref-review-proposed {
      margin-top: 8px;
      display: grid;
      gap: 4px;
      color: var(--muted);
      font-size: .54rem;
      line-height: 1.45;
    }
    .xref-review-proposed-label {
      font-family: var(--mono);
      font-size: .46rem;
      letter-spacing: .05em;
      text-transform: uppercase;
      color: var(--accent2);
    }
    .xref-review-proposed-line del,
    .xref-review-proposed-line ins {
      border-radius: 4px;
      padding: 0 2px;
      text-decoration: none;
    }
    .xref-review-proposed-line del {
      color: #8a5a1f;
      background: rgba(160,99,35,.10);
    }
    .xref-review-proposed-line ins {
      color: #2e6f52;
      background: rgba(52,120,90,.10);
    }
    .xref-review-snippet {
      font-size: .56rem;
      color: var(--muted);
      line-height: 1.5;
    }
    .xref-review-badges {
      display: flex;
      gap: 6px;
      flex-wrap: wrap;
      flex-shrink: 0;
    }
    .xref-review-badge {
      font-family: var(--mono);
      font-size: .46rem;
      letter-spacing: .04em;
      text-transform: uppercase;
      border-radius: 999px;
      padding: 3px 8px;
      background: var(--paper-mid);
      color: var(--muted);
    }
    .xref-review-badge.status-matched { background: #dbeafe; color: #1d4ed8; }
    .xref-review-badge.status-unmatched { background: #fef3c7; color: #92400e; }
    .xref-review-badge.type-figure,
    .xref-review-badge.type-table,
    .xref-review-badge.type-equation,
    .xref-review-badge.type-section,
    .xref-review-badge.type-reference,
    .xref-review-badge.type-algorithm,
    .xref-review-badge.type-listing,
    .xref-review-badge.type-appendix,
    .xref-review-badge.type-doi,
    .xref-review-badge.type-url { background: rgba(44,62,107,.08); color: var(--accent2); }
    .xref-review-controls {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .xref-review-actions {
      display: flex;
      gap: 8px;
      align-items: center;
      flex-wrap: wrap;
    }
    .xref-review-target {
      flex-direction: column;
      align-items: flex-start;
      gap: 4px;
    }
    .xref-review-target .xref-review-select {
      width: 100%;
    }
    .xref-review-select {
      min-width: 124px;
      max-width: 100%;
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;
      background: var(--paper) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 10px center;
      border: 1px solid var(--border);
      border-radius: 8px;
      font-family: var(--mono);
      font-size: .54rem;
      color: var(--ink);
      padding: 6px 28px 6px 10px;
      text-overflow: ellipsis;
      overflow: hidden;
    }
    .xref-review-muted {
      font-size: .52rem;
      color: var(--muted);
    }
    @media (max-width: 760px) {
      .xref-resolver-filterbar {
        align-items: flex-start;
        flex-direction: column;
      }
      .xref-resolver-bulk {
        grid-template-columns: 1fr;
      }
      .xref-resolver-bulk .xref-review-muted {
        white-space: normal;
      }
    }

    /* ── Pricing Page ── */
    /* ── Pricing Page ── */
    #pricingMode { flex: 1; overflow-y: auto; min-height: 0; }
    .pricing-wrap {
      max-width: 980px; margin: 0 auto; padding: 32px 20px 48px;
      font-family: var(--body); font-size: .75rem;
    }
    .pricing-hero {
      text-align: center; margin-bottom: 32px;
    }
    .pricing-hero h2 {
      font-family: var(--display); font-size: 1.7rem; font-weight: 700;
      color: var(--ink); letter-spacing: -.02em; margin-bottom: 8px;
      line-height: 1.15;
    }
    .pricing-hero p {
      font-size: .82rem; color: var(--muted); max-width: 420px; margin: 0 auto;
      line-height: 1.5;
    }
    .pricing-stats-bar {
      text-align: center; font-family: var(--mono); font-size: .52rem;
      color: var(--muted); letter-spacing: .02em; margin-top: 14px;
    }
    .pricing-stats-bar span { font-weight: 700; color: var(--ink); }
    /* ── Launch Banner ── */
    .launch-banner {
      background: linear-gradient(135deg, var(--accent) 0%, #a83225 100%);
      color: #fff; text-align: center;
      padding: 22px 20px 18px; border-radius: 8px; margin-bottom: 24px;
      display: none;
    }
    .launch-banner .lb-title {
      font-family: var(--display); font-size: 1.05rem; font-weight: 700;
      letter-spacing: .02em; margin-bottom: 14px;
    }
    .launch-banner .lb-countdown {
      display: inline-flex; gap: 6px; align-items: center; margin-bottom: 10px;
    }
    .launch-banner .lb-unit {
      background: rgba(255,255,255,.15); border-radius: 6px;
      padding: 8px 10px 6px; text-align: center; min-width: 48px;
    }
    .launch-banner .lb-num {
      font-family: var(--mono); font-size: 1.3rem; font-weight: 800; line-height: 1;
    }
    .launch-banner .lb-label {
      font-family: var(--mono); font-size: .36rem; opacity: .7;
      letter-spacing: .08em; margin-top: 4px;
    }
    .launch-banner .lb-sep {
      font-size: 1.1rem; font-weight: 300; opacity: .4; margin: 0 -2px;
    }
    .launch-banner .lb-sub {
      font-family: var(--mono); font-size: .52rem; opacity: .75;
    }
    /* ── Promo Sections ── */
    .promo-section {
      display: none; margin-bottom: 28px;
      background: #faf8f5; border: 1px solid var(--border);
      border-radius: 10px; padding: 22px 20px 18px;
    }
    .promo-section-head {
      font-family: var(--display); font-size: 1rem; font-weight: 700;
      color: var(--ink); margin-bottom: 3px;
    }
    .promo-section-sub {
      font-size: .68rem; color: var(--muted); margin-bottom: 16px;
    }
    .promo-badge {
      display: inline-block; background: var(--accent); color: #fff;
      font-family: var(--mono); font-size: .42rem; font-weight: 700;
      padding: 2px 8px; border-radius: 3px; letter-spacing: .04em;
      vertical-align: middle; margin-left: 6px;
    }
    .promo-section .pricing-grid {
      grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px;
    }
    .promo-section .pricing-card {
      border-radius: 8px;
      transition: transform .25s ease, box-shadow .25s ease;
    }
    .promo-section .pricing-card:first-child { border-radius: 8px; }
    .promo-section .pricing-card:last-child { border-radius: 8px; }
    .promo-section .pricing-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 10px 28px rgba(0,0,0,.07);
    }
    .promo-section .pricing-card.recommended {
      border: 2px solid var(--accent);
      box-shadow: 0 4px 16px rgba(192,57,43,.08);
    }
    .promo-section .pricing-card.recommended:hover {
      transform: translateY(-4px);
      box-shadow: 0 12px 32px rgba(192,57,43,.14);
    }
    .promo-original {
      text-decoration: line-through; color: var(--muted); font-size: .6rem; margin-right: 4px;
    }
    .annual-bonus-badge {
      display: inline-block; background: #d1fae5; color: #065f46;
      font-size: .44rem; font-weight: 700; padding: 2px 7px; border-radius: 4px;
      margin-top: 4px;
    }
    .pricing-section { margin-bottom: 32px; }
    .pricing-section-head {
      font-family: var(--display); font-size: 1.15rem; font-weight: 700;
      color: var(--ink); margin-bottom: 4px;
    }
    .pricing-section-sub {
      font-size: .78rem; color: var(--muted); margin-bottom: 16px;
    }

    /* ── Tier Grid — price anchoring layout ── */
    .pricing-grid {
      display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
      align-items: stretch;
    }
    .pricing-grid.pack-grid {
      grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px;
    }

    /* ── Tier Cards ── */
    .pricing-card {
      background: var(--paper); border: 1px solid var(--border);
      padding: 20px 16px 18px; text-align: center; display: flex; flex-direction: column;
      position: relative;
      transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    }
    .pricing-card:first-child { border-radius: 8px 0 0 8px; }
    .pricing-card:last-child { border-radius: 0 8px 8px 0; }
    .pricing-card:hover {
      z-index: 2;
      transform: translateY(-3px);
      box-shadow: 0 8px 24px rgba(0,0,0,.06);
    }

    /* ── Popular (Pro) — the anchored middle tier ── */
    .pricing-card.popular {
      background: var(--accent); border-color: var(--accent);
      color: #fff; z-index: 3; border-radius: 10px;
      margin: -10px -2px -10px;
      box-shadow: 0 12px 40px rgba(192,57,43,.25), 0 2px 8px rgba(0,0,0,.08);
      padding: 28px 18px 22px;
    }
    .pricing-card.popular:hover {
      transform: translateY(-5px);
      box-shadow: 0 20px 56px rgba(192,57,43,.3), 0 6px 16px rgba(0,0,0,.1);
    }
    .pricing-card.popular .pop-badge {
      position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
      background: var(--ink); color: var(--paper); font-family: var(--mono);
      font-size: .58rem; font-weight: 700; padding: 3px 14px; border-radius: 12px;
      letter-spacing: .06em; white-space: nowrap; text-transform: uppercase;
    }
    .pricing-card.popular .tier-name { color: rgba(255,255,255,.85); }
    .pricing-card.popular .tier-price { color: #fff; font-size: 1.7rem; }
    .pricing-card.popular .tier-period { color: rgba(255,255,255,.7); }
    .pricing-card.popular .tier-desc { color: rgba(255,255,255,.85); }
    .pricing-card.popular .tier-sub { color: rgba(255,255,255,.65); }
    .pricing-card.popular .tier-features { border-top-color: rgba(255,255,255,.2); }
    .pricing-card.popular .tier-features .tf-row { color: #fff; }
    .pricing-card.popular .tier-features .tf-icon.yes { color: #fff; }
    .pricing-card.popular .tier-features .tf-text { color: #fff; }
    .pricing-card.popular .tier-features .tf-divider { color: rgba(255,255,255,.6); border-top-color: rgba(255,255,255,.15); }
    .pricing-card.popular .tier-features .tf-val { color: rgba(255,255,255,.65); }
    .pricing-card.popular .savings-badge { background: #fff; color: var(--accent); font-weight: 700; }
    .pricing-card.popular .tier-price-original { color: rgba(255,255,255,.6); }
    .pricing-card.popular .tier-price-original s { opacity: .7; }
    .pricing-card.popular .tier-promo-pct { background: rgba(255,255,255,.25); color: #fff; }
    .pricing-card.popular .pricing-btn {
      background: #fff; color: var(--accent); font-weight: 700;
    }
    .pricing-card.popular .pricing-btn:hover {
      background: rgba(255,255,255,.92);
      box-shadow: 0 4px 16px rgba(255,255,255,.25);
    }

    /* ══════════════════════════════════════════════════════════════
       V2 PREMIUM PRICING — scoped under .v2-pricing
       ══════════════════════════════════════════════════════════════ */
    .v2-pricing {
      max-width: 900px; margin: 0 auto; padding: 40px 20px 56px;
      font-family: var(--body); font-size: .75rem;
    }

    /* ── Premium Hero ── */
    .v2-pricing .v2-hero {
      display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(240px, 0.85fr);
      gap: 32px; align-items: end; margin-bottom: 48px;
    }
    .v2-pricing .v2-hero-copy { display: grid; gap: 12px; }
    .v2-pricing .v2-hero-copy h2 {
      font-family: var(--display); font-size: 2.4rem; font-weight: 700;
      color: var(--ink); line-height: 1.08; letter-spacing: -.04em;
      margin: 0;
    }
    .v2-pricing .v2-hero-copy p {
      font-size: .86rem; color: var(--muted); line-height: 1.6;
      margin: 0; max-width: 380px;
    }
    .v2-pricing .v2-hero-chips {
      display: flex; flex-wrap: wrap; gap: 8px;
    }
    .v2-pricing .v2-hero-chip {
      display: inline-block; font-family: var(--mono); font-size: .44rem;
      font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
      padding: 6px 10px; border-radius: 999px;
      border: 1px solid rgba(204, 197, 176, 0.86);
      background: rgba(255, 255, 255, 0.82); color: #50493d;
    }
    .v2-pricing .v2-hero-statbox {
      display: grid; gap: 10px; padding: 16px;
      border-radius: 20px; border: 1px solid rgba(204, 197, 176, 0.92);
      background: linear-gradient(180deg, rgba(255,255,255,0.88), rgba(245,240,232,0.98));
      box-shadow: 0 18px 40px rgba(44, 62, 107, 0.12);
    }
    .v2-pricing .v2-hero-statbox small {
      font: 700 10px/1.1 var(--mono), monospace;
      letter-spacing: .16em; text-transform: uppercase; color: var(--muted);
    }
    .v2-pricing .v2-stat-row {
      display: flex; justify-content: space-between; align-items: center;
      font-family: var(--mono); font-size: .58rem;
    }
    .v2-pricing .v2-stat-label { color: var(--muted); text-transform: uppercase; letter-spacing: .06em; }
    .v2-pricing .v2-stat-value { color: var(--ink); font-weight: 700; }

    /* ── Plan Cards Grid ── */
    .v2-pricing .v2-plan-grid {
      display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr);
      gap: 16px; margin-bottom: 24px;
    }

    /* ── Plan Card — base ── */
    .v2-pricing .v2-plan-card {
      border-radius: 18px; padding: 22px 20px 20px;
      display: flex; flex-direction: column; gap: 14px;
      position: relative; min-height: 380px;
      transition: transform .3s ease, box-shadow .3s ease;
      border: 1px solid rgba(204, 197, 176, 0.92);
      box-shadow: 0 22px 50px rgba(44, 62, 107, 0.1);
    }

    /* ── Starter Card — light ── */
    .v2-pricing .v2-plan-card--starter {
      background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(245,240,232,0.98));
    }

    /* ── Pro Card — dark navy ── */
    .v2-pricing .v2-plan-card--pro {
      background:
        radial-gradient(circle at top right, rgba(29, 138, 80, 0.16), transparent 28%),
        linear-gradient(180deg, rgba(44, 62, 107, 0.98), rgba(18, 26, 46, 0.98));
      border-color: rgba(44, 62, 107, 0.88);
      color: rgba(245, 240, 232, 0.92);
      transform: translateY(-6px);
      box-shadow: 0 28px 60px rgba(13, 13, 13, 0.24);
    }
    .v2-pricing .v2-plan-card--pro:hover {
      transform: translateY(-8px);
      box-shadow: 0 32px 72px rgba(13, 13, 13, 0.28);
    }

    /* ── Eyebrow ── */
    .v2-pricing .v2-eyebrow {
      font: 700 10px/1.1 var(--mono), monospace;
      letter-spacing: .16em; text-transform: uppercase;
    }
    .v2-pricing .v2-plan-card--starter .v2-eyebrow { color: var(--accent); }
    .v2-pricing .v2-plan-card--pro .v2-eyebrow { color: rgba(245, 240, 232, 0.76); }

    /* ── Plan header ── */
    .v2-pricing .v2-plan-header { display: grid; gap: 8px; padding-right: 92px; }
    .v2-pricing .v2-plan-header h4 {
      margin: 0; font-family: var(--display); font-size: 1.5rem;
      font-weight: 600; letter-spacing: -.03em;
    }
    .v2-pricing .v2-plan-card--starter .v2-plan-header h4 { color: var(--ink); }
    .v2-pricing .v2-plan-card--pro .v2-plan-header h4 { color: rgba(245, 240, 232, 0.96); }

    /* ── Price row ── */
    .v2-pricing .v2-plan-price {
      display: flex; align-items: baseline; gap: 6px;
      font-family: var(--mono); color: var(--ink);
    }
    .v2-pricing .v2-plan-price strong {
      font-size: 2.4rem; line-height: 0.9;
      font-family: var(--mono);
    }
    .v2-pricing .v2-plan-price span { font-size: .72rem; color: var(--muted); }
    .v2-pricing .v2-plan-card--pro .v2-plan-price,
    .v2-pricing .v2-plan-card--pro .v2-plan-price strong { color: rgba(245, 240, 232, 0.96); }
    .v2-pricing .v2-plan-card--pro .v2-plan-price span { color: rgba(245, 240, 232, 0.6); }

    /* ── Tagline ── */
    .v2-pricing .v2-plan-sub {
      font-size: .72rem; line-height: 1.55;
    }
    .v2-pricing .v2-plan-card--starter .v2-plan-sub { color: var(--muted); }
    .v2-pricing .v2-plan-card--pro .v2-plan-sub { color: rgba(245, 240, 232, 0.72); }

    /* ── Feature list ── */
    .v2-pricing .v2-plan-features {
      display: grid; gap: 8px; list-style: none; padding: 0; margin: 0;
    }
    .v2-pricing .v2-plan-features li {
      display: flex; align-items: center; gap: 8px;
      font-size: .72rem; line-height: 1.45;
    }
    .v2-pricing .v2-plan-features li::before {
      content: ''; width: 6px; height: 6px; border-radius: 999px;
      flex: none;
    }
    .v2-pricing .v2-plan-card--starter .v2-plan-features li { color: #423c30; }
    .v2-pricing .v2-plan-card--starter .v2-plan-features li::before { background: var(--border); }
    .v2-pricing .v2-plan-card--pro .v2-plan-features li { color: rgba(245, 240, 232, 0.92); }
    .v2-pricing .v2-plan-card--pro .v2-plan-features li::before { background: rgba(245, 240, 232, 0.62); }
    .v2-pricing .v2-plan-features li.v2-not-included {
      text-decoration: line-through; opacity: .45;
    }

    /* ── Usage Panel (green border) ── */
    .v2-pricing .v2-usage-panel {
      display: grid; gap: 10px; padding: 14px;
      border-radius: 16px;
      border: 1px solid rgba(29, 138, 80, 0.18);
      background: rgba(29, 138, 80, 0.06);
    }
    .v2-pricing .v2-plan-card--pro .v2-usage-panel {
      background: rgba(255, 255, 255, 0.08);
      border-color: rgba(245, 240, 232, 0.16);
    }
    .v2-pricing .v2-usage-row { display: grid; gap: 6px; }
    .v2-pricing .v2-usage-row strong {
      display: flex; justify-content: space-between; gap: 10px;
      font: 700 11px/1.2 var(--mono), monospace;
      letter-spacing: .12em; text-transform: uppercase;
    }
    .v2-pricing .v2-plan-card--starter .v2-usage-row strong { color: var(--ink); }
    .v2-pricing .v2-plan-card--pro .v2-usage-row strong { color: rgba(245, 240, 232, 0.96); }
    .v2-pricing .v2-usage-bar {
      height: 8px; border-radius: 999px;
      background: rgba(13, 13, 13, 0.08); overflow: hidden;
    }
    .v2-pricing .v2-plan-card--pro .v2-usage-bar { background: rgba(255, 255, 255, 0.1); }
    .v2-pricing .v2-usage-bar > span {
      display: block; height: 100%; border-radius: inherit;
      background: linear-gradient(90deg, var(--green), rgba(29, 138, 80, 0.55));
      transition: width .4s ease;
    }
    .v2-pricing .v2-usage-bar > span.v2-usage-warn {
      background: linear-gradient(90deg, #ffa726, #ef5350);
    }

    /* ── Mini stat panels (Pro card) ── */
    .v2-pricing .v2-stat-grid {
      display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
    }
    .v2-pricing .v2-mini-panel {
      padding: 12px 13px; display: grid; gap: 6px;
      border-radius: 18px; border: 1px solid rgba(204, 197, 176, 0.92);
      background: rgba(255, 255, 255, 0.74);
    }
    .v2-pricing .v2-plan-card--pro .v2-mini-panel {
      background: rgba(255, 255, 255, 0.08);
      border-color: rgba(245, 240, 232, 0.16);
    }
    .v2-pricing .v2-mini-panel h5 {
      margin: 0; font-family: var(--display); font-size: .78rem;
      font-weight: 600; letter-spacing: -.03em; color: var(--ink);
    }
    .v2-pricing .v2-plan-card--pro .v2-mini-panel h5 { color: rgba(245, 240, 232, 0.96); }
    .v2-pricing .v2-mini-panel strong {
      font: 700 1rem/1 var(--mono), monospace; color: var(--accent2);
    }
    .v2-pricing .v2-plan-card--pro .v2-mini-panel strong { color: rgba(245, 240, 232, 0.96); }
    .v2-pricing .v2-mini-panel p {
      margin: 0; font-size: .6rem; line-height: 1.55; color: var(--muted);
    }
    .v2-pricing .v2-plan-card--pro .v2-mini-panel p { color: rgba(245, 240, 232, 0.72); }

    /* ── Current plan badge ── */
    .v2-pricing .v2-plan-card--current { position: relative; overflow: hidden; }
    .v2-pricing .v2-plan-card--current::after {
      content: 'current plan'; position: absolute; top: 16px; right: 16px;
      border-radius: 999px; padding: 7px 10px;
      background: rgba(29, 138, 80, 0.1); color: var(--green);
      border: 1px solid rgba(29, 138, 80, 0.18);
      font: 700 10px/1 var(--mono), monospace;
      letter-spacing: .12em; text-transform: uppercase;
    }

    /* ── CTA buttons ── */
    .v2-pricing .v2-cta-row { display: flex; gap: 10px; align-items: center; margin-top: auto; }
    .v2-pricing .v2-cta, .v2-pricing .v2-cta-subtle {
      border-radius: 999px; padding: 13px 16px;
      font: 700 11px/1.1 var(--mono), monospace;
      letter-spacing: .12em; text-transform: uppercase;
      text-align: center; border: none; cursor: pointer;
      transition: all .2s ease; text-decoration: none;
    }
    .v2-pricing .v2-cta {
      flex: 1; background: var(--accent); color: #fff;
      box-shadow: 0 16px 28px rgba(192, 57, 43, 0.22);
    }
    .v2-pricing .v2-cta:hover { background: #a83225; box-shadow: 0 20px 36px rgba(192, 57, 43, 0.28); }
    .v2-pricing .v2-cta-subtle {
      flex: 1; color: var(--ink);
      border: 1px solid rgba(204, 197, 176, 0.92);
      background: rgba(255, 255, 255, 0.76);
    }
    .v2-pricing .v2-cta-subtle:hover { border-color: var(--ink); }
    .v2-pricing .v2-plan-card--pro .v2-cta {
      background: var(--paper); color: var(--accent2); box-shadow: none;
    }
    .v2-pricing .v2-plan-card--pro .v2-cta:hover { background: #fff; }
    .v2-pricing .v2-plan-card--pro .v2-cta-subtle {
      background: rgba(255, 255, 255, 0.08);
      border-color: rgba(245, 240, 232, 0.18);
      color: rgba(245, 240, 232, 0.88);
    }
    .v2-pricing .v2-cta-current {
      background: transparent; color: var(--green);
      border: 1px solid rgba(29, 138, 80, 0.3);
      cursor: default; box-shadow: none;
    }
    .v2-pricing .v2-cta-current:hover { background: transparent; box-shadow: none; }

    /* ── Team Card ── */
    .v2-pricing .v2-team-card {
      background: rgba(255, 255, 255, 0.74);
      border: 1px solid rgba(204, 197, 176, 0.92); border-radius: 18px;
      padding: 18px 20px; display: flex; gap: 16px;
      justify-content: space-between; align-items: center;
      margin-bottom: 24px;
    }
    .v2-pricing .v2-team-copy { flex: 1; }
    .v2-pricing .v2-team-copy h3 {
      font-family: var(--display); font-size: 1rem; font-weight: 600;
      color: var(--ink); margin: 0 0 4px; letter-spacing: -.02em;
    }
    .v2-pricing .v2-team-copy p { font-size: .68rem; color: var(--muted); margin: 0; line-height: 1.5; }
    .v2-pricing .v2-team-cta {
      display: inline-block; font: 700 11px/1.1 var(--mono), monospace;
      letter-spacing: .12em; text-transform: uppercase;
      color: var(--accent2); text-decoration: none;
      border: 1px solid rgba(44, 62, 107, 0.3); border-radius: 999px;
      padding: 11px 18px; transition: all .2s ease; white-space: nowrap;
    }
    .v2-pricing .v2-team-cta:hover { background: var(--accent2); color: #fff; }

    /* ── Skeleton Loading ── */
    .v2-pricing-skeleton {
      max-width: 900px; margin: 0 auto; padding: 40px 20px 56px;
    }
    .v2-pricing-skeleton .v2-skel-bar {
      background: linear-gradient(90deg, var(--border) 25%, rgba(204,197,176,.4) 50%, var(--border) 75%);
      background-size: 200% 100%;
      animation: v2SkelShimmer 1.5s ease infinite;
      border-radius: 6px;
    }
    @keyframes v2SkelShimmer {
      0% { background-position: 200% 0; }
      100% { background-position: -200% 0; }
    }

    /* ── Responsive ── */
    @media (max-width: 700px) {
      .v2-pricing .v2-hero { grid-template-columns: 1fr; gap: 20px; }
      .v2-pricing .v2-hero-copy h2 { font-size: 1.8rem; }
      .v2-pricing .v2-plan-grid { grid-template-columns: 1fr; }
      .v2-pricing .v2-plan-card--pro { transform: none; }
      .v2-pricing .v2-plan-card--pro:hover { transform: translateY(-4px); }
      .v2-pricing .v2-plan-header { padding-right: 0; }
      .v2-pricing .v2-plan-card--current::after { position: static; width: fit-content; }
      .v2-pricing .v2-stat-grid { grid-template-columns: 1fr; }
      .v2-pricing .v2-team-card { flex-direction: column; text-align: center; }
    }

    /* ══════════════════════════════════════════════════════════════
       V2 PROMPTS — explanation-first overlay design
       ══════════════════════════════════════════════════════════════ */
    .v2-prompt-overlay {
      position: fixed; inset: 0;
      background: rgba(13, 13, 13, .5);
      backdrop-filter: blur(3px);
      display: flex; align-items: center; justify-content: center;
      z-index: 10002; padding: 16px;
    }
    .v2-prompt-card {
      background: var(--paper); border-radius: 20px;
      max-width: 440px; width: 100%;
      padding: 28px 24px 22px;
      box-shadow: 0 24px 72px rgba(0,0,0,.28);
    }
    .v2-prompt-eyebrow {
      font: 700 10px/1.1 var(--mono), monospace;
      letter-spacing: .16em; text-transform: uppercase;
      color: var(--accent); margin-bottom: 10px;
    }
    .v2-prompt-title {
      font-family: var(--display); font-size: 1.3rem; font-weight: 600;
      color: var(--ink); margin-bottom: 10px; line-height: 1.15;
      letter-spacing: -.03em;
    }
    .v2-prompt-body {
      font-size: .74rem; color: #4a4337; line-height: 1.6;
      margin-bottom: 16px;
    }
    .v2-prompt-meta {
      display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px;
    }
    .v2-prompt-meta-chip {
      border-radius: 999px; padding: 8px 10px;
      background: rgba(192, 57, 43, 0.08); color: var(--accent);
      font: 700 10px/1.1 var(--mono), monospace;
      letter-spacing: .12em; text-transform: uppercase;
    }
    .v2-prompt-actions {
      display: flex; gap: 10px;
    }
    .v2-prompt-btn-primary {
      flex: 1; border-radius: 999px; padding: 13px 16px; border: none;
      background: var(--accent); color: #fff;
      font: 700 11px/1.1 var(--mono), monospace;
      letter-spacing: .12em; text-transform: uppercase;
      cursor: pointer; text-align: center; transition: background .2s;
    }
    .v2-prompt-btn-primary:hover { background: #a83225; }
    .v2-prompt-btn-secondary {
      flex: 1; border-radius: 999px; padding: 13px 16px;
      background: rgba(255, 255, 255, 0.82);
      border: 1px solid rgba(204, 197, 176, 0.92);
      color: var(--ink);
      font: 700 11px/1.1 var(--mono), monospace;
      letter-spacing: .12em; text-transform: uppercase;
      cursor: pointer; text-align: center; transition: all .2s;
    }
    .v2-prompt-btn-secondary:hover { border-color: var(--ink); }

    /* ── Current plan indicator ── */
    .pricing-card.current { border: 2px solid var(--accent); }

    /* ── Card internals ── */
    .pricing-card .tier-name {
      font-family: var(--mono); font-weight: 700; font-size: .72rem;
      color: var(--muted); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 8px;
    }
    .pricing-card .tier-price {
      font-family: var(--display); font-size: 1.5rem; font-weight: 800;
      color: var(--ink); line-height: 1; margin-bottom: 2px;
      font-variant-numeric: tabular-nums;
    }
    .pricing-card .tier-period {
      font-family: var(--mono); font-size: .64rem; color: var(--muted); margin-bottom: 6px;
    }
    .pricing-card .tier-price-original {
      font-family: var(--mono); font-size: .68rem; color: var(--muted); margin-bottom: 4px;
    }
    .pricing-card .tier-price-original s { opacity: .6; }
    .pricing-card .tier-promo-pct {
      display: inline-block; background: var(--accent); color: #fff;
      font-size: .58rem; font-weight: 700; padding: 1px 5px; border-radius: 3px;
      vertical-align: middle; letter-spacing: .03em;
    }
    .pricing-card .tier-desc {
      font-size: .72rem; color: var(--muted); line-height: 1.4; margin-bottom: 8px;
      min-height: 2.8em;
    }
    .pricing-card .tier-sub { font-size: .68rem; color: var(--muted); margin-bottom: 6px; }
    .pricing-card .tier-features {
      border-top: 1px solid var(--border); padding-top: 10px; margin-bottom: 14px;
      flex: 1; text-align: left;
    }
    .pricing-card .tier-features .tf-row {
      display: flex; align-items: flex-start; gap: 6px; margin: 4px 0;
      font-size: .68rem; color: var(--ink); line-height: 1.4;
    }
    .pricing-card .tier-features .tf-icon {
      flex-shrink: 0; font-size: .68rem; width: 16px; text-align: center; margin-top: 1px;
    }
    .pricing-card .tier-features .tf-icon.yes { color: var(--green); font-weight: 700; }
    .pricing-card .tier-features .tf-icon.no { color: var(--border); }
    .pricing-card .tier-features .tf-icon.label { color: var(--accent); font-weight: 600; font-size: .58rem; }
    .pricing-card .tier-features .tf-text { flex: 1; }
    .pricing-card .tier-features .tf-text.disabled { color: var(--muted); text-decoration: line-through; opacity: .5; }
    .pricing-card .tier-features .tf-val {
      font-size: .56rem; color: var(--muted); font-weight: 600; margin-left: 2px;
    }
    .pricing-card .tier-features .tf-divider {
      font-size: .52rem; font-weight: 700; color: var(--muted); text-transform: uppercase;
      letter-spacing: .08em; margin: 8px 0 3px; padding-top: 6px;
      border-top: 1px solid var(--border);
    }
    .pricing-card .tier-features .tf-divider:first-child { border-top: none; margin-top: 0; padding-top: 0; }
    .pricing-card .savings-badge {
      display: inline-block; background: #d1fae5; color: #065f46;
      font-size: .6rem; font-weight: 600; padding: 3px 10px; border-radius: 10px; margin-top: 4px;
      letter-spacing: .02em;
    }

    /* ── Pricing Buttons ── */
    .pricing-btn {
      background: var(--ink); color: var(--paper); border: none; border-radius: 6px;
      font-family: var(--mono); font-size: .76rem; padding: 11px 20px;
      font-weight: 600; letter-spacing: .04em; cursor: pointer;
      transition: background .2s, transform .2s, box-shadow .2s, opacity .2s;
      margin-top: auto;
    }
    .pricing-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 4px 12px rgba(13,13,13,.15);
      opacity: .92;
    }
    .pricing-btn:active { transform: translateY(0); box-shadow: none; }
    .pricing-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
    .pricing-btn.accent { background: var(--accent); color: #fff; }
    .pricing-btn.accent:hover { box-shadow: 0 4px 12px rgba(192,57,43,.2); }
    .pricing-btn.outline {
      background: none; color: var(--muted); border: 1px solid var(--border); cursor: default;
    }
    .pricing-btn.outline:hover { opacity: 1; transform: none; box-shadow: none; }

    /* ── Billing Toggle ── */
    .billing-toggle {
      display: inline-flex; background: var(--paper-mid); border-radius: 8px; padding: 3px; gap: 2px;
    }
    .billing-toggle button {
      padding: 8px 20px; border: none; border-radius: 6px;
      font-family: var(--mono); font-size: .76rem; font-weight: 600;
      cursor: pointer; transition: background .25s, color .25s, box-shadow .25s;
    }
    .billing-toggle button.active {
      background: var(--ink); color: var(--paper);
      box-shadow: 0 2px 8px rgba(13,13,13,.15);
    }
    .billing-toggle button:not(.active) { background: transparent; color: var(--muted); }
    .billing-toggle button:not(.active):hover { color: var(--ink); }

    /* ── Pack Cards ── */
    .pricing-grid.pack-grid .pricing-card {
      border-radius: 8px; padding: 18px 14px;
    }

    /* ── Credit Table ── */
    .credit-table { width: 100%; border-collapse: collapse; font-size: .76rem; }
    .credit-table th {
      text-align: left; padding: 8px 10px; background: var(--paper-mid);
      font-weight: 700; color: var(--muted); text-transform: uppercase;
      letter-spacing: .06em; font-size: .62rem; border-bottom: 1px solid var(--border);
    }
    .credit-table td {
      padding: 7px 10px; border-bottom: 1px solid var(--border); color: var(--ink);
      transition: background .15s;
    }
    .credit-table tr:hover td { background: rgba(204,197,176,.1); }
    .credit-table .free-tag { color: var(--green); font-weight: 600; }
    .pricing-callout {
      background: var(--paper-mid); border: 1px solid var(--border); border-radius: 6px;
      padding: 12px 16px; font-size: .74rem; color: var(--ink); margin-top: 14px;
    }
    .pricing-note { font-size: .72rem; color: var(--muted); margin: 4px 0; }

    /* ── Pricing Responsive ── */
    @media (max-width: 860px) {
      .pricing-grid { grid-template-columns: repeat(2, 1fr); gap: 0; }
      .pricing-card:first-child { border-radius: 8px 0 0 0; }
      .pricing-card:nth-child(2) { border-radius: 0 8px 0 0; }
      .pricing-card:nth-child(3) { border-radius: 0 0 0 8px; }
      .pricing-card:last-child { border-radius: 0 0 8px 0; }
      .pricing-card.popular { margin: -8px -2px -8px; }
    }
    @media (max-width: 640px) {
      .pricing-grid { grid-template-columns: 1fr !important; gap: 10px; }
      .pricing-grid .pricing-card { border-radius: 8px !important; }
      .pricing-card.popular { margin: 0; padding: 22px 16px 18px; }
      .pricing-grid.pack-grid { grid-template-columns: repeat(2, 1fr) !important; }
      .pricing-hero h2 { font-size: 1.25rem; }
    }

    /* Hide mobile toggle bar on desktop (must precede media queries) */
    .mob-toggle-bar { display: none; }

    /* ══════════════════════════════════════════════════════════════════
       RESPONSIVE — Touch targets
       ══════════════════════════════════════════════════════════════════ */
    @media (pointer: coarse) {
      .stab, .navbtn, .fmtbtn, .mode-btn, .pricing-btn, .bsm,
      select, input[type="text"], input[type="number"], input[type="file"] {
        min-height: 44px;
      }
      .stab { padding: 10px 14px; }
      select, input[type="text"], input[type="number"] { padding: 10px 8px; }
    }

    /* ══════════════════════════════════════════════════════════════════
       RESPONSIVE — Tablet (≤ 1024px)
       ══════════════════════════════════════════════════════════════════ */
    @media (max-width: 1024px) {
      .workspace {
        grid-template-columns: minmax(340px, 45%) 1fr;
      }
      #view-app header {
        flex-wrap: wrap;
      }
      .hright {
        flex-wrap: wrap;
      }
      .tgrid {
        grid-template-columns: repeat(2, 1fr);
      }
      .steps-bar {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
      }
    }

    /* ══════════════════════════════════════════════════════════════════
       RESPONSIVE — Mobile (≤ 640px)
       ══════════════════════════════════════════════════════════════════ */
    @media (max-width: 640px) {
      /* 4a — unlock body scrolling */
      #view-app { overflow: visible; overflow-y: auto; height: auto; }
      #formatterMode { overflow: visible; height: auto; flex: none; }

      /* 4b — compact header */
      #view-app header { padding: 8px 12px; gap: 8px; }
      #view-app header h1 { font-size: .88rem; }
      #view-app header p { display: none; }
      /* Hide "no upload · private" text, keep green LOCAL label */
      #view-app header .hright > div:first-child > div:nth-child(2) { display: none; }
      .hright { width: 100%; justify-content: flex-end; gap: 6px; }
      .mode-toggle { width: 100%; order: 10; }
      .mode-btn { flex: 1; text-align: center; padding: 8px 6px; }

      /* 4c — single-panel workspace toggle */
      .workspace {
        display: flex;
        flex-direction: column;
        overflow: visible;
      }
      .left, .right {
        width: 100%;
        border-right: none;
        overflow: visible;
        min-height: 0;
      }
      .spanel { overflow: visible; }
      .scroll { overflow: visible; flex: none; }
      .mob-hidden { display: none !important; }

      /* Mobile panel toggle bar (created by JS) */
      .mob-toggle-bar {
        display: flex;
        position: sticky;
        top: 0;
        z-index: 100;
        background: var(--ink);
        border-bottom: 2px solid var(--accent);
      }
      .mob-toggle-btn {
        flex: 1;
        background: transparent;
        color: var(--muted);
        border: none;
        font-family: var(--mono);
        font-size: .68rem;
        font-weight: 600;
        padding: 10px 0;
        cursor: pointer;
        letter-spacing: .04em;
        transition: all .15s;
      }
      .mob-toggle-btn.active {
        color: var(--paper);
        box-shadow: inset 0 -2px 0 var(--accent);
      }

      /* 4d — collapse grids to 1-column */
      .cust-body { grid-template-columns: 1fr !important; }
      .hdg-pane.active { grid-template-columns: 1fr !important; }
      .tgrid { grid-template-columns: 1fr !important; }
      .twoc { grid-template-columns: 1fr !important; }
      .dcb { grid-template-columns: 1fr !important; }
      .mi-author-row { grid-template-columns: 1fr !important; }
      #hdrRowsContainer > div { grid-template-columns: 1fr !important; }
      /* Override inline-style grids inside cust-body */
      .cust-body > div[style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
      }

      /* 4e — step bar compact */
      .steps-bar { padding: 0 8px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
      .stab span { display: none; }
      .stab.active span { display: inline; }
      .stab { padding: 8px 10px; gap: 4px; }
      .snum { width: 22px; height: 22px; font-size: .6rem; }
      .ssep { min-width: 8px; }

      /* 4f — format bar sticky bottom */
      .fbar {
        position: sticky;
        bottom: 0;
        z-index: 90;
      }

      /* 4g — preview panel */
      .right { min-height: 70vh; }
      .obar { flex-wrap: wrap; }

      /* 4h — linker & pricing tighter */
      .linker-wrap { padding: 0 10px; margin: 16px auto; }
      .pricing-wrap { padding: 0 10px; }

      /* 4i — modals fit viewport */
      .modal { max-height: 90vh; overflow-y: auto; }
      .pp-checkout-box { max-height: 85vh; overflow-y: auto; }
    }

    .pp-checkout-overlay {
      position: fixed; inset: 0; background: rgba(13,13,13,.55);
      backdrop-filter: blur(4px); display: flex; align-items: center;
      justify-content: center; z-index: 10001; padding: 16px;
    }
    .pp-checkout-box {
      background: var(--paper); border-radius: 12px; max-width: 360px; width: 100%;
      padding: 24px; box-shadow: 0 20px 60px rgba(0,0,0,.25); text-align: center;
    }

    /* ── Referral Prompt ── */
    .ref-prompt-overlay {
      position: fixed; inset: 0; background: rgba(0,0,0,.55);
      backdrop-filter: blur(4px);
      display: flex; align-items: center; justify-content: center;
      z-index: 10001; padding: 16px;
    }
    .ref-prompt-box {
      background: var(--paper); border: 1px solid var(--border); border-radius: 12px;
      padding: 28px 32px; max-width: 420px; width: 100%; box-shadow: 0 8px 32px rgba(0,0,0,.25);
    }
    .ref-prompt-title {
      font-weight: 700; font-size: 16px; color: var(--ink); margin-bottom: 16px;
    }
    .ref-prompt-code-row {
      display: flex; gap: 8px; align-items: center; margin-bottom: 12px;
    }
    .ref-prompt-code-row input {
      flex: 1; padding: 7px 10px; border: 1px solid var(--border); border-radius: 6px;
      font-family: var(--mono); font-size: 13px; background: var(--paper); color: var(--ink);
      text-transform: uppercase;
    }
    .ref-prompt-code-row button, .ref-prompt-copy-btn {
      padding: 7px 14px; border: none; border-radius: 6px; cursor: pointer;
      font-size: 12px; font-weight: 600; background: var(--accent); color: #fff;
    }
    .ref-prompt-link {
      font-family: var(--mono); font-size: 12px; color: var(--muted);
      margin-bottom: 12px; word-break: break-all;
    }
    .ref-prompt-reward {
      font-size: 13px; color: var(--ink); margin-bottom: 8px;
    }
    .ref-prompt-count {
      font-size: 12px; color: var(--muted); margin-bottom: 16px;
    }
    .ref-prompt-error {
      font-size: 12px; color: #e74c3c; margin-top: 4px; min-height: 16px;
    }
    .ref-prompt-dismiss {
      float: right; padding: 7px 18px; border: 1px solid var(--border); border-radius: 6px;
      background: transparent; color: var(--muted); cursor: pointer; font-size: 12px;
    }
    /* ── Admin Panel ── */
    #adminMode { display:none; padding:24px 32px; height:100%; overflow-y:auto; background:color-mix(in srgb, var(--paper) 96%, var(--border)); }
    .admin-layout { display:grid; grid-template-columns:170px 1fr; gap:28px; min-height:80vh; }

    /* Sidebar */
    .admin-sidebar { display:flex; flex-direction:column; gap:2px; position:sticky; top:24px; align-self:start; }
    .admin-tab { padding:9px 14px; border:none; background:none; text-align:left; font-family:var(--body);
      font-size:.78rem; color:var(--muted); border-radius:8px; cursor:pointer; font-weight:500;
      transition:background .15s, color .15s; letter-spacing:-.01em; }
    .admin-tab:hover { background:color-mix(in srgb, var(--border) 50%, transparent); color:var(--ink); }
    .admin-tab.active { background:var(--ink); color:var(--paper); font-weight:600; }

    /* Panel */
    .admin-content { min-width:0; }
    .admin-panel { display:none; }
    .admin-panel.active { display:block; }

    /* Section titles */
    .admin-section-title { font-size:1.05rem; font-weight:700; color:var(--ink); margin:0 0 18px; letter-spacing:-.02em; }
    .admin-section-subtitle { font-size:.68rem; color:var(--muted); font-weight:400; margin-left:6px; }

    /* Cards */
    .admin-card { background:var(--paper); border:1px solid var(--border); border-radius:10px; padding:20px 22px;
      margin-bottom:16px; transition:border-color .2s, box-shadow .2s; }
    .admin-card:hover { border-color:color-mix(in srgb, var(--accent) 30%, var(--border));
      box-shadow:0 2px 12px color-mix(in srgb, var(--ink) 4%, transparent); }
    .admin-card-title { font-size:.82rem; font-weight:600; color:var(--ink); margin:0 0 14px; letter-spacing:-.01em; }

    /* Stat grid */
    .admin-stat-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(160px, 1fr)); gap:14px; margin-bottom:24px; }
    .admin-stat { background:var(--paper); border:1px solid var(--border); border-radius:10px; padding:16px 18px;
      transition:border-color .2s, box-shadow .2s; }
    .admin-stat:hover { border-color:color-mix(in srgb, var(--accent) 30%, var(--border));
      box-shadow:0 2px 8px color-mix(in srgb, var(--ink) 4%, transparent); }
    .admin-stat-label { font-size:.6rem; color:var(--muted); text-transform:uppercase; letter-spacing:.6px; font-weight:600; }
    .admin-stat-value { font-size:1.5rem; font-weight:700; color:var(--ink); margin-top:4px;
      font-variant-numeric:tabular-nums; letter-spacing:-.02em; }
    .admin-stat-sub { font-size:.65rem; color:var(--muted); margin-top:3px; font-weight:500; }
    .admin-stat--accent .admin-stat-value { color:var(--accent); }

    /* Tables */
    .admin-table { width:100%; border-collapse:separate; border-spacing:0; font-size:.74rem; }
    .admin-table th { text-align:left; padding:10px 12px; font-weight:600; color:var(--muted); font-size:.62rem;
      text-transform:uppercase; letter-spacing:.5px; border-bottom:2px solid var(--border);
      background:color-mix(in srgb, var(--border) 20%, transparent); position:sticky; top:0; }
    .admin-table td { padding:10px 12px; border-bottom:1px solid color-mix(in srgb, var(--border) 60%, transparent);
      vertical-align:middle; }
    .admin-table tbody tr { transition:background .12s; }
    .admin-table tbody tr:hover td { background:color-mix(in srgb, var(--accent) 4%, transparent); }
    .admin-table-wrap { background:var(--paper); border:1px solid var(--border); border-radius:10px;
      overflow:hidden; }
    .admin-table-wrap .admin-table th:first-child { border-radius:9px 0 0 0; }
    .admin-table-wrap .admin-table th:last-child { border-radius:0 9px 0 0; }

    /* Badges */
    .admin-badge { display:inline-flex; align-items:center; padding:3px 9px; border-radius:5px; font-size:.6rem;
      font-weight:600; letter-spacing:.3px; }
    .admin-badge--success { background:#d4edda; color:#155724; }
    .admin-badge--warn { background:#fff3cd; color:#856404; }
    .admin-badge--danger { background:#f8d7da; color:#721c24; }
    .admin-badge--info { background:color-mix(in srgb, var(--accent2) 12%, transparent); color:var(--accent2); }
    .admin-badge--neutral { background:color-mix(in srgb, var(--border) 50%, transparent); color:var(--muted); }
    /* Legacy badge compat */
    .admin-badge.verified, .admin-badge.pending_verification { background:#d4edda; color:#155724; }
    .admin-badge.pending { background:#fff3cd; color:#856404; }
    .admin-badge.fraud_flagged, .admin-badge.fraud { background:#f8d7da; color:#721c24; }

    /* Forms */
    .admin-form-row { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
    .admin-form-row label { min-width:170px; font-size:.73rem; font-weight:600; color:var(--ink); }
    .admin-form-row input, .admin-form-row select, .admin-form-row textarea {
      flex:1; padding:8px 12px; border:1px solid var(--border); border-radius:7px;
      font-family:var(--body); font-size:.74rem; background:var(--paper); color:var(--ink);
      transition:border-color .15s, box-shadow .15s; }
    .admin-form-row input:focus, .admin-form-row select:focus, .admin-form-row textarea:focus {
      outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent); }
    .admin-form-row input[type="checkbox"] { flex:none; width:18px; height:18px; accent-color:var(--accent); }
    .admin-form-row textarea { font-family:var(--mono); font-size:.7rem; }
    .admin-form-inline { display:flex; gap:8px; flex-wrap:wrap; align-items:end; margin-bottom:16px; }
    .admin-form-inline .admin-field { display:flex; flex-direction:column; gap:3px; }
    .admin-form-inline .admin-field label { font-size:.6rem; color:var(--muted); text-transform:uppercase;
      letter-spacing:.5px; font-weight:600; }
    .admin-form-inline .admin-field input,
    .admin-form-inline .admin-field select {
      padding:8px 10px; border:1px solid var(--border); border-radius:7px; font-family:var(--body);
      font-size:.74rem; background:var(--paper); color:var(--ink); transition:border-color .15s, box-shadow .15s; }
    .admin-form-inline .admin-field input:focus,
    .admin-form-inline .admin-field select:focus {
      outline:none; border-color:var(--accent); box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent); }

    /* Buttons */
    .admin-btn { padding:8px 16px; border:none; border-radius:7px; font-size:.72rem; font-weight:600;
      cursor:pointer; font-family:var(--body); transition:transform .1s, filter .15s, box-shadow .15s; }
    .admin-btn:active { transform:scale(.97); }
    .admin-btn-primary { background:var(--ink); color:var(--paper); }
    .admin-btn-primary:hover { box-shadow:0 2px 8px color-mix(in srgb, var(--ink) 20%, transparent); }
    .admin-btn-accent { background:var(--accent); color:#fff; }
    .admin-btn-accent:hover { filter:brightness(1.08); }
    .admin-btn-danger { background:#dc3545; color:#fff; }
    .admin-btn-danger:hover { filter:brightness(1.08); }
    .admin-btn-ghost { background:transparent; color:var(--muted); border:1px solid var(--border); }
    .admin-btn-ghost:hover { background:color-mix(in srgb, var(--border) 30%, transparent); color:var(--ink); }
    .admin-btn-sm { padding:5px 10px; font-size:.64rem; border-radius:5px; }

    /* Search bar */
    .admin-search { display:flex; gap:8px; margin-bottom:18px; }
    .admin-search input { flex:1; padding:9px 14px; border:1px solid var(--border); border-radius:8px;
      font-family:var(--body); font-size:.78rem; background:var(--paper); color:var(--ink);
      transition:border-color .15s, box-shadow .15s; }
    .admin-search input:focus { outline:none; border-color:var(--accent);
      box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent); }
    .admin-search input::placeholder { color:var(--muted); }

    /* Filter bar */
    .admin-filter { margin-bottom:16px; }
    .admin-filter select { padding:7px 12px; border:1px solid var(--border); border-radius:7px;
      font-size:.74rem; font-family:var(--body); background:var(--paper); color:var(--ink);
      transition:border-color .15s; cursor:pointer; }
    .admin-filter select:focus { outline:none; border-color:var(--accent); }

    /* Analytics cards */
    .admin-analytics-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(300px, 1fr)); gap:16px; }
    .admin-analytics-card { background:var(--paper); border:1px solid var(--border); border-radius:10px; padding:18px 20px; }
    .admin-analytics-card h3 { font-size:.72rem; font-weight:600; color:var(--muted); text-transform:uppercase;
      letter-spacing:.5px; margin:0 0 12px; }
    .admin-analytics-metric { display:flex; gap:28px; }
    .admin-analytics-metric-item { display:flex; flex-direction:column; }
    .admin-analytics-metric-num { font-size:1.6rem; font-weight:700; color:var(--ink); font-variant-numeric:tabular-nums;
      letter-spacing:-.02em; }
    .admin-analytics-metric-label { font-size:.6rem; color:var(--muted); text-transform:uppercase; letter-spacing:.5px;
      font-weight:500; margin-top:2px; }
    .admin-mini-table { width:100%; border-collapse:collapse; font-size:.72rem; margin-top:8px; }
    .admin-mini-table th { text-align:left; padding:5px 8px; font-weight:600; color:var(--muted); font-size:.58rem;
      text-transform:uppercase; letter-spacing:.4px; border-bottom:1px solid var(--border); }
    .admin-mini-table td { padding:6px 8px; border-bottom:1px solid color-mix(in srgb, var(--border) 50%, transparent); }
    .admin-mini-table td:last-child { text-align:right; font-weight:600; font-variant-numeric:tabular-nums; }
    .admin-mini-table tbody tr:hover td { background:color-mix(in srgb, var(--accent) 4%, transparent); }

    /* Event log */
    .admin-event-log { max-height:260px; overflow-y:auto; font-family:var(--mono); font-size:.64rem;
      background:var(--paper); border:1px solid var(--border); border-radius:8px; padding:8px 10px; }
    .admin-event-row { padding:4px 0; border-bottom:1px solid color-mix(in srgb, var(--border) 40%, transparent);
      display:flex; gap:8px; line-height:1.5; }
    .admin-event-time { color:var(--muted); white-space:nowrap; font-variant-numeric:tabular-nums; }
    .admin-event-name { font-weight:600; color:var(--ink); }
    .admin-event-meta { color:var(--muted); word-break:break-all; }

    /* Empty state */
    .admin-empty { text-align:center; padding:48px 20px; }
    .admin-empty-icon { font-size:2rem; margin-bottom:8px; opacity:.35; }
    .admin-empty-text { font-size:.8rem; font-weight:500; color:var(--ink); }
    .admin-empty-sub { font-size:.68rem; color:var(--muted); margin-top:4px; }

    /* Leads (reuse shared patterns) */
    .admin-leads-header { display:flex; align-items:baseline; gap:12px; margin-bottom:20px; }
    .admin-leads-header h2 { font-size:1.05rem; font-weight:700; color:var(--ink); margin:0; letter-spacing:-.02em; }
    .admin-leads-count { font-size:.7rem; font-weight:500; color:var(--muted); background:color-mix(in srgb, var(--border) 40%, transparent);
      padding:2px 8px; border-radius:10px; font-variant-numeric:tabular-nums; }
    .admin-leads-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(340px, 1fr)); gap:16px; }
    .admin-lead-card { background:var(--paper); border:1px solid var(--border); border-radius:10px; padding:20px 22px;
      transition:border-color .2s, box-shadow .2s; position:relative; }
    .admin-lead-card:hover { border-color:color-mix(in srgb, var(--accent) 40%, var(--border));
      box-shadow:0 2px 12px color-mix(in srgb, var(--accent) 8%, transparent); }
    .admin-lead-top { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; margin-bottom:14px; }
    .admin-lead-identity h3 { font-size:.85rem; font-weight:600; color:var(--ink); margin:0 0 2px; letter-spacing:-.01em; }
    .admin-lead-identity .admin-lead-org { font-size:.72rem; color:var(--muted); font-weight:500; }
    .admin-lead-time { font-size:.62rem; color:var(--muted); white-space:nowrap; font-variant-numeric:tabular-nums; padding-top:2px; }
    .admin-lead-meta { display:flex; gap:16px; margin-bottom:14px; flex-wrap:wrap; }
    .admin-lead-meta-item { display:flex; flex-direction:column; gap:1px; }
    .admin-lead-meta-label { font-size:.58rem; color:var(--muted); text-transform:uppercase; letter-spacing:.6px; font-weight:600; }
    .admin-lead-meta-value { font-size:.75rem; color:var(--ink); font-weight:500; }
    .admin-lead-meta-value a { color:var(--accent); text-decoration:none; }
    .admin-lead-meta-value a:hover { text-decoration:underline; }
    .admin-lead-usecase { font-size:.72rem; color:var(--ink); line-height:1.5; background:color-mix(in srgb, var(--border) 25%, transparent);
      border-radius:6px; padding:10px 12px; margin:0; white-space:pre-wrap; word-break:break-word; }
    .admin-lead-empty { text-align:center; padding:48px 20px; color:var(--muted); }
    .admin-lead-empty-icon { font-size:2rem; margin-bottom:8px; opacity:.4; }
    .admin-lead-empty-text { font-size:.8rem; font-weight:500; }
    .admin-lead-empty-sub { font-size:.68rem; color:var(--muted); margin-top:4px; }
    /* API Dashboard */
    #apiMode { display:none; padding:0; height:100%; overflow-y:auto; background:var(--paper); }
    #apiDashMode { display:none; padding:20px 30px; height:100%; overflow-y:auto; }
    #apiClientMode { display:none; padding:0; height:100%; overflow-y:auto; background:var(--paper); width:65%; margin:0 auto; }
    .api-landing-shell { display:block; }
    .api-landing-shell > section { width:100%; }
    .api-hero-shell.hero {
      min-height:auto;
      background:var(--paper);
      border-bottom:1px solid rgba(13,13,13,.08);
    }
    .api-hero-shell .side-label,
    .api-hero-shell .lot-tag,
    .api-hero-shell .cat-rule,
    .api-hero-shell .cat-desc,
    .api-hero-shell .provenance,
    .api-hero-shell .bid-row,
    .api-hero-shell .board-context,
    .api-hero-shell .board-cite {
      opacity:1;
      transform:none;
      width:auto;
    }
    .api-hero-shell .copy-col {
      padding:108px 56px 88px 48px;
    }
    .api-hero-shell .board-col {
      padding:108px 56px 88px 48px;
      display:flex;
      align-items:center;
      justify-content:center;
    }
    .api-hero-title {
      max-width:9.6ch;
      margin-bottom:28px;
      text-wrap:balance;
    }
    .api-hero-title em {
      font-style:italic;
      color:var(--accent);
    }
    .api-hero-shell .cat-desc {
      max-width:39ch;
      margin-bottom:34px;
    }
    .api-hero-shell .provenance {
      max-width:440px;
      margin-bottom:30px;
    }
    .api-btn-bid {
      background:none;
      padding:0;
      cursor:pointer;
      appearance:none;
    }
    .api-btn-bid:focus-visible,
    .api-lp-link:focus-visible,
    .api-field input:focus-visible,
    .api-field textarea:focus-visible {
      outline:2px solid rgba(192,57,43,.45);
      outline-offset:3px;
    }
    .api-hero-actions {
      display:grid;
      gap:10px;
    }
    .api-hero-links {
      display:flex;
      gap:16px;
      flex-wrap:wrap;
      align-items:center;
    }
    .api-lp-link {
      border:none;
      background:none;
      padding:0;
      cursor:pointer;
      font-family:var(--fm);
      font-size:10px;
      letter-spacing:.12em;
      text-transform:uppercase;
      color:rgba(13,13,13,.34);
      text-decoration:none;
      transition:color .25s ease, transform .25s var(--ease);
    }
    .api-lp-link:hover { color:var(--accent); transform:translateX(2px); }
    .api-hero-links .api-lp-link:last-child { color:var(--ink); }
    .api-hero-links .api-lp-link:last-child:hover { color:var(--accent); }
    .api-board-stack {
      width:min(100%, 520px);
      display:grid;
      gap:18px;
    }
    .api-board-surface {
      background:rgba(235,228,212,.75);
      border:1px solid rgba(13,13,13,.08);
      border-radius:30px;
      padding:28px;
      box-shadow:0 24px 52px rgba(13,13,13,.08);
      position:relative;
      overflow:hidden;
    }
    .api-board-surface::before {
      content:'';
      position:absolute;
      inset:0;
      pointer-events:none;
      background:linear-gradient(135deg, rgba(255,255,255,.32), transparent 46%);
    }
    .api-board-kicker {
      display:block;
      margin-bottom:18px;
      font-family:var(--fm);
      font-size:10px;
      letter-spacing:.18em;
      text-transform:uppercase;
      color:rgba(13,13,13,.34);
    }
    .api-board-flow {
      display:grid;
      gap:0;
      margin-bottom:22px;
    }
    .api-board-step {
      display:grid;
      grid-template-columns:52px 1fr;
      gap:14px;
      padding:12px 0;
      border-top:1px solid rgba(13,13,13,.08);
    }
    .api-board-step:first-child { border-top:none; padding-top:0; }
    .api-board-step-index {
      font-family:var(--fd);
      font-size:1.55rem;
      line-height:1;
      color:var(--accent);
    }
    .api-board-step strong {
      display:block;
      margin-bottom:4px;
      font-family:var(--fs);
      font-size:15px;
      font-weight:600;
      color:var(--ink);
    }
    .api-board-step span {
      display:block;
      font-family:var(--fm);
      font-size:11px;
      line-height:1.8;
      color:var(--muted);
    }
    .api-board-code {
      margin:0;
      padding:20px 22px;
      background:#171717;
      border-radius:24px;
      color:var(--paper);
      font-family:var(--fm);
      font-size:11px;
      line-height:1.85;
      white-space:pre-wrap;
      overflow-x:auto;
      box-shadow:0 18px 36px rgba(13,13,13,.16);
    }
    .api-board-note {
      margin:0;
      font-family:var(--fm);
      font-size:10px;
      letter-spacing:.06em;
      color:rgba(13,13,13,.34);
      line-height:1.8;
    }
    .api-board-col .board-context,
    .api-board-col .board-cite {
      max-width:460px;
    }
    .api-board-col .board-context {
      font-size:12px;
      line-height:1.85;
      color:rgba(13,13,13,.4);
    }
    .api-board-col .board-cite {
      color:rgba(13,13,13,.34);
      margin-top:2px;
    }
    .api-bridge-shell.bridge {
      padding:118px 0 112px;
      border-bottom:1px solid rgba(13,13,13,.08);
      background:
        radial-gradient(circle at top right, rgba(192,57,43,.06), transparent 28%),
        linear-gradient(180deg, rgba(235,228,212,.24), rgba(245,240,232,0));
    }
    .api-flow-shell {
      max-width:1160px;
      margin:0 auto;
      padding:0 40px;
      display:grid;
      grid-template-columns:minmax(0, .84fr) minmax(0, 1.16fr);
      gap:44px;
      align-items:start;
    }
    .api-flow-intro {
      display:grid;
      gap:24px;
      align-self:start;
    }
    .api-flow-intro .eyebrow { margin-bottom:0; }
    .api-flow-title {
      margin:0;
      max-width:10.8ch;
      font-family:var(--fd);
      font-size:clamp(2.5rem, 4.4vw, 4.4rem);
      font-weight:400;
      line-height:1.02;
      letter-spacing:-.045em;
      color:var(--ink);
      text-wrap:balance;
    }
    .api-flow-copy {
      margin:0;
      max-width:38ch;
      font-family:var(--fm);
      font-size:13px;
      line-height:1.85;
      color:var(--muted);
      letter-spacing:.02em;
    }
    .api-flow-board {
      position:relative;
      padding:26px 28px 24px;
      border:1px solid rgba(13,13,13,.08);
      border-radius:34px;
      background:rgba(250,247,241,.82);
      box-shadow:0 24px 52px rgba(13,13,13,.06);
      overflow:hidden;
    }
    .api-flow-board::before {
      content:'';
      position:absolute;
      inset:0;
      pointer-events:none;
      background:linear-gradient(135deg, rgba(255,255,255,.44), transparent 52%);
    }
    .api-flow-board-kicker {
      display:block;
      margin-bottom:16px;
      font-family:var(--fm);
      font-size:10px;
      letter-spacing:.18em;
      text-transform:uppercase;
      color:rgba(13,13,13,.34);
    }
    .api-flow-steps {
      display:grid;
      gap:0;
      border-top:1px solid rgba(13,13,13,.08);
    }
    .api-flow-step {
      display:grid;
      grid-template-columns:56px minmax(0, 1fr);
      gap:16px;
      padding:18px 0;
      border-bottom:1px solid rgba(13,13,13,.08);
    }
    .api-flow-step-num {
      font-family:var(--fd);
      font-size:1.6rem;
      line-height:1;
      color:var(--accent);
    }
    .api-flow-step h3 {
      margin:0 0 6px;
      font-family:var(--fs);
      font-size:18px;
      font-weight:600;
      color:var(--ink);
    }
    .api-flow-step p,
    .api-flow-step span {
      display:block;
      margin:0;
      font-family:var(--fm);
      font-size:12px;
      line-height:1.8;
      color:var(--muted);
    }
    .api-flow-step span {
      margin-top:8px;
      color:var(--ink);
    }
    .api-flow-summary {
      display:flex;
      justify-content:space-between;
      align-items:center;
      gap:16px;
      padding-top:18px;
    }
    .api-flow-summary strong,
    .api-flow-summary span {
      font-family:var(--fm);
      font-size:10px;
      letter-spacing:.14em;
      text-transform:uppercase;
      color:rgba(13,13,13,.34);
    }
    .api-ops-shell {
      padding:124px 0;
      border-bottom:1px solid rgba(13,13,13,.08);
    }
    .api-ops-inner {
      max-width:1120px;
      margin:0 auto;
      padding:0 40px;
      display:grid;
      grid-template-columns:minmax(0, .92fr) minmax(0, 1.08fr);
      gap:52px;
      align-items:start;
    }
    .api-ops-head {
      margin-bottom:0;
      opacity:1;
      transform:none;
    }
    .api-ops-copy {
      margin:26px 0 0;
      max-width:40ch;
      font-family:var(--fm);
      font-size:13px;
      line-height:1.85;
      color:var(--muted);
      letter-spacing:.02em;
    }
    .api-ops-list {
      border-top:1px solid rgba(13,13,13,.08);
    }
    .api-ops-entry {
      display:grid;
      grid-template-columns:66px 1fr;
      gap:18px;
      padding:22px 0;
      border-bottom:1px solid rgba(13,13,13,.08);
    }
    .api-ops-entry-num {
      font-family:var(--fd);
      font-size:1.75rem;
      line-height:1;
      color:var(--accent);
    }
    .api-ops-entry h3 {
      margin:0 0 8px;
      font-family:var(--fs);
      font-size:18px;
      font-weight:600;
      color:var(--ink);
    }
    .api-ops-entry p,
    .api-ops-entry span {
      display:block;
      margin:0;
      font-family:var(--fm);
      font-size:12px;
      line-height:1.8;
      color:var(--muted);
    }
    .api-ops-entry span {
      margin-top:8px;
      color:var(--ink);
    }
    .api-proof-shell.trust {
      min-height:auto;
      padding:120px 0 112px;
      position:relative;
      background:
        linear-gradient(180deg, rgba(37,32,28,.82) 0%, rgba(13,13,13,1) 20%),
        var(--ink);
      border-top:1px solid rgba(245,240,232,.08);
    }
    .api-proof-shell.trust::before,
    .api-contact-shell.cta-section::before {
      content:'';
      position:absolute;
      inset:0 0 auto 0;
      height:120px;
      pointer-events:none;
      background:linear-gradient(180deg, rgba(245,240,232,.1), rgba(245,240,232,0));
    }
    .api-proof-shell .trust-inner {
      max-width:1160px;
      display:grid;
      grid-template-columns:minmax(0, 1.05fr) minmax(0, .95fr);
      gap:36px 48px;
      align-items:start;
    }
    .api-proof-lead {
      display:grid;
      gap:22px;
    }
    .api-proof-shell .trust-eyebrow {
      margin-bottom:0;
    }
    .api-proof-shell .trust-body-text {
      margin:0;
      max-width:12.4ch;
      font-size:clamp(2.4rem, 4vw, 4.15rem);
      line-height:1.04;
      letter-spacing:-.045em;
      color:var(--paper);
      text-wrap:balance;
    }
    .api-proof-aside {
      display:grid;
      gap:18px;
      align-self:end;
    }
    .api-proof-copy {
      margin:0;
      max-width:35ch;
      font-family:var(--fm);
      font-size:12px;
      line-height:1.85;
      color:rgba(245,240,232,.6);
      letter-spacing:.02em;
    }
    .api-proof-list {
      grid-column:1 / -1;
      display:grid;
      grid-template-columns:repeat(2, minmax(0, 1fr));
      gap:0 30px;
      border-top:1px solid rgba(245,240,232,.08);
    }
    .api-proof-list .trust-fn-entry {
      margin:0;
      padding:22px 0 20px;
      border-radius:0;
      border-bottom:1px solid rgba(245,240,232,.08);
      opacity:1;
      transform:none;
    }
    .api-proof-list .trust-fn-entry:nth-last-child(-n + 2) {
      border-bottom:none;
    }
    .api-proof-list .trust-fn-title {
      font-size:16px;
    }
    .api-proof-list .trust-fn-detail {
      max-width:34ch;
    }
    .api-proof-list .trust-meta {
      grid-column:2;
      margin-top:0;
      align-self:end;
      justify-self:start;
    }
    .api-tech-shell {
      padding:124px 0;
      border-bottom:1px solid rgba(13,13,13,.08);
      background:linear-gradient(180deg, rgba(235,228,212,.34), rgba(245,240,232,0));
    }
    .api-tech-inner {
      max-width:1120px;
      margin:0 auto;
      padding:0 40px;
      display:grid;
      gap:44px;
      align-items:start;
    }
    .api-tech-head {
      max-width:980px;
      display:grid;
      grid-template-columns:minmax(0, .92fr) minmax(0, 1.08fr);
      gap:48px;
      align-items:end;
    }
    .api-tech-copy .eyebrow { margin-bottom:26px; }
    .api-tech-copy h2 {
      margin:0;
      font-family:var(--fd);
      font-size:clamp(2rem, 3.8vw, 3.1rem);
      font-weight:400;
      line-height:1.02;
      letter-spacing:-.04em;
      color:var(--ink);
      text-wrap:balance;
    }
    .api-tech-copy p {
      margin:0;
      max-width:44ch;
      font-family:var(--fm);
      font-size:13px;
      line-height:1.85;
      color:var(--muted);
      letter-spacing:.02em;
    }
    .api-tech-layout {
      display:grid;
      grid-template-columns:minmax(0, .95fr) minmax(0, 1.05fr);
      gap:40px;
      align-items:start;
    }
    .api-tech-points {
      margin:0;
      padding:0;
      list-style:none;
      border-top:1px solid rgba(13,13,13,.08);
    }
    .api-tech-points li {
      padding:15px 0;
      border-bottom:1px solid rgba(13,13,13,.08);
      font-family:var(--fm);
      font-size:12px;
      line-height:1.8;
      color:var(--muted);
    }
    .api-tech-points strong {
      color:var(--ink);
      font-weight:500;
    }
    .api-tech-actions {
      display:flex;
      gap:16px;
      flex-wrap:wrap;
      align-items:center;
      margin-top:28px;
    }
    .api-tech-code {
      display:grid;
      gap:18px;
    }
    .api-tech-code-block {
      background:#171717;
      color:var(--paper);
      border-radius:30px;
      padding:24px;
      box-shadow:0 20px 42px rgba(13,13,13,.16);
    }
    .api-tech-code-label {
      display:block;
      margin-bottom:12px;
      font-family:var(--fm);
      font-size:10px;
      letter-spacing:.18em;
      text-transform:uppercase;
      color:rgba(245,240,232,.42);
    }
    .api-tech-code-block pre {
      margin:0;
      font-family:var(--fm);
      font-size:12px;
      line-height:1.85;
      color:var(--paper);
      white-space:pre-wrap;
      overflow-x:auto;
    }
    .api-contact-shell.cta-section {
      min-height:auto;
      padding:126px 0 118px;
      position:relative;
      background:
        linear-gradient(180deg, rgba(37,32,28,.82) 0%, rgba(13,13,13,1) 20%),
        var(--ink);
      border-top:1px solid rgba(245,240,232,.08);
    }
    .api-form-shell {
      margin-top:28px;
      padding:28px;
      background:var(--paper);
      color:var(--ink);
      border-radius:32px;
      border:1px solid rgba(245,240,232,.12);
      box-shadow:0 24px 54px rgba(0,0,0,.16);
    }
    .api-form-grid {
      display:grid;
      grid-template-columns:repeat(2, minmax(0, 1fr));
      gap:14px;
    }
    .api-field { display:grid; gap:8px; }
    .api-field label {
      font-family:var(--fm);
      font-size:10px;
      letter-spacing:.14em;
      text-transform:uppercase;
      color:var(--muted);
    }
    .api-field input,
    .api-field textarea {
      width:100%;
      box-sizing:border-box;
      border:1px solid rgba(13,13,13,.12);
      border-radius:18px;
      padding:15px 16px;
      font:inherit;
      background:rgba(255,255,255,.82);
      color:var(--ink);
      transition:border-color .24s cubic-bezier(.32,.72,0,1), box-shadow .24s cubic-bezier(.32,.72,0,1), background .24s cubic-bezier(.32,.72,0,1);
    }
    .api-field input:hover,
    .api-field textarea:hover { border-color:rgba(13,13,13,.24); }
    .api-field textarea { min-height:154px; resize:vertical; }
    .api-field input::placeholder,
    .api-field textarea::placeholder { color:rgba(122,114,96,.38); }
    .api-field-help {
      margin-top:-2px;
      color:var(--muted);
      font-size:11px;
      line-height:1.7;
      font-family:var(--fm);
    }
    .api-honeypot { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; pointer-events:none; }
    .api-contact-actions {
      display:flex;
      gap:16px;
      flex-wrap:wrap;
      align-items:center;
      margin-top:18px;
    }
    .api-lp-btn {
      display:inline-flex;
      align-items:center;
      justify-content:center;
      min-height:48px;
      padding:0 22px;
      border-radius:999px;
      border:1.5px solid var(--ink);
      background:none;
      color:var(--ink);
      cursor:pointer;
      font-family:var(--fm);
      font-size:11px;
      font-weight:500;
      letter-spacing:.12em;
      text-transform:uppercase;
      transition:transform .28s var(--ease), background .28s var(--ease), border-color .28s var(--ease), color .28s var(--ease), box-shadow .28s var(--ease);
    }
    .api-lp-btn:hover { transform:translateY(-1px); }
    .api-lp-btn:active { transform:translateY(1px) scale(.985); }
    .api-lp-btn--primary {
      background:var(--ink);
      color:var(--paper);
      border-color:var(--ink);
      box-shadow:0 12px 28px rgba(13,13,13,.12);
    }
    .api-lp-btn:disabled {
      opacity:.62;
      cursor:wait;
      transform:none;
      box-shadow:none;
    }
    .api-contact-status {
      min-height:22px;
      margin-top:14px;
      font-family:var(--fm);
      font-size:11px;
      line-height:1.7;
      color:rgba(245,240,232,.52);
      transition:color .2s ease;
    }
    .api-contact-status--pending { color:#d7c7a4; }
    .api-contact-status--success { color:#6dc28f; }
    .api-contact-status--error { color:#ff8d80; }
    .api-contact-note {
      margin-top:22px;
      padding-top:20px;
      border-top:1px solid rgba(13,13,13,.08);
      font-family:var(--fm);
      font-size:12px;
      line-height:1.85;
      color:var(--muted);
    }
    .api-contact-note strong { color:rgba(245,240,232,.88); }
    .api-contact-note { color:rgba(245,240,232,.48); border-top-color:rgba(245,240,232,.08); }
    .apid-shell {
      max-width:1160px; margin:0 auto; padding:32px 20px 56px;
      font-family:var(--body); font-size:.75rem;
    }
    .apid-header {
      display:flex; flex-direction:column; align-items:flex-start; gap:12px;
      text-align:left; margin-bottom:24px;
    }
    .apid-eyebrow {
      font-family:var(--mono); font-size:.58rem; font-weight:700; letter-spacing:.14em;
      text-transform:uppercase; color:var(--muted);
    }
    .apid-header h1 {
      font-family:var(--display); font-size:2.7rem; font-weight:700;
      color:var(--ink); letter-spacing:-.02em; margin:0;
      line-height:.98;
      text-wrap:balance;
    }
    .apid-header p {
      margin:0; color:var(--muted); font-size:.9rem; line-height:1.6; max-width:560px;
    }
    .apid-actions { display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-start; }
    .apid-card {
      background:var(--paper); border:1px solid var(--border); border-radius:10px; padding:18px;
      box-shadow:0 8px 24px rgba(13,13,13,.04);
    }
    .apid-card h2 {
      margin:0 0 10px; font-family:var(--display); font-size:1.02rem; color:var(--ink);
      letter-spacing:-.01em;
    }
    .apid-card-head {
      display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:12px;
    }
    .apid-card-head p {
      margin:4px 0 0; color:var(--muted); font-size:.74rem; line-height:1.5;
      max-width:34ch;
    }
    .apid-section-label {
      display:block; margin-bottom:8px; font-family:var(--mono); font-size:.56rem; font-weight:700;
      letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
    }
    .apid-status-runner {
      display:grid;
      grid-template-columns:repeat(4, minmax(0, 1fr));
      gap:10px;
      margin-bottom:16px;
    }
    .apid-status-chip {
      border:1px solid var(--border);
      border-radius:16px;
      background:rgba(255,255,255,.72);
      padding:12px 14px;
      box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
    }
    .apid-status-chip-value {
      display:block;
      font-family:var(--display);
      font-size:1.7rem;
      line-height:.95;
      letter-spacing:-.06em;
      color:var(--ink);
    }
    .apid-status-chip-label {
      display:block;
      margin-top:6px;
      font-family:var(--mono);
      font-size:.56rem;
      text-transform:uppercase;
      letter-spacing:.14em;
      color:var(--muted);
    }
    .apid-studio-main {
      display:grid;
      grid-template-columns:minmax(0, 1.25fr) 290px;
      gap:16px;
      align-items:start;
      margin-bottom:18px;
    }
    .apid-hero-surface {
      position:relative;
      overflow:hidden;
      border-radius:28px;
      border:1px solid rgba(255,255,255,.08);
      background:
        radial-gradient(circle at top left, rgba(255,255,255,.16), transparent 32%),
        linear-gradient(135deg, var(--ink) 0%, #26211c 56%, #382821 100%);
      padding:22px;
      color:var(--paper);
      box-shadow:0 28px 64px rgba(13,13,13,.22);
    }
    .apid-hero-surface::after {
      content:'';
      position:absolute;
      inset:1px;
      border-radius:27px;
      border:1px solid rgba(255,255,255,.06);
      pointer-events:none;
    }
    .apid-hero-top {
      display:flex;
      justify-content:space-between;
      gap:12px;
      align-items:flex-start;
      position:relative;
      z-index:1;
    }
    .apid-hero-top h2 {
      margin:8px 0 4px;
      font-family:var(--display);
      font-size:2.2rem;
      line-height:.94;
      letter-spacing:-.06em;
      color:#fff;
    }
    .apid-hero-copy {
      margin:0;
      color:rgba(245,240,232,.7);
      font-size:.8rem;
      line-height:1.55;
    }
    .apid-live-pill {
      display:inline-flex;
      align-items:center;
      justify-content:center;
      border-radius:999px;
      padding:7px 11px;
      background:rgba(29,138,80,.14);
      border:1px solid rgba(173,225,191,.16);
      color:#d5f0dd;
      font-family:var(--mono);
      font-size:.56rem;
      font-weight:700;
      text-transform:uppercase;
      letter-spacing:.12em;
    }
    .apid-live-pill--inactive {
      background:rgba(192,57,43,.16);
      border-color:rgba(255,255,255,.08);
      color:#f7d7d2;
    }
    .apid-hero-key {
      position:relative;
      z-index:1;
      margin-top:32px;
      font-family:var(--mono);
      font-size:1rem;
      line-height:1.4;
      letter-spacing:-.03em;
      color:#f4ede1;
      word-break:break-all;
    }
    .apid-hero-note {
      position:relative;
      z-index:1;
      margin-top:8px;
      color:rgba(245,240,232,.62);
      font-size:.72rem;
      line-height:1.55;
      max-width:44ch;
    }
    .apid-hero-actions {
      position:relative;
      z-index:1;
      display:flex;
      gap:10px;
      flex-wrap:wrap;
      margin-top:18px;
    }
    .apid-hero-btn {
      border-radius:999px;
      padding:10px 14px;
      border:1px solid rgba(255,255,255,.14);
      background:rgba(255,255,255,.08);
      color:#fff;
      font-family:var(--mono);
      font-size:.58rem;
      font-weight:700;
      text-transform:uppercase;
      letter-spacing:.1em;
      cursor:pointer;
    }
    .apid-hero-btn:hover { background:rgba(255,255,255,.13); }
    .apid-hero-btn--alert {
      background:rgba(192,57,43,.18);
      border-color:rgba(255,255,255,.08);
    }
    .apid-hero-btn--alert:hover { background:rgba(192,57,43,.25); }
    .apid-hero-grid {
      position:relative;
      z-index:1;
      display:grid;
      grid-template-columns:repeat(3, minmax(0, 1fr));
      gap:10px;
      margin-top:20px;
    }
    .apid-hero-cell {
      border-top:1px solid rgba(255,255,255,.12);
      padding-top:12px;
    }
    .apid-hero-cell strong {
      display:block;
      font-family:var(--display);
      font-size:1.3rem;
      line-height:.95;
      letter-spacing:-.05em;
      color:#fff;
    }
    .apid-hero-cell span {
      display:block;
      margin-top:5px;
      color:rgba(245,240,232,.6);
      font-family:var(--mono);
      font-size:.56rem;
      text-transform:uppercase;
      letter-spacing:.12em;
    }
    .apid-utility-rail {
      display:grid;
      gap:12px;
    }
    .apid-utility-panel {
      border-radius:22px;
      border:1px solid var(--border);
      background:rgba(255,255,255,.76);
      padding:16px;
      box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
    }
    .apid-utility-panel h2 {
      margin:0 0 8px;
      font-family:var(--display);
      font-size:1.45rem;
      line-height:.96;
      letter-spacing:-.05em;
    }
    .apid-utility-panel pre,
    .apid-utility-panel p {
      margin:0;
      color:#5d5447;
      font-size:.74rem;
      line-height:1.65;
    }
    .apid-utility-panel pre {
      white-space:pre-wrap;
      font-family:var(--mono);
    }
    .apid-utility-panel .apid-btn {
      margin-top:12px;
    }
    .apid-banner { margin-bottom:16px; border:1px solid #4caf50; background:#e8f5e9; color:#155724; border-radius:8px; padding:12px 14px; font-size:.8rem; }
    .apid-archive-band { margin-bottom:18px; }
    .apid-archive-label {
      margin-bottom:10px;
      font-family:var(--mono);
      font-size:.56rem;
      text-transform:uppercase;
      letter-spacing:.14em;
      color:var(--muted);
    }
    .apid-archive-row {
      display:grid;
      grid-template-columns:repeat(3, minmax(0, 1fr));
      gap:12px;
    }
    .apid-archive-card {
      border:1px solid var(--border);
      border-radius:22px;
      background:rgba(255,255,255,.72);
      padding:16px;
      display:grid;
      gap:10px;
      box-shadow:inset 0 1px 0 rgba(255,255,255,.78);
    }
    .apid-archive-card h2 {
      margin:0;
      font-family:var(--display);
      font-size:1.35rem;
      line-height:.95;
      letter-spacing:-.05em;
    }
    .apid-archive-card p {
      margin:0;
      color:#6b6357;
      font-size:.74rem;
      line-height:1.6;
    }
    .apid-archive-meta {
      display:flex;
      justify-content:space-between;
      gap:10px;
      align-items:center;
    }
    .apid-badge {
      display:inline-flex;
      align-items:center;
      justify-content:center;
      padding:6px 10px;
      border-radius:999px;
      font-family:var(--mono);
      font-size:.56rem;
      font-weight:700;
      letter-spacing:.08em;
      text-transform:uppercase;
    }
    .apid-badge--active { background:#dff3e4; color:#1d6d38; }
    .apid-badge--revoked { background:#fce8ea; color:#b42318; }
    .apid-badge--draft { background:rgba(255,255,255,.64); color:var(--muted); border:1px solid var(--border); }
    .apid-archive-date {
      font-family:var(--mono);
      font-size:.58rem;
      color:var(--muted);
      text-transform:uppercase;
      letter-spacing:.1em;
    }
    @keyframes apid-shimmer {
      0% { background-position: -400px 0; }
      100% { background-position: 400px 0; }
    }
    .apid-skeleton {
      display:flex;
      flex-direction:column;
      gap:16px;
      padding:8px 0;
    }
    .apid-skeleton-row {
      display:grid;
      grid-template-columns:repeat(4, 1fr);
      gap:12px;
    }
    .apid-skeleton-chip {
      height:72px;
      border-radius:8px;
      background:linear-gradient(90deg, rgba(204,197,176,.12) 25%, rgba(204,197,176,.24) 50%, rgba(204,197,176,.12) 75%);
      background-size:800px 100%;
      animation:apid-shimmer 1.6s ease-in-out infinite;
    }
    .apid-skeleton-hero {
      height:240px;
      border-radius:10px;
      background:linear-gradient(90deg, rgba(62,56,47,.08) 25%, rgba(62,56,47,.14) 50%, rgba(62,56,47,.08) 75%);
      background-size:800px 100%;
      animation:apid-shimmer 1.6s ease-in-out infinite;
    }
    .apid-skeleton-bar {
      height:14px;
      border-radius:4px;
      background:linear-gradient(90deg, rgba(204,197,176,.12) 25%, rgba(204,197,176,.24) 50%, rgba(204,197,176,.12) 75%);
      background-size:800px 100%;
      animation:apid-shimmer 1.6s ease-in-out infinite;
    }
    .apid-skeleton-bar--short { width:40%; }
    .apid-skeleton-bar--med { width:65%; }
    .apid-packs-wrap { margin-bottom:18px; }
    .apid-packs {
      display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:0; align-items:stretch;
      margin-top:14px;
    }
    .apid-pack {
      background:var(--paper); border:1px solid var(--border); padding:20px 16px 18px;
      text-align:center; display:flex; flex-direction:column; position:relative;
      transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    }
    .apid-pack:first-child { border-radius:8px 0 0 8px; }
    .apid-pack:last-child { border-radius:0 8px 8px 0; }
    .apid-pack:hover {
      z-index:2; transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.06);
    }
    .apid-pack--featured {
      background:var(--accent); border-color:var(--accent); color:#fff; z-index:3; border-radius:10px;
      margin:-10px -2px; padding:28px 18px 22px;
      box-shadow:0 12px 40px rgba(192,57,43,.25), 0 2px 8px rgba(0,0,0,.08);
    }
    .apid-pack--featured:hover {
      transform:translateY(-5px);
      box-shadow:0 20px 56px rgba(192,57,43,.3), 0 6px 16px rgba(0,0,0,.1);
    }
    .apid-pack-badge {
      position:absolute; top:-11px; left:50%; transform:translateX(-50%);
      background:var(--ink); color:var(--paper); font-family:var(--mono); font-size:.58rem;
      font-weight:700; padding:3px 14px; border-radius:12px; letter-spacing:.06em;
      white-space:nowrap; text-transform:uppercase;
    }
    .apid-pack-name {
      font-family:var(--mono); font-weight:700; font-size:.72rem;
      color:var(--muted); text-transform:uppercase; letter-spacing:.08em; margin-bottom:8px;
    }
    .apid-pack-links {
      font-family:var(--display); font-size:1.55rem; font-weight:800; color:var(--ink); line-height:1;
      letter-spacing:-.03em;
    }
    .apid-pack-price {
      font-family:var(--display); font-size:1.4rem; font-weight:800; color:var(--ink);
      line-height:1; margin:6px 0 4px; letter-spacing:-.03em;
    }
    .apid-pack-checkout { margin-top:14px; min-height:42px; }
    .apid-pack-checkout-note { color:var(--muted); font-size:.72rem; font-family:var(--mono); padding:8px 0; }
    .apid-pack-unit { font-size:.68rem; color:var(--muted); line-height:1.5; }
    .apid-pack-copy { margin:10px 0 12px; font-size:.7rem; color:var(--muted); line-height:1.5; min-height:2.8em; }
    .apid-pack--featured .apid-pack-name,
    .apid-pack--featured .apid-pack-links,
    .apid-pack--featured .apid-pack-price,
    .apid-pack--featured .apid-pack-copy,
    .apid-pack--featured .apid-pack-unit {
      color:#fff;
    }
    .apid-pack--featured .apid-pack-unit,
    .apid-pack--featured .apid-pack-copy { color:rgba(255,255,255,.78); }
    .apid-btn { padding:8px 14px; border-radius:7px; border:1px solid transparent; cursor:pointer; font-size:.74rem; font-weight:700; }
    .apid-btn--primary { background:var(--accent); color:#fff; }
    .apid-btn--primary:hover { filter:brightness(1.05); }
    .apid-btn--secondary { background:transparent; color:var(--ink); border-color:var(--border); }
    .apid-btn--danger { background:transparent; color:#b42318; border-color:#ef9a9a; }
    .apid-btn--light { background:#fff; color:var(--accent); }
    .apid-btn--light:hover { filter:brightness(.98); }
    .apid-key-reveal { background:rgba(204,197,176,.14); border:1px solid rgba(204,197,176,.6); border-radius:8px; padding:14px; margin-bottom:16px; }
    .apid-key-reveal-title { display:block; margin-bottom:6px; color:var(--ink); }
    .apid-key-reveal code { display:block; margin-top:8px; font-family:var(--mono); font-size:.72rem; color:var(--ink); word-break:break-all; }
    .apid-empty { text-align:center; padding:40px 20px; }
    .apid-empty h2 { margin:0 0 8px; font-size:1.2rem; color:var(--ink); }
    .apid-empty p { margin:0 0 16px; color:var(--muted); font-size:.8rem; }
    .apid-docs-block { margin-top:18px; }
    .apid-docs-endpoint {
      display:flex; align-items:center; gap:10px; margin:16px 0 18px;
      padding:14px 18px; background:#2c2824; border-radius:10px;
      font-family:var(--mono); font-size:.78rem; color:#e8e0d4;
      overflow-x:auto;
    }
    .apid-docs-method {
      display:inline-block; padding:3px 8px; border-radius:5px;
      background:var(--accent); color:#fff; font-weight:700; font-size:.68rem;
      letter-spacing:.04em; flex-shrink:0;
    }
    .apid-docs-url { opacity:.85; }
    .apid-docs-grid { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:14px; margin-top:0; }
    .apid-docs-panel {
      border-radius:10px; overflow:hidden;
    }
    .apid-docs-panel-head {
      display:flex; align-items:center; justify-content:space-between;
      padding:10px 16px; background:#38332e;
      font-family:var(--mono); font-size:.62rem; font-weight:700;
      color:rgba(232,224,212,.6); letter-spacing:.1em; text-transform:uppercase;
    }
    .apid-docs-panel-body {
      padding:14px 16px; background:#2c2824;
      font-family:var(--mono); font-size:.7rem; color:#e8e0d4;
      white-space:pre-wrap; line-height:1.7; overflow-x:auto;
    }
    .apid-docs-panel-body .apid-docs-key { color:#c9a96e; }
    .apid-docs-panel-body .apid-docs-str { color:#a3be8c; }
    .apid-docs-panel-body .apid-docs-num { color:#d4976c; }
    .apid-docs-meta {
      display:flex; gap:12px; margin:16px 0; flex-wrap:wrap;
    }
    .apid-docs-meta-chip {
      display:flex; align-items:center; gap:8px;
      padding:10px 16px; background:var(--paper-dark); border:1px solid var(--border);
      border-radius:8px; font-size:.74rem; color:var(--ink); flex:1; min-width:200px;
    }
    .apid-docs-meta-chip strong {
      font-family:var(--mono); font-size:.68rem; color:var(--muted);
      text-transform:uppercase; letter-spacing:.06em; flex-shrink:0;
    }
    .apid-docs-curl {
      position:relative; margin:16px 0; border-radius:10px; overflow:hidden;
    }
    .apid-docs-curl-head {
      display:flex; align-items:center; justify-content:space-between;
      padding:10px 16px; background:#38332e;
    }
    .apid-docs-curl-head span {
      font-family:var(--mono); font-size:.62rem; font-weight:700;
      color:rgba(232,224,212,.6); letter-spacing:.1em; text-transform:uppercase;
    }
    .apid-docs-curl-copy {
      padding:4px 10px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
      border-radius:5px; color:rgba(232,224,212,.7); font-size:.62rem; font-family:var(--mono);
      cursor:pointer; transition:background .15s;
    }
    .apid-docs-curl-copy:hover { background:rgba(255,255,255,.14); }
    .apid-docs-curl pre {
      margin:0; padding:16px 18px; background:#2c2824;
      font-family:var(--mono); font-size:.72rem; color:#e8e0d4;
      white-space:pre-wrap; line-height:1.8; overflow-x:auto;
    }
    .apid-docs-curl pre .apid-docs-flag { color:#81a1c1; }
    .apid-docs-curl pre .apid-docs-str { color:#a3be8c; }
    .apid-docs-errtbl {
      width:100%; border-collapse:collapse; margin-top:6px;
    }
    .apid-docs-errtbl th {
      text-align:left; padding:8px 12px; font-family:var(--mono);
      font-size:.6rem; color:var(--muted); letter-spacing:.1em;
      text-transform:uppercase; border-bottom:2px solid var(--border);
    }
    .apid-docs-errtbl td {
      padding:8px 12px; font-size:.74rem; color:var(--ink);
      border-bottom:1px solid var(--border);
    }
    .apid-docs-errtbl tr:last-child td { border-bottom:none; }
    .apid-docs-errtbl .apid-docs-status {
      display:inline-block; min-width:36px; padding:2px 8px; border-radius:4px;
      font-family:var(--mono); font-size:.68rem; font-weight:700; text-align:center;
    }
    .apid-docs-status--4xx { background:#fce8ea; color:#b42318; }
    .apid-docs-status--5xx { background:#fff3cd; color:#856404; }
    .apid-docs-settings-toggle {
      display:flex; align-items:center; gap:6px; margin:14px 0 0;
      padding:0; border:none; background:none; cursor:pointer;
      font-family:var(--mono); font-size:.66rem; font-weight:700;
      color:var(--muted); letter-spacing:.08em; text-transform:uppercase;
      transition:color .15s;
    }
    .apid-docs-settings-toggle:hover { color:var(--ink); }
    .apid-docs-settings-toggle .apid-docs-arrow {
      display:inline-block; transition:transform .2s; font-size:.7rem;
    }
    .apid-docs-settings-toggle.apid-open .apid-docs-arrow { transform:rotate(90deg); }
    .apid-docs-settings-body {
      display:none; margin:10px 0 0; border-radius:10px; overflow:hidden;
    }
    .apid-docs-settings-body.apid-open { display:block; }
    .apid-docs-settings-tbl {
      width:100%; border-collapse:collapse;
    }
    .apid-docs-settings-tbl th {
      text-align:left; padding:8px 14px; font-family:var(--mono);
      font-size:.58rem; color:rgba(232,224,212,.6); letter-spacing:.1em;
      text-transform:uppercase; background:#38332e;
    }
    .apid-docs-settings-tbl td {
      padding:7px 14px; font-size:.7rem; color:#e8e0d4;
      background:#2c2824; border-top:1px solid rgba(255,255,255,.06);
      vertical-align:top;
    }
    .apid-docs-settings-tbl td:first-child {
      font-family:var(--mono); color:#c9a96e; white-space:nowrap;
    }
    .apid-docs-settings-tbl td:nth-child(2) {
      font-family:var(--mono); color:#a3be8c; font-size:.66rem;
    }
    .apid-docs-settings-tbl td:nth-child(3) {
      color:rgba(232,224,212,.6); font-size:.66rem;
    }
    .apid-inline-note { margin-top:10px; font-size:.72rem; color:var(--muted); }
    /* ─── API Client Dashboard ─── */
    .apic-shell { min-height:100%; display:flex; flex-direction:column; background:var(--paper); }
    .apic-center {
      flex:1;
      display:flex;
      align-items:center;
      justify-content:center;
      padding:24px;
    }
    .apic-card {
      background:#fff;
      border:1px solid var(--border);
      border-radius:10px;
      padding:28px;
    }
    .apic-gate-card { width:min(100%, 420px); }
    .apic-mark {
      font-family:var(--mono);
      font-size:.68rem;
      letter-spacing:.28em;
      text-transform:uppercase;
      color:var(--muted);
      margin-bottom:10px;
    }
    .apic-card h2 {
      margin:0 0 8px;
      font-size:1.5rem;
      font-family:var(--display);
      color:var(--ink);
    }
    .apic-copy { margin:0; color:var(--muted); font-size:.9rem; line-height:1.6; }
    .apic-actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:16px; }
    /* top nav */
    .apic-topnav {
      display:flex;
      align-items:center;
      gap:10px;
      padding:0 20px;
      height:44px;
      background:var(--paper);
      border-bottom:1px solid var(--border);
      flex-shrink:0;
    }
    .apic-topnav-logo {
      font-family:var(--mono);
      font-size:.75rem;
      font-weight:700;
      letter-spacing:.16em;
      text-transform:uppercase;
      color:var(--ink);
    }
    .apic-topnav-sep { color:var(--border); font-size:.9rem; }
    .apic-topnav-org { font-family:var(--mono); font-size:.72rem; color:var(--muted); }
    .apic-topnav-right { margin-left:auto; display:flex; align-items:center; gap:8px; }
    .apic-credits-badge {
      font-family:var(--mono);
      font-size:.68rem;
      color:var(--ink);
      background:var(--paper);
      border:1px solid var(--border);
      border-radius:999px;
      padding:3px 10px;
      white-space:nowrap;
    }
    /* tab strip */
    .apic-tabnav {
      display:flex;
      padding:0 20px;
      background:var(--paper);
      border-bottom:1px solid var(--border);
      flex-shrink:0;
      overflow-x:auto;
    }
    .apic-tab {
      border:none;
      background:transparent;
      color:var(--muted);
      padding:10px 12px;
      border-bottom:2px solid transparent;
      cursor:pointer;
      font-family:var(--mono);
      font-size:.72rem;
      letter-spacing:.04em;
      white-space:nowrap;
      transition:color .15s ease, border-color .15s ease;
    }
    .apic-tab:hover { color:var(--ink); }
    .apic-tab.is-active { color:var(--ink); border-bottom-color:var(--accent); }
    /* content */
    .apic-main { flex:1; padding:20px; }
    .apic-panel { display:none; }
    .apic-panel.is-active { display:block; }
    .apic-panel-head {
      display:flex;
      justify-content:space-between;
      align-items:center;
      gap:12px;
      margin-bottom:16px;
    }
    .apic-panel-head h3 {
      margin:0;
      font-size:1.1rem;
      font-family:var(--display);
      color:var(--ink);
    }
    /* buttons */
    .apic-btn,
    .apic-btn-secondary,
    .apic-btn-danger {
      display:inline-flex;
      align-items:center;
      justify-content:center;
      border-radius:6px;
      padding:7px 14px;
      font-family:var(--mono);
      font-size:.72rem;
      font-weight:600;
      letter-spacing:.03em;
      cursor:pointer;
      border:1px solid transparent;
      transition:opacity .15s ease;
      text-decoration:none;
      white-space:nowrap;
    }
    .apic-btn { background:var(--ink); color:var(--paper); border-color:var(--ink); }
    .apic-btn-secondary { background:var(--paper); color:var(--ink); border-color:var(--border); }
    .apic-btn-danger { background:var(--paper); color:var(--accent); border-color:var(--border); }
    .apic-btn:hover, .apic-btn-secondary:hover, .apic-btn-danger:hover { opacity:.75; }
    .apic-btn:disabled, .apic-btn-secondary:disabled, .apic-btn-danger:disabled {
      opacity:.35;
      cursor:default;
    }
    /* form controls */
    .apic-select,
    .apic-input,
    .apic-textarea {
      width:100%;
      border:1px solid var(--border);
      border-radius:6px;
      background:#fff;
      color:var(--ink);
      font-family:var(--mono);
      font-size:.8rem;
      padding:8px 10px;
      outline:none;
    }
    .apic-input:focus,
    .apic-select:focus,
    .apic-textarea:focus { border-color:var(--accent2); box-shadow:0 0 0 3px rgba(44,62,107,.08); }
    .apic-textarea { min-height:100px; resize:vertical; }
    /* rows */
    .apic-stack { display:grid; gap:0; }
    .apic-row {
      display:grid;
      grid-template-columns:minmax(0,1fr) auto auto auto;
      gap:12px;
      align-items:center;
      padding:10px 0;
      border-bottom:1px solid var(--border);
    }
    .apic-row:last-child { border-bottom:none; }
    .apic-stat-row {
      display:grid;
      grid-template-columns:minmax(0,1.4fr) auto auto;
      gap:12px;
      align-items:center;
      padding:10px 0;
      border-bottom:1px solid var(--border);
    }
    .apic-stat-row:last-child { border-bottom:none; }
    .apic-name {
      min-width:0;
      font-family:var(--mono);
      font-size:.8rem;
      font-weight:600;
      color:var(--ink);
      overflow:hidden;
      text-overflow:ellipsis;
      white-space:nowrap;
    }
    .apic-meta { font-family:var(--mono); font-size:.68rem; color:var(--muted); white-space:nowrap; }
    /* badges */
    .apic-badge {
      display:inline-flex;
      align-items:center;
      justify-content:center;
      border-radius:4px;
      padding:2px 7px;
      font-family:var(--mono);
      font-size:.6rem;
      font-weight:700;
      letter-spacing:.06em;
      text-transform:uppercase;
      white-space:nowrap;
      border:1px solid var(--border);
    }
    .apic-badge-owner { background:var(--ink); color:var(--paper); border-color:var(--ink); }
    .apic-badge-manager { background:var(--accent2); color:#fff; border-color:var(--accent2); }
    .apic-badge-operator,
    .apic-badge-default { background:var(--paper); color:var(--muted); }
    .apic-badge-active { background:#2c6b3e; color:#fff; border-color:#2c6b3e; }
    .apic-badge-review {
      background:color-mix(in srgb, var(--accent2) 14%, var(--paper));
      color:var(--accent2);
      border-color:color-mix(in srgb, var(--accent2) 36%, var(--border));
    }
    .apic-badge-pending { background:var(--paper); color:var(--muted); }
    .apic-badge-failed { background:var(--accent); color:#fff; border-color:var(--accent); }
    /* form layout */
    .apic-form-grid { display:grid; gap:12px; padding-top:16px; border-top:1px solid var(--border); margin-top:16px; }
    .apic-field { display:grid; gap:5px; }
    .apic-field label { font-family:var(--mono); font-size:.7rem; font-weight:600; color:var(--ink); }
    .apic-form-actions { display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
    .apic-scan-actions { justify-content:center; margin-top:12px; }
    .apic-note { font-family:var(--mono); font-size:.7rem; color:var(--muted); min-height:16px; }
    .apic-token-box {
      display:none;
      padding:12px;
      border-radius:6px;
      border:1px solid var(--border);
      background:var(--paper);
    }
    .apic-token-box code {
      display:block;
      overflow:auto;
      padding:8px 10px;
      border-radius:4px;
      background:var(--ink);
      color:var(--paper);
      font-family:var(--mono);
      font-size:.68rem;
    }
    .apic-copy-actions { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-top:8px; }
    /* upload tab */
    .apic-preset-row { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
    .apic-preset-row label { font-family:var(--mono); font-size:.72rem; color:var(--muted); white-space:nowrap; }
    .apic-preset-row .apic-select { width:auto; min-width:180px; }
    .apic-dropzone {
      display:grid;
      place-items:center;
      min-height:120px;
      padding:20px;
      border:1.5px dashed var(--border);
      border-radius:8px;
      background:#fff;
      color:var(--muted);
      font-family:var(--mono);
      font-size:.8rem;
    }
    .apic-dropzone strong { display:block; color:var(--ink); margin-bottom:4px; font-size:.85rem; }
    .apic-dropzone:hover,
    .apic-dropzone.is-dragover { border-color:var(--accent); }
    .apic-queue { display:grid; gap:0; margin:10px 0; }
    .apic-batch-actions {
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      margin:10px 0 0;
      padding:10px 12px;
      border:1px solid var(--border);
      border-radius:8px;
      background:#fff;
    }
    .apic-batch-copy {
      display:grid;
      gap:2px;
      min-width:0;
    }
    .apic-batch-title {
      font-family:var(--mono);
      font-size:.68rem;
      font-weight:700;
      letter-spacing:0;
      color:var(--ink);
    }
    .apic-batch-meta {
      font-family:var(--mono);
      font-size:.66rem;
      letter-spacing:0;
      color:var(--muted);
    }
    .apic-row-actions { display:flex; gap:8px; justify-content:flex-end; flex-wrap:wrap; }
    .apic-upload-note { margin-top:10px; }
    .apic-empty {
      padding:20px;
      text-align:center;
      color:var(--muted);
      font-family:var(--mono);
      font-size:.76rem;
      border:1px dashed var(--border);
      border-radius:6px;
    }
    /* preset edit panel */
    .apic-preset-edit-panel {
      margin-top:16px;
      border:1px solid var(--border);
      border-radius:8px;
      overflow:hidden;
      background:#fff;
    }
    .apic-preset-edit-head {
      display:flex;
      align-items:center;
      gap:10px;
      padding:11px 14px;
      background:var(--paper);
      border-bottom:1px solid var(--border);
    }
    .apic-preset-name-input {
      flex:1;
      border:none;
      background:transparent;
      font-family:var(--mono);
      font-size:.82rem;
      font-weight:600;
      color:var(--ink);
      outline:none;
    }
    .apic-preset-name-input::placeholder { color:var(--muted); }
    @media (max-width: 920px) {
      .api-hero-shell .copy-col,
      .api-hero-shell .board-col {
        padding:92px 24px 56px;
      }
      .api-hero-title { max-width:13.5ch; }
      .api-flow-shell,
      .api-ops-inner,
      .api-tech-inner,
      .api-proof-shell .trust-inner,
      .api-tech-head,
      .api-tech-layout { grid-template-columns:1fr; gap:40px; padding:0 24px; }
      .api-proof-lead .trust-body-text {
        max-width:11.8ch;
      }
      .api-proof-aside,
      .api-proof-list,
      .api-proof-list .trust-meta {
        grid-column:auto;
      }
      .api-proof-list {
        grid-template-columns:1fr;
      }
      .api-proof-list .trust-fn-entry:nth-last-child(-n + 2) {
        border-bottom:1px solid rgba(245,240,232,.08);
      }
      .api-proof-list .trust-fn-entry:last-of-type {
        border-bottom:none;
      }
      .api-form-grid { grid-template-columns:1fr; }
      .apid-hero-grid, .apid-detail-grid, .apid-grid, .apid-packs, .apid-docs-grid { grid-template-columns:1fr; }
      .apid-docs-meta { flex-direction:column; }
      .apid-skeleton-row { grid-template-columns:repeat(2, 1fr); }
      .apid-hero-stats { grid-template-columns:1fr; }
      .apid-header { align-items:center; }
      .apid-pack:first-child, .apid-pack:last-child, .apid-pack--featured { border-radius:8px; margin:0; }
      .apic-row,
      .apic-stat-row { grid-template-columns:1fr; align-items:flex-start; }
      .apic-batch-actions { align-items:stretch; flex-direction:column; }
      .apic-batch-actions .apic-btn-secondary { width:100%; }
    }
    @media (max-width: 640px) {
      #apiDashMode { padding:16px; }
      .api-hero-shell .copy-col,
      .api-hero-shell .board-col { padding:76px 20px 40px; }
      .apic-main { padding:14px 16px; }
      .apic-topnav, .apic-tabnav { padding-left:14px; padding-right:14px; }
      .apic-center { padding:16px; }
      .api-hero-title {
        max-width:11.5ch;
        font-size:clamp(40px, 13vw, 58px);
        margin-bottom:20px;
      }
      .api-hero-shell .cat-desc {
        max-width:30ch;
        margin-bottom:26px;
      }
      .api-hero-shell .provenance { margin-bottom:24px; }
      .api-board-stack { gap:14px; }
      .api-board-col .board-context,
      .api-board-col .board-cite,
      .api-flow-copy,
      .api-flow-step p,
      .api-flow-step span,
      .api-ops-copy,
      .api-tech-copy p,
      .api-tech-points li,
      .api-contact-note { font-size:11px; }
      .api-bridge-shell.bridge,
      .api-ops-shell,
      .api-tech-shell,
      .api-proof-shell.trust,
      .api-contact-shell.cta-section { padding-top:92px; padding-bottom:84px; }
      .api-flow-title {
        max-width:11.5ch;
        font-size:clamp(2.05rem, 10vw, 3.05rem);
      }
      .api-flow-board {
        border-radius:26px;
        padding:20px;
      }
      .api-flow-step {
        grid-template-columns:38px 1fr;
        gap:14px;
      }
      .api-flow-step-num {
        font-size:1.05rem;
      }
      .api-flow-step h3 {
        font-size:16px;
      }
      .api-hero-links,
      .api-contact-actions,
      .api-tech-actions { flex-direction:column; align-items:flex-start; }
      .api-btn-bid { width:100%; }
      .api-btn-bid .bid-label { flex:1; }
      .api-board-surface,
      .api-form-shell,
      .api-tech-code-block { border-radius:24px; padding:20px; }
      .api-ops-inner,
      .api-tech-inner,
      .trust-inner,
      .cta-inner { padding-left:20px; padding-right:20px; }
      .api-proof-lead .trust-body-text {
        max-width:none;
        font-size:clamp(2rem, 10vw, 2.85rem);
        line-height:1.08;
      }
      .api-ops-entry,
      .cta-entry { grid-template-columns:34px 1fr; }
      .api-ops-entry-num,
      .cta-fn-num { font-size:12px; }
      .api-ops-entry h3 { font-size:16px; }
      .api-ops-entry p,
      .api-ops-entry span,
      .api-field-help,
      .api-contact-status { font-size:11px; }
      .api-lp-btn { width:100%; }
      .apid-card { padding:14px; }
      .apid-status-runner,
      .apid-hero-grid,
      .apid-note-grid { grid-template-columns:1fr 1fr; }
      .apid-studio-main,
      .apid-archive-row { grid-template-columns:1fr; }
      .apid-header { align-items:flex-start; text-align:left; }
      .apid-header h1 { font-size:2.2rem; }
    }
    @media (max-width: 640px) {
      .apid-shell { padding:24px 16px 44px; }
      .apid-status-runner,
      .apid-hero-grid,
      .apid-note-grid { grid-template-columns:1fr; }
      .apid-hero-top { flex-direction:column; }
    }
    .admin-btn-danger:hover { filter:brightness(1.1); }
    .admin-btn-sm { padding:3px 8px; font-size:.6rem; }
    .admin-search { display:flex; gap:8px; margin-bottom:14px; }
    .admin-search input { flex:1; padding:8px 12px; border:1px solid var(--border); border-radius:6px;
      font-family:var(--body); font-size:.8rem; }
    .admin-section-title { font-size:.9rem; font-weight:700; color:var(--ink); margin-bottom:12px; border-bottom:2px solid var(--accent); padding-bottom:6px; }
