@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#000000;
  --bg2:#0c0c0e;
  --bg3:#15151a;
  --bg4:#1f1f25;
  --bg5:#292930;
  --card:#0c0c0e;
  --card2:#15151a;
  --border:rgba(255,255,255,.05);
  --border2:rgba(255,255,255,.10);
  --border3:rgba(255,255,255,.18);
  --text:#ffffff;
  --text2:#b8bcc6;
  --dim:#5e6573;
  --accent:#ffffff;
  --accent-fg:#000000;
  --accent-soft:rgba(255,255,255,.06);
  --accent-strong:rgba(255,255,255,.14);
  --green:#5ee19a;
  --green-soft:rgba(94,225,154,.10);
  --red:#ff7080;
  --red-soft:rgba(255,112,128,.10);
  --amber:#ffc857;
  --amber-soft:rgba(255,200,87,.10);
  --blue:#7fb6ff;
  --blue-soft:rgba(127,182,255,.10);
  --radius:18px;
  --radius-sm:12px;
  --radius-xs:9px;
  --font:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono','SF Mono','Cascadia Code',monospace;
  --shadow:0 1px 2px rgba(0,0,0,.6),0 12px 32px rgba(0,0,0,.45);
  --shadow-lg:0 8px 24px rgba(0,0,0,.55),0 36px 64px rgba(0,0,0,.6);
  --sidebar-w:236px;
  --gap:16px;
}

html,body{height:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.005em;
  min-height:100vh;
}

/* Inline icons: stop them from stretching when their parent is a flex/grid
   row without explicit alignment. We force a default 1em box on any SVG
   without explicit width/height attributes. */
svg:not([width]):not([height]){width:1em;height:1em;flex-shrink:0}
svg{flex-shrink:0;vertical-align:middle}
a{color:var(--text);text-decoration:none;transition:color .15s}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
::selection{background:var(--text);color:var(--bg)}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:var(--border3)}

/* ───── LAYOUT ───── */
/* Body itself is the flex row: sidebar | main column.
   Sidebar and .layout are rendered as siblings inside <body>, this lets both
   sit side-by-side without each view having to wrap them in an extra div. */
body{display:flex;align-items:flex-start;padding:var(--gap);gap:var(--gap);min-height:100vh}
.layout{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--gap);padding:0}
.main{display:flex;flex-direction:column;gap:var(--gap);min-width:0;flex:1}
.container{display:contents}

/* Auth pages don't have a sidebar — restore block layout. */
body:has(.auth-wrap){display:block;padding:0;gap:0}

/* ───── SIDEBAR (floating card) ───── */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--card);border-radius:var(--radius);
  display:flex;flex-direction:column;
  position:sticky;top:var(--gap);
  max-height:calc(100vh - var(--gap) * 2);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.sb-brand{
  display:flex;align-items:center;gap:11px;padding:22px 22px 20px;
}
.sb-brand .mark{
  width:36px;height:36px;border-radius:10px;
  background:#fff;color:#000;
  display:flex;align-items:center;justify-content:center;
}
.sb-brand .mark svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.sb-brand .name{font-weight:800;font-size:16px;letter-spacing:-.4px}
.sb-brand .name .dot{color:var(--dim)}

