/* ══════════════════════════════════════════
   DESIGN TOKENS
══════════════════════════════════════════ */
:root {
  --primary:       #5B47FB;
  --primary-dark:  #4535E8;
  --primary-glow:  rgba(91,71,251,.18);
  --primary-light: #EEF0FF;
  --accent:        #F43F5E;
  --accent-light:  #FFF0F3;
  --success:       #10B981;
  --success-bg:    #ECFDF5;
  --success-text:  #065F46;
  --warning:       #F59E0B;
  --warning-bg:    #FFFBEB;
  --warning-text:  #92400E;
  --danger:        #EF4444;
  --danger-bg:     #FEF2F2;
  --danger-text:   #991B1B;
  --info:          #3B82F6;
  --info-bg:       #EFF6FF;
  --info-text:     #1E40AF;

  --white:         #FFFFFF;
  --sidebar-bg:    #0D1526;
  --sidebar-w:     264px;
  --topbar-h:      60px;

  --surface:       #F3F4F8;
  --card:          #FFFFFF;
  --border:        #E5E7EB;
  --border-strong: #D1D5DB;

  --text:          #0F172A;
  --text-2:        #4B5563;
  --text-3:        #9CA3AF;

  --sh-xs: 0 1px 2px rgba(0,0,0,.04);
  --sh-sm: 0 1px 4px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.04);
  --sh-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);
  --sh-lg: 0 12px 40px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);
  --sh-xl: 0 24px 64px rgba(0,0,0,.16);

  --r-sm:  6px;
  --r-md:  10px;
  --r-lg:  14px;
  --r-xl:  20px;
  --ease:  cubic-bezier(.4,0,.2,1);
  --dur:   .2s;
}

/* ══════════════════════════════════════════
   BASE
══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:14px}
body{background:var(--surface);color:var(--text);font-family:'DM Sans',system-ui,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:'Sora',sans-serif;font-weight:700;letter-spacing:-.3px}
code,pre,.mono{font-family:'DM Mono',monospace}
a{text-decoration:none;color:inherit}
img{display:block}
input,select,textarea,button{font-family:inherit;font-size:inherit}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#CBD5E1;border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:#94A3B8}

/* ══════════════════════════════════════════
   UTILS
══════════════════════════════════════════ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.25rem}
.flex{display:flex}
.flex-center{display:flex;align-items:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-col{display:flex;flex-direction:column}
.gap-1{gap:.5rem}.gap-2{gap:.75rem}.gap-3{gap:1rem}
.w-0{width:0}.w-1{width:.25rem}.w-2{width:.5rem}.w-4{width:1rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-16{width:4rem}.w-32{width:8rem}.w-64{width:16rem}.w-full{width:100%}.w-screen{width:100vw}
.h-0{height:0}.h-1{height:.25rem}.h-2{height:.5rem}.h-4{height:1rem}.h-8{height:2rem}.h-16{height:4rem}.h-32{height:8rem}.h-64{height:16rem}.h-full{height:100%}.h-screen{height:100vh}
.m-0{margin:0}.m-1{margin:.25rem}.m-2{margin:.5rem}.m-3{margin:.75rem}.m-4{margin:1rem}.m-5{margin:1.25rem}.m-6{margin:1.5rem}.m-8{margin:2rem}.m-10{margin:2.5rem}.m-12{margin:3rem}.m-16{margin:4rem}.m-20{margin:5rem}.m-24{margin:6rem}.m-32{margin:8rem}.m-auto{margin:auto}
.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-7{margin-top:2rem}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-7{margin-bottom:2rem}
.ml-0{margin-left:0}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-5{margin-left:1.25rem}.ml-6{margin-left:1.5rem}.ml-7{margin-left:2rem}
.mr-0{margin-right:0}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.mr-5{margin-right:1.25rem}.mr-6{margin-right:1.5rem}.mr-7{margin-right:2rem}
.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-10{padding:2.5rem}.p-12{padding:3rem}.p-16{padding:4rem}.p-20{padding:5rem}.p-24{padding:6rem}.p-32{padding:8rem}
.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-7{padding-top:2rem}
.pb-0{padding-bottom:0}.pb-1{padding-bottom:.25rem}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}.pb-6{padding-bottom:1.5rem}.pb-7{padding-bottom:2rem}
.pl-0{padding-left:0}.pl-1{padding-left:.25rem}.pl-2{padding-left:.5rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pl-5{padding-left:1.25rem}.pl-6{padding-left:1.5rem}.pl-7{padding-left:2rem}
.pr-0{padding-right:0}.pr-1{padding-right:.25rem}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pr-5{padding-right:1.25rem}.pr-6{padding-right:1.5rem}.pr-7{padding-right:2rem}

.text-xs { font-size: 0.75rem; /* 12px */ }
.text-sm { font-size: 0.875rem; /* 14px */ }
.text-base { font-size: 1rem; /* 16px */ }
.text-lg { font-size: 1.125rem; /* 18px */ }
.text-xl { font-size: 1.25rem; /* 20px */ }
.text-2xl { font-size: 1.5rem; /* 24px */ }
.text-3xl { font-size: 1.875rem; /* 30px */ }
.text-4xl { font-size: 2.25rem; /* 36px */ }
.text-5xl { font-size: 3rem; /* 48px */ }
.text-6xl { font-size: 3.75rem; /* 60px */ }
.text-7xl { font-size: 4.5rem; /* 72px */ }
.text-8xl { font-size: 6rem; /* 96px */ }
.text-9xl { font-size: 8rem; /* 128px */ }

.text-right { text-align: right!important; }
.text-center { text-align: center!important; }
.text-left { text-align: left!important; }
.text-justify { text-align: justify!important; }

.font-thin         { font-weight: 100 !important; } /* very thin */
.font-extra-light  { font-weight: 200 !important; } /* extra light */
.font-light        { font-weight: 300 !important; } /* light */
.font-normal       { font-weight: 400 !important; } /* normal / regular */
.font-medium       { font-weight: 500 !important; } /* medium */
.font-semibold     { font-weight: 600 !important; } /* semi-bold / demi-bold */
.font-bold         { font-weight: 700 !important; } /* bold */
.font-extra-bold   { font-weight: 800 !important; } /* extra bold / ultra-bold */
.font-black        { font-weight: 900 !important; } /* black / heavy */

