/* ═══════════════════════════════════════════════════════════════
   Open Liberty — Binance Dark Gold Theme  |  Fully Responsive
   Breakpoints: 1280 / 1024 / 768 / 480 / 360
═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600;700;800&family=Inter:wght@300;400;500;600;700&family=Rajdhani:wght@400;500;600;700&display=swap');

/* ── Variables ── */
:root {
  --gold:        #F0B90B;
  --gold-light:  #F8D12F;
  --gold-dark:   #C99A00;
  --gold-glow:   rgba(240,185,11,0.28);
  --bg-primary:  #0B0E11;
  --bg-secondary:#161A1E;
  --bg-card:     #1E2329;
  --bg-card-hover:#252B33;
  --bg-input:    #2B3139;
  --border:      #2B3139;
  --border-gold: rgba(240,185,11,0.4);
  --text-primary:#EAECEF;
  --text-secondary:#848E9C;
  --text-muted:  #5E6673;
  --green:       #0ECB81;
  --red:         #F6465D;
  --blue:        #1890FF;
  --sidebar-w:   260px;
  --header-h:    60px;
  --r:           8px;
  --r-lg:        12px;
  --shadow:      0 4px 20px rgba(0,0,0,0.4);
  --shadow-gold: 0 0 24px rgba(240,185,11,0.15);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 14px; scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Inter', sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  min-height: 100vh;
  line-height: 1.5;
  overflow-x: hidden;
}
a { color: var(--gold); text-decoration: none; transition: color .2s; }
a:hover { color: var(--gold-light); }
img { max-width: 100%; }

/* ════════════════════════════════
   AUTH PAGES
════════════════════════════════ */
.auth-wrapper {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-primary);
  position: relative; overflow: hidden;
  padding: 1rem;
}
.auth-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(240,185,11,.12) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 10% 80%,  rgba(240,185,11,.06) 0%, transparent 50%);
}
.auth-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(240,185,11,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(240,185,11,.04) 1px, transparent 1px);
  background-size: 50px 50px;
}
.auth-card {
  position: relative; z-index: 2;
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  padding: 2.5rem;
  width: 100%; max-width: 460px;
  box-shadow: var(--shadow-gold), 0 20px 60px rgba(0,0,0,.5);
  animation: slideUp .4s ease;
}
@keyframes slideUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

.auth-logo { text-align: center; margin-bottom: 2rem; }
.auth-logo img {
  width: 110px; height: auto;
  filter: drop-shadow(0 0 18px rgba(240,185,11,.4));
}
.auth-title {
  font-family: 'Orbitron', monospace;
  font-size: 1.4rem; font-weight: 700;
  color: var(--gold); text-align: center;
  margin-bottom: .25rem;
  text-transform: uppercase; letter-spacing: 2px;
}
.auth-subtitle { text-align:center; color:var(--text-secondary); font-size:.875rem; margin-bottom:2rem; }

/* ── Forms ── */
.form-group { margin-bottom: 1.25rem; }
.form-label { display:block; font-size:.75rem; font-weight:600; color:var(--text-secondary); margin-bottom:.5rem; text-transform:uppercase; letter-spacing:.5px; }
.input-wrapper { position: relative; }

.form-input {
  width:100%; background:var(--bg-input); border:1px solid var(--border);
  border-radius:var(--r); padding:.75rem 1rem;
  color:var(--text-primary); font-size:.9rem; font-family:'Inter',sans-serif;
  transition:all .2s; outline:none;
}
.form-input:focus { border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-glow); background:#2F3640; }
.form-input::placeholder { color:var(--text-muted); }
.form-input.has-icon { padding-right: 2.75rem; }
.form-input[readonly] { cursor:not-allowed; opacity:.7; }

.input-toggle {
  position:absolute; right:.875rem; top:50%; transform:translateY(-50%);
  background:none; border:none; color:var(--text-secondary);
  cursor:pointer; display:flex; align-items:center; padding:0; transition:color .2s;
}
.input-toggle:hover { color:var(--gold); }

