/* ============================================================
   M2 CRYPTO — Dark Theme Override
   Inspired by: premium crypto trading app aesthetics
   Drop this AFTER style.css in header.php
   ============================================================ */

/* ─── Google Font Upgrade ─── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/* ─── CSS Variables / Design Tokens ─── */
:root {
  --bg-primary:    #0D0F14;
  --bg-surface:    #161B26;
  --bg-surface2:   #1C2333;
  --bg-surface3:   #222A3A;
  --border-color:  rgba(255,255,255,0.07);
  --accent:        #00C9A7;          /* teal — primary */
  --accent-glow:   rgba(0,201,167,0.18);
  --accent-orange: #F0A500;          /* gold — secondary */
  --text-primary:  #E8EAED;
  --text-secondary:#8A97A8;
  --text-muted:    #4E5A6B;
  --green:         #00C076;
  --green-bg:      rgba(0,192,118,0.15);
  --red:           #F6465D;
  --red-bg:        rgba(246,70,93,0.15);
  --shadow:        0 4px 24px rgba(0,0,0,0.45);
}

/* ─── Base ─── */
*:not(i):not([class*="ion-"]), body {
  font-family: 'Inter', 'Poppins', sans-serif !important;
}

body {
  background: var(--bg-primary) !important;
  color: var(--text-primary) !important;
}