.text-muted{color:var(--text-3)}
.text-1 { color: var(--text); }
.text-2{color:var(--text-2)}
.text-white{color:var(--white)}
.text-primary{color:var(--primary)}
.text-success{color:var(--success)}
.text-danger{color:var(--danger)}
.text-warning{color:var(--warning)}

.mono{font-family:'DM Mono',monospace}
.truncate{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}

/* ══════════════════════════════════════════
   BORDER-RADIUS UTILS
══════════════════════════════════════════ */
.radius-sm {border-radius: 4px;} /* Küçük yuvarlama */
.radius-md {border-radius: 8px;} /* Orta yuvarlama */
.radius-lg {border-radius: 16px;} /* Büyük yuvarlama */
.radius-full {border-radius: 50%;} /* Tam yuvarlama (circle) */
.radius-xl {border-radius: 32px;} /* Çok büyük yuvarlama (super-large) */
.radius-tl {border-top-left-radius: 8px;} /* Sadece üst sol köşe yuvarlama */
.radius-tr {border-top-right-radius: 8px;} /* Sadece üst sağ köşe yuvarlama */
.radius-bl {border-bottom-left-radius: 8px;} /* Sadece alt sol köşe yuvarlama */
.radius-br {border-bottom-right-radius: 8px;} /* Sadece alt sağ köşe yuvarlama */

/* ══════════════════════════════════════════
   DISPLAY
══════════════════════════════════════════ */
.text-center {text-align:center;}
.block {display: block!important;}
.inline-block {display: inline-block;}
.inline {display: inline;}
.flex {display: flex;}
.grid {display: grid;}
.hidden {display: none!important;}
.inline-flex {display: inline-flex;}
.inline-grid {display: inline-grid;}

/* ══════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════ */
.app-topbar{
  position:fixed;top:0;left:0;right:0;height:var(--topbar-h);
  background:var(--sidebar-bg);
  border-bottom:1px solid rgba(255,255,255,.05);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 1.25rem;z-index:200;gap:1rem;
}
.app-sidebar{
  position:fixed;top:var(--topbar-h);left:0;
  width:var(--sidebar-w);height:calc(100vh - var(--topbar-h));
  background:var(--sidebar-bg);
  border-right:1px solid rgba(255,255,255,.04);
  display:flex;flex-direction:column;
  overflow-y:auto;overflow-x:hidden;
  z-index:150;
  transition:transform .3s var(--ease);
}
.app-main{
  margin-left:var(--sidebar-w);
  padding:calc(var(--topbar-h) + 2rem) 2rem 2rem;
  min-height:100vh;min-width:0;
  transition:margin-left .3s var(--ease);
}
.mobile-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  z-index:140;opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease);backdrop-filter:blur(2px);
}
.mobile-overlay.show{opacity:1;pointer-events:all}