.form-select {
  width:100%; background:var(--bg-input); border:1px solid var(--border);
  border-radius:var(--r); padding:.75rem 2.5rem .75rem 1rem;
  color:var(--text-primary); font-size:.9rem; font-family:'Inter',sans-serif;
  outline:none; cursor:pointer; transition:all .2s;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23848E9C' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .875rem center;
}
.form-select:focus { border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-glow); }

.form-textarea {
  width:100%; background:var(--bg-input); border:1px solid var(--border);
  border-radius:var(--r); padding:.75rem 1rem;
  color:var(--text-primary); font-size:.9rem; font-family:'Inter',sans-serif;
  outline:none; resize:vertical; min-height:90px; transition:all .2s;
}
.form-textarea:focus { border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-glow); }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media(max-width:480px){ .form-row { grid-template-columns:1fr; } }

.form-error { color:var(--red); font-size:.78rem; margin-top:.35rem; display:none; }
.form-error.show { display:block; }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.75rem 1.5rem; border-radius:var(--r);
  font-weight:600; font-size:.875rem; cursor:pointer; border:none;
  transition:all .18s; font-family:'Inter',sans-serif;
  text-transform:uppercase; letter-spacing:.5px; white-space:nowrap;
}
.btn-primary { background:var(--gold); color:#000; }
.auth-card .btn-primary, form > .btn-primary, .modal-body + .modal-footer .btn-primary, .section-body > .btn-primary { width:100%; }
.btn-primary:hover { background:var(--gold-light); transform:translateY(-1px); box-shadow:0 4px 20px var(--gold-glow); }
.btn-primary:active { transform:translateY(0); }
.btn-outline { background:transparent; color:var(--gold); border:1px solid var(--gold); }
.btn-outline:hover { background:var(--gold-glow); }
.btn-ghost { background:var(--bg-input); color:var(--text-primary); }
.btn-ghost:hover { background:var(--bg-card-hover); }
.btn-danger { background:var(--red); color:#fff; }
.btn-sm { padding:.4rem .9rem; font-size:.75rem; }

/* ── Alerts ── */
.alert {
  padding:.875rem 1rem; border-radius:var(--r); font-size:.875rem;
  margin-bottom:1.25rem; display:flex; align-items:flex-start; gap:.5rem;
}
.alert-success { background:rgba(14,203,129,.10); border:1px solid rgba(14,203,129,.3); color:var(--green); }
.alert-danger   { background:rgba(246,70,93,.10);  border:1px solid rgba(246,70,93,.3);  color:var(--red); }
.alert-warning  { background:rgba(240,185,11,.10); border:1px solid rgba(240,185,11,.3); color:var(--gold); }
.alert-info     { background:rgba(24,144,255,.10);  border:1px solid rgba(24,144,255,.3);  color:var(--blue); }

/* ── Auth divider ── */
.auth-divider {
  text-align:center; color:var(--text-muted); margin:1.25rem 0; font-size:.85rem; position:relative;
}
.auth-divider::before,.auth-divider::after {
  content:''; position:absolute; top:50%; width:42%; height:1px; background:var(--border);
}
.auth-divider::before{left:0;} .auth-divider::after{right:0;}

/* ── Loader ── */
.loader-overlay {
  position:fixed; inset:0;
  background:rgba(11,14,17,.95);
  display:none; flex-direction:column; align-items:center; justify-content:center;
  z-index:9999;
}
.loader-overlay.show { display:flex; }
.loader-ring {
  width:56px; height:56px;
  border:3px solid var(--border); border-top-color:var(--gold);
  border-radius:50%; animation:spin .8s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }
.loader-text {
  margin-top:1rem; color:var(--text-secondary); font-size:.8rem;
  font-family:'Rajdhani',sans-serif; letter-spacing:2px; text-transform:uppercase;
  animation:pulse 1.5s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}

/* ── Success Page ── */
.success-wrapper {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:var(--bg-primary); position:relative; overflow:hidden; padding:1rem;
}
.success-card {
  background:var(--bg-card); border:1px solid var(--border-gold);
  border-radius:var(--r-lg); padding:3rem 2rem; text-align:center;
  max-width:460px; width:100%; box-shadow:var(--shadow-gold);
  animation:slideUp .5s ease;
}
.success-icon {
  width:72px; height:72px;
  background:rgba(14,203,129,.15); border:2px solid var(--green);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  margin:0 auto 1.5rem; animation:pop .5s ease .2s both;
}
@keyframes pop{from{transform:scale(0)}to{transform:scale(1)}}
.success-title { font-family:'Orbitron',monospace; font-size:1.3rem; font-weight:700; color:var(--gold); margin-bottom:.75rem; text-transform:uppercase; }
.success-msg   { color:var(--text-secondary); margin-bottom:2rem; line-height:1.6; }
.countdown-bar { background:var(--bg-input); border-radius:100px; height:4px; margin:1.5rem 0; overflow:hidden; }
.countdown-fill { height:100%; background:var(--gold); animation:countdown 5s linear forwards; }
@keyframes countdown{from{width:100%}to{width:0%}}

/* ════════════════════════════════
   DASHBOARD LAYOUT
════════════════════════════════ */
.app-wrapper { display:flex; min-height:100vh; }

/* ── Sidebar ── */
.sidebar {
  width: var(--sidebar-w);
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: fixed; left:0; top:0; bottom:0;
  z-index: 100;
  transition: transform .3s ease;
  overflow-y: auto; overflow-x: hidden;
  flex-shrink: 0;
}
.sidebar-logo {
  padding: 1.125rem 1.25rem;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: .75rem;
  flex-shrink: 0;
}
.sidebar-logo img { width:40px; height:40px; object-fit:contain; filter:drop-shadow(0 0 10px rgba(240,185,11,.4)); flex-shrink:0; }
.sidebar-brand { font-family:'Orbitron',monospace; font-size:.8rem; font-weight:700; color:var(--gold); letter-spacing:1px; line-height:1.2; }
.sidebar-brand span { display:block; font-family:'Inter',sans-serif; font-size:.65rem; color:var(--text-muted); font-weight:400; letter-spacing:.5px; }

.sidebar-nav { flex:1; padding:.75rem 0; }
.nav-section-label { padding:.5rem 1.125rem; font-size:.65rem; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:1.5px; margin-top:.625rem; }

.nav-item {
  display:flex; align-items:center; gap:.7rem;
  padding:.7rem 1.125rem;
  color:var(--text-secondary); font-size:.85rem; font-weight:500;
  cursor:pointer; transition:all .18s;
  border-left:3px solid transparent; text-decoration:none;
}
.nav-item:hover { color:var(--text-primary); background:rgba(240,185,11,.05); border-left-color:rgba(240,185,11,.3); }
.nav-item.active { color:var(--gold); background:rgba(240,185,11,.08); border-left-color:var(--gold); }
.nav-item svg { flex-shrink:0; }

.sidebar-footer {
  padding: .875rem;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}
.user-mini {
  display:flex; align-items:center; gap:.7rem;
  padding:.7rem; background:var(--bg-card); border-radius:var(--r);
}
.user-avatar {
  width:36px; height:36px;
  background:linear-gradient(135deg,var(--gold-dark),var(--gold));
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:'Orbitron',monospace; font-weight:700; font-size:.75rem; color:#000;
  flex-shrink:0;
}
.user-mini-info { flex:1; min-width:0; }
.user-mini-name  { font-size:.78rem; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.user-mini-email { font-size:.67rem; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ── Main Content ── */
.main-content {
  flex: 1;
  margin-left: var(--sidebar-w);
  display: flex; flex-direction: column;
  min-height: 100vh;
  min-width: 0;  /* critical — prevents flex overflow */
  overflow-x: hidden;
}

/* ── Top Header ── */
.top-header {
  height: var(--header-h);
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  padding: 0 1.25rem;
  display: flex; align-items: center; justify-content: space-between;
  position: sticky; top:0; z-index:50;
  gap: .75rem;
}
.header-left  { display:flex; align-items:center; gap:.875rem; min-width:0; }
.header-right { display:flex; align-items:center; gap:.625rem; flex-shrink:0; }

.menu-toggle {
  background:none; border:none; color:var(--text-secondary);
  cursor:pointer; padding:.4rem; display:none;
  border-radius:var(--r); transition:all .2s; flex-shrink:0;
}
.menu-toggle:hover { background:var(--bg-card); color:var(--gold); }

.page-title {
  font-family:'Rajdhani',sans-serif; font-size:1.05rem; font-weight:700;
  color:var(--text-primary); text-transform:uppercase; letter-spacing:1px;
  white-space:nowrap;
}

/* ── Ticker ── */
.ticker-bar {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  padding: .45rem 0;
  overflow: hidden; width:100%;
}
.ticker-inner {
  display: flex; gap: 2rem;
  animation: ticker 40s linear infinite;
  white-space: nowrap; width: max-content;
}
.ticker-inner:hover { animation-play-state: paused; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ticker-item { display:inline-flex; align-items:center; gap:.4rem; font-size:.72rem; font-weight:500; }
.ticker-item .name  { color:var(--text-secondary); }
.ticker-item .price { color:var(--text-primary); font-family:'Rajdhani',sans-serif; font-weight:600; }
.ticker-item .change.up   { color:var(--green); }
.ticker-item .change.down { color:var(--red); }

/* ── Page Body ── */
.page-body {
  padding: 1.25rem;
  flex: 1;
  min-width: 0;
  overflow-x: hidden;
}

/* ════════════════════════════════
   STAT CARDS — FULLY RESPONSIVE
   Desktop:  3 columns (1280+) / 3 cols (1024+) / 3 cols (768+)
   Tablet:   2 columns (480+)
   Mobile:   2 columns (default)
════════════════════════════════ */
.stat-grid {
  display: grid;
  /* Always 3 columns on desktop, never auto-fill */
  grid-template-columns: repeat(3, 1fr);
  gap: .875rem;
  margin-bottom: 1.375rem;
}

.stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 1.125rem 1rem;
  transition: all .2s;
  position: relative; overflow: hidden;
  min-width: 0; /* prevent flex overflow */
}
.stat-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0; transition:opacity .2s;
}
.stat-card:hover { border-color:var(--border-gold); background:var(--bg-card-hover); transform:translateY(-2px); box-shadow:var(--shadow-gold); }
.stat-card:hover::before { opacity:1; }

.stat-icon {
  width:38px; height:38px; border-radius:var(--r);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:.75rem; flex-shrink:0;
}
.stat-icon.gold  { background:rgba(240,185,11,.15); color:var(--gold); }
.stat-icon.green { background:rgba(14,203,129,.15);  color:var(--green); }
.stat-icon.red   { background:rgba(246,70,93,.15);   color:var(--red); }
.stat-icon.blue  { background:rgba(24,144,255,.15);  color:var(--blue); }

.stat-label {
  font-size:.68rem; color:var(--text-secondary); font-weight:600;
  text-transform:uppercase; letter-spacing:.5px; margin-bottom:.3rem;
}
.stat-value {
  font-family:'Rajdhani',sans-serif; font-size:1.4rem; font-weight:700;
  color:var(--text-primary); line-height:1.2;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.stat-value.gold  { color:var(--gold); }
.stat-value.green { color:var(--green); }
.stat-change {
  font-size:.7rem; margin-top:.3rem;
  display:flex; align-items:center; gap:.25rem;
}
.stat-change.up   { color:var(--green); }
.stat-change.down { color:var(--red); }

/* ════════════════════════════════
   SECTION CARDS / TABLES
════════════════════════════════ */
.section-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: 1.25rem;
}
.section-header {
  padding: .875rem 1.125rem;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .5rem;
}
.section-title {
  font-family:'Rajdhani',sans-serif; font-size:.9rem; font-weight:700;
  color:var(--text-primary); text-transform:uppercase; letter-spacing:1px;
  display:flex; align-items:center; gap:.5rem;
}
.section-title .dot { width:7px; height:7px; background:var(--gold); border-radius:50%; display:inline-block; }
.section-body { padding: 1.125rem; }

/* ── Tables ── */
.data-table { width:100%; border-collapse:collapse; }
.data-table th {
  padding:.5rem .75rem; text-align:left; font-size:.68rem; font-weight:600;
  color:var(--text-muted); text-transform:uppercase; letter-spacing:.5px;
  border-bottom:1px solid var(--border); white-space:nowrap;
}
.data-table td {
  padding:.65rem .75rem; font-size:.82rem; color:var(--text-primary);
  border-bottom:1px solid rgba(43,49,57,.5); vertical-align:middle;
}
.data-table tbody tr:last-child td { border-bottom:none; }
.data-table tbody tr:hover td { background:rgba(240,185,11,.025); }

/* ── Badges ── */
.badge {
  display:inline-flex; align-items:center;
  padding:.18rem .55rem; border-radius:100px;
  font-size:.67rem; font-weight:600; text-transform:uppercase; letter-spacing:.5px; white-space:nowrap;
}
.badge-success { background:rgba(14,203,129,.15);  color:var(--green); }
.badge-danger  { background:rgba(246,70,93,.15);   color:var(--red); }
.badge-warning { background:rgba(240,185,11,.15);  color:var(--gold); }
.badge-info    { background:rgba(24,144,255,.15);  color:var(--blue); }
.badge-muted   { background:rgba(132,142,156,.15); color:var(--text-secondary); }

/* ── Tabs ── */
.tabs { display:flex; gap:0; border-bottom:1px solid var(--border); margin-bottom:1.5rem; flex-wrap:wrap; }
.tab-btn {
  padding:.7rem 1.125rem; background:none; border:none;
  color:var(--text-secondary); font-size:.85rem; font-weight:500;
  cursor:pointer; position:relative; transition:color .2s; white-space:nowrap;
  font-family:'Inter',sans-serif;
}
.tab-btn::after { content:''; position:absolute; bottom:-1px; left:0; right:0; height:2px; background:var(--gold); transform:scaleX(0); transition:transform .2s; }
.tab-btn:hover  { color:var(--text-primary); }
.tab-btn.active { color:var(--gold); }
.tab-btn.active::after { transform:scaleX(1); }
.tab-panel { display:none; }
.tab-panel.active { display:block; }

/* ── Tier Cards ── */
.tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.tier-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:1.375rem 1.125rem;
  transition:all .3s; position:relative; overflow:hidden;
}
.tier-card:hover { border-color:var(--gold); transform:translateY(-3px); box-shadow:0 8px 28px rgba(240,185,11,.18); }
.tier-card.featured { border-color:var(--gold); background:linear-gradient(135deg,var(--bg-card) 0%,rgba(240,185,11,.05) 100%); }
.tier-badge {
  display:inline-flex; align-items:center; gap:.35rem;
  background:rgba(240,185,11,.15); color:var(--gold);
  padding:.3rem .7rem; border-radius:100px;
  font-size:.67rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-bottom:.75rem;
}
.tier-name   { font-family:'Orbitron',monospace; font-size:.78rem; font-weight:700; color:var(--text-primary); margin-bottom:.2rem; }
.tier-amount { font-family:'Rajdhani',sans-serif; font-size:1.75rem; font-weight:700; color:var(--gold); margin-bottom:.2rem; line-height:1; }
.tier-desc   { font-size:.75rem; color:var(--text-muted); margin-bottom:1rem; }
.tier-features { list-style:none; margin-bottom:1.25rem; }
.tier-features li { display:flex; align-items:flex-start; gap:.45rem; font-size:.77rem; color:var(--text-secondary); padding:.3rem 0; border-bottom:1px solid rgba(43,49,57,.5); }
.tier-features li:last-child { border-bottom:none; }
.tier-features li::before { content:'✓'; color:var(--green); font-weight:700; flex-shrink:0; margin-top:1px; }
.tier-tagline { font-family:'Rajdhani',sans-serif; font-size:.77rem; color:var(--text-muted); font-style:italic; margin-bottom:1.125rem; }

/* ── Week Badge ── */
.week-badge {
  background:var(--bg-input); border:1px solid var(--border-gold);
  border-radius:var(--r); padding:.65rem 1rem;
  display:flex; align-items:center; justify-content:space-between; gap:.75rem;
}
.week-badge .week-label  { font-size:.75rem; color:var(--text-secondary); white-space:nowrap; }
.week-badge .week-status { display:flex; align-items:center; gap:.4rem; font-size:.75rem; font-weight:600; color:var(--green); white-space:nowrap; }
.week-badge .week-status .dot-live { width:6px; height:6px; background:var(--green); border-radius:50%; animation:blink 1s ease-in-out infinite; flex-shrink:0; }
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ── Referral Box ── */
.referral-box {
  background:var(--bg-input); border:1px solid var(--border-gold);
  border-radius:var(--r); padding:.7rem 1rem;
  display:flex; align-items:center; gap:.75rem;
}
.referral-link { flex:1; color:var(--text-secondary); font-size:.82rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ── Search ── */
.search-wrapper { position:relative; }
.search-input {
  width:100%; background:var(--bg-input); border:1px solid var(--border);
  border-radius:var(--r); padding:.75rem 1rem .75rem 2.75rem;
  color:var(--text-primary); font-size:.9rem; font-family:'Inter',sans-serif;
  outline:none; transition:all .2s;
}
.search-input:focus { border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-glow); }
.search-icon { position:absolute; left:.875rem; top:50%; transform:translateY(-50%); color:var(--text-muted); pointer-events:none; }

/* ── Help ── */
.help-category { margin-bottom:1.75rem; }
.help-category-title { font-family:'Rajdhani',sans-serif; font-size:.875rem; font-weight:700; color:var(--gold); text-transform:uppercase; letter-spacing:1px; margin-bottom:.75rem; padding-bottom:.45rem; border-bottom:1px solid var(--border-gold); }
.help-article { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--r); margin-bottom:.65rem; overflow:hidden; }
.help-article-header { padding:.875rem 1rem; cursor:pointer; display:flex; align-items:center; justify-content:space-between; transition:background .2s; gap:.75rem; }
.help-article-header:hover { background:var(--bg-card-hover); }
.help-article-title { font-size:.85rem; font-weight:600; color:var(--text-primary); }
.help-article-body { padding:0 1rem 1rem; font-size:.82rem; color:var(--text-secondary); line-height:1.6; display:none; }
.help-article-body.open { display:block; }

/* ── Finance Account Cards ── */
.account-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:1rem 1.125rem;
  display:flex; align-items:flex-start; gap:.875rem;
  margin-bottom:.75rem; transition:all .2s;
}
.account-card:hover { border-color:var(--border-gold); }
.account-card.default { border-color:var(--gold); }
.account-icon { width:42px; height:42px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
.account-icon.bank  { background:rgba(24,144,255,.15); }
.account-icon.gcash { background:rgba(14,203,129,.15); }
.account-icon.maya  { background:rgba(240,185,11,.15); }

/* ── Modal ── */
.modal-overlay {
  position:fixed; inset:0;
  background:rgba(0,0,0,.72);
  display:none; align-items:center; justify-content:center;
  z-index:200; padding:1rem;
}
.modal-overlay.show { display:flex; }
.modal {
  background:var(--bg-card); border:1px solid var(--border-gold);
  border-radius:var(--r-lg); width:100%; max-width:480px;
  animation:slideUp .3s ease; max-height:90vh; overflow-y:auto;
}
.modal-header {
  padding:1.125rem 1.375rem; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; gap:.75rem;
}
.modal-title { font-family:'Rajdhani',sans-serif; font-size:.95rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; display:flex; align-items:center; }
.modal-close { background:none; border:none; color:var(--text-secondary); cursor:pointer; padding:.25rem; transition:color .2s; flex-shrink:0; }
.modal-close:hover { color:var(--red); }
.modal-body { padding:1.375rem; }
.modal-footer { padding:.875rem 1.375rem; border-top:1px solid var(--border); display:flex; gap:.75rem; justify-content:flex-end; }

/* ── Date Filter ── */
.date-filter { display:flex; gap:.75rem; align-items:flex-end; flex-wrap:wrap; margin-bottom:1.125rem; }

/* ── Profile Avatar ── */
.profile-avatar {
  width:68px; height:68px;
  background:linear-gradient(135deg,var(--gold-dark),var(--gold));
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-family:'Orbitron',monospace; font-weight:700; font-size:1.4rem; color:#000;
  margin:0 auto .875rem;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bg-primary); }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--gold-dark); }

