/* =========================================================
   TradingWaves Journal UI System
   Premium SaaS Base - Light + Dark
========================================================= */

:root {
  --tw-radius-sm: 8px;
  --tw-radius-md: 12px;
  --tw-radius-lg: 18px;
  --tw-radius-xl: 24px;

  --tw-shadow-sm: 0 2px 8px rgba(15, 23, 42, .04);
  --tw-shadow-md: 0 8px 24px rgba(15, 23, 42, .08);
  --tw-shadow-lg: 0 18px 50px rgba(15, 23, 42, .12);

  --tw-font: "Inter", "Segoe UI", Arial, sans-serif;
}

body.theme-light {
  --tw-bg: #f5f8fc;
  --tw-sidebar: #ffffff;
  --tw-surface: #ffffff;
  --tw-surface-2: #f8fbff;
  --tw-surface-3: #eef5ff;
  --tw-border: #d9e6f5;
  --tw-border-soft: #edf3fa;
  --tw-text: #071f45;
  --tw-heading: #061a3a;
  --tw-muted: #617089;

  --tw-primary: #08c76f;
  --tw-primary-dark: #069e59;
  --tw-blue: #37a7d8;
  --tw-yellow: #d9b84e;
  --tw-red: #dc5b5b;
  --tw-green-soft: #e7fbf1;
  --tw-blue-soft: #eaf7fd;
  --tw-yellow-soft: #fff7df;
  --tw-red-soft: #fff0f0;
}

body.theme-dark {
  --tw-bg: #081426;
  --tw-sidebar: #0c1b30;
  --tw-surface: #10233d;
  --tw-surface-2: #142b4a;
  --tw-surface-3: #18365d;
  --tw-border: #244769;
  --tw-border-soft: #1d3958;
  --tw-text: #eaf2ff;
  --tw-heading: #ffffff;
  --tw-muted: #9fb3cf;

  --tw-primary: #12d879;
  --tw-primary-dark: #0fb968;
  --tw-blue: #4cb7df;
  --tw-yellow: #e0bf55;
  --tw-red: #ef6b6b;
  --tw-green-soft: rgba(18, 216, 121, .12);
  --tw-blue-soft: rgba(76, 183, 223, .13);
  --tw-yellow-soft: rgba(224, 191, 85, .14);
  --tw-red-soft: rgba(239, 107, 107, .13);
}

/* Global */
body.twj-app {
  font-family: var(--tw-font) !important;
  background: var(--tw-bg) !important;
  color: var(--tw-text) !important;
  font-size: 15px;
}

#page-wrapper {
  background: var(--tw-bg) !important;
  min-height: 100vh;
  border-left: 1px solid var(--tw-border-soft);
}

.container-fluid.twj-page,
.twj-page {
  max-width: 1480px;
  margin: 0 auto;
  padding: 24px 28px 48px !important;
}

/* Page headings */
.page-header,
.twj-page h1,
.twj-page h2 {
  color: var(--tw-heading) !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em;
  border-bottom: 1px solid var(--tw-border) !important;
}

.page-header {
  font-size: 34px !important;
  line-height: 1.12 !important;
  margin: 12px 0 22px !important;
  padding-bottom: 16px !important;
}

.twj-page h2:not(.page-header) {
  font-size: 30px;
}

.text-muted,
.review-muted {
  color: var(--tw-muted) !important;
}

/* Panels / cards */
.panel,
.twj-panel,
.review-card {
  background: var(--tw-surface) !important;
  border: 1px solid var(--tw-border) !important;
  border-radius: var(--tw-radius-lg) !important;
  box-shadow: var(--tw-shadow-sm) !important;
  overflow: hidden;
  margin-bottom: 24px !important;
}

.panel-heading {
  background: var(--tw-surface-2) !important;
  border-bottom: 1px solid var(--tw-border) !important;
  color: var(--tw-heading) !important;
  font-weight: 800 !important;
  font-size: 17px !important;
  padding: 16px 18px !important;
}

.panel-body {
  padding: 20px 22px !important;
}

/* Premium hover */
.panel:hover,
.twj-panel:hover {
  box-shadow: var(--tw-shadow-md) !important;
  transition: box-shadow .18s ease, transform .18s ease;
}

/* Buttons */
.btn {
  border-radius: 999px !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  padding: 8px 16px !important;
  min-height: 36px;
  border-width: 1px !important;
}

.btn-primary,
.btn-success {
  background: var(--tw-primary) !important;
  border-color: var(--tw-primary) !important;
  color: #fff !important;
}

.btn-primary:hover,
.btn-success:hover {
  background: var(--tw-primary-dark) !important;
  border-color: var(--tw-primary-dark) !important;
}

.btn-info {
  background: var(--tw-blue) !important;
  border-color: var(--tw-blue) !important;
  color: #fff !important;
}

.btn-warning {
  background: var(--tw-yellow) !important;
  border-color: var(--tw-yellow) !important;
  color: #1d2430 !important;
}

.btn-danger {
  background: var(--tw-red) !important;
  border-color: var(--tw-red) !important;
  color: #fff !important;
}

.btn-default {
  background: var(--tw-surface) !important;
  border-color: var(--tw-border) !important;
  color: var(--tw-text) !important;
}

/* Forms */
.form-control {
  background: var(--tw-surface) !important;
  border: 1px solid var(--tw-border) !important;
  border-radius: var(--tw-radius-md) !important;
  color: var(--tw-text) !important;
  box-shadow: none !important;
  min-height: 38px;
  font-size: 14px;
}

.form-control:focus {
  border-color: var(--tw-primary) !important;
  box-shadow: 0 0 0 3px rgba(8, 199, 111, .14) !important;
}

/* Tables */
.table {
  margin-bottom: 0;
}

.table > thead > tr > th {
  background: var(--tw-surface-2) !important;
  color: var(--tw-heading) !important;
  border-bottom: 1px solid var(--tw-border) !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  padding: 13px 12px !important;
}

.table > tbody > tr > td {
  color: var(--tw-text) !important;
  border-top: 1px solid var(--tw-border-soft) !important;
  padding: 13px 12px !important;
  vertical-align: middle !important;
}

.table > tbody > tr:hover {
  background: var(--tw-surface-2) !important;
}

/* Badges */
.review-badge,
.label {
  border-radius: 999px !important;
  padding: 5px 9px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

.review-badge.good,
.label-success {
  background: var(--tw-green-soft) !important;
  color: var(--tw-primary-dark) !important;
}

.review-badge.bad,
.label-danger {
  background: var(--tw-red-soft) !important;
  color: var(--tw-red) !important;
}

.review-badge.neutral,
.label-default {
  background: var(--tw-surface-3) !important;
  color: var(--tw-muted) !important;
}

/* Alerts */
.alert {
  border-radius: var(--tw-radius-lg) !important;
  border: 1px solid transparent !important;
  padding: 16px 18px !important;
}

.alert-success {
  background: var(--tw-green-soft) !important;
  border-color: rgba(8, 199, 111, .18) !important;
  color: var(--tw-primary-dark) !important;
}

.alert-info {
  background: var(--tw-blue-soft) !important;
  border-color: rgba(55, 167, 216, .2) !important;
  color: #126480 !important;
}

.alert-warning {
  background: var(--tw-yellow-soft) !important;
  border-color: rgba(217, 184, 78, .25) !important;
  color: #7a5c13 !important;
}

.alert-danger {
  background: var(--tw-red-soft) !important;
  border-color: rgba(220, 91, 91, .2) !important;
  color: var(--tw-red) !important;
}










/* =========================================================
   Sidebar - Premium App Navigation
========================================================= */

.navbar-default.sidebar {
  background: var(--tw-sidebar) !important;
  border-right: 1px solid var(--tw-border) !important;
  box-shadow: 8px 0 30px rgba(15, 23, 42, .03);
}

.sidebar .nav > li > a {
  color: var(--tw-text) !important;
  font-weight: 650;
  padding: 12px 18px !important;
  border-left: 3px solid transparent;
}

.sidebar .nav > li > a:hover,
.sidebar .nav > li > a:focus {
  background: var(--tw-surface-2) !important;
  color: var(--tw-primary-dark) !important;
  border-left-color: var(--tw-primary);
}

.sidebar .nav-second-level > li > a {
  padding: 10px 18px 10px 32px !important;
  font-size: 13px;
  color: var(--tw-muted) !important;
}

.sidebar .nav-second-level > li > a:hover {
  color: var(--tw-primary-dark) !important;
}

.twj-sidebar-group-label {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--tw-muted);
  padding: 22px 18px 8px;
}

.twj-community-promo {
  margin: 20px 14px 24px;
  padding: 18px;
  border-radius: var(--tw-radius-lg);
  background: linear-gradient(180deg, var(--tw-surface-2), var(--tw-surface));
  border: 1px solid var(--tw-border);
}

.twj-upgrade-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--tw-heading);
  margin: 0 0 8px;
}

.twj-upgrade-text {
  font-size: 13px;
  color: var(--tw-muted);
}

.twj-upgrade-benefits {
  padding-left: 16px;
  font-size: 12px;
  color: var(--tw-text);
}

.twj-upgrade-btn {
  width: 100%;
  margin-top: 10px;
}













/* =========================================================
   KPI / Stat Cards
========================================================= */

.review-stat-card,
.twj-review-stat-card,
.dashboard-card,
.twj-kpi-card {
  border: 1px solid var(--tw-border) !important;
  border-radius: var(--tw-radius-lg) !important;
  background: var(--tw-surface) !important;
  box-shadow: var(--tw-shadow-sm) !important;
  overflow: hidden;
}

.review-stat-card .panel-heading,
.twj-review-stat-card .panel-heading {
  min-height: 108px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(circle at top right, rgba(8,199,111,.12), transparent 34%),
    var(--tw-surface) !important;
  border-bottom: none !important;
}

.review-stat-value,
.twj-review-stat-value {
  font-size: 34px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  color: var(--tw-heading) !important;
}

.review-stat-label,
.twj-review-stat-label {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--tw-muted) !important;
  margin-top: 8px;
}













/* =========================================================
   Review Hub
========================================================= */

.twj-page-review-hub .review-section-subtitle,
.twj-page-review-hub .twj-review-hub-top-note {
  font-size: 15px;
  color: var(--tw-muted);
  margin-bottom: 18px;
}

.twj-review-hub-status-row {
  margin-bottom: 12px;
}

.twj-review-hub-status-alert,
.twj-review-hub-inline-alert {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.twj-review-hub-inline-btn {
  margin-left: 12px;
}

.review-label {
  color: var(--tw-heading);
  font-weight: 800;
}

.twj-review-hub-actions-panel .btn-block {
  margin-bottom: 10px;
}

.twj-review-hub-actions-panel .btn-block:last-child {
  margin-bottom: 0;
}

.thumbnail {
  border: 1px solid var(--tw-border) !important;
  border-radius: var(--tw-radius-lg) !important;
  background: var(--tw-surface) !important;
  padding: 10px !important;
  box-shadow: var(--tw-shadow-sm);
}

.thumbnail img {
  border-radius: var(--tw-radius-md);
}

.thumbnail .caption {
  padding: 12px 4px 4px !important;
}

















/* =========================================================
   Dashboard
========================================================= */

.twj-dashboard-hero,
.twj-dashboard-section {
  background: var(--tw-surface);
  border: 1px solid var(--tw-border);
  border-radius: var(--tw-radius-xl);
  box-shadow: var(--tw-shadow-sm);
  padding: 24px;
  margin-bottom: 24px;
}

.twj-dashboard-kpis {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 24px 0;
}

.twj-dashboard-kpis > * {
  float: none !important;
  width: auto !important;
}

.twj-metric-value {
  font-size: 28px !important;
  font-weight: 900 !important;
  color: var(--tw-heading) !important;
}

.twj-metric-label {
  font-size: 13px !important;
  color: var(--tw-muted) !important;
  font-weight: 700;
}

@media (max-width: 1200px) {
  .twj-dashboard-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .twj-dashboard-kpis {
    grid-template-columns: 1fr;
  }
}











/* =========================================================
   Top Brand
========================================================= */

.twj-app-brand {
  display: flex !important;
  align-items: center;
  gap: 10px;
  height: 56px !important;
  padding: 8px 18px !important;
  color: var(--tw-heading) !important;
}

.twj-brand-mark {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, #d7ff45, #7aa300 60%, #1c2b00);
  box-shadow: 0 0 14px rgba(168, 220, 20, .45);
  flex: 0 0 auto;
}

.twj-brand-text-wrap {
  display: flex;
  flex-direction: column;
  line-height: 1.05;
}

.twj-brand-title {
  font-size: 17px;
  font-weight: 900;
  letter-spacing: -.03em;
}

.twj-brand-subtitle {
  font-size: 9px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--tw-muted);
}









.twj-page-kicker {
  color: var(--tw-primary-dark);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-weight: 900;
  margin-bottom: 6px;
}















/* =========================================================
   TWJ PREMIUM UI PASS 01
   Add this at the VERY BOTTOM of assets/css/twj-ui.css
========================================================= */

/* ---------- App width and spacing ---------- */

body.theme-light #page-wrapper,
body.theme-dark #page-wrapper {
    padding-top: 0 !important;
}

body.theme-light .twj-page,
body.theme-dark .twj-page {
    max-width: 1440px !important;
    margin: 0 auto !important;
    padding: 28px 28px 48px !important;
}

/* ---------- Typography ---------- */

body.theme-light,
body.theme-dark {
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: 14px;
}

body.theme-light h1,
body.theme-light h2,
body.theme-light h3,
body.theme-dark h1,
body.theme-dark h2,
body.theme-dark h3 {
    font-weight: 800 !important;
    letter-spacing: -0.04em;
}

body.theme-light .page-header,
body.theme-dark .page-header {
    font-size: 34px !important;
    line-height: 1.1 !important;
    margin: 30px 0 22px !important;
    padding-bottom: 18px !important;
}

/* ---------- Premium panels ---------- */

body.theme-light .panel,
body.theme-dark .panel {
    border-radius: 18px !important;
    overflow: hidden !important;
    box-shadow: 0 10px 30px rgba(15, 35, 70, 0.08) !important;
}

body.theme-dark .panel {
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.28) !important;
}

body.theme-light .panel-heading,
body.theme-dark .panel-heading {
    padding: 18px 22px !important;
    font-size: 16px !important;
}

body.theme-light .panel-body,
body.theme-dark .panel-body {
    padding: 22px !important;
}

/* ---------- Buttons ---------- */

body.theme-light .btn,
body.theme-dark .btn {
    border-radius: 999px !important;
    font-weight: 700 !important;
    letter-spacing: -0.01em;
}

body.theme-light .btn-success,
body.theme-light .btn-primary,
body.theme-dark .btn-success,
body.theme-dark .btn-primary {
    background: linear-gradient(135deg, #00d26a, #00b85c) !important;
    border-color: transparent !important;
    box-shadow: 0 8px 20px rgba(0, 210, 106, 0.22) !important;
}

body.theme-light .btn-warning,
body.theme-dark .btn-warning {
    background: linear-gradient(135deg, #e7c64f, #d4aa28) !important;
    border-color: transparent !important;
    color: #152033 !important;
}

/* ---------- KPI / stat cards ---------- */

body.theme-light .review-stat-card,
body.theme-dark .review-stat-card,
body.theme-light .twj-review-stat-card,
body.theme-dark .twj-review-stat-card,
body.theme-light .dashboard-card,
body.theme-dark .dashboard-card {
    border-radius: 18px !important;
    overflow: hidden !important;
}

body.theme-light .review-stat-value,
body.theme-dark .review-stat-value,
body.theme-light .twj-review-stat-value,
body.theme-dark .twj-review-stat-value,
body.theme-light .twj-metric-value,
body.theme-dark .twj-metric-value {
    font-size: 30px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: -0.04em;
}

body.theme-light .review-stat-label,
body.theme-dark .review-stat-label,
body.theme-light .twj-review-stat-label,
body.theme-dark .twj-review-stat-label,
body.theme-light .twj-metric-label,
body.theme-dark .twj-metric-label {
    font-size: 12px !important;
    font-weight: 700 !important;
    color: var(--tw-muted) !important;
}

/* ---------- Tables ---------- */

body.theme-light .table,
body.theme-dark .table {
    margin-bottom: 0 !important;
}

body.theme-light .table > thead > tr > th,
body.theme-dark .table > thead > tr > th {
    font-size: 12px !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

body.theme-light .table > tbody > tr,
body.theme-dark .table > tbody > tr {
    transition: background 0.18s ease, transform 0.18s ease;
}

body.theme-light .table > tbody > tr:hover {
    background: #f5fbff !important;
}

body.theme-dark .table > tbody > tr:hover {
    background: rgba(255,255,255,0.035) !important;
}

/* ---------- Forms ---------- */

body.theme-light .form-control,
body.theme-dark .form-control {
    min-height: 38px !important;
    border-radius: 12px !important;
}

/* ---------- Alerts ---------- */

body.theme-light .alert,
body.theme-dark .alert {
    border-radius: 16px !important;
    padding: 18px 22px !important;
}

/* ---------- Sidebar polish ---------- */

.twj-sidebar-group-label {
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: 0.16em !important;
    text-transform: uppercase !important;
    color: var(--tw-muted) !important;
    padding: 18px 12px 8px !important;
}

.sidebar .nav > li > a {
    font-weight: 700 !important;
}

/* ---------- Dark mode improvements ---------- */

body.theme-dark {
    --tw-bg: #071426;
    --tw-surface: #102844;
    --tw-surface-2: #143352;
    --tw-border: rgba(135, 180, 255, 0.18);
    --tw-text: #f4f8ff;
    --tw-muted: #9db3d8;
}

body.theme-dark .navbar,
body.theme-dark .navbar-default {
    background: #08182b !important;
    border-color: rgba(255,255,255,0.08) !important;
}

body.theme-dark .sidebar {
    background: #0b1d33 !important;
}

body.theme-dark .sidebar .nav > li > a {
    color: #f4f8ff !important;
}

body.theme-dark .sidebar .nav > li > a:hover,
body.theme-dark .sidebar .nav > li.active > a {
    background: rgba(0, 210, 106, 0.12) !important;
    color: #ffffff !important;
}

/* ---------- Mobile ---------- */

@media (max-width: 768px) {
    body.theme-light .twj-page,
    body.theme-dark .twj-page {
        padding: 18px 14px 36px !important;
    }

    body.theme-light .page-header,
    body.theme-dark .page-header {
        font-size: 28px !important;
    }
}












/* =========================================================
   TWJ PREMIUM UI PASS 02
========================================================= */

/* ---------- Global surfaces ---------- */

body.theme-dark {
    background:
        radial-gradient(circle at top left, rgba(0,210,106,0.06), transparent 25%),
        radial-gradient(circle at top right, rgba(0,140,255,0.08), transparent 30%),
        #03101f !important;
}

body.theme-light {
    background:
        radial-gradient(circle at top left, rgba(0,210,106,0.03), transparent 20%),
        #f3f6fb !important;
}

/* ---------- Main content ---------- */

#page-wrapper {
    border-left: 1px solid rgba(255,255,255,0.04);
}

body.theme-light #page-wrapper {
    border-left: 1px solid rgba(20,40,70,0.06);
}

/* ---------- Premium cards ---------- */

body.theme-dark .panel,
body.theme-dark .dashboard-card,
body.theme-dark .review-stat-card,
body.theme-dark .twj-review-stat-card {
    background:
        linear-gradient(
            180deg,
            rgba(16,40,68,0.98),
            rgba(10,26,44,0.98)
        ) !important;

    border: 1px solid rgba(120,170,255,0.12) !important;
}

body.theme-light .panel,
body.theme-light .dashboard-card,
body.theme-light .review-stat-card,
body.theme-light .twj-review-stat-card {
    background: rgba(255,255,255,0.92) !important;
    border: 1px solid rgba(20,40,70,0.08) !important;
}

/* ---------- Hover depth ---------- */

body.theme-dark .panel:hover,
body.theme-dark .dashboard-card:hover,
body.theme-dark .review-stat-card:hover,
body.theme-dark .twj-review-stat-card:hover {
    transform: translateY(-2px);
    transition: all 0.2s ease;
    box-shadow:
        0 18px 40px rgba(0,0,0,0.30),
        0 0 0 1px rgba(0,210,106,0.06) !important;
}

body.theme-light .panel:hover,
body.theme-light .dashboard-card:hover,
body.theme-light .review-stat-card:hover,
body.theme-light .twj-review-stat-card:hover {
    transform: translateY(-2px);
    transition: all 0.2s ease;
    box-shadow:
        0 20px 40px rgba(15,35,70,0.10),
        0 0 0 1px rgba(0,210,106,0.05) !important;
}

/* ---------- Metric cards ---------- */

body.theme-dark .twj-metric-value,
body.theme-dark .review-stat-value,
body.theme-dark .twj-review-stat-value {
    color: #ffffff !important;
    text-shadow: 0 2px 12px rgba(255,255,255,0.08);
}

body.theme-light .twj-metric-value,
body.theme-light .review-stat-value,
body.theme-light .twj-review-stat-value {
    color: #031b3d !important;
}

/* ---------- Tables ---------- */

body.theme-dark .table {
    background: transparent !important;
}

body.theme-dark .table > thead > tr > th {
    background: rgba(255,255,255,0.02);
    border-bottom: 1px solid rgba(255,255,255,0.06) !important;
}

body.theme-dark .table > tbody > tr {
    border-bottom: 1px solid rgba(255,255,255,0.04);
}

body.theme-dark .table > tbody > tr:hover {
    transform: scale(1.002);
}

/* ---------- Inputs ---------- */

body.theme-dark .form-control,
body.theme-dark select,
body.theme-dark input {
    background: rgba(7,22,38,0.92) !important;
    border: 1px solid rgba(120,170,255,0.14) !important;
    color: #f5f8ff !important;
}

body.theme-light .form-control,
body.theme-light select,
body.theme-light input {
    background: #ffffff !important;
}

body.theme-dark .form-control:focus,
body.theme-dark select:focus,
body.theme-dark input:focus {
    border-color: rgba(0,210,106,0.5) !important;
    box-shadow:
        0 0 0 3px rgba(0,210,106,0.10) !important;
}

/* ---------- Sidebar ---------- */

body.theme-dark .sidebar {
    background:
        linear-gradient(
            180deg,
            #081a2e 0%,
            #061423 100%
        ) !important;
}

body.theme-dark .sidebar .nav > li {
    border-bottom: 1px solid rgba(255,255,255,0.04);
}

body.theme-dark .sidebar .nav > li > a {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
}

body.theme-dark .sidebar .nav > li.active > a {
    border-left: 3px solid #00d26a !important;
}

/* ---------- Pills / status ---------- */

.label,
.badge {
    border-radius: 999px !important;
    font-weight: 700 !important;
    padding: 6px 10px !important;
}

/* ---------- Page title polish ---------- */

.page-header,
h1.page-header {
    position: relative;
}

.page-header::after,
h1.page-header::after {
    content: "";
    display: block;
    width: 72px;
    height: 4px;
    margin-top: 14px;
    border-radius: 999px;
    background: linear-gradient(
        90deg,
        #00d26a,
        #00a2ff
    );
}

/* ---------- CTA buttons ---------- */

.btn-success:hover,
.btn-primary:hover {
    transform: translateY(-1px);
    filter: brightness(1.04);
}

.btn {
    transition: all 0.18s ease;
}

/* ---------- Top navbar ---------- */

.navbar {
    backdrop-filter: blur(12px);
}

/* ---------- Empty sections ---------- */

body.theme-dark .well,
body.theme-light .well {
    border-radius: 18px !important;
}

/* ---------- Review workflow cards ---------- */

.review-progress-card,
.next-action-card {
    border-radius: 18px !important;
    overflow: hidden;
}

/* ---------- Scrollbars ---------- */

::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-thumb {
    background: rgba(120,140,180,0.45);
    border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(120,140,180,0.70);
}













/* =========================================================
   DASHBOARD CALENDAR FIX - PREMIUM GRID
   Keep this at the VERY END of twj-ui.css
========================================================= */

#dashboard-calendar-anchor {
  scroll-margin-top: 90px;
}