/* ══════════════════════════════════════════
   TOPBAR
══════════════════════════════════════════ */
.tb-brand{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.tb-logo{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary),#7C3AED);
  display:flex;align-items:center;justify-content:center;
  font-family:'Sora',sans-serif;font-weight:800;font-size:13px;color:#fff;
  box-shadow:0 2px 10px rgba(91,71,251,.4);flex-shrink:0;
}
.tb-name{color:#fff;font-family:'Sora',sans-serif;font-weight:700;font-size:15px}
.tb-center{flex:1;display:flex;justify-content:center}
.tb-balance{
  display:flex;align-items:center;gap:.5rem;
  padding:.4rem .85rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-md);
}
.tb-balance-label{color:rgba(255,255,255,.4);font-size:12px}
.tb-balance-value{color:#fff;font-weight:700;font-size:13.5px;font-family:'Sora',sans-serif}
.tb-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.tb-btn{
  width:36px;height:36px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.6);cursor:pointer;transition:all var(--dur) var(--ease);
  position:relative;
}
.tb-btn:hover{background:rgba(255,255,255,.12);color:#fff}
.tb-btn .dot{
  position:absolute;top:-3px;right:-3px;
  width:14px;height:14px;background:var(--accent);
  border-radius:50%;border:2px solid var(--sidebar-bg);
  font-size:8px;font-weight:700;color:#fff;
  display:flex;align-items:center;justify-content:center;
}
.tb-user{
  display:flex;align-items:center;gap:.55rem;
  padding:.3rem .65rem .3rem .4rem;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r-md);cursor:pointer;transition:all var(--dur) var(--ease);
}
.tb-user:hover{background:rgba(255,255,255,.11)}
.tb-avatar{
  width:30px;height:30px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),#7C3AED);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;flex-shrink:0;
}
.tb-uname{color:#fff;font-size:12.5px;font-weight:600;line-height:1.2}
.tb-urole{color:rgba(255,255,255,.4);font-size:10.5px}

/* ══════════════════════════════════════════
   SIDEBAR NAV
══════════════════════════════════════════ */
.sb-nav{padding:1rem .75rem;flex:1}
.sb-label{
  font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;
  color:rgba(255,255,255,.22);padding:.75rem .75rem .3rem;margin-top:.5rem;
  display:block;
}
.sb-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:.55rem .75rem;border-radius:var(--r-md);
  color:rgba(255,255,255,.5);font-size:13px;font-weight:500;
  cursor:pointer;margin-bottom:1px;gap:.55rem;
  border:1px solid transparent;
  transition:all var(--dur) var(--ease);user-select:none;
}
.sb-item:hover{background:rgba(255,255,255,.055);color:rgba(255,255,255,.85)}
.sb-item.active{background:rgba(91,71,251,.2);color:#fff;border-color:rgba(91,71,251,.3)}
.sb-item.active .sb-icon{color:#A5B4FC}
.sb-item-l{display:flex;align-items:center;gap:.6rem}
.sb-icon{width:16px;height:16px;flex-shrink:0;color:rgba(255,255,255,.3);transition:color var(--dur) var(--ease)}
.sb-item:hover .sb-icon{color:rgba(255,255,255,.65)}
.sb-chevron{
  width:14px;height:14px;color:rgba(255,255,255,.2);
  transition:transform .25s var(--ease);flex-shrink:0;
}
.sb-item.open .sb-chevron{transform:rotate(90deg)}
.sb-badge{
  background:var(--accent);color:#fff;font-size:9px;font-weight:700;
  padding:1px 5px;border-radius:99px;min-width:16px;text-align:center;
  line-height:1.6;flex-shrink:0;
}
.sb-badge.warn{background:var(--warning)}
.sb-sub{
  max-height:0;overflow:hidden;
  transition:max-height .3s var(--ease);
  margin-left:1rem;padding-left:.5rem;
  border-left:1px solid rgba(255,255,255,.07);
}
.sb-sub.open{max-height:300px}
.sb-subitem{
  display:flex;align-items:center;gap:.5rem;
  padding:.38rem .6rem;border-radius:var(--r-sm);
  color:rgba(255,255,255,.4);font-size:12.5px;
  cursor:pointer;margin-bottom:1px;
  transition:all var(--dur) var(--ease);
}
.sb-subitem:hover{color:rgba(255,255,255,.75);background:rgba(255,255,255,.05)}
.sb-subitem.active{color:#A5B4FC}
.sb-subitem::before{content:'';width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.6;flex-shrink:0}
.sb-footer{padding:.75rem;border-top:1px solid rgba(255,255,255,.06)}
.sb-logout{
  display:flex;align-items:center;gap:.6rem;
  padding:.55rem .75rem;border-radius:var(--r-md);
  color:rgba(248,113,113,.65);font-size:13px;font-weight:500;
  cursor:pointer;transition:all var(--dur) var(--ease);
}
.sb-logout:hover{background:rgba(248,113,113,.09);color:#F87171}

/* ══════════════════════════════════════════
   PAGE HEADER
══════════════════════════════════════════ */
.page-head{margin-bottom:1.75rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.page-title{font-size:22px;font-weight:800;letter-spacing:-.5px;line-height:1.2}
.page-title h2 {
    font-family: 'Sora', sans-serif;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text);
    margin-bottom: 0.25rem;
}
.page-title p {
    font-size: 0.875rem;
    color: var(--text-3);
}
.page-sub{font-size:13px;color:var(--text-2);margin-top:.25rem}
.breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:12px;color:var(--text-3);margin-bottom:.35rem}
.breadcrumb span{color:var(--text-3)}

/* ══════════════════════════════════════════
   CARDS
══════════════════════════════════════════ */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid var(--border)}
.card-title{font-size:14.5px;font-weight:700;font-family:'Sora',sans-serif}
.card-subtitle{font-size:12px;color:var(--text-3);margin-top:2px}
.card-body{padding:1.4rem}
.card-footer{padding:1rem 1.4rem;border-top:1px solid var(--border);background:#FAFBFC;border-radius:0 0 var(--r-lg) var(--r-lg)}

/* ══════════════════════════════════════════
   STAT CARDS
══════════════════════════════════════════ */
.stat-grid-1{display:grid;grid-template-columns:repeat(1,1fr);gap:1rem;margin-bottom:1.5rem}
.stat-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}
.stat-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}
.stat-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}
.stat-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:1.2rem 1.4rem;
  transition:all var(--dur) var(--ease);cursor:default;
  position:relative;overflow:hidden;
}
.stat-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.stat-card::before{
  content:'';position:absolute;top:-20px;right:-20px;
  width:80px;height:80px;border-radius:50%;
  background:var(--icon-bg,#EEF0FF);opacity:.5;
}
.stat-icon{
  width:40px;height:40px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:.85rem;flex-shrink:0;
}
.stat-val{font-size:26px;font-weight:800;font-family:'Sora',sans-serif;letter-spacing:-1px;line-height:1;margin-bottom:.25rem}
.stat-label{font-size:12px;color:var(--text-3);font-weight:500}
.stat-trend{font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:3px;margin-top:.4rem;padding:.15rem .5rem;border-radius:99px}
.trend-up{color:#065F46;background:#D1FAE5}
.trend-dn{color:#991B1B;background:#FEE2E2}
.trend-neu{color:var(--text-3);background:#F3F4F8}

/* Stat Card Border Accent Colors */
.stat-card.accent-warning {
    border-left: 4px solid var(--warning) !important;
}

.stat-card.accent-danger {
    border-left: 4px solid var(--danger) !important;
}

.stat-card.accent-success {
    border-left: 4px solid var(--success) !important;
}

.stat-card.accent-primary {
    border-left: 4px solid var(--primary) !important;
}

.stat-card.accent-info {
    border-left: 4px solid var(--info) !important;
}

/* ══════════════════════════════════════════
   BALANCE CARD (hero)
══════════════════════════════════════════ */
.balance-card{
  background:linear-gradient(135deg,#0D1526 0%,#1a2744 50%,#0f1e38 100%);
  border-radius:var(--r-xl);padding:1.75rem;color:#fff;
  position:relative;overflow:hidden;
}
.balance-card::before{
  content:'';position:absolute;
  top:-60px;right:-60px;width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,71,251,.25),transparent 70%);
  pointer-events:none;
}
.balance-card::after{
  content:'';position:absolute;
  bottom:-40px;left:30px;width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(244,63,94,.12),transparent 70%);
  pointer-events:none;
}
.bc-label{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:rgba(255,255,255,.4);margin-bottom:.5rem;font-weight:600}
.bc-amount{font-size:40px;font-weight:800;font-family:'Sora',sans-serif;letter-spacing:-2px;line-height:1}
.bc-sub{font-size:13px;color:rgba(255,255,255,.5);margin-top:.5rem}
.bc-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:1}
.bc-btn{
  flex:1;padding:.65rem;border-radius:var(--r-md);
  font-size:13px;font-weight:600;cursor:pointer;
  transition:all var(--dur) var(--ease);border:none;
  display:flex;align-items:center;justify-content:center;gap:.4rem;
}
.bc-btn-primary{background:var(--primary);color:#fff}
.bc-btn-primary:hover{background:var(--primary-dark);box-shadow:0 4px 14px rgba(91,71,251,.4)}
.bc-btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.15)}
.bc-btn-ghost:hover{background:rgba(255,255,255,.18)}

