/* ULAN Explorer — OFEX-ish cards (hover + gradient stripe) */
/* Designed to live alongside Tailwind + your /assets/css/style.css */

.ulanx {
  --ux-bg: rgba(255,255,255,.02);
  --ux-bg2: rgba(255,255,255,.015);
  --ux-stroke: rgba(255,255,255,.08);
  --ux-stroke2: rgba(255,255,255,.14);
  --ux-text: rgba(233, 242, 255, 1);
  --ux-muted: rgba(154, 176, 207, 1);
  --ux-accent: #00F0D4;
  --ux-accent2: #32FFB1;
  --ux-danger: #ff6b6b;
}

.ulanx-card {
  position: relative;
  border: 1px solid var(--ux-stroke);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border-radius: 20px;
  box-shadow: 0 10px 35px rgba(0,0,0,.32);
  overflow: hidden;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.ulanx-card::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:3px;
  background: linear-gradient(180deg, rgba(0,240,212,.95), rgba(50,255,177,.25));
  opacity:.0;
  transition: opacity .18s ease;
}

.ulanx-card:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.14);
  box-shadow: 0 14px 48px rgba(0,0,0,.42);
}

.ulanx-card:hover::before{
  opacity:.7;
}

.ulanx-h2{
  font-size: 14px;
  letter-spacing: .25px;
  font-weight: 800;
  margin: 0 0 10px;
  color: var(--ux-text);
}

.ulanx-note{
  color: var(--ux-muted);
  font-size: 12px;
  line-height: 1.45;
}

.ulanx-err{ color: var(--ux-danger); }

.ulanx-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--ux-stroke);
  background: rgba(255,255,255,.02);
  color: var(--ux-muted);
  font-size: 12px;
  backdrop-filter: blur(10px);
}

.ulanx-dot{
  width:9px;height:9px;border-radius:999px;
  background: var(--ux-accent);
  box-shadow: 0 0 0 6px rgba(0,240,212,.10);
}

.ulanx-btn{
  cursor:pointer;
  border: 1px solid var(--ux-stroke);
  background: rgba(255,255,255,.02);
  color: var(--ux-text);
  padding: 10px 12px;
  border-radius: 14px;
  font-size: 13px;
  transition: .15s ease;
  display:inline-flex;
  align-items:center;
  gap:8px;
  user-select:none;
}

.ulanx-btn:hover{
  border-color: rgba(0,240,212,.35);
  transform: translateY(-1px);
}

.ulanx-btn:active{ transform: translateY(0px); }

.ulanx-btn-primary{
  border-color: rgba(0,240,212,.28);
  background: linear-gradient(180deg, rgba(0,240,212,.10), rgba(255,255,255,.02));
}

.ulanx-search{
  display:flex;
  align-items:center;
  gap:10px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.25);
  border-radius: 14px;
  padding: 10px 12px;
}

.ulanx-search input{
  width:100%;
  background:transparent;
  border:0;
  outline:none;
  color: var(--ux-text);
  font-size: 13px;
}

.ulanx-table{
  width:100%;
  border-collapse: collapse;
  font-size: 13px;
}

.ulanx-table th,
.ulanx-table td{
  padding: 10px 8px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  vertical-align: middle;
}

.ulanx-table th{
  text-align:left;
  color: var(--ux-muted);
  font-weight: 700;
}

.ulanx-num{
  text-align:right;
  font-variant-numeric: tabular-nums;
}

.ulanx-addr{
  display:inline-flex;
  align-items:center;
  gap:8px;
  justify-content:flex-end;
  max-width: 100%;
}

.ulanx-chip{
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(0,0,0,.22);
  border-radius: 12px;
  padding: 7px 10px;
  max-width: 520px;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--ux-text);
  text-decoration: none;
}

.ulanx-chip:hover{
  border-color: rgba(0,240,212,.22);
  box-shadow: 0 0 0 6px rgba(0,240,212,.05);
}

.ulanx-chip.full{
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  word-break: break-all;
}

.ulanx-iconbtn{
  cursor:pointer;
  width:34px;height:34px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.02);
  display:grid;
  place-items:center;
  transition: .15s ease;
}