.twj-calendar-panel-body {
  padding: 18px !important;
}

.twj-calendar-wrap {
  width: 100%;
}

.calendar-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 18px !important;
}

.twj-calendar-nav-center {
  text-align: center !important;
}

.calendar-month-title {
  margin: 0 0 8px !important;
  font-weight: 800 !important;
  color: var(--tw-text) !important;
}

.calendar-grid {
  display: grid !important;
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 10px !important;
  width: 100% !important;
}

.calendar-weekday {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 34px !important;
  border-radius: 10px !important;
  background: var(--tw-surface-2) !important;
  color: var(--tw-muted) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}

.calendar-day {
  min-height: 118px !important;
  padding: 10px !important;
  border: 1px solid var(--tw-border) !important;
  border-radius: 14px !important;
  background: var(--tw-surface) !important;
  color: var(--tw-text) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 5px !important;
  overflow: hidden !important;
}

.calendar-day.empty {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.calendar-day.positive {
  background: linear-gradient(135deg, rgba(17,194,109,.13), var(--tw-surface)) !important;
  border-color: rgba(17,194,109,.35) !important;
}

.calendar-day.negative {
  background: linear-gradient(135deg, rgba(217,83,79,.13), var(--tw-surface)) !important;
  border-color: rgba(217,83,79,.35) !important;
}

.calendar-day-number {
  font-size: 16px !important;
  font-weight: 900 !important;
  color: var(--tw-text) !important;
}

.calendar-day-trades {
  font-size: 12px !important;
  color: var(--tw-muted) !important;
}

.calendar-day-pnl {
  font-size: 13px !important;
  font-weight: 800 !important;
  color: var(--tw-text) !important;
}

.calendar-day-meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin-top: auto !important;
}

.calendar-day-badge {
  display: inline-flex !important;
  align-items: center !important;
  border-radius: 999px !important;
  padding: 2px 7px !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  background: rgba(217,83,79,.13) !important;
  color: var(--tw-red) !important;
}

.calendar-day-badge.trades {
  background: rgba(17,194,109,.14) !important;
  color: var(--tw-green) !important;
}

.calendar-day-badge.journal {
  background: rgba(78,174,208,.14) !important;
  color: var(--tw-blue) !important;
}

.calendar-day-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-top: 6px !important;
}

.calendar-day-link {
  font-size: 11px !important;
  font-weight: 800 !important;
  color: var(--tw-blue) !important;
  text-decoration: none !important;
}

.calendar-day-link:hover {
  text-decoration: underline !important;
}

.twj-chart-side-body {
  min-height: 220px !important;
}

.twj-chart-side-body canvas {
  width: 100% !important;
  max-height: 220px !important;
}

/* Dark mode table/calendar contrast fix */
body.theme-dark .calendar-day,
body.theme-dark .calendar-weekday {
  background-color: var(--tw-surface) !important;
}

body.theme-dark .calendar-weekday {
  background-color: var(--tw-surface-2) !important;
}

/* Mobile */
@media (max-width: 991px) {
  .calendar-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .calendar-weekday {
    display: none !important;
  }

  .calendar-day.empty {
    display: none !important;
  }

  .calendar-nav {
    flex-direction: column !important;
  }
}

@media (max-width: 520px) {
  .calendar-grid {
    grid-template-columns: 1fr !important;
  }
}












/* =========================================================
   DASHBOARD FIX PASS 03 - TOOLBAR, HEADINGS, CHARTS
========================================================= */

/* Dashboard top toolbar */
.twj-dashboard-toolbar {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  width: 100% !important;
}

.twj-dashboard-toolbar-center {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.twj-dashboard-toolbar-center form {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 0 !important;
}

.twj-dashboard-toolbar-theme {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-left: auto !important;
}

.twj-reset-layout-btn {
  flex: 0 0 auto !important;
}

/* Stop filters/buttons from overlapping */
.dashboard-filter-panel .form-inline {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
}

.dashboard-filter-panel .form-inline label {
  margin: 0 2px 0 0 !important;
  font-size: 12px !important;
  color: var(--tw-muted) !important;
  font-weight: 800 !important;
}

.dashboard-filter-panel .form-inline .form-control {
  width: auto !important;
  max-width: 180px !important;
}

/* Collapse headings */
.dashboard-collapse-toggle {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  color: var(--tw-text) !important;
  text-decoration: none !important;
}

.dashboard-collapse-toggle:hover,
.dashboard-collapse-toggle:focus {
  color: var(--tw-text) !important;
  text-decoration: none !important;
}

.dashboard-collapse-toggle .section-title,
.panel-heading .section-title {
  display: inline-flex !important;
  align-items: center !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  color: var(--tw-text) !important;
}

.dashboard-collapse-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(0,210,106,.10) !important;
  color: var(--tw-green) !important;
  flex: 0 0 auto !important;
}

.panel-heading > a {
  display: flex !important;
}

/* Compact dashboard panels */
.twj-compact-panel .panel-heading {
  min-height: auto !important;
  padding: 14px 18px !important;
}

.twj-compact-panel .panel-body {
  padding: 16px 18px !important;
}

/* Today's actions */
.twj-actions-panel .panel-body .row {
  display: flex;
  flex-wrap: wrap;
}

.twj-next-task-box {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  margin-bottom: 14px !important;
}

.twj-next-task-action {
  flex: 0 0 auto !important;
}

.twj-quick-actions-bar {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 14px !important;
  padding-top: 14px !important;
  border-top: 1px solid var(--tw-border) !important;
}

/* Tables more terminal/pro */
.twj-table-compact > thead > tr > th,
.compact-table > thead > tr > th {
  padding: 10px 12px !important;
  font-size: 11px !important;
}

.twj-table-compact > tbody > tr > td,
.compact-table > tbody > tr > td {
  padding: 9px 12px !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
}

/* KPI cards not too tall */
.twj-kpi-card .panel-heading {
  min-height: 118px !important;
  padding: 14px 10px !important;
}

.twj-kpi-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 8px !important;
  background: rgba(0,210,106,.12) !important;
  color: var(--tw-green) !important;
}

.twj-cell-subtext {
  margin-top: 7px !important;
  font-size: 11px !important;
  line-height: 1.35 !important;
  color: var(--tw-muted) !important;
}

