/* ============================================================
   SignChain.id — Dashboard Shared CSS (Refactored Clean)
   ============================================================ */

/* ── Variables & Reset ──────────────────────────────────────── */
:root{
  --ink:#0c0f1a;--paper:#f5f2eb;--cream:#edeadf;--cream2:#e5e1d5;
  --teal:#0b9e8a;--teal2:#097d6e;--amber:#c97d12;--red:#c03838;
  --muted:#7a7568;--muted2:#9a9488;
  --border:rgba(12,15,26,.09);--border2:rgba(12,15,26,.16);
  --mono:'IBM Plex Mono',monospace;--disp:'Plus Jakarta Sans',sans-serif;--body:'Inter',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--paper);color:var(--ink);font-family:var(--body);font-size:15px;line-height:1.65;min-height:100vh;}

/* ── Navbar ─────────────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.85rem 2rem;background:rgba(245,242,235,.93);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);}
.nav-logo{font-family:var(--disp);font-size:1.1rem;font-weight:800;letter-spacing:-.5px;color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:9px;}
.nav-logo-box{width:30px;height:30px;background:var(--ink);border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--paper);font-size:12px;font-weight:700;}
.nav-right{display:flex;align-items:center;gap:1rem;}
.nav-user{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);}
.nav-avatar{width:30px;height:30px;border-radius:50%;background:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-size:11px;font-weight:700;color:var(--paper);}
.nav-kyc-badge{font-family:var(--mono);font-size:10px;letter-spacing:1px;padding:3px 8px;border-radius:3px;}
.nav-kyc-badge.unverified{background:rgba(201,125,18,.1);color:var(--amber);border:1px solid rgba(201,125,18,.2);}
.nav-kyc-badge.verified,.nav-kyc-badge.approved{background:rgba(11,158,138,.1);color:var(--teal);border:1px solid rgba(11,158,138,.2);}
.nav-kyc-badge.pending{background:rgba(201,125,18,.1);color:var(--amber);border:1px solid rgba(201,125,18,.2);}
.btn-logout{font-size:12px;color:var(--muted);background:none;border:1px solid var(--border2);border-radius:4px;padding:5px 12px;cursor:pointer;font-family:var(--body);transition:all .2s;}
.btn-logout:hover{background:var(--cream2);color:var(--ink);}

/* ── Layout ─────────────────────────────────────────────────── */
.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh;padding-top:56px;}
.main{padding:2rem 2.5rem;max-width:1200px;min-width:0;}

/* ── Sidebar ────────────────────────────────────────────────── */
.sidebar{background:var(--cream);border-right:1px solid var(--border);padding:1.75rem 1.25rem;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;display:flex;flex-direction:column;gap:.25rem;}
.sidebar-label{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);padding:.5rem .75rem;margin-top:.75rem;}
.sidebar-link{display:flex;align-items:center;gap:9px;padding:.6rem .75rem;border-radius:5px;font-size:13px;font-weight:500;color:var(--muted);text-decoration:none;transition:all .2s;}
.sidebar-link:hover{background:var(--cream2);color:var(--ink);}
.sidebar-link.active{background:var(--ink);color:var(--paper);}
.sidebar-link .sl-icon{font-size:14px;width:18px;flex-shrink:0;}
.sidebar-quota{margin-top:auto;background:var(--paper);border:1px solid var(--border);border-radius:7px;padding:.9rem 1rem;}
.sq-label{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:.4rem;}
.sq-bar{height:4px;background:var(--cream2);border-radius:2px;overflow:hidden;margin-bottom:.4rem;}
.sq-fill{height:100%;background:var(--teal);border-radius:2px;transition:width .5s ease;}
.sq-text{font-size:12px;color:var(--muted);display:flex;justify-content:space-between;}
.sq-upgrade{display:block;text-align:center;margin-top:.65rem;font-size:12px;color:var(--teal);text-decoration:none;font-weight:500;}

/* ── Page Header (semua halaman) ────────────────────────────── */
.page-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--teal);margin-bottom:.4rem;display:flex;align-items:center;gap:8px;}
.page-eyebrow::before{content:'';width:16px;height:1px;background:var(--teal);}
.page-title{font-family:var(--disp);font-size:1.6rem;font-weight:800;letter-spacing:-1px;color:var(--ink);line-height:1.1;margin-bottom:.4rem;}
.page-title span{color:var(--teal);}
.page-desc{font-size:14px;color:var(--muted);margin-bottom:2rem;line-height:1.7;max-width:560px;}
.page-header{margin-bottom:2rem;}

/* ── Global Badges ──────────────────────────────────────────── */
.badge{font-family:var(--mono);font-size:10px;letter-spacing:1px;padding:3px 9px;border-radius:3px;text-transform:uppercase;white-space:nowrap;display:inline-block;}
.badge.valid,.badge.active,.badge.paid{background:rgba(11,158,138,.1);color:var(--teal);border:1px solid rgba(11,158,138,.2);}
.badge.revoked,.badge.inactive,.badge.failed{background:rgba(192,56,56,.1);color:var(--red);border:1px solid rgba(192,56,56,.2);}
.badge.pending{background:rgba(201,125,18,.1);color:var(--amber);border:1px solid rgba(201,125,18,.2);}
.badge.expired,.badge.cancel{background:var(--cream2);color:var(--muted);border:1px solid var(--border2);}

/* ── Global Table ───────────────────────────────────────────── */
.table-wrap{background:var(--paper);border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.table-wrap-scroll{overflow-x:auto;}
.table-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.table-title{font-family:var(--disp);font-size:.95rem;font-weight:700;color:var(--ink);}
.table-count{font-family:var(--mono);font-size:11px;color:var(--muted);}
table{width:100%;border-collapse:collapse;}
th{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);padding:.75rem 1.25rem;text-align:left;border-bottom:1px solid var(--border);background:var(--cream);white-space:nowrap;}
td{padding:.9rem 1.25rem;border-bottom:1px solid var(--border);font-size:13px;color:var(--ink);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(12,15,26,.015);}
.pagination{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-top:1px solid var(--border);font-size:13px;color:var(--muted);}
.page-btns{display:flex;gap:.35rem;}
.page-btn{width:32px;height:32px;border-radius:4px;border:1px solid var(--border2);background:var(--paper);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;font-family:var(--mono);transition:all .2s;}
.page-btn:hover{background:var(--cream2);}
.page-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink);}