.sb-nav{padding:8px 14px;flex:1;overflow-y:auto}
.sb-section{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:1.2px;font-weight:700;padding:14px 10px 8px}
.sb-link{
  display:flex;align-items:center;gap:11px;
  padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;
  color:var(--text2);transition:all .12s;margin-bottom:3px;
}
.sb-link:hover{background:var(--bg3);color:var(--text)}
.sb-link.active{background:#fff;color:#000;font-weight:600;box-shadow:0 6px 16px rgba(255,255,255,.08)}
.sb-link.active svg{stroke-width:2.2}
.sb-link svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

.sb-foot{padding:14px 14px 18px;border-top:1px solid var(--border)}
.sb-user{display:flex;align-items:center;gap:10px;padding:10px 11px;border-radius:11px;background:var(--bg3);margin-bottom:8px}
.sb-user .av{width:32px;height:32px;border-radius:50%;background:#fff;color:#000;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;font-family:var(--mono);flex-shrink:0}
.sb-user .info{flex:1;min-width:0}
.sb-user .uname{font-size:12.5px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-user .urole{font-size:10px;color:var(--dim);font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px}

.sb-logout{
  display:flex;align-items:center;justify-content:center;gap:9px;
  padding:10px 12px;border-radius:11px;background:transparent;
  color:var(--text2);font-size:12.5px;font-weight:600;
  transition:all .15s;width:100%;
}
.sb-logout svg{width:16px;height:16px;flex-shrink:0}
.sb-logout:hover{background:var(--red-soft);color:var(--red)}

.sb-lang{display:flex;gap:4px;padding:0 14px 4px}
.sb-lang-btn{
  flex:1;text-align:center;font-family:var(--mono);font-size:10.5px;font-weight:700;
  padding:6px 0;border-radius:8px;color:var(--dim);background:var(--bg3);
  transition:all .12s;letter-spacing:1px;
}
.sb-lang-btn:hover{color:var(--text);background:var(--bg4)}
.sb-lang-btn.active{background:#fff;color:#000}

.sb-pills{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.sb-pill{display:flex;justify-content:space-between;align-items:center;padding:9px 13px;background:var(--bg3);border-radius:10px;font-size:11px}
.sb-pill .l{color:var(--dim);text-transform:uppercase;letter-spacing:.6px;font-weight:600;font-size:10px}
.sb-pill .v{color:var(--text);font-family:var(--mono);font-weight:700;font-size:13px}
.sb-pill.good .v{color:var(--green)}
.sb-pill.bad  .v{color:var(--red)}

/* ───── PAGE HEAD ───── */
.page-head{
  background:var(--card);border-radius:var(--radius);
  padding:24px 28px;display:flex;justify-content:space-between;align-items:flex-end;
  gap:18px;flex-wrap:wrap;box-shadow:var(--shadow);
}
.page-head h1{font-size:28px;font-weight:800;letter-spacing:-1px;color:var(--text)}
.page-head .sub{color:var(--dim);font-size:13px;margin-top:6px;letter-spacing:.1px}

/* ───── CARDS ───── */
.card{
  background:var(--card);
  border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);
  transition:transform .15s ease;
}
.card-h{padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-h .title{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text2)}
.card-h .title-lg{font-size:16px;font-weight:700;letter-spacing:-.3px;text-transform:none;color:var(--text)}
.card-h .extra{color:var(--dim);font-size:12px}
.card-b{padding:0 24px 24px}
.card-b.no-pad{padding:0}
.card.card-bordered{border:1px solid var(--border)}
.card.card-flat{box-shadow:none}

/* ───── GRID ───── */
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--gap)}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--gap)}
.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--gap)}
@media(max-width:1100px){.grid-3,.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ───── STATS ───── */
.stat{
  background:var(--card);border-radius:var(--radius);
  padding:22px 24px;box-shadow:var(--shadow);
}
.stat .lbl{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--dim);font-weight:700;margin-bottom:14px}
.stat .val{font-size:34px;font-weight:800;font-family:var(--mono);letter-spacing:-1.7px;color:var(--text);line-height:1}
.stat .sub{font-size:12px;color:var(--text2);margin-top:10px}

