:root{
  --primary:#4361ee;
  --bank:#9b59b6;
  --success:#2ecc71;
  --danger:#e74c3c;
  --warning:#f39c12;

  --bg:#f4f7fe;
  --card:#ffffff;
  --text:#2d3436;
  --muted:#8492a6;
  --line:#eef2f7;

  /* backward-compat (was referenced in some places) */
  --dark: var(--text);

  --radius:12px;
}

/* ========== Base / Reset ========== */
*{ box-sizing:border-box; font-family:'Cairo',sans-serif; }
html,body{ height:100%; }
body{
  margin:0;
  min-height:100vh;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  -webkit-text-size-adjust:100%;
}

img{ max-width:100%; height:auto; }
a{ color:inherit; }

button,input,select,textarea{ font:inherit; }
button{ -webkit-tap-highlight-color:transparent; }

/* Focus (keyboard friendly) */
:focus{ outline:none; }
:focus-visible{ box-shadow:0 0 0 3px rgba(67,97,238,.14); border-color:rgba(67,97,238,.45) !important; }

/* Small helpers */
.a-like{ text-decoration:none; color:inherit; }
.row{ display:flex; align-items:center; gap:10px; }

/* Input helpers used in pages (filters, etc.) */
.field-label{
  display:block;
  font-size:.82rem;
  color:var(--muted);
  font-weight:800;
  margin-bottom:6px;
}

/* keep default styling for raw elements + allow "class=input" usage */
input,select,textarea,
input.input,select.input,textarea.input{
  width:100%;
  padding:12px;
  border:1px solid #eee;
  border-radius:12px;
  margin-top:10px;
  font-size:.92rem;
  background:#fafafa;
  outline:none;
}

/* When fields use the helper class "input" (usually with a label), remove extra top spacing */
input.input,select.input,textarea.input{ margin-top:0; }
textarea{ resize:none; min-height:85px; }
input:focus,select:focus,textarea:focus,
input.input:focus,select.input:focus,textarea.input:focus{
  border-color:rgba(67,97,238,.35);
  background:#fff;
}

/* ========== Navbar ========== */
.navbar{
  background:#fff;
  padding:.55rem 5%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  box-shadow:0 2px 15px rgba(0,0,0,.05);
  position:sticky;
  top:0;
  z-index:1600;
}
.logo{ font-size:1.05rem; display:flex; align-items:center; gap:8px; }
.user-menu-container{ position:relative; }