.ulanx-iconbtn:hover{
  border-color: rgba(0,240,212,.28);
  transform: translateY(-1px);
}

.ulanx-iconbtn svg{
  width:16px;height:16px;
  opacity:.9;
  fill: var(--ux-muted);
}

.ulanx-iconbtn:hover svg{ fill: var(--ux-accent); }

.ulanx-toast{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9999;
  display:flex;
  flex-direction:column;
  gap:10px;
  pointer-events:none;
}

.ulanx-toastItem{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(10,14,24,.75);
  backdrop-filter: blur(14px);
  border-radius: 14px;
  padding: 10px 12px;
  color: var(--ux-text);
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
  max-width: 420px;
  font-size: 13px;
}

.ulanx-toastItem .small{
  color: var(--ux-muted);
  font-size: 12px;
  margin-top: 2px;
}


/* Distribution */
.ulanx-dist{ margin-top:14px; }
.ulanx-dist-row{ display:grid; grid-template-columns: 60px 1fr 90px; gap:12px; align-items:center; padding:10px 0; border-top:1px solid rgba(255,255,255,.06); }
.ulanx-dist-row:first-child{ border-top:0; padding-top:6px; }
.ulanx-dist-label{ color:rgba(255,255,255,.78); font-size:13px; }
.ulanx-dist-bar{ height:10px; border-radius:999px; background: rgba(255,255,255,.06); overflow:hidden; }
.ulanx-dist-barfill{ height:100%; border-radius:999px; background: linear-gradient(90deg, rgba(0,240,212,.95), rgba(50,255,177,.55)); box-shadow: 0 0 0 1px rgba(0,240,212,.18) inset; }
.ulanx-dist-pct{ text-align:right; color:rgba(255,255,255,.85); font-variant-numeric: tabular-nums; }
.ulanx-dist-foot{ margin-top:12px; color:rgba(255,255,255,.55); font-size:12px; display:flex; align-items:center; gap:10px; }
.ulanx-dot{ opacity:.6; }

.ulanx-link{ color: rgba(0,240,212,.92); text-decoration:none; }
.ulanx-link:hover{ text-decoration:underline; }

/* Metadata */
.ulanx-meta{ display:flex; gap:16px; align-items:center; padding-top:10px; }
.ulanx-meta-logo{ width:56px; height:56px; border-radius:18px; background: rgba(0,240,212,.08); border:1px solid rgba(0,240,212,.18); position:relative; overflow:hidden; flex:0 0 auto; box-shadow: 0 10px 30px rgba(0,0,0,.35); }
.ulanx-meta-logo img{ width:100%; height:100%; object-fit:cover; display:none; }
.ulanx-meta-fallback{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-weight:700; letter-spacing:.06em; color: rgba(0,240,212,.92); }
.ulanx-meta-main{ min-width:0; }
.ulanx-meta-name{ font-size:18px; font-weight:700; line-height:1.2; color: rgba(255,255,255,.92); }
.ulanx-meta-sub{ display:flex; gap:10px; align-items:center; margin-top:6px; flex-wrap:wrap; }
.ulanx-meta-links{ margin-top:6px; }
.ulanx-card-actions{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.ulanx-toggle{ display:flex; gap:8px; align-items:center; color: rgba(255,255,255,.72); font-size:12px; user-select:none; }
.ulanx-toggle input{ width:14px; height:14px; accent-color: rgba(0,240,212,.9); }

/* Transfers toolbar */
.ulanx-toolbar{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.ulanx-toolbarRight{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.ulanx-select{
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.25);
  color: var(--ux-text);
  padding: 10px 12px;
  border-radius: 14px;
  font-size: 13px;
  outline:none;
}

.ulanx-select:focus{
  border-color: rgba(0,240,212,.28);
  box-shadow: 0 0 0 6px rgba(0,240,212,.05);
}

.ulanx-check{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.25);
  color: var(--ux-text);
  font-size: 13px;
  user-select:none;
}

.ulanx-check input{
  width:16px;
  height:16px;
  accent-color: rgba(0,240,212,.9);
}

.ulanx-btn:disabled,
.ulanx-iconbtn:disabled{
  opacity: .55;
  cursor: not-allowed;
  transform:none !important;
}