/* ══════════════════════════════════════════
   TABLES
══════════════════════════════════════════ */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-lg);border:1px solid var(--border)}
.data-table{width:100%;border-collapse:collapse;font-size:13.5px}
.data-table thead th{
  background:#F9FAFB;padding:.7rem 1rem;
  text-align:left;font-size:11px;font-weight:700;
  letter-spacing:.6px;text-transform:uppercase;
  color:var(--text-3);border-bottom:1px solid var(--border);
  white-space:nowrap;
}
.data-table tbody tr{border-bottom:1px solid #F3F4F6;transition:background var(--dur) var(--ease)}
.data-table tbody tr:last-child{border-bottom:none}
.data-table tbody tr:hover{background:#F9FAFB}
.data-table td{padding:.8rem 1rem;color:var(--text);vertical-align:middle}
.table-empty{text-align:center;padding:3rem 1rem;color:var(--text-3)}
.table-empty .icon{font-size:2.5rem;margin-bottom:.75rem}
.table-empty .msg{font-size:14px;font-weight:600;color:var(--text-2);margin-bottom:.4rem}
.table-empty .hint{font-size:12.5px}

/* ══════════════════════════════════════════
   BADGES
══════════════════════════════════════════ */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:.22rem .65rem;border-radius:99px;
  font-size:11px;font-weight:700;letter-spacing:.2px;white-space:nowrap;
}
.badge::before{content:none;width:5px;height:5px;border-radius:50%;background:currentColor}
.badge-success{background:var(--success-bg);color:var(--success-text)}
.badge-danger{background:var(--danger-bg);color:var(--danger-text)}
.badge-warning{background:var(--warning-bg);color:var(--warning-text)}
.badge-info{background:var(--info-bg);color:var(--info-text)}
.badge-neutral{background:#F3F4F6;color:#6B7280}
.badge-primary{background:#EEF0FF;color:#4535E8}

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.55rem 1.1rem;border-radius:var(--r-md);
  font-size:13.5px;font-weight:500;cursor:pointer;
  transition:all var(--dur) var(--ease);border:1px solid transparent;
  white-space:nowrap;line-height:1.4;outline:none;
}
.btn:focus-visible{box-shadow:0 0 0 3px var(--primary-glow)}
.btn-sm{padding:.38rem .8rem;font-size:12.5px;border-radius:var(--r-sm)}
.btn-lg{padding:.75rem 1.5rem;font-size:15px}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 1px 4px rgba(91,71,251,.25)}
.btn-primary:hover{background:var(--primary-dark);box-shadow:0 4px 14px rgba(91,71,251,.35);transform:translateY(-1px)}
.btn-primary:active{transform:none}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#DC2626;transform:translateY(-1px)}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#059669;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text-2);border-color:var(--border)}
.btn-ghost:hover{background:#F9FAFB;color:var(--text);border-color:var(--border-strong)}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary-light)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn-icon{width:34px;height:34px;padding:0;border-radius:var(--r-sm)}
.btn-full{width:100%}
.loading-btn .spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}

/* ══════════════════════════════════════════
   FORMS
══════════════════════════════════════════ */
.form-group{margin-bottom:1.2rem}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:.4rem}
.form-label .req{color:var(--accent);margin-left:2px}
.form-control{
  width:100%;padding:.6rem .9rem;
  border:1.5px solid var(--border);border-radius:var(--r-md);
  font-size:13.5px;color:var(--text);background:#fff;
  transition:all var(--dur) var(--ease);outline:none;line-height:1.5;
}
.form-control:hover{border-color:var(--border-strong)}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.form-control::placeholder{color:var(--text-3)}
.form-control:disabled{background:#F9FAFB;cursor:not-allowed;color:var(--text-3)}
.form-control.is-invalid{border-color:var(--danger)}
.form-hint{font-size:12px;color:var(--text-3);margin-top:.3rem}
.form-error{font-size:12px;color:var(--danger);margin-top:.3rem;font-weight:500}
select.form-control{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .85rem center;
  padding-right:2.5rem;
}
.input-group{display:flex;border:1.5px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:all var(--dur) var(--ease)}
.input-group:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.input-group .form-control{border:none;border-radius:0}
.input-group .form-control:focus{box-shadow:none}
.input-group-text{
  display:flex;align-items:center;padding:0 .85rem;
  background:#F9FAFB;color:var(--text-3);font-size:13px;
  border-right:1px solid var(--border);white-space:nowrap;font-weight:500;
}
.input-group-text.end{border-right:none;border-left:1px solid var(--border)}

/* ══════════════════════════════════════════
   ALERTS
══════════════════════════════════════════ */
.alert{
  display:flex;align-items:flex-start;gap:.8rem;
  padding:.9rem 1.1rem;border-radius:var(--r-md);
  border:1px solid;font-size:13.5px;line-height:1.5;
  margin-bottom:1rem;
}
.alert-success{background:var(--success-bg);border-color:#A7F3D0;color:var(--success-text)}
.alert-danger{background:var(--danger-bg);border-color:#FCA5A5;color:var(--danger-text)}
.alert-warning{background:var(--warning-bg);border-color:#FDE68A;color:var(--warning-text)}
.alert-info{background:var(--info-bg);border-color:#BFDBFE;color:var(--info-text)}
.alert-icon{font-size:1rem;flex-shrink:0;margin-top:.1rem}

/* ══════════════════════════════════════════
   TOAST
══════════════════════════════════════════ */
#toast-container{
  position:fixed;top:calc(var(--topbar-h) + 1rem);right:1.25rem;
  z-index:9999;display:flex;flex-direction:column;gap:.5rem;
  pointer-events:none;max-width:340px;width:calc(100vw - 2.5rem);
}
.toast{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:.9rem 1rem;
  box-shadow:var(--sh-lg);
  display:flex;align-items:flex-start;gap:.7rem;
  pointer-events:all;position:relative;overflow:hidden;
  animation:toastIn .3s cubic-bezier(.34,1.56,.64,1) forwards;
}
.toast.out{animation:toastOut .25s ease-in forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(110%)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(110%)}}
.toast-bar{position:absolute;bottom:0;left:0;height:3px;border-radius:0;animation:toastPrg linear forwards;transform-origin:left}
@keyframes toastPrg{to{transform:scaleX(0)}}
.toast-ic{width:32px;height:32px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.toast-body{flex:1;min-width:0}
.toast-title{font-weight:700;font-size:13px;line-height:1.3}
.toast-msg{font-size:12px;color:var(--text-2);margin-top:2px;line-height:1.4}
.toast-x{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:18px;line-height:1;flex-shrink:0;padding:0;transition:color var(--dur)}
.toast-x:hover{color:var(--text)}
.toast.success{border-left:4px solid var(--success)} .toast.success .toast-ic{background:var(--success-bg);color:var(--success-text)} .toast.success .toast-bar{background:var(--success)}
.toast.error{border-left:4px solid var(--danger)} .toast.error .toast-ic{background:var(--danger-bg);color:var(--danger-text)} .toast.error .toast-bar{background:var(--danger)}
.toast.warning{border-left:4px solid var(--warning)} .toast.warning .toast-ic{background:var(--warning-bg);color:var(--warning-text)} .toast.warning .toast-bar{background:var(--warning)}
.toast.info{border-left:4px solid var(--info)} .toast.info .toast-ic{background:var(--info-bg);color:var(--info-text)} .toast.info .toast-bar{background:var(--info)}

/* ══════════════════════════════════════════
   MODAL
══════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(10,20,40,.55);
  backdrop-filter:blur(4px);z-index:500;
  display:flex;align-items:center;justify-content:center;padding:1rem;
  opacity:0;pointer-events:none;transition:opacity .2s var(--ease);
}
.modal-overlay.show{opacity:1;pointer-events:all}
.modal{
  background:var(--card);border-radius:var(--r-xl);
  box-shadow:var(--sh-xl);width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;
  transform:scale(.95) translateY(12px);
  transition:transform .25s var(--ease);position:relative;
}
.modal-overlay.show .modal{transform:scale(1) translateY(0)}
.modal-lg{max-width:680px}
.modal-sm{max-width:380px}
.modal-head{
  padding:1.4rem 1.6rem 1.2rem;
  display:flex;align-items:flex-start;justify-content:space-between;
  border-bottom:1px solid var(--border);gap:1rem;
}
.modal-title{font-size:16px;font-weight:800;font-family:'Sora',sans-serif}
.modal-sub{font-size:12.5px;color:var(--text-2);margin-top:3px}
.modal-close{
  width:30px;height:30px;border-radius:var(--r-sm);background:none;border:none;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-3);font-size:20px;line-height:1;
  transition:all var(--dur) var(--ease);flex-shrink:0;
}
.modal-close:hover{background:#F3F4F6;color:var(--text)}
.modal-body{padding:1.4rem 1.6rem}
.modal-foot{
  padding:1.1rem 1.6rem;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:flex-end;gap:.7rem;
}

/* ══════════════════════════════════════════
   SPINNER
══════════════════════════════════════════ */
.spin{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.spin-dark{border-color:rgba(91,71,251,.2);border-top-color:var(--primary)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
.fade-up{animation:fadeUp .35s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.stagger>*{animation:fadeUp .35s ease both}
.stagger>*:nth-child(1){animation-delay:.04s}
.stagger>*:nth-child(2){animation-delay:.08s}
.stagger>*:nth-child(3){animation-delay:.12s}
.stagger>*:nth-child(4){animation-delay:.16s}
.stagger>*:nth-child(5){animation-delay:.2s}
.stagger>*:nth-child(6){animation-delay:.24s}

/* ══════════════════════════════════════════
   PAYMENT METHOD CARDS
══════════════════════════════════════════ */
.pay-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}
.pay-method{
  border:2px solid var(--border);background:var(--card);
  border-radius:var(--r-lg);padding:1rem;text-align:center;
  cursor:pointer;transition:all var(--dur) var(--ease);position:relative;
}
.pay-method:hover{border-color:var(--border-strong);box-shadow:var(--sh-sm)}
.pay-method.selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 1px var(--primary)}
.pay-method-icon{
  width:44px;height:44px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto .75rem;font-size:1.25rem;
}
.pay-method-name{font-size:13px;font-weight:700;margin-bottom:2px}
.pay-method-hint{font-size:11px;color:var(--text-3)}
.pay-method-check{
  position:absolute;top:8px;right:8px;
  width:20px;height:20px;border-radius:50%;
  background:var(--primary);color:#fff;
  display:none;align-items:center;justify-content:center;font-size:10px;
}
.pay-method.selected .pay-method-check{display:flex}

/* Amount pills */
.amount-pills{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-bottom:1.25rem}
.amount-pill{
  padding:.5rem;border-radius:var(--r-md);border:1.5px solid var(--border);
  background:var(--card);text-align:center;font-size:12.5px;font-weight:600;
  cursor:pointer;transition:all var(--dur) var(--ease);color:var(--text-2);
}
.amount-pill:hover{border-color:var(--primary);color:var(--primary)}
.amount-pill.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}

/* Big amount input */
.amount-big-input{
  border:2px solid var(--border);border-radius:var(--r-lg);
  padding:1rem 1.2rem;background:#FAFBFF;
  display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;
  transition:border-color var(--dur) var(--ease);
}
.amount-big-input:focus-within{border-color:var(--primary);background:#fff}
.amount-big-input input{
  flex:1;border:none;background:transparent;outline:none;
  font-size:2rem;font-weight:800;font-family:'Sora',sans-serif;
  color:var(--text);letter-spacing:-1px;width:100%;
}
.amount-big-input .currency{font-size:1.25rem;font-weight:600;color:var(--text-3)}

/* ══════════════════════════════════════════
   KYC STEPS
══════════════════════════════════════════ */
.kyc-steps{display:flex;gap:0;margin-bottom:2rem;position:relative}
.kyc-steps::before{content:'';position:absolute;top:18px;left:18px;right:18px;height:2px;background:var(--border);z-index:0}
.kyc-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:1;position:relative}
.kyc-step-dot{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:13px;border:2px solid var(--border);
  background:var(--card);color:var(--text-3);transition:all .3s;
}
.kyc-step.done .kyc-step-dot{background:var(--success);border-color:var(--success);color:#fff}
.kyc-step.active .kyc-step-dot{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px var(--primary-glow)}
.kyc-step-label{font-size:11.5px;font-weight:600;color:var(--text-3);text-align:center}
.kyc-step.done .kyc-step-label,.kyc-step.active .kyc-step-label{color:var(--text)}

/* Upload zone */
.upload-zone{
  border:2px dashed var(--border);border-radius:var(--r-lg);
  padding:2rem;text-align:center;cursor:pointer;
  transition:all var(--dur) var(--ease);background:#FAFBFF;
}
.upload-zone:hover{border-color:var(--primary);background:var(--primary-light)}
.upload-zone.drag{border-color:var(--primary);background:var(--primary-light)}
.upload-zone input{display:none}
.upload-icon{font-size:2rem;margin-bottom:.5rem}
.upload-title{font-size:14px;font-weight:600;margin-bottom:.25rem}
.upload-hint{font-size:12px;color:var(--text-3)}

/* ══════════════════════════════════════════
   SUPPORT TICKETS
══════════════════════════════════════════ */
.ticket-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:1.2rem 1.4rem;
  transition:all var(--dur) var(--ease);cursor:pointer;
}
.ticket-card:hover{border-color:var(--primary);box-shadow:var(--sh-md)}
.ticket-id{font-family:'DM Mono',monospace;font-size:11px;color:var(--text-3)}
.ticket-subject{font-size:14.5px;font-weight:700;margin:.25rem 0}
.ticket-preview{font-size:12.5px;color:var(--text-2);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.ticket-reply{
  background:#F8F9FF;border-radius:var(--r-md);
  padding:.85rem 1rem;margin-top:.75rem;font-size:12.5px;
  border-left:3px solid var(--primary);
}
.ticket-reply-label{font-weight:700;color:var(--primary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}

/* ══════════════════════════════════════════
   TICKETS / SUPPORT PAGE
══════════════════════════════════════════ */

.ticket-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.ticket-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 1.25rem;
  margin-bottom: 1rem;
  transition: all var(--dur) var(--ease);
  cursor: pointer;
}

.ticket-card:hover {
  border-color: var(--primary);
  box-shadow: var(--sh-sm);
  transform: translateY(-2px);
}

.ticket-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: .75rem;
}

.ticket-id {
  font-size: .75rem;
  color: var(--text-3);
  font-family: 'DM Mono', monospace;
  margin-bottom: .25rem;
}

.ticket-subject {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
}

.ticket-meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: .5rem;
  font-size: .75rem;
  color: var(--text-3);
}

.ticket-preview {
  font-size: .875rem;
  color: var(--text-2);
  line-height: 1.6;
  margin-bottom: .75rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ticket-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: .75rem;
  border-top: 1px solid var(--border);
  font-size: .75rem;
  color: var(--text-3);
}

.ticket-reply-count {
  display: flex;
  align-items: center;
  gap: .25rem;
}

/* Ticket Detail */
.ticket-detail-header {
  background: var(--bg-2);
  padding: 5px;
  border-radius: var(--r-md);
  margin-bottom: 1.5rem;
}

.ticket-detail-subject {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: .5rem;
}

.ticket-detail-meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  font-size: .875rem;
  color: var(--text-2);
}

.ticket-messages {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-bottom: 1.5rem;
  max-height: 500px;
  overflow-y: auto;
  padding-right: .5rem;
}

.ticket-message {
  padding: 1rem;
  border-radius: var(--r-md);
  background: var(--bg-2);
}

.ticket-message.customer {
  background: var(--primary-light);
  border-left: 3px solid var(--primary);
}

.ticket-message.admin {
  background: var(--success-bg);
  border-left: 3px solid var(--success);
}

.ticket-message-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: .5rem;
  font-size: .75rem;
  color: var(--text-3);
}

.ticket-message-body {
  font-size: .875rem;
  line-height: 1.6;
  color: var(--text-2);
}

.ticket-reply-form {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 1.25rem;
}

.ticket-reply-form textarea {
  resize: vertical;
  min-height: 100px;
}

/* Category Badge Colors */
.badge-deposit {
  background: var(--success-bg);
  color: var(--success-text);
}

.badge-withdrawal {
  background: var(--info-bg);
  color: var(--info-text);
}

.badge-kyc {
  background: var(--warning-bg);
  color: var(--warning-text);
}

.badge-account {
  background: #F3E8FF;
  color: #6B21A8;
}

.badge-technical {
  background: #FEE2E2;
  color: #991B1B;
}

.badge-other {
  background: var(--surface);
  color: var(--text-2);
}

/* Priority Indicators */
.priority-indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  margin-right: 2px;
}

