/* Cardmarket Bot — global stylesheet
 * Extracted from templates/base.html so the same rules are shared across
 * every page (login included) and the browser can cache one file.
 */
:root { color-scheme: dark; }

body {
  font-family: system-ui, sans-serif;
  background: #14161a; color: #e6e6e6;
  margin: 0; padding: 0;
}

header {
  background: #1c1f25; padding: 12px 20px;
  border-bottom: 1px solid #2a2e36;
  display: flex; align-items: center; gap: 18px;
}
header a { color: #e6e6e6; text-decoration: none; font-weight: 600; }
header a.active { color: #4fb1ff; }

main { max-width: 1100px; margin: 0 auto; padding: 20px; }

table { border-collapse: collapse; width: 100%; }
th, td {
  padding: 8px 10px; border-bottom: 1px solid #2a2e36;
  text-align: left; vertical-align: top; font-size: 14px;
}
th { background: #1c1f25; color: #b6c0cf; font-weight: 600; }
tr:hover td { background: #1a1d23; }

input[type=text], input[type=url], input[type=number], input[type=password] {
  background: #0f1115; color: #e6e6e6;
  border: 1px solid #2a2e36; border-radius: 6px;
  padding: 6px 8px; font-size: 14px;
}
input[type=text]:focus, input[type=url]:focus,
input[type=number]:focus, input[type=password]:focus {
  outline: none; border-color: #4fb1ff;
}

button, .btn {
  background: #4fb1ff; color: #0f1115; border: 0;
  padding: 7px 14px; border-radius: 6px;
  font-weight: 600; cursor: pointer;
  text-decoration: none; display: inline-block; font-size: 14px;
}
button.secondary, .btn.secondary { background: #2a2e36; color: #e6e6e6; }
button.danger,    .btn.danger    { background: #e25555; color: #fff; }

.flash { padding: 10px 14px; border-radius: 6px; margin-bottom: 14px; }
.flash.ok    { background: #1d3a2a; color: #a6f0c2; }
.flash.error { background: #3a1d1d; color: #f4a6a6; }

.muted { color: #8a93a3; }
.row   { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.grow  { flex: 1; }

h1 { font-size: 22px; margin: 0 0 18px; }
h2 { font-size: 18px; margin: 22px 0 10px; }
code { background: #1c1f25; padding: 2px 6px; border-radius: 4px; }

.badge {
  display: inline-block; padding: 2px 8px; border-radius: 999px;
  font-size: 12px; font-weight: 600;
}
.badge.buy     { background: #1d3a2a; color: #a6f0c2; }
.badge.watch   { background: #2a3a1d; color: #d8f0a6; }
.badge.neutral { background: #2a2e36; color: #b6c0cf; }
.badge.high    { background: #3a2e1d; color: #f0d2a6; }
.badge.muted   { background: #2a2e36; color: #8a93a3; }

.pill {
  display: inline-block; padding: 1px 7px; border-radius: 4px;
  font-size: 11px; background: #2a2e36; color: #b6c0cf; margin-right: 4px;
}

.delta-down { color: #6ee7a8; }
.delta-up   { color: #f4a6a6; }

details summary { cursor: pointer; font-weight: 600; padding: 4px 0; }

.grid2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
}
@media (max-width: 800px) {
  .grid2 { grid-template-columns: 1fr; }
}

.form-grid {
  display: grid; grid-template-columns: 220px 1fr; gap: 8px 14px;
  align-items: center; max-width: 720px;
}
.form-grid label { color: #b6c0cf; font-size: 13px; }

select {
  background: #0f1115; color: #e6e6e6; border: 1px solid #2a2e36;
  border-radius: 6px; padding: 6px 8px; font-size: 14px;
}

.help { font-size: 12px; color: #8a93a3; }
.spark { vertical-align: middle; }

/* Generic card surface (used by positions / login). */
.card {
  background: #1c1f25; border: 1px solid #2a2e36;
  border-radius: 8px; padding: 14px 16px; margin-bottom: 14px;
}
/* Inline P&L colour cues. */
.good { color: #6ee7a8; font-weight: 600; }
.bad  { color: #f4a6a6; font-weight: 600; }
/* Compact button variant. */
.btn.small, button.small {
  padding: 3px 9px; font-size: 12px; border-radius: 4px;
}

/* Make wide tables horizontally scrollable on phones instead of clipping. */
.table-wrap {
  width: 100%; overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* Visible focus ring for keyboard users. */
a:focus, button:focus, input:focus, select:focus, summary:focus {
  outline: 2px solid #4fb1ff; outline-offset: 2px;
}

@media (max-width: 600px) {
  main   { padding: 12px; }
  header { flex-wrap: wrap; gap: 10px; padding: 10px 12px; }
  th, td { font-size: 13px; padding: 6px 8px; }
}

/* Login-page layout (centred card on a full-height background). */
body.login-page {
  min-height: 100vh; display: flex;
  align-items: center; justify-content: center;
}
body.login-page .card {
  width: 320px; padding: 28px 32px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .35);
  margin: 0;
}
body.login-page label {
  display: block; font-size: 13px; color: #b6c0cf; margin: 12px 0 4px;
}
body.login-page input {
  width: 100%; box-sizing: border-box;
  padding: 9px 10px;
}
body.login-page button {
  width: 100%; margin-top: 18px; padding: 10px;
}
body.login-page .error {
  background: #3a1d1d; color: #f4a6a6;
  padding: 9px 12px; border-radius: 6px;
  font-size: 13px; margin-bottom: 4px;
}