/* ── Empty State ── */
.empty-state { text-align:center; padding:2.5rem 1rem; color:var(--text-muted); }
.empty-state svg { margin-bottom:.875rem; opacity:.4; }
.empty-state p { font-size:.875rem; }

/* ── Sidebar overlay ── */
.sidebar-overlay { position:fixed; inset:0; background:rgba(0,0,0,.55); z-index:99; display:none; }
.sidebar-overlay.show { display:block; }

/* ════════════════════════════════
   TRADINGVIEW RESPONSIVE WRAPPER
════════════════════════════════ */
.tv-chart-wrapper {
  position: relative;
  width: 100%;
  /* Mobile: 16:9 aspect ratio */
  padding-bottom: 60%;
  overflow: hidden;
  background: var(--bg-primary);
}
@media (min-width: 480px) { .tv-chart-wrapper { padding-bottom: 55%; } }
@media (min-width: 768px) { .tv-chart-wrapper { padding-bottom: 0; height: 460px; } }
@media (min-width: 1280px) { .tv-chart-wrapper { height: 500px; } }

#tv_chart_container {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
}
#tv_chart_container iframe,
#tv_chart_container > div { width:100% !important; height:100% !important; border:none !important; display:block !important; }

.tv-sym-btn {
  background:var(--bg-input); border:1px solid var(--border);
  color:var(--text-secondary); padding:.35rem .7rem;
  border-radius:var(--r); font-size:.73rem; font-weight:700;
  cursor:pointer; font-family:'Inter',sans-serif; letter-spacing:.5px;
  transition:all .15s; line-height:1; white-space:nowrap;
}
.tv-sym-btn:hover { color:var(--gold); border-color:rgba(240,185,11,.5); background:rgba(240,185,11,.07); }
.tv-sym-btn.active { color:#000; background:var(--gold); border-color:var(--gold); }

/* ════════════════════════════════
   RESPONSIVE BREAKPOINTS
════════════════════════════════ */

/* Large desktop — 6 stat cards in 3 cols */
@media (min-width: 1280px) {
  .stat-grid { grid-template-columns: repeat(3, 1fr); }
  .tier-grid { grid-template-columns: repeat(5, 1fr); }
}

/* Normal desktop */
@media (min-width: 1024px) and (max-width: 1279px) {
  .stat-grid { grid-template-columns: repeat(3, 1fr); }
  .tier-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Tablet landscape */
@media (min-width: 768px) and (max-width: 1023px) {
  .stat-grid { grid-template-columns: repeat(3, 1fr); }
  .tier-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Tablet portrait / large mobile */
@media (max-width: 767px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.open { transform: translateX(0); box-shadow: 4px 0 30px rgba(0,0,0,.55); }
  .main-content { margin-left: 0; }
  .menu-toggle  { display: flex; }

  .stat-grid    { grid-template-columns: repeat(2, 1fr); gap:.75rem; }
  .tier-grid    { grid-template-columns: repeat(2, 1fr); }
  .page-body    { padding: 1rem; }
  .top-header   { padding: 0 1rem; }

  .form-row     { grid-template-columns: 1fr; }
  .date-filter  { flex-direction: column; align-items: stretch; }
}

/* Mobile portrait */
@media (max-width: 480px) {
  .stat-grid    { grid-template-columns: repeat(2, 1fr); gap:.625rem; }
  .stat-card    { padding: .875rem .75rem; }
  .stat-value   { font-size: 1.15rem; }
  .stat-label   { font-size: .63rem; }
  .tier-grid    { grid-template-columns: 1fr; }
  .page-body    { padding: .875rem; }

  .auth-card    { padding: 1.5rem; }
  .modal-body, .modal-footer { padding: 1rem; }
  .section-body { padding: 1rem; }
  .section-header { padding: .75rem 1rem; }

  /* Stack welcome row vertically */
  .dash-welcome-row { flex-direction: column !important; align-items: flex-start !important; }
  .week-badge { width: 100%; }
}

/* Very small phones */
@media (max-width: 360px) {
  html { font-size: 13px; }
  .stat-grid  { gap: .5rem; }
  .stat-card  { padding: .75rem .625rem; }
  .stat-value { font-size: 1.05rem; }
  .page-body  { padding: .75rem; }
}
