/* ══════════════════════════════════════════════
   TOKENS & RESET
══════════════════════════════════════════════ */
:root {
  --bg:          #1e2329;
  --bg-2:        #252b35;
  --bg-3:        #2d3441;
  --bg-4:        #343c4a;
  --border:      rgba(212,175,127,0.12);
  --border-hi:   rgba(212,175,127,0.35);
  --gold:        #d4af7f;
  --gold-hi:     #e8c99a;
  --gold-dim:    rgba(212,175,127,0.14);
  --gold-glow:   rgba(212,175,127,0.25);
  --text-1:      #e8e8e8;
  --text-2:      #9ca3af;
  --text-3:      #6b7280;
  --success:     #10b981;
  --success-dim: rgba(16,185,129,0.12);
  --danger:      #ef4444;
  --danger-dim:  rgba(239,68,68,0.12);
  --warning:     #f59e0b;
  --warning-dim: rgba(245,158,11,0.12);
  --font:        'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:        'Consolas','Monaco','Courier New',monospace;
  --r-xs:        4px;
  --r-sm:        8px;
  --r-md:        12px;
  --r-lg:        16px;
  --r-xl:        20px;
  --sidebar-w:   260px;
  --tr:          all 0.18s ease;
}

*  { box-sizing:border-box; margin:0; padding:0; }
html,body { height:100%; overflow:hidden; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text-1);
  font-size: 15px;
  line-height: 1.6;
}
a { color: var(--gold); text-decoration: none; }
a:hover { color: var(--gold-hi); }
.hidden { display:none !important; }
code {
  font-family: var(--mono);
  font-size: 0.82rem;
  background: var(--bg-3);
  padding: 0.15rem 0.4rem;
  border-radius: var(--r-xs);
  color: var(--gold);
}

/* ══════════════════════════════════════════════
   SCROLLBAR
══════════════════════════════════════════════ */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--bg-4); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--text-3); }

/* ══════════════════════════════════════════════
   DECORATIVE BLOBS
══════════════════════════════════════════════ */
.blob {
  position: fixed;
  border-radius: 50%;
  filter: blur(130px);
  pointer-events: none;
  z-index: 0;
  opacity: 0.07;
}
.blob-1 { width:700px;height:700px;background:#d4af7f;top:-250px;right:-150px; }
.blob-2 { width:600px;height:600px;background:#6366f1;bottom:-200px;left:-150px; }

/* ══════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  padding: 0.6rem 1.3rem;
  font-family: var(--font);
  font-size: 0.88rem;
  font-weight: 600;
  border-radius: var(--r-sm);
  cursor: pointer;
  border: none;
  transition: var(--tr);
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.btn-gold {
  background: linear-gradient(135deg, #d4af7f 0%, #b8924a 100%);
  color: #1e2329;
}
.btn-gold:hover {
  background: linear-gradient(135deg, #e8c99a 0%, #d4af7f 100%);
  box-shadow: 0 4px 20px var(--gold-glow);
  transform: translateY(-1px);
}
.btn-outline {
  background: transparent;
  color: var(--text-1);
  border: 1px solid var(--border);
}
.btn-outline:hover { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.btn-ghost {
  background: transparent;
  color: var(--text-2);
  border: 1px solid transparent;
}
.btn-ghost:hover { background: var(--bg-3); color: var(--text-1); }
.btn-danger {
  background: transparent;
  color: var(--danger);
  border: 1px solid rgba(239,68,68,0.3);
}
.btn-danger:hover { background: var(--danger-dim); }
.btn-sm { padding:0.4rem 0.85rem; font-size:0.8rem; }
.btn-full { width:100%; }
.btn:disabled { opacity:0.4; cursor:not-allowed; transform:none !important; box-shadow:none !important; }
.btn-icon {
  background: var(--bg-3);
  border: 1px solid var(--border);
  color: var(--text-2);
  padding: 0.35rem 0.65rem;
  font-size: 0.75rem;
  border-radius: var(--r-xs);
  cursor: pointer;
  transition: var(--tr);
}
.btn-icon:hover { color: var(--gold); border-color: var(--border-hi); }

/* ══════════════════════════════════════════════
   FORMS
══════════════════════════════════════════════ */
.field { display:flex; flex-direction:column; gap:0.4rem; margin-bottom:1.1rem; }
.field label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-2);
  letter-spacing: 0.02em;
}
.field input,.field textarea,.field select {
  background: var(--bg-3);
  border: 1px solid var(--border);
  color: var(--text-1);
  font-family: var(--font);
  font-size: 0.9rem;
  padding: 0.65rem 0.95rem;
  border-radius: var(--r-sm);
  transition: var(--tr);
  width: 100%;
}
.field input:focus,.field textarea:focus,.field select:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px var(--gold-dim);
}
.field input::placeholder { color: var(--text-3); }
.field .hint { font-size:0.78rem; color:var(--text-3); }
.form-error {
  color: var(--danger);
  font-size: 0.83rem;
  padding: 0.6rem 0.9rem;
  background: var(--danger-dim);
  border: 1px solid rgba(239,68,68,0.25);
  border-radius: var(--r-sm);
  margin-top: 0.5rem;
}
.form-ok {
  color: var(--success);
  font-size: 0.83rem;
  padding: 0.6rem 0.9rem;
  background: var(--success-dim);
  border: 1px solid rgba(16,185,129,0.25);
  border-radius: var(--r-sm);
  margin-top: 0.5rem;
}