/* ── Global Modal ───────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(12,15,26,.5);z-index:200;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.modal-overlay.show{display:flex;}
.modal{background:var(--paper);border-radius:10px;width:100%;max-width:520px;margin:1rem;max-height:90vh;overflow-y:auto;}
.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--paper);}
.modal-title{font-family:var(--disp);font-size:1rem;font-weight:700;color:var(--ink);}
.modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted);}
.modal-body{padding:1.5rem;}
.modal-actions{display:flex;gap:.6rem;flex-wrap:wrap;padding-top:1rem;border-top:1px solid var(--border);margin-top:1rem;}
.modal-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:5px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid var(--border2);background:var(--paper);color:var(--ink);text-decoration:none;font-family:var(--body);}
.modal-btn:hover{background:var(--cream2);}
.modal-btn.primary{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.modal-btn.primary:hover{background:var(--teal);}
.modal-btn.danger{color:var(--red);border-color:rgba(192,56,56,.25);background:rgba(192,56,56,.05);}
.modal-btn.danger:hover{background:var(--red);color:var(--paper);}

/* ── Global Toast ───────────────────────────────────────────── */
.toast{position:fixed;bottom:2rem;right:2rem;background:var(--ink);color:var(--paper);padding:.8rem 1.2rem;border-radius:7px;font-size:13px;font-family:var(--mono);display:none;z-index:999;max-width:360px;}
.toast.show{display:block;}
.toast.ok{background:var(--teal);}
.toast.err{background:var(--red);}

/* ── Global Form Elements ───────────────────────────────────── */
.ff{display:flex;flex-direction:column;gap:.35rem;}
.ff.full{grid-column:1/-1;}
.ff label{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
.ff input,.ff select,.ff textarea{background:var(--cream);border:1px solid var(--border2);border-radius:5px;padding:9px 11px;font-size:13px;font-family:var(--body);color:var(--ink);outline:none;transition:border-color .2s;}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--teal);background:var(--paper);}
.ff input::placeholder{color:var(--muted2);}
.ff .fn{font-size:11px;color:var(--muted2);line-height:1.5;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;}
.mf{margin-bottom:1rem;}
.mf-key{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);margin-bottom:.3rem;}
.mf-val{font-size:14px;color:var(--ink);line-height:1.6;}
.mf-val.mono{font-family:var(--mono);font-size:12px;word-break:break-all;color:var(--teal);}
.mf-divider{height:1px;background:var(--border);margin:1.25rem 0;}

/* ── Spinner / Progress ─────────────────────────────────────── */
.spinner{width:15px;height:15px;border:2px solid rgba(245,242,235,.3);border-top-color:var(--paper);border-radius:50%;animation:spin .6s linear infinite;display:none;}
@keyframes spin{to{transform:rotate(360deg)}}
.progress-wrap{display:none;margin:1rem 0;}
.progress-wrap.show{display:block;}
.progress-label-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--muted);margin-bottom:.4rem;}
.progress-bar{height:3px;background:var(--cream2);border-radius:2px;overflow:hidden;}
.progress-fill{height:100%;background:var(--teal);border-radius:2px;width:0%;transition:width .45s ease;}
.progress-steps{display:flex;gap:6px;margin-top:.6rem;flex-wrap:wrap;}
.ps-item{font-family:var(--mono);font-size:10px;letter-spacing:1px;padding:3px 9px;border-radius:3px;}
.ps-item.wait{background:var(--cream2);color:var(--muted2);}
.ps-item.active{background:rgba(201,125,18,.1);color:var(--amber);}
.ps-item.done{background:rgba(11,158,138,.1);color:var(--teal);}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes bounce{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(-4px);opacity:1}}

/* ── Empty State ────────────────────────────────────────────── */
.empty-state{text-align:center;padding:3.5rem 2rem;}
.empty-icon{font-size:40px;margin-bottom:.75rem;opacity:.4;}
.empty-title{font-family:var(--disp);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:.5rem;}
.empty-text,.empty-desc{font-size:14px;color:var(--muted);line-height:1.7;}