/* ───── BUTTONS ───── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 18px;font-size:13px;font-weight:600;border-radius:11px;
  transition:all .15s;border:1px solid transparent;cursor:pointer;
  font-family:inherit;letter-spacing:.1px;
}
.btn:disabled{opacity:.4;pointer-events:none}
.btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-primary{background:#fff;color:#000;border-color:#fff}
.btn-primary:hover{background:#ededed;border-color:#ededed}
.btn-ghost{background:var(--bg3);color:var(--text);border-color:transparent}
.btn-ghost:hover{background:var(--bg4)}
.btn-outline{background:transparent;color:var(--text);border-color:var(--border2)}
.btn-outline:hover{background:var(--bg3);border-color:var(--border3)}
.btn-red{background:var(--red-soft);color:var(--red);border-color:transparent}
.btn-red:hover{background:rgba(255,112,128,.18)}
.btn-sm{padding:6px 12px;font-size:11.5px;border-radius:8px}
.btn-lg{padding:12px 22px;font-size:14px}
.btn-block{width:100%}

/* ───── FORM ───── */
.fg{margin-bottom:16px}
.fg label{display:block;font-size:12px;color:var(--text2);margin-bottom:7px;font-weight:500;letter-spacing:.2px}
.fg small,.help{color:var(--dim);font-size:11.5px;margin-top:5px;display:block;line-height:1.55}
.input{
  width:100%;padding:11px 14px;background:var(--bg3);border:1px solid transparent;
  border-radius:10px;color:var(--text);font-size:13px;transition:all .15s;
}
.input:focus{outline:none;border-color:#fff;background:var(--bg);box-shadow:0 0 0 3px var(--accent-soft)}
.input.mono{font-family:var(--mono);font-size:12px}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%23b8bcc6' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:32px}
textarea.input{min-height:84px;resize:vertical}

/* ───── TOGGLE ───── */
.toggle{position:relative;display:inline-block;width:38px;height:22px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle .slider{position:absolute;inset:0;background:var(--bg4);border-radius:22px;cursor:pointer;transition:.2s}
.toggle .slider::before{content:'';position:absolute;width:16px;height:16px;left:3px;top:3px;background:var(--text2);border-radius:50%;transition:.2s}
.toggle input:checked + .slider{background:#fff}
.toggle input:checked + .slider::before{transform:translateX(16px);background:#000}

.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0}
.toggle-row + .toggle-row{border-top:1px solid var(--border)}
.tr-name{font-size:13px;font-weight:600;color:var(--text)}
.tr-desc{font-size:11.5px;color:var(--dim);margin-top:3px;line-height:1.5}

/* ───── TABLE ───── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{
  text-align:left;padding:13px 22px;font-size:10px;text-transform:uppercase;letter-spacing:.9px;
  color:var(--dim);font-weight:700;
}
tbody td{padding:14px 22px;border-top:1px solid var(--border);color:var(--text2);white-space:nowrap}
tbody tr:hover td{background:rgba(255,255,255,.02);color:var(--text)}
td code,.code{font-family:var(--mono);font-size:11.5px;color:var(--text);background:var(--bg3);padding:3px 9px;border-radius:6px}
td strong{color:var(--text);font-weight:600}

/* ───── ALERTS ───── */
.alert{padding:13px 18px;border-radius:11px;font-size:13px;margin-bottom:18px;display:flex;align-items:center;gap:10px;line-height:1.5}
.alert svg{width:17px!important;height:17px!important;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2}
.alert-ok{background:var(--green-soft);color:var(--green)}
.alert-err{background:var(--red-soft);color:var(--red)}
.alert-warn{background:var(--amber-soft);color:var(--amber)}
.alert-info{background:var(--blue-soft);color:var(--blue)}

/* ───── BADGES ───── */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;padding:4px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.7px;font-family:var(--mono);white-space:nowrap;line-height:1.2}
.badge svg{width:11px!important;height:11px!important;stroke:currentColor;fill:none;stroke-width:2}
.b-completed,.b-paid{background:var(--green-soft);color:var(--green)}
.b-processing,.b-uploading,.b-pending{background:var(--amber-soft);color:var(--amber)}
.b-failed,.b-expired{background:var(--red-soft);color:var(--red)}
.b-active{background:var(--green-soft);color:var(--green)}
.b-inactive{background:var(--bg4);color:var(--dim)}

/* ───── LOGIN ───── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:30px;background:radial-gradient(800px 500px at 50% -100px,rgba(255,255,255,.05),transparent),var(--bg);position:relative}
.auth-lang{position:absolute;top:22px;right:22px;display:flex;gap:4px;background:var(--card);padding:4px;border-radius:10px;box-shadow:var(--shadow)}
.auth-lang-btn{font-family:var(--mono);font-size:10.5px;font-weight:700;padding:7px 13px;border-radius:7px;color:var(--dim);letter-spacing:1px;transition:all .12s}
.auth-lang-btn:hover{color:var(--text)}
.auth-lang-btn.active{background:#fff;color:#000}
.auth-box{width:400px;max-width:100%}
.auth-box .card{background:var(--card);box-shadow:var(--shadow-lg)}
.auth-hdr{text-align:center;padding:38px 30px 22px}
.auth-hdr .auth-logo{
  width:64px;height:64px;border-radius:18px;
  background:#fff;color:#000;
  display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.auth-hdr .auth-logo svg{width:32px;height:32px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.auth-hdr h1{font-size:22px;font-weight:800;letter-spacing:-.5px;color:var(--text)}
.auth-hdr p{color:var(--dim);font-size:13px;margin-top:6px}
.auth-body{padding:0 30px 30px}
.auth-foot{text-align:center;padding:18px;font-size:12px;color:var(--dim);background:rgba(255,255,255,.025)}
.auth-foot a{color:var(--text);font-weight:600}
.auth-foot a:hover{text-decoration:underline}

/* ───── DROPZONE ───── */
.dz{
  border:1.5px dashed var(--border3);border-radius:14px;
  padding:46px 28px;text-align:center;cursor:pointer;
  transition:all .2s;background:var(--bg3);
}
.dz:hover,.dz.over{border-color:#fff;background:var(--bg4)}
.dz .dz-icon{
  width:56px;height:56px;margin:0 auto 16px;border-radius:14px;
  background:var(--bg2);
  display:flex;align-items:center;justify-content:center;color:var(--text2);
}
.dz:hover .dz-icon,.dz.over .dz-icon{color:#fff}
.dz .dz-icon svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.dz .dz-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.2px}
.dz .dz-sub{font-size:12px;color:var(--dim);line-height:1.6}

/* ───── FILE CARD ───── */
.fc{display:flex;align-items:center;gap:14px;background:var(--bg3);border-radius:12px;padding:14px 18px}
.fc-icon{width:42px;height:42px;background:var(--bg2);color:var(--text);border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fc-icon svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.fc-info{flex:1;min-width:0}
.fc-name{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fc-meta{font-size:11px;color:var(--dim);margin-top:3px;font-family:var(--mono)}

/* ───── PROGRESS ───── */
.prog{height:6px;background:var(--bg3);border-radius:8px;overflow:hidden}
.prog-bar{height:100%;background:#fff;border-radius:8px;transition:width .3s}

/* ───── STEPS ───── */
.steps{display:flex;gap:6px;padding:6px;background:var(--card);border-radius:14px;box-shadow:var(--shadow)}
.step{flex:1;padding:11px 14px;border-radius:10px;font-size:12px;font-weight:600;color:var(--dim);display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s}
.step.active{background:#fff;color:#000}
.step.done{color:var(--green)}
.step-num{display:inline-flex;width:19px;height:19px;border-radius:50%;background:var(--bg4);color:var(--text);font-family:var(--mono);font-size:10px;align-items:center;justify-content:center;font-weight:700}
.step.active .step-num{background:rgba(0,0,0,.18);color:#000}
.step.done .step-num{background:var(--green);color:#000}

/* ───── FORMAT PILLS ───── */
.fmt-row{display:flex;gap:8px;flex-wrap:wrap}
.fmt-pill{flex:1;min-width:90px;padding:15px 12px;border-radius:11px;text-align:center;cursor:pointer;font-family:var(--mono);font-weight:700;font-size:13px;color:var(--text2);background:var(--bg3);transition:all .15s;text-transform:uppercase;letter-spacing:.6px}
.fmt-pill:hover{background:var(--bg4);color:var(--text)}
.fmt-pill.active{background:#fff;color:#000}
.fmt-pill.disabled{opacity:.4;pointer-events:none}
.fmt-pill .fp-sub{font-size:9px;font-weight:500;color:inherit;opacity:.65;display:block;margin-top:4px;letter-spacing:.4px;text-transform:none;font-family:var(--font)}

/* ───── INFO BLOCK ───── */
.info-block{background:var(--card);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow)}
.info-block h3{font-size:13px;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:10px;letter-spacing:.5px;text-transform:uppercase}
.info-block ul{list-style:none;margin:8px 0 0 0;padding:0}
.info-block li{font-size:13px;color:var(--text2);padding:7px 0;line-height:1.55}
.info-block li.warn::before{content:"!";color:var(--amber);font-weight:800;margin-right:10px;font-family:var(--mono);font-size:13px;display:inline-block;width:14px;text-align:center}
.info-block li.ok::before{content:"+";color:var(--green);font-weight:800;margin-right:10px;font-family:var(--mono);font-size:13px;display:inline-block;width:14px;text-align:center}
.info-block li.dot::before{content:"→";color:var(--dim);font-weight:600;margin-right:10px;font-family:var(--mono);display:inline-block;width:14px;text-align:center}
.info-block .note{margin-top:16px;padding:13px 15px;background:var(--amber-soft);color:var(--amber);border-radius:11px;font-size:12.5px;line-height:1.55}

/* ───── MODAL ───── */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.modal.show{display:flex}
.modal-box{background:var(--card);border-radius:var(--radius);width:520px;max-width:100%;box-shadow:var(--shadow-lg);overflow:hidden;max-height:90vh;display:flex;flex-direction:column}
.modal-h{padding:18px 24px;display:flex;justify-content:space-between;align-items:center}
.modal-h .title{font-size:14px;font-weight:700;color:var(--text)}
.modal-h .x{font-size:22px;color:var(--dim);cursor:pointer;line-height:1}
.modal-h .x:hover{color:var(--text)}
.modal-b{padding:6px 24px 22px;overflow:auto}
.modal-f{padding:14px 24px 18px;display:flex;justify-content:flex-end;gap:10px}

/* ───── PACKAGES ───── */
.pkg-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
@media(max-width:900px){.pkg-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:520px){.pkg-grid{grid-template-columns:1fr}}
.pkg-card{
  position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;
  background:var(--bg3);border-radius:14px;padding:22px 16px 18px;cursor:pointer;
  transition:all .15s;border:2px solid transparent;
}
.pkg-card:hover{background:var(--bg4)}
.pkg-card.active{background:#fff;color:#000;border-color:#fff}
.pkg-card.active .text-dim,.pkg-card.active .pkg-c-l,.pkg-card.active .pkg-mid,.pkg-card.active .pkg-rate{color:rgba(0,0,0,.55)}
.pkg-top{margin-bottom:6px}
.pkg-c{font-family:var(--mono);font-size:38px;font-weight:800;letter-spacing:-2px;line-height:1}
.pkg-c-l{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--dim);font-weight:700;margin-top:2px}
.pkg-mid{font-size:12.5px;color:var(--text2);margin:8px 0 14px;min-height:18px}
.pkg-mid strong{font-family:var(--mono);font-weight:700;color:inherit}
.pkg-price{font-family:var(--mono);font-size:24px;font-weight:800;letter-spacing:-1px}
.pkg-rate{font-size:10.5px;color:var(--dim);font-family:var(--mono);margin-top:4px}

/* ───── BUY / INVOICE ───── */
.buy-amount{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:14px;color:var(--text);background:var(--bg3);padding:10px 16px;border-radius:11px}
.buy-amount strong{color:#fff;font-weight:800;font-size:16px}
.coin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.coin-pill{padding:11px 8px;border-radius:11px;text-align:center;cursor:pointer;font-family:var(--mono);font-size:12px;color:var(--text2);background:var(--bg3);font-weight:700;text-transform:uppercase;transition:all .15s;letter-spacing:.5px}
.coin-pill:hover{background:var(--bg4);color:var(--text)}
.coin-pill.active{background:#fff;color:#000}

.invoice-grid{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}
@media(max-width:780px){.invoice-grid{grid-template-columns:1fr}}
.qr-box{background:#fff;border-radius:14px;padding:14px;display:flex;align-items:center;justify-content:center}
.qr-box img{display:block;max-width:100%;height:auto}

/* ───── SIDELOAD HOST PICKER ───── */
.host-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.host-card{padding:14px 16px;border-radius:13px;background:var(--bg3);cursor:pointer;transition:all .15s;position:relative}
.host-card:hover{background:var(--bg4)}
.host-card.active{background:#fff;color:#000}
.host-card.disabled{opacity:.4;cursor:not-allowed;filter:grayscale(1)}
.host-card .h-name{font-family:var(--mono);font-size:12px;font-weight:700;margin-bottom:4px}
.host-card .h-pub{font-size:10.5px;opacity:.65;margin-bottom:8px}
.host-card .h-dll{font-size:11px;font-family:var(--mono);opacity:.8}
.host-card .h-miss{position:absolute;top:8px;right:8px;font-size:9px;background:var(--amber-soft);color:var(--amber);padding:2px 6px;border-radius:4px;font-family:var(--mono);font-weight:700;text-transform:uppercase}

/* ───── UTIL ───── */
.flex{display:flex}.flex-1{flex:1}.justify-between{justify-content:space-between}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.text-dim{color:var(--dim)}.text-sm{font-size:12px}.text-xs{font-size:11px}.mono{font-family:var(--mono)}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:24px}
.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:24px}
.divider{border:none;border-top:1px solid var(--border);margin:18px 0}
.copy-btn{cursor:pointer;color:var(--dim);font-size:10px;font-family:var(--mono);padding:4px 9px;border-radius:6px;background:var(--bg);transition:all .15s;letter-spacing:.5px;font-weight:700}
.copy-btn:hover{color:var(--text);background:var(--bg4)}
.code-row{display:flex;align-items:center;gap:10px;background:var(--bg3);border-radius:10px;padding:10px 14px;font-family:var(--mono);font-size:12px}
.code-row code{flex:1;word-break:break-all;background:none;padding:0;color:var(--text);font-family:var(--mono)}
.empty{padding:48px 24px;text-align:center;color:var(--dim);font-size:13px}
.empty strong{display:block;color:var(--text2);margin-bottom:6px;font-size:14px}

@media(max-width:880px){
  .layout{flex-direction:column;padding:8px;gap:8px}
  .sidebar{position:relative;width:100%;height:auto}
  .sb-nav{display:flex;overflow-x:auto;padding:6px}
  .sb-section{display:none}
  .sb-link{flex-shrink:0;margin-bottom:0;margin-right:4px}
  .sb-foot{display:none}
}
