/* PACT design system — tokens are promises. */
:root{
  --void:#0a0a0a;
  --void-2:#141414;
  --void-3:#1c1c1c;
  --ash:#2a2a2a;
  --ash-2:#444;
  --stone:#666;
  --chalk:#fafafa;
  --chalk-2:#cfcfcf;
  --chalk-3:#888;
  --seal:#e8de4a;
  --seal-d:#bfb52e;
  --seal-2:#fff385;
  --oxblood:#7c1818;
  --oxblood-2:#a82424;
  --oxblood-d:#5a0e0e;
  --green:#5ce28a;
  --red:#e25c5c;
  --amber:#e8b04a;

  --slab:'Roboto Slab',Georgia,serif;
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;

  --r-sm:2px;
  --r-md:0;
  --r-lg:0;

  --sidebar-w:230px;
  --topbar-h:60px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--void)}
body{
  color:var(--chalk);font-family:var(--sans);font-weight:400;font-size:14px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-color:var(--void);
  background-image:radial-gradient(rgba(232,222,74,0.04) 1px, transparent 1px);
  background-size:14px 14px;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit}
::selection{background:var(--seal);color:var(--void)}

/* ─── APP SHELL ─── */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
@media(max-width:880px){.app{grid-template-columns:1fr}}

.sidebar{
  background:var(--void-2);border-right:1px solid var(--ash);
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;z-index:40;
  overflow-y:auto;padding:18px 14px;
}
@media(max-width:880px){.sidebar{display:none}}

.sidebar-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px;margin-bottom:6px}
.sidebar-brand .mk{
  width:28px;height:28px;flex-shrink:0;position:relative;
  background:var(--void);border:2px solid var(--seal);
  border-radius:50%;
}
.sidebar-brand .mk::before{
  content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:14px;height:2px;background:var(--seal);
}
.sidebar-brand .name{font-family:var(--slab);font-weight:700;font-size:22px;letter-spacing:-0.5px;color:var(--chalk);text-transform:uppercase}
.sidebar-brand .name .dot{color:var(--seal)}

.sidebar-section{padding:14px 12px 6px;font-family:var(--mono);font-size:9px;letter-spacing:3px;color:var(--seal);text-transform:uppercase;font-weight:600}
.sidebar a.nav{
  display:flex;align-items:center;gap:10px;padding:9px 12px;margin-bottom:1px;
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;color:var(--chalk-2);text-transform:uppercase;
  border-left:2px solid transparent;transition:all .12s;
}
.sidebar a.nav:hover{background:var(--void-3);color:var(--chalk);border-left-color:var(--ash-2)}
.sidebar a.nav.active{background:var(--void-3);color:var(--seal);border-left-color:var(--seal)}
.sidebar a.nav .ic{display:inline-block;width:14px;text-align:center;font-size:11px;flex-shrink:0;color:var(--seal)}

.sidebar-footer{margin-top:auto;padding:14px 12px 4px;font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--chalk-3);border-top:1px solid var(--ash);text-transform:uppercase}
.sidebar-footer a{display:block;padding:5px 0;transition:color .12s}
.sidebar-footer a:hover{color:var(--seal)}

/* ─── TOPBAR ─── */
.topbar{
  position:sticky;top:0;z-index:30;height:var(--topbar-h);
  display:flex;align-items:center;gap:14px;padding:0 28px;
  background:rgba(10,10,10,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--ash);
}
@media(max-width:880px){.topbar{padding:0 20px}}
.topbar .topbar-mobile-brand{display:none;align-items:center;gap:8px}
@media(max-width:880px){.topbar .topbar-mobile-brand{display:flex}}
.topbar .topbar-mobile-brand .mk{width:18px;height:18px;border:2px solid var(--seal);border-radius:50%;position:relative}
.topbar .topbar-mobile-brand .mk::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:8px;height:1.5px;background:var(--seal)}
.topbar .topbar-mobile-brand .name{font-family:var(--slab);font-weight:700;font-size:16px;text-transform:uppercase}
.topbar .crumb{font-family:var(--mono);font-size:11px;letter-spacing:2px;color:var(--chalk-3);text-transform:uppercase}
.topbar .crumb .seal{color:var(--seal);font-weight:600}
.topbar .spacer{flex:1}