/* ─── App Header ─── */
.appHeader {
  background: var(--bg-primary) !important;
  border-bottom: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.appHeader:before {
  background: var(--bg-primary) !important;
}

/* ─── Dashboard Dark Header (header1.php) ─── */
.dark-app-header {
  background: linear-gradient(90deg, #0D0F14 0%, #0f1923 100%) !important;
  border-bottom: 1px solid rgba(0,201,167,0.12) !important;
  box-shadow: 0 2px 20px rgba(0,0,0,0.4) !important;
}

.dark-app-header .logo {
  height: 32px;
  filter: brightness(1.1) drop-shadow(0 0 6px rgba(0,201,167,0.35));
}

/* ─── Section Title Row ─── */
.section-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px 10px;
}

.section-title {
  color: var(--text-primary) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em;
  display: flex;
  align-items: center;
  gap: 8px;
}

.section-title::before {
  content: '';
  display: inline-block;
  width: 3px;
  height: 16px;
  background: var(--accent);
  border-radius: 2px;
}

.section-title-link {
  font-size: 12px;
  font-weight: 500;
  color: var(--accent) !important;
  text-decoration: none !important;
  opacity: 0.85;
  transition: opacity 0.2s;
}

.section-title-link:hover {
  opacity: 1;
}


.appHeader .pageTitle {
  color: var(--text-primary) !important;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.appHeader .headerButton,
.appHeader .left ion-icon,
.appHeader .right ion-icon {
  color: var(--text-primary) !important;
}

/* ─── Bottom Navigation ─── */
.appBottomMenu {
  background: var(--bg-surface) !important;
  border-top: 1px solid var(--border-color) !important;
  padding-bottom: max(env(safe-area-inset-bottom), 8px);
}

.appBottomMenu .item .col ion-icon,
.appBottomMenu .item ion-icon {
  color: var(--text-muted) !important;
}

.appBottomMenu .item strong {
  color: var(--text-muted) !important;
  font-size: 10px;
  font-weight: 400;
}

.appBottomMenu .item.active:before {
  background: var(--accent) !important;
}

.appBottomMenu .item.active ion-icon,
.appBottomMenu .item.active strong {
  color: var(--accent) !important;
  font-weight: 600;
}

/* Center Trade button pill style */
.appBottomMenu .item .action-button {
  background: var(--accent) !important;
  box-shadow: 0 0 20px var(--accent-glow);
  border-radius: 50%;
}

/* ─── Cards ─── */
.card {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 16px !important;
  box-shadow: var(--shadow) !important;
  color: var(--text-primary) !important;
}

.card .card-body {
  color: var(--text-primary) !important;
}

.card .card-header,
.card .card-footer {
  background: transparent !important;
  border-color: var(--border-color) !important;
  color: var(--text-secondary) !important;
}

/* ─── Section Titles ─── */
.section-title {
  color: var(--text-primary) !important;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.listview-title {
  color: var(--text-muted) !important;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ─── List Views ─── */
.listview > li,
.image-listview > li {
  background: transparent !important;
  border-color: var(--border-color) !important;
}

.listview > li:after,
.image-listview > li:after {
  background: var(--border-color) !important;
}

.listview .item,
.image-listview .item {
  color: var(--text-primary) !important;
  background: transparent !important;
}

.listview .item .in,
.image-listview .item .in {
  border-color: var(--border-color) !important;
}

.image-listview .item .icon-box {
  background: var(--bg-surface2) !important;
  border-radius: 12px !important;
}

/* ─── Wide Block ─── */
.wide-block {
  background: var(--bg-surface) !important;
  border-color: var(--border-color) !important;
}

/* ─── Sidebar Panel ─── */
.modal-content {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
}

.modal-header,
.modal-footer {
  border-color: var(--border-color) !important;
}

.profileBox .in strong {
  color: var(--text-primary) !important;
}

.profileBox .in .text-muted {
  color: var(--text-secondary) !important;
}

.sidebar-balance {
  background: linear-gradient(135deg, #0f2027, #203a43, #2c5364) !important;
}

/* ─── Forms & Inputs ─── */
.form-control {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: 12px !important;
  padding: 12px 14px !important;
}

.form-control::placeholder {
  color: var(--text-muted) !important;
}

.form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-glow) !important;
  background: var(--bg-surface2) !important;
}

.label {
  color: var(--text-secondary) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ─── Buttons ─── */
.btn-primary {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #000 !important;
  font-weight: 600 !important;
  border-radius: 12px !important;
  box-shadow: 0 4px 16px var(--accent-glow) !important;
}

.btn-primary:hover, .btn-primary:active {
  background: #00e0bb !important;
  border-color: #00e0bb !important;
}

.btn-secondary {
  background: var(--bg-surface3) !important;
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: 12px !important;
}

.btn-danger {
  background: var(--red) !important;
  border-color: var(--red) !important;
  color: #fff !important;
  border-radius: 12px !important;
}

.btn-success {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #000 !important;
  border-radius: 12px !important;
}

/* ─── Badges — Pill Style ─── */
.badge {
  border-radius: 999px !important;
  padding: 4px 10px !important;
  font-weight: 600 !important;
  font-size: 11px !important;
}

.badge-success,
.badge.bg-success {
  background: var(--green-bg) !important;
  color: var(--green) !important;
  border: 1px solid var(--green) !important;
}

.badge-danger,
.badge.bg-danger {
  background: var(--red-bg) !important;
  color: var(--red) !important;
  border: 1px solid var(--red) !important;
}

.badge-warning,
.badge.bg-warning {
  background: rgba(240,165,0,0.15) !important;
  color: var(--accent-orange) !important;
  border: 1px solid var(--accent-orange) !important;
}

.badge-primary,
.badge.bg-primary {
  background: var(--accent-glow) !important;
  color: var(--accent) !important;
  border: 1px solid var(--accent) !important;
}

.badge-info,
.badge.bg-info {
  background: rgba(14,165,233,0.15) !important;
  color: #38bdf8 !important;
  border: 1px solid #38bdf8 !important;
}

/* ─── Tables ─── */
.table {
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

.table thead th {
  background: var(--bg-surface2) !important;
  color: var(--text-muted) !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  border-color: var(--border-color) !important;
  font-weight: 500 !important;
  padding: 10px 12px !important;
}

.table tbody tr {
  border-color: var(--border-color) !important;
  transition: background 0.15s ease;
}

.table tbody tr:hover {
  background: var(--bg-surface2) !important;
}

.table tbody td {
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
  vertical-align: middle !important;
  padding: 12px 12px !important;
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
  background: rgba(255,255,255,0.025) !important;
}

/* ─── Trade Table — override Bootstrap bg-primary purple ─── */
.table.bg-primary,
table.bg-primary {
  background: var(--bg-surface) !important;
}

.table.bg-primary thead tr,
.table.bg-primary thead th {
  background: var(--bg-surface2) !important;
  color: var(--text-muted) !important;
  border-color: var(--border-color) !important;
}

.table.bg-primary tbody tr {
  background: var(--bg-surface) !important;
  border-color: var(--border-color) !important;
}

.table.bg-primary tbody tr:nth-child(odd) {
  background: var(--bg-surface2) !important;
}

.table.bg-primary tbody tr:hover {
  background: var(--bg-surface3) !important;
}

.table.bg-primary tbody td {
  background: transparent !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

/* ─── Join Us stat-box icons ─── */
.stat-box {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 16px !important;
  padding: 16px 12px !important;
  transition: background 0.2s;
}

.stat-box:hover {
  background: var(--bg-surface3) !important;
}

.stat-box h5,
.stat-box .title {
  color: var(--text-primary) !important;
  margin-top: 8px !important;
  font-size: 11px !important;
}

/* ─── Login page (index.php) dark mode ─── */
body .section h1,
body .section h4 {
  color: var(--text-primary) !important;
}

/* ─── Tabs ─── */
.nav-tabs {
  border-color: var(--border-color) !important;
}

.nav-tabs .nav-link {
  color: var(--text-secondary) !important;
  border-color: transparent !important;
  border-radius: 10px 10px 0 0 !important;
  font-weight: 500;
  padding: 10px 16px;
  transition: all 0.2s ease;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-link:hover {
  color: var(--accent) !important;
  background: transparent !important;
  border-bottom-color: var(--accent) !important;
}

.nav-tabs.lined .nav-link.active {
  border-bottom: 2px solid var(--accent) !important;
}

/* ─── Transaction Items ─── */
.transactions .item {
  background: var(--bg-surface) !important;
  border-radius: 14px !important;
  margin-bottom: 8px !important;
  border: 1px solid var(--border-color) !important;
  padding: 14px 16px !important;
  transition: all 0.2s ease;
}

.transactions .item:hover {
  border-color: var(--accent) !important;
  box-shadow: 0 0 12px var(--accent-glow) !important;
}

.transactions .item .card-body {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* ─── Profit / Loss Colors ─── */
.text-success { color: var(--green) !important; }
.text-danger  { color: var(--red) !important; }
.text-warning { color: var(--accent-orange) !important; }
.text-primary { color: var(--accent) !important; }
.text-muted   { color: var(--text-secondary) !important; }

/* ─── Coin Icon Circles ─── */
.coin-icon,
.imaged.rounded-circle,
img.rounded-circle {
  border: 2px solid var(--border-color) !important;
  border-radius: 50% !important;
}

/* ─── Dashboard Trade Table ─── */
.market-list-item,
.crypto-row {
  display: flex;
  align-items: center;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-color);
  transition: background 0.15s;
}

.market-list-item:hover {
  background: var(--bg-surface2) !important;
  border-radius: 12px;
}

/* Price up/down mini tags */
.price-change.up {
  color: var(--green) !important;
  background: var(--green-bg) !important;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
}

.price-change.down {
  color: var(--red) !important;
  background: var(--red-bg) !important;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
}

/* ─── Loader ─── */
#loader {
  background: var(--bg-primary) !important;
}

/* ─── Dark Mode Switch ─── */
.form-check-input:checked {
  background-color: var(--accent) !important;
  border-color: var(--accent) !important;
}

/* ─── Scrollbar (thin dark) ─── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: var(--bg-primary); }
::-webkit-scrollbar-thumb { background: var(--bg-surface3); border-radius: 99px; }

/* ─── Toastr Notifications ─── */
#toast-container > div {
  border-radius: 12px !important;
  box-shadow: var(--shadow) !important;
  opacity: 1 !important;
}

/* ─── Extra: Percentage display in trade tables ─── */
td .percent-up,
span.percent-up {
  color: var(--green) !important;
  background: var(--green-bg);
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 12px;
}

td .percent-down,
span.percent-down {
  color: var(--red) !important;
  background: var(--red-bg);
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 12px;
}

/* ─── Portfolio Stats Row ─── */
.stat-card {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 14px !important;
  padding: 14px !important;
  text-align: center;
}

.stat-card .stat-label {
  color: var(--text-muted) !important;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.stat-card .stat-value {
  color: var(--text-primary) !important;
  font-weight: 700;
  font-size: 16px;
  margin-top: 4px;
}

/* ─── Action Buttons Grid (Deposit/Withdraw etc) ─── */
.action-group {
  background: transparent !important;
}

.action-group .action-button .iconbox {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 14px !important;
  width: 48px !important;
  height: 48px !important;
  color: var(--accent) !important;
}

.action-group .action-button {
  color: var(--text-secondary) !important;
}

/* ─── Trade Table (Dashboard) ─── */
.table-responsive {
  background: var(--bg-surface) !important;
  border-radius: 16px !important;
  border: 1px solid var(--border-color) !important;
  overflow: hidden !important;
}

table.trade-table {
  background: transparent !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  width: 100% !important;
  margin: 0 !important;
}

table.trade-table thead tr {
  background: var(--bg-surface2) !important;
}

table.trade-table thead th {
  background: transparent !important;
  color: var(--text-muted) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.09em !important;
  padding: 10px 12px !important;
  border-bottom: 1px solid var(--border-color) !important;
  white-space: nowrap;
}

table.trade-table tbody tr.trade-row {
  background: transparent !important;
  transition: background 0.15s ease;
}

table.trade-table tbody tr.trade-row:hover {
  background: var(--bg-surface2) !important;
}

table.trade-table tbody tr.trade-row td {
  padding: 11px 12px !important;
  border-bottom: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  font-size: 13px !important;
  vertical-align: middle !important;
  background: transparent !important;
}

table.trade-table tbody tr.trade-row:last-child td {
  border-bottom: none !important;
}

/* ID column */
table.trade-table tbody td:first-child {
  color: var(--text-muted) !important;
  font-size: 11px !important;
  font-weight: 500;
  width: 28px;
}

/* Coin name column */
table.trade-table tbody td:nth-child(2) span {
  font-weight: 500;
  color: var(--text-primary) !important;
  font-size: 12px;
}

/* Price column */
td.live-price {
  font-weight: 600 !important;
  color: var(--text-primary) !important;
  font-size: 12px !important;
  white-space: nowrap;
}

/* Percent column — auto-colors via JS */
td.live-percent {
  white-space: nowrap;
}

td.live-percent .val {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  background: var(--green-bg);
  color: var(--green);
}

/* Flash animations for live price updates */
@keyframes flashGreen {
  0%   { background: rgba(0,192,118,0.25); }
  100% { background: transparent; }
}
@keyframes flashRed {
  0%   { background: rgba(246,70,93,0.25); }
  100% { background: transparent; }
}

tr.flash-green {
  animation: flashGreen 0.8s ease-out forwards;
}
tr.flash-red {
  animation: flashRed 0.8s ease-out forwards;
}

/* ═══════════════════════════════════════════════════
   PREMIUM WALLET CARD
   ═══════════════════════════════════════════════════ */

/* Override base wallet-card */
.wallet-card {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 18px !important;
  box-shadow: var(--shadow) !important;
}

.wallet-card .balance .left .title,
.wallet-card .balance .title {
  color: var(--text-secondary) !important;
}

.wallet-card .balance .left .total,
.wallet-card .balance .total {
  color: var(--text-primary) !important;
}

.wallet-card .wallet-footer {
  border-top: 1px solid var(--border-color) !important;
  background: transparent !important;
}

.wallet-card .wallet-footer .item a {
  color: var(--text-secondary) !important;
}

.wallet-card .wallet-footer .item strong {
  color: var(--text-secondary) !important;
}

/* ─── New Premium Card ─── */
.premium-wallet-card {
  position: relative;
  overflow: hidden;
  background: linear-gradient(145deg, #0f1923 0%, #162231 50%, #0d1a26 100%);
  border: 1px solid rgba(0,201,167,0.15);
  border-radius: 20px;
  padding: 24px 20px 18px;
  box-shadow:
    0 8px 32px rgba(0,0,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

/* Decorative glow orbs */
.wallet-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.35;
  pointer-events: none;
}
.wallet-orb-1 {
  width: 140px; height: 140px;
  background: #00C9A7;
  top: -40px; right: -20px;
}
.wallet-orb-2 {
  width: 100px; height: 100px;
  background: #3B82F6;
  bottom: -30px; left: -10px;
}

/* Top row */
.wallet-top-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  z-index: 1;
}

.wallet-greeting {
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 4px 0;
}

.wallet-balance {
  color: #fff !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em;
  margin: 0 0 6px 0;
  line-height: 1.1;
}

.wallet-badge-live {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  color: var(--green);
  background: var(--green-bg);
  border: 1px solid rgba(0,192,118,0.3);
  padding: 2px 8px;
  border-radius: 999px;
  animation: pulseLive 2s ease-in-out infinite;
}

@keyframes pulseLive {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

/* Referral pill */
.wallet-refer-pill {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}

.refer-label {
  color: var(--text-muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.refer-value {
  color: var(--accent);
  font-size: 16px;
  font-weight: 700;
}

/* Divider */
.wallet-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,201,167,0.25), transparent);
  margin: 16px 0;
  position: relative;
  z-index: 1;
}

/* Action buttons row */
.wallet-actions-row {
  display: flex;
  justify-content: space-around;
  position: relative;
  z-index: 1;
}

.wallet-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-decoration: none !important;
  color: var(--text-secondary) !important;
  font-size: 11px;
  font-weight: 500;
  transition: all 0.2s ease;
}

.wallet-action-btn:hover,
.wallet-action-btn:active {
  color: #fff !important;
  transform: translateY(-2px);
}

.wallet-action-icon {
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  font-size: 22px;
  transition: all 0.2s ease;
}

.deposit-icon {
  background: rgba(0,192,118,0.12);
  color: var(--green);
  border: 1px solid rgba(0,192,118,0.25);
}
.deposit-icon:hover { box-shadow: 0 0 16px rgba(0,192,118,0.3); }

.withdraw-icon {
  background: rgba(246,70,93,0.12);
  color: var(--red);
  border: 1px solid rgba(246,70,93,0.25);
}

.share-icon {
  background: rgba(240,165,0,0.12);
  color: var(--accent-orange);
  border: 1px solid rgba(240,165,0,0.25);
}

.history-icon {
  background: rgba(59,130,246,0.12);
  color: #3B82F6;
  border: 1px solid rgba(59,130,246,0.25);
}

/* ═══════════════════════════════════════════════════
   COMMUNITY SECTION
   ═══════════════════════════════════════════════════ */

.community-section {
  background: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 16px;
  overflow: hidden;
}

.community-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px 10px;
}

.community-title {
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 600;
}

.community-badge {
  font-size: 10px;
  font-weight: 700;
  color: var(--green);
  background: var(--green-bg);
  border: 1px solid rgba(0,192,118,0.3);
  padding: 2px 10px;
  border-radius: 999px;
  letter-spacing: 0.05em;
}

.community-links {
  display: flex;
  flex-direction: column;
}

.community-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-top: 1px solid var(--border-color);
  text-decoration: none !important;
  color: var(--text-primary) !important;
  font-size: 13px;
  font-weight: 500;
  transition: background 0.15s ease;
}

.community-link:hover {
  background: var(--bg-surface2) !important;
}

.community-link span {
  flex: 1;
}

.community-arrow {
  color: var(--text-muted);
  font-size: 16px;
}

.community-icon-wrap {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  font-size: 18px;
}

.whatsapp-link .community-icon-wrap {
  background: rgba(37,211,102,0.12);
  color: #25D366;
  border: 1px solid rgba(37,211,102,0.25);
}

.telegram-link .community-icon-wrap {
  background: rgba(0,136,204,0.12);
  color: #0088cc;
  border: 1px solid rgba(0,136,204,0.25);
}

.youtube-link .community-icon-wrap {
  background: rgba(255,0,0,0.12);
  color: #FF4444;
  border: 1px solid rgba(255,0,0,0.25);
}

/* ─── Stat Box override ─── */
.stat-box {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 14px !important;
  color: var(--text-primary) !important;
}

/* ─── Section Heading override ─── */
.section-heading .title {
  color: var(--text-primary) !important;
}

.section-heading .link {
  color: var(--accent) !important;
}

/* ═══════════════════════════════════════════════════
   ACTION-SHEET MODALS (Deposit / Withdraw)
   ═══════════════════════════════════════════════════ */

.action-sheet .modal-dialog,
.action-sheet .modal-content {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 20px 20px 0 0 !important;
  color: var(--text-primary) !important;
}

.action-sheet .modal-header {
  border-bottom: 1px solid var(--border-color) !important;
  padding: 16px 20px 12px;
}

.action-sheet .modal-title {
  color: var(--text-primary) !important;
  font-size: 16px;
  font-weight: 600;
}

.action-sheet .modal-body {
  background: var(--bg-surface) !important;
}

/* ─── Form inputs inside modals ─── */
.action-sheet .form-control,
.action-sheet select.form-control,
.action-sheet .custom-select {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: 10px !important;
}

.action-sheet .form-control:focus,
.action-sheet select.form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-glow) !important;
}

.action-sheet .input-group-text {
  background: var(--bg-surface3) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-secondary) !important;
}

.action-sheet label.label {
  color: var(--text-secondary) !important;
  font-size: 12px;
  font-weight: 500;
}

/* ─── Deposit quick-amount buttons ─── */
.action-sheet .depositBTN {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: 8px !important;
  font-size: 12px !important;
  padding: 6px 12px !important;
  transition: all 0.15s ease;
}

.action-sheet .depositBTN:hover,
.action-sheet .depositBTN:active {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  background: var(--accent-glow) !important;
}

/* ─── Submit / primary button override ─── */
.action-sheet .btn-primary {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #000 !important;
  font-weight: 700 !important;
  border-radius: 12px !important;
  letter-spacing: 0.02em;
}

.action-sheet .btn-primary:hover {
  background: #00b896 !important;
  box-shadow: 0 4px 16px var(--accent-glow) !important;
}

.action-sheet .btn-primary:disabled {
  background: var(--bg-surface3) !important;
  border-color: var(--border-color) !important;
  color: var(--text-muted) !important;
}

/* ═══════════════════════════════════════════════════
   DIALOGBOX MODALS (success / error)
   ═══════════════════════════════════════════════════ */

.dialogbox .modal-content {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: 18px !important;
}

.dialogbox .modal-footer {
  border-top: 1px solid var(--border-color) !important;
  background: var(--bg-surface) !important;
  padding: 0 !important;
}

.dialogbox .modal-footer button[type="submit"],
.dialogbox .modal-footer a.btn-text-primary {
  color: var(--accent) !important;
}

.dialogbox .modal-footer button[data-bs-dismiss="modal"],
.dialogbox .modal-footer a.btn-text-secondary {
  color: var(--text-muted, #8A97A8) !important;
}

.dialogbox .icon-wrapper {
  color: var(--green) !important;
}

/* ═══════════════════════════════════════════════════
   SPLIDE / SLICK CAROUSEL SLIDER
   ═══════════════════════════════════════════════════ */

.carousel-single .splide__slide img,
.carousel-single .slick-slide img {
  border-radius: 12px;
  border: 1px solid var(--border-color);
}

.splide__arrow {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
}

.splide__arrow svg {
  fill: var(--text-secondary) !important;
}

.splide__pagination__page {
  background: var(--text-muted) !important;
}

.splide__pagination__page.is-active {
  background: var(--accent) !important;
  transform: scale(1.25);
}

/* ═══════════════════════════════════════════════════
   TABLE — row hover
   ═══════════════════════════════════════════════════ */

.trade-table tbody tr.trade-row:hover {
  background: var(--bg-surface2) !important;
  cursor: pointer;
}

/* ─── Coin icon container ─── */
.coin-icon-wrap {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.05);
  border-radius: 6px;
  padding: 2px;
}

/* ─── Live-percent pill base ─── */
.live-percent .val {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  background: rgba(255,255,255,0.07);
  color: var(--text-secondary);
}

/* ─── Live-price value ─── */
.live-price .val {
  font-weight: 500;
  color: var(--text-primary);
}

/* ═══════════════════════════════════════════════════
   SIDEBAR PANEL (panelbox)
   ═══════════════════════════════════════════════════ */

.panelbox .modal-dialog,
.panelbox .modal-content {
  background: var(--bg-surface) !important;
  border-right: 1px solid var(--border-color) !important;
}

.panelbox .modal-body {
  background: var(--bg-surface) !important;
  padding: 0 !important;
}

/* ─── Profile box at top of sidebar ─── */
.profileBox {
  background: linear-gradient(135deg, #0f1923, #162231) !important;
  border-bottom: 1px solid var(--border-color) !important;
  padding: 14px 16px !important;
  display: flex;
  align-items: center;
  gap: 12px;
}

.profileBox strong {
  color: var(--text-primary) !important;
  font-size: 14px;
  font-weight: 600;
}

.profileBox .text-muted {
  color: var(--text-muted) !important;
  font-size: 11px;
}

.profileBox .image-wrapper img {
  border: 2px solid rgba(0,201,167,0.4);
  border-radius: 50%;
}

.profileBox .sidebar-close {
  color: var(--text-muted) !important;
  margin-left: auto;
}

/* ─── Sidebar balance ─── */
.sidebar-balance {
  background: var(--bg-surface2) !important;
  border-bottom: 1px solid var(--border-color) !important;
  padding: 12px 16px !important;
}

.sidebar-balance .listview-title {
  color: var(--text-muted) !important;
  font-size: 11px !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0 0 4px !important;
}

.sidebar-balance .amount {
  color: var(--text-primary) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
}

/* ─── Listview section titles ─── */
.listview-title {
  color: var(--text-muted) !important;
  font-size: 11px !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 12px 16px 6px !important;
  background: transparent !important;
}

/* ─── Listview items ─── */
.listview.flush .item,
.listview .item {
  background: transparent !important;
  color: var(--text-primary) !important;
  border-bottom: 1px solid var(--border-color) !important;
  padding: 12px 16px !important;
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none !important;
  transition: background 0.15s ease;
}

.listview .item:hover {
  background: var(--bg-surface2) !important;
}

.listview .item .in {
  color: var(--text-primary) !important;
  font-size: 14px;
  font-weight: 500;
}

/* ─── Icon boxes inside sidebar ─── */
.listview .icon-box {
  width: 36px !important;
  height: 36px !important;
  border-radius: 10px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Override Bootstrap bg-primary icon boxes with accent teal */
.listview .icon-box.bg-primary {
  background: rgba(0,201,167,0.15) !important;
  border: 1px solid rgba(0,201,167,0.25) !important;
  color: var(--accent) !important;
}

.listview .icon-box.bg-primary ion-icon {
  color: var(--accent) !important;
  font-size: 18px;
}

/* ─── Logout / danger icon box ─── */
.listview .icon-box.bg-danger {
  background: rgba(246,70,93,0.12) !important;
  border: 1px solid rgba(246,70,93,0.25) !important;
  color: var(--red) !important;
}

.listview .icon-box.bg-danger ion-icon {
  color: var(--red) !important;
}

/* ─── Sidebar close backdrop ─── */
.panelbox .modal-backdrop {
  background: rgba(0,0,0,0.7) !important;
}

/* ═══════════════════════════════════════════════════
   TOASTR notification override
   ═══════════════════════════════════════════════════ */

#toast-container .toast {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 12px !important;
  box-shadow: var(--shadow) !important;
  color: var(--text-primary) !important;
  opacity: 1 !important;
}

#toast-container .toast-success {
  border-left: 3px solid var(--green) !important;
}

#toast-container .toast-error {
  border-left: 3px solid var(--red) !important;
}