/* Mobile toolbar */
@media (max-width: 991px) {
  .twj-dashboard-toolbar,
  .twj-dashboard-toolbar-center,
  .twj-dashboard-toolbar-theme,
  .dashboard-filter-panel .form-inline {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .twj-dashboard-toolbar-center,
  .twj-dashboard-toolbar-theme {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .twj-dashboard-toolbar-center form,
  .dashboard-filter-panel .form-inline .form-control,
  .twj-dashboard-toolbar .btn {
    width: 100% !important;
    max-width: 100% !important;
  }

  .twj-next-task-box {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
}











/* =========================================================
   DASHBOARD FIX PASS 04 - CHARTS + PANEL HEADINGS
========================================================= */

.twj-panel-heading-with-subtitle .dashboard-collapse-toggle {
  align-items: center !important;
}

.twj-heading-text {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  min-width: 0 !important;
}

.twj-panel-subtitle {
  display: block !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-weight: 500 !important;
  color: var(--tw-muted) !important;
  letter-spacing: 0 !important;
  max-width: 850px !important;
}

/* Main chart sizing */
.twj-chart-main-body {
  height: 360px !important;
  max-height: 360px !important;
  padding: 18px !important;
}

.twj-main-chart-wrap {
  position: relative !important;
  width: 100% !important;
  height: 320px !important;
  max-height: 320px !important;
}

.twj-main-chart-wrap canvas,
#equityChartMini {
  width: 100% !important;
  height: 320px !important;
  max-height: 320px !important;
}

/* Side/small chart sizing */
.twj-chart-side-body,
.twj-donut-card .panel-body,
.twj-chart-card .panel-body,
.dashboard-chart-card .panel-body {
  position: relative !important;
  height: 260px !important;
  max-height: 260px !important;
  min-height: 260px !important;
  overflow: hidden !important;
}

.twj-chart-side-body canvas,
.twj-donut-card canvas,
.twj-chart-card canvas,
.dashboard-chart-card canvas {
  width: 100% !important;
  height: 220px !important;
  max-height: 220px !important;
}

/* Goals / progress bars */
.twj-target-row {
  margin-bottom: 18px !important;
}

.twj-target-label {
  display: flex !important;
  justify-content: space-between !important;
  gap: 10px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  color: var(--tw-text) !important;
  margin-bottom: 7px !important;
}

.twj-target-value {
  color: var(--tw-muted) !important;
  font-weight: 700 !important;
}

.progress {
  height: 9px !important;
  border-radius: 999px !important;
  background: rgba(120, 150, 190, .16) !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

.progress-bar {
  border-radius: 999px !important;
}

/* Mini intelligence cards */
.twj-mini-intel-card .panel-heading {
  min-height: 96px !important;
  padding: 14px !important;
}

.twj-mini-intel-card .twj-metric-value {
  font-size: 18px !important;
  line-height: 1.15 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}

/* Score cards */
.twj-score-card {
  border-radius: 18px !important;
  padding: 24px !important;
  min-height: 145px !important;
  background: var(--tw-surface) !important;
  border: 1px solid var(--tw-border) !important;
  box-shadow: 0 10px 30px rgba(0,0,0,.12) !important;
}

.twj-score-value {
  font-size: 46px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: -0.05em !important;
}

.twj-score-title {
  margin-top: 10px !important;
  font-size: 13px !important;
  color: var(--tw-muted) !important;
  font-weight: 800 !important;
}

/* Prevent weird long panels */
canvas {
  max-width: 100% !important;
}








/* =========================================================
   DASHBOARD FIX PASS 05 - COLLAPSE HEADINGS + DONUT CHART
========================================================= */

.dashboard-collapse-toggle {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 4px 12px !important;
}

.dashboard-collapse-toggle .section-title {
  order: 1 !important;
  flex: 1 1 auto !important;
}

.dashboard-collapse-toggle .dashboard-collapse-icon {
  order: 2 !important;
  margin-left: auto !important;
}

.dashboard-collapse-toggle .twj-panel-subtitle {
  order: 3 !important;
  flex: 0 0 100% !important;
  display: block !important;
  margin-top: 2px !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-weight: 500 !important;
  color: var(--tw-muted) !important;
  letter-spacing: 0 !important;
}









/* Win vs Loss donut hard sizing */
.twj-donut-panel {
  height: auto !important;
}

.twj-donut-panel-body {
  height: 300px !important;
  max-height: 300px !important;
  min-height: 300px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.twj-donut-chart-wrap {
  position: relative !important;
  width: 100% !important;
  height: 220px !important;
  max-height: 220px !important;
}

.twj-donut-chart-wrap canvas,
#winLossChart {
  width: 100% !important;
  height: 220px !important;
  max-height: 220px !important;
}

.twj-donut-stats {
  display: flex !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-top: 10px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.twj-donut-stat-win {
  color: var(--tw-green) !important;
}

.twj-donut-stat-loss {
  color: var(--tw-red) !important;
}













/* =========================================================
   WIN VS LOSS DONUT FINAL FIX
========================================================= */

.twj-donut-panel-body {
  height: 300px !important;
  min-height: 300px !important;
  max-height: 300px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}

.twj-donut-chart-wrap {
  position: relative !important;
  width: 100% !important;
  height: 220px !important;
  max-height: 220px !important;
}

.twj-donut-chart-wrap canvas,
#winLossChart {
  width: 100% !important;
  height: 220px !important;
  max-height: 220px !important;
  display: block !important;
}

.twj-donut-stats {
  display: flex !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 14px !important;
  margin-top: 8px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.twj-donut-stat-win {
  color: var(--tw-green) !important;
}

.twj-donut-stat-loss {
  color: var(--tw-red) !important;
}











/* =========================================================
   PREMIUM PANEL HEADINGS / COLLAPSE FIX
========================================================= */

.twj-panel > .panel-heading {
  border-radius: 18px 18px 0 0 !important;
  padding: 16px 20px !important;
  border: 0 !important;
  background: rgba(255,255,255,0.72) !important;
  border-bottom: 1px solid rgba(14, 38, 68, 0.08) !important;
}

.twj-panel .dashboard-collapse-toggle {
  display: grid !important;
  grid-template-columns: auto 32px 1fr !important;
  align-items: center !important;
  gap: 14px !important;
  width: 100% !important;
  text-decoration: none !important;
  color: inherit !important;
  border: 0 !important;
  outline: none !important;
}

.twj-panel .section-title {
  font-size: 15px !important;
  font-weight: 900 !important;
  letter-spacing: -0.01em !important;
  color: #061b3a !important;
  white-space: nowrap !important;
}

.twj-panel .twj-panel-subtitle {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #54708f !important;
  line-height: 1.4 !important;
}

.twj-panel .dashboard-collapse-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(0, 207, 140, 0.12) !important;
  color: #062342 !important;
  order: 2 !important;
}

.twj-panel .twj-panel-subtitle {
  order: 3 !important;
}

.twj-panel .section-title {
  order: 1 !important;
}

/* Remove ugly browser focus rectangle */
.twj-panel .dashboard-collapse-toggle:focus,
.twj-panel .dashboard-collapse-toggle:active {
  outline: none !important;
  box-shadow: none !important;
  border: 0 !important;
}







body.theme-dark .twj-panel > .panel-heading {
  background: rgba(20, 54, 89, 0.92) !important;
  border-bottom: 1px solid rgba(120, 170, 220, 0.16) !important;
}

body.theme-dark .twj-panel .section-title {
  color: #ffffff !important;
}

body.theme-dark .twj-panel .twj-panel-subtitle {
  color: #9db3d8 !important;
}

body.theme-dark .twj-panel .dashboard-collapse-icon {
  background: rgba(0, 207, 140, 0.16) !important;
  color: #ffffff !important;
}














/* =========================================================
   TABLE ACTION BUTTON STACK FIX
========================================================= */

.twj-action-stack,
.btn-group-vertical.twj-action-stack {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  align-items: stretch !important;
}

.twj-action-stack .btn,
.btn-group-vertical.twj-action-stack .btn {
  margin: 0 !important;
  border-radius: 999px !important;
  min-width: 112px !important;
  padding: 8px 14px !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  box-shadow: 0 8px 18px rgba(0, 207, 140, 0.16) !important;
}

.twj-table td {
  vertical-align: middle !important;
}

.twj-table td:last-child {
  min-width: 135px !important;
}











/* =========================================================
   DONUT SPACING FINAL POLISH
========================================================= */

.twj-donut-panel-body {
  padding-bottom: 28px !important;
}

.twj-donut-stats {
  margin-top: 12px !important;
  margin-bottom: 8px !important;
  position: relative !important;
  z-index: 2 !important;
}

.twj-donut-panel {
  overflow: hidden !important;
}











/* =========================================================
   PREMIUM TAG / LABEL STYLE
========================================================= */

.twj-table .label,
.twj-inline-badge,
.label {
  border-radius: 999px !important;
  padding: 7px 11px !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: -0.01em !important;
  border: 1px solid rgba(255,255,255,0.35) !important;
}

.twj-table .label-success,
.label-success {
  background: rgba(0, 207, 140, 0.14) !important;
  color: #00895f !important;
}

.twj-table .label-danger,
.label-danger {
  background: rgba(239, 68, 68, 0.13) !important;
  color: #dc2626 !important;
}

.twj-table .label-warning,
.label-warning {
  background: rgba(245, 158, 11, 0.16) !important;
  color: #b77900 !important;
}

.twj-table .label-info,
.label-info {
  background: rgba(56, 189, 248, 0.16) !important;
  color: #087ea4 !important;
}

body.theme-dark .twj-table .label,
body.theme-dark .label {
  border-color: rgba(255,255,255,0.08) !important;
}















/* =========================================================
   DASHBOARD DENSITY FIX - PREMIUM COMPACT MODE
========================================================= */

.twj-panel,
.dashboard-panel,
.twj-card,
.twj-kpi-card,
.twj-score-card {
  border-radius: 14px !important;
}

.twj-panel > .panel-heading {
  padding: 13px 18px !important;
  min-height: 48px !important;
}

.twj-panel > .panel-body,
.dashboard-panel > .panel-body {
  padding: 18px 20px !important;
}

.twj-secondary-row,
.twj-core-support-row,
.twj-dashboard-chart-row,
.twj-score-row,
.twj-score-message-row {
  margin-top: 18px !important;
  margin-bottom: 18px !important;
}

.twj-kpi-grid {
  gap: 18px !important;
  margin-top: 22px !important;
  margin-bottom: 24px !important;
}

.twj-kpi-card {
  min-height: 108px !important;
}

.twj-kpi-card .panel-heading {
  padding: 18px 14px !important;
}

.twj-metric-value {
  font-size: 28px !important;
  line-height: 1.05 !important;
}

.twj-metric-label {
  font-size: 12px !important;
}

.twj-kpi-icon {
  width: 28px !important;
  height: 28px !important;
  margin-bottom: 7px !important;
}






/* =========================================================
   WIN VS LOSS DONUT FIX
========================================================= */

.twj-donut-panel {
  min-height: auto !important;
}

.twj-donut-panel-body {
  height: 255px !important;
  padding: 16px 20px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.twj-donut-panel-body canvas {
  max-width: 210px !important;
  max-height: 210px !important;
}

.twj-donut-stats {
  margin-top: 8px !important;
  margin-bottom: 0 !important;
  display: flex !important;
  justify-content: center !important;
  gap: 14px !important;
  font-size: 12px !important;
}








/* =========================================================
   ACTIONS / PROFILE COMPACT FIX
========================================================= */

.twj-actions-panel .panel-body {
  padding: 16px 20px !important;
}

.twj-next-task-box {
  min-height: 68px !important;
  padding: 16px 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.twj-today-links .list-group-item {
  padding: 10px 14px !important;
  font-size: 13px !important;
}

.twj-quick-actions-bar {
  margin-top: 14px !important;
  padding-top: 14px !important;
  gap: 8px !important;
}

.twj-quick-actions-bar .btn {
  padding: 8px 14px !important;
}

.twj-profile-summary {
  padding: 16px 20px !important;
}

.twj-profile-item {
  margin-bottom: 8px !important;
}

.twj-profile-label {
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  color: #64748b !important;
}

.twj-profile-value {
  font-size: 13px !important;
  font-weight: 700 !important;
}

.twj-profile-guidance {
  margin-top: 10px !important;
  font-size: 13px !important;
}











/* =========================================================
   TABLE ACTION BUTTONS SMALLER
========================================================= */

.twj-action-stack .btn,
.btn-group-vertical.twj-action-stack .btn {
  min-width: 104px !important;
  padding: 7px 12px !important;
  font-size: 11px !important;
  box-shadow: none !important;
}

.twj-table td {
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}










/* =========================================================
   DASHBOARD DENSITY FIX - PREMIUM COMPACT MODE
========================================================= */

.twj-panel,
.dashboard-panel,
.twj-card,
.twj-kpi-card,
.twj-score-card {
  border-radius: 14px !important;
}

.twj-panel > .panel-heading {
  padding: 13px 18px !important;
  min-height: 48px !important;
}

.twj-panel > .panel-body,
.dashboard-panel > .panel-body {
  padding: 18px 20px !important;
}

.twj-secondary-row,
.twj-core-support-row,
.twj-dashboard-chart-row,
.twj-score-row,
.twj-score-message-row {
  margin-top: 18px !important;
  margin-bottom: 18px !important;
}

.twj-kpi-grid {
  gap: 18px !important;
  margin-top: 22px !important;
  margin-bottom: 24px !important;
}

.twj-kpi-card {
  min-height: 108px !important;
}

.twj-kpi-card .panel-heading {
  padding: 18px 14px !important;
}

.twj-metric-value {
  font-size: 28px !important;
  line-height: 1.05 !important;
}

.twj-metric-label {
  font-size: 12px !important;
}

.twj-kpi-icon {
  width: 28px !important;
  height: 28px !important;
  margin-bottom: 7px !important;
}








/* =========================================================
   WIN VS LOSS DONUT FIX
========================================================= */

.twj-donut-panel {
  min-height: auto !important;
}

.twj-donut-panel-body {
  height: 255px !important;
  padding: 16px 20px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.twj-donut-panel-body canvas {
  max-width: 210px !important;
  max-height: 210px !important;
}

.twj-donut-stats {
  margin-top: 8px !important;
  margin-bottom: 0 !important;
  display: flex !important;
  justify-content: center !important;
  gap: 14px !important;
  font-size: 12px !important;
}

.twj-donut-panel {
  max-height: 360px !important;
  overflow: hidden !important;
}

.twj-donut-panel-body {
  height: 285px !important;
  padding: 14px 20px 18px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
}

.twj-donut-panel-body canvas {
  max-width: 210px !important;
  max-height: 210px !important;
}

.twj-donut-stats {
  margin-top: 8px !important;
  margin-bottom: 0 !important;
  display: flex !important;
  gap: 14px !important;
  justify-content: center !important;
  font-size: 12px !important;
}

.twj-donut-panel-body {
  height: 285px !important;
  padding: 14px 20px 18px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.twj-donut-chart-wrap {
  width: 210px !important;
  height: 210px !important;
  position: relative !important;
}

.twj-donut-chart-wrap canvas {
  width: 210px !important;
  height: 210px !important;
  max-width: 210px !important;
  max-height: 210px !important;
}

.twj-donut-stats {
  margin-top: 10px !important;
  display: flex !important;
  justify-content: center !important;
  gap: 14px !important;
  font-size: 12px !important;
}









/* =========================================================
   ACTIONS / PROFILE COMPACT FIX
========================================================= */

.twj-actions-panel .panel-body {
  padding: 16px 20px !important;
}

.twj-next-task-box {
  min-height: 68px !important;
  padding: 16px 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.twj-today-links .list-group-item {
  padding: 10px 14px !important;
  font-size: 13px !important;
}

.twj-quick-actions-bar {
  margin-top: 14px !important;
  padding-top: 14px !important;
  gap: 8px !important;
}

.twj-quick-actions-bar .btn {
  padding: 8px 14px !important;
}

.twj-profile-summary {
  padding: 16px 20px !important;
}

.twj-profile-item {
  margin-bottom: 8px !important;
}

.twj-profile-label {
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  color: #64748b !important;
}

.twj-profile-value {
  font-size: 13px !important;
  font-weight: 700 !important;
}

.twj-profile-guidance {
  margin-top: 10px !important;
  font-size: 13px !important;
}











/* =========================================================
   TABLE ACTION BUTTONS SMALLER
========================================================= */

.twj-action-stack .btn,
.btn-group-vertical.twj-action-stack .btn {
  min-width: 104px !important;
  padding: 7px 12px !important;
  font-size: 11px !important;
  box-shadow: none !important;
}

.twj-table td {
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}













/* =========================================================
   TWJ FINAL COMPACT PREMIUM PASS
========================================================= */

.twj-panel,
.dashboard-panel,
.twj-chart-panel {
  margin-bottom: 18px !important;
}

.twj-panel > .panel-heading {
  min-height: 44px !important;
  padding: 12px 18px !important;
}

.twj-panel > .panel-body {
  padding: 16px 20px !important;
}

.twj-kpi-grid {
  gap: 16px !important;
  margin: 20px 0 24px !important;
}

.twj-kpi-card {
  min-height: 104px !important;
}

.twj-kpi-card .panel-heading {
  padding: 16px 12px !important;
}

.twj-metric-value {
  font-size: 26px !important;
}

.twj-cell-subtext {
  font-size: 11px !important;
  line-height: 1.3 !important;
}

.twj-secondary-row,
.twj-core-support-row,
.twj-dashboard-chart-row,
.twj-score-row,
.twj-score-message-row {
  margin-top: 16px !important;
  margin-bottom: 16px !important;
}



















.dashboard-collapse-toggle {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  width: 100% !important;
  text-decoration: none !important;
  color: inherit !important;
}

.dashboard-collapse-toggle .section-title {
  flex: 0 0 auto !important;

  font-size: 15px !important;
  font-weight: 800 !important;
  color: #061b3a !important;

  white-space: nowrap !important;
}

.dashboard-collapse-icon {
  flex: 0 0 auto !important;

  width: 26px !important;
  height: 26px !important;

  border-radius: 999px !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  background: rgba(0, 207, 140, 0.12) !important;
  color: #062342 !important;
}

.twj-panel-subtitle {
  flex: 1 1 auto !important;

  font-size: 12px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;

  color: #64748b !important;

  min-width: 0 !important;
}












/* =========================================================
   GLOBAL DASHBOARD DENSITY
========================================================= */

.twj-panel {
  margin-bottom: 16px !important;
}

.twj-panel > .panel-body {
  padding: 16px 18px !important;
}

.twj-secondary-row {
  margin-top: 14px !important;
  margin-bottom: 14px !important;
}

.twj-mini-kpi-row {
  margin-bottom: 10px !important;
}

.twj-chart-panel {
  min-height: auto !important;
}

.table-responsive {
  margin-bottom: 0 !important;
}









/* =========================================================
   TABLE COMPACT MODE
========================================================= */

.twj-table th {
  padding: 11px 12px !important;
  font-size: 11px !important;
  letter-spacing: .04em !important;
}

.twj-table td {
  padding: 10px 12px !important;
  font-size: 12px !important;
  vertical-align: middle !important;
}

.twj-table .label {
  padding: 5px 9px !important;
  font-size: 10px !important;
}

.twj-cell-subtext {
  margin-top: 2px !important;
  font-size: 10px !important;
}










/* =========================================================
   KPI CARDS COMPACT
========================================================= */

.twj-kpi-card {
  min-height: 96px !important;
}

.twj-kpi-card .panel-heading {
  padding: 14px 10px !important;
}

.twj-metric-value {
  font-size: 24px !important;
  line-height: 1 !important;
}

.twj-metric-label {
  margin-top: 4px !important;
  font-size: 11px !important;
}













/* =========================================================
   CHART HEIGHT NORMALIZATION
========================================================= */

.twj-chart-panel .panel-body {
  height: 260px !important;
}

#dailyPnLChart {
  max-height: 220px !important;
}

#equityChartMain {
  max-height: 220px !important;
}

#strategyPnLChart,
#strategyWinRateChart,
#setupPnLChart,
#setupWinRateChart {
  max-height: 190px !important;
}













/* =========================================================
   PREMIUM HOVER FEEDBACK
========================================================= */

.twj-panel,
.twj-kpi-card,
.twj-score-card {
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease;
}

.twj-panel:hover,
.twj-kpi-card:hover,
.twj-score-card:hover {
  transform: translateY(-2px);
  box-shadow:
    0 10px 24px rgba(15, 23, 42, 0.06),
    0 2px 8px rgba(15, 23, 42, 0.04);
}










/* =========================================================
   PREMIUM SECTION HEADERS
========================================================= */

.twj-panel > .panel-heading {
  min-height: 52px;
  padding: 0 18px !important;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  display: flex;
  align-items: center;
}

.twj-panel > .panel-heading .dashboard-collapse-toggle {
  width: 100%;
  min-height: 52px;
  display: grid !important;
  grid-template-columns: auto 32px 1fr;
  align-items: center;
  column-gap: 14px;
  color: inherit;
  text-decoration: none !important;
}

.twj-panel > .panel-heading .section-title {
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #071b3a;
  white-space: nowrap;
}

.twj-panel > .panel-heading .twj-panel-subtitle {
  font-size: 12px;
  font-weight: 500;
  color: #55708f;
  line-height: 1.35;
}

.dashboard-collapse-icon {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 204, 136, 0.12);
  color: #006f5f;
}

.dashboard-collapse-icon i {
  font-size: 12px;
}













body.theme-dark .twj-panel > .panel-heading {
  background: rgba(19, 53, 86, 0.82) !important;
  border-bottom-color: rgba(148, 163, 184, 0.18) !important;
}

body.theme-dark .twj-panel > .panel-heading .section-title {
  color: #f8fafc;
}

body.theme-dark .twj-panel > .panel-heading .twj-panel-subtitle {
  color: #9fb6d3;
}

body.theme-dark .dashboard-collapse-icon {
  background: rgba(0, 204, 136, 0.16);
  color: #6ee7b7;
}












/* =========================================================
   COMPACT PROFESSIONAL DASHBOARD SPACING
========================================================= */

.twj-dashboard-section,
.twj-panel {
  margin-bottom: 18px !important;
}

.twj-panel .panel-body {
  padding: 16px 18px !important;
}

.twj-metric-card,
.twj-stat-card,
.dashboard-stat-card {
  min-height: auto !important;
  padding: 14px 16px !important;
  border-radius: 16px !important;
}

.twj-metric-value,
.dashboard-stat-value {
  font-size: 30px !important;
  line-height: 1 !important;
  margin-bottom: 4px !important;
}

.twj-metric-label,
.dashboard-stat-label {
  font-size: 12px !important;
  opacity: 0.82;
}

/* Tables */

.twj-panel table tbody td,
.twj-panel table thead th {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  vertical-align: middle !important;
}

.twj-panel table thead th {
  font-size: 11px !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* Buttons */

.twj-panel .btn,
.twj-action-btn {
  min-height: 36px !important;
  padding: 8px 14px !important;
  border-radius: 12px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

/* Chart panels */

.twj-chart-panel .panel-body {
  padding: 14px 18px 18px !important;
}

.twj-chart-panel canvas {
  max-height: 280px !important;
}

/* Reduce giant empty gaps */

.row.twj-dashboard-chart-row,
.row.twj-secondary-row {
  margin-bottom: 10px !important;
}

/* Compact badges */

.label,
.badge,
.twj-status-pill {
  font-size: 11px !important;
  padding: 5px 10px !important;
  border-radius: 999px !important;
}














/* =========================================================
   DASHBOARD VISUAL HIERARCHY
========================================================= */

/* Primary panels */
.twj-primary-panel {
  border: 1px solid rgba(0, 207, 140, 0.18) !important;

  box-shadow:
    0 8px 24px rgba(15, 23, 42, 0.04),
    0 2px 6px rgba(15, 23, 42, 0.03) !important;
}

/* Secondary analytics */
.twj-secondary-panel {
  opacity: 0.98;
}

/* Tertiary informational blocks */
.twj-tertiary-panel {
  opacity: 0.95;
  border-color: rgba(148, 163, 184, 0.12) !important;
}

/* Stronger section separation */
.twj-dashboard-section {
  margin-top: 26px !important;
}

.twj-dashboard-section:first-child {
  margin-top: 0 !important;
}










/* =========================================================
   SECTION TITLE ACCENT
========================================================= */

.section-title::before {
  content: '';

  width: 6px;
  height: 16px;

  border-radius: 999px;

  background: linear-gradient(
    180deg,
    #00cf8c,
    #0ea5e9
  );

  display: inline-block;

  margin-right: 10px;

  vertical-align: middle;
}











/* =========================================================
   PREMIUM INTERACTION FEEDBACK
========================================================= */

.twj-panel {
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    background-color .18s ease;
}

.twj-panel:hover {
  transform: translateY(-2px);

  box-shadow:
    0 14px 30px rgba(15, 23, 42, 0.06),
    0 2px 10px rgba(15, 23, 42, 0.05);
}











/* =========================================================
   DARK MODE DEPTH
========================================================= */

body.theme-dark .twj-panel {
  background:
    linear-gradient(
      180deg,
      rgba(20, 44, 74, 0.96),
      rgba(14, 33, 58, 0.98)
    ) !important;

  border-color:
    rgba(148, 163, 184, 0.10) !important;
}

body.theme-dark .twj-primary-panel {
  border-color:
    rgba(0, 207, 140, 0.20) !important;
}















/* =========================================================
   TRADING COMMAND CENTER STYLE
========================================================= */

.twj-command-panel {
  border: 1px solid rgba(0, 207, 140, 0.22) !important;
  background:
    radial-gradient(circle at top left, rgba(0, 207, 140, 0.08), transparent 28%),
    var(--tw-surface) !important;
}

body.theme-dark .twj-command-panel {
  background:
    radial-gradient(circle at top left, rgba(0, 207, 140, 0.12), transparent 28%),
    linear-gradient(180deg, rgba(17, 42, 72, .98), rgba(8, 24, 43, .98)) !important;
}

.twj-command-panel > .panel-heading {
  background: transparent !important;
  border-bottom: 1px solid rgba(0, 207, 140, 0.16) !important;
}

.twj-command-panel .section-title::before {
  background: linear-gradient(180deg, #00cf8c, #c7ff4f) !important;
}










/* =========================================================
   COMMAND CENTER QUICK ACTIONS
========================================================= */

.twj-quick-actions-bar {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

.twj-quick-actions-bar .btn {
  border-radius: 12px !important;
  min-height: 38px !important;
  padding: 9px 15px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

.twj-quick-actions-bar .btn i {
  margin-right: 5px !important;
}









/* =========================================================
   COMMAND CENTER LINK CARDS
========================================================= */

.twj-today-links .list-group-item {
  border: 1px solid var(--tw-border) !important;
  border-radius: 12px !important;
  margin-bottom: 8px !important;
  background: var(--tw-surface-2) !important;
  color: var(--tw-text) !important;
  font-weight: 700 !important;
  transition: all .16s ease;
}

.twj-today-links .list-group-item:hover {
  transform: translateX(3px);
  border-color: rgba(0, 207, 140, .35) !important;
  color: var(--tw-green) !important;
}

.twj-today-links .list-group-item i {
  width: 18px;
  margin-right: 6px;
  color: var(--tw-green);
}











/* =========================================================
   PROP FIRM SCORE CARDS
========================================================= */

.twj-score-row {
  margin-top: 20px !important;
  margin-bottom: 14px !important;
}

.twj-score-card {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  padding: 22px 24px !important;
  min-height: 128px !important;
  background:
    radial-gradient(circle at top right, rgba(0, 207, 140, .10), transparent 34%),
    var(--tw-surface) !important;
  border: 1px solid rgba(0, 207, 140, .16) !important;
}

body.theme-dark .twj-score-card {
  background:
    radial-gradient(circle at top right, rgba(0, 207, 140, .14), transparent 34%),
    linear-gradient(180deg, rgba(18, 43, 73, .98), rgba(9, 24, 43, .98)) !important;
}

.twj-score-card::after {
  content: "";
  position: absolute;
  right: -34px;
  top: -34px;
  width: 96px;
  height: 96px;
  border-radius: 999px;
  background: rgba(0, 207, 140, .08);
  pointer-events: none;
}

.twj-score-value {
  font-size: 42px !important;
  font-weight: 950 !important;
  line-height: .95 !important;
  letter-spacing: -0.06em !important;
  color: var(--tw-text) !important;
}

.twj-score-title {
  margin-top: 10px !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  color: var(--tw-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}

.twj-score-alert {
  margin-top: 0 !important;
  min-height: 56px !important;
  padding: 12px 14px !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
}












/* =========================================================
   DASHBOARD SECTION SEPARATORS
========================================================= */

.twj-dashboard-section {
  position: relative !important;
  margin-top: 34px !important;
  padding-top: 26px !important;
}

.twj-dashboard-section::before {
  content: '';

  position: absolute;
  top: 0;
  left: 0;
  right: 0;

  height: 1px;

  background:
    linear-gradient(
      90deg,
      transparent,
      rgba(0, 207, 140, 0.18),
      transparent
    );
}

body.theme-dark .twj-dashboard-section::before {
  background:
    linear-gradient(
      90deg,
      transparent,
      rgba(0, 207, 140, 0.24),
      transparent
    );
}










/* =========================================================
   DASHBOARD STICKY NAV
========================================================= */

.twj-dashboard-nav {
  position: sticky;
  top: 72px;
  z-index: 40;

  display: flex;
  flex-wrap: wrap;
  gap: 10px;

  padding: 12px 0 18px;

  backdrop-filter: blur(14px);

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.88),
      rgba(255,255,255,0.58)
    );
}

body.theme-dark .twj-dashboard-nav {
  background:
    linear-gradient(
      180deg,
      rgba(7,19,35,0.92),
      rgba(7,19,35,0.68)
    );
}

.twj-dashboard-nav a {
  padding: 9px 14px;

  border-radius: 999px;

  text-decoration: none !important;

  font-size: 12px;
  font-weight: 800;

  color: var(--tw-text);

  background: rgba(0, 207, 140, 0.08);

  transition:
    transform .15s ease,
    background .15s ease;
}

.twj-dashboard-nav a:hover {
  transform: translateY(-1px);

  background: rgba(0, 207, 140, 0.16);
}

















html {
  scroll-behavior: smooth;
  scroll-padding-top: 110px;
}

.twj-dashboard-nav {
  position: sticky;
  top: 0;
  z-index: 50;

  display: flex;
  gap: 10px;
  flex-wrap: wrap;

  padding: 14px 18px;
  margin-bottom: 24px;

  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);

  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 14px;

  box-shadow: 0 4px 18px rgba(0,0,0,0.04);
}

.theme-dark .twj-dashboard-nav {
  background: rgba(17,24,39,0.92);
  border-color: rgba(255,255,255,0.06);
}

.twj-dashboard-nav a {
  padding: 8px 14px;
  border-radius: 999px;

  font-size: 12px;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;

  color: #6b7280;
  text-decoration: none;

  transition: all .18s ease;
}

.twj-dashboard-nav a:hover {
  background: rgba(107,115,0,0.12);
  color: #6b7300;
}

.twj-dashboard-section {
  margin-top: 34px;
  padding-top: 8px;
}













/* =========================================================
   STICKY DASHBOARD NAV POLISH
========================================================= */

.twj-dashboard-only-nav {
  top: 64px !important;
}

.twj-dashboard-nav {
  justify-content: center;
}

.twj-dashboard-nav a {
  border: 1px solid transparent;
}

.twj-dashboard-nav a:hover {
  border-color: rgba(0, 207, 140, .28);
  background: rgba(0, 207, 140, .10);
  color: var(--tw-green);
  transform: translateY(-1px);
}

body.theme-dark .twj-dashboard-nav a {
  color: #9fb3d8;
}

body.theme-dark .twj-dashboard-nav a:hover {
  color: #6ee7b7;
}












/* =========================================================
   DASHBOARD HERO PREMIUM UPGRADE
========================================================= */

.twj-dashboard-hero {
  position: relative;
  overflow: hidden;

  border: 1px solid rgba(0, 207, 140, .18) !important;
  border-radius: 22px !important;

  background:
    radial-gradient(circle at top left, rgba(0, 207, 140, .12), transparent 30%),
    radial-gradient(circle at bottom right, rgba(14, 165, 233, .10), transparent 28%),
    var(--tw-surface) !important;

  box-shadow:
    0 18px 44px rgba(15, 23, 42, .08),
    inset 0 1px 0 rgba(255,255,255,.04) !important;
}

body.theme-dark .twj-dashboard-hero {
  background:
    radial-gradient(circle at top left, rgba(0, 207, 140, .14), transparent 30%),
    radial-gradient(circle at bottom right, rgba(14, 165, 233, .16), transparent 28%),
    linear-gradient(180deg, rgba(16, 42, 72, .98), rgba(8, 24, 43, .98)) !important;

  box-shadow:
    0 20px 48px rgba(0, 0, 0, .30),
    inset 0 1px 0 rgba(255,255,255,.04) !important;
}

.twj-dashboard-hero::after {
  content: "";
  position: absolute;
  right: -90px;
  top: -90px;
  width: 260px;
  height: 260px;
  border-radius: 999px;
  background: rgba(0, 207, 140, .08);
  pointer-events: none;
}

.twj-dashboard-hero-kicker {
  color: var(--tw-green) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  margin-bottom: 8px !important;
}

.twj-dashboard-title {
  border-bottom: 0 !important;
  margin: 0 0 10px !important;
  padding-bottom: 0 !important;
  font-size: 36px !important;
  letter-spacing: -0.055em !important;
}

.twj-dashboard-title::after {
  display: none !important;
}

.twj-dashboard-hero-subtitle {
  max-width: 760px !important;
  margin: 0 !important;
  color: var(--tw-muted) !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
}

.twj-hero-plan-box {
  min-width: 170px !important;
  padding: 16px 18px !important;
  border-radius: 18px !important;
  background: rgba(0, 207, 140, .09) !important;
  border: 1px solid rgba(0, 207, 140, .18) !important;
  text-align: right !important;
}

.twj-hero-plan-label {
  font-size: 11px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .10em !important;
  color: var(--tw-muted) !important;
}

.twj-hero-plan-value {
  margin-top: 5px !important;
  font-size: 20px !important;
  font-weight: 900 !important;
  color: var(--tw-text) !important;
}

@media (max-width: 768px) {
  .twj-dashboard-hero {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .twj-dashboard-title {
    font-size: 28px !important;
  }

  .twj-hero-plan-box {
    width: 100% !important;
    text-align: left !important;
    margin-top: 16px !important;
  }
}













/* =========================================================
   MARKET FILTER CONTROL PANEL
========================================================= */

.twj-control-panel {
  border-radius: 18px !important;
  border: 1px solid rgba(0, 207, 140, .12) !important;
}

.twj-control-panel > .panel-heading {
  background: transparent !important;
  border-bottom: 1px solid var(--tw-border) !important;
}

.twj-control-panel .form-inline {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: end !important;
  gap: 10px !important;
}

.twj-control-panel label {
  font-size: 11px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--tw-muted) !important;
  margin: 0 4px 0 0 !important;
}

.twj-control-panel .form-control {
  min-height: 38px !important;
  border-radius: 12px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.twj-control-panel .btn {
  min-height: 38px !important;
  padding-left: 18px !important;
  padding-right: 18px !important;
}

body.theme-dark .twj-control-panel {
  background:
    linear-gradient(180deg, rgba(16, 42, 72, .94), rgba(8, 24, 43, .96)) !important;
}







/* =========================================================
   FILTER LAYOUT IMPROVEMENT
========================================================= */

.twj-control-panel .panel-body {
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

.twj-control-panel .form-group {
  margin-bottom: 0 !important;
}

.twj-control-panel .form-inline {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 12px !important;
}

.twj-control-panel .form-inline .form-group {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.twj-control-panel select.form-control {
  min-width: 150px !important;
}

.twj-control-panel input.form-control {
  min-width: 140px !important;
}

.twj-control-panel .btn {
  white-space: nowrap !important;
}








/* =========================================================
   KPI COMPRESSION
========================================================= */

.twj-stat-card,
.dashboard-stat-card,
.metric-card {
  min-height: 138px !important;
}

.twj-stat-card .panel-body,
.dashboard-stat-card .panel-body,
.metric-card .panel-body {
  padding-top: 18px !important;
  padding-bottom: 16px !important;
}

.twj-stat-value {
  margin-bottom: 2px !important;
  line-height: 1 !important;
}








/* =========================================================
   DASHBOARD MAX WIDTH
========================================================= */

.twj-dashboard-shell {
  max-width: 1500px;
  margin: 0 auto;
}













.twj-dashboard-shell {
  max-width: 1480px;
  margin: 0 auto;
}

.twj-hero-plan-box {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: center !important;
  gap: 8px !important;
}

.twj-hero-billing-btn {
  border-radius: 999px !important;
  padding: 7px 14px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
}

@media (max-width: 768px) {
  .twj-hero-plan-box {
    align-items: flex-start !important;
  }
}
















/* =========================================================
   DASHBOARD FINAL POLISH PASS - NAV + SECTIONS + DENSITY
========================================================= */

/* 1) Stop dashboard nav from floating over charts */
.twj-dashboard-nav,
.twj-dashboard-only-nav {
  position: relative !important;
  top: auto !important;
  z-index: 1 !important;
  margin: 18px 0 24px !important;
  padding: 12px 16px !important;
  justify-content: center !important;
  background: rgba(255,255,255,0.72) !important;
  border: 1px solid rgba(14, 38, 68, 0.08) !important;
  border-radius: 16px !important;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.05) !important;
}

body.theme-dark .twj-dashboard-nav,
body.theme-dark .twj-dashboard-only-nav {
  background: rgba(16, 35, 61, 0.82) !important;
  border-color: rgba(120, 170, 220, 0.14) !important;
}

/* 2) Make visual chapters separators, not huge boxed sections */
.twj-dashboard-section {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin-top: 26px !important;
  margin-bottom: 18px !important;
}

.twj-dashboard-section::before {
  display: none !important;
}

/* 3) Reduce dashboard vertical bloat */
.twj-panel,
.dashboard-panel {
  margin-bottom: 18px !important;
}

.twj-panel > .panel-heading,
.dashboard-panel > .panel-heading {
  min-height: 46px !important;
  padding: 12px 18px !important;
}

.twj-panel > .panel-body,
.dashboard-panel > .panel-body {
  padding: 16px 18px !important;
}

/* 4) Compact KPI cards */
.twj-dashboard-kpis {
  gap: 14px !important;
  margin-top: 18px !important;
  margin-bottom: 22px !important;
}

.twj-kpi-card .panel-heading {
  min-height: 96px !important;
  padding: 14px 12px !important;
}

.twj-kpi-icon {
  width: 24px !important;
  height: 24px !important;
  margin-bottom: 6px !important;
}

.twj-metric-value {
  font-size: 25px !important;
}

.twj-cell-subtext {
  font-size: 10.5px !important;
  margin-top: 5px !important;
}

/* 5) Cleaner collapsed heading alignment */
.twj-panel .dashboard-collapse-toggle {
  grid-template-columns: auto 28px 1fr !important;
  gap: 10px !important;
}

.twj-panel .section-title {
  font-size: 14px !important;
}

.twj-panel .twj-panel-subtitle {
  font-size: 11.5px !important;
}

/* 6) Compact charts */
.twj-chart-panel .panel-body {
  height: 300px !important;
  max-height: 300px !important;
  padding: 14px 18px !important;
}

.twj-chart-panel canvas {
  max-height: 255px !important;
}










/* =========================================================
   DASHBOARD COMPACT PREMIUM PASS
   Add at the very bottom of twj-ui.css
========================================================= */

/* 1. Reduce vertical space between dashboard panels */
.twj-page .row,
.twj-secondary-row,
.twj-core-support-row,
.twj-core-support-subrow,
.twj-dashboard-chart-row,
.twj-score-row,
.twj-score-message-row,
.twj-dashboard-pro-filter-row {
    margin-bottom: 16px !important;
}

/* 2. Compact all dashboard panels */
.twj-page .twj-panel,
.twj-page .dashboard-panel,
.twj-page .twj-card,
.twj-page .twj-chart-panel,
.twj-page .twj-compact-panel {
    margin-bottom: 16px !important;
    border-radius: 16px !important;
}

/* 3. Compact panel headings */
.twj-page .twj-panel > .panel-heading,
.twj-page .dashboard-panel > .panel-heading,
.twj-page .twj-chart-panel > .panel-heading,
.twj-page .twj-compact-panel > .panel-heading {
    padding: 12px 18px !important;
    min-height: 52px !important;
    display: flex !important;
    align-items: center !important;
}

/* 4. Make collapse header links cleaner */
.twj-page .dashboard-collapse-toggle {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
}

.twj-page .dashboard-collapse-toggle .section-title {
    font-size: 15px !important;
    line-height: 1.2 !important;
}

.twj-page .twj-panel-subtitle {
    font-size: 12px !important;
    line-height: 1.25 !important;
    opacity: 0.78 !important;
}

/* 5. Compact collapsed panels */
.twj-page .panel-collapse:not(.in) {
    display: none !important;
}

/* 6. Compact panel body */
.twj-page .panel-body {
    padding: 18px 20px !important;
}

/* 7. Compact tables */
.twj-page .twj-table th,
.twj-page .twj-table td,
.twj-page .table th,
.twj-page .table td {
    padding: 10px 12px !important;
    font-size: 13px !important;
    vertical-align: middle !important;
}

/* 8. Compact buttons */
.twj-page .btn {
    padding: 7px 14px !important;
    border-radius: 999px !important;
    line-height: 1.2 !important;
}

.twj-page .btn-sm,
.twj-page .btn-xs {
    padding: 6px 12px !important;
    font-size: 12px !important;
}

/* 9. Compact action button stacks */
.twj-page .twj-action-stack .btn {
    margin-bottom: 6px !important;
    min-width: 120px !important;
}

/* 10. Compact alerts */
.twj-page .alert,
.twj-page .twj-compact-alert {
    padding: 12px 16px !important;
    margin-bottom: 12px !important;
    border-radius: 14px !important;
}

/* 11. Compact mini KPI rows */
.twj-page .twj-mini-kpi-row,
.twj-page .twj-mini-stat-row {
    margin-bottom: 14px !important;
}

.twj-page .twj-mini-intel-card .panel-heading,
.twj-page .twj-kpi-card .panel-heading {
    padding: 18px 14px !important;
}

/* 12. Reduce hero vertical height */
.twj-page .twj-dashboard-hero {
    padding: 28px 32px !important;
    margin-bottom: 18px !important;
}

.twj-page .twj-dashboard-title {
    font-size: 30px !important;
    margin-top: 10px !important;
    margin-bottom: 12px !important;
}

.twj-page .twj-dashboard-hero-subtitle {
    margin-bottom: 16px !important;
}

/* 13. Compact filter areas */
.twj-page .dashboard-filter-panel .panel-body,
.twj-page .twj-dashboard-pro-filter-row,
.twj-page .twj-dashboard-filter-row {
    padding-top: 14px !important;
    padding-bottom: 14px !important;
}

/* 14. Dark mode table contrast fix */
.theme-dark .twj-page .table-striped > tbody > tr:nth-of-type(odd) {
    background-color: rgba(255,255,255,0.035) !important;
}

.theme-dark .twj-page .table-striped > tbody > tr:nth-of-type(even) {
    background-color: transparent !important;
}

.theme-dark .twj-page .twj-table th,
.theme-dark .twj-page .table th {
    background-color: rgba(255,255,255,0.06) !important;
}











/* =========================================================
   DASHBOARD WIDGET FOUNDATION
========================================================= */

.twj-dashboard-widget {
  width: 100%;
  margin-bottom: 16px;
}

.twj-widget-full {
  display: block;
}

.twj-widget-half {
  width: 50%;
}

.twj-widget-wide {
  width: 66.666%;
}

@media (max-width: 992px) {
  .twj-widget-half,
  .twj-widget-wide {
    width: 100%;
  }
}









/* =========================================================
   DASHBOARD GRID SYSTEM
========================================================= */

.twj-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 18px;
    width: 100%;
    align-items: start;
}

/* Widget Base */

.twj-dashboard-widget {
    min-width: 0;
}

/* Full Width */

.twj-widget-full {
    grid-column: span 12;
}

/* Half Width */

.twj-widget-half {
    grid-column: span 6;
}

/* Wide */

.twj-widget-wide {
    grid-column: span 8;
}

/* Small */

.twj-widget-small {
    grid-column: span 4;
}

/* Mobile */

@media (max-width: 1200px) {

    .twj-widget-half,
    .twj-widget-wide,
    .twj-widget-small {
        grid-column: span 12;
    }
}











/* =========================================================
   DRAG & DROP
========================================================= */

.twj-widget-ghost {
    opacity: 0.4;
}

.twj-widget-chosen {
    transform: scale(1.01);
}

.twj-widget-dragging {
    cursor: grabbing;
}







.twj-dashboard-grid{
    display:flex;
    flex-direction:column;
    gap:20px;
}

.twj-dashboard-widget {
    position: relative;
}

.twj-widget-drag-handle {
    position: absolute;
    top: 18px;
    right: 18px;
    z-index: 20;
    width: 34px;
    height: 34px;
    padding: 0;
    border: 1px solid rgba(148, 163, 184, 0.35);
    border-radius: 999px;
    background: #f8fafc;
    color: #64748b;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: grab;
    opacity: 0.7;
    transition: background-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease, transform 0.15s ease;
}

.twj-dashboard-widget:hover .twj-widget-drag-handle {
    opacity: 1;
}

.twj-widget-drag-handle:hover {
    background: #eaf7f1;
    color: #00a86b;
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.1);
}

.twj-widget-drag-handle:active {
    cursor: grabbing;
    transform: scale(0.96);
}

.twj-widget-chosen .twj-widget-drag-handle {
    cursor: grabbing;
}















/* Dashboard widget grid layout */
#twj-dashboard-grid.twj-dashboard-grid {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    gap: 24px !important;
    align-items: start;
}

#twj-dashboard-grid > .twj-dashboard-widget {
    width: 100% !important;
    min-width: 0;
    margin-bottom: 0 !important;
    position: relative;
}

#twj-dashboard-grid > .twj-widget-full {
    grid-column: span 12;
}

#twj-dashboard-grid > .twj-widget-half {
    grid-column: span 6;
}

#twj-dashboard-grid > .twj-widget-third {
    grid-column: span 4;
}

#twj-dashboard-grid > .twj-widget-quarter {
    grid-column: span 3;
}

@media (max-width: 991px) {
    #twj-dashboard-grid > .twj-dashboard-widget,
    #twj-dashboard-grid > .twj-widget-full,
    #twj-dashboard-grid > .twj-widget-half,
    #twj-dashboard-grid > .twj-widget-third,
    #twj-dashboard-grid > .twj-widget-quarter {
        grid-column: span 12;
    }
}