/* ══════════════════════════════════════════════
   AUTH SCREEN
══════════════════════════════════════════════ */
.auth-screen {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  overflow: auto;
  position: relative;
}
.auth-card {
  position: relative;
  z-index: 1;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 2.75rem;
  width: 100%;
  max-width: 440px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5), 0 0 0 1px rgba(212,175,127,0.06);
}
.auth-brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.4rem;
}
.brand-logo {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0 0 14px var(--gold-glow);
}
.brand-name {
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: -0.5px;
  background: linear-gradient(135deg, #d4af7f, #e8c99a);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.auth-tagline { font-size:0.85rem; color:var(--text-3); margin-bottom:2rem; }
.auth-tabs {
  display: flex;
  gap: 0.25rem;
  background: var(--bg-3);
  border-radius: var(--r-sm);
  padding: 0.25rem;
  margin-bottom: 1.75rem;
}
.auth-tab {
  flex: 1;
  background: none;
  border: none;
  color: var(--text-2);
  font-family: var(--font);
  font-size: 0.88rem;
  font-weight: 600;
  padding: 0.55rem;
  border-radius: 6px;
  cursor: pointer;
  transition: var(--tr);
}
.auth-tab.active { background:var(--bg-2); color:var(--gold); box-shadow:0 1px 4px rgba(0,0,0,0.3); }
.auth-form { display:none; }
.auth-form.active { display:block; }
.auth-divider { text-align:center; font-size:0.78rem; color:var(--text-3); margin:1.25rem 0; }

/* ══════════════════════════════════════════════
   MNEMONIC SCREEN
══════════════════════════════════════════════ */
.mnemonic-screen {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  overflow: auto;
  position: relative;
  background: var(--bg);
}
.mnemonic-card {
  position: relative;
  z-index: 1;
  background: var(--bg-2);
  border: 1px solid var(--border-hi);
  border-radius: var(--r-xl);
  padding: 2.5rem;
  max-width: 580px;
  width: 100%;
  text-align: center;
  box-shadow: 0 0 60px var(--gold-dim);
}
.mnemonic-card h1 { font-size:1.5rem; font-weight:700; margin-bottom:0.6rem; }
.mnemonic-subtitle { font-size:0.88rem; color:var(--text-2); margin-bottom:2rem; line-height:1.7; }
.mnemonic-subtitle strong { color:var(--gold); }
.mnemonic-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.6rem;
  margin-bottom: 1.75rem;
  text-align: left;
}
.mword {
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 0.55rem 0.7rem;
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.mword-num { font-size:0.7rem; color:var(--text-3); min-width:1.4ch; }
.mword-val { font-size:0.85rem; font-weight:600; color:var(--gold-hi); font-family:var(--mono); }
.mnemonic-alert {
  display: flex;
  gap: 0.75rem;
  background: var(--warning-dim);
  border: 1px solid rgba(245,158,11,0.3);
  border-radius: var(--r-sm);
  padding: 0.9rem 1rem;
  text-align: left;
  margin-bottom: 1.5rem;
  font-size: 0.83rem;
  color: var(--warning);
  line-height: 1.5;
}
.confirm-check {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.88rem;
  margin-bottom: 1.25rem;
  cursor: pointer;
  justify-content: center;
  color: var(--text-2);
}
.confirm-check input { accent-color:var(--gold); width:16px; height:16px; }

/* ══════════════════════════════════════════════
   DASHBOARD LAYOUT
══════════════════════════════════════════════ */
.dashboard { display:grid; grid-template-columns:var(--sidebar-w) 1fr; height:100vh; overflow:hidden; }

/* SIDEBAR */
.sidebar {
  background: var(--bg-2);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 1.5rem 1rem;
  overflow-y: auto;
  height: 100vh;
}
.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 2rem;
  padding: 0 0.25rem;
}
.sidebar-brand img { width:34px; height:34px; border-radius:50%; box-shadow:0 0 10px var(--gold-glow); }
.sidebar-brand-name { font-size:1.3rem; font-weight:800; letter-spacing:-0.3px;
  background:linear-gradient(135deg,#d4af7f,#e8c99a);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* Business switcher */
.biz-switcher { margin-bottom:1.5rem; position:relative; }
.biz-label { font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.9px; color:var(--text-3); margin-bottom:0.4rem; }
.biz-current {
  display: flex; justify-content:space-between; align-items:center;
  background: var(--bg-3); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:0.6rem 0.9rem;
  cursor:pointer; font-size:0.88rem; font-weight:600;
  transition:var(--tr);
}
.biz-current:hover { border-color:var(--gold); }
.biz-arrow { color:var(--text-3); font-size:0.7rem; transition:var(--tr); }
.biz-current.open .biz-arrow { transform:rotate(180deg); color:var(--gold); }
.biz-dropdown {
  position:absolute; top:calc(100% + 4px); left:0; right:0;
  background:var(--bg-3); border:1px solid var(--border);
  border-radius:var(--r-sm); z-index:50;
  box-shadow:0 8px 30px rgba(0,0,0,0.4);
  overflow:hidden;
}
.biz-dd-item {
  padding:0.7rem 1rem; font-size:0.88rem; cursor:pointer;
  transition:var(--tr); font-weight:500;
  display:flex; align-items:center; gap:0.5rem;
}
.biz-dd-item:hover { background:var(--bg-4); }
.biz-dd-item.active { color:var(--gold); }
.biz-dd-item .dot { width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0; }
.biz-dd-add {
  width:100%; background:none; border:none; border-top:1px solid var(--border);
  color:var(--gold); font-family:var(--font); font-size:0.85rem; font-weight:600;
  padding:0.65rem 1rem; cursor:pointer; text-align:left; transition:var(--tr);
}
.biz-dd-add:hover { background:var(--gold-dim); }

/* Nav */
.sidebar-nav { display:flex; flex-direction:column; gap:0.15rem; flex:1; }
.nav-section-label {
  font-size:0.68rem; font-weight:700; text-transform:uppercase;
  letter-spacing:0.9px; color:var(--text-3);
  padding:0.75rem 0.85rem 0.35rem;
}
.nav-item {
  display:flex; align-items:center; gap:0.65rem;
  padding:0.6rem 0.85rem; border-radius:var(--r-sm);
  cursor:pointer; font-size:0.88rem; font-weight:500;
  color:var(--text-2); text-decoration:none;
  transition:var(--tr); border:1px solid transparent;
}
.nav-item:hover { color:var(--text-1); background:var(--bg-3); }
.nav-item.active { color:var(--gold); background:var(--gold-dim); border-color:var(--border-hi); }
.nav-icon { font-size:0.95rem; width:1.1rem; text-align:center; flex-shrink:0; }
.nav-badge {
  margin-left:auto; background:var(--gold); color:var(--bg);
  font-size:0.65rem; font-weight:800; padding:0.1rem 0.45rem;
  border-radius:20px;
}

/* Sidebar footer */
.sidebar-footer { border-top:1px solid var(--border); padding-top:1rem; margin-top:auto; }
.sidebar-user { display:flex; align-items:center; gap:0.75rem; margin-bottom:0.6rem; }
.user-av {
  width:36px; height:36px; border-radius:50%;
  background:linear-gradient(135deg,#d4af7f,#b8924a);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:0.9rem; color:#1e2329; flex-shrink:0;
}
.user-meta { display:flex; flex-direction:column; overflow:hidden; }
.user-name { font-size:0.88rem; font-weight:600; }
.user-email { font-size:0.73rem; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* MAIN CONTENT */
.dash-main { overflow-y:auto; height:100vh; background:var(--bg); }

/* Views */
.view { display:none; padding:2.5rem 2.75rem; max-width:1100px; }
.view.active { display:block; }
.view-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:2rem; }
.view-title { font-size:1.45rem; font-weight:700; letter-spacing:-0.3px; margin-bottom:0.25rem; }
.view-sub { font-size:0.85rem; color:var(--text-2); }

/* Empty state */
.empty-state { text-align:center; padding:5rem 2rem; }
.empty-ico { font-size:3.5rem; margin-bottom:1rem; filter:grayscale(0.2); }
.empty-state h2 { font-size:1.2rem; font-weight:700; margin-bottom:0.5rem; }
.empty-state p { font-size:0.88rem; color:var(--text-2); margin-bottom:1.5rem; max-width:400px; margin-left:auto; margin-right:auto; }

/* ── Stats ── */
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:1.5rem; }
@media(max-width:1000px){ .stats-row{ grid-template-columns:repeat(2,1fr); } }
.stat-card {
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:var(--r-md); padding:1.25rem 1.5rem;
  display:flex; flex-direction:column; gap:0.35rem;
  transition:var(--tr);
}
.stat-card:hover { border-color:var(--border-hi); }
.stat-label { font-size:0.73rem; text-transform:uppercase; letter-spacing:0.8px; color:var(--text-3); font-weight:700; }
.stat-val { font-size:1.55rem; font-weight:700; }
.stat-sub { font-size:0.78rem; color:var(--text-3); }
.stat-val.gold { color:var(--gold); }

/* ── Keys Card ── */
.keys-card {
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:var(--r-md); padding:1.5rem; margin-bottom:1.5rem;
}
.keys-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:1.25rem; }
.keys-card-header h3 { font-size:0.95rem; font-weight:700; }
.key-row {
  display:flex; align-items:center; gap:0.85rem;
  padding:0.85rem 0; border-bottom:1px solid var(--border);
}
.key-row:last-child { border:none; }
.key-label { font-size:0.78rem; font-weight:600; color:var(--text-2); width:140px; flex-shrink:0; }
.key-val {
  font-family:var(--mono); font-size:0.8rem; background:var(--bg-3);
  padding:0.35rem 0.7rem; border-radius:var(--r-xs);
  color:var(--gold); overflow:hidden; text-overflow:ellipsis;
  white-space:nowrap; flex:1;
}
.key-val.masked { color:var(--text-3); letter-spacing:3px; }
.key-actions { display:flex; gap:0.4rem; align-items:center; }

/* ── Info box ── */
.info-box {
  background:var(--gold-dim); border:1px solid var(--border-hi);
  border-radius:var(--r-md); padding:1.1rem 1.25rem;
  margin-bottom:1.5rem;
}
.info-box-head { display:flex; align-items:center; gap:0.5rem; font-size:0.88rem; font-weight:700; color:var(--gold); margin-bottom:0.5rem; }
.info-box p { font-size:0.83rem; color:var(--text-2); line-height:1.6; }
.info-box ul { padding-left:1.1rem; margin-top:0.4rem; }
.info-box li { font-size:0.83rem; color:var(--text-2); margin-bottom:0.25rem; }
.info-box code { background:rgba(212,175,127,0.15); color:var(--gold-hi); }

/* ── Faucet ── */
.faucet-card {
  background:var(--success-dim); border:1px solid rgba(16,185,129,0.25);
  border-radius:var(--r-md); padding:1.25rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.faucet-card-text h3 { font-size:0.9rem; font-weight:700; color:var(--success); margin-bottom:0.25rem; }
.faucet-card-text p { font-size:0.82rem; color:var(--text-2); }

/* ── Transactions Table ── */
.tbl-wrap { background:var(--bg-2); border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; }
.tbl { width:100%; border-collapse:collapse; }
.tbl th {
  background:var(--bg-3); padding:0.8rem 1.1rem;
  text-align:left; font-size:0.73rem; font-weight:700;
  text-transform:uppercase; letter-spacing:0.5px;
  color:var(--text-3); border-bottom:1px solid var(--border);
}
.tbl td { padding:0.9rem 1.1rem; font-size:0.87rem; border-bottom:1px solid rgba(48,54,65,0.5); }
.tbl tr:last-child td { border:none; }
.tbl tr:hover td { background:rgba(255,255,255,0.015); }
.tbl-empty { text-align:center; color:var(--text-3); padding:3rem 1rem !important; }
.amt-in  { color:var(--success); font-weight:700; }
.amt-out { color:var(--danger); font-weight:700; }
.pill {
  display:inline-flex; align-items:center; gap:0.3rem;
  padding:0.2rem 0.6rem; border-radius:20px;
  font-size:0.73rem; font-weight:700;
}
.pill-success { background:var(--success-dim); color:var(--success); }
.pill-gold    { background:var(--gold-dim); color:var(--gold); }
.pill-warn    { background:var(--warning-dim); color:var(--warning); }

/* ══════════════════════════════════════════════
   SETTINGS PAGE
══════════════════════════════════════════════ */
.settings-layout { display:grid; grid-template-columns:200px 1fr; gap:2rem; }
.settings-sidebar { display:flex; flex-direction:column; gap:0.15rem; }
.set-nav-item {
  padding:0.6rem 0.85rem; border-radius:var(--r-sm);
  font-size:0.88rem; font-weight:500; color:var(--text-2);
  cursor:pointer; transition:var(--tr); border:1px solid transparent;
  display:flex; align-items:center; gap:0.5rem;
}
.set-nav-item:hover { color:var(--text-1); background:var(--bg-2); }
.set-nav-item.active { color:var(--gold); background:var(--gold-dim); border-color:var(--border-hi); }
.settings-panel { display:none; }
.settings-panel.active { display:block; }
.settings-section {
  background:var(--bg-2); border:1px solid var(--border);
  border-radius:var(--r-md); padding:1.75rem;
  margin-bottom:1.25rem;
}
.settings-section-head { margin-bottom:1.5rem; }
.settings-section-head h3 { font-size:1rem; font-weight:700; margin-bottom:0.3rem; }
.settings-section-head p { font-size:0.83rem; color:var(--text-2); }
.settings-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.settings-footer { display:flex; align-items:center; justify-content:space-between; padding-top:1.25rem; border-top:1px solid var(--border); margin-top:0.5rem; }
.settings-footer-note { font-size:0.78rem; color:var(--text-3); }

/* API key display row inside settings */
.api-key-display {
  background:var(--bg-3); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:1rem 1.25rem;
  margin-bottom:1rem;
}
.api-key-display-label { font-size:0.73rem; font-weight:700; text-transform:uppercase; letter-spacing:0.7px; color:var(--text-3); margin-bottom:0.5rem; }
.api-key-display-row { display:flex; align-items:center; gap:0.75rem; }
.api-key-display-val {
  flex:1; font-family:var(--mono); font-size:0.82rem;
  background:var(--bg-4); border:1px solid var(--border);
  border-radius:var(--r-xs); padding:0.5rem 0.75rem;
  color:var(--gold); overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.api-key-display-val.masked { color:var(--text-3); letter-spacing:3px; font-size:0.9rem; }

/* Webhook test badge */
.webhook-status { display:inline-flex; align-items:center; gap:0.4rem; font-size:0.8rem; }
.dot-live { width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 6px var(--success);animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:0.4} }

/* ══════════════════════════════════════════════
   MODALS
══════════════════════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0;
  background:rgba(30,35,41,0.88);
  backdrop-filter:blur(10px);
  z-index:200;
  display:flex; align-items:center; justify-content:center;
  padding:1rem;
}
.modal-card {
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:2rem;
  width:100%; max-width:500px;
  position:relative;
  box-shadow:0 20px 60px rgba(0,0,0,0.6), 0 0 0 1px var(--border);
  animation:slideUp 0.22s ease;
  max-height:90vh; overflow-y:auto;
}
@keyframes slideUp { from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1} }
.modal-close {
  position:absolute; top:1rem; right:1rem;
  background:var(--bg-3); border:1px solid var(--border);
  color:var(--text-2); font-size:1rem; width:28px; height:28px;
  border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:var(--tr);
}
.modal-close:hover { color:var(--danger); border-color:rgba(239,68,68,0.4); }
.modal-head { margin-bottom:1.5rem; }
.modal-head h2 { font-size:1.15rem; font-weight:700; margin-bottom:0.3rem; }
.modal-head p { font-size:0.83rem; color:var(--text-2); }

/* ── Checkout Modal ── */
.checkout-card { max-width:440px; }
.co-brand {
  display:flex; align-items:center; gap:0.5rem;
  font-size:0.72rem; font-weight:700; color:var(--gold);
  text-transform:uppercase; letter-spacing:0.6px;
  margin-bottom:0.6rem;
}
.co-brand img { width:20px; height:20px; border-radius:50%; }
.co-amount {
  background:var(--bg-3); border:1px solid var(--border-hi);
  border-radius:var(--r-md); padding:1.25rem;
  text-align:center; margin-bottom:1rem;
}
.co-amount-label { font-size:0.75rem; color:var(--text-2); margin-bottom:0.25rem; }
.co-amount-val { font-size:2.25rem; font-weight:800; color:var(--gold); line-height:1; }
.co-amount-val span { font-size:1rem; font-weight:600; }
.co-meta { font-size:0.8rem; color:var(--text-2); margin-bottom:1.25rem; }
.co-meta strong { color:var(--text-1); }
.co-wallet-row {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--bg-3); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:0.7rem 1rem; margin-bottom:1rem;
  font-size:0.82rem;
}
.co-wallet-row code { background:none; padding:0; color:var(--gold-hi); font-size:0.78rem; }
.co-wallet-bal { color:var(--success); font-weight:700; white-space:nowrap; }
.co-divider { display:flex;align-items:center;gap:0.6rem;color:var(--text-3);font-size:0.73rem;margin:1rem 0; }
.co-divider::before,.co-divider::after { content:'';flex:1;height:1px;background:var(--border); }
.co-manual-row { display:flex; gap:0.5rem; }
.co-manual-row input {
  flex:1; background:var(--bg-3); border:1px solid var(--border);
  color:var(--text-1); font-family:var(--mono);
  padding:0.6rem 0.85rem; border-radius:var(--r-sm); font-size:0.82rem;
}
.co-manual-row input:focus { outline:none; border-color:var(--gold); }
.co-status {
  display:flex; align-items:center; gap:0.85rem;
  background:var(--bg-3); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:0.85rem 1rem;
  font-size:0.85rem; margin-top:1rem;
}
.co-status.ok { background:var(--success-dim); border-color:rgba(16,185,129,0.3); color:var(--success); }
.co-status.err { background:var(--danger-dim); border-color:rgba(239,68,68,0.3); color:var(--danger); }

/* Spinner */
.spin { width:18px;height:18px;border:2px solid rgba(212,175,127,0.2);border-top-color:var(--gold);border-radius:50%;animation:spinr 0.75s linear infinite;flex-shrink:0; }
@keyframes spinr { to{transform:rotate(360deg)} }

/* ── Sign out btn ── */
.btn-signout {
  width:100%; background:none;
  border:1px solid var(--border); color:var(--text-3);
  font-size:0.8rem; padding:0.45rem;
  border-radius:var(--r-sm); cursor:pointer; transition:var(--tr);
  font-family:var(--font);
}
.btn-signout:hover { color:var(--danger); border-color:rgba(239,68,68,0.4); }

/* Separator */
.sep { height:1px; background:var(--border); margin:1.5rem 0; }

/* ══════════════════════════════════════════════
   RESPONSIVE DESIGN (Mobiles & Tablets - Drawer Sidebar)
══════════════════════════════════════════════ */
.mobile-header { display: none; }
.drawer-overlay { display: none; }

@media (max-width: 860px) {
  html, body { overflow: hidden; height: 100vh; }
  
  .dashboard { display: flex; flex-direction: column; height: 100vh; overflow: hidden; }
  
  /* Mobile Header */
  .mobile-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0.8rem 1.25rem; background: var(--bg-2); border-bottom: 1px solid var(--border);
    z-index: 50; flex-shrink: 0;
  }
  .mobile-brand { display: flex; align-items: center; gap: 0.6rem; font-weight: 800; font-size: 1.25rem; background: linear-gradient(135deg, #d4af7f, #e8c99a); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
  .mobile-brand img { width: 30px; height: 30px; border-radius: 50%; box-shadow: 0 0 8px var(--gold-glow); }
  .btn-hamburger { background: none; border: none; color: var(--gold); cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0.2rem; }
  
  /* Drawer Overlay */
  .drawer-overlay {
    display: block; position: fixed; inset: 0; background: rgba(30,35,41,0.7); backdrop-filter: blur(4px);
    z-index: 150; opacity: 0; pointer-events: none; transition: opacity 0.3s ease;
  }
  .drawer-overlay.open { opacity: 1; pointer-events: auto; }
  
  /* Sidebar as Drawer */
  .sidebar {
    position: fixed; top: 0; bottom: 0; left: 0; width: 280px; max-width: 85vw;
    height: 100vh; z-index: 200; background: var(--bg-2); border-right: 1px solid var(--border);
    transform: translateX(-100%); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex; flex-direction: column; padding: 1.5rem 1rem; overflow-y: auto;
  }
  .sidebar.open { transform: translateX(0); box-shadow: 10px 0 30px rgba(0,0,0,0.5); }
  .sidebar-brand { display: flex; margin-bottom: 2rem; justify-content: flex-start; }
  .biz-switcher { width: 100%; margin-bottom: 1.5rem; }
  .sidebar-nav { display: flex; flex-direction: column; overflow-x: hidden; padding-bottom: 0; gap: 0.15rem; border-bottom: none; margin-bottom: 0; }
  .nav-section-label { display: block; padding: 0.75rem 0.85rem 0.35rem; }
  .nav-item { white-space: normal; padding: 0.6rem 0.85rem; font-size: 0.88rem; flex-direction: row; gap: 0.65rem; }
  .sidebar-footer { display: block; border-top: 1px solid var(--border); padding-top: 1rem; margin-top: auto; }
  .sidebar-user { display: flex; }
  .btn-signout { width: 100%; margin-top: 0.6rem; padding: 0.6rem; }
  
  /* Main Content Area */
  .dash-main { flex: 1; width: 100%; overflow-y: auto; position: relative; z-index: 10; padding-bottom: 2rem; }
  .view { padding: 1.5rem; width: 100%; box-sizing: border-box; }
  
  /* Fix settings layout */
  .settings-layout { display: flex; flex-direction: column; gap: 1rem; }
  .settings-sidebar { flex-direction: row; overflow-x: auto; padding-bottom: 0.5rem; }
  .set-nav-item { white-space: nowrap; }
  .settings-row { grid-template-columns: 1fr; }
  
  /* Grids and Tables */
  .stats-row { grid-template-columns: 1fr; }
  .tbl-wrap { overflow-x: auto; width: 100%; }
  
  /* Modals and Auth */
  .auth-card, .mnemonic-card, .modal-card { padding: 1.5rem; margin: 1rem auto; width: 90%; }
  .mnemonic-grid { grid-template-columns: repeat(2, 1fr); }
  
  /* Fix cropped text and long strings */
  .key-row { flex-direction: column; align-items: flex-start; gap: 0.5rem; }
  .key-val { width: 100%; box-sizing: border-box; }
  .api-key-display-row { flex-direction: column; align-items: flex-start; gap: 0.5rem; }
  .api-key-display-val { width: 100%; box-sizing: border-box; }
}

/* ══════════════════════════════════════════════
   MOBILE MODE (Phones)
══════════════════════════════════════════════ */
@media (max-width: 480px) {
  .view { padding: 1rem; }
  .sidebar { padding: 1rem; }
  
  .auth-card, .mnemonic-card, .modal-card { padding: 1.25rem; width: 95%; margin: 0.5rem auto; border-radius: var(--r-md); }
  
  .stat-card { padding: 1rem; }
  .stat-val { font-size: 1.4rem; }
  
  .keys-card { padding: 1rem; }
  .settings-section { padding: 1rem; }
  
  .view-header { flex-direction: column; gap: 1rem; align-items: flex-start; }
  .view-header .btn { width: 100%; }
  
  .co-amount-val { font-size: 1.8rem; }
  .co-wallet-row { flex-direction: column; align-items: flex-start; gap: 0.5rem; }
  
  .faucet-card { flex-direction: column; align-items: flex-start; gap: 1rem; }
  #btn-faucet { width: 100%; }
}