#toast-container .toast-title {
  color: var(--text-primary) !important;
  font-weight: 600;
}

#toast-container .toast-message {
  color: var(--text-secondary) !important;
}

/* ═══════════════════════════════════════════════════
   AUTH PAGES (Login / Register)
   ═══════════════════════════════════════════════════ */

.auth-header {
  padding: 30px 20px 20px;
}

.auth-header .logo {
  max-height: 52px;
  max-width: 80%;
  width: auto;
  object-fit: contain;
  filter: brightness(1.1) drop-shadow(0 0 10px rgba(0,201,167,0.3));
  margin-bottom: 24px;
}

.auth-header h1 {
  color: #fff !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}

.auth-header h4 {
  color: var(--text-secondary) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
}

.auth-card {
  background: var(--bg-surface) !important;
  border: 1px solid var(--border-color) !important;
  border-radius: 20px !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5) !important;
  padding: 10px 0;
}

.auth-card .form-control {
  background: var(--bg-surface2) !important;
  border: 1px solid var(--border-color) !important;
  color: var(--text-primary) !important;
  border-radius: 12px !important;
  padding: 12px 16px !important;
  font-size: 15px;
}

.auth-card .form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-glow) !important;
}

.auth-card label.label {
  color: var(--text-secondary) !important;
  font-size: 12px;
  font-weight: 500;
  margin-bottom: 6px;
}