.twj-widget-controls {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 30;
    display: flex;
    gap: 6px;
    align-items: center;
}

.twj-widget-controls button {
    width: 34px;
    height: 34px;
    border: 1px solid #dbe5f3;
    background: #ffffff;
    color: #64748b;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.twj-widget-controls button:hover {
    background: #eef6ff;
    color: #0f172a;
}

.twj-widget-controls .twj-widget-drag-handle {
    position: static !important;
    top: auto !important;
    right: auto !important;
}

.twj-dashboard-widget.twj-widget-collapsed .panel-body,
.twj-dashboard-widget.twj-widget-collapsed .panel-collapse,
.twj-dashboard-widget.twj-widget-collapsed .twj-chart-main-body,
.twj-dashboard-widget.twj-widget-collapsed .twj-chart-side-body {
    display: none !important;
}

.twj-dashboard-widget.twj-widget-collapsed .panel {
    margin-bottom: 0;
}


.twj-widget-controls .twj-widget-visibility-btn {
    opacity: 0.55;
}

.twj-widget-controls .twj-widget-visibility-btn:hover {
    opacity: 1;
    background: #f8fafc;
    border-color: #cbd5e1;
    color: #475569;
}

.twj-widget-controls .twj-widget-visibility-btn.is-saving {
    opacity: 0.35;
    pointer-events: none;
}















/* Dashboard widget headings with subtitles */

/* Compact one-line widget headings */
.twj-panel-heading-with-subtitle {
    display: flex !important;
    align-items: center !important;
    min-height: 44px !important;
    padding-right: 130px !important;
}

.twj-panel-heading-with-subtitle .dashboard-collapse-toggle,
.twj-panel-heading-with-subtitle .twj-heading-text {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 24px !important;
    min-width: 0;
    width: 100%;
}

.twj-panel-heading-with-subtitle .section-title {
    flex: 0 0 auto;
    display: inline-block !important;
    white-space: nowrap;
    font-weight: 700;
    line-height: 1.2;
}

