:root {
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #111;
}

body { margin: 0; background: #f5f5f5; font-family: Roboto;
  font-weight: 300;
  font-style: normal; }
  
 body strong {font-family: Roboto; font-weight: 900;}

.app { max-width: 1150px; margin: 0 auto; padding: 16px; }

.header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

h1 { margin: 0 0 6px 0; font-size: 22px; color:#111; font-family: 'Outfit', sans-serif; }
h2 { margin: 10px 0 10px 0; font-size: 16px; font-family: 'Outfit', sans-serif;}
.sub { margin: 0; opacity: 0.75; }

.meta { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.pill {
  padding: 6px 10px;
  border: 1px solid #efefef;
  border-radius: 999px;
  background: #fff;
  font-size: 13px;
}

.layout {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 16px;
  margin-top: 16px;
}

.panel {
  border: 1px solid #e3e3e3;
  background: #fff;
  border-radius: 5px;
  padding: 4px 14px 14px 14px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}

.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
label { display: grid; gap: 6px; font-size: 13px; }
input, select {
  padding: 10px;
  border-radius: 10px;
  border: 1px solid #ddd;
  background: #fff;
  font-size: 14px;
}

hr { border: none; border-top: 1px solid #eee; margin: 14px 0; }

.hint { font-size: 12px; opacity: 0.75; margin-bottom: 10px; }

.allocator { display: grid; gap: 10px; }

.alloc-row {
  display: grid;
  grid-template-columns: 28px 1fr 60px 90px;
  gap: 10px;
  align-items: center;
}

.icon {
  width: 28px; height: 28px;
  border-radius: 10px;
  background: #f2f2f2;
  border: 1px solid #e6e6e6;
  display: grid;
  place-items: center;
  font-size: 14px;
}

.range { width: 100%; }
.pct { text-align: right; font-variant-numeric: tabular-nums; }
.money { text-align: right; font-variant-numeric: tabular-nums; opacity: 0.8; font-size: 13px; }

.alloc-meta { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-top: 10px; flex-wrap: wrap; }

.controls { display: flex; gap: 8px; flex-wrap: wrap; }
.btn {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid #d0d0d0;
  background: #f6f6f6;
  cursor: pointer;
  font-size: 14px;
}
.btn.primary { background: darkgreen; color: #fff; border-color: #111; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.card {
  border: 1px solid #eee;
  background: #fafafa;
  border-radius: 5px;
  padding: 12px;
  min-height: 86px;
}
.card.small { min-height: unset; }

.split { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 12px; margin-top: 12px; }

.table { display: grid; gap: 6px; }
.row {
  display: grid;
  grid-template-columns: 1fr 90px 90px 220px;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid #eee;
  border-radius: 5px;
  background: #fff;
  font-size: 13px;
}

.row strong { font-weight: 600; }
.right { text-align: right; font-variant-numeric: tabular-nums; }

.log {
  border: 1px solid #eee;
  border-radius: 5px;
  background: #fff;
  padding: 10px;
  max-height: 150px;
  overflow: auto;
  display: grid;
  gap: 8px;
  font-size: 13px;
}
.log-item { border-bottom: 1px dashed #eee; padding-bottom: 8px; }
.log-item:last-child { border-bottom: none; padding-bottom: 0; }

.legal { margin: 12px 0 0; font-size: 12px; opacity: 0.7; }

.trade {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  align-items: center;
}

.trade input {
  width: 90px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid #ddd;
  font-size: 13px;
}

.btn.small {
  padding: 8px 10px;
  border-radius: 10px;
  font-size: 13px;
}
.up { background: #0b5f2a; color:white; }     /* dark green */
.down { background: #7a0b0b; color:white; }   /* dark red */
.row {
  align-items: center;
}
.row > * { min-width: 0; }

#ui-regime {font-size:12px; line-height:16px;}


@media (max-width: 920px) {
  .layout { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .split { grid-template-columns: 1fr; }
  .trade {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 6px;
  }
  .trade input[type="number"] {
    width: 90px;
  }
   .trade {
    justify-self: end;
    text-align: right;
  }

  .trade input {
    width: 80px;
  }

}