.auth-btn {
  background: var(--accent) !important;
  border: none !important;
  color: #000 !important;
  font-weight: 700 !important;
  border-radius: 12px !important;
  letter-spacing: 0.02em;
  padding: 14px !important;
  box-shadow: 0 4px 16px var(--accent-glow) !important;
  transition: all 0.2s ease;
  font-size: 16px;
}

.auth-btn:hover, .auth-btn:active {
  background: #00b896 !important;
  transform: translateY(-2px);
}

/* Hide old violet background from legacy style.css */
.wallet-card-section:before {
  display: none !important;
}

/* Remove legacy purple background from trade page header */
.gradientSection {
  background: transparent !important;
  background-image: none !important;
}

/* ═══════════════════════════════════════════════════
   FIX: Text clipping in form inputs (descenders cut off)
   Root cause: style.css sets height:40px with padding:0
   on .form-group.basic .form-control — no room for descenders
   ═══════════════════════════════════════════════════ */

.form-group.basic .form-control,
.form-group.basic .custom-select,
.form-group.basic select.form-control {
  height: auto !important;
  min-height: 44px !important;
  padding: 10px 36px 10px 12px !important;
  line-height: 1.5 !important;
  border-radius: 10px !important;
  border: 1px solid var(--border-color) !important;
  border-bottom: 1px solid var(--border-color) !important;
  background: var(--bg-surface2) !important;
  color: var(--text-primary) !important;
  font-size: 14px !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

.form-group.basic .form-control:focus,
.form-group.basic select.form-control:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px var(--accent-glow) !important;
  outline: none !important;
}