.user-icon-btn{
  background:#f8f9fa;
  border:1px solid #eee;
  width:44px; height:44px;
  border-radius:12px;
  cursor:pointer;
  color:var(--primary);
  font-size:1.15rem;
  display:flex; align-items:center; justify-content:center;
  transition:transform .15s ease, border-color .15s ease, background-color .15s ease;
}
.user-icon-btn:hover{ transform:translateY(-1px); border-color:rgba(67,97,238,.25); background:#fff; }

.dropdown-menu{
  position:absolute;
  top:calc(100% + 10px);
  inset-inline-end:0; /* aligns with hamburger (left side in RTL) */
  width:300px;
  max-width:calc(100vw - 24px);
  max-height:min(70vh, 520px);
  background:#fff;
  border:1px solid #edf0f7;
  border-radius:16px;
  box-shadow:0 14px 40px rgba(0,0,0,.14);
  display:none;
  flex-direction:column;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  z-index:1650;
}
.dropdown-menu.active{ display:flex; }

/* Dropdown scrollbar */
.dropdown-menu::-webkit-scrollbar{ width:10px; }
.dropdown-menu::-webkit-scrollbar-thumb{ background:#e6ebf5; border-radius:999px; border:2px solid transparent; background-clip:content-box; }
.dropdown-menu::-webkit-scrollbar-track{ background:transparent; }



/* Backdrop for mobile drawer menu */
.menu-backdrop{
  position:fixed;
  inset:0;
  /* keep a click-catcher to close the menu without dimming the page */
  background:transparent;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .15s ease;
  z-index:1500;
}
.menu-backdrop.active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
html.menu-open, html.menu-open body{ overflow:hidden; }

/* Mobile: compact dropdown panel (no full-screen drawer) */
@media (max-width: 820px){
  .dropdown-menu{
    position:fixed;
    top:calc(env(safe-area-inset-top) + 58px);
    /* align with hamburger (left side on screen in RTL) */
    inset-inline-end:clamp(12px, 5vw, 28px);
    inset-inline-start:auto;

    width:min(84vw, 300px);
    max-height:calc(100vh - (env(safe-area-inset-top) + 96px));
    height:auto;

    display:flex; /* keep for smooth transitions */
    border-radius:16px;
    box-shadow:0 16px 44px rgba(0,0,0,.16);
    transform:translateY(-8px);
    opacity:0;
    visibility:hidden;
    pointer-events:none;

    overflow:auto;
    -webkit-overflow-scrolling:touch;
    z-index:1650;
  }
  .dropdown-menu.active{
    transform:translateY(0);
    opacity:1;
    visibility:visible;
    pointer-events:auto;
  }

  /* slightly tighter items on small screens */
  .menu-item{ padding:11px 12px; font-size:.85rem; }
  .menu-userbox{ padding:11px 12px; }
}


.menu-userbox{
  position:sticky;
  top:0;
  z-index:2;
  padding:12px 14px;
  background:rgba(244,247,254,.65);
  border-bottom:1px solid #f0f0f0;
  display:flex;
  align-items:center;
  gap:10px;
}
.avatar{
  width:34px; height:34px;
  border-radius:10px;
  background:#fff;
  border:1px solid #e8ecf7;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--primary);
  font-size:1rem;
  flex:0 0 auto;
}
.user-meta{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.user-name{ font-weight:800; font-size:.9rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.user-role{ font-size:.76rem; color:var(--muted); font-weight:700; }

.menu-item{
  padding:12px 14px;
  border:none;
  background:none;
  text-align:start;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--text);
  text-decoration:none;
  font-size:.86rem;
  border-bottom:1px solid #f7f7f7;
  transition:background-color .15s ease, color .15s ease;
}
.menu-item i{ width:22px; text-align:center; opacity:.9; }
.menu-item:active{ background:#f1f4fb; }
.menu-item:focus-visible{ box-shadow:0 0 0 3px rgba(67,97,238,.18); }
.menu-item:last-child{ border-bottom:none; }

.menu-item:hover{ background:#f8f9fa; color:var(--primary); }
.menu-item.danger{ color:var(--danger); }
.menu-item.danger:hover{ background:#fff5f5; color:var(--danger); }

.menu-item.small{ font-size:.84rem; }
.menu-item .right-tag{
  margin-inline-start:auto;
  font-size:.74rem;
  color:var(--muted);
  font-weight:800;
}

/* ========== Page Layout ========== */
.content-area{ padding:1rem 5%; max-width:1100px; margin:0 auto; }
.page-header{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:10px; }

.head-card{
  background:#fff;
  border:1px solid #eef2f7;
  border-radius:14px;
  padding:12px 14px;
  display:flex;
  align-items:center;
  gap:12px;
  flex:1 1 520px;
  box-shadow:0 2px 12px rgba(0,0,0,.03);
}
.head-title{ flex:1; min-width:200px; }
.head-title h2{ font-size:1.15rem; margin:0; }
.head-title p{ margin:6px 0 0; font-size:.84rem; color:var(--muted); }

.head-actions{
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:nowrap;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  padding:2px;
  scrollbar-width:thin;
}
.head-actions > *{ flex:0 0 auto; }


/* ========== Buttons ========== */
.mini-btn{
  width:40px; height:40px;
  border-radius:12px;
  border:1px solid #eef2f7;
  background:linear-gradient(180deg, #ffffff, #fbfcff);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  color:var(--primary);
  box-shadow:0 2px 12px rgba(0,0,0,.02);
  transition:transform .15s ease, border-color .15s ease, filter .15s ease;
}
.mini-btn:hover{ transform:translateY(-1px); border-color:rgba(67,97,238,.35); }
.mini-btn:active{ transform:translateY(0); filter:brightness(.98); }
.mini-btn.danger{ color:var(--danger); }
.mini-btn.danger:hover{ border-color:rgba(231,76,60,.25); }

/* Full-width main buttons in modals/forms */
.btn-main{
  background:var(--primary);
  color:#fff;
  border:none;
  padding:12px;
  width:100%;
  border-radius:12px;
  cursor:pointer;
  font-weight:900;
  margin-top:14px;
  font-size:1rem;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  transition:filter .15s ease, transform .15s ease;
}
.btn-main:hover{ filter:brightness(.97); }
.btn-main:active{ transform:translateY(0); filter:brightness(.96); }

.btn-ghost{
  width:100%;
  background:transparent;
  border:1px solid #e9edf6;
  color:#444;
  padding:10px;
  border-radius:12px;
  cursor:pointer;
  font-weight:800;
  margin-top:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  transition:background-color .15s ease, border-color .15s ease, color .15s ease;
}
.btn-ghost:hover{ border-color:rgba(67,97,238,.35); color:var(--primary); background:#fbfcff; }

/* Generic button used in many pages (IMPORTANT: visible by default) */
.btn{
  border:1px solid #e9edf6;
  border-radius:12px;
  padding:12px 14px;
  cursor:pointer;
  font-weight:900;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  background:#fff;
  color:var(--text);
  transition:transform .15s ease, border-color .15s ease, filter .15s ease, background-color .15s ease;
}
.btn:hover{ transform:translateY(-1px); border-color:rgba(67,97,238,.35); }
.btn:active{ transform:translateY(0); filter:brightness(.98); }
.btn-primary{ background:var(--primary); border-color:transparent; color:#fff; }
.btn-primary:hover{ filter:brightness(.97); }
.btn-outline{ background:#fff; border:1px solid #e9edf6; color:var(--text); }
.btn-outline:hover{ border-color:rgba(67,97,238,.35); color:var(--primary); }
.btn-danger{ background:#fff0f0; border:1px solid rgba(231,76,60,.25); color:#9b1c1c; }
.btn-danger:hover{ filter:brightness(.99); border-color:rgba(231,76,60,.35); }

.row-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }

/* ========== Vault Cards ========== */
.vault-grid{ display:flex; flex-direction:column; gap:10px; margin-top:10px; padding-bottom:calc(90px + env(safe-area-inset-bottom)); }

.vault-card{
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:0 2px 10px rgba(0,0,0,.03);
  overflow:hidden;
  border-right:5px solid var(--primary);
  position:relative;
}
.vault-card.bank{ border-right-color:var(--bank); }
.vault-card.fx{ border-right-color:var(--warning); }
.vault-card.frozen{ opacity:.82; border-right-color:#bdc3c7; }
.vault-card.locked{ box-shadow:0 2px 10px rgba(0,0,0,.03), 0 0 0 2px rgba(243,156,18,.10) inset; }

.card-top{
  padding:8px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:rgba(244,247,254,.65);
  border-bottom:1px solid var(--line);
  gap:10px;
  flex-wrap:wrap;
}

.status{
  display:flex; align-items:center; gap:8px;
  font-size:.72rem; font-weight:800;
  white-space:nowrap;
}
.dot{ width:8px; height:8px; border-radius:50%; }

.card-actions{ display:flex; gap:6px; flex-wrap:wrap; justify-content:flex-end; }
.action-btn{
  width:38px; height:32px;
  border-radius:10px;
  border:1px solid #dfe6e9;
  background:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  color:#636e72;
  font-size:.9rem;
  text-decoration:none;
  transition:transform .15s ease, border-color .15s ease, color .15s ease, background-color .15s ease;
}
.action-btn:hover{
  color:var(--primary);
  border-color:var(--primary);
  background:#f8faff;
  transform:translateY(-1px);
}
.action-btn:active{ transform:translateY(0); filter:brightness(.98); }
.action-btn.disabled{ pointer-events:none; opacity:.35; background:#f5f5f5; }
.action-btn.danger{ color: var(--danger) !important; }
.action-btn.danger:hover{ border-color:rgba(231,76,60,.25); background:#fff5f5; }

.card-body{ padding:12px 14px; }
.card-row{ display:flex; align-items:flex-start; justify-content:space-between; gap:14px; }

.main-info{ min-width:230px; }
.title{
  margin:0;
  font-size:.98rem;
  display:flex;
  align-items:center;
  gap:10px;
  line-height:1.3;
  flex-wrap:wrap;
}
.type-badge{
  font-size:.66rem;
  padding:3px 8px;
  border-radius:7px;
  background:#f0f2f5;
  color:#5f6d7e;
  font-weight:700;
}
.type-badge.fx{ background:#fff7e6; color:#8a5b00; }

.info-grid{
  flex:1;
  display:grid;
  grid-template-columns:repeat(3, minmax(120px, 1fr));
  gap:10px 14px;
  padding-top:2px;
}
.info-grid.fx-grid{ grid-template-columns:repeat(2, minmax(140px, 1fr)); }
.data-item{ display:flex; flex-direction:column; gap:2px; }
.label{ font-size:.70rem; color:var(--muted); }
.value{ font-size:.86rem; font-weight:800; color:var(--text); }

.fx-cost{
  grid-column:1 / -1;
  padding-top:10px;
  border-top:1px solid var(--line);
  margin-top:4px;
}
.fx-cost .fx-cost-label{ font-size:.78rem; color:var(--muted); font-weight:800; margin-bottom:4px; }
.fx-cost .fx-cost-amount{ font-size:1.25rem; font-weight:900; letter-spacing:.2px; }
.fx-unit{ margin-top:6px; font-size:.86rem; color:var(--muted); font-weight:800; }

.balance{ min-width:170px; text-align:left; }
.balance .label{ display:block; }
.amount{ font-size:1.15rem; font-weight:900; letter-spacing:.2px; display:inline-block; }
.currency{ font-size:.75rem; color:var(--muted); font-weight:normal; margin-right:4px; }
.bal-positive{ color:var(--success); }
.bal-negative{ color:var(--danger); }
.bal-zero{ color:var(--text); }

/* Mini icons on card (bank/fx) */
.card-mini-actions{
  position:absolute;
  left:12px;
  bottom:12px;
  display:flex;
  align-items:center;
  gap:8px;
  z-index:3;
}

/* When mini icons are grouped, disable absolute positioning per-icon */
.vault-card .card-mini-actions .bank-card-mini,
.vault-card .card-mini-actions .fx-card-mini,
.vault-card .card-mini-actions .fx-profit-mini{
  position:static;
  left:auto;
  bottom:auto;
}

.bank-card-mini,
.fx-card-mini{
  position:absolute;
  left:12px;
  bottom:12px;
  width:34px; height:34px;
  border-radius:12px;
  border:1px solid #eef2f7;
  background:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.06);
  transition:transform .15s ease, border-color .15s ease;
}
.bank-card-mini{ color:var(--bank); }
.fx-card-mini{ color:var(--warning); }
.bank-card-mini:hover{ transform:translateY(-1px); border-color:rgba(155,89,182,.35); }
.fx-card-mini:hover{ transform:translateY(-1px); border-color:rgba(243,156,18,.35); }

/* FX profit mini */
.fx-profit-mini{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid #eef2f7;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.06);
  transition:transform .15s ease, border-color .15s ease;
  color:var(--success);
}
.fx-profit-mini:hover{ transform:translateY(-1px); border-color:rgba(46,204,113,.35); }

/* Hide sensitive values */
.hidden-data{ filter:blur(6px); pointer-events:none; user-select:none; }

/* Lock badge */
.lock-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:2px 8px;
  border-radius:999px;
  font-size:.70rem;
  font-weight:900;
  color:#a66a00;
  background:rgba(243,156,18,.12);
  border:1px solid rgba(243,156,18,.25);
}

/* ========== Badges / Tags (used in trash & archive pages) ========== */
.tag{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background:#f6f8ff;
  border:1px solid #e9edf6;
  color:#334;
  font-weight:900;
  font-size:.78rem;
  line-height:1;
}
.tag.warn{
  background:rgba(243,156,18,.12);
  border-color:rgba(243,156,18,.25);
  color:#8a5b00;
}

/* Vault header layout used by archived/trash pages */
.vault-header{
  padding:12px 14px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  background:rgba(244,247,254,.65);
  border-bottom:1px solid var(--line);
}
.vault-title{ font-weight:900; font-size:1rem; line-height:1.3; }
.vault-sub{ margin-top:4px; font-size:.82rem; font-weight:800; color:var(--muted); }
.vault-balance{ font-weight:900; font-size:1rem; white-space:nowrap; text-align:left; }
.vault-meta{ padding:10px 14px; display:flex; gap:8px; flex-wrap:wrap; }

/* List titles used in transactions-trash */
.list-title{ font-weight:900; font-size:.95rem; }
.list-sub{ font-weight:800; font-size:.82rem; color:var(--muted); margin-top:4px; line-height:1.6; }
.list-meta{ display:flex; gap:8px; flex-wrap:wrap; margin-top:8px; }

/* ========== Modal (Windows) ========== */
.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.5);
  display:none;
  justify-content:center;
  align-items:flex-start;
  z-index:2000;
  padding:16px;
  padding-top:calc(16px + env(safe-area-inset-top));
  padding-bottom:calc(16px + env(safe-area-inset-bottom));
  overflow:auto;
}

.modal-content{
  background:#fff;
  padding:18px;
  border-radius:16px;
  width:100%;
  max-width:560px;
  box-shadow:0 20px 40px rgba(0,0,0,.2);
  position:relative;
  margin:18px auto;
  max-height:calc(100vh - 80px);
  overflow:auto;
  display:flex;
  flex-direction:column;
}

.modal-header{
  border-bottom:1px solid #eee;
  padding-bottom:10px;
  margin-bottom:12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  position:sticky;
  top:0;
  background:#fff;
  z-index:2;
}

.modal-body{ flex:1 1 auto; }
.modal-footer{ margin-top:12px; display:flex; justify-content:flex-start; gap:10px; flex-wrap:wrap; }

/* Details rows (used in details modals) */
.detail-row{
  display:flex; justify-content:space-between;
  padding:10px 0;
  border-bottom:1px dashed #eee;
  font-size:.92rem;
  gap:12px;
}
.detail-label{ color:var(--muted); white-space:nowrap; }
.detail-value{ font-weight:900; color:var(--text); text-align:left; }

/* Audit details helpers */
.audit-details{ display:flex; flex-direction:column; gap:8px; }
.audit-details .detail-row{ align-items:flex-start; }
.audit-details .detail-value{ text-align:right; white-space:pre-wrap; overflow-wrap:anywhere; }

.code-block{
  margin:0;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid #e9edf6;
  background:#f6f8ff;
  max-height:280px;
  overflow:auto;
  font-size:.85rem;
  line-height:1.6;
}
.audit-raw summary{ cursor:pointer; font-weight:900; color:var(--muted); }

/* Inline info badge used in many modals */
.inline-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:12px;
  background:#f4f7fe;
  color:#445;
  border:1px solid #e9edf6;
  font-weight:800;
  font-size:.85rem;
  margin-top:8px;
  width:100%;
  justify-content:space-between;
}
.inline-badge small{ color:var(--muted); font-weight:700; }

.help-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; font-size:.85rem; color:var(--muted); font-weight:700; }
.pill{
  padding:8px 10px;
  background:#f6f8ff;
  border:1px solid #e9edf6;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#334;
}

/* Alerts */
.mini-alert{
  display:none;
  margin-top:12px;
  padding:10px 12px;
  border-radius:12px;
  font-size:.9rem;
  line-height:1.6;
}
.mini-alert.success{ display:block; background:#eafaf1; color:#1b7a44; border:1px solid rgba(46,204,113,.25); }
.mini-alert.error{ display:block; background:#fff0f0; color:#9b1c1c; border:1px solid rgba(231,76,60,.25); }
.mini-alert.warn{ display:block; background:#fff7e6; color:#8a5b00; border:1px solid rgba(243,156,18,.25); }

/* ========== Sections / Settings pages ========== */
.section{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
  box-shadow:0 2px 12px rgba(0,0,0,.03);
  margin-top:12px;
}
.section h3{
  margin:0 0 10px;
  font-size:1rem;
  display:flex;
  align-items:center;
  gap:10px;
}

.grid-2{ display:grid; grid-template-columns:repeat(2, minmax(180px, 1fr)); gap:12px; }
.grid-3{ display:grid; grid-template-columns:repeat(3, minmax(160px, 1fr)); gap:12px; }

@media (max-width: 900px){
  .grid-2{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:1fr; }
}

.notice{
  background:#f4f7fe;
  border:1px solid #e9edf6;
  border-radius:12px;
  padding:10px 12px;
  font-weight:800;
  color:#445;
  line-height:1.7;
}
.notice i{ color:var(--primary); }

/* Switch */
.switch{ display:flex; align-items:center; gap:10px; font-weight:900; }
.switch input[type="checkbox"]{
  width:46px;
  height:26px;
  appearance:none;
  background:#dfe6e9;
  border-radius:999px;
  position:relative;
  outline:none;
  cursor:pointer;
  border:1px solid #cfd8dc;
  margin-top:0; /* prevent extra spacing from generic input rules */
}
.switch input[type="checkbox"]::after{
  content:'';
  position:absolute;
  width:20px; height:20px;
  top:2px; right:2px;
  background:#fff;
  border-radius:50%;
  box-shadow:0 2px 6px rgba(0,0,0,.15);
  transition:all .2s ease;
}
.switch input[type="checkbox"]:checked{ background:rgba(67,97,238,.55); border-color:rgba(67,97,238,.55); }
.switch input[type="checkbox"]:checked::after{ right:24px; }

/* Lists (admins, trash items, etc.) */
.list{ border:1px solid #eef2f7; border-radius:14px; overflow:hidden; background:#fff; }
.list-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-bottom:1px solid #f0f0f0;
  background:#fff;
}
.list-item:last-child{ border-bottom:none; }
.list-item .meta{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.list-item .meta strong{ font-size:.9rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.list-item .meta small{ color:var(--muted); font-weight:800; }
.list-item .actions{ display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }

.small-btn{
  border:1px solid #e9edf6;
  background:#fff;
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  font-weight:900;
  color:#445;
  transition:transform .15s ease, border-color .15s ease, background-color .15s ease;
}
.small-btn:hover{ transform:translateY(-1px); border-color:rgba(67,97,238,.35); color:var(--primary); }
.small-btn:active{ transform:translateY(0); filter:brightness(.98); }
.small-btn.danger{ color:var(--danger); }
.small-btn.danger:hover{ border-color:rgba(231,76,60,.25); background:#fff5f5; }

/* ========== Transactions list ========== */
.tx-wrap{ margin-top:10px; border:1px solid #eef2f7; border-radius:14px; background:#fbfcff; overflow:hidden; }
.tx-list{ max-height:360px; overflow:auto; padding:8px; }
.tx-item{ background:#fff; border:1px solid #eef2f7; border-radius:12px; padding:10px 12px; margin:8px 0; box-shadow:0 2px 10px rgba(0,0,0,.02); }
.tx-top{ display:flex; justify-content:space-between; gap:10px; align-items:center; font-weight:900; font-size:.9rem; }
.tx-date{ font-weight:800; font-size:.78rem; color:var(--muted); white-space:nowrap; }
.tx-sub{ margin-top:6px; font-size:.82rem; color:#556; font-weight:800; line-height:1.5; }
.tx-amount{ margin-top:8px; font-size:1rem; font-weight:900; text-align:left; }

/* ========== KV details box (used across modals) ========== */
.kv{ border:1px solid #eef2f7; border-radius:14px; overflow:hidden; background:#fff; }
.kv-row{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; padding:10px 12px; border-bottom:1px solid #f0f0f0; }
.kv-row:last-child{ border-bottom:none; }
.kv-k{ color:var(--muted); font-weight:900; white-space:nowrap; }
.kv-v{ font-weight:900; word-break:break-word; text-align:left; }

/* Tables */
.table-wrap{ overflow:auto; border-radius:16px; border:1px solid rgba(0,0,0,.06); background:#fff; }
.data-table{ width:100%; border-collapse:collapse; }
.data-table thead th{ background:rgba(67,97,238,.06); color:var(--text); font-weight:800; padding:12px 10px; font-size:.9rem; white-space:nowrap; }
.data-table tbody td{ padding:12px 10px; border-top:1px solid rgba(0,0,0,.06); font-size:.9rem; vertical-align:top; }
.data-table tbody tr:hover{ background:rgba(0,0,0,.02); }

/* Responsive */
@media (max-width: 900px){
  .info-grid{ grid-template-columns:repeat(2, minmax(120px, 1fr)); }
  .balance{ min-width:140px; }
}

@media (max-width: 768px){
  .content-area{ padding:1rem 4%; }
  .card-row{ flex-wrap:wrap; }
  .main-info{ min-width:unset; width:100%; }
  .info-grid{ width:100%; grid-template-columns:repeat(2, minmax(120px, 1fr)); }
  .info-grid.fx-grid{ grid-template-columns:repeat(2, minmax(140px, 1fr)); }
  .balance{ width:100%; text-align:right; padding-top:8px; border-top:1px solid var(--line); }
  .modal-content{ padding:16px; max-width:600px; }
  .vault-header{ flex-wrap:wrap; }
}


/* Header card responsive behavior (icons row becomes scrollable) */
@media (max-width: 720px){
  .head-card{ flex-direction:column; align-items:stretch; }
  .head-title{ min-width:0; }
  .head-actions{ justify-content:flex-start; width:100%; padding:6px 2px; }
}


/* ========== FX Profit ========= */
.fx-filters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:flex-end;
  margin:10px 0 12px;
  padding:10px;
  background:rgba(67,97,238,.05);
  border:1px solid rgba(67,97,238,.12);
  border-radius:14px;
}
.fx-filters .field{ flex:1 1 170px; margin:0; }
.fx-filters label{
  display:block;
  font-size:.78rem;
  font-weight:900;
  color:var(--muted);
  margin-bottom:6px;
}
.fx-filters input,
.fx-filters select{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  font-size:.9rem;
  margin-top:0;
}
.fx-filters .btn{
  padding:10px 12px;
  border-radius:12px;
}
.fx-filters .btns{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.fx-inline-check{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:900;
  color:var(--text);
  font-size:.85rem;
}
.fx-inline-check input{ width:auto; margin:0; }

.fx-stats{
  display:grid;
  grid-template-columns:repeat(4, minmax(140px, 1fr));
  gap:10px;
  margin-top:10px;
}
@media(max-width: 900px){
  .fx-stats{ grid-template-columns:repeat(2, minmax(140px, 1fr)); }
}
.fx-stat{
  padding:12px;
  border:1px solid rgba(0,0,0,.06);
  border-radius:14px;
  background:#fff;
}
.fx-stat .k{ font-size:.78rem; color:var(--muted); font-weight:900; margin-bottom:6px; }
.fx-stat .v{ font-size:1rem; font-weight:900; }
.fx-stat .hint{ font-size:.75rem; color:var(--muted); margin-top:6px; font-weight:800; }

.fx-accordion{
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  background:#fff;
  overflow:hidden;
  margin-top:12px;
}
.fx-accordion > summary{
  cursor:pointer;
  list-style:none;
  padding:12px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-weight:900;
  background:rgba(0,0,0,.02);
}
.fx-accordion > summary::-webkit-details-marker{ display:none; }
.fx-accordion .accordion-body{ padding:12px 14px; }

.badge-soft{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:.78rem;
  border:1px solid rgba(0,0,0,.06);
  background:#fff;
  color:var(--text);
}
.badge-soft.success{ background:rgba(46,204,113,.10); border-color:rgba(46,204,113,.18); color:#136a37; }
.badge-soft.danger{ background:rgba(231,76,60,.08); border-color:rgba(231,76,60,.18); color:#8e1b14; }
.badge-soft.info{ background:rgba(67,97,238,.08); border-color:rgba(67,97,238,.16); color:#273c9b; }