/* ── Card (Profile, etc) ────────────────────────────────────── */
.card{background:var(--paper);border:1px solid var(--border);border-radius:10px;margin-bottom:1.25rem;overflow:hidden;}
.card-header{padding:1.1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.card-title{font-family:var(--disp);font-size:.95rem;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:8px;}
.card-body{padding:1.5rem;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}
.field-label{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:.35rem;}
.field-value{font-size:14px;color:var(--ink);font-weight:500;}
.field-value.muted{color:var(--muted);font-weight:400;}

/* ════════════════════════════════════════════════════════════
   DASHBOARD HOME
   ════════════════════════════════════════════════════════════ */
.welcome-card{background:var(--ink);border-radius:10px;padding:1.75rem 2rem;margin-bottom:1.75rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;}
.wc-greeting{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(245,242,235,.4);margin-bottom:.4rem;}
.wc-name{font-family:var(--disp);font-size:1.5rem;font-weight:800;color:var(--paper);letter-spacing:-.5px;margin-bottom:.4rem;}
.wc-sub{font-size:13px;color:rgba(245,242,235,.5);}
.wc-btn{background:var(--teal);color:var(--paper);border:none;border-radius:6px;padding:11px 22px;font-size:13px;font-weight:600;font-family:var(--body);cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .2s;display:inline-block;}
.wc-btn:hover{background:var(--teal2);}
.kyc-banner{background:rgba(201,125,18,.07);border:1px solid rgba(201,125,18,.2);border-radius:8px;padding:1rem 1.25rem;display:flex;align-items:center;gap:12px;margin-bottom:1.75rem;}
.kb-icon{font-size:20px;flex-shrink:0;}
.kb-text{flex:1;font-size:13px;color:var(--amber);line-height:1.6;}
.kb-btn{background:var(--amber);color:var(--paper);border:none;border-radius:4px;padding:7px 16px;font-size:12px;font-weight:500;cursor:pointer;font-family:var(--body);white-space:nowrap;text-decoration:none;display:inline-block;transition:background .2s;}
.kb-btn:hover{background:#b06d0e;}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.75rem;}
.stat-card{background:var(--paper);border:1px solid var(--border);border-radius:8px;padding:1.25rem;}
.sc-num{font-family:var(--disp);font-size:2rem;font-weight:800;color:var(--ink);letter-spacing:-1.5px;line-height:1;}
.sc-label{font-size:12px;color:var(--muted);margin-top:4px;font-family:var(--mono);}
.sc-sub{font-size:11px;margin-top:3px;}
.sc-sub.ok{color:var(--teal);}
.sc-sub.warn{color:var(--amber);}
.status-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.75rem;}
.status-card{background:var(--paper);border:1px solid var(--border);border-radius:8px;padding:1.25rem;}
.stc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.stc-title{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);}
.stc-badge{font-family:var(--mono);font-size:10px;letter-spacing:1px;padding:3px 9px;border-radius:3px;text-transform:uppercase;}
.stc-badge.ok{background:rgba(11,158,138,.1);color:var(--teal);border:1px solid rgba(11,158,138,.2);}
.stc-badge.warn{background:rgba(201,125,18,.1);color:var(--amber);border:1px solid rgba(201,125,18,.2);}
.stc-badge.err{background:rgba(192,56,56,.1);color:var(--red);border:1px solid rgba(192,56,56,.2);}
.stc-val{font-family:var(--disp);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:.25rem;}
.stc-desc{font-size:12px;color:var(--muted);}
.stc-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--teal);text-decoration:none;margin-top:.75rem;font-weight:500;}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem;}
.section-title{font-family:var(--disp);font-size:1rem;font-weight:700;color:var(--ink);}
.section-link{font-size:12px;color:var(--teal);text-decoration:none;font-weight:500;}
.quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.75rem;}
.qa-card{background:var(--paper);border:1px solid var(--border);border-radius:8px;padding:1.25rem;text-decoration:none;transition:all .2s;display:flex;flex-direction:column;gap:.5rem;}
.qa-card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 6px 20px rgba(12,15,26,.06);}
.qa-icon{font-size:22px;}
.qa-title{font-family:var(--disp);font-size:.9rem;font-weight:700;color:var(--ink);}
.qa-desc{font-size:12px;color:var(--muted);line-height:1.5;}
.recent-list{background:var(--paper);border:1px solid var(--border);border-radius:8px;overflow:hidden;}
/* recent list pakai class tabel dari files section */
.btn-register-link{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--paper);padding:11px 22px;border-radius:5px;font-size:13px;font-weight:500;text-decoration:none;transition:background .2s;}
.btn-register-link:hover{background:var(--teal);}

/* ════════════════════════════════════════════════════════════
   MY FILES
   ════════════════════════════════════════════════════════════ */