/* Input group (Rs prefix box) */
.form-group.basic .input-group .input-group-text {
  height: auto !important;
  min-height: 44px !important;
  padding: 10px 14px !important;
  line-height: 1.5 !important;
  border-radius: 10px 0 0 10px !important;
  border: 1px solid var(--border-color) !important;
  background: var(--bg-surface3) !important;
  color: var(--text-secondary) !important;
  font-weight: 600;
}

.form-group.basic .input-group .form-control {
  border-radius: 0 10px 10px 0 !important;
}

/* Label above inputs */
.form-group.basic .label,
.form-group.basic label.label {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--text-secondary) !important;
  margin-bottom: 6px !important;
  display: block !important;
}

/* Spacing between form groups */
.action-sheet-content .form-group.basic {
  padding: 6px 0 !important;
}

/* ═══════════════════════════════════════════════════
   CUSTOM DROPDOWN (replaces native <select>)
   ═══════════════════════════════════════════════════ */

.custom-dropdown {
  position: relative;
  width: 100%;
  user-select: none;
  -webkit-user-select: none;
}

.custom-dropdown-selected {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  background: var(--bg-surface2);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.2s;
  min-height: 44px;
}

.custom-dropdown-selected:hover,
.custom-dropdown.open .custom-dropdown-selected {
  border-color: var(--accent);
}