.twj-panel-heading-with-subtitle .twj-panel-subtitle {
    flex: 1 1 auto;
    display: inline-block !important;
    margin-left: 0 !important;
    font-size: 12px;
    line-height: 1.3;
    color: #64748b;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}


/* Compact title + subtitle widget heading */
.twj-dashboard-widget .panel-heading.text {
    display: flex !important;
    align-items: center !important;
    gap: 22px !important;
    min-height: 46px !important;
    padding-right: 130px !important;
    white-space: nowrap;
}

.twj-dashboard-widget .panel-heading.text .section-title {
    flex: 0 0 auto;
    display: inline-flex !important;
    align-items: center;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
}

.twj-dashboard-widget .panel-heading.text .twj-panel-subtitle {
    flex: 1 1 auto;
    display: inline-block !important;
    margin-left: 0 !important;
    font-size: 12px;
    line-height: 1.25;
    color: #64748b;
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}






/* Clean compact widget heading: title + subtitle */
.twj-widget-copy-heading {
    min-height: 46px !important;
    padding: 12px 130px 12px 18px !important;
    display: flex !important;
    align-items: center !important;
}

.twj-widget-heading-copy {
    display: flex !important;
    align-items: baseline !important;
    gap: 28px !important;
    width: 100%;
    min-width: 0;
}

.twj-widget-heading-title {
    flex: 0 0 auto;
    font-weight: 700;
    font-size: 14px;
    line-height: 1.2;
    color: #001b44;
    white-space: nowrap;
}

.twj-widget-heading-subtitle {
    flex: 1 1 auto;
    min-width: 0;
    font-size: 12px;
    line-height: 1.3;
    font-weight: 500;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}





/* Keep original section-title styling, only separate subtitle */
.twj-widget-copy-heading {
    min-height: 46px !important;
    padding: 12px 130px 12px 18px !important;
    display: flex !important;
    align-items: center !important;
}

.twj-widget-heading-copy {
    display: flex !important;
    align-items: center !important;
    gap: 28px !important;
    width: 100%;
    min-width: 0;
}

.twj-widget-copy-heading .section-title {
    flex: 0 0 auto;
    display: inline-flex !important;
    align-items: center;
    white-space: nowrap;
}

.twj-widget-copy-heading .twj-panel-subtitle {
    flex: 1 1 auto;
    min-width: 0;
    margin-left: 0 !important;
    font-size: 12px;
    line-height: 1.3;
    font-weight: 500;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}








/* Wrapper spacing */
.twj-widget-title-heading {
    min-height: 46px !important;
    padding: 12px 130px 12px 18px !important;
    display: flex !important;
    align-items: center !important;
}

.twj-widget-title-copy {
    display: flex !important;
    align-items: center !important;
    gap: 28px !important;
    width: 100%;
    min-width: 0;
}

.twj-widget-title-copy .section-title {
    flex: 0 0 auto;
    white-space: nowrap;
}

.twj-widget-title-copy .twj-panel-subtitle {
    flex: 1 1 auto;
    min-width: 0;
    margin-left: 0 !important;
    font-size: 12px;
    line-height: 1.3;
    font-weight: 500;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}








/* Subtle dashboard widget hover elevation */
#twj-dashboard-grid > .twj-dashboard-widget {
    transition: all .2s ease;
    will-change: transform;
}

#twj-dashboard-grid > .twj-dashboard-widget > .panel {
    transition: all .2s ease;
}

@media (hover: hover) and (pointer: fine) {
    #twj-dashboard-grid > .twj-dashboard-widget:hover {
        transform: translateY(-2px);
    }

    #twj-dashboard-grid > .twj-dashboard-widget:hover > .panel {
        box-shadow: 0 10px 30px rgba(0, 0, 0, .05);
    }
}

/* Avoid hover movement while dragging */
#twj-dashboard-grid > .twj-dashboard-widget.twj-widget-chosen,
#twj-dashboard-grid > .twj-dashboard-widget.twj-widget-ghost,
#twj-dashboard-grid > .twj-dashboard-widget.sortable-chosen,
#twj-dashboard-grid > .twj-dashboard-widget.sortable-drag {
    transform: none !important;
}










/* Normalize widget control alignment */
#twj-dashboard-grid > .twj-dashboard-widget {
    position: relative;
}

/* Keep all widget controls in the same top/right position */
#twj-dashboard-grid > .twj-dashboard-widget > .twj-widget-controls {
    top: 13px !important;
    right: 14px !important;
    height: 34px;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

/* Make every control button exactly identical */
#twj-dashboard-grid .twj-widget-controls button {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    padding: 0 !important;
    line-height: 1 !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Fix widgets that have direct Bootstrap row wrappers */
#twj-dashboard-grid > .twj-dashboard-widget > .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

#twj-dashboard-grid > .twj-dashboard-widget > .row > .col-lg-12,
#twj-dashboard-grid > .twj-dashboard-widget > .row > .col-md-12,
#twj-dashboard-grid > .twj-dashboard-widget > .row > .col-sm-12 {
    padding-left: 0 !important;
    padding-right: 0 !important;
}


#twj-dashboard-grid > .twj-dashboard-widget > .row > .col-lg-12:only-child,
#twj-dashboard-grid > .twj-dashboard-widget > .row > .col-md-12:only-child,
#twj-dashboard-grid > .twj-dashboard-widget > .row > .col-sm-12:only-child {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Make panel headings reserve the same button space everywhere */
#twj-dashboard-grid > .twj-dashboard-widget .panel > .panel-heading {
    min-height: 52px;
    padding-right: 130px !important;
}



/* Keep widget control buttons visually consistent */
#twj-dashboard-grid > .twj-dashboard-widget > .twj-widget-controls {
    top: 13px !important;
    right: 14px !important;
    height: 34px !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

#twj-dashboard-grid > .twj-dashboard-widget > .twj-widget-controls button {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
}











/* Dashboard Studio */
.twj-dashboard-studio {
    max-width: 1180px;
    margin: 0 auto;
    padding: 34px 24px 80px;
}

.twj-studio-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 24px;
    margin-bottom: 24px;
    padding-bottom: 22px;
    border-bottom: 1px solid #dbe7f3;
}

.twj-studio-kicker {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.8px;
    color: #00a884;
    margin-bottom: 8px;
}

.twj-studio-header h1 {
    margin: 0 0 8px;
    font-size: 34px;
    line-height: 1.1;
    color: #001f4d;
}

.twj-studio-header p {
    margin: 0;
    color: #60708a;
    font-size: 14px;
}

.twj-studio-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 220px 100px;
    gap: 14px;
    align-items: center;
    margin-bottom: 28px;
}

.twj-widget-search,
.twj-widget-preset {
    width: 100%;
    border: 1px solid #d8e3ef;
    border-radius: 14px;
    padding: 12px 14px;
    background: #fff;
    color: #001f4d;
}

.twj-studio-count {
    height: 44px;
    border: 1px solid #d8e3ef;
    border-radius: 14px;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    color: #60708a;
    font-weight: 700;
}

.twj-studio-count span {
    color: #00a884;
}

.twj-widget-category {
    margin-bottom: 34px;
}

.twj-widget-category-heading {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 14px;
}

.twj-widget-category-heading h2 {
    margin: 0;
    font-size: 18px;
    color: #001f4d;
}

.twj-widget-category-heading span {
    font-size: 12px;
    color: #7a8aa3;
    font-weight: 700;
}

.twj-widget-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.twj-widget-card {
    display: block;
    background: #fff;
    border: 1px solid #dbe7f3;
    border-left: 5px solid #dbe7f3;
    border-radius: 16px;
    padding: 18px;
    cursor: pointer;
    box-shadow: 0 12px 30px rgba(15, 35, 70, 0.05);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.twj-widget-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 38px rgba(15, 35, 70, 0.09);
}

.twj-widget-card.is-enabled {
    border-left-color: #00c875;
}

.twj-widget-card input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.twj-widget-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 8px;
}

.twj-widget-card h3 {
    margin: 0;
    font-size: 16px;
    color: #001f4d;
}

.twj-widget-card p {
    margin: 0 0 14px;
    color: #60708a;
    line-height: 1.45;
    font-size: 13px;
}

.twj-widget-card-meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.twj-widget-card-meta span {
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    background: #f3f8ff;
    color: #60708a;
    padding: 5px 9px;
    border-radius: 999px;
}

.twj-widget-switch {
    width: 42px;
    height: 24px;
    border-radius: 999px;
    background: #dbe7f3;
    padding: 3px;
    flex: 0 0 auto;
    transition: background .18s ease;
}

.twj-widget-switch span {
    display: block;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 2px 6px rgba(15, 35, 70, 0.18);
    transition: transform .18s ease;
}

.twj-widget-card.is-enabled .twj-widget-switch {
    background: #00c875;
}

.twj-widget-card.is-enabled .twj-widget-switch span {
    transform: translateX(18px);
}

.twj-studio-actions {
    display: flex;
    gap: 12px;
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid #dbe7f3;
}

@media (max-width: 900px) {
    .twj-studio-header,
    .twj-studio-actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .twj-studio-toolbar,
    .twj-widget-card-grid {
        grid-template-columns: 1fr;
    }
}








.twj-widget-category h2 {
    font-size: 42px;
    line-height: 1;
    letter-spacing: -1.5px;
    font-weight: 800;
    margin-bottom: 20px;
    color: #061539;
}


.twj-widget-card:hover {
    transform: translateY(-3px);
    border-color: #00c875;
    box-shadow:
        0 10px 25px rgba(0,0,0,0.06),
        0 0 0 1px rgba(0,200,117,0.15);
}


.twj-widget-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}


.twj-widget-toggle {
    margin-top: 2px;
}







/* Dashboard Studio tier pills */
.twj-dashboard-studio .twj-widget-card-meta span:first-child {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 22px;
    padding: 4px 9px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0;
}

/* FREE / Core / Standard */
.twj-dashboard-studio .twj-widget-card[data-widget-tier="FREE"] .twj-widget-card-meta span:first-child,
.twj-dashboard-studio .twj-widget-card[data-widget-tier="CORE"] .twj-widget-card-meta span:first-child,
.twj-dashboard-studio .twj-widget-card[data-widget-tier="STANDARD"] .twj-widget-card-meta span:first-child {
    background: #e8fff4;
    color: #00a85a;
}

/* PRO */
.twj-dashboard-studio .twj-widget-card[data-widget-tier="PRO"] .twj-widget-card-meta span:first-child {
    background: #eef3ff;
    color: #356dff;
}

/* ELITE */
.twj-dashboard-studio .twj-widget-card[data-widget-tier="ELITE"] .twj-widget-card-meta span:first-child {
    background: #fff5dc;
    color: #d4a100;
}




.twj-dashboard-studio .twj-widget-card[data-widget-tier="PRO"] {
    border-top-color: #356dff;
}

.twj-dashboard-studio .twj-widget-card[data-widget-tier="ELITE"] {
    border-top-color: #d4a100;
}

.twj-dashboard-studio .twj-widget-card[data-widget-tier="FREE"],
.twj-dashboard-studio .twj-widget-card[data-widget-tier="CORE"],
.twj-dashboard-studio .twj-widget-card[data-widget-tier="STANDARD"] {
    border-top-color: #00c875;
}















/* Dashboard Studio category icons */
.twj-widget-category-heading h2 {
    display: flex;
    align-items: center;
    gap: 10px;
}

.twj-category-icon {
    width: 30px;
    height: 30px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #e8fff4;
    color: #00a85a;
    font-size: 14px;
    flex: 0 0 auto;
}

.twj-widget-category:nth-of-type(2) .twj-category-icon {
    background: #eef3ff;
    color: #356dff;
}

.twj-widget-category:nth-of-type(3) .twj-category-icon {
    background: #fff5dc;
    color: #d4a100;
}

.twj-widget-category:nth-of-type(4) .twj-category-icon {
    background: #f0fdfa;
    color: #0891b2;
}

.twj-widget-category:nth-of-type(5) .twj-category-icon {
    background: #f5f3ff;
    color: #7c3aed;
}

.twj-widget-category:nth-of-type(6) .twj-category-icon {
    background: #fff7ed;
    color: #ea580c;
}

.twj-widget-category:nth-of-type(7) .twj-category-icon {
    background: #eff6ff;
    color: #2563eb;
}












/* Dashboard Studio category heading scale */
.twj-dashboard-studio .twj-widget-category-heading {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin: 34px 0 18px !important;
}

.twj-dashboard-studio .twj-widget-category-heading h2 {
    display: inline-flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin: 0 !important;
    font-size: 22px !important;
    line-height: 1.1 !important;
    font-weight: 800 !important;
    color: #061a3d !important;
    letter-spacing: 0 !important;
}

.twj-dashboard-studio .twj-widget-category-heading h2 > span:not(.twj-category-icon) {
    font-size: 22px !important;
    line-height: 1.1 !important;
    font-weight: 800 !important;
    color: #061a3d !important;
}

.twj-dashboard-studio .twj-category-icon {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 8px 18px rgba(15, 35, 70, 0.08);
}

.twj-dashboard-studio .twj-widget-category-heading > span {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #64748b !important;
}















/* Dashboard Studio split editor */
.twj-studio-builder {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 430px;
    gap: 26px;
    align-items: start;
}

.twj-studio-control-pane {
    min-width: 0;
}

.twj-studio-preview-pane {
    position: sticky;
    top: 20px;
    min-width: 0;
}

.twj-live-preview-shell {
    background: #ffffff;
    border: 1px solid #dbe7f3;
    border-radius: 20px;
    box-shadow: 0 18px 45px rgba(15, 35, 70, 0.08);
    padding: 18px;
}

.twj-live-preview-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    margin-bottom: 14px;
}

.twj-live-preview-kicker {
    color: #00a85a;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 4px;
}

.twj-live-preview-header h2 {
    margin: 0;
    font-size: 20px;
    line-height: 1.1;
    color: #061a3d;
}

.twj-live-preview-count {
    background: #e8fff4;
    color: #00a85a;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.twj-live-preview-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 10px;
    min-height: 440px;
    max-height: calc(100vh - 260px);
    overflow: auto;
    padding: 14px;
    border-radius: 16px;
    border: 1px solid #e4edf7;
    background: linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
}

.twj-preview-widget {
    background: #ffffff;
    border: 1px solid #dbe7f3;
    border-radius: 12px;
    padding: 11px;
    min-height: 74px;
    box-shadow: 0 10px 22px rgba(15, 35, 70, 0.06);
    cursor: grab;
    transition: transform .18s ease, box-shadow .18s ease;
}

.twj-preview-widget:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(15, 35, 70, 0.1);
}

.twj-preview-widget-full {
    grid-column: span 12;
}

.twj-preview-widget-half {
    grid-column: span 6;
}

.twj-preview-widget-third {
    grid-column: span 4;
}

.twj-preview-widget-quarter {
    grid-column: span 3;
}

.twj-preview-widget-heading {
    display: flex;
    align-items: center;
    gap: 7px;
    color: #061a3d;
    font-size: 12px;
    font-weight: 800;
    margin-bottom: 10px;
}

.twj-preview-dot {
    width: 5px;
    height: 18px;
    border-radius: 999px;
    background: #00c2c7;
    flex: 0 0 auto;
}

.twj-preview-widget-body {
    display: grid;
    gap: 6px;
}

.twj-preview-widget-body span {
    display: block;
    height: 7px;
    border-radius: 999px;
    background: #edf3fb;
}

.twj-preview-widget-body span:nth-child(1) {
    width: 86%;
}

.twj-preview-widget-body span:nth-child(2) {
    width: 64%;
}

.twj-preview-widget-body span:nth-child(3) {
    width: 42%;
}

.twj-preview-widget-ghost {
    opacity: .45;
}

.twj-preview-empty {
    grid-column: span 12;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    border: 1px dashed #cbd8e7;
    border-radius: 14px;
    color: #64748b;
    font-weight: 700;
}

.twj-live-preview-note {
    margin: 12px 2px 0;
    color: #64748b;
    font-size: 12px;
    line-height: 1.4;
}

@media (max-width: 1200px) {
    .twj-studio-builder {
        grid-template-columns: 1fr;
    }

    .twj-studio-preview-pane {
        position: static;
    }

    .twj-live-preview-grid {
        max-height: none;
    }
}














/* Dashboard Studio wider professional canvas */
.twj-dashboard-studio {
    width: calc(100% - 56px) !important;
    max-width: 1540px !important;
    margin: 0 auto !important;
    padding: 46px 28px 120px !important;
}

.twj-studio-builder {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(390px, 440px) !important;
    gap: 32px !important;
    align-items: start !important;
}

.twj-studio-control-pane {
    min-width: 0 !important;
}

.twj-studio-preview-pane {
    position: sticky !important;
    top: 96px !important;
    align-self: start !important;
}

.twj-widget-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 18px !important;
}

.twj-studio-toolbar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 230px 120px !important;
    gap: 14px !important;
    align-items: center !important;
}

/* Always-accessible Studio save bar */
.twj-studio-floating-actions {
    position: sticky !important;
    top: 76px !important;
    z-index: 80 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 18px !important;
    margin: 18px 0 28px !important;
    padding: 14px 16px !important;
    background: rgba(255, 255, 255, 0.92) !important;
    border: 1px solid #dbe7f3 !important;
    border-radius: 18px !important;
    box-shadow: 0 14px 34px rgba(15, 35, 70, 0.08) !important;
    backdrop-filter: blur(10px);
}

.twj-studio-floating-copy {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.twj-studio-floating-copy strong {
    color: #001f4f !important;
    font-weight: 800 !important;
}

.twj-studio-floating-copy span {
    color: #60708a !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

.twj-studio-floating-buttons {
    display: flex !important;
    gap: 10px !important;
    align-items: center !important;
    white-space: nowrap !important;
}

.twj-studio-actions {
    display: none !important;
}

@media (max-width: 1300px) {
    .twj-studio-builder {
        grid-template-columns: 1fr !important;
    }

    .twj-studio-preview-pane {
        position: static !important;
    }
}

@media (max-width: 900px) {
    .twj-dashboard-studio {
        width: calc(100% - 24px) !important;
        padding: 28px 12px 110px !important;
    }

    .twj-widget-card-grid,
    .twj-studio-toolbar {
        grid-template-columns: 1fr !important;
    }

    .twj-studio-floating-actions {
        top: 12px !important;
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .twj-studio-floating-buttons {
        justify-content: stretch !important;
    }

    .twj-studio-floating-buttons .btn {
        flex: 1 1 auto !important;
    }
}











/* Compact sticky Dashboard Studio command bar */
.twj-dashboard-studio {
    width: calc(100% - 56px) !important;
    max-width: 1540px !important;
}

.twj-studio-sticky-bar {
    position: sticky;
    top: 12px;
    z-index: 50;
    min-height: 52px;
    margin: 22px 0 34px;
    padding: 8px 10px;
    border: 1px solid rgba(203, 218, 235, 0.9);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(14px);
    box-shadow: 0 14px 36px rgba(15, 35, 70, 0.08);
    display: grid;
    grid-template-columns: minmax(320px, 1fr) auto;
    gap: 14px;
    align-items: center;
}

.twj-studio-filter-controls,
.twj-studio-action-controls {
    display: flex;
    align-items: center;
    gap: 10px;
}

.twj-widget-search {
    flex: 1 1 auto;
    min-width: 260px;
}

.twj-widget-preset {
    width: 220px;
    flex: 0 0 220px;
}

.twj-studio-status {
    min-width: 170px;
    font-size: 12px;
    color: #60708a;
    line-height: 1.2;
}

.twj-studio-status strong {
    display: block;
    color: #00a85a;
}

.twj-unsaved-state {
    display: block;
    color: #94a3b8;
}

.twj-unsaved-state.is-dirty {
    color: #d4a100;
    font-weight: 700;
}

.twj-studio-save-btn,
.twj-studio-back-btn {
    height: 38px;
    white-space: nowrap;
    padding-left: 16px !important;
    padding-right: 16px !important;
}

@media (max-width: 1100px) {
    .twj-studio-sticky-bar {
        grid-template-columns: 1fr;
    }

    .twj-studio-action-controls {
        justify-content: space-between;
        flex-wrap: wrap;
    }
}










/* Dashboard Studio width: match main dashboard feel */
.twj-dashboard-studio {
    width: calc(100% - 48px) !important;
    max-width: 1480px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Let controls + preview use the wider space better */
.twj-studio-layout,
.twj-studio-workspace {
    width: 100% !important;
    max-width: none !important;
}

/* Give the widget controls more room than the preview */
.twj-studio-layout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 430px !important;
    gap: 32px !important;
    align-items: start !important;
}

@media (max-width: 1200px) {
    .twj-dashboard-studio {
        width: calc(100% - 28px) !important;
    }

    .twj-studio-layout {
        grid-template-columns: 1fr !important;
    }
}























/* Modern Sidebar */
@media (min-width: 768px) {
    .twj-app .navbar-header,
    .twj-app .twj-app-brand {
        width: 270px !important;
    }

    .twj-app .sidebar {
        width: 270px !important;
    }

    .twj-app #page-wrapper {
        margin-left: 270px !important;
    }
}

.twj-app .sidebar {
    background: rgba(255, 255, 255, 0.96) !important;
    border-right: 1px solid rgba(210, 222, 238, 0.75) !important;
    box-shadow: 10px 0 30px rgba(15, 35, 70, 0.035);
}

.twj-app .sidebar ul li {
    border-bottom: 0 !important;
}

.twj-app #side-menu {
    padding: 12px 10px 24px !important;
}

.twj-app .twj-sidebar-group-label {
    padding: 18px 16px 7px !important;
    margin: 4px 0 2px !important;
    font-size: 10px !important;
    line-height: 1;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
    text-transform: uppercase;
    color: #7b8aa3 !important;
    opacity: 0.78;
}

.twj-app #side-menu > li > a,
.twj-app #side-menu .nav-second-level > li > a {
    border-radius: 12px !important;
    margin: 2px 6px !important;
    border-left: 3px solid transparent;
    color: #10223f !important;
    font-weight: 700;
    transition: background .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.twj-app #side-menu > li > a {
    padding: 11px 14px !important;
}