.priority-low {
  background: var(--text-3);
}

.priority-medium {
  background: var(--info);
}

.priority-high {
  background: var(--warning);
}

.priority-urgent {
  background: var(--danger);
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

/* Empty State Animation */
.empty-state {
  text-align: center;
  padding: 3rem;
  animation: fadeIn 0.5s ease;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ══════════════════════════════════════════
   BANK CARDS
══════════════════════════════════════════ */
.bank-card{
  background:var(--card);border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:1.1rem 1.3rem;
  transition:all var(--dur) var(--ease);
}
.bank-card.default{border-color:var(--primary);background:var(--primary-light)}
.bank-card-name{font-size:14px;font-weight:700;margin-bottom:.25rem}
.bank-card-detail{font-size:12.5px;color:var(--text-2)}
.bank-card-iban{font-family:'DM Mono',monospace;font-size:12px;color:var(--text-2);margin-top:.3rem}

/* ══════════════════════════════════════════
   SECURITY
══════════════════════════════════════════ */
.security-score{
  display:flex;align-items:center;gap:1.5rem;
  padding:1.25rem 1.4rem;background:var(--card);
  border:1px solid var(--border);border-radius:var(--r-lg);
  margin-bottom:1.5rem;
}
.score-ring{width:64px;height:64px;flex-shrink:0}
.score-ring svg{transform:rotate(-90deg)}
.score-info .label{font-size:12px;color:var(--text-3);font-weight:600;margin-bottom:.25rem}
.score-info .value{font-size:24px;font-weight:800;font-family:'Sora',sans-serif}
.score-info .sub{font-size:12.5px;color:var(--text-2);margin-top:.2rem}
.security-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.4rem;border-bottom:1px solid var(--border);
}
.security-item:last-child{border-bottom:none}
.security-item-l{display:flex;align-items:center;gap:.85rem}
.security-item-icon{width:38px;height:38px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center}
.security-item-label{font-size:13.5px;font-weight:600}
.security-item-hint{font-size:12px;color:var(--text-3);margin-top:.2rem}

/* Toggle switch */
.toggle{width:42px;height:24px;position:relative;cursor:pointer}
.toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle-track{
  position:absolute;inset:0;border-radius:99px;
  background:#D1D5DB;transition:background .2s;
}
.toggle input:checked~.toggle-track{background:var(--primary)}
.toggle-thumb{
  position:absolute;top:3px;left:3px;
  width:18px;height:18px;border-radius:50%;
  background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);
  transition:left .2s;
}
.toggle input:checked~.toggle-thumb{left:21px}