.custom-dropdown-arrow {
  font-size: 16px;
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}

.custom-dropdown.open .custom-dropdown-arrow {
  transform: rotate(180deg);
}

.custom-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--bg-surface2);
  border: 1px solid var(--border-color);
  border-radius: 12px;
  overflow: hidden;
  z-index: 9999;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}

.custom-dropdown.open .custom-dropdown-menu {
  display: block;
}

.custom-dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 16px;
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
  border-bottom: 1px solid var(--border-color);
}

.custom-dropdown-item:last-child {
  border-bottom: none;
}

.custom-dropdown-item:hover {
  background: var(--bg-surface3);
}

.custom-dropdown-item.active {
  background: var(--accent-glow);
  color: var(--accent);
}

.custom-dropdown-item ion-icon {
  font-size: 18px;
  flex-shrink: 0;
  color: var(--text-secondary);
}

.custom-dropdown-item.active ion-icon {
  color: var(--accent);
}

.dropdown-badge {
  margin-left: auto;
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  background: var(--accent-glow);
  padding: 2px 8px;
  border-radius: 20px;
}

/* ═══════════════════════════════════════════════════
   FIX: Logo sizes across all contexts
   ═══════════════════════════════════════════════════ */

/* App header top bar logo */
.appHeader .pageTitle {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.appHeader .pageTitle .logo {
  max-height: none !important;
  height: 44px !important;
  width: 160px !important;
  object-fit: contain !important;
  display: block !important;
}

/* Login / register page logo */
.auth-logo {
  display: block !important;
  width: 200px !important;
  height: auto !important;
  max-height: none !important;
  margin: 0 auto 16px !important;
  object-fit: contain !important;
}

/* Loading spinner logo */
#loader .loading-icon {
  width: 100px !important;
  height: 100px !important;
  object-fit: contain !important;
}