.stats-mini{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;}
.sm-card{background:var(--paper);border:1px solid var(--border);border-radius:7px;padding:.75rem 1.25rem;display:flex;align-items:center;gap:.75rem;}
.sm-num{font-family:var(--disp);font-size:1.3rem;font-weight:800;color:var(--ink);letter-spacing:-.5px;}
.sm-label{font-size:12px;color:var(--muted);font-family:var(--mono);}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap;}
.search-wrap{position:relative;flex:1;max-width:320px;}
.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:13px;color:var(--muted2);}
.search-input{width:100%;background:var(--paper);border:1px solid var(--border2);border-radius:6px;padding:8px 12px 8px 32px;font-size:13px;font-family:var(--body);color:var(--ink);outline:none;transition:border-color .2s;}
.search-input:focus{border-color:var(--teal);}
.search-input::placeholder{color:var(--muted2);}
.toolbar-right{display:flex;align-items:center;gap:.5rem;}
.filter-btn{font-size:12px;padding:7px 14px;border-radius:5px;border:1px solid var(--border2);background:var(--paper);color:var(--muted);cursor:pointer;font-family:var(--body);transition:all .2s;}
.filter-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.filter-btn:hover:not(.active){background:var(--cream2);color:var(--ink);}
.view-btn{width:32px;height:32px;border-radius:5px;border:1px solid var(--border2);background:var(--paper);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .2s;}
.view-btn.active{background:var(--ink);color:var(--paper);}
.file-cell{display:flex;align-items:center;gap:10px;}
.file-type-icon{width:34px;height:34px;border-radius:6px;background:var(--ink);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.file-name{font-size:13px;font-weight:500;color:var(--ink);max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.file-hash{font-family:var(--mono);font-size:10px;color:var(--muted2);margin-top:2px;}
.contact-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-family:var(--mono);color:var(--teal);background:rgba(11,158,138,.08);border:1px solid rgba(11,158,138,.15);border-radius:3px;padding:2px 7px;white-space:nowrap;}
.owner-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-family:var(--mono);color:var(--ink);background:var(--cream);border:1px solid var(--border2);border-radius:3px;padding:2px 7px;white-space:nowrap;}
.owner-name{font-size:12px;font-weight:500;color:var(--ink);}
.ref-id{font-family:var(--mono);font-size:11px;color:var(--muted);max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.date-cell{font-family:var(--mono);font-size:11px;color:var(--muted);white-space:nowrap;}
.action-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:4px 10px;border-radius:4px;border:1px solid var(--border2);background:var(--paper);color:var(--ink);cursor:pointer;font-family:var(--body);transition:all .2s;text-decoration:none;margin-right:3px;}
.action-btn:hover{background:var(--cream2);}
.action-btn.teal{color:var(--teal);border-color:rgba(11,158,138,.25);background:rgba(11,158,138,.05);}
.action-btn.cert{color:var(--teal);border-color:rgba(11,158,138,.2);background:rgba(11,158,138,.04);}
.action-btn.cert:hover{background:rgba(11,158,138,.1);}
.grid-wrap{display:none;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;}
.grid-wrap.show{display:grid;}
.table-wrap.hide{display:none;}
.file-card{background:var(--paper);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:all .2s;}
.file-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 6px 20px rgba(12,15,26,.06);}
.fc-top{padding:1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;}
.fc-icon{width:42px;height:42px;border-radius:8px;background:var(--ink);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.fc-name{font-size:13px;font-weight:500;color:var(--ink);line-height:1.4;word-break:break-word;}
.fc-body{padding:1rem 1.25rem;}
.fc-field{margin-bottom:.6rem;}
.fc-key{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:2px;}
.fc-val{font-size:12px;color:var(--ink);}
.fc-val.mono{font-family:var(--mono);font-size:10px;word-break:break-all;line-height:1.6;color:var(--teal);}
.fc-actions{display:flex;gap:.4rem;padding-top:.75rem;border-top:1px solid var(--border);}

/* ════════════════════════════════════════════════════════════
   REGISTER DOC
   ════════════════════════════════════════════════════════════ */
.kyc-lock{background:rgba(201,125,18,.07);border:1px solid rgba(201,125,18,.2);border-radius:8px;padding:2rem;text-align:center;}
.kyc-lock-icon{font-size:36px;margin-bottom:.75rem;}
.kyc-lock-title{font-family:var(--disp);font-size:1.1rem;font-weight:700;color:var(--amber);margin-bottom:.5rem;}
.kyc-lock-desc{font-size:13px;color:var(--muted);margin-bottom:1.25rem;line-height:1.7;}
.kyc-lock-btn{display:inline-flex;align-items:center;gap:6px;background:var(--amber);color:var(--paper);padding:10px 22px;border-radius:5px;font-size:13px;font-weight:600;text-decoration:none;transition:background .2s;}
.kyc-lock-btn:hover{background:#b06d0e;}
.upload-card{background:var(--paper);border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.uc-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);}
.uc-title{font-family:var(--disp);font-size:1rem;font-weight:700;color:var(--ink);}
.uc-sub{font-size:12px;color:var(--muted);margin-top:2px;}
.uc-body{padding:1.5rem;}
.upload-zone{border:2px dashed var(--border2);border-radius:8px;padding:2.5rem;text-align:center;cursor:pointer;transition:all .25s;position:relative;background:var(--cream);}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--teal);background:rgba(11,158,138,.03);}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.uz-icon{width:52px;height:52px;border-radius:10px;background:var(--ink);display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto .9rem;}
.uz-title{font-family:var(--disp);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:.3rem;}
.uz-desc{font-size:13px;color:var(--muted);}
.uz-desc strong{color:var(--teal);}
.file-pill{display:none;align-items:center;gap:10px;background:var(--cream);border:1px solid var(--border);border-radius:7px;padding:.75rem 1rem;margin-top:.75rem;}
.file-pill.show{display:flex;}
.fp-icon{width:36px;height:36px;border-radius:6px;background:var(--ink);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.fp-info{flex:1;min-width:0;}
.fp-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fp-size{font-size:11px;color:var(--muted);font-family:var(--mono);margin-top:1px;}
.fp-remove{background:none;border:none;color:var(--muted2);cursor:pointer;font-size:15px;padding:4px;transition:color .2s;margin-left:auto;}
.fp-remove:hover{color:var(--red);}
.hash-box{display:none;background:var(--cream);border:1px solid var(--border);border-radius:7px;padding:.8rem 1rem;margin-top:.75rem;}
.hash-box.show{display:block;}
.hb-label{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);margin-bottom:.3rem;display:flex;align-items:center;gap:6px;}
.hb-computing{display:inline-flex;gap:3px;align-items:center;}
.hb-dot{width:4px;height:4px;border-radius:50%;background:var(--teal);animation:bounce .9s ease infinite;}
.hb-dot:nth-child(2){animation-delay:.15s;}.hb-dot:nth-child(3){animation-delay:.3s;}
.hb-val{font-family:var(--mono);font-size:11px;color:var(--teal);word-break:break-all;line-height:1.7;}
.btn-register{width:100%;background:var(--teal);color:var(--paper);border:none;border-radius:6px;padding:13px;font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:1rem;}
.btn-register:hover:not(:disabled){background:var(--teal2);}
.btn-register:disabled{opacity:.4;cursor:not-allowed;}
.reg-result{display:none;background:var(--paper);border:1px solid rgba(11,158,138,.25);border-radius:8px;overflow:hidden;margin-top:1rem;}
.reg-result.show{display:block;animation:fadeUp .4s ease both;}
.rr-top{background:rgba(11,158,138,.07);border-bottom:1px solid rgba(11,158,138,.15);padding:1rem 1.25rem;display:flex;align-items:center;gap:10px;}
.rr-icon{width:36px;height:36px;border-radius:50%;background:rgba(11,158,138,.15);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.rr-title{font-family:var(--disp);font-size:.95rem;font-weight:700;color:var(--teal);}
.rr-sub{font-size:12px;color:rgba(11,158,138,.65);margin-top:1px;}
.rr-body{padding:1.25rem;}
.rr-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem;}
.rr-field{background:var(--cream);border-radius:5px;padding:.6rem .8rem;}
.rr-field.full{grid-column:1/-1;}
.rrf-key{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:2px;}
.rrf-val{font-family:var(--mono);font-size:11px;color:var(--teal);word-break:break-all;line-height:1.6;}
.rrf-val.dark{color:var(--ink);}
.rr-actions{display:flex;gap:.5rem;flex-wrap:wrap;}
.rr-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid var(--border2);background:var(--paper);color:var(--ink);text-decoration:none;}
.rr-btn:hover{background:var(--cream);}
.rr-btn.primary{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.rr-btn.primary:hover{background:var(--teal);}

/* ════════════════════════════════════════════════════════════
   FILE VERIFICATION
   ════════════════════════════════════════════════════════════ */
.tabs{display:flex;gap:2px;background:var(--cream);border-radius:7px;padding:4px;margin-bottom:2rem;width:fit-content;}
.tab-btn{padding:8px 20px;border-radius:5px;border:none;background:none;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .2s;font-family:var(--body);}
.tab-btn.active{background:var(--paper);color:var(--ink);box-shadow:0 1px 4px rgba(12,15,26,.08);}
.tab-content{display:none;}
.tab-content.active{display:block;}
.info-strip{display:flex;align-items:flex-start;gap:8px;padding:.7rem 1rem;background:var(--cream);border-radius:6px;margin-bottom:1rem;font-size:13px;color:var(--muted);line-height:1.6;border:1px solid var(--border);}
.or-div{display:flex;align-items:center;gap:12px;margin:1.25rem 0;font-family:var(--mono);font-size:10px;color:var(--muted2);letter-spacing:1px;}
.or-div::before,.or-div::after{content:'';flex:1;height:1px;background:var(--border);}
.hash-input-wrap{position:relative;margin-bottom:.5rem;}
.hash-lbl{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;display:block;}
.hash-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--muted2);}
.hash-input{width:100%;background:var(--cream);border:1px solid var(--border2);border-radius:6px;padding:11px 52px 11px 36px;font-family:var(--mono);font-size:12px;color:var(--ink);outline:none;transition:border-color .2s;}
.hash-input:focus{border-color:var(--teal);background:var(--paper);}
.hash-input::placeholder{color:var(--muted2);}
.hash-count{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:11px;color:var(--muted2);}
.hash-count.valid{color:var(--teal);}
.btn-main{width:100%;border:none;border-radius:6px;padding:13px;font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:1rem;}
.btn-ink{background:var(--ink);color:var(--paper);}
.btn-ink:hover:not(:disabled){background:var(--teal);}
.btn-main:disabled{opacity:.4;cursor:not-allowed;}
.result-area{display:none;margin-top:1.5rem;}
.result-area.show{display:block;animation:fadeUp .4s ease both;}
.result-card{border-radius:10px;overflow:hidden;border:1px solid var(--border);}
.rc-banner{padding:1.2rem 1.5rem;display:flex;align-items:center;gap:14px;}
.rc-banner.valid{background:rgba(11,158,138,.08);border-bottom:1px solid rgba(11,158,138,.15);}
.rc-banner.revoked{background:rgba(201,125,18,.08);border-bottom:1px solid rgba(201,125,18,.15);}
.rc-banner.invalid{background:rgba(192,56,56,.08);border-bottom:1px solid rgba(192,56,56,.15);}
.rc-icon{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.rc-icon.valid{background:rgba(11,158,138,.15);color:var(--teal);}
.rc-icon.revoked{background:rgba(201,125,18,.15);color:var(--amber);}
.rc-icon.invalid{background:rgba(192,56,56,.15);color:var(--red);}
.rc-title{font-family:var(--disp);font-size:1.15rem;font-weight:800;letter-spacing:-.3px;}
.rc-title.valid{color:var(--teal);}
.rc-title.revoked{color:var(--amber);}
.rc-title.invalid{color:var(--red);}
.rc-sub{font-size:13px;margin-top:2px;opacity:.7;}
.rc-badge{margin-left:auto;font-family:var(--mono);font-size:11px;letter-spacing:1.5px;padding:5px 14px;border-radius:4px;flex-shrink:0;text-transform:uppercase;}
.rc-badge.valid{background:rgba(11,158,138,.12);color:var(--teal);border:1px solid rgba(11,158,138,.25);}
.rc-badge.revoked{background:rgba(201,125,18,.12);color:var(--amber);border:1px solid rgba(201,125,18,.25);}
.rc-badge.invalid{background:rgba(192,56,56,.12);color:var(--red);border:1px solid rgba(192,56,56,.25);}
.rc-body{background:var(--paper);padding:1.4rem 1.5rem;}
.rc-sec{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);margin-bottom:.65rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);}
.rc-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1.25rem;}
.rc-field{background:var(--cream);border-radius:6px;padding:.7rem .9rem;}
.rc-field.full{grid-column:1/-1;}
.rf-key{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:3px;}
.rf-val{font-size:13px;font-weight:500;color:var(--ink);}
.rf-val.mono{font-family:var(--mono);font-size:11px;word-break:break-all;line-height:1.6;}
.rf-val.teal{color:var(--teal);}
.rf-val.link{color:var(--teal);cursor:pointer;}
.rf-val.link:hover{text-decoration:underline;}
.pub-card{background:var(--cream);border-radius:8px;padding:.9rem 1.1rem;display:flex;align-items:center;gap:12px;margin-bottom:1.25rem;}
.pub-av{width:42px;height:42px;border-radius:7px;background:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--disp);font-size:13px;font-weight:700;color:var(--paper);flex-shrink:0;}
.pub-name{font-size:14px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.pub-kyc{display:inline-flex;align-items:center;gap:3px;background:rgba(11,158,138,.1);border:1px solid rgba(11,158,138,.2);border-radius:3px;padding:2px 7px;font-family:var(--mono);font-size:9px;letter-spacing:1px;color:var(--teal);}
.pub-org{font-size:12px;color:var(--muted);margin-top:1px;}
.rc-actions{display:flex;gap:.6rem;flex-wrap:wrap;}
.rc-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border-radius:5px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid var(--border2);background:var(--paper);color:var(--ink);}
.rc-btn:hover{background:var(--cream);}
.rc-btn.primary{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.rc-btn.primary:hover{background:var(--teal);}
.warn-box{background:rgba(201,125,18,.07);border:1px solid rgba(201,125,18,.2);border-radius:6px;padding:.8rem 1rem;margin-bottom:1rem;display:flex;gap:8px;font-size:13px;color:var(--amber);line-height:1.6;}
.causes{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.2rem;}
.cause{display:flex;gap:10px;padding:.7rem .9rem;background:var(--cream);border-radius:6px;font-size:13px;color:var(--muted);line-height:1.5;}

/* ════════════════════════════════════════════════════════════
   CONTACTS
   ════════════════════════════════════════════════════════════ */
.invite-card{background:var(--ink);border-radius:10px;padding:1.5rem 2rem;display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem;}
.ic-text{flex:1;}
.ic-title{font-family:var(--disp);font-size:1rem;font-weight:700;color:var(--paper);margin-bottom:.25rem;}
.ic-desc{font-size:13px;color:rgba(245,242,235,.5);}
.btn-invite{background:var(--teal);color:var(--paper);border:none;border-radius:6px;padding:10px 20px;font-size:13px;font-weight:600;font-family:var(--body);cursor:pointer;white-space:nowrap;transition:background .2s;}
.btn-invite:hover{background:var(--teal2);}
.btn-sm{font-size:11px;padding:4px 10px;border-radius:4px;border:1px solid var(--border2);background:var(--paper);color:var(--ink);cursor:pointer;font-family:var(--body);transition:all .2s;margin-right:4px;}
.btn-sm:hover{background:var(--cream2);}
.btn-sm.danger{color:var(--red);border-color:rgba(192,56,56,.25);}
.btn-sm.danger:hover{background:var(--red);color:var(--paper);}
.btn-sm.warn{color:var(--amber);border-color:rgba(201,125,18,.25);}
.modal-err{background:rgba(192,56,56,.08);border:1px solid rgba(192,56,56,.2);border-radius:5px;padding:.65rem .9rem;font-size:13px;color:var(--red);margin-bottom:1rem;display:none;}
.modal-err.show{display:block;}
.btn-modal{flex:1;padding:11px;border-radius:6px;font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;border:none;transition:all .2s;}
.btn-modal.primary{background:var(--teal);color:var(--paper);}
.btn-modal.primary:hover{background:var(--teal2);}
.btn-modal.primary:disabled{opacity:.5;cursor:not-allowed;}
.btn-modal.cancel{background:var(--cream2);color:var(--ink);}
.btn-modal.cancel:hover{background:var(--cream);}

/* ════════════════════════════════════════════════════════════
   BILLING
   ════════════════════════════════════════════════════════════ */
.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;}
.sum-card{background:var(--paper);border:1px solid var(--border);border-radius:10px;padding:1.25rem 1.5rem;}
.sum-label{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:.4rem;}
.sum-val{font-family:var(--disp);font-size:1.6rem;font-weight:800;color:var(--ink);letter-spacing:-1px;line-height:1;}
.sum-val.teal{color:var(--teal);}
.sum-sub{font-size:12px;color:var(--muted);margin-top:4px;}
.plan-banner{background:var(--ink);border-radius:10px;padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem;}
.pb-label{font-family:var(--mono);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(245,242,235,.4);margin-bottom:.3rem;}
.pb-name{font-family:var(--disp);font-size:1.2rem;font-weight:800;color:var(--paper);}
.pb-detail{font-size:13px;color:rgba(245,242,235,.5);margin-top:2px;}
.pb-expires{font-family:var(--mono);font-size:11px;color:rgba(245,242,235,.4);text-align:right;}
.pb-expires strong{color:rgba(245,242,235,.8);display:block;font-size:13px;margin-top:2px;}
.btn-upgrade-sm{background:var(--teal);color:var(--paper);border:none;border-radius:6px;padding:9px 18px;font-size:13px;font-weight:600;font-family:var(--body);cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .2s;}
.btn-upgrade-sm:hover{background:var(--teal2);}

