@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap");

:root {
  color-scheme: dark;
  --magistry-ink: #f4f7ff;
  --magistry-muted: #a7b2c7;
  --magistry-bg: #0d1524;
  --magistry-panel: #1d293a;
  --magistry-panel-strong: #263449;
  --magistry-line: #344257;
  --magistry-accent: #7477ff;
  --magistry-accent-soft: rgba(116, 119, 255, 0.17);
  --magistry-success: #59c19a;
  --magistry-warning: #e0b46d;
  --magistry-error: #ff7777;
  --magistry-info: #9ba6ff;
  --magistry-shadow: 0 12px 28px rgba(3, 8, 18, 0.28);
  font-family: "Inter", system-ui, sans-serif;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--magistry-bg);
  color: var(--magistry-ink);
}

a { color: inherit; }

.magistry-shell { min-height: 100vh; display: flex; flex-direction: column; }

.magistry-header {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto minmax(220px, 1fr);
  gap: 16px;
  align-items: center;
  padding: 16px 28px;
  border-bottom: 1px solid var(--magistry-line);
  background: rgba(29, 41, 58, 0.96);
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(16px);
}

.magistry-brand {
  text-decoration: none;
  font-size: 26px;
  font-weight: 800;
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.magistry-brand small {
  margin-top: 6px;
  font: 700 11px/1.2 "Inter", system-ui, sans-serif;
  color: var(--magistry-muted);
  text-transform: uppercase;
  letter-spacing: 0;
}

.magistry-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex-wrap: wrap;
}

.magistry-nav a {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 11px;
  border: 1px solid transparent;
  border-radius: 8px;
  color: var(--magistry-muted);
  font-weight: 700;
  text-decoration: none;
}

.magistry-nav a[aria-current="page"], .magistry-nav a:hover {
  border-color: rgba(116, 119, 255, 0.34);
  color: #eef1ff;
  background: var(--magistry-accent-soft);
}

.magistry-icon {
  width: 26px;
  height: 26px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  color: var(--magistry-accent);
  background: var(--magistry-accent-soft);
  flex: 0 0 auto;
}

.magistry-icon svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.magistry-wallet {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.magistry-wallet-provider {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--magistry-muted);
  font-size: 12px;
  font-weight: 800;
}

.magistry-wallet-provider select {
  min-height: 30px;
  max-width: 180px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 5px 8px;
  background: #121d2f;
  color: var(--magistry-ink);
  font: 700 12px/1 "Inter", system-ui, sans-serif;
}

.magistry-wallet-pill, .magistry-status {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  border: 1px solid rgba(116, 119, 255, 0.36);
  border-radius: 999px;
  padding: 5px 10px;
  font: 600 12px/1 "IBM Plex Mono", monospace;
  color: #b7bdff;
  background: var(--magistry-accent-soft);
}

.magistry-main {
  width: min(1180px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 46px 0 70px;
  flex: 1;
}

.magistry-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.75fr);
  gap: 32px;
  align-items: end;
  padding: 36px 0 28px;
  border-bottom: 1px solid var(--magistry-line);
}

.magistry-hero h1, .magistry-page-title {
  margin: 0;
  font-size: 54px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0;
}

.magistry-hero p, .magistry-lede {
  font-size: 18px;
  line-height: 1.5;
  color: var(--magistry-muted);
}

.magistry-eyebrow {
  margin: 0 0 10px;
  color: var(--magistry-muted);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.magistry-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.magistry-card, .magistry-panel {
  border: 1px solid var(--magistry-line);
  background: var(--magistry-panel);
  border-radius: 8px;
  box-shadow: var(--magistry-shadow);
}

.magistry-card {
  min-height: 178px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 20px;
  text-decoration: none;
}

.magistry-card:hover {
  border-color: rgba(116, 119, 255, 0.45);
  background: #223048;
}

.magistry-card h2, .magistry-panel h2, .magistry-panel h3 {
  margin: 0;
  font-size: 20px;
  line-height: 1.15;
}

.magistry-card p, .magistry-panel p, .magistry-muted {
  color: var(--magistry-muted);
  line-height: 1.45;
}

.magistry-panel {
  padding: 22px;
  margin-top: 18px;
}

.magistry-disclosure {
  padding: 0;
  overflow: hidden;
}

.magistry-disclosure-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 64px;
  padding: 18px 22px;
  color: var(--magistry-ink);
  cursor: pointer;
  font-size: 20px;
  font-weight: 800;
  line-height: 1.15;
  list-style: none;
}

.magistry-disclosure-summary::-webkit-details-marker {
  display: none;
}