/* Footer add-to-home modal logo */
.imaged.w64 {
  width: 80px !important;
  height: 80px !important;
  object-fit: contain !important;
}

/* ── Header height increase for logo visibility ── */
.dark-app-header.appHeader,
.appHeader.dark-app-header {
  height: 56px !important;
}

.appHeader .pageTitle {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}

.appHeader .pageTitle img {
  max-height: none !important;
  height: 150px !important;
  width: 200px !important;
  object-fit: contain !important;
  display: block !important;
}

/* ── Dashboard header height to fit logo ── */
.dark-app-header.appHeader {
  height: 60px !important;
  min-height: 60px !important;
}
.dark-app-header.appHeader .left,
.dark-app-header.appHeader .right {
  height: 60px !important;
}

/* ─── App Footer ─── */
.appFooter {
  background: var(--bg-surface) !important;
  color: var(--text-secondary) !important;
  border-top: 1px solid var(--border-color) !important;
}

.appFooter .footer-title {
  color: var(--text-secondary) !important;
}

/* ─── Profile Page — listview items ─── */
.listview.image-listview.text.inset.no-line,
.listview.image-listview.text.inset {
  background: var(--bg-surface) !important;
  border-radius: 14px !important;
  border: 1px solid var(--border-color) !important;
}

.listview.image-listview.text .item,
.listview.flush.transparent.no-line .item {
  background: transparent !important;
  color: var(--text-primary) !important;
}

.listview.image-listview.text .in,
.listview .in {
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

/* ─── Sidebar panel ─── */
.panelbox .modal-content {
  background: var(--bg-surface) !important;
}

.panelbox .listview-title {
  color: var(--text-muted) !important;
}

.panelbox .listview.flush.transparent.no-line.image-listview .item .in {
  color: var(--text-primary) !important;
}

/* ─── crypto_trade interval tabs ─── */
.btn-outline-primary {
  color: var(--accent) !important;
  border-color: var(--accent) !important;
  background: transparent !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:active {
  background: var(--accent) !important;
  color: #000 !important;
}

/* ─── App Header bg-primary fallback override ─── */
.appHeader.bg-primary {
  background: var(--bg-surface) !important;
  border-bottom: 1px solid var(--border-color) !important;
}