/* ════════════════════════════════════════════════════════════
   KYC
   ════════════════════════════════════════════════════════════ */
.sc-top{padding:1.25rem 1.5rem;display:flex;align-items:center;gap:14px;}
.sc-top.unverified{background:rgba(201,125,18,.07);border-bottom:1px solid rgba(201,125,18,.15);}
.sc-top.pending,.sc-top.approved{background:rgba(11,158,138,.07);border-bottom:1px solid rgba(11,158,138,.15);}
.sc-top.rejected{background:rgba(192,56,56,.07);border-bottom:1px solid rgba(192,56,56,.15);}
.sc-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.sc-icon.unverified{background:rgba(201,125,18,.15);}
.sc-icon.pending,.sc-icon.approved{background:rgba(11,158,138,.15);}
.sc-icon.rejected{background:rgba(192,56,56,.15);}
.sc-title{font-family:var(--disp);font-size:1.1rem;font-weight:700;}
.sc-title.unverified{color:var(--amber);}
.sc-title.pending,.sc-title.approved{color:var(--teal);}
.sc-title.rejected{color:var(--red);}
.sc-sub{font-size:13px;margin-top:2px;color:var(--muted);}
.sc-badge{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:1.5px;padding:4px 12px;border-radius:3px;flex-shrink:0;text-transform:uppercase;}
.sc-badge.unverified{background:rgba(201,125,18,.1);color:var(--amber);border:1px solid rgba(201,125,18,.2);}
.sc-badge.pending,.sc-badge.approved{background:rgba(11,158,138,.1);color:var(--teal);border:1px solid rgba(11,158,138,.2);}
.sc-badge.rejected{background:rgba(192,56,56,.1);color:var(--red);border:1px solid rgba(192,56,56,.2);}
.kyc-form{background:var(--paper);border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.kf-section{padding:1.5rem;border-bottom:1px solid var(--border);}
.kf-section:last-child{border-bottom:none;}
.kf-title{font-family:var(--disp);font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:1.1rem;display:flex;align-items:center;gap:8px;}
.step-num{width:22px;height:22px;background:var(--ink);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;color:var(--paper);flex-shrink:0;}
.doc-upload{border:1.5px dashed var(--border2);border-radius:7px;padding:1.25rem;text-align:center;cursor:pointer;transition:all .2s;position:relative;background:var(--cream);}
.doc-upload:hover{border-color:var(--teal);background:rgba(11,158,138,.03);}
.doc-upload input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.doc-upload.uploaded{border-color:var(--teal);background:rgba(11,158,138,.04);}
.du-icon{font-size:24px;margin-bottom:.5rem;}
.du-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:.2rem;}
.du-desc{font-size:12px;color:var(--muted);}
.du-preview{display:none;align-items:center;gap:8px;margin-top:.5rem;}
.du-preview.show{display:flex;}
.du-prev-icon{width:28px;height:28px;border-radius:4px;background:var(--teal);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--paper);flex-shrink:0;}
.du-prev-name{font-size:12px;color:var(--teal);font-family:var(--mono);flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.du-prev-size{font-size:11px;color:var(--muted2);font-family:var(--mono);}
.privacy-note{background:var(--cream);border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem;display:flex;gap:8px;font-size:12px;color:var(--muted);line-height:1.6;margin-top:1rem;}
.btn-submit{width:100%;background:var(--teal);color:var(--paper);border:none;border-radius:6px;padding:13px;font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;}
.btn-submit:hover:not(:disabled){background:var(--teal2);}
.btn-submit:disabled{opacity:.4;cursor:not-allowed;}
.alert{padding:.75rem 1rem;border-radius:6px;font-size:13px;margin-bottom:1rem;display:none;line-height:1.6;align-items:flex-start;gap:8px;}
.alert.show{display:flex;}
.alert.err{background:rgba(192,56,56,.07);border:1px solid rgba(192,56,56,.2);color:var(--red);}
.alert.ok{background:rgba(11,158,138,.07);border:1px solid rgba(11,158,138,.2);color:var(--teal);}
.pending-info{background:var(--cream);border:1px solid var(--border);border-radius:8px;padding:1.5rem;}
.pi-steps{display:flex;flex-direction:column;gap:1rem;margin-top:1rem;}
.pi-step{display:flex;gap:12px;align-items:flex-start;}
.pi-step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;flex-shrink:0;}
.pi-step-num.done{background:var(--teal);color:var(--paper);}
.pi-step-num.active{background:rgba(201,125,18,.15);color:var(--amber);border:1px solid rgba(201,125,18,.3);}
.pi-step-num.wait{background:var(--cream2);color:var(--muted2);}
.pi-step-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:2px;}
.pi-step-desc{font-size:12px;color:var(--muted);}
.approved-card{background:rgba(11,158,138,.05);border:1px solid rgba(11,158,138,.2);border-radius:8px;padding:1.5rem;text-align:center;}
.approved-icon{width:60px;height:60px;border-radius:50%;background:rgba(11,158,138,.15);display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 1rem;}
.approved-title{font-family:var(--disp);font-size:1.2rem;font-weight:800;color:var(--teal);margin-bottom:.5rem;}
.approved-desc{font-size:13px;color:var(--muted);line-height:1.7;}
.approved-fields{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1.25rem;text-align:left;}
.af{background:var(--paper);border-radius:6px;padding:.7rem .9rem;}
.af-key{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:2px;}
.af-val{font-size:13px;font-weight:500;color:var(--ink);}