.magistry-disclosure-summary::after {
  content: "Show";
  flex: 0 0 auto;
  color: #b7bdff;
  font-size: 13px;
  font-weight: 800;
}

.magistry-disclosure[open] .magistry-disclosure-summary {
  border-bottom: 1px solid var(--magistry-line);
}

.magistry-disclosure[open] .magistry-disclosure-summary::after {
  content: "Hide";
}

.magistry-disclosure-body {
  padding: 22px;
}

.magistry-document-viewer {
  display: grid;
  gap: 14px;
  margin-top: 16px;
}

.magistry-pdf-viewer {
  width: 100%;
  height: min(78vh, 760px);
  min-height: 520px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  background: #111827;
}

.magistry-pdf-canvas-viewer {
  width: 100%;
  max-height: min(78vh, 760px);
  min-height: 520px;
  overflow: auto;
  display: grid;
  gap: 14px;
  padding: 12px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  background: #111827;
}

.magistry-pdf-canvas-viewer[hidden] {
  display: none;
}

.magistry-pdf-canvas-viewer canvas {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto;
  background: #fff;
  box-shadow: 0 8px 18px rgba(3, 8, 18, 0.3);
}

.magistry-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }

.magistry-end-actions {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--magistry-line);
}

.magistry-button, button.magistry-button {
  min-height: 36px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  background: var(--magistry-panel);
  color: var(--magistry-ink);
  padding: 8px 12px;
  font: 700 14px/1 "Inter", system-ui, sans-serif;
  text-decoration: none;
  cursor: pointer;
}

.magistry-button.primary {
  border-color: var(--magistry-accent);
  background: var(--magistry-accent);
  color: #fff;
}

.magistry-button:hover:not(:disabled) {
  border-color: rgba(116, 119, 255, 0.5);
  background: var(--magistry-panel-strong);
}

.magistry-button.primary:hover:not(:disabled) {
  background: #8587ff;
}

.magistry-button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.magistry-form-grid {
  display: grid;
  gap: 12px;
}

.magistry-field {
  display: grid;
  gap: 5px;
  font-weight: 700;
}

.magistry-field span,
.magistry-field legend {
  color: var(--magistry-muted);
  font-size: 13px;
}

.magistry-field legend {
  padding: 0;
  font-weight: 700;
}

.magistry-field input, .magistry-field select, .magistry-field textarea {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 8px 10px;
  font: 500 15px/1.3 "Inter", system-ui, sans-serif;
  background: #121d2f;
  color: var(--magistry-ink);
}

.magistry-field input:focus, .magistry-field select:focus, .magistry-field textarea:focus {
  border-color: var(--magistry-accent);
  outline: 2px solid rgba(116, 119, 255, 0.18);
  outline-offset: 0;
}

.magistry-check {
  grid-template-columns: 18px 1fr;
  align-items: start;
  gap: 10px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 10px 12px;
  background: #121d2f;
}

.magistry-check input {
  width: 18px;
  min-height: 18px;
  margin: 2px 0 0;
}

.magistry-check span {
  color: var(--magistry-ink);
  font-size: 14px;
  line-height: 1.35;
}

.magistry-choice-field {
  border: 0;
  padding: 0;
  margin: 0;
}