/* Login log */
.login-log{
  display:flex;align-items:center;justify-content:space-between;
  padding:.8rem 1.4rem;border-bottom:1px solid var(--border);
}
.login-log:last-child{border-bottom:none}
.login-log-device{display:flex;align-items:center;gap:.65rem}
.login-log-icon{width:34px;height:34px;border-radius:var(--r-sm);background:#F3F4F6;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}
.login-log-ip{font-family:'DM Mono',monospace;font-size:11.5px;color:var(--text-3);margin-top:.15rem}
.login-log-time{font-size:12px;color:var(--text-3);text-align:right}

/* ══════════════════════════════════════════
   FILTER BAR
══════════════════════════════════════════ */
.filter-bar{
  display:flex;align-items:center;gap:.75rem;
  padding:1rem 1.4rem;border-bottom:1px solid var(--border);
  flex-wrap:wrap;
}
.filter-group{display:flex;align-items:center;gap:.5rem}
.filter-label{font-size:12px;font-weight:600;color:var(--text-3);white-space:nowrap}
.filter-select{
  padding:.38rem .65rem;border:1.5px solid var(--border);
  border-radius:var(--r-sm);font-size:12.5px;
  background:#fff;outline:none;cursor:pointer;
  transition:border-color var(--dur);
}
.filter-select:focus{border-color:var(--primary)}
.search-input{
  display:flex;align-items:center;gap:.5rem;flex:1;min-width:180px;
  background:#fff;border:1.5px solid var(--border);
  border-radius:var(--r-md);padding:.38rem .75rem;
  transition:border-color var(--dur);
}
.search-input:focus-within{border-color:var(--primary)}
.search-input input{border:none;outline:none;flex:1;font-size:13px;background:transparent}
.search-input svg{color:var(--text-3);flex-shrink:0}

/* ══════════════════════════════════════════
   INFO ROWS
══════════════════════════════════════════ */
.info-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border)}
.info-row:last-child{border-bottom:none}
.info-key{font-size:13px;color:var(--text-3);font-weight:500}
.info-val{font-size:13px;font-weight:500;color:var(--text-2)}
.copy-btn{
  background:none;border:none;cursor:pointer;
  color:var(--text-3);padding:.2rem .4rem;border-radius:var(--r-sm);
  transition:all var(--dur);font-size:12px;
}
.copy-btn:hover{background:#F3F4F6;color:var(--primary)}

/* ══════════════════════════════════════════
   PROFILE AVATAR
══════════════════════════════════════════ */
.profile-avatar{
  width:76px;height:76px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),#7C3AED);
  display:flex;align-items:center;justify-content:center;
  font-size:1.75rem;font-weight:800;color:#fff;flex-shrink:0;
  font-family:'Sora',sans-serif;
  box-shadow:0 4px 20px rgba(91,71,251,.3);
}