/* ════════════════════════════════════════════════════════════
   PROFILE & API KEY
   ════════════════════════════════════════════════════════════ */
.api-box{background:var(--cream);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;display:flex;align-items:center;gap:12px;margin-bottom:1rem;}
.api-key-hidden{font-family:var(--mono);font-size:18px;color:var(--muted);letter-spacing:4px;flex:1;overflow:hidden;min-width:0;}
.api-key-text{font-family:var(--mono);font-size:13px;color:var(--ink);letter-spacing:.5px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:none;}
.api-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:var(--paper);color:var(--ink);font-family:var(--body);transition:all .2s;white-space:nowrap;}
.api-btn:hover{background:var(--cream2);}
.api-btn.teal{background:var(--teal);color:var(--paper);border-color:var(--teal);}
.api-btn.teal:hover{background:var(--teal2);}
.api-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.25rem;}
.api-stats{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;}
.api-stat{background:var(--cream);border:1px solid var(--border);border-radius:6px;padding:.65rem 1rem;}
.api-stat-val{font-family:var(--disp);font-size:1.2rem;font-weight:700;color:var(--ink);}
.api-stat-lbl{font-size:11px;color:var(--muted);}
.kyc-warning{background:rgba(201,125,18,.06);border:1px solid rgba(201,125,18,.2);border-radius:8px;padding:1rem 1.25rem;display:flex;gap:12px;align-items:flex-start;margin-bottom:1.5rem;}
.kw-icon{font-size:18px;flex-shrink:0;margin-top:1px;}
.kw-text{font-size:13px;color:var(--amber);line-height:1.6;}
.kw-btn{display:inline-block;margin-top:.5rem;font-size:12px;color:var(--amber);font-weight:500;text-decoration:none;border:1px solid rgba(201,125,18,.3);border-radius:4px;padding:5px 12px;}
.usage-table{width:100%;border-collapse:collapse;font-size:13px;}
.usage-table th{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--border);}
.usage-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border);color:var(--ink);}
.usage-table tr:last-child td{border-bottom:none;}
.usage-table td.mono{font-family:var(--mono);font-size:12px;color:var(--muted);}
.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:5px;font-size:14px;font-weight:500;cursor:pointer;background:var(--ink);color:var(--paper);border:none;font-family:var(--body);transition:background .2s;}
.btn-primary:hover{background:#1a2035;}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;}
.form-label{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:.4rem;display:block;}
.form-input{width:100%;padding:.65rem .9rem;border:1px solid var(--border2);border-radius:6px;font-size:14px;font-family:var(--body);background:var(--paper);color:var(--ink);transition:border-color .2s;outline:none;}
.form-input:focus{border-color:var(--teal);}

/* ════════════════════════════════════════════════════════════
   UPGRADE / PLANS
   ════════════════════════════════════════════════════════════ */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2rem;}
