/* LynxCapital Market SPA */
.market-spa-body { background: #F7FBF7; overflow-x: hidden; }
.market-top-header { z-index: 120; }
.market-mobile-menu { display: none !important; }
.market-sidebar { position: fixed; top: 73px; left: 0; bottom: 0; width: 240px; z-index: 90; background: #064E3B; color: #fff; overflow-y: auto; padding: 18px 14px; box-shadow: 12px 0 30px rgba(6,78,59,.15); }
.market-sidebar-header { display: flex; align-items: center; gap: 10px; padding: 4px 8px 18px; border-bottom: 1px solid rgba(255,255,255,.14); margin-bottom: 12px; }
.market-sidebar-header img { width: 34px; height: 34px; border-radius: 10px; background: #fff; }
.market-sidebar-header strong { font-size: 1.05rem; letter-spacing: -.01em; }
.market-side-nav { display: grid; gap: 6px; }
.side-link, .side-group-toggle { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 10px; border: 0; border-radius: 12px; background: transparent; color: rgba(255,255,255,.88); padding: 0.72rem 0.78rem; font: inherit; font-size: .83rem; font-weight: 900; text-decoration: none; text-align: left; cursor: pointer; transition: background .18s ease, color .18s ease, opacity .18s ease; }
.side-group-toggle { color: #BFF7D3; text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; }
.side-group-toggle::after { content: "▾"; font-size: .74rem; opacity: .8; transition: transform .18s ease; }
.side-group:not(.is-open) .side-group-toggle::after { transform: rotate(-90deg); }
.side-link:hover, .side-group-toggle:hover { background: rgba(255,255,255,.1); color: #fff; }
.side-link.is-active { background: rgba(93, 202, 165, .42); color: #fff; font-weight: 950; }
.side-link.is-soon { opacity: .52; }
.side-link span { margin-left: auto; }
.side-submenu { display: grid; gap: 4px; max-height: 320px; overflow: hidden; transition: max-height .22s ease, opacity .22s ease; }
.side-group:not(.is-open) .side-submenu { max-height: 0; opacity: 0; }
.side-submenu .side-link { padding-left: 1.25rem; font-size: .8rem; font-weight: 780; }
.market-sidebar-backdrop { display: none; position: fixed; inset: 0; z-index: 80; background: rgba(0,0,0,.38); }
.market-app-shell { margin-left: 240px; padding-top: 73px; min-height: 100vh; background: #F7FBF7; }
.market-view { min-height: calc(100vh - 73px); transition: opacity .15s ease; }
.market-view.is-changing { opacity: 0; }
.spa-panel { padding: clamp(28px, 4vw, 56px); }
.spa-panel h1 { margin: 0 0 12px; color: #064E3B; font-size: clamp(2rem, 4vw, 3.35rem); line-height: 1; letter-spacing: -.045em; }
.view-subtitle, .spa-panel > p:not(.eyebrow):not(.page-label) { max-width: 780px; color: #667085; font-size: 1.04rem; line-height: 1.65; }
.overview-grid { display: grid; gap: 14px; margin-top: 22px; }
.category-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.metric-grid-spa { grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 620px; }
.overview-grid article, .overview-card, .berita-item-full, .coming-soon-view { border: 1px solid #E6E2D8; border-radius: 22px; background: #fff; padding: 20px; box-shadow: 0 16px 40px rgba(6,78,59,.05); }
.overview-grid article span, .mini-stat-grid article span { display: block; color: #667085; font-size: .78rem; font-weight: 850; text-transform: uppercase; }
.overview-grid article strong, .mini-stat-grid article strong { display: block; margin-top: 6px; color: #064E3B; font-size: 1.25rem; font-weight: 950; }
.overview-grid article em, .mini-stat-grid article em { display: block; margin-top: 4px; color: #667085; font-size: .84rem; font-style: normal; font-weight: 750; }
.overview-two-col { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 16px; }
.overview-card h2 { margin: 0 0 14px; color: #064E3B; font-size: 1.25rem; }
.mini-stat-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.mini-stat-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.mini-stat-grid article { border: 1px solid #E6E2D8; border-radius: 16px; background: #FAFAFA; padding: 14px; }
.iframe-panel { padding: 22px; }
.iframe-head { padding: 8px 6px 18px; }
.iframe-head h1 { font-size: clamp(1.8rem, 3vw, 2.6rem); }
.market-tool-frame { display: block; width: 100%; min-height: 900px; border: 0; border-radius: 24px; background: #FAFAFA; box-shadow: 0 18px 55px rgba(6,78,59,.08); }
.berita-panel { background: #fff; }
.page-label { color: #F59E0B; font-size: .78rem; font-weight: 800; letter-spacing: .10em; text-transform: uppercase; margin: 0 0 4px; line-height: 1; }
.rsi-subtitle { color: #6F6F6F; font-size: 1rem; line-height: 1.3; margin: 0; }
.berita-list-full { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 22px; max-width: 980px; }
.berita-item-full h2 { margin: 6px 0 8px; color: #064E3B; font-size: clamp(1.12rem, 1.8vw, 1.45rem); line-height: 1.25; }
.berita-item-full p { margin: 0; color: #667085; line-height: 1.6; }
.berita-item-full a { display: inline-flex; margin-top: 10px; color: #064E3B; font-weight: 900; text-decoration: none; }
.berita-item-full a:hover { text-decoration: underline; }
.news-meta { color: #7A817C!important; font-size: .78rem; font-weight: 850; text-transform: uppercase; }
.coming-soon-view { max-width: 760px; margin: clamp(28px, 8vw, 80px) auto; text-align: center; }
.coming-soon-view h1 { font-size: clamp(2rem, 4vw, 3rem); }
.empty-state { padding: 22px; border: 1px dashed #C9D8CF; border-radius: 18px; background: #fff; color: #667085; }
@media (max-width: 1024px) { .market-sidebar { width: 200px; } .market-app-shell { margin-left: 200px; } .category-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .market-sidebar-toggle { display: none; } }
@media (max-width: 767px) { .market-mobile-menu { display: inline-flex; } .market-sidebar-toggle { display: none !important; } .market-sidebar { top: 0; width: min(82vw, 310px); z-index: 140; transform: translateX(-105%); transition: transform .22s ease; padding-top: 18px; } .market-sidebar-open .market-sidebar { transform: translateX(0); } .market-sidebar-open .market-sidebar-backdrop { display: block; } .market-app-shell { margin-left: 0; padding-top: 128px; } .spa-panel { padding: 24px 16px; } .category-grid, .metric-grid-spa, .overview-two-col, .mini-stat-grid, .mini-stat-grid.two { grid-template-columns: 1fr; } .market-tool-frame { border-radius: 16px; min-height: 1100px; } }

/* Market SPA compact polish */
.spa-panel {
  padding: 28px 34px;
}

.spa-panel h1 {
  font-size: clamp(1.65rem, 2.35vw, 2rem);
  line-height: 1.08;
  margin-bottom: 8px;
}

.view-subtitle,
.spa-panel > p:not(.eyebrow):not(.page-label) {
  font-size: 0.96rem;
  line-height: 1.5;
  margin-bottom: 0;
}

.category-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.overview-grid article {
  position: relative;
  min-height: 88px;
  padding: 14px 14px 12px;
}

.category-grid article em {
  position: absolute;
  top: 10px;
  right: 10px;
  margin: 0;
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(6, 78, 59, 0.08);
  color: #064E3B;
  font-size: 0.68rem;
  line-height: 1;
}

.category-grid article span {
  padding-right: 78px;
}

.overview-grid article strong {
  font-size: 1.02rem;
  line-height: 1.2;
}

.metric-grid-spa {
  gap: 10px;
  margin-top: 14px;
  max-width: 520px;
}

.metric-grid-spa article {
  min-height: 76px;
  padding: 12px 14px;
}

.metric-grid-spa article strong {
  font-size: 1.32rem;
}

.overview-two-col {
  gap: 12px;
  margin-top: 12px;
}

.overview-card {
  padding: 14px;
  border-radius: 18px;
}

.overview-card h2 {
  margin-bottom: 10px;
  font-size: 1.05rem;
}

.mini-stat-grid {
  gap: 8px;
}

.mini-stat-grid article {
  padding: 10px;
  border-radius: 13px;
}

.mini-stat-grid article strong {
  font-size: 1.05rem;
}

.iframe-panel {
  padding: 18px 22px;
}

.iframe-head {
  padding: 0 4px 12px;
}

.iframe-head h1 {
  font-size: clamp(1.55rem, 2.2vw, 1.9rem);
}

.market-tool-frame {
  min-height: 860px;
  border-radius: 18px;
}

.coming-soon-view {
  max-width: 480px;
  margin: 46px auto;
  padding: 26px 24px;
}

.coming-soon-icon {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  margin: 0 auto 12px;
  border-radius: 18px;
  background: rgba(245, 158, 11, 0.12);
  font-size: 1.7rem;
}

.coming-soon-view h1 {
  font-size: clamp(1.35rem, 2.2vw, 1.5rem);
  margin-bottom: 8px;
}

.coming-soon-view p:not(.eyebrow) {
  font-size: 0.94rem;
}

.berita-panel h1 {
  font-size: clamp(1.55rem, 2.4vw, 1.75rem);
}

.berita-list-full {
  gap: 10px;
  margin-top: 16px;
  max-width: 900px;
}

@media (max-width: 768px) {
  .berita-list-full {
    grid-template-columns: 1fr !important;
  }
}

.berita-item-full {
  padding: 15px 16px;
  border-radius: 17px;
}

.berita-item-full h2 {
  margin: 4px 0 6px;
  font-size: clamp(1rem, 1.45vw, 1.15rem);
}

.berita-item-full p:not(.news-meta) {
  font-size: 0.92rem;
  line-height: 1.5;
}

.berita-item-full a {
  margin-top: 7px;
  font-size: 0.9rem;
}

@media (max-width: 767px) {
  .spa-panel { padding: 22px 14px; }
  .category-grid { grid-template-columns: 1fr; }
}

/* Layout/responsiveness fixes for Market Desk SPA */
.market-spa-body,
.market-spa-body html {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

.market-spa-body .site-header {
  width: 100%;
}

.market-spa-body .navbar {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0 24px;
}

.market-spa-body .brand {
  margin-right: auto;
}

.market-spa-body .nav-links {
  margin-left: auto;
}

.market-spa-body {
  --market-sidebar-width: 220px;
  --market-sidebar-collapsed-width: 50px;
  --market-header-height: 73px;
}

.market-sidebar {
  width: var(--market-sidebar-width);
  padding: 14px 10px;
  transition: width 250ms ease, transform 250ms ease;
  box-shadow: none;
}

.market-sidebar-header {
  min-height: 46px;
  justify-content: space-between;
  gap: 6px;
  padding: 4px 4px 12px;
}

.market-sidebar-title {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 9px;
}

.market-sidebar-toggle {
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 10px;
  background: rgba(255,255,255,.08);
  color: #fff;
  cursor: pointer;
  font-size: 1rem;
  transition: background 180ms ease;
}

.market-sidebar-toggle:hover {
  background: rgba(255,255,255,.16);
}

.market-app-shell {
  width: calc(100vw - var(--market-sidebar-width));
  margin-left: var(--market-sidebar-width);
  padding-top: var(--market-header-height);
  transition: margin-left 250ms ease, width 250ms ease;
}

.market-view,
.spa-panel,
.overview-panel,
.iframe-panel,
.berita-panel {
  width: 100%;
  max-width: 100%;
}

.market-sidebar-collapsed .market-sidebar {
  width: var(--market-sidebar-collapsed-width);
  padding-left: 6px;
  padding-right: 6px;
}

.market-sidebar-collapsed .market-app-shell {
  width: calc(100vw - var(--market-sidebar-collapsed-width));
  margin-left: var(--market-sidebar-collapsed-width);
}

.market-sidebar-collapsed .market-sidebar-title strong,
.market-sidebar-collapsed .side-link,
.market-sidebar-collapsed .side-group-toggle {
  font-size: 0;
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}

.market-sidebar-collapsed .market-sidebar-header {
  display: grid;
  justify-items: center;
}

.market-sidebar-collapsed .market-sidebar-title {
  justify-content: center;
}

.market-sidebar-collapsed .market-sidebar-header img {
  display: none;
}

.market-sidebar-collapsed .market-sidebar-toggle {
  order: -1;
}

.market-sidebar-collapsed .side-link::before,
.market-sidebar-collapsed .side-group-toggle::before {
  font-size: .84rem;
  font-weight: 950;
  letter-spacing: 0;
  color: inherit;
}

.market-sidebar-collapsed .side-link[data-route="/market"]::before { content: "O"; }
.market-sidebar-collapsed .side-link[data-route="/market/rsi"]::before { content: "R"; }
.market-sidebar-collapsed .side-link[data-route="/market/technical/macd"]::before { content: "M"; }
.market-sidebar-collapsed .side-link[data-route="/market/berita"]::before { content: "B"; }
.market-sidebar-collapsed .side-link.is-soon::before { content: "•"; }
.market-sidebar-collapsed .side-group[data-group="makro"] .side-group-toggle::before { content: "M"; }
.market-sidebar-collapsed .side-group[data-group="teknikal"] .side-group-toggle::before { content: "T"; }
.market-sidebar-collapsed .side-group[data-group="fundamental"] .side-group-toggle::before { content: "F"; }
.market-sidebar-collapsed .side-group[data-group="screener"] .side-group-toggle::before { content: "S"; }
.market-sidebar-collapsed .side-group[data-group="market-data"] .side-group-toggle::before { content: "D"; }

.market-sidebar-collapsed .side-link span,
.market-sidebar-collapsed .side-group-toggle::after,
.market-sidebar-collapsed .side-submenu {
  display: none;
}

.market-tool-frame {
  width: 100%;
  max-width: 100%;
  min-height: calc(100vh - 110px);
  overflow: hidden;
}

.iframe-panel {
  overflow-x: hidden;
}

@media (min-width: 768px) and (max-width: 1024px) {
  .market-sidebar {
    width: 200px;
    min-width: 200px;
  }

  .market-sidebar-title {
    display: flex;
  }

  .market-app-shell {
    margin-left: 200px;
    width: calc(100vw - 200px);
  }

  .market-sidebar-collapsed .market-sidebar {
    width: 200px;
    min-width: 200px;
  }
}

@media (max-width: 767px) {
  .market-spa-body .navbar {
    padding: 0 14px;
  }

  .market-mobile-menu {
    top: 18px;
    right: 14px;
    left: auto;
  }

  .market-sidebar {
    top: 0;
    width: min(82vw, 310px);
    transform: translateX(-105%);
    box-shadow: 14px 0 34px rgba(0,0,0,.18);
  }

  .market-sidebar-collapsed .market-sidebar {
    width: min(82vw, 310px);
  }

  .market-sidebar-collapsed .side-link,
  .market-sidebar-collapsed .side-group-toggle {
    font-size: .83rem;
    justify-content: space-between;
    padding: .72rem .78rem;
  }

  .market-sidebar-collapsed .market-sidebar-title strong,
  .market-sidebar-collapsed .side-group-toggle {
    font-size: .72rem;
  }

  .market-sidebar-collapsed .side-link::before,
  .market-sidebar-collapsed .side-group-toggle::before {
    content: none !important;
  }

  .market-sidebar-collapsed .market-sidebar-header img,
  .market-sidebar-collapsed .side-link span,
  .market-sidebar-collapsed .side-group-toggle::after,
  .market-sidebar-collapsed .side-submenu {
    display: initial;
  }

  .market-app-shell,
  .market-sidebar-collapsed .market-app-shell {
    width: 100vw;
    margin-left: 0;
    padding-top: 128px;
  }
}

/* Prevent navbar mega submenu from creating horizontal overflow in app layout */
.market-spa-body .submenu-menu {
  left: auto;
  right: calc(100% + 8px);
}

.market-spa-body .dropdown-menu,
.market-spa-body .submenu-menu {
  max-width: calc(100vw - 24px);
}

/* Market SPA final polish: subtle scrollbars, tighter top spacing, compact cards */
.market-spa-body,
.market-app-shell,
.market-sidebar,
.market-view {
  scrollbar-width: thin;
  scrollbar-color: rgba(100, 116, 139, 0.45) transparent;
}

.market-spa-body::-webkit-scrollbar,
.market-app-shell::-webkit-scrollbar,
.market-sidebar::-webkit-scrollbar,
.market-view::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

.market-spa-body::-webkit-scrollbar-thumb,
.market-app-shell::-webkit-scrollbar-thumb,
.market-sidebar::-webkit-scrollbar-thumb,
.market-view::-webkit-scrollbar-thumb {
  background: rgba(100, 116, 139, 0.42);
  border-radius: 999px;
}

.market-spa-body::-webkit-scrollbar-track,
.market-app-shell::-webkit-scrollbar-track,
.market-sidebar::-webkit-scrollbar-track,
.market-view::-webkit-scrollbar-track {
  background: transparent;
}

.market-app-shell {
  padding-top: calc(var(--market-header-height) + 8px);
}

.spa-panel {
  padding-top: 0;
}

.metric-grid-spa {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-width: 100%;
}

.coming-soon-view {
  max-width: 400px;
  width: min(400px, 100%);
  margin: 12px auto 0;
}

.berita-panel {
  min-height: calc(100vh - var(--market-header-height) - 8px);
  background: #fff;
  padding-top: 8px;
}

@media (max-width: 1100px) {
  .metric-grid-spa {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .market-app-shell,
  .market-sidebar-collapsed .market-app-shell {
    padding-top: 104px;
  }

  .metric-grid-spa {
    grid-template-columns: 1fr;
  }
}

/* Sidebar Lucide icons */
.side-link,
.side-group-toggle {
  justify-content: flex-start;
  gap: 8px;
}

.side-link > i,
.side-group-toggle > i,
.side-link > svg,
.side-group-toggle > svg {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  color: currentColor;
  stroke-width: 2.2;
}

.side-label {
  min-width: 0;
  flex: 1 1 auto;
}

.side-group-toggle::after {
  margin-left: auto;
}

.side-link span:not(.side-label) {
  margin-left: auto;
}

.market-sidebar-collapsed .market-sidebar-title strong {
  display: none;
}

.market-sidebar-collapsed .side-link,
.market-sidebar-collapsed .side-group-toggle {
  position: relative;
  justify-content: center;
  gap: 0;
}

.market-sidebar-collapsed .side-label,
.market-sidebar-collapsed .side-link span:not(.side-label) {
  display: none;
}

.market-sidebar-collapsed .side-link > i,
.market-sidebar-collapsed .side-group-toggle > i,
.market-sidebar-collapsed .side-link > svg,
.market-sidebar-collapsed .side-group-toggle > svg {
  width: 18px;
  height: 18px;
  flex-basis: 18px;
}

.market-sidebar-collapsed .side-link::before,
.market-sidebar-collapsed .side-group-toggle::before {
  content: none !important;
}

.market-sidebar-collapsed .side-link:hover::after,
.market-sidebar-collapsed .side-group-toggle:hover::after {
  content: attr(title);
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  z-index: 200;
  white-space: nowrap;
  padding: 6px 9px;
  border-radius: 8px;
  background: #0F172A;
  color: #fff;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: none;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.24);
}

.market-sidebar-collapsed .side-group-toggle:hover::after {
  margin-left: 0;
}

@media (max-width: 767px) {
  .market-sidebar-collapsed .side-label,
  .market-sidebar-collapsed .side-link span:not(.side-label),
  .market-sidebar-collapsed .market-sidebar-title strong {
    display: inline;
  }

  .market-sidebar-collapsed .side-link,
  .market-sidebar-collapsed .side-group-toggle {
    justify-content: flex-start;
    gap: 8px;
  }

  .market-sidebar-collapsed .side-link > i,
  .market-sidebar-collapsed .side-group-toggle > i,
  .market-sidebar-collapsed .side-link > svg,
  .market-sidebar-collapsed .side-group-toggle > svg {
    width: 16px;
    height: 16px;
    flex-basis: 16px;
  }

  .market-sidebar-collapsed .side-link:hover::after,
  .market-sidebar-collapsed .side-group-toggle:hover::after {
    content: none;
  }
}

/* Sidebar item normalization: single links and collapsible categories use identical styling */
.market-side-nav .side-link,
.market-side-nav .side-group-toggle,
.market-side-nav .side-submenu .side-link {
  min-height: 40px;
  padding: 0.68rem 0.78rem;
  border-radius: 11px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.83rem;
  font-weight: 850;
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: none;
}

.market-side-nav .side-group-toggle {
  color: rgba(255, 255, 255, 0.86);
}

.market-side-nav .side-link:hover,
.market-side-nav .side-group-toggle:hover {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
}

.market-side-nav .side-link.is-active {
  background: #043828;
  color: #fff;
  font-weight: 850;
}

.market-side-nav .side-link.is-active:hover {
  background: #043828;
}

.market-side-nav .side-submenu .side-link {
  padding-left: 2rem;
}

.market-side-nav .side-link.is-soon {
  opacity: 0.5;
}

.market-side-nav .side-label {
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
}

.market-side-nav .side-link span:not(.side-label) {
  font-size: 0.62rem;
  font-weight: 850;
}

.market-sidebar-collapsed .market-side-nav .side-link,
.market-sidebar-collapsed .market-side-nav .side-group-toggle {
  min-height: 40px;
  padding: 0;
}

/* Bahasa + sidebar consistency pass */
.market-side-nav {
  gap: 5px;
}

.market-side-nav .side-group {
  display: grid;
  gap: 5px;
}

.market-side-nav .side-link,
.market-side-nav .side-group-toggle,
.market-side-nav .side-submenu .side-link {
  min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 0.62rem 0.72rem;
  border-radius: 10px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.83rem;
  font-weight: 820;
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: none;
  background: transparent;
}

.market-side-nav .side-group-toggle {
  color: rgba(255, 255, 255, 0.86);
}

.market-side-nav .side-link > svg,
.market-side-nav .side-group-toggle > svg,
.market-side-nav .side-link > i,
.market-side-nav .side-group-toggle > i {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  align-self: center;
  color: currentColor;
}

.market-side-nav .side-label {
  flex: 1 1 auto;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

.market-side-nav .side-link:hover,
.market-side-nav .side-group-toggle:hover {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
}

.market-side-nav .side-link.is-active,
.market-side-nav .side-link.is-active:hover {
  background: #043828;
  color: #fff;
  font-weight: 820;
}

.market-side-nav .side-submenu {
  gap: 5px;
}

.market-side-nav .side-submenu .side-link {
  padding-left: 12px;
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.78rem;
  font-weight: 760;
}

.market-side-nav .side-submenu .side-link:hover {
  color: #fff;
}

.market-side-nav .side-link.is-soon {
  opacity: 0.5;
}

.market-side-nav .side-link span:not(.side-label) {
  margin-left: auto;
  padding: 2px 6px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.24);
  font-size: 0.58rem;
  font-weight: 820;
  line-height: 1.2;
  text-transform: uppercase;
}

.market-side-nav .side-group-toggle::after {
  margin-left: auto;
  opacity: 0.72;
}

.market-sidebar-collapsed .market-side-nav .side-link,
.market-sidebar-collapsed .market-side-nav .side-group-toggle {
  justify-content: center;
  padding: 0;
  gap: 0;
}

.market-sidebar-collapsed .market-side-nav .side-submenu {
  display: none;
}

/* Sidebar badge and active-state final fix */
.market-side-nav .side-link span:not(.side-label) {
  white-space: nowrap;
  flex: 0 0 auto;
  padding: 2px 6px;
  border: 0;
  border-radius: 4px;
  background: #F59E0B;
  color: #fff;
  font-size: 9px;
  font-weight: 800;
  line-height: 1.15;
  text-transform: uppercase;
}

.market-side-nav .side-link:not(.is-active),
.market-side-nav .side-link:not(.is-active):visited,
.market-side-nav .side-link:not(.is-active):focus:not(:hover),
.market-side-nav .side-group-toggle:not(:hover) {
  background: transparent;
}

.market-side-nav .side-link.is-active,
.market-side-nav .side-link.is-active:hover,
.market-side-nav .side-link.is-active:focus {
  background: #043828;
  color: #fff;
}

.market-side-nav .side-link[data-route="/market"]:not(.is-active),
.market-side-nav .side-link[data-route="/market/berita"]:not(.is-active) {
  background: transparent;
  color: rgba(255, 255, 255, 0.86);
  font-weight: 820;
}

/* Final: Ringkasan/Berita Pasar default exactly like other level-1 items */
.market-side-nav > .side-link[data-route="/market"]:not(.is-active),
.market-side-nav > .side-link[data-route="/market/berita"]:not(.is-active) {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  color: rgba(255, 255, 255, 0.86) !important;
}

.market-side-nav > .side-link[data-route="/market"]:not(.is-active):hover,
.market-side-nav > .side-link[data-route="/market/berita"]:not(.is-active):hover {
  background: rgba(255, 255, 255, 0.10) !important;
  color: #fff !important;
}

.market-side-nav > .side-link[data-route="/market"].is-active,
.market-side-nav > .side-link[data-route="/market/berita"].is-active {
  background: #043828 !important;
  color: #fff !important;
}

#panel-rsi-heatmap {
  overflow: hidden;
  height: calc(100vh - 73px);
  margin: 0;
  padding: 0;
}

.market-app-shell:has(#panel-rsi-heatmap) {
  padding-top: 0;
}

.market-app-shell:has(#panel-macd-scatter) {
  background: #fff;
  padding-top: 0;
}

.market-app-shell:has(.berita-panel) {
  background: #fff;
  padding-top: calc(var(--market-header-height) - 58px);
}

.market-app-shell.panel-fullscreen {
  padding-top: 0;
}

/* Shared technical chip controls */
.universe-btn { border:1.5px solid #064E3B; border-radius:999px; padding:.45rem .9rem; background:#fff; color:#064E3B; font:inherit; font-size:.85rem; font-weight:700; cursor:pointer; transition:.2s ease; white-space:nowrap; flex-shrink:0; }
.universe-btn.active { background:#064E3B; color:#fff; }

.signal-chip-row { display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:nowrap; overflow-x:auto; background:#fff; border:.5px solid #e5e7eb; border-radius:12px; padding:9px 14px; margin:0 0 14px; }
.signal-chip-row::-webkit-scrollbar { display:none; }
.signal-chip-row { -ms-overflow-style:none; scrollbar-width:none; }
.signal-chip-row .chip-label { font-size:10px; font-weight:700; color:#6B7280; text-transform:uppercase; letter-spacing:.06em; flex-shrink:0; }
.signal-chip { display:inline-flex; align-items:center; gap:5px; padding:4px 10px; border-radius:999px; border:.5px solid #e5e7eb; background:#fff; font-size:11px; font-weight:700; cursor:pointer; color:#6B7280; white-space:nowrap; flex-shrink:0; font-family:inherit; transition:.15s ease; }
.signal-chip:hover { transform:translateY(-1px); }
.signal-chip .chip-dot { width:7px; height:7px; border-radius:50%; display:inline-block; flex-shrink:0; }
.signal-chip .chip-count { font-size:10px; margin-left:2px; }
.signal-chip.is-active { color:#fff; }
.signal-chip.is-active .chip-dot { background:#fff!important; }

.periode-row { display:flex; align-items:center; gap:8px; margin:.5rem 0 .25rem; }
.periode-row .label { font-size:10px; font-weight:700; color:#6B7280; text-transform:uppercase; letter-spacing:.06em; }
.periode-wrap { display:inline-flex; padding:3px; border:.5px solid #e5e7eb; border-radius:999px; background:#F9FAFB; }
.periode-btn { border:0; background:transparent; color:#9CA3AF; font-family:inherit; font-size:11px; font-weight:700; padding:4px 12px; border-radius:999px; cursor:pointer; }
.periode-btn.active { background:#064E3B; color:#fff; }
.periode-btn:disabled { cursor:not-allowed; font-style:italic; }