/* ══════════════════════════════════════════
   COMPANY BANK INFO
══════════════════════════════════════════ */
.company-bank{
  background:linear-gradient(135deg,#1a2744,#0D1526);
  border-radius:var(--r-lg);padding:1.25rem;color:#fff;
  margin-bottom:.75rem;position:relative;overflow:hidden;
}
.company-bank::before{
  content:'';position:absolute;top:-30px;right:-30px;
  width:100px;height:100px;border-radius:50%;
  background:rgba(91,71,251,.15);pointer-events:none;
}
.company-bank-label{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.4);margin-bottom:.3rem;font-weight:600}
.company-bank-value{font-size:14px;font-weight:500;color:#fff}
.company-bank-value.mono{font-family:'DM Mono',monospace;font-size:13px;letter-spacing:.5px}

/* ══════════════════════════════════════════
   EMPTY STATE
══════════════════════════════════════════ */
.empty-state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:4rem 2rem;text-align:center;
}
.empty-icon{
  width:72px;height:72px;border-radius:50%;
  background:#F3F4F6;display:flex;align-items:center;justify-content:center;
  font-size:2rem;margin-bottom:1.25rem;
}
.empty-title{font-size:16px;font-weight:700;margin-bottom:.4rem}
.empty-hint{font-size:13px;color:var(--text-3);max-width:280px;line-height:1.5}

/* ══════════════════════════════════════════
   PAGINATION
══════════════════════════════════════════ */
.pagination{display:flex;align-items:center;gap:.4rem;justify-content:center;padding:1rem}
.page-btn{
  min-width:34px;height:34px;border-radius:var(--r-sm);
  border:1px solid var(--border);background:var(--card);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:500;cursor:pointer;
  transition:all var(--dur) var(--ease);padding:0 .5rem;
}
.page-btn:hover{background:#F3F4F6;border-color:var(--border-strong)}
.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}
.page-btn:disabled{opacity:.4;cursor:not-allowed}