.magistry-radio-group {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.magistry-payment-choice {
  min-height: 46px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  grid-template-areas: "option info buy";
  align-items: center;
  gap: 10px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 10px 12px;
  background: #121d2f;
  cursor: pointer;
}

.magistry-payment-choice:has(.magistry-payment-option input:checked) {
  border-color: var(--magistry-accent);
  background: rgba(116, 119, 255, 0.17);
}

.magistry-payment-option {
  grid-area: option;
  display: grid;
  grid-template-columns: 18px 1fr;
  align-items: center;
  gap: 10px;
  min-width: 0;
  cursor: pointer;
}

.magistry-payment-option input {
  width: 18px;
  min-height: 18px;
  margin: 0;
}

.magistry-payment-option span {
  color: var(--magistry-ink);
  font-size: 14px;
  line-height: 1.3;
}

.magistry-payment-info {
  grid-area: info;
  position: relative;
  width: 20px;
  height: 20px;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(116, 119, 255, 0.44);
  border-radius: 999px;
  color: #d9ddff;
  background: rgba(116, 119, 255, 0.2);
  font: 800 12px/1 "IBM Plex Mono", monospace;
  cursor: help;
}

.magistry-payment-info:focus {
  outline: 2px solid rgba(116, 119, 255, 0.35);
  outline-offset: 2px;
}

.magistry-payment-tooltip {
  position: absolute;
  right: -1px;
  bottom: calc(100% + 10px);
  z-index: 20;
  width: min(320px, calc(100vw - 64px));
  padding: 10px 12px;
  border: 1px solid rgba(116, 119, 255, 0.45);
  border-radius: 8px;
  background: #121d2f;
  box-shadow: var(--magistry-shadow);
  color: var(--magistry-ink);
  font: 600 13px/1.4 "Inter", system-ui, sans-serif;
  opacity: 0;
  pointer-events: none;
  transform: translateY(4px);
  transition: opacity 120ms ease, transform 120ms ease;
}

.magistry-payment-info:hover .magistry-payment-tooltip,
.magistry-payment-info:focus .magistry-payment-tooltip {
  opacity: 1;
  transform: translateY(0);
}

.magistry-payment-buy {
  grid-area: buy;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(89, 193, 154, 0.55);
  border-radius: 8px;
  padding: 6px 9px;
  color: #d8fff0;
  background: rgba(89, 193, 154, 0.16);
  font: 800 12px/1 "Inter", system-ui, sans-serif;
  text-decoration: none;
  white-space: nowrap;
}

.magistry-payment-buy:hover,
.magistry-payment-buy:focus {
  border-color: rgba(89, 193, 154, 0.85);
  background: rgba(89, 193, 154, 0.24);
  outline: none;
}

.magistry-code {
  overflow: auto;
  max-height: 360px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 12px;
  background: #121d2f;
  font: 12px/1.5 "IBM Plex Mono", monospace;
  white-space: pre-wrap;
  word-break: break-word;
}

.magistry-confirmation {
  display: grid;
  gap: 10px;
  border: 1px solid rgba(89, 193, 154, 0.5);
  border-radius: 8px;
  padding: 14px 16px;
  background: rgba(89, 193, 154, 0.12);
  color: var(--magistry-ink);
}

.magistry-confirmation[hidden] {
  display: none;
}

.magistry-confirmation strong {
  color: var(--magistry-success);
  font-size: 16px;
}

.magistry-confirmation p {
  margin: 0;
  color: var(--magistry-muted);
}

.magistry-confirmation dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.magistry-confirmation dl div {
  display: grid;
  grid-template-columns: minmax(160px, 0.35fr) 1fr;
  gap: 12px;
  border-top: 1px solid var(--magistry-line);
  padding-top: 8px;
}

.magistry-confirmation dt {
  color: var(--magistry-muted);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.magistry-confirmation dd {
  margin: 0;
  overflow-wrap: anywhere;
  font-family: "IBM Plex Mono", monospace;
  font-size: 12px;
}

.magistry-toc {
  max-height: 420px;
  overflow: auto;
}

.magistry-toc ol {
  display: grid;
  gap: 5px;
  margin: 12px 0 0;
  padding-left: 18px;
}

.magistry-toc li {
  line-height: 1.25;
}

.magistry-toc a {
  color: #b7bdff;
  text-decoration: none;
}

.magistry-toc a:hover {
  text-decoration: underline;
}

.magistry-toc-depth-3 {
  margin-left: 14px;
}

.magistry-toc-depth-4 {
  margin-left: 28px;
  font-size: 13px;
}

.magistry-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: 14px;
}

.magistry-table th, .magistry-table td {
  border-bottom: 1px solid var(--magistry-line);
  padding: 9px 8px;
  text-align: left;
  vertical-align: top;
}

.magistry-table th {
  width: 136px;
  color: var(--magistry-muted);
  font-size: 12px;
  text-transform: uppercase;
}

.magistry-table td,
.magistry-table .magistry-mono {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.magistry-mono { font-family: "IBM Plex Mono", monospace; }

.magistry-registry-table-scroll {
  max-height: 530px;
  overflow-y: auto;
  overflow-x: hidden;
  border: 1px solid var(--magistry-line);
  border-radius: 10px;
}

.magistry-registry-table {
  min-width: 0;
}

.magistry-registry-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--magistry-panel);
}

.magistry-registry-status-col { width: 18%; }
.magistry-registry-record-col { width: 34%; }
.magistry-registry-classification-col { width: 23%; }
.magistry-registry-signer-col { width: 25%; }

.magistry-registry-head-summary {
  display: grid;
  gap: 12px;
  margin: 16px 0;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 14px;
  background: #121d2f;
}

.magistry-registry-head-summary h3 {
  margin: 0;
  font-size: 18px;
}

.magistry-metadata-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.magistry-metadata-grid div {
  min-width: 0;
  border-top: 1px solid var(--magistry-line);
  padding-top: 8px;
}

