/* Smooth horizontal scrolling for update message */
.marquee-pill {
  overflow: hidden;
  position: relative;
  max-width: 100%;
  display: block;
}
.scrolling-update-text {
  display: inline-block;
  white-space: nowrap;
  animation: scroll-update 32s linear infinite;
  font-size: 1em;
  padding-left: 100%;
  box-sizing: border-box;
}
@keyframes scroll-update {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}
@media (max-width: 600px) {
  .app {
    display: block;
    padding: 2px;
  }
  header {
    position: static;
    padding: 6px 2px;
    font-size: 14px;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    min-height: 40px;
    height: auto;
    border-radius: 6px;
  }
  .mode-select {
    padding: 10px 2px;
    border-radius: 6px;
  }
  .col {
    min-height: 80px;
    border-radius: 6px;
    padding: 2px;
    margin-bottom: 8px;
  }
  .center .panel, .panel {
    padding: 4px 2px;
    font-size: 12px;
    border-radius: 6px;
  }
  .search input, .search button {
    font-size: 13px;
    padding: 6px 2px;
  }
  .items {
    max-height: 180px;
    font-size: 12px;
  }
  .item {
    padding: 6px 2px;
    font-size: 12px;
  }
  .item img {
    width: 16px;
    height: 16px;
  }
  .holdings {
    max-height: 120px;
    overflow-y: auto;
  }
  table th, table td {
    padding: 4px 2px;
    font-size: 11px;
  }
  .footer {
    font-size: 10px;
    padding: 4px 1px;
  }
  h1 {
    font-size: 15px;
  }
  .pill, .sub, .switch {
    font-size: 11px;
  }
  .trade input, .btn {
    font-size: 12px;
    padding: 6px 2px;
    min-height: 38px;
  }
  .grid {
    gap: 4px;
    grid-template-columns: 1fr;
  }
  .metric {
    padding: 4px;
    font-size: 11px;
    border-radius: 4px;
  }
  .panel[style*="max-height"] {
    max-height: 180px !important;
  }
  #settingsModal {
    align-items: flex-start !important;
    justify-content: flex-start !important;
    padding: 0 !important;
  }
  #settingsModal > div {
    min-width: 0 !important;
    width: 98vw !important;
    padding: 10px 4px !important;
    border-radius: 8px !important;
    box-shadow: none !important;
  }
  #removeSaveConfirm {
    font-size: 0.95em;
    padding: 6px;
  }
  #confirmRemoveSaveBtn {
    font-size: 0.95em;
    padding: 6px;
  }
}
/* Remove Save Confirmation Styles */
#removeSaveConfirm {
  width: 100%;
  margin-bottom: 12px;
  display: none;
}
#confirmRemoveSaveBtn {
  display: none;
  margin-bottom: 12px;
}
/* Moved from inline styles in index.html */
.mt10 { margin-top: 10px; }
.h3panel { margin: 0 0 8px; font-size: 14px; font-weight: 600; }
 :root{
      --bg:#0f1115; --panel:#151922; --muted:#8b95a7; --text:#e6e9ef; --accent:#6ee7ff; --accent2:#a78bfa; --danger:#ef4444; --good:#22c55e; --card:#0b0e13; --chip:#1f2430;
    }
    *{box-sizing:border-box}
    html,body{height:100%}
    body{margin:0;background:linear-gradient(180deg,#0b0e13,#0f1115 20%,#0f1115);color:var(--text);font:14px/1.4 'Spectral',serif}
    a{color:var(--accent)}
    .app {
      display: grid;
      grid-template-columns: 320px 1fr 360px;
      gap: 12px;
      min-height: 100vh;
      padding: 12px;
    }
    header {
      grid-column: 1/4;
      display: flex;
      align-items: center;
      gap: 16px;
      background: var(--panel);
      border: 1px solid #1e2430;
      border-radius: 14px;
      padding: 10px 14px;
      box-shadow: 0 6px 24px rgba(0,0,0,.3);
      min-width: 0;
      max-width: 100vw;
      min-height: 60px;
      height: 60px;
      margin-bottom: 0;
      white-space: nowrap;
      text-overflow: ellipsis;
      word-break: break-word;
      visibility: visible;
      justify-content: flex-start;
      flex-shrink: 0;
      flex-grow: 0;
      overflow: hidden;
      position: sticky;
      top: 0;
      z-index: 100;
    }
    header h1{font-size:18px;margin:0 6px 0 0;letter-spacing:.2px;font-weight:700}
    header .sub{color:var(--muted);font-size:12px}
    .pill{background:var(--chip);border:1px solid #242b38;border-radius:999px;padding:6px 10px;color:#cbd5e1;font-size:12px}
    .mode-select{grid-column:1/4;background:var(--panel);border:1px solid #1e2430;border-radius:14px;padding:24px;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.25)}
    .mode-select h2{margin:0 0 8px;font-size:24px;font-weight:700}
    .mode-select p{color:var(--muted);margin:0 0 24px}
    .mode-btns{display:flex;gap:16px;justify-content:center}
    .mode-btn{background:linear-gradient(135deg,#1a1f2e,#242b38);border:2px solid #2a3340;border-radius:12px;padding:20px 32px;cursor:pointer;transition:all .3s;color:var(--text)}
    .mode-btn:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 24px rgba(110,231,255,.2)}
    .mode-btn .title{font-size:18px;font-weight:700;margin-bottom:6px}
    .mode-btn .desc{font-size:13px;color:var(--muted)}
    .col{background:var(--panel);border:1px solid #1e2430;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.25);min-height:200px}
    .col {
      min-height: 200px;
    }
    .col h2{margin:0;padding:12px 14px;border-bottom:1px solid #202636;font-size:13px;color:#cbd5e1;display:flex;align-items:center;gap:10px;font-weight:600}
    .left{overflow:auto}
    .left {
      min-height: 400px;
    }
    .search{padding:10px 12px;border-bottom:1px solid #202636;display:flex;gap:8px}
    .search input{flex:1;background:#0d1016;border:1px solid #202636;border-radius:10px;padding:10px;color:#e5e7eb;font-family:'Spectral',serif}
    .search input::placeholder{color:#6b7280}
    .search button{background:#0d1016;border:1px solid #202636;border-radius:10px;padding:10px 12px;color:#cbd5e1;cursor:pointer;font-family:'Spectral',serif;transition:all .2s}
    .search button:hover{background:#151922;border-color:#2a3340}
    .items{max-height:calc(100vh - 220px);overflow:auto}
    .item{display:flex;gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid #202636;cursor:pointer;transition:all .2s}
    .item:hover{background:#131827}
    .item img{width:24px;height:24px;image-rendering:pixelated}
    .item .name{font-weight:600}
    .item .sub{font-size:12px;color:var(--muted)}
    .center{padding:0 0 10px}
    .center .panel{padding:12px 14px}
    .center {
      min-height: 400px;
    }
    .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
    .metric{background:var(--card);border:1px solid #1c2130;border-radius:12px;padding:10px}
    .metric .label{font-size:12px;color:#a6b0c2}
    .metric .value{font-size:18px;font-weight:700}
    .trade{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
    .trade input{width:100%;padding:10px;border-radius:10px;border:1px solid #202636;background:#0d1016;color:#e5e7eb;font-family:'Spectral',serif}
    .btn{padding:10px 12px;border-radius:10px;border:1px solid #202636;background:#0d1016;color:#e7e9eb;cursor:pointer;font-family:'Spectral',serif;transition:all .2s;font-weight:600}
    .btn:hover{background:#151922}
    .btn.buy{border-color:#1f3b2a;background:linear-gradient(135deg,#1a3025,#1f3b2a)}
    .btn.buy:hover{border-color:var(--good);box-shadow:0 4px 12px rgba(34,197,94,.2)}
    .btn.sell{border-color:#3a2020;background:linear-gradient(135deg,#3a2020,#4a2828)}
    .btn.sell:hover{border-color:var(--danger);box-shadow:0 4px 12px rgba(239,68,68,.2)}
    .btn.primary{background:linear-gradient(90deg,var(--accent),var(--accent2));color:#0b0e13;font-weight:700;border:none}
    .right{padding-bottom:10px}
    .right {
      min-height: 400px;
    }
    .holdings{max-height:calc(100vh - 300px);overflow:hidden;position:relative}
    .holdings table{position:relative;z-index:1}
    table{width:100%;border-collapse:collapse}
    th,td{padding:8px 10px;border-bottom:1px solid #202636;text-align:left;font-size:13px}
    th{position:sticky;top:0;background:#121723;z-index:1;font-weight:600}
    .profit-pos{color:var(--good)}
    .profit-neg{color:var(--danger)}
    .badge{font-size:11px;background:#0e131e;border:1px solid #243049;padding:2px 6px;border-radius:6px;color:#9fb8ff}
    .footer{grid-column:1/4;color:var(--muted);font-size:12px;padding:10px 2px}
    .muted{color:var(--muted)}
    .switch{display:inline-flex;align-items:center;gap:8px}
    .switch input{accent-color:var(--accent)}
    .small{font-size:12px}
    .warn{color:#ffb86b}
    .flex{display:flex;gap:10px;align-items:center}
    .icon{width:32px;height:32px;image-rendering:pixelated}
    .hidden{display:none}
    .tooltip{position:relative;cursor:help;border-bottom:1px dotted var(--muted);display:inline-block}
    .tooltip .tooltiptext{
      visibility: hidden;
      width: 220px;
      background: #1a1f2e;
      color: #e6e9ef;
      text-align: left;
      border-radius: 8px;
      padding: 10px;
      position: absolute;
      z-index: 99999;
      bottom: 125%;
      left: 50%;
      margin-left: -110px;
      opacity: 0;
      transition: opacity .3s;
      border: 1px solid #2a3340;
      font-size: 12px;
      line-height: 1.5;
      box-shadow: 0 4px 12px rgba(0,0,0,.5);
      pointer-events: none;
    }
    th {
      overflow: visible;
    }
    .tooltip .tooltiptext::after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:#1a1f2e transparent transparent transparent}
    .tooltip:hover .tooltiptext{visibility:visible;opacity:1}
    th.tooltip{border-bottom:1px solid #202636}
    /* Add visual feedback for clickable rows in Holdings panel */
.holdings table tbody tr {
  cursor: pointer;
  transition: background-color 0.2s;
}
.holdings table tbody tr:hover {
  background-color: var(--panel);
}
    @media (max-width: 1200px){
      .app{grid-template-columns:1fr;gap:12px}
      header{grid-column:1}
      .mode-select{grid-column:1}
      .footer{grid-column:1}
      .mode-btns{flex-direction:column}
      header {
        max-width: 100vw;
        min-width: 0;
        height: 60px;
        min-height: 60px;
        padding: 10px 8px;
      }
    }
    @media (max-width: 800px) {
      .app {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto auto auto;
        gap: 8px;
        padding: 4px;
      }
      header {
        grid-column: 1;
        height: auto;
        min-height: 48px;
        padding: 8px 4px;
        font-size: 15px;
        flex-wrap: wrap;
      }
      .mode-select {
        grid-column: 1;
        padding: 16px 4px;
      }
      .col {
        min-height: 120px;
        border-radius: 8px;
        padding: 4px;
        box-shadow: none;
      }
      .left, .center, .right {
        min-height: 120px;
        padding-bottom: 4px;
      }
      .center .panel, .panel {
        padding: 8px 4px;
        font-size: 13px;
        border-radius: 8px;
        box-shadow: none;
      }
      .search input, .search button {
        font-size: 14px;
        padding: 8px 4px;
      }
      .items {
        max-height: 300px;
        font-size: 13px;
      }
      .item {
        padding: 8px 4px;
        font-size: 13px;
      }
      .item img {
        width: 20px;
        height: 20px;
      }
      .holdings {
        max-height: 200px;
        overflow-y: auto;
      }
      table th, table td {
        padding: 6px 4px;
        font-size: 12px;
      }
      .footer {
        font-size: 11px;
        padding: 6px 2px;
      }
      h1 {
        font-size: 17px;
      }
      .pill, .sub, .switch {
        font-size: 12px;
      }
      .trade input, .btn {
        font-size: 13px;
        padding: 8px 4px;
      }
      .grid {
        gap: 6px;
      }
      .metric {
        padding: 6px;
        font-size: 12px;
        border-radius: 6px;
      }
      .panel[style*="max-height"] {
        max-height: 300px !important;
      }
    }
    .info-message {
      color: #ffd700 !important;
      font-size: 1.25em;
      font-weight: bold;
      margin-bottom: 16px;
    }
    .cooldown-msg {
      display: none;
      margin-top: 8px;
      text-align: center;
      font-size: 1.1em;
      color: #fff;
      font-weight: bold;
    }
    .music-toggle-label {
      display: block;
      margin-bottom: 12px;
      font-weight: bold;
      color: #fff;
    }
    #removeSaveConfirm {
      width: 100%;
      margin-bottom: 12px;
      padding: 8px;
      border-radius: 6px;
      border: 1px solid #ffd700;
      font-size: 1em;
    }