/* ─── BUTTONS ─── */
.btn{
  display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:2px;
  padding:9px 16px;border:1px solid transparent;cursor:pointer;
  transition:all .14s ease;background:transparent;color:var(--chalk);
  line-height:1;text-transform:uppercase;border-radius:0;
}
.btn-primary{background:var(--seal);color:var(--void);border-color:var(--seal);font-weight:700}
.btn-primary:hover{background:var(--chalk);border-color:var(--chalk)}
.btn-ghost{border-color:var(--ash-2);color:var(--chalk-2);background:transparent}
.btn-ghost:hover{border-color:var(--seal);color:var(--seal)}
.btn-line{border-color:var(--chalk);color:var(--chalk);background:transparent}
.btn-line:hover{background:var(--chalk);color:var(--void)}
.btn-seal{background:var(--seal);color:var(--void);font-weight:700}
.btn-seal:hover{background:var(--seal-2)}
.btn[disabled]{opacity:.4;cursor:not-allowed}
.btn-tiny{padding:7px 12px;font-size:10px}

.dot{width:6px;height:6px;border-radius:50%;background:var(--seal);box-shadow:0 0 6px rgba(232,222,74,.7)}
.dot.pulse{animation:dotp 1.6s ease-in-out infinite}
@keyframes dotp{0%,100%{box-shadow:0 0 0 0 rgba(232,222,74,.7)}50%{box-shadow:0 0 0 6px rgba(232,222,74,0)}}

/* ─── MAIN CANVAS ─── */
.canvas{padding:28px 32px 80px;max-width:1400px}
@media(max-width:680px){.canvas{padding:20px}}

.page-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:28px;flex-wrap:wrap;border-bottom:1px solid var(--ash);padding-bottom:18px}
.page-tag{font-family:var(--mono);font-size:10px;letter-spacing:3px;color:var(--seal);text-transform:uppercase;margin-bottom:8px;font-weight:600}
.page-head h1{font-family:var(--slab);font-weight:700;font-size:clamp(36px,5vw,64px);letter-spacing:-1.5px;line-height:1;color:var(--chalk);margin:0;text-transform:uppercase}
.page-head h1 .seal{color:var(--seal)}
.page-head .lead{font-family:'Georgia',serif;font-style:italic;font-size:16px;color:var(--chalk-2);margin:8px 0 0;max-width:580px;line-height:1.5}

/* ─── CARDS ─── */
.card{background:var(--void-2);border:1px solid var(--ash);padding:24px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--ash)}
.card-head h3{font-family:var(--mono);font-size:10px;letter-spacing:3px;color:var(--seal);text-transform:uppercase;font-weight:600;margin:0}

.section-meta{display:flex;align-items:baseline;gap:14px;font-family:var(--mono);font-size:10px;letter-spacing:3px;color:var(--seal);text-transform:uppercase;margin-bottom:18px;flex-wrap:wrap;font-weight:600}
.section-meta .num{color:var(--seal);font-weight:700}
.section-meta .line{flex:1;height:1px;background:var(--ash)}

/* ─── INPUTS ─── */
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:2px;color:var(--seal);text-transform:uppercase;margin-bottom:7px;font-weight:600}
.field input,.field textarea,.field select{
  width:100%;background:var(--void);border:1px solid var(--ash-2);
  padding:11px 14px;font-size:14px;color:var(--chalk);outline:none;transition:border-color .12s;border-radius:0;
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--seal)}
.field input::placeholder,.field textarea::placeholder{color:var(--stone)}
.field textarea{min-height:70px;resize:vertical}
.field .hint{font-family:var(--mono);font-size:10px;letter-spacing:1px;color:var(--chalk-3);margin-top:5px;text-transform:uppercase}

