:root {
  --bg-color: #f9f9f9;
  --card-bg: #ffffff;
  --text-color: #000000;
  --muted-text: #777;
  --label-color: #000;
}

body.dark {
  --bg-color: #121212;
  --card-bg: #1e1e1e;
  --text-color: #f1f1f1;
  --muted-text: #aaa;
  --label-color: #fff;
}

body {
  margin: 0;
  padding: 0;
  font-family: sans-serif;
  background: var(--bg-color);
  color: var(--text-color);
  height: 100vh;
  display: flex;
  flex-direction: column;
  overflow: auto; /* ✅ statt hidden */
}


/* 🔝 Topbar */
.topbar {
  height: 80px;
  background: var(--bg-color);
  border-bottom: 1px solid var(--muted-text);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
}

.topbar a {
  text-decoration: none;
  border: none;
  outline: none;
  color: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.2rem;
}

#themeToggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.2rem;
  cursor: pointer;
}
#themeIcon {
  height: 24px;
  vertical-align: middle;
}


/* 📦 Hauptlayout */
.main-layout {
  padding-top: 70px;
	display: flex;
  flex-direction: row;
  flex-grow: 1;
  min-height: 0; /* wichtig für flexbox */
  overflow: auto; /* oder nur x/ y je nach Layout */
}



/* 📊 Sidebar */
.price-list {
  margin-top: 12px;
	width: 220px;
  background: var(--card-bg);
  border-right: 1px solid var(--muted-text);
  overflow-y: auto;
  padding: 0.5rem;
  font-family: monospace;
  font-size: 0.9rem;
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  gap: 0.0rem;
}

.price-item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.1rem 0.2rem;
  border-radius: 6px;
  color: var(--text-color);
  text-decoration: none;
  transition: background 0.2s ease;
	font-size: 0.85rem;     /* optional: leicht kleiner machen */

}

.price-item:hover {
  background-color: rgba(255, 255, 255, 0.05);
}

.price-item img {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--card-bg);
  padding: 1px;
  object-fit: contain;
}

/* 📄 Hauptinhalt */
/* Hauptinhalt rechts neben der Sidebar */
#main-content {
  flex-grow: 1;
  min-width: 0;
  overflow-y: auto;
  height: 100%;
  padding: 1rem;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 0 !important;
}

#main-content .price-list {
  display: none !important;
}


/* 📦 Signalkarten */
.signal-card {
  background: var(--card-bg);
  border-radius: 10px;
  padding: 1rem;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
  max-width: 520px;
  width: 100%;
  margin: 0 auto 0.9rem auto;
}

.signal-card .card-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 0.5rem;
}

.signal-card .logo {
  width: 32px;
  height: 32px;
  object-fit: contain;
  border-radius: 50%;
  background: transparent;
}

.signal-card .pair {
  font-weight: bold;
  font-size: 1.1rem;
}

.signal-card .timestamp {
  font-size: 0.8rem;
  color: var(--muted-text);
}

.signal-card .card-details {
  font-family: 'Fira Code', monospace;
  font-size: 0.9rem;
  display: grid;
  grid-template-columns: 1.7fr 0.3fr;
  gap: 0.3rem 1.5rem;
}

.signal-card .status {
  margin-top: 0.5rem;
  font-weight: bold;
  font-size: 0.9rem;
}

.signal-card.profit {
  border: 2px solid #2ecc71;
}

.signal-card.loss {
  border: 2px solid #e74c3c;
}