.twj-app #side-menu .nav-second-level {
    background: transparent !important;
    padding: 2px 0 8px !important;
}

.twj-app #side-menu .nav-second-level > li > a {
    padding: 8px 14px 8px 42px !important;
    font-size: 13px;
    color: #53627a !important;
    font-weight: 700;
}

.twj-app #side-menu > li > a:hover,
.twj-app #side-menu .nav-second-level > li > a:hover {
    background: rgba(0, 200, 117, 0.07) !important;
    color: #001f3f !important;
}

.twj-app #side-menu a.twj-nav-active {
    background: rgba(0, 200, 117, 0.10) !important;
    border-left-color: #00c875 !important;
    color: #001f3f !important;
    box-shadow: 0 8px 22px rgba(0, 200, 117, 0.10);
}

.twj-app #side-menu a.twj-nav-active i {
    color: #00a85a !important;
}

.twj-app #side-menu > li > a.twj-parent-active {
    background: rgba(15, 35, 70, 0.035) !important;
    color: #001f3f !important;
}

.twj-app #side-menu .arrow {
    opacity: 0.45;
    margin-top: 3px;
}

.twj-app .twj-community-promo {
    margin: 20px 12px 10px !important;
    padding: 18px !important;
    border: 1px solid #dbe7f3 !important;
    border-radius: 18px !important;
    background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%) !important;
    box-shadow: 0 14px 34px rgba(15, 35, 70, 0.07);
}

.twj-app .twj-elite-kicker {
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #d4a100;
    margin-bottom: 7px;
}

.twj-app .twj-community-promo h4 {
    margin: 0 0 8px !important;
    font-size: 15px !important;
    line-height: 1.2;
}

.twj-app .twj-community-promo p {
    margin: 0 0 12px !important;
    color: #64748b;
    font-size: 12px;
    line-height: 1.45;
}

.twj-app .twj-community-promo ul {
    margin: 0 0 14px !important;
    padding: 0 !important;
    list-style: none !important;
}

.twj-app .twj-community-promo li {
    margin: 6px 0 !important;
    font-size: 12px;
    color: #334155;
}

.twj-app .twj-community-promo li i {
    color: #00a85a;
    margin-right: 7px;
}
















/* Sidebar V2 */
:root {
    --twj-sidebar-width: 260px;
    --twj-sidebar-collapsed-width: 76px;
}

@media (min-width: 768px) {
    .twj-app .navbar-header,
    .twj-app .twj-app-brand,
    .twj-app .sidebar {
        width: var(--twj-sidebar-width) !important;
    }

    .twj-app #page-wrapper {
        margin-left: var(--twj-sidebar-width) !important;
    }

    .twj-app.twj-sidebar-collapsed .navbar-header,
    .twj-app.twj-sidebar-collapsed .sidebar {
        width: var(--twj-sidebar-collapsed-width) !important;
    }

    .twj-app.twj-sidebar-collapsed #page-wrapper {
        margin-left: var(--twj-sidebar-collapsed-width) !important;
    }
}

.twj-app .sidebar {
    background: rgba(255,255,255,.96) !important;
    border-right: 1px solid rgba(210,222,238,.75) !important;
    box-shadow: 10px 0 30px rgba(15,35,70,.035);
}

.twj-app .sidebar ul li {
    border: 0 !important;
}

.twj-app #side-menu {
    padding: 12px 10px 24px !important;
}

.twj-app .twj-sidebar-group-label {
    padding: 18px 16px 7px !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase;
    color: #7b8aa3 !important;
    opacity: .78;
}

.twj-app #side-menu > li > a,
.twj-app #side-menu .nav-second-level > li > a {
    border-radius: 12px !important;
    margin: 2px 6px !important;
    border-left: 3px solid transparent;
    color: #10223f !important;
    font-weight: 700;
    transition: background .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.twj-app #side-menu > li > a {
    padding: 11px 14px !important;
}

.twj-app #side-menu .nav-second-level > li > a {
    padding: 8px 14px 8px 42px !important;
    font-size: 13px;
    color: #53627a !important;
    font-weight: 700;
}

.twj-app #side-menu > li > a:hover,
.twj-app #side-menu .nav-second-level > li > a:hover {
    background: rgba(0,200,117,.07) !important;
    color: #001f3f !important;
}

.twj-app #side-menu .nav-second-level > li > a.twj-nav-active {
    background: rgba(0,208,132,.08) !important;
    border-left-color: #00d084 !important;
    color: #001f3f !important;
    font-weight: 800 !important;
    box-shadow: inset 3px 0 0 #00d084, 0 8px 18px rgba(0,200,117,.08);
}

.twj-app #side-menu > li > a.twj-parent-active {
    background: rgba(15,35,70,.035) !important;
}

.twj-app #side-menu .arrow {
    opacity: .55 !important;
    font-size: 14px !important;
    margin-top: 2px !important;
}

.twj-app #side-menu i.fa-fw {
    width: 20px !important;
    text-align: center;
    opacity: .9;
}

.twj-soon-link {
    display: flex !important;
    align-items: center;
    gap: 8px;
}

.twj-soon-link .twj-soon-badge {
    margin-left: auto;
    font-size: 10px;
    font-weight: 800;
    color: #64748b;
    background: #eef3f8;
    border-radius: 999px;
    padding: 3px 7px;
}

.twj-sidebar-elite-footer {
    margin: 18px 16px 12px !important;
    padding: 14px 4px 4px !important;
    border-top: 1px solid rgba(210,222,238,.85) !important;
}

.twj-elite-footer-title {
    font-size: 12px;
    font-weight: 900;
    color: #10223f;
    margin-bottom: 6px;
}

.twj-elite-footer-title i {
    color: #d4a100;
    margin-right: 6px;
}

.twj-elite-footer-text {
    font-size: 12px;
    line-height: 1.4;
    color: #64748b;
    margin-bottom: 10px;
}

.twj-elite-footer-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 7px 12px;
    background: #00c875;
    color: #fff !important;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none !important;
}

.twj-sidebar-mode-toggle:hover {
    background: #eef6ff;
    color: #0f172a;
}

.twj-app.twj-sidebar-collapsed .twj-brand-text-wrap,
.twj-app.twj-sidebar-collapsed .twj-sidebar-group-label,
.twj-app.twj-sidebar-collapsed .nav-second-level,
.twj-app.twj-sidebar-collapsed .twj-sidebar-elite-footer,
.twj-app.twj-sidebar-collapsed #side-menu .arrow,
.twj-app.twj-sidebar-collapsed .twj-menu-badge,
.twj-app.twj-sidebar-collapsed .twj-soon-badge {
    display: none !important;
}

.twj-app.twj-sidebar-collapsed #side-menu > li > a {
    font-size: 0 !important;
    justify-content: center;
    padding: 13px 10px !important;
}

.twj-app.twj-sidebar-collapsed #side-menu > li > a i {
    font-size: 16px !important;
    margin: 0 !important;
}














/* TradingWaves logo */
.twj-app .twj-app-brand-logo {
    display: flex !important;
    align-items: center !important;
    height: 56px !important;
    padding: 8px 14px !important;
    overflow: hidden !important;
}

.twj-app .twj-brand-logo-img {
    display: block !important;
    width: 100% !important;
    max-width: 224px !important;
    height: auto !important;
    max-height: 42px !important;
    object-fit: contain !important;
    object-position: left center !important;
}

/* Compact sidebar: show only the circular mark area */
.twj-app.twj-sidebar-collapsed .twj-app-brand-logo {
    justify-content: center !important;
    padding: 8px 10px !important;
}

.twj-app.twj-sidebar-collapsed .twj-brand-logo-img {
    width: 42px !important;
    height: 42px !important;
    max-width: 42px !important;
    max-height: 42px !important;
    object-fit: cover !important;
    object-position: left center !important;
    border-radius: 999px !important;
}












.twj-app .navbar-header {
    width: 260px !important;
    min-height: 76px !important;
}

.twj-sidebar-brand-row {
    width: 100%;
    min-height: 76px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
}

.twj-app .twj-sidebar-mode-toggle {
    position: static !important;
    flex: 0 0 36px;
    width: 36px !important;
    height: 36px !important;
    border-radius: 999px !important;
    border: 1px solid #cfe0f3 !important;
    background: #ffffff !important;
    color: #0f766e !important;
    box-shadow: 0 8px 22px rgba(15, 35, 70, 0.12) !important;
}

.twj-app .twj-app-brand-logo {
    flex: 1 1 auto;
    min-width: 0;
    height: 54px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px;
}

.twj-brand-icon-img {
    width: 42px !important;
    height: 42px !important;
    border-radius: 999px;
    object-fit: cover;
    flex: 0 0 42px;
}

.twj-brand-wordmark {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.twj-brand-name {
    font-size: 15px;
    font-weight: 800;
    color: #001b3f;
    line-height: 1.1;
    white-space: nowrap;
}

.twj-brand-tagline {
    margin-top: 3px;
    font-size: 8px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #64748b;
    white-space: nowrap;
}

.twj-sidebar-collapsed .navbar-header {
    width: 72px !important;
}

.twj-sidebar-collapsed .twj-sidebar-brand-row {
    flex-direction: column;
    justify-content: center;
    gap: 7px;
    padding: 8px 0;
}

.twj-sidebar-collapsed .twj-app-brand-logo {
    flex: 0 0 auto;
    height: 40px !important;
    justify-content: center !important;
}

.twj-sidebar-collapsed .twj-brand-wordmark {
    display: none !important;
}

.twj-sidebar-collapsed .twj-brand-icon-img {
    width: 38px !important;
    height: 38px !important;
}














:root {
    --twj-sidebar-width: 282px;
    --twj-sidebar-collapsed-width: 72px;
}

@media (min-width: 768px) {
    body.twj-app .navbar-header,
    body.twj-app .navbar-default.sidebar {
        width: var(--twj-sidebar-width) !important;
    }

    body.twj-app #page-wrapper {
        margin-left: var(--twj-sidebar-width) !important;
    }

    body.twj-app.twj-sidebar-collapsed .navbar-header,
    body.twj-app.twj-sidebar-collapsed .navbar-default.sidebar {
        width: var(--twj-sidebar-collapsed-width) !important;
    }

    body.twj-app.twj-sidebar-collapsed #page-wrapper {
        margin-left: var(--twj-sidebar-collapsed-width) !important;
    }
}

.twj-sidebar-brand-row {
    width: 100%;
    min-height: 78px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    overflow: hidden;
}

.twj-app .twj-sidebar-mode-toggle {
    position: static !important;
    flex: 0 0 36px;
    width: 36px !important;
    height: 36px !important;
    border-radius: 999px !important;
    border: 1px solid #cfe0f3 !important;
    background: #ffffff !important;
    color: #0f766e !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 22px rgba(15, 35, 70, 0.12) !important;
}

.twj-app .twj-app-brand-logo {
    flex: 1 1 auto;
    min-width: 0;
    height: 54px !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px;
    overflow: hidden;
}

.twj-brand-icon-img {
    width: 44px !important;
    height: 44px !important;
    border-radius: 999px;
    object-fit: cover;
    flex: 0 0 44px;
    opacity: 1 !important;
}

.twj-brand-wordmark {
    display: flex;
    flex-direction: column;
    min-width: 0;
    overflow: hidden;
}

.twj-brand-name {
    font-size: 15px;
    font-weight: 800;
    color: #001b3f;
    line-height: 1.1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.twj-brand-tagline {
    margin-top: 3px;
    font-size: 8px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

body.twj-sidebar-collapsed .twj-sidebar-brand-row {
    min-height: 92px;
    flex-direction: column;
    justify-content: center;
    gap: 8px;
    padding: 8px 0;
}

body.twj-sidebar-collapsed .twj-app-brand-logo {
    flex: 0 0 auto;
    width: 44px !important;
    height: 44px !important;
    justify-content: center !important;
    overflow: visible !important;
}

body.twj-sidebar-collapsed .twj-brand-wordmark {
    display: none !important;
}

body.twj-sidebar-collapsed .twj-brand-icon-img {
    width: 38px !important;
    height: 38px !important;
    opacity: 1 !important;
}















/* Hybrid top brand + navigation-only sidebar */
.twj-topbar-brand-header {
    height: 74px;
    display: flex !important;
    align-items: center;
    gap: 12px;
    padding: 0 16px;
    overflow: visible !important;
    position: relative;
    z-index: 1001;
}

.twj-topbar-brand {
    height: 74px !important;
    display: flex !important;
    align-items: center !important;
    gap: 11px;
    padding: 0 !important;
    margin: 0 !important;
    color: #001b3f !important;
    min-width: 0;
}

.twj-topbar-brand:hover,
.twj-topbar-brand:focus {
    text-decoration: none;
}

.twj-topbar-brand-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #061321;
    box-shadow: 0 8px 22px rgba(0, 30, 60, 0.14);
    overflow: hidden;
}

.twj-topbar-brand-icon img {
    width: 44px;
    height: 44px;
    display: block;
    object-fit: cover;
    border-radius: 999px;
}

.twj-topbar-brand-copy {
    display: flex !important;
    flex-direction: column;
    min-width: 0;
}

.twj-topbar-brand-name {
    font-size: 17px;
    font-weight: 900;
    line-height: 1.05;
    color: #001b3f;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.twj-topbar-brand-subtitle {
    margin-top: 4px;
    font-size: 8px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #526783;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.twj-sidebar-mode-toggle:hover {
    background: #eefaff;
    color: #004f70;
}

/* Keep header brand visible even when sidebar is collapsed */
body.twj-sidebar-collapsed .twj-topbar-brand-copy {
    display: flex !important;
}

body.twj-sidebar-collapsed .twj-topbar-brand {
    width: auto !important;
    justify-content: flex-start !important;
}

/* Sidebar is navigation only */
.navbar-default.sidebar .twj-sidebar-brand-row,
.navbar-default.sidebar .twj-app-brand {
    display: none !important;
}

@media (min-width: 768px) {
    body.twj-app .navbar-header,
    body.twj-app.twj-sidebar-collapsed .navbar-header {
        width: 360px !important;
        min-width: 360px !important;
    }
}



















/* =========================================================
   TWJ Header / Logo / Sidebar Polish
   ========================================================= */

:root {
    --twj-sidebar-expanded: 250px;
    --twj-sidebar-collapsed: 64px;
    --twj-topbar-height: 58px;
}

/* Top header: more compact */
.twj-app .navbar-static-top {
    min-height: var(--twj-topbar-height);
    border-bottom: 1px solid rgba(15, 45, 80, 0.08);
    background: rgba(255, 255, 255, 0.96);
}

.twj-topbar-brand-header {
    height: var(--twj-topbar-height);
    display: flex;
    align-items: center;
    gap: 10px;
    padding-left: 18px;
}

/* Collapse button alignment */
.twj-sidebar-mode-toggle:hover {
    color: #06c76f;
    border-color: rgba(6, 199, 111, 0.35);
    transform: translateY(-1px);
}

/* Brand sizing */
.twj-topbar-brand {
    height: var(--twj-topbar-height);
    transition: all 0.18s ease;
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 0 !important;
    max-width: 220px;
    overflow: hidden;
}

.twj-topbar-brand-icon {
    width: 42px;
    height: 42px;
    min-width: 42px;
    border-radius: 999px;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
}

.twj-topbar-brand-icon img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.twj-topbar-brand-copy {
    display: flex;
    flex-direction: column;
    min-width: 0;
    line-height: 1.05;
}

.twj-topbar-brand-name {
    font-size: 16px;
    font-weight: 900;
    color: #071f3d;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.twj-topbar-brand-subtitle {
    margin-top: 4px;
    font-size: 8.5px;
    font-weight: 800;
    letter-spacing: 1.15px;
    text-transform: uppercase;
    color: #426078;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Sidebar width consistency */
.twj-app .sidebar {
    width: var(--twj-sidebar-expanded);
}

.twj-app #page-wrapper {
    margin-left: var(--twj-sidebar-expanded);
    padding-top: 0;
    transition: margin-left 0.2s ease;
}

/* Collapsed sidebar */
body.twj-sidebar-collapsed .twj-app .sidebar,
body.twj-sidebar-collapsed .sidebar {
    width: var(--twj-sidebar-collapsed);
}

body.twj-sidebar-collapsed #page-wrapper {
    margin-left: var(--twj-sidebar-collapsed);
}

/* Hide brand copy when collapsed, keep icon stable */
/* =========================================================
   COLLAPSED MODE CLEAN HEADER
   ========================================================= */

body.twj-sidebar-collapsed .twj-topbar-brand {
    display: none !important;
}

body.twj-sidebar-collapsed .twj-topbar-brand-copy {
    display: none !important;
    transition: opacity 0.15s ease;
}

body.twj-sidebar-collapsed .twj-topbar-brand-header {
    width: 64px;
    min-width: 64px;
    max-width: 64px;
    padding: 0;
    justify-content: center;
    position: relative;
}

body.twj-sidebar-collapsed .twj-sidebar-mode-toggle {
    position: relative;
    left: auto;
    top: auto;
    margin: 0 auto;
}

/* Remove weird empty spacing */
body.twj-sidebar-collapsed .navbar-header {
    overflow: hidden;
}





/* Collapsed sidebar nav icons */
body.twj-sidebar-collapsed #side-menu {
    padding-top: 70px;
}

body.twj-sidebar-collapsed #side-menu > li.twj-sidebar-group-label,
body.twj-sidebar-collapsed #side-menu .nav-second-level,
body.twj-sidebar-collapsed #side-menu > li > a .arrow,
body.twj-sidebar-collapsed #side-menu > li > a .twj-menu-badge,
body.twj-sidebar-collapsed #side-menu > li > a .twj-soon-badge,
body.twj-sidebar-collapsed .twj-elite-footer-title,
body.twj-sidebar-collapsed .twj-elite-footer-text,
body.twj-sidebar-collapsed .twj-elite-footer-link {
    display: none !important;
}

body.twj-sidebar-collapsed #side-menu > li > a {
    width: 46px;
    height: 46px;
    margin: 8px auto;
    padding: 0 !important;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0;
}

body.twj-sidebar-collapsed #side-menu > li > a i {
    font-size: 16px;
    margin: 0 !important;
}

body.twj-sidebar-collapsed #side-menu > li > a.twj-nav-active,
body.twj-sidebar-collapsed #side-menu > li.active > a {
    background: linear-gradient(135deg, rgba(6, 199, 111, 0.14), rgba(0, 200, 255, 0.08));
    border-left: 4px solid #06c76f;
}

/* Main content spacing */
.twj-dashboard-shell,
.twj-page {
    max-width: 1440px;
    margin-left: 9px;
    margin-right: auto;
}

body.twj-sidebar-collapsed .twj-dashboard-shell,
body.twj-sidebar-collapsed .twj-page {
    max-width: 1500px;
}

/* Mobile safety */
@media (max-width: 768px) {
    .twj-topbar-brand {
        max-width: 190px;
    }

    .twj-topbar-brand-icon {
        width: 38px;
        height: 38px;
        min-width: 38px;
    }

    .twj-topbar-brand-name {
        font-size: 14px;
    }

    .twj-topbar-brand-subtitle {
        display: none;
    }

    .twj-app #page-wrapper,
    body.twj-sidebar-collapsed #page-wrapper {
        margin-left: 0;
    }
}


















.twj-topbar-brand-copy small,
.twj-topbar-brand-subtitle {
    display: none !important;
}

.twj-topbar-brand {
    gap: 10px;
    max-width: 210px;
}

.twj-topbar-brand-title {
    font-size: 15px;
    line-height: 1.1;
    white-space: nowrap;
    overflow: visible;
    text-overflow: clip;
}



body.twj-sidebar-collapsed .twj-topbar-brand {
    display: none !important;
}

body.twj-sidebar-collapsed .twj-topbar-brand-header {
    width: 64px;
    min-width: 64px;
    justify-content: center;
}