.plan-card{background:var(--paper);border:2px solid var(--border);border-radius:12px;padding:1.5rem;position:relative;transition:all .2s;}
.plan-card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:0 8px 24px rgba(12,15,26,.08);}
.plan-card.active{border-color:var(--teal);background:rgba(11,158,138,.03);}
.plan-card.featured{border-color:var(--ink);background:var(--ink);}
.plan-card.featured .plan-name,.plan-card.featured .plan-price,.plan-card.featured .plan-period,.plan-card.featured .plan-feat{color:var(--paper);}
.plan-card.featured .plan-per{color:rgba(245,242,235,.6);}
.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--teal);color:var(--paper);font-family:var(--mono);font-size:10px;letter-spacing:1.5px;padding:3px 12px;border-radius:20px;white-space:nowrap;}
.plan-name{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);margin-bottom:.5rem;}
.plan-price{font-family:var(--disp);font-size:2rem;font-weight:800;color:var(--ink);line-height:1;}
.plan-period{font-size:13px;color:var(--muted);margin-bottom:.25rem;}
.plan-per{font-size:12px;color:var(--teal);font-family:var(--mono);margin-bottom:1rem;}
.plan-divider{height:1px;background:var(--border);margin:1rem 0;}
.plan-card.featured .plan-divider{background:rgba(245,242,235,.15);}
.plan-feat{font-size:13px;color:var(--muted);margin-bottom:.4rem;display:flex;align-items:center;gap:6px;}
.plan-feat .pf-check{color:var(--teal);font-weight:700;}
.btn-upgrade{width:100%;border:none;border-radius:6px;padding:12px;font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;transition:all .2s;margin-top:1.25rem;}
.btn-upgrade.ink{background:var(--ink);color:var(--paper);}
.btn-upgrade.ink:hover{background:#1a1f35;}
.btn-upgrade.teal{background:var(--teal);color:var(--paper);}
.btn-upgrade.teal:hover{background:var(--teal2);}
.btn-upgrade.white{background:var(--paper);color:var(--ink);}
.btn-upgrade.white:hover{background:var(--cream);}
.btn-upgrade:disabled{opacity:.5;cursor:not-allowed;}
.current-plan-card{background:var(--cream);border:1px solid var(--border);border-radius:10px;padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;margin-bottom:2rem;}
.cp-icon{width:44px;height:44px;border-radius:50%;background:var(--ink);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.cp-name{font-family:var(--disp);font-size:1rem;font-weight:700;color:var(--ink);}
.cp-detail{font-size:13px;color:var(--muted);margin-top:2px;}
.cp-expires{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--muted2);text-align:right;}
.payment-modal{display:none;position:fixed;inset:0;background:rgba(12,15,26,.5);backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center;}
.payment-modal.show{display:flex;}
.pm-box{background:var(--paper);border-radius:12px;padding:2rem;max-width:420px;width:90%;text-align:center;}
.pm-title{font-family:var(--disp);font-size:1.2rem;font-weight:800;color:var(--ink);margin-bottom:.5rem;}
.pm-desc{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:1.5rem;}
.pm-amount{font-family:var(--disp);font-size:1.8rem;font-weight:800;color:var(--teal);margin-bottom:.25rem;}
.pm-plan-label{font-family:var(--mono);font-size:11px;color:var(--muted2);letter-spacing:1px;text-transform:uppercase;margin-bottom:1.5rem;}
.pm-btn{width:100%;border:none;border-radius:6px;padding:13px;font-size:14px;font-weight:600;font-family:var(--body);cursor:pointer;background:var(--teal);color:var(--paper);transition:all .2s;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;gap:8px;}
.pm-btn:hover{background:var(--teal2);}
.pm-btn:disabled{opacity:.5;cursor:not-allowed;}
.pm-cancel{font-size:13px;color:var(--muted);cursor:pointer;background:none;border:none;font-family:var(--body);}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════ */
@media(max-width:768px){
  .layout{grid-template-columns:1fr;}
  .sidebar{display:none;}
  .main{padding:1.25rem;}
  .stats-grid,.status-grid,.quick-actions,.summary-grid,.plan-grid{grid-template-columns:1fr;}
  .welcome-card{flex-direction:column;}
  .stats-mini{flex-wrap:wrap;}
  .toolbar{flex-direction:column;align-items:flex-start;}
  .search-wrap{max-width:100%;width:100%;}
  .form-grid,.rr-grid,.rc-grid,.approved-fields{grid-template-columns:1fr;}
  .plan-banner{flex-direction:column;align-items:flex-start;}
}

/* ── Plan quota box (upgrade.html) ───────────────────────────── */
.plan-quota-box{background:rgba(11,158,138,.07);border:1px solid rgba(11,158,138,.18);border-radius:6px;padding:8px 12px;margin-bottom:1rem;font-family:var(--mono);font-size:1.3rem;font-weight:700;color:var(--teal);line-height:1;}
.plan-quota-box span{font-size:11px;color:var(--muted);display:block;margin-top:2px;font-weight:400;}
.plan-card.featured .plan-quota-box{background:rgba(11,158,138,.15);border-color:rgba(11,158,138,.3);}