/* ─── EMPTY ─── */
.empty{padding:36px;text-align:center;color:var(--chalk-3);font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;background:var(--void-2);border:1px solid var(--ash)}
.spinner{display:inline-block;width:10px;height:10px;border:1.5px solid var(--ash-2);border-top-color:var(--seal);border-radius:50%;animation:sp 0.8s linear infinite;margin-right:8px;vertical-align:-1px}
@keyframes sp{to{transform:rotate(360deg)}}

/* ─── STATUS BOX ─── */
.status-box{margin-top:12px;padding:12px 14px;font-family:var(--mono);font-size:11px;display:none;letter-spacing:1px;border:1px solid;text-transform:uppercase}
.status-box.show{display:block}
.status-box.info{background:rgba(232,222,74,.06);border-color:rgba(232,222,74,.4);color:var(--seal)}
.status-box.error{background:rgba(226,92,92,.06);border-color:rgba(226,92,92,.4);color:var(--red)}
.status-box.success{background:rgba(92,226,138,.06);border-color:rgba(92,226,138,.4);color:var(--green)}
.status-box a{color:inherit;text-decoration:underline}

/* ─── MODALS ─── */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:32px 18px;backdrop-filter:blur(8px);overflow-y:auto}
.modal.show{display:flex}
.modal-inner{background:var(--void-2);border:1px solid var(--ash-2);max-width:680px;width:100%;padding:36px clamp(24px,4vw,44px);margin:auto;position:relative}
.modal-inner.narrow{max-width:420px}
.modal h3{font-family:var(--slab);font-weight:700;font-size:36px;letter-spacing:-1px;margin:0 0 6px;color:var(--chalk);line-height:1.05;text-transform:uppercase}
.modal h3 .seal{color:var(--seal)}
.modal .subtitle{font-family:var(--mono);font-size:10px;letter-spacing:3px;color:var(--seal);text-transform:uppercase;margin-bottom:14px;font-weight:600}
.modal h4{font-family:var(--slab);font-weight:700;font-size:18px;margin:24px 0 8px;color:var(--chalk);text-transform:uppercase;letter-spacing:0.5px}
.modal p{color:var(--chalk-2);font-size:13px;line-height:1.65;margin:0 0 12px}
.modal ul{padding-left:18px;color:var(--chalk-2);font-size:13px;line-height:1.65;margin:0 0 12px}
.modal ul li{margin-bottom:5px}
.modal strong{color:var(--chalk);font-weight:700}
.modal code{font-family:var(--mono);background:var(--void);color:var(--seal);padding:1px 6px;font-size:11px;border:1px solid var(--ash)}
.modal-close{background:none;border:none;color:var(--chalk-3);cursor:pointer;font-size:22px;position:absolute;top:14px;right:16px;line-height:1;font-family:var(--mono)}
.modal-close:hover{color:var(--seal)}

.wallet-pick{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:var(--void);border:1px solid var(--ash-2);cursor:pointer;color:var(--chalk);font-size:13px;text-align:left;margin-bottom:6px;transition:all .12s}
.wallet-pick:hover{border-color:var(--seal);background:var(--void-3)}
.wallet-pick .ico{width:32px;height:32px;background:var(--seal);color:var(--void);display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:13px;flex-shrink:0}
.wallet-pick .meta{flex:1}
.wallet-pick .meta .name{font-family:var(--slab);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.wallet-pick .meta .sub{font-family:var(--mono);font-size:10px;color:var(--chalk-3);margin-top:1px;letter-spacing:1px;text-transform:uppercase}
.wallet-badge .addr{font-family:var(--mono);font-size:11px;color:var(--chalk);letter-spacing:.5px}