body.twj-sidebar-collapsed .twj-sidebar-mode-toggle {
    top: 18px;
    right: -18px;
}












/* =========================================
   SIDEBAR COLLAPSE BUTTON
========================================= */

.twj-sidebar-mode-toggle{
    position: absolute !important;

    top: 78px !important;
    left: 50% !important;

    transform: translateX(-50%) !important;

    width: 34px !important;
    height: 34px !important;

    border-radius: 999px !important;

    background: #ffffff !important;
    border: 1px solid #d7e7f5 !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    z-index: 99999 !important;

    box-shadow: 0 4px 12px rgba(0,0,0,0.06) !important;
}















.twj-topbar-brand-copy{
    display:flex;
    align-items:center;
}

.twj-topbar-brand-name{
    font-size: 29px !important;
    font-weight: 800 !important;
    letter-spacing: -0.5px !important;
    white-space: nowrap !important;
}


















/* =========================================================
   FINAL TWJ SIDEBAR / LOGO FIX
   Keep this at the VERY BOTTOM of twj-ui.css
========================================================= */

:root {
    --twj-sidebar-width: 286px;
    --twj-sidebar-collapsed-width: 64px;
    --twj-topbar-height: 74px;
}

/* Top brand/header */
.twj-app .navbar-static-top {
    min-height: var(--twj-topbar-height) !important;
    background: #fff !important;
    border-bottom: 1px solid rgba(15, 45, 80, 0.08) !important;
}

.twj-app .navbar-header.twj-topbar-brand-header {
    width: var(--twj-sidebar-width) !important;
    min-width: var(--twj-sidebar-width) !important;
    height: var(--twj-topbar-height) !important;
    display: flex !important;
    align-items: flex-end !important;
    padding-bottom: 10px !important;
    padding: 0 18px !important;
    overflow: hidden !important;
}

.twj-app .twj-topbar-brand {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    height: var(--twj-topbar-height) !important;
    max-width: 220px !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
}

.twj-app .twj-topbar-brand-icon {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    border-radius: 999px !important;
    overflow: hidden !important;
    box-shadow:
    0 10px 24px rgba(0, 18, 40, 0.18),
    0 0 0 1px rgba(0, 210, 106, 0.08) !important;
}

.twj-app .twj-topbar-brand-icon img {
    width: 44px !important;
    height: 44px !important;
    object-fit: cover !important;
    display: block !important;
}

.twj-app .twj-topbar-brand-copy {
    display: block !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.twj-app .twj-topbar-brand-name {
    position: relative !important;
    display: inline-block !important;

    font-size: 16px !important;
    font-weight: 900 !important;
    letter-spacing: -0.2px !important;

    line-height: 1.18 !important;

    color: #001b3f !important;

    white-space: nowrap !important;

    padding-bottom: 6px !important;
}

/* Green accent underline */
.twj-app .twj-topbar-brand-name::after {
    content: "" !important;

    position: absolute !important;
    left: 0 !important;
    bottom: 0 !important;

    width: 34px !important;
    height: 3px !important;

    border-radius: 999px !important;

    background: linear-gradient(
        90deg,
        #00d26a 0%,
        #00e08a 100%
    ) !important;

    box-shadow:
        0 0 8px rgba(0,210,106,0.25) !important;
}

.twj-app .twj-topbar-brand-subtitle,
.twj-app .twj-topbar-brand-copy small {
    display: none !important;
}

/* Sidebar sizing */
@media (min-width: 768px) {
    body.twj-app .navbar-default.sidebar {
        width: var(--twj-sidebar-width) !important;
        margin-top: var(--twj-topbar-height) !important;
    }

    body.twj-app #page-wrapper {
        margin-left: var(--twj-sidebar-width) !important;
    }

    body.twj-app.twj-sidebar-collapsed .navbar-header.twj-topbar-brand-header {
        width: var(--twj-sidebar-collapsed-width) !important;
        min-width: var(--twj-sidebar-collapsed-width) !important;
        padding: 0 !important;
        justify-content: center !important;
    }

    body.twj-app.twj-sidebar-collapsed .navbar-default.sidebar {
        width: var(--twj-sidebar-collapsed-width) !important;
    }

    body.twj-app.twj-sidebar-collapsed #page-wrapper {
        margin-left: var(--twj-sidebar-collapsed-width) !important;
    }
}

/* Collapsed logo: keep icon visible, hide text only */
body.twj-app.twj-sidebar-collapsed .twj-topbar-brand {
    display: flex !important;
    max-width: 44px !important;
    justify-content: center !important;
}

body.twj-app.twj-sidebar-collapsed .twj-topbar-brand-copy {
    display: none !important;
}

body.twj-app.twj-sidebar-collapsed .twj-topbar-brand-icon {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
}

body.twj-app.twj-sidebar-collapsed .twj-topbar-brand-icon img {
    width: 38px !important;
    height: 38px !important;
}

/* Sidebar collapse button: belongs to sidebar, not logo */
.twj-app .navbar-default.sidebar {
    position: absolute !important;
}

.twj-app .twj-sidebar-mode-toggle {
    position: absolute !important;
    top: -52px !important;
    right: -20px !important;
    left: auto !important;
    transform: none !important;
    width: 34px !important;
    height: 34px !important;
    border-radius: 999px !important;
    border: 1px solid #d7e7f5 !important;
    background: #ffffff !important;
    color: #0f766e !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 99999 !important;
    box-shadow: 0 6px 18px rgba(15, 35, 70, 0.12) !important;
}

.twj-app .twj-sidebar-mode-toggle:hover {
    color: #00c875 !important;
    border-color: rgba(0, 200, 117, 0.4) !important;
}

/* Collapsed menu icons */
body.twj-app.twj-sidebar-collapsed #side-menu {
    padding-top: 16px !important;
}

body.twj-app.twj-sidebar-collapsed #side-menu > li.twj-sidebar-group-label,
body.twj-app.twj-sidebar-collapsed #side-menu .nav-second-level,
body.twj-app.twj-sidebar-collapsed #side-menu .arrow,
body.twj-app.twj-sidebar-collapsed .twj-sidebar-elite-footer,
body.twj-app.twj-sidebar-collapsed .twj-menu-badge,
body.twj-app.twj-sidebar-collapsed .twj-soon-badge {
    display: none !important;
}

body.twj-app.twj-sidebar-collapsed #side-menu > li > a {
    width: 46px !important;
    height: 46px !important;
    margin: 8px auto !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0 !important;
}

body.twj-app.twj-sidebar-collapsed #side-menu > li > a i {
    font-size: 16px !important;
    margin: 0 !important;
}

















:root {
    --twj-sidebar-width: 286px;
    --twj-sidebar-collapsed-width: 64px;
    --twj-topbar-height: 74px;
}

.twj-app .twj-topbar-brand {
    max-width: 250px !important;
}

.twj-app .twj-topbar-brand-name {
    font-size: 16px !important;
    letter-spacing: -0.2px !important;
}








.sidebar .nav > li > a i {
    position: relative;
    top: 1px;
}










.twj-brand-name {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
    font-size: 15px;
    font-weight: 900;
    color: #001b3f;
}

.twj-brand-name span:first-child::after {
    content: "";
    display: block;
    width: 34px;
    height: 3px;
    margin-top: 5px;
    border-radius: 999px;
    background: linear-gradient(90deg, #00d26a, #00a2ff);
}


.twj-brand-name {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
    font-size: 16px;
    font-weight: 900;
    color: #001b3f;
    letter-spacing: -0.02em;
    margin-left: -3px;
}

.twj-brand-name .twj-line-2 {
    margin-left: 39px;
    margin-top: -3px;
    font-size: 18px;
}











.twj-collapsed-workflow-nav {
    display: none;
}

@media (min-width: 768px) {
    body.twj-sidebar-collapsed #side-menu {
        display: none !important;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav {
        display: flex !important;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        padding: 16px 8px 22px;
        margin: 0;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a {
        width: 46px;
        height: 46px;
        margin: 0 auto;
        border-radius: 14px;
        display: flex !important;
        align-items: center;
        justify-content: center;
        color: #1f2d44;
        transition: background .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a:hover {
        background: rgba(0, 200, 117, 0.08);
        color: #00a85a;
        transform: translateY(-1px);
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a.twj-collapsed-active {
        background: rgba(0, 200, 117, 0.13);
        color: #00a85a;
        box-shadow: inset 3px 0 0 #00c875, 0 12px 26px rgba(0, 200, 117, 0.13);
    }
}













/* Stable collapsed sidebar workflow rail */
@media (min-width: 768px) {
    body.twj-sidebar-collapsed #side-menu {
        display: none !important;
        pointer-events: none !important;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
        width: 64px !important;
        margin: 0 !important;
        padding: 16px 8px 22px !important;
        list-style: none !important;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li {
        width: 46px !important;
        height: 46px !important;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        list-style: none !important;
        flex: 0 0 46px !important;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a,
    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a:hover,
    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a:focus,
    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a:active {
        width: 46px !important;
        height: 46px !important;
        min-height: 46px !important;
        margin: 0 !important;
        padding: 0 !important;
        border: 0 !important;
        border-left: 0 !important;
        border-radius: 14px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-sizing: border-box !important;
        transform: none !important;
        transition: none !important;
        outline: 0 !important;
        text-decoration: none !important;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a:hover,
    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a:focus {
        background: rgba(0, 200, 117, 0.08) !important;
        color: #00a85a !important;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a.twj-collapsed-active {
        background: rgba(0, 200, 117, 0.13) !important;
        color: #00a85a !important;
        box-shadow: inset 3px 0 0 #00c875, 0 12px 26px rgba(0, 200, 117, 0.13) !important;
    }

    body.twj-sidebar-collapsed .twj-collapsed-workflow-nav > li > a > i {
        width: 16px !important;
        margin: 0 !important;
        line-height: 1 !important;
        text-align: center !important;
        transform: none !important;
    }
}













@media (max-width: 767px) {
    body.twj-app .twj-collapsed-workflow-nav,
    body.twj-app.twj-sidebar-collapsed .twj-collapsed-workflow-nav {
        display: none !important;
    }

    body.twj-app.twj-sidebar-collapsed #side-menu {
        display: block !important;
        pointer-events: auto !important;
    }

    body.twj-app .twj-sidebar-mode-toggle {
        display: none !important;
    }

    body.twj-app.twj-sidebar-collapsed #page-wrapper {
        margin-left: 0 !important;
    }
}















/* =========================================================
   TWJ PREMIUM SAAS PASS - GLOBAL DENSITY
========================================================= */

.twj-page {
    padding-top: 18px !important;
}

.page-header {
    margin-top: 0 !important;
    margin-bottom: 16px !important;
    padding-bottom: 12px !important;
    font-size: 32px !important;
}

.twj-panel,
.panel {
    margin-bottom: 18px !important;
}

.panel-heading {
    padding: 12px 16px !important;
}

.panel-body {
    padding: 12px 14px !important;
}

/* Premium compact table */
.twj-table-pro {
    font-size: 13px;
    margin-bottom: 0;
}

.twj-table-pro > thead > tr > th {
    padding: 9px 10px !important;
    white-space: nowrap;
    text-transform: uppercase;
    font-size: 11px !important;
    letter-spacing: .04em;
}

.twj-table-pro > tbody > tr > td {
    padding: 9px 10px !important;
    vertical-align: middle !important;
}

/* Sort headers */
.twj-sort-link {
    color: inherit;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.twj-sort-link:hover {
    color: var(--tw-primary-dark) !important;
}

/* Compact actions */
.twj-action-group {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    align-items: center;
}

.twj-btn-xs {
    min-height: 26px !important;
    height: 26px !important;
    padding: 3px 9px !important;
    font-size: 11px !important;
    line-height: 1 !important;
}

/* Compact toolbar/filter system */
.twj-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    background: var(--tw-surface);
    border: 1px solid var(--tw-border);
    border-radius: 16px;
    padding: 10px 12px;
    margin-bottom: 16px;
}

.twj-toolbar .form-control {
    min-height: 32px !important;
    height: 32px !important;
}

/* Open positions current price */
.twj-inline-form {
    display: flex !important;
    gap: 6px;
    align-items: center;
}

.twj-price-input {
    width: 96px !important;
    min-height: 30px !important;
    height: 30px !important;
}

/* Dashboard compact plan strip */
.twj-plan-strip {
    min-height: 64px !important;
    padding: 14px 18px !important;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

#trade-table {
    scroll-margin-top: 90px;
}






/* Premium SaaS tables */
.twj-ajax-table {
    transition: opacity .18s ease;
}

.twj-table-shell {
    overflow: auto;
    max-height: 58vh;
    border: 1px solid #e8eef6;
    border-radius: 14px;
}

.twj-table-pro {
    margin-bottom: 0;
    font-size: 12.5px;
    border-collapse: separate;
    border-spacing: 0;
}

.twj-table-pro thead th {
    position: sticky;
    top: 0;
    z-index: 8;
    background: #f8fbff;
    border-bottom: 1px solid #dbe7f3 !important;
    padding: 9px 10px !important;
    white-space: nowrap;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.twj-table-pro tbody td {
    padding: 8px 10px !important;
    vertical-align: middle !important;
    border-top: 1px solid #eef3f8 !important;
}

.twj-table-pro tbody tr:hover {
    background: #f8fbff;
}

.twj-sort-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #0b1f3a;
    text-decoration: none !important;
}

.twj-sort-link:hover {
    color: #00b894;
}

.twj-num {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.twj-center {
    text-align: center;
}

.twj-date-line,
.twj-time-line,
.twj-price-line {
    display: block;
    line-height: 1.25;
}

.twj-time-line,
.twj-price-line {
    color: #64748b;
}

.twj-actions-cell {
    min-width: 96px;
}

.twj-table-actions {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.twj-table-actions .btn,
.twj-btn-xs {
    height: 24px !important;
    min-height: 24px !important;
    line-height: 18px !important;
    font-size: 11px;
    font-weight: 600;
    border-radius: 999px;
    padding: 4px 10px;
    transition: all 0.18s ease;
}

.twj-table-actions form {
    margin: 0;
}

/* Compact stat cards above tables */
.twj-table-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 14px;
}

.twj-table-stat {
    min-width: 145px;
    padding: 12px 16px;
    border-radius: 14px;
    border: 1px solid #dbeafe;
    background: #f8fbff;
}

.twj-table-stat strong {
    display: block;
    font-size: 18px;
    line-height: 1.1;
    font-weight: 800;
}

.twj-table-stat span {
    font-size: 12px;
    color: #64748b;
}



.twj-table-actions .btn {
    border: 1px solid #d8e4f0 !important;
    background: #ffffff !important;
    color: #0b1f3a !important;
}

.twj-table-actions .twj-btn-view {
    background: #eff6ff !important;
    color: #2563eb !important;
    border: 1px solid #bfdbfe !important;
}

.twj-table-actions .twj-btn-review {
    background: #10b981 !important;
    color: white !important;
    border: 1px solid #10b981 !important;
    box-shadow: 0 2px 8px rgba(22,163,74,.15);
}

.twj-table-actions .twj-btn-view:hover {
    background: #dbeafe !important;
}

.twj-table-actions .twj-btn-review:hover {
    background: #059669 !important;
}

.twj-table-actions .twj-btn-archive:hover {
    background: #ffedd5 !important;
}


/* EDIT */
.twj-table-actions .twj-btn-edit {
    background: #f8fafc !important;
    color: #475569 !important;
    border: 1px solid #cbd5e1 !important;
}

.twj-table-actions .twj-btn-edit:hover {
    background: #f1f5f9 !important;
}



.twj-table-stat {
    min-width: 145px;
    padding: 12px 16px;
    border-radius: 14px;
    border: 1px solid #dbeafe;
    background: linear-gradient(135deg, #ffffff 0%, #f8fbff 100%);
}

.twj-table-stat-info {
    border-color: #bae6fd;
    background: linear-gradient(135deg, #f0f9ff 0%, #ffffff 100%);
}

.twj-table-stat-profit {
    border-color: #bbf7d0;
    background: linear-gradient(135deg, #ecfdf5 0%, #ffffff 100%);
}

.twj-table-stat-warning {
    border-color: #fde68a;
    background: linear-gradient(135deg, #fffbeb 0%, #ffffff 100%);
}

.twj-table-stat-danger {
    border-color: #fecaca;
    background: linear-gradient(135deg, #fef2f2 0%, #ffffff 100%);
}




.twj-table thead th {
    background: #f8fafc;
    border-bottom: 1px solid #e2e8f0;
    color: #64748b;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
    position: sticky;
    top: 0;
    z-index: 5;
}


.twj-card,
.twj-table-wrapper,
.twj-filters-card {
    box-shadow:
        0 1px 2px rgba(15,23,42,.03),
        0 8px 24px rgba(15,23,42,.04);
}




.twj-table tbody tr {
    transition: background .15s ease;
}

.twj-table tbody tr:hover {
    background: #f8fbff;
}





.pagination .page-link {
    border-radius: 10px !important;
    margin: 0 2px;
    border: 1px solid #dbe3ee;
    color: #334155;
    font-weight: 600;
}

.pagination .page-item.active .page-link {
    background: #2563eb;
    border-color: #2563eb;
    color: white;
}



.twj-table td {
    padding-top: 14px;
    padding-bottom: 14px;
}




.twj-table tbody tr:nth-child(even) {
    background: #fcfdff;
}


.twj-table-pro tbody tr {
    box-shadow: inset 0 -1px 0 #eef2f7;
}



.pagination {
    gap: 4px;
}

.pagination .page-link {
    min-width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}




body {
    background:
        radial-gradient(circle at top left,
        #f8fbff 0%,
        #f4f7fb 35%,
        #eef3f8 100%);
}





.twj-filters-card .form-control,
.twj-filters-card select {
    height: 34px !important;
    min-height: 34px !important;
    font-size: 13px;
    border-radius: 10px;
}



.twj-filters-card .row {
    margin-bottom: 6px;
}


.twj-filters-card label {
    margin-bottom: 4px;
    font-size: 12px;
    font-weight: 600;
    color: #64748b;
}



.twj-filter-actions .btn {
    height: 34px !important;
    padding: 0 14px !important;
    border-radius: 10px;
    font-size: 12px;
    font-weight: 600;
}


.twj-filters-collapsed .panel-body {
    display: none;
}




.twj-btn-view {
    background: transparent !important;
    border: 1px solid #dbeafe !important;
    color: #3b82f6 !important;
}


.twj-btn-edit {
    background: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    color: #64748b !important;
}



.twj-btn-review {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    border: none !important;
    color: white !important;
    box-shadow:
        0 4px 10px rgba(16,185,129,.18),
        0 1px 2px rgba(0,0,0,.06);
}



.twj-btn-archive {
    background: transparent !important;
    border: 1px dashed #fdba74 !important;
    color: #c2410c !important;
}






/* =========================================================
   TRADE LOG FINAL OVERRIDES
========================================================= */

/* Compact collapsible filters */
.twj-filters-card .panel-heading {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    min-height: 48px !important;
    padding: 12px 18px !important;
}

.twj-filter-toggle {
    border: 1px solid #dbeafe;
    background: #ffffff;
    color: #2563eb;
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 800;
}

.twj-filters-collapsed .panel-body {
    display: none !important;
}

.twj-filters-card .panel-body {
    padding: 14px 18px !important;
}

.twj-filters-card .form-group {
    margin-bottom: 10px !important;
}

.twj-filters-card label {
    margin-bottom: 4px !important;
    font-size: 12px !important;
    color: #64748b !important;
    font-weight: 700 !important;
}

.twj-filters-card .form-control {
    height: 34px !important;
    min-height: 34px !important;
    font-size: 13px !important;
    border-radius: 10px !important;
}

.twj-filter-actions {
    display: flex;
    gap: 8px;
    margin-top: 4px;
}

.twj-filter-actions .btn {
    height: 34px !important;
    min-height: 34px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
}

/* Action buttons with more punch */
.twj-table-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
    align-items: center !important;
}

.twj-table-actions .btn,
.twj-table-actions button {
    min-width: 72px !important;
    height: 24px !important;
    min-height: 24px !important;
    padding: 3px 10px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    line-height: 16px !important;
    box-shadow: none !important;
}

.twj-table-actions form {
    margin: 0 !important;
}



.twj-table-actions .btn,
.twj-table-actions button {
    min-width: 72px !important;
    height: 24px !important;
    min-height: 24px !important;
    padding: 3px 10px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 850 !important;
    line-height: 16px !important;
}

.twj-btn-view {
    background: #eef6ff !important;
    border: 1px solid #93c5fd !important;
    color: #1d4ed8 !important;
}

.twj-btn-edit {
    background: #f8fafc !important;
    border: 1px solid #94a3b8 !important;
    color: #334155 !important;
}

.twj-btn-review {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    border: 1px solid #059669 !important;
    color: #ffffff !important;
    box-shadow: 0 4px 10px rgba(16,185,129,.22) !important;
}

.twj-btn-archive {
    background: #fff1f2 !important;
    border: 1px solid #fda4af !important;
    color: #be123c !important;
}









/* Bootstrap 3 pagination fix */
.pagination > li > a,
.pagination > li > span {
    border-radius: 10px !important;
    margin: 0 2px !important;
    border: 1px solid #dbe3ee !important;
    color: #334155 !important;
    font-weight: 700 !important;
}

.pagination > .active > a,
.pagination > .active > span {
    background: #2563eb !important;
    border-color: #2563eb !important;
    color: #ffffff !important;
}








/* Trade Log compact filter toolbar */
.twj-filters-card .panel-body {
    padding: 10px 14px !important;
}

.twj-filter-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 10px;
}

.twj-filter-field {
    flex: 1 1 130px;
    min-width: 130px;
}

.twj-filter-field-sm {
    flex: 0 0 88px;
    min-width: 88px;
}

.twj-filter-field label {
    display: block;
    margin: 0 0 3px !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    color: #64748b !important;
}

.twj-filter-field .form-control {
    height: 32px !important;
    min-height: 32px !important;
    padding: 5px 10px !important;
    font-size: 12px !important;
    border-radius: 10px !important;
}

.twj-filter-actions {
    display: flex;
    align-items: center;
    gap: 7px;
    flex: 0 0 auto;
}

.twj-filter-apply,
.twj-filter-clear {
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 13px !important;
    border-radius: 10px !important;
    font-size: 12px !important;
    font-weight: 800 !important;
}

.twj-filter-apply {
    background: #10b981 !important;
    border-color: #10b981 !important;
    color: #ffffff !important;
}

.twj-filter-clear {
    background: #f8fafc !important;
    border-color: #cbd5e1 !important;
    color: #475569 !important;
}











/* =========================================================
   TRADE LOG FINAL BUTTON + FILTER OVERRIDE
========================================================= */

#trade-log-filters.twj-filters-card {
    margin-bottom: 14px !important;
}

#trade-log-filters.twj-filters-card > .panel-heading {
    min-height: 44px !important;
    height: 44px !important;
    padding: 8px 16px !important;
}

#trade-log-filters.twj-filters-card > .panel-body {
    padding: 10px 14px !important;
}

#trade-log-filters .twj-filter-bar {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: flex-end !important;
    gap: 9px !important;
}

#trade-log-filters .twj-filter-field {
    flex: 1 1 125px !important;
    min-width: 125px !important;
}

#trade-log-filters .twj-filter-field-sm {
    flex: 0 0 82px !important;
    min-width: 82px !important;
}

#trade-log-filters label {
    margin: 0 0 3px !important;
    font-size: 11px !important;
    line-height: 1.1 !important;
}

#trade-log-filters .form-control {
    height: 30px !important;
    min-height: 30px !important;
    padding: 4px 9px !important;
    font-size: 12px !important;
}

#trade-log-filters .twj-filter-actions {
    display: flex !important;
    gap: 7px !important;
    align-items: center !important;
}