/* 🎛️ Buttons */
.button {
  padding: 0.45rem 1rem;
  background: linear-gradient(135deg, #0077cc, #005fa3);
  color: white;
  border: none;
  border-radius: 6px;
  font-size: 0.9rem;
  font-weight: bold;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
}

.button:hover {
  background: linear-gradient(135deg, #005fa3, #004b89);
}

.button.cancel,
.button.marketclose {
  background: #e74c3c;
}

.button.cancel:hover,
.button.marketclose:hover {
  background: #c0392b;
}

/* ☀️ Theme Toggle */
.theme-toggle {
  cursor: pointer;
}

.logo-pair {
  position: relative;
  width: 40px;
  height: 28px;
}

.logo-pair img {
  position: absolute;
  border-radius: 50%;
}

.logo-pair .base {
  width: 28px;
  height: 28px;
  left: 0;
  z-index: 2;
  background: var(--card-bg);
  padding: 2px;
}

.logo-pair .quote {
  width: 20px;
  height: 20px;
  left: 24px;
  top: 8px;
  z-index: 1;
}

/* 📱 Responsiv */
@media (max-width: 768px) {
  .main-layout {
    flex-direction: column;
  }

  .price-list {
    width: 100%;
    flex-direction: row;
    flex-wrap: wrap;
    max-height: 70px;
    overflow-y: auto;
    border-right: none;
    border-bottom: 1px solid var(--muted-text);
  }


  .topbar {
    flex-direction: column;
    align-items: flex-start;
    height: auto;
    padding: 0.5rem 1rem;
    gap: 0.5rem;
  }
}


.signal-card {
background: var(--card-bg);
border-radius: 10px;
padding: 1rem;
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
max-width: 520px;
width: 100%;
text-align: left;
margin: 0 auto 0.9rem auto; /* ⬅️ Abstand nach unten */

}


.signal-card .card-header {
display: flex;
align-items: center;
gap: 1rem;
margin-bottom: 0.5rem;
}

.signal-card .logo {
width: 32px;
height: 32px;
object-fit: contain;
background: transparent;
border-radius: 50%;
}

.signal-card .pair {
font-weight: bold;
font-size: 1.1rem;
}

.signal-card .timestamp {
font-size: 0.8rem;
color: var(--muted-text);
}

.signal-card .card-details {
font-family: 'Fira Code', monospace;
font-size: 0.9rem;
margin-bottom: 0.5rem;
display: grid;
grid-template-columns: 1.7fr 0.3fr;
gap: 0.3rem 1.5rem;
} 

.signal-card .card-details strong {
color: var(--label-color);
font-weight: 600;
}

.signal-card .status {
font-size: 0.9rem;
font-weight: bold;
margin-top: 0.5rem;
}

.signal-card.profit {
border: 2px solid #2ecc71;
}

.signal-card.loss {
border: 2px solid #e74c3c;
}

.button {
padding: 0.45rem 1rem;
background: linear-gradient(135deg, #0077cc, #005fa3);
color: white;
border: none;
border-radius: 6px;
font-size: 0.9rem;
font-weight: bold;
cursor: pointer;
display: inline-flex;
align-items: center;
gap: 0.5rem;
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.15);
transition: background 0.2s ease;
}

.button:hover {
background: linear-gradient(135deg, #005fa3, #004b89);
}

.button img {
height: 16px;
width: 16px;
}

.signal-card .button.cancel,
.signal-card .button.marketclose {
background: #e74c3c;
}

.signal-card .button.cancel:hover,
.signal-card .button.marketclose:hover {
background: #c0392b;
}

.icon.theme-toggle {
cursor: pointer;
font-size: 1.4rem;
}

.logo-pair {
position: relative;
width: 40px;
height: 28px;
}

.logo-pair img {
border-radius: 50%;
position: absolute;
top: 0;
}

.logo-pair .base {
width: 28px;
height: 28px;
left: 0;
z-index: 2;
background-color: var(--card-bg);
padding: 2px;
}

.logo-pair .quote {
width: 20px;
height: 20px;
left: 24px;
top: 8px;
z-index: 1;
}

.filterbar {
  padding: 0.3rem 0;
  background: var(--bg-color);
  border-bottom: 1px solid var(--muted-text);
  z-index: 9;
  width: 100%;
}

.filterbar select,
.filterbar input {
  padding: 0.3rem;
  font-size: 0.85rem;
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  align-items: center;
}
#filterWrapper {
  margin-bottom: 0.5rem; /* kleiner Abstand zum Inhalt */
}

#filterToggleBtn {
  margin: 0.5rem auto;
  padding: 0.3rem 0.6rem;
  font-size: 0.85rem;
}

.filterbar {
  padding: 0.3rem 0;
  background: var(--bg-color);
  border-bottom: 1px solid var(--muted-text);
  width: 100%;
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}


textarea#importText,
textarea#signalText {
  width: 100%;
  height: 300px; /* oder mehr, z. B. 400px */
  font-family: monospace;
  font-size: 0.95rem;
  padding: 1rem;
  border-radius: 6px;
  border: 1px solid var(--border-light, #ccc);
  resize: vertical;
  background: var(--box-light, #fff);
  color: var(--text-light, #000);
}

body.dark textarea#importText,
body.dark textarea#signalText {
  border-color: var(--border-dark, #444);
  background: var(--box-dark, #1e1e1e);
  color: var(--text-dark, #f1f1f1);
}

.asset-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
	gap: 1rem;
	margin-bottom: 2rem;
	padding: 0 1rem;
}

.asset-button {
	position: relative;
	background: var(--card-bg);
	border: 1px solid var(--border-color);
	border-radius: 8px;
	padding: 0.3rem;
	cursor: pointer;
	text-align: center;
	font-size: 0.85rem;
	height: 90px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	transition: transform 0.15s;
}

.asset-button:hover {
	transform: scale(1.03);
}

.asset-button.disabled {
	pointer-events: none;
	opacity: 0.5;
	cursor: not-allowed;
}

.logo-pair {
	position: relative;
	width: 44px;
	height: 34px;
	margin-top: 4px;
	margin-bottom: 2px;
}

.logo-pair img {
	border-radius: 50%;
	position: absolute;
	top: 0;
	object-fit: contain;
}

.logo-pair img.base {
	width: 36px;
	height: 36px;
	left: 0;
	z-index: 2;
	background-color: var(--card-bg);
	padding: 2px;
}

.logo-pair img.quote {
	width: 22px;
	height: 22px;
	left: 28px;
	top: 10px;
	z-index: 1;
	padding: 1px;
}

.loading {
	position: absolute;
	top: -8px;
	left: 18px;
	width: 22px;
	height: 22px;
	z-index: 10;
}

.signal-list {
  padding-top: 70px;
	display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 1rem;
  width: 100%;
  padding: 0 1rem 2rem 1rem;  /* ⬅️ links/rechts 1rem Abstand */
  box-sizing: border-box;
}

.filter-bar {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 10px 0;
  padding: 8px;
}

.filter-select, .filter-input {
  padding: 6px 10px;
  font-family: 'Fira Code', monospace;
  border: 1px solid var(--border-color);
  border-radius: 4px;
  background: var(--background-secondary);
  color: var(--text-color);
}

#filterBar select,
#filterBar input {
  padding: 6px;
  font-size: 14px;
  border-radius: 4px;
  border: 1px solid #ccc;
}