.magistry-metadata-grid dt {
  color: var(--magistry-muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.magistry-metadata-grid dd {
  margin: 3px 0 0;
  overflow-wrap: anywhere;
  font: 500 12px/1.45 "IBM Plex Mono", monospace;
}

.magistry-registry-summary-row td {
  padding-top: 13px;
  padding-bottom: 7px;
  border-bottom: 0;
}

.magistry-registry-detail-row td {
  padding-top: 4px;
  padding-bottom: 13px;
  color: var(--magistry-muted);
}

.magistry-table-label {
  display: block;
  margin-bottom: 4px;
  color: var(--magistry-muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.magistry-file-disclosure {
  display: block;
}

.magistry-file-disclosure summary {
  width: max-content;
  max-width: 100%;
  cursor: pointer;
  color: #c4c8ff;
  font-weight: 800;
}

.magistry-file-disclosure summary:hover {
  color: var(--magistry-ink);
}

.magistry-registry-files {
  display: grid;
  gap: 6px;
  margin: 8px 0 0;
  padding: 0;
}

.magistry-registry-file {
  display: grid;
  grid-template-columns: minmax(100px, 1fr) minmax(86px, 0.7fr) minmax(160px, 1.5fr) minmax(110px, 1fr);
  gap: 8px;
  align-items: start;
  border-top: 1px solid var(--magistry-line);
  padding-top: 6px;
}

.magistry-registry-file-heading {
  border-top: 0;
  padding-top: 0;
  color: var(--magistry-muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.magistry-registry-file-label {
  color: var(--magistry-text);
  font-weight: 800;
}

.magistry-registry-file-meta {
  color: var(--magistry-muted);
  font-size: 12px;
  text-transform: uppercase;
}

.magistry-registry-file-cid {
  display: block;
}

.magistry-registry-file-hash {
  display: block;
  color: var(--magistry-muted);
}

.magistry-registry-review {
  display: grid;
  gap: 10px;
  border: 1px solid var(--magistry-line);
  border-radius: 10px;
  padding: 14px;
  background: var(--magistry-panel-strong);
}

.magistry-registry-review h3 {
  margin: 0;
  font-size: 18px;
}

.magistry-registry-review-list {
  display: grid;
  gap: 10px;
  max-height: 440px;
  overflow-y: auto;
  padding-right: 2px;
}

.magistry-registry-review-item {
  display: grid;
  grid-template-columns: minmax(180px, 1.2fr) minmax(140px, 0.7fr) minmax(150px, 0.8fr) minmax(180px, 1fr);
  gap: 10px;
  align-items: end;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 12px;
  background: var(--magistry-panel);
}

.magistry-registry-review-item .magistry-field {
  margin: 0;
}

.magistry-result-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.magistry-result-list li {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--magistry-line);
  border-radius: 8px;
  padding: 10px;
  background: var(--magistry-panel-strong);
}

.magistry-footer {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  border-top: 1px solid var(--magistry-line);
  padding: 18px 24px;
  color: var(--magistry-muted);
  font-size: 13px;
}

.magistry-footer a {
  color: #b7bdff;
  font-weight: 700;
  text-decoration: none;
}

.magistry-footer a:hover {
  color: var(--magistry-ink);
  text-decoration: underline;
  text-underline-offset: 3px;
}

@media (max-width: 900px) {
  .magistry-header { grid-template-columns: 1fr; }
  .magistry-nav, .magistry-wallet { justify-content: flex-start; }
  .magistry-hero { grid-template-columns: 1fr; }
  .magistry-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .magistry-hero h1, .magistry-page-title { font-size: 42px; }
}

@media (max-width: 620px) {
  .magistry-main { width: min(100vw - 20px, 1180px); padding-top: 24px; }
  .magistry-header { padding: 12px; }
  .magistry-grid { grid-template-columns: 1fr; }
  .magistry-radio-group { grid-template-columns: 1fr; }
  .magistry-payment-choice {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "option info"
      "buy buy";
    align-items: start;
  }
  .magistry-payment-buy {
    width: 100%;
    min-height: 36px;
  }
  .magistry-registry-file {
    grid-template-columns: 1fr;
  }
  .magistry-registry-file-heading {
    display: none;
  }
  .magistry-metadata-grid {
    grid-template-columns: 1fr;
  }
  .magistry-registry-review-item {
    grid-template-columns: 1fr;
  }
  .magistry-pdf-viewer { min-height: 460px; }
  .magistry-footer { flex-direction: column; }
}