#trade-log-filters .twj-filter-apply,
#trade-log-filters .twj-filter-clear {
    height: 30px !important;
    min-height: 30px !important;
    padding: 0 13px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 800 !important;
}

#trade-log-filters .twj-filter-apply {
    background: #10b981 !important;
    border-color: #10b981 !important;
    color: #ffffff !important;
}

#trade-log-filters .twj-filter-clear {
    background: #ffffff !important;
    border-color: #cbd5e1 !important;
    color: #334155 !important;
}

/* Strong action button overrides */
#trade-table .twj-table-actions .btn,
#trade-table .twj-table-actions button {
    min-width: 74px !important;
    height: 24px !important;
    min-height: 24px !important;
    padding: 3px 10px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 850 !important;
    line-height: 16px !important;
    box-shadow: none !important;
}

#trade-table .twj-table-actions .twj-btn-view {
    background: #e0f2fe !important;
    border-color: #38bdf8 !important;
    color: #0369a1 !important;
}

#trade-table .twj-table-actions .twj-btn-edit {
    background: #f1f5f9 !important;
    border-color: #94a3b8 !important;
    color: #334155 !important;
}

#trade-table .twj-table-actions .twj-btn-review {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
    border-color: #059669 !important;
    color: #ffffff !important;
    box-shadow: 0 4px 10px rgba(16,185,129,.25) !important;
}

#trade-table .twj-table-actions .twj-btn-archive {
    background: #fff1f2 !important;
    border-color: #fb7185 !important;
    color: #be123c !important;
}

#trade-table .twj-table-actions .twj-btn-view:hover,
#trade-table .twj-table-actions .twj-btn-edit:hover,
#trade-table .twj-table-actions .twj-btn-review:hover,
#trade-table .twj-table-actions .twj-btn-archive:hover {
    transform: translateY(-1px) !important;
    filter: brightness(.98);
}







#trade-table .twj-actions-cell {
    min-width: 92px !important;
    width: 92px !important;
}

#trade-table .twj-table-actions {
    gap: 4px !important;
}

#trade-table .twj-table-actions .btn,
#trade-table .twj-table-actions button {
    height: 22px !important;
    min-height: 22px !important;
    padding: 2px 9px !important;
    font-size: 10.5px !important;
    line-height: 15px !important;
}

#trade-table .twj-table-shell {
    max-height: 54vh !important;
}




#trade-table .twj-btn-review {
    min-width: 82px !important;
}






#trade-table .twj-table-pro tbody td {
    padding-top: 12px !important;
    padding-bottom: 12px !important;
}




#trade-table .twj-table-pro tbody tr:hover {
    background: #f8fbff !important;
}




.twj-table-stat {
    position: relative;
    overflow: hidden;
}

.twj-table-stat::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 3px;
    width: 100%;
    background: rgba(16,185,129,.35);
}

.twj-table-stat-warning::before {
    background: rgba(245,158,11,.45);
}

.twj-table-stat-danger::before {
    background: rgba(244,63,94,.45);
}

.twj-table-stat-info::before {
    background: rgba(59,130,246,.35);
}



.twj-sort-link.is-active {
    color: #0f766e !important;
    font-weight: 900 !important;
}





#trade-table .twj-table-shell {
    overflow-y: auto !important;
    overflow-x: auto !important;
    padding-right: 8px !important;
}

#trade-table .twj-actions-cell {
    position: sticky;
    right: 0;
    z-index: 4;
    background: inherit;
    min-width: 98px !important;
    width: 98px !important;
    box-shadow: -8px 0 12px rgba(15,23,42,.035);
}

#trade-table thead th:last-child {
    position: sticky;
    right: 0;
    z-index: 9;
    background: #f8fafc;
    box-shadow: -8px 0 12px rgba(15,23,42,.04);
}






#trade-table .twj-sort-link.is-active {
    color: #0f766e !important;
    font-weight: 900 !important;
}






#trade-table.twj-loading {
    position: relative;
    opacity: .75;
}

#trade-table.twj-loading::after {
    content: "Updating...";
    position: absolute;
    top: 12px;
    right: 18px;
    background: #0f766e;
    color: #fff;
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 11px;
    font-weight: 800;
    z-index: 20;
}




/* Final fixed professional table density */
#trade-table .twj-table-pro tbody td {
    padding-top: 11px !important;
    padding-bottom: 11px !important;
}

#trade-table .twj-table-stats {
    margin-top: 0 !important;
    margin-bottom: 12px !important;
}








.twj-table-heading {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.twj-table-heading-actions {
    position: relative;
}

.twj-columns-toggle {
    height: 30px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid #dbeafe;
    background: #ffffff;
    color: #2563eb;
    font-size: 12px;
    font-weight: 800;
}

.twj-columns-menu {
    display: none;
    position: absolute;
    right: 0;
    top: 36px;
    width: 190px;
    background: #ffffff;
    border: 1px solid #dbe3ee;
    border-radius: 14px;
    padding: 10px;
    box-shadow: 0 12px 30px rgba(15,23,42,.12);
    z-index: 50;
}

.twj-columns-menu.open {
    display: block;
}

.twj-columns-menu label {
    display: flex;
    gap: 8px;
    align-items: center;
    margin: 0;
    padding: 6px 4px;
    font-size: 12px;
    font-weight: 700;
    color: #334155;
}





.twj-table-pro thead th {
    position: sticky;
    top: 0;
    z-index: 5;
}


.twj-table-pro tbody tr:hover {
    background: #f8fbff;
}




.trade-win {
    border-left: 3px solid #22c55e;
}

.trade-loss {
    border-left: 3px solid #ef4444;
}




#trade-table .twj-table-stats {
    background: #ffffff !important;
    border-radius: 16px !important;
    padding: 10px 10px 8px !important;
    margin-bottom: 10px !important;
    overflow: hidden !important;
}

#trade-table .twj-table-stat {
    background-clip: padding-box !important;
}



#trade-table .twj-table-pro th:nth-child(6),
#trade-table .twj-table-pro td:nth-child(6),
#trade-table .twj-table-pro th:nth-child(7),
#trade-table .twj-table-pro td:nth-child(7) {
    min-width: 92px !important;
    white-space: nowrap !important;
}

#trade-table .twj-date-line,
#trade-table .twj-time-line,
#trade-table .twj-price-line {
    white-space: nowrap !important;
}







.twj-filter-actions .btn,
.twj-filter-actions button,
.twj-filter-actions input[type="submit"] {
    height: 38px !important;
    line-height: 38px !important;
    padding: 0 16px !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;

    vertical-align: middle !important;
}



.twj-filter-actions .btn-secondary,
.twj-filter-actions .btn-clear {
    position: relative;
    top: -1px;
}



.twj-filter-actions .btn-secondary,
.twj-filter-actions .btn-clear {
    line-height: normal !important;
}








/* =========================================================
   TWJ SHARED PREMIUM STAT CARDS
========================================================= */

.twj-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(160px, 1fr));
    gap: 14px;
    margin-bottom: 16px;
}

.twj-kpi-card {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    padding: 14px 18px;
    border: 1px solid #dbeafe;
    background: #f8fbff;
    box-shadow: 0 1px 2px rgba(15,23,42,.03);
}

.twj-kpi-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: #38bdf8;
}

.twj-kpi-value {
    display: block;
    font-size: 18px;
    line-height: 1.15;
    font-weight: 900;
    color: #06214a;
}

.twj-kpi-label {
    display: block;
    margin-top: 3px;
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
}

.twj-kpi-info {
    background: #eff8ff;
    border-color: #bae6fd;
}

.twj-kpi-success {
    background: #f0fdf7;
    border-color: #bbf7d0;
}

.twj-kpi-warning {
    background: #fffbeb;
    border-color: #fde68a;
}

.twj-kpi-danger {
    background: #fff1f2;
    border-color: #fecdd3;
}

.twj-kpi-info::before { background: #38bdf8; }
.twj-kpi-success::before { background: #10b981; }
.twj-kpi-warning::before { background: #f59e0b; }
.twj-kpi-danger::before { background: #f43f5e; }

@media (max-width: 1100px) {
    .twj-kpi-grid {
        grid-template-columns: repeat(2, minmax(160px, 1fr));
    }
}

@media (max-width: 640px) {
    .twj-kpi-grid {
        grid-template-columns: 1fr;
    }
}




#trade-table .twj-trade-kpi-grid {
    display: grid;
    grid-template-columns: repeat(8, minmax(120px, 1fr));
    gap: 10px;
    margin-bottom: 12px;
}

#trade-table .twj-trade-kpi-card {
    position: relative;
    overflow: hidden;
    border-radius: 14px;
    padding: 12px 14px;
    border: 1px solid #dbeafe;
    background: #f8fbff;
    box-shadow: 0 1px 2px rgba(15,23,42,.03);
}

#trade-table .twj-trade-kpi-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: #38bdf8;
}

#trade-table .twj-kpi-value {
    display: block;
    font-size: 18px;
    line-height: 1.15;
    font-weight: 900;
    color: #06214a;
}

#trade-table .twj-kpi-label {
    display: block;
    margin-top: 3px;
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
}

#trade-table .twj-kpi-info {
    background: #eff8ff;
    border-color: #bae6fd;
}

#trade-table .twj-kpi-success {
    background: #f0fdf7;
    border-color: #bbf7d0;
}

#trade-table .twj-kpi-warning {
    background: #fffbeb;
    border-color: #fde68a;
}

#trade-table .twj-kpi-danger {
    background: #fff1f2;
    border-color: #fecdd3;
}

#trade-table .twj-kpi-info::before { background: #38bdf8; }
#trade-table .twj-kpi-success::before { background: #10b981; }
#trade-table .twj-kpi-warning::before { background: #f59e0b; }
#trade-table .twj-kpi-danger::before { background: #f43f5e; }












/* Softer Trade Log KPI cards - closer to Review Center style */
#trade-table .twj-trade-kpi-card {
    border-radius: 16px !important;
    padding: 14px 18px !important;
    border-width: 1px !important;
    box-shadow: 0 1px 2px rgba(15,23,42,.03) !important;
}

#trade-table .twj-trade-kpi-card::before {
    height: 2px !important;
    opacity: .55 !important;
}

#trade-table .twj-kpi-info {
    background: #f0f9ff !important;
    border-color: #bae6fd !important;
}

#trade-table .twj-kpi-success {
    background: #f0fdf7 !important;
    border-color: #bbf7d0 !important;
}

#trade-table .twj-kpi-warning {
    background: #fffbeb !important;
    border-color: #fde68a !important;
}

#trade-table .twj-kpi-danger {
    background: #fff5f5 !important;
    border-color: #fecaca !important;
}

#trade-table .twj-kpi-value {
    font-size: 18px !important;
    font-weight: 850 !important;
}

#trade-table .twj-kpi-label {
    color: #64748b !important;
    font-weight: 600 !important;
}













/* =========================================================
   TRADE LOG FINAL KPI CARD SOURCE OF TRUTH
========================================================= */

#trade-table .twj-trade-kpi-grid {
    display: grid !important;
    grid-template-columns: repeat(8, minmax(120px, 1fr)) !important;
    gap: 10px !important;
    margin: 0 0 12px !important;
    padding: 0 !important;
    background: transparent !important;
}

#trade-table .twj-trade-kpi-card {
    position: relative !important;
    min-height: 64px !important;
    border-radius: 16px !important;
    padding: 13px 16px !important;
    overflow: hidden !important;
    box-shadow: 0 1px 2px rgba(15,23,42,.03) !important;
}

#trade-table .twj-trade-kpi-card::before {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    height: 3px !important;
    opacity: .7 !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-info {
    background: #f0f9ff !important;
    border: 1px solid #bae6fd !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-success {
    background: #f0fdf7 !important;
    border: 1px solid #bbf7d0 !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-warning {
    background: #fffbeb !important;
    border: 1px solid #fde68a !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-danger {
    background: #fff1f2 !important;
    border: 1px solid #fecdd3 !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-info::before {
    background: #38bdf8 !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-success::before {
    background: #10b981 !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-warning::before {
    background: #f59e0b !important;
}

#trade-table .twj-trade-kpi-card.twj-kpi-danger::before {
    background: #f43f5e !important;
}

#trade-table .twj-trade-kpi-card .twj-kpi-value {
    display: block !important;
    font-size: 18px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    color: #06214a !important;
    letter-spacing: -0.03em !important;
}

#trade-table .twj-trade-kpi-card .twj-kpi-label {
    display: block !important;
    margin-top: 4px !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    font-weight: 600 !important;
    color: #64748b !important;
}












/* =========================================================
   TRADE LOG FINAL PANEL + KPI SPACING FIX
========================================================= */

#trade-table.panel {
    overflow: visible !important;
}

#trade-table > .panel-heading.twj-table-heading {
    min-height: 52px !important;
    padding: 14px 18px !important;
    margin: 0 !important;
    border-bottom: 1px solid #dbe7f3 !important;
}

#trade-table > .panel-body {
    padding: 14px 18px 18px !important;
}

/* Remove unwanted inner top gap */
#trade-table .twj-trade-kpi-grid,
#trade-table .twj-table-stats {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* If old table-stats wrapper is still present */
#trade-table .twj-table-stats {
    background: transparent !important;
    border: 0 !important;
}

/* KPI cards final look */
#trade-table .twj-trade-kpi-grid {
    display: grid !important;
    grid-template-columns: repeat(8, minmax(120px, 1fr)) !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
}

#trade-table .twj-trade-kpi-card {
    min-height: 62px !important;
    border-radius: 16px !important;
    padding: 13px 16px !important;
}



/* Trade Log final spacing correction */
#trade-table > .panel-body {
    padding: 10px 18px 18px !important;
}

#trade-table .twj-trade-kpi-grid {
    margin-top: 0 !important;
    margin-bottom: 10px !important;
}

#trade-table .twj-trade-kpi-card {
    min-height: 58px !important;
    padding: 11px 15px !important;
}








/* =========================================
   TRADE LOG KPI CARDS
   Match Review Center style
========================================= */

#trade-table .twj-trade-kpi-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
    gap:12px;
    margin:0 0 14px 0 !important;
}

#trade-table .twj-trade-kpi-card{
    position:relative;
    background:#f8fbfc !important;
    border:1px solid #dbe7ef !important;
    border-radius:16px !important;
    padding:14px 16px !important;
    min-height:74px !important;

    display:flex;
    flex-direction:column;
    justify-content:center;

    box-shadow:
        0 1px 2px rgba(15,23,42,.03),
        inset 0 1px 0 rgba(255,255,255,.7);

    transition:all .18s ease;
    overflow:hidden;
}

/* subtle colored top accent */
#trade-table .twj-trade-kpi-card::before{
    content:"";
    position:absolute;
    top:0;
    left:0;
    right:0;
    height:3px;
    border-radius:999px;
    opacity:.95;
}

/* hover */
#trade-table .twj-trade-kpi-card:hover{
    transform:translateY(-1px);
    box-shadow:
        0 6px 18px rgba(15,23,42,.06),
        inset 0 1px 0 rgba(255,255,255,.8);
}

/* value */
#trade-table .twj-trade-kpi-value{
    font-size:31px !important;
    line-height:1 !important;
    font-weight:800 !important;
    letter-spacing:-0.03em;
    color:#0f172a !important;
    margin-bottom:7px;
}

/* label */
#trade-table .twj-trade-kpi-label{
    font-size:13px !important;
    font-weight:600 !important;
    color:#64748b !important;
    line-height:1.2;
}

/* =========================================
   COLOR THEMES
========================================= */

#trade-table .twj-kpi-blue{
    background:#f3f9fd !important;
    border-color:#b9def8 !important;
}
#trade-table .twj-kpi-blue::before{
    background:#38bdf8;
}

#trade-table .twj-kpi-green{
    background:#f2fbf6 !important;
    border-color:#bdeccf !important;
}
#trade-table .twj-kpi-green::before{
    background:#22c55e;
}

#trade-table .twj-kpi-yellow{
    background:#fffaf0 !important;
    border-color:#f7db98 !important;
}
#trade-table .twj-kpi-yellow::before{
    background:#f59e0b;
}

#trade-table .twj-kpi-red{
    background:#fff5f5 !important;
    border-color:#f5c2c7 !important;
}
#trade-table .twj-kpi-red::before{
    background:#ef4444;
}











/* Trade Log KPI row using Review Center card style */
.twj-trade-score-row {
    margin: 0 0 14px 0;
}

.twj-trade-score-row > [class*="col-"] {
    margin-bottom: 12px;
}

/* Prevent old Trade Log KPI styles from fighting the Review Center cards */
.twj-trade-score-row .twj-score-card {
    min-height: 92px;
    padding: 22px 24px;
}

