/* ══════════════════════════════════════════
   NOTIFICATION MENU
══════════════════════════════════════════ */
.notification{position:relative}
.notification-menu{
  position:absolute;top:calc(100% + 8px);right:0;
  width:300px;background:var(--card);
  border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);z-index:300;
  opacity:0;transform:translateY(-8px) scale(.97);
  pointer-events:none;transition:all .18s var(--ease);
}
.notification-menu.show{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.notification-head{padding:.85rem 1rem;border-bottom:1px solid var(--border);font-weight:700;font-size:13.5px}
.notification-item{padding:.7rem 1rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--dur)}
.notification-item:last-child{border-bottom:none}
.notification-item:hover{background:#F9FAFB}
.notification-item-title{font-size:13px;font-weight:600;margin-bottom:.2rem}
.notification-item-time{font-size:11.5px;color:var(--text-3)}

/* ══════════════════════════════════════════
   DROPDOWN MENU
══════════════════════════════════════════ */
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;top:calc(100% + 8px);right:0;
  width:300px;background:var(--card);
  border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);z-index:300;
  opacity:0;transform:translateY(-8px) scale(.97);
  pointer-events:none;transition:all .18s var(--ease);
}
.dropdown-menu.show{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.dropdown-head{padding:.85rem 1rem;border-bottom:1px solid var(--border);font-weight:700;font-size:13.5px}
.dropdown-item{padding:.7rem 1rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--dur)}
.dropdown-item:last-child{border-bottom:none}
.dropdown-item:hover{background:#F9FAFB}
.dropdown-item-title{font-size:13px;font-weight:600;margin-bottom:.2rem}
.dropdown-item-time{font-size:11.5px;color:var(--text-3)}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1024px){
  .app-sidebar{transform:translateX(-100%)}
  .app-sidebar.open{transform:translateX(0);box-shadow:var(--sh-xl)}
  .app-main{margin-left:0}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .app-main{padding:calc(var(--topbar-h) + 1.25rem) 1rem 1.25rem}
  .tb-balance,.tb-center{display:none}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .pay-methods{grid-template-columns:1fr}
  .amount-pills{grid-template-columns:repeat(2,1fr)}
  .page-head{flex-direction:column}
  .notification-menu{top:calc(100% + 20px);left:50%;transform:translateX(-38%) translateY(-8px) scale(.9)!important;width:275px;max-height:400px;overflow-y:auto;}
  .notification-item{padding:.5rem 1rem;}
  #toast-container{transform:translateX(5%) translateY(-8px) scale(.9);}
  .sb-footer{position:relative;bottom:60px;} /* Mobil sidebar çıkış yap butonu konumu */ 
  
}
@media(max-width:480px){
  .stat-grid{grid-template-columns:1fr}
  .tb-name{display:none}
}

/* Sadece mobilde gizle */
@media(max-width:768px) {
  .hide-mobile { display: none !important; }
}

/* Sadece desktopda gizle */
@media(min-width:769px) {
  .hide-desktop { display: none !important; }
}

/* page transitions */
.page{animation:fadeUp .3s ease both;display:none}
.page.active{display:block}

/* ══════════════════════════════════════════
   TRADING ACCOUNTS
══════════════════════════════════════════ */
.badge-live {
  background: var(--success-bg);
  color: var(--success-text);
}

.badge-demo {
  background: var(--info-bg);
  color: var(--info-text);
}

.account-type-selector {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.account-type-card {
  border: 2px solid var(--border);
  border-radius: var(--r-md);
  padding: 1.25rem;
  cursor: pointer;
  transition: all var(--dur) var(--ease);
  text-align: center;
}

.account-type-card:hover {
  border-color: var(--primary);
  background: var(--primary-light);
}

.account-type-card.selected {
  border-color: var(--primary);
  background: var(--primary-light);
  box-shadow: 0 0 0 3px var(--primary-glow);
}

.account-type-card input[type="radio"] {
  display: none;
}

.account-type-icon {
  font-size: 2.5rem;
  margin-bottom: .5rem;
}

.account-type-label {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: .25rem;
}

.account-type-desc {
  font-size: .75rem;
  color: var(--text-2);
}

.platform-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.platform-card {
  border: 2px solid var(--border);
  border-radius: var(--r-md);
  padding: 1rem;
  cursor: pointer;
  transition: all var(--dur) var(--ease);
}

.platform-card:hover {
  border-color: var(--primary);
}

.platform-card.selected {
  border-color: var(--primary);
  background: var(--primary-light);
}

.platform-icon {
  font-size: 2rem;
  margin-bottom: .5rem;
}

.platform-name {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: .25rem;
}

.platform-server {
  font-size: .75rem;
  color: var(--text-2);
  font-family: 'DM Mono', monospace;
}

/* VERIFY IBAN */

.verify-info-grid {
  display: grid;
  gap: 1.5rem;
}

.verify-info-item {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 1rem;
  transition: all var(--dur) var(--ease);
}

.verify-info-item:hover {
  border-color: var(--primary);
  box-shadow: 0 2px 8px var(--primary-glow);
}

.verify-info-label {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .75rem;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
  margin-bottom: .5rem;
}

.verify-info-label svg {
  flex-shrink: 0;
}

.verify-info-value {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-1);
  font-family: 'DM Mono', monospace;
  word-break: break-all;
}

.btn-copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .375rem;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: all var(--dur) var(--ease);
  color: var(--text-2);
  flex-shrink: 0;
}

.btn-copy:hover {
  background: var(--primary);
  border-color: var(--primary);
  color: white;
  transform: scale(1.05);
}

.btn-copy:active {
  transform: scale(0.95);
}

.status-badge-inline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  font-size: .75rem;
  font-weight: 700;
  vertical-align: middle;
  margin-right: .5rem;
}

.status-badge-inline.status-success {
  background: var(--success-bg);
  color: var(--success-text);
}

.status-badge-inline.status-error {
  background: var(--danger-bg);
  color: var(--danger-text);
}

.verify-error-message {
  text-align: center;
  padding: 2rem 1rem;
}

.verify-error-message svg {
  color: var(--danger);
  margin-bottom: 1rem;
  opacity: 0.5;
}

.verify-error-message h3 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: .5rem;
}

.verify-error-message p {
  color: var(--text-2);
  font-size: .875rem;
  line-height: 1.6;
  max-width: 500px;
  margin: 0 auto;
}

.input-group {
  display: flex;
  gap: .75rem;
  align-items: stretch;
}

.input-group .form-control {
  flex: 1;
}

.input-group .btn {
  white-space: nowrap;
}

.form-control-lg {
  padding: .875rem 1rem;
  font-size: 1rem;
}

@media (max-width: 768px) {
  .verify-info-value {
    font-size: .875rem;
  }
  
  .input-group {
    flex-direction: column;
  }
  
  .input-group .btn {
    width: 100%;
  }
}
