.card > .plus-btn {
  position: absolute !important;
  bottom: 3px !important;
  right: 3px !important;
  width: 16px !important;
  height: 16px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  border-radius: 50% !important;
  background: #eaf0ff !important;
  color: #000 !important;
  font-size: 10px !important;
  line-height: 1 !important;
  border: 1px solid #9ca3af !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: none !important;
  padding: 0 !important;
  z-index: 50 !important;
}
.card > .plus-btn:hover {
  background: #f3f4f6 !important;
}


.plus-btn {
  position: absolute !important;
  bottom: 4px !important;
  right: 4px !important;
  width: 16px !important;
  height: 16px !important;
  border-radius: 50% !important;
  background: #eaf0ff !important;
  color: #000 !important;
  font-size: 10px !important;
  line-height: 1 !important;
  border: 1px solid #9ca3af !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: none !important;
  padding: 0 !important;
  min-width: 0 !important;
  z-index: 50 !important;
}
.plus-btn:hover {
  background: #f3f4f6 !important;
}
/*
 * Mission popup container.  The popup is hidden by default but can be
 * displayed via JavaScript.  Do not use !important here so that the
 * script is able to control the display state.  A translucent overlay
 * covers the page when the popup is shown.
 */
#mission-popup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.4);
  z-index: 9999;
}

#mission-popup .mission-popup-content {
  position: relative !important;
  margin: 40px auto !important;
  background: white !important;
  padding: 20px 30px !important;
  border-radius: 8px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2) !important;
  font-family: sans-serif !important;
  text-align: left !important;
  max-width: 800px !important;
  width: 90% !important;
  max-height: 90vh !important;
  overflow-y: auto !important;
}

#mission-popup .mission-popup-close {
  float: right;
  font-size: 20px;
  font-weight: bold;
  cursor: pointer;
}

body{margin:0;font-family:Inter,Arial,sans-serif;background:#f6f8fb;color:#0b1220}
header{background:#fff;border-bottom:1px solid #e1e5ec;padding:10px;position:sticky;top:0;z-index:10}
h1{margin:0;font-size:18px}
.top{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.total{font-size:18px;font-weight:800}

/* Make the grand total score more prominent.  By targeting only the
   total display within the header (.top) we avoid affecting other
   elements such as the saved time totals. */
.top .total{
  font-size:32px;
  line-height:1;
}
.top .total #grandTotal{
  font-size:36px;
}
.progress{height:12px;background:#e7ebf2;border-radius:6px;overflow:hidden;margin-top:6px}

.progress span {
  display: block;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg,#3b82f6,#1e3a8a);
  transition: width 0.8s ease-in-out, background 0.5s;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3) inset;
}
.progress span.maxed {
  background: linear-gradient(90deg,#fbbf24,#f97316,#dc2626);
}

main{padding:10px;max-width:1400px;margin:auto}
.grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.card{background:#fff;border:1px solid #e1e5ec;border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:6px;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.mhead{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e1e5ec;padding-bottom:4px}
.left{display:flex;align-items:center;gap:6px}
.thumb{width:40px;height:40px;border-radius:6px;flex:0 0 auto;object-fit:contain;border:1px solid #d7ddea;background:#f3f4f8}
.title{font-weight:700;font-size:14px}
.sum{font-weight:800}
.toggle{padding:6px;border:1px solid #e1e5ec;border-radius:6px;cursor:pointer;font-size:13px}
.toggle.on{background:#eaf0ff;border-color:#9bb8ff}
.stepper{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.btn{padding:2px 6px;margin:2px;border:1px solid #ccc;background:#fff;cursor:pointer;border-radius:6px}
.btn.active{background:#cde}
textarea{width:100%;min-height:30px;font-size:12px;border:1px dashed #ccc;border-radius:6px;padding:4px;resize:none;overflow:auto}
.roundctl{display:flex;align-items:center;gap:6px}
select{padding:4px}
.chart-container{margin-top:30px;background:#fff;border:1px solid #e1e5ec;border-radius:12px;padding:10px}

#confetti-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:999;display:none}
.progress.flash{animation:flash 1s ease-in-out 2}
@keyframes flash{0%,100%{box-shadow:0 0 0 transparent}50%{box-shadow:0 0 20px 5px #4ade80}}


.progress span.maxed {
  background: linear-gradient(90deg,#facc15,#f59e0b,#d97706);
  box-shadow: 0 0 15px rgba(250,204,21,0.9);
}
.total.golden {
  color: #d97706;
  text-shadow: 0 0 6px rgba(250,204,21,0.7);
}


.btn.fullmat {
  background: #fff;
  color: #111;
  
  border: 1px solid #e1e5ec;
  border-radius: 8px;
  box-shadow: none;
}
.btn.fullmat.golden {
  font-weight: 800;
  background: linear-gradient(90deg,#facc15,#f59e0b,#d97706);
  border: 1px solid #d97706;
  box-shadow: 0 0 6px rgba(250,204,21,0.7);
}
.btn.fullmat.golden:hover {
  filter: brightness(1.08);
  box-shadow: 0 0 12px rgba(250,204,21,0.9);
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

#mission-popup-content img {
  display: block !important;
  margin: 10px auto !important;
  max-width: 60% !important;
  height: auto !important;
}
#mission-popup-content {
  font-size: 16px !important;
  line-height: 1.5 !important;
}
#mission-popup-content h2 {
  font-size: 20px !important;
  margin-bottom: 10px !important;
}


#mission-popup-content .clarification {
  font-style: italic !important;
  color: #2563eb !important;
  background: #f0f7ff !important;
  padding: 6px 10px !important;
  border-left: 3px solid #93c5fd !important;
  display: block !important;
  margin: 8px 0 !important;
}


#mission-popup-content .constraint {
  font-style: italic !important;
  color: #b91c1c !important;
  background: #fef2f2 !important;
  padding: 6px 10px !important;
  border-left: 3px solid #f87171 !important;
  display: block !important;
  margin: 8px 0 !important;
}


#mission-popup-content .constraint {
  font-style: italic !important;
  color: #92400e !important;
  background: #fef9c3 !important;
  padding: 6px 10px !important;
  border-left: 3px solid #facc15 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 8px 0 !important;
}
#mission-popup-content .constraint strong {
  color: #dc2626 !important;
  font-size: 16px !important;
  margin-bottom: 0 !important;
}
#mission-popup-content .constraint img {
  width: 74px !important;
  height: 74px !important;
  flex-shrink: 0 !important;
  margin-top: 4px !important;
}


#mission-popup-content .constraint {
  background: #fef9c3 !important;
  border-left: 3px solid #facc15 !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  margin: 8px 0 !important;
  padding: 10px !important;
}
#mission-popup-content .constraint img {
  width: 74px !important;
  height: 74px !important;
  flex-shrink: 0 !important;
  margin-top: 4px !important;
}
#mission-popup-content .constraint .constraint-text {
  display: flex !important;
  flex-direction: column !important;
}
#mission-popup-content .constraint strong {
  color: #dc2626 !important;
  font-size: 16px !important;
  margin-bottom: 0 !important;
}
#mission-popup-content .constraint span {
  font-style: normal !important;
  color: #92400e !important;
}


#mission-popup-content .constraint strong {
  color: #dc2626 !important;
  font-size: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}
#mission-popup-content .constraint .constraint-text span {
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}


#mission-popup-content .constraint {
  line-height: 1.2 !important;
}
#mission-popup-content .constraint strong {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  display: block !important;
}
#mission-popup-content .constraint .constraint-text span {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  display: block !important;
}


#bar {
  z-index: 9999 !important;
  position: relative !important;
}
.card {
  position: relative !important;
  z-index: 0 !important;
}
.btn.mission-info {
  z-index: 1 !important;
}


.summary-box {
  background: #fff;
  border: 1px solid #e1e5ec;
  border-radius: 12px;
  padding: 16px;
  margin-top: 20px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.summary-box .sheet {
  width: 100%;
}
.summary-box .chart {
  width: 100%;
}

/* --- Sticky Header + First Column Fix --- */
table thead th {
  position: sticky;
  top: 0;
  z-index: 5;
  background: #fff;
}

table th:first-child,
table td:first-child {
  position: sticky;
  left: 0;
  z-index: 10;
  background: #fff;
}


/* --- Sticky Top-Left "Round" Header Fix --- */
table thead th:first-child {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 15;
  background: #fff;
}


/* --- Final Sticky Header + First Column + Top-Left "Round" Fix --- */
table thead th {
  position: sticky;
  top: 0;
  z-index: 5;
  background: #fff;
}

table th:first-child,
table td:first-child {
  position: sticky;
  left: 0;
  z-index: 10;
  background: #fff;
}

table thead th:first-child {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 20;
  background: #fff;
}


/* --- Visual Enhancement: Shadows for Sticky Header + Column --- */
table thead th {
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

table th:first-child,
table td:first-child {
  box-shadow: 2px 0 4px rgba(0,0,0,0.1);
}

table thead th:first-child {
  z-index: 25;
  box-shadow: 2px 2px 6px rgba(0,0,0,0.15);
}


/* --- Sticky Table Fixes (Corrected) --- */
#summaryTable thead th {
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 10;
}

#summaryTable th:first-child,
#summaryTable td:first-child {
  position: sticky;
  left: 0;
  background: #fff;
  z-index: 15;
}

#summaryTable thead th:first-child {
  top: 0;
  left: 0;
  z-index: 20;
  background: #fff;
}


#summaryGraphBox,
#summaryTableContainer {
  max-width: 1400px;
  margin: 30px auto;
}


#summaryGraphBox,
#summaryTableContainer {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}


#summaryGraphBox,
#summaryTableContainer,
#summaryGraphBox *,
#summaryTableContainer * {
  background: #f9f9f9 !important;
}

/* === DARK ONLY: Summary graph & table === */
@media (prefers-color-scheme: dark) {
  #summaryGraphBox,
  #summaryTableContainer,
  #summaryGraphBox *,
  #summaryTableContainer * {
    background: #1e2533 !important;
    color: #fff !important;
  }
}

/* Fallback class/attribute dark toggles for summary areas */
:is(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme="dark" i], [data-bs-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :is(#summaryGraphBox, #summaryTableContainer, #summaryGraphBox *, #summaryTableContainer *) {
  background: #1e2533 !important;
  color: #fff !important;
}


/* Dark-only override for summary areas */
@media (prefers-color-scheme: dark) {
  #summaryGraphBox,
  #summaryTableContainer,
  #summaryGraphBox *,
  #summaryTableContainer * {
    background: #1e2533 !important;
    color: #fff !important;
  }
}
.dark #summaryGraphBox,
.dark #summaryTableContainer,
.dark #summaryGraphBox *,
.dark #summaryTableContainer * {
  background: #1e2533 !important;
  color: #fff !important;
}


/* === Dark mode overrides for summary graph/table (inserted) === */
@media (prefers-color-scheme: dark) {
  #summaryGraphBox,
  #summaryTableContainer,
  #summaryGraphBox *,
  #summaryTableContainer * {
      background: #1e2533 !important;
      color: #fff !important;
  }
}

/* Fallback for setups that toggle dark mode with a class */
.dark #summaryGraphBox,
.dark #summaryTableContainer,
.dark #summaryGraphBox *,
.dark #summaryTableContainer * {
    background: #1e2533 !important;
    color: #fff !important;
}


/* === INSERTED: Dark mode overrides for summary sections === */
@media (prefers-color-scheme: dark) {
  #summaryGraphBox,
  #summaryTableContainer,
  #summaryGraphBox *,
  #summaryTableContainer * {
    background: #1e2533 !important;
    color: #fff !important;
  }
}

/* Class/attribute-based dark toggles (broad support) */
html.dark #summaryGraphBox,
html.dark #summaryTableContainer,
html.dark #summaryGraphBox *,
html.dark #summaryTableContainer *,
body.dark #summaryGraphBox,
body.dark #summaryTableContainer,
body.dark #summaryGraphBox *,
body.dark #summaryTableContainer *,
.theme-dark #summaryGraphBox,
.theme-dark #summaryTableContainer,
.theme-dark #summaryGraphBox *,
.theme-dark #summaryTableContainer *,
[data-theme="dark"] #summaryGraphBox,
[data-theme="dark"] #summaryTableContainer,
[data-theme="dark"] #summaryGraphBox *,
[data-theme="dark"] #summaryTableContainer * {
  background: #1e2533 !important;
  color: #fff !important;
}



#summaryGraphBox,
#summaryTableContainer {
  border: 1px solid #ccc !important;
  border-radius: 8px !important;
  color: #333 !important;
  font-family: Arial, sans-serif !important;
}

#summaryGraphBox *,
#summaryTableContainer * {
  color: #333 !important;
  font-family: Arial, sans-serif !important;
}


#summaryGraphBox h2,
#summaryTableContainer h2 {
  font-size: 18px !important;
  font-weight: 600 !important;
  text-align: center !important;
  margin: 0 0 16px 0 !important;
  color: #222 !important;
  font-family: Arial, sans-serif !important;
}


#summaryGraphBox h2,
#summaryTableContainer h2 {
  font-size: 20px !important;
  font-weight: bold !important;
  color: #333 !important;
  text-align: center !important;
  font-family: Arial, sans-serif !important;
}


#summaryGraphBox h2,
#summaryTableContainer h2 {
  font-size: 20px !important;
  font-weight: 600 !important;
  color: #222 !important;
  text-align: center !important;
  font-family: Arial, sans-serif !important;
  margin: 16px 0 !important;
  padding: 0 !important;
}


/* Unified header style */
#summaryGraphBox h2,
#summaryTableContainer h2,
.chart-container h2 {
  font-size: 20px !important;
  font-weight: 600 !important;
  color: #222 !important;
  text-align: center !important;
  font-family: Arial, sans-serif !important;
  margin: 16px 0 !important;
  padding: 0 !important;
}

/* Unify border style for all Table/Chart boxes */
#summaryGraphBox,
.chart-container,
#summaryTableContainer {
  border: 1px solid #ccc !important;
  border-radius: 12px !important;
}

:root{
    --bg: #f7f7f9;
    --card: #ffffff;
    --muted: #6b7280;
    --accent: #2563eb;
    --accent-600:#1d4ed8;
    --ring: rgba(37,99,235,0.35);
    --shadow: 0 8px 24px rgba(0,0,0,0.08);
  }
  body{ background: var(--bg); }
  /* Mission cards */
  .card{
    background: var(--card) !important;
    border-radius: 14px !important;
    box-shadow: var(--shadow);
    transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  }
  .card:hover{ transform: translateY(-2px); box-shadow: 0 12px 28px rgba(0,0,0,0.12); }
  .card .title{ font-weight: 700; letter-spacing: .2px; }
  /* Buttons */
  .btn{
    transition: transform .06s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
    border-radius: 10px !important;
  }
  .btn:active{ transform: translateY(1px) scale(0.99); }
  .btn.primary, .btn.fullmat.golden{
    box-shadow: 0 6px 18px rgba(29,78,216,.25);
  }
  /* Inputs */
  textarea, input, select, button{ outline: none; }
  textarea:focus, input:focus, select:focus{ box-shadow: 0 0 0 3px var(--ring); border-color: var(--accent-600); }
  /* Notes box auto-grow look */
  #global-notes-wrap textarea{
    min-height: 90px;
    resize: none;
    transition: background-color .25s ease, box-shadow .25s ease, min-height .2s ease;
  }
  #global-notes-wrap textarea.editing{
    background: #fffbeb;
  }
  /* Chart container already styled; keep gray and shadow */
  .chart-container{
    background:#f0f0f0 !important;
    border-radius:12px !important;
    box-shadow: 0 8px 22px rgba(0,0,0,0.12) !important;
  }
  .chart-container h3{ font-size: 1.1rem; font-weight: 800; color:#111827; }
  /* Autosave badge */
  #saveBadge{
    display:inline-block; margin-left:8px; font-size:.85rem; color: var(--muted);
    vertical-align: middle;
  }
  #saveBadge.saving{ color:#92400e; }
  #saveBadge.saved{ color:#065f46; }
  /* Full Mat pulse when golden */
  @keyframes pulseGlow{
    0%{ box-shadow: 0 0 0 0 rgba(250,204,21,.55); }
    70%{ box-shadow: 0 0 0 12px rgba(250,204,21,0); }
    100%{ box-shadow: 0 0 0 0 rgba(250,204,21,0); }
  }
  .btn.fullmat.golden{ animation: pulseGlow 2.4s ease-out infinite; }
  /* Fade-in for cards on round switch */
  .fade-in{ animation: fadeUp .24s ease both; }
  @keyframes fadeUp{
    from{ opacity:0; transform: translateY(6px); }
    to{ opacity:1; transform: translateY(0); }
  }
  /* Total number emphasis */
  .total .big{ font-weight: 800; }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Global toolbar buttons */
  #toolbar, .toolbar { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
  .btn{ height: 38px; padding: 0 14px; font-weight: 600; border: 1px solid #e5e7eb; }
  .btn.primary{ background:#2563eb; color:#fff; border-color:#1d4ed8; }
  .btn.primary:hover{ filter: brightness(1.05); box-shadow: 0 6px 18px rgba(37,99,235,.25); }
  .btn.secondary{ background:#f9fafb; color:#111827; }
  .btn.secondary:hover{ background:#f3f4f6; }
  .btn.danger{ background:#fee2e2; color:#991b1b; border-color:#fecaca; }
  .btn.danger:hover{ background:#fecaca; }
  .btn.ghost{ background:#fff; }
  .btn .icon{ margin-right:8px; font-size:1rem; line-height:1; }
  /* Make the FULL MAT stand out but not confusing */
  #fullMatBtn{ min-width: 140px; }
  /* Mission token buttons (e.g., precision tokens or option selections) */
  button[data-points]{
    display:inline-flex; align-items:center; justify-content:center;
    min-width: 56px; height: 40px; padding: 0 10px; margin: 4px;
    border-radius: 10px; border:1px solid #e5e7eb; background:#fff; cursor:pointer;
    font-weight: 600; transition: background .2s ease, box-shadow .2s ease, transform .06s ease;
  }
  button[data-points]:hover{ background:#f9fafb; box-shadow: 0 4px 12px rgba(0,0,0,.06); }
  button[data-points]:active{ transform: translateY(1px) scale(.99); }
  button[data-points].active{
    border-color:#10b981; background:#ecfdf5; box-shadow: 0 0 0 3px rgba(16,185,129,.2);
  }
  button[data-points].active::after{
    content:"✓"; margin-left:8px; font-weight:800; color:#059669;
  }
  /* Improve spacing inside mission cards action rows */
  .card .actions, .card .controls{ display:flex; flex-wrap:wrap; gap: 6px; }
  /* Make +/- counter buttons clearer if present */
  .card .counter button{ min-width:40px; height:36px; font-size:1.05rem; }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Unify *all* buttons inside mission cards */
  .card button{
    display:inline-flex; align-items:center; justify-content:center;
    min-width: 56px; height: 40px; padding: 0 12px; margin: 4px 4px 4px 0;
    border-radius: 10px; border:1px solid #e5e7eb; background:#fff; cursor:pointer;
    font-weight: 600; transition: background .2s ease, box-shadow .2s ease, transform .06s ease, border-color .2s ease;
    touch-action: manipulation;
  }
  .card button:hover{ background:#f9fafb; box-shadow: 0 4px 12px rgba(0,0,0,.06); }
  .card button:active{ transform: translateY(1px) scale(.99); }
  /* Active/selected states inside missions */
  .card button.active, .card button[aria-pressed="true"]{
    border-color:#10b981; background:#ecfdf5; box-shadow: 0 0 0 3px rgba(16,185,129,.2);
  }
  .card button.active::after{
    content:"✓"; margin-left:8px; font-weight:800; color:#059669;
  }
  /* Counter groups */
  .card .counter{ display:inline-flex; align-items:center; gap:8px; flex-wrap:wrap; }
  .card .counter .count-value{
    min-width: 46px; height:40px; padding:0 10px;
    display:inline-flex; align-items:center; justify-content:center;
    border:1px solid #e5e7eb; border-radius:10px; background:#fff; font-weight:700;
  }
  .card .counter.active .count-value,
  .card .counter.active button{
    border-color:#10b981; background:#ecfdf5; box-shadow: 0 0 0 3px rgba(16,185,129,.2);
  }
  /* Helper labels inside cards */
  .card .label{ font-weight:700; color:#111827; margin-right:8px; }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

.card{ position: relative; }
  .card.done{
    border-color:#22c55e !important;
    background: linear-gradient(0deg,#ecfdf5 0%, #ffffff 65%) !important;
    box-shadow: 0 0 0 2px rgba(34,197,94,.25), 0 10px 24px rgba(0,0,0,.10) !important;
  }
  .card .done-badge{
    position:absolute; top:8px; right:8px;
    display:inline-flex; align-items:center; gap:6px;
    background:#16a34a; color:#fff; padding:4px 8px; border-radius:10px;
    font-size:.85rem; font-weight:700; box-shadow: 0 2px 8px rgba(22,163,74,.35);
  }
  .card.done .done-badge::before{ content:"✓"; font-weight:900; }
  .card:not(.done) .done-badge{ display:none; }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Layout spacing for mission control rows */
  .card .actions, .card .controls, .card .counter { display:flex; align-items:center; flex-wrap:wrap; gap:8px; }

  /* Make ALL mission buttons (tokens, toggles, +/-) identical size */
  .card button,
  .card button[data-points],
  .card .counter button{
    height: 44px !important;
    min-width: 64px !important;
    padding: 0 14px !important;
    border-radius: 12px !important;
    border:1px solid #e5e7eb;
    background:#fff;
    font-weight: 700;
    font-size: 1rem;
    line-height: 1;
    display:inline-flex; align-items:center; justify-content:center;
    transition: background .15s ease, box-shadow .15s ease, transform .06s ease, border-color .15s ease;
    touch-action: manipulation;
    cursor: pointer;
  }
  .card button:hover{ background:#f9fafb; box-shadow: 0 4px 12px rgba(0,0,0,.06); }
  .card button:active{ transform: translateY(1px) scale(.99); }

  /* Active/selected tokens and active counters share the same success style */
  .card button.active,
  .card .counter.active button{
    border-color:#10b981; background:#ecfdf5; box-shadow: 0 0 0 3px rgba(16,185,129,.2);
  }
  .card button.active::after{
    content:"✓"; margin-left:8px; font-weight:800; color:#059669;
  }

  /* The numeric value pill matches button size for visual unity */
  .card .counter .count-value{
    height:44px !important;
    min-width:64px !important;
    padding:0 12px;
    border-radius:12px;
    border:1px solid #e5e7eb;
    background:#fff;
    font-weight:800;
    display:inline-flex; align-items:center; justify-content:center;
  }
  .card .counter.active .count-value{
    border-color:#10b981; background:#ecfdf5; box-shadow: 0 0 0 3px rgba(16,185,129,.2);
  }

  /* Make + and - clearly readable and consistent */
  .card .counter button.plus,
  .card .counter button.minus{
    font-size: 1.2rem;
    font-weight:900;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Normalize +/- to match all mission buttons exactly */
  .card button,
  .card .counter button,
  .card .counter .count-value{
    height:44px !important;
    min-width:64px !important;
    box-sizing:border-box !important;
    line-height:1 !important;
  }
  .card .counter button.plus,
  .card .counter button.minus{
    font-size:1rem !important;
    font-weight:700 !important;
    padding:0 14px !important;
    min-width:64px !important;
    height:44px !important;
    letter-spacing:0 !important;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Smaller +/- controls, but keep them aligned with the value pill */
  .card .counter{ align-items: center; gap:10px; }
  .card .counter .count-value{
    height: 40px !important;
    min-width: 56px !important;
    font-size: 1rem !important;
  }
  .card .counter button.plus,
  .card .counter button.minus{
    height: 36px !important;
    min-width: 48px !important;
    padding: 0 10px !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    border-radius: 10px !important;
  }
  /* Tighten gaps so the group feels compact */
  .card .counter button.plus, .card .counter button.minus, .card .counter .count-value{
    margin: 2px 4px 2px 0 !important;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Ultra-compact +/- while preserving readability */
  .card .counter{ align-items:center; gap:8px; }
  .card .counter .count-value{
    height: 34px !important;
    min-width: 50px !important;
    font-size: 0.95rem !important;
    border-radius: 8px !important;
  }
  .card .counter button.plus,
  .card .counter button.minus{
    height: 30px !important;
    min-width: 40px !important;
    padding: 0 8px !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    border-radius: 8px !important;
  }
  .card .counter button.plus, .card .counter button.minus, .card .counter .count-value{
    margin: 1px 3px 1px 0 !important;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Real +/- containers are .stepper — make them compact and consistent */
  .card .stepper, .stepper{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
  .stepper button.btn{
    height: 28px !important;
    min-width: 36px !important;
    padding: 0 8px !important;
    border-radius: 8px !important;
    border:1px solid #e5e7eb; background:#fff; font-weight:700; font-size:.95rem; line-height:1;
    transition: background .15s ease, box-shadow .15s ease, transform .06s ease, border-color .15s ease;
  }
  .stepper button.btn:hover{ background:#f3f4f6; box-shadow: 0 3px 10px rgba(0,0,0,.06); }
  .stepper button.btn:active{ transform: translateY(1px) scale(.99); }
  .stepper span[id^="val_"]{
    display:inline-flex; align-items:center; justify-content:center;
    height: 30px !important;
    min-width: 44px !important;
    padding: 0 10px; border-radius: 8px; border:1px solid #e5e7eb; background:#fff; font-weight:800;
  }
  /* Active highlight when value > 0 */
  .stepper.active button.btn, .stepper.active span[id^="val_"]{
    border-color:#10b981; background:#ecfdf5; box-shadow: 0 0 0 3px rgba(16,185,129,.18);
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Switch active/selected visual from green to blue across mission buttons */
  .card button.active,
  .card button[aria-pressed="true"],
  .card .counter.active button,
  .card .counter.active .count-value,
  .stepper.active button,
  .stepper.active span[id^="val_"],
  .card button[data-points].active{
    border-color:#2563eb !important;
    /* Active background updated to a softer light blue */
    background:#eaf0ff !important;
    box-shadow: 0 0 0 3px rgba(37,99,235,.20) !important;
  }
  .card button.active::after{ color:#1d4ed8 !important; }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Universal Mission Card Button Style */
  .card button,
  .card button[data-points],
  .card .counter button,
  .card .counter .count-value {
    height: 44px !important;
    min-width: 64px !important;
    padding: 0 14px !important;
    border-radius: 12px !important;
    border: 1px solid #e5e7eb !important;
    background: #eaf0ff !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .15s ease, box-shadow .15s ease, transform .06s ease;
    cursor: pointer;
  }

  /* Hover */
  .card button:hover,
  .card .counter button:hover {
    background: #f9fafb !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06) !important;
    transform: translateY(-1px);
  }

  /* Active/Selected */
  .card button.active,
  .card .counter.active button,
  .card .counter.active .count-value,
  .card button[aria-pressed="true"] {
    border-color: #2563eb !important;
    /* Use same light blue highlight for selected buttons */
    background: #eaf0ff !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.20) !important;
  }

  /* Consistent Checkmark */
  .card button.active::after,
  .card button[aria-pressed="true"]::after {
    content: "✓";
    margin-left: 6px;
    font-weight: 800;
    color: #1d4ed8;
  }

  /* Ensure +/- buttons match visually */
  .card .counter button.plus,
  .card .counter button.minus {
    font-size: 1.2rem !important;
    font-weight: 900 !important;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Wrapper for counter row */
  .card .counter {
    display: inline-flex;
    align-items: center;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #d1d5db;
    background: #fff;
  }

  /* Minus and plus buttons */
  .card .counter button.minus,
  .card .counter button.plus {
    background: #374151 !important; /* dark gray */
    color: #fff !important;
    border: none !important;
    height: 40px !important;
    min-width: 44px !important;
    font-weight: 900 !important;
    font-size: 1.1rem !important;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s ease;
  }
  .card .counter button.minus:hover,
  .card .counter button.plus:hover {
    background: #1f2937 !important; /* darker hover */
  }

  /* Value box and label look like middle cells */
  .card .counter .count-value,
  .card .counter .label {
    background: #fff;
    color: #111;
    height: 40px !important;
    min-width: 44px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    border-left: 1px solid #d1d5db;
    border-right: 1px solid #d1d5db;
  }

  /* Active highlight */
  .card .counter.active {
    box-shadow: 0 0 0 3px rgba(37,99,235,0.2);
    border-color: #2563eb;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Make stepper controls look like a single pill with dark +/- endcaps */
  .card .stepper {
    display: inline-flex;
    align-items: center;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #d1d5db;
    background: #fff;
  }

  /* Reset any prior stepper/button sizing so we control it here */
  .card .stepper > .btn,
  .card .stepper > span,
  .card .stepper > .label {
    height: 40px !important;
    line-height: 40px !important;
  }

  /* Endcaps: dark +/- buttons */
  .card .stepper > .btn:first-child,
  .card .stepper > .btn:last-child {
    background: #374151 !important;
    color: #fff !important;
    border: none !important;
    min-width: 44px !important;
    padding: 0 12px !important;
    font-weight: 900 !important;
    font-size: 1.1rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .2s ease !important;
    box-shadow: none !important;
  }
  .card .stepper > .btn:first-child:hover,
  .card .stepper > .btn:last-child:hover {
    background: #1f2937 !important;
  }

  /* Middle cells: value, unit labels, counts, etc. */
  .card .stepper > span[id^="val_"],
  .card .stepper > span,
  .card .stepper > .label {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 12px !important;
    background: #eaf0ff !important;
    color: #111 !important;
    font-weight: 700 !important;
    min-width: 44px !important;
    border-left: 1px solid #d1d5db !important;
  }

  /* Remove inner borders around first middle cell after minus (handled by container border) */
  .card .stepper > .btn:first-child + * {
    border-left: 1px solid #d1d5db !important;
  }

  /* Active highlight for the whole control */
  .card .stepper.active {
    box-shadow: 0 0 0 3px rgba(37,99,235,0.20) !important;
    border-color: #2563eb !important;
  }
  /* Keep endcaps dark even when active (override earlier blue overrides) */
  .card .stepper.active > .btn:first-child,
  .card .stepper.active > .btn:last-child {
    background: #374151 !important;
    color: #fff !important;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Hide token selection buttons that are not part of a counter/stepper (+/-) */
  .card [data-id] button[data-points] {
    display: none !important;
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Make precision-stepper visually match normal token buttons */
.stepper.precision-stepper {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: transparent;
  border: none;
  padding: 0;
  margin-top: 4px;
}
.stepper.precision-stepper button.btn {
  font-size: 0.85em; /* match normal button font size */
  padding: 4px 8px;
  border-radius: 6px;
  min-width: 32px;
  line-height: 1.2;
}
.stepper.precision-stepper .count-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85em;
  min-width: 28px;
  font-weight: 600;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Shrink only the - and + buttons inside steppers */
.stepper button.btn {
  font-size: 0.75em;
  padding: 2px 6px;
  min-width: 24px;
  line-height: 1.1;
  border-radius: 4px;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Make - and + buttons extremely compact */
.stepper button.btn {
  font-size: 0.65em;
  padding: 1px 4px;
  min-width: 18px;
  line-height: 1;
  border-radius: 3px;
  margin: 0;
}
.stepper {
  gap: 2px; /* tighter spacing */
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Force -/+ buttons to be as small as possible */
.stepper button.btn {
  font-size: 10px !important;
  padding: 0 3px !important;
  width: 20px !important;
  min-width: 20px !important;
  height: 20px !important;
  line-height: 18px !important;
  border-radius: 3px !important;
  margin: 0 !important;
}
.stepper {
  gap: 1px !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Ultra-compact -/+ buttons */
.stepper button.btn {
  font-size: 8px !important;
  width: 16px !important;
  min-width: 16px !important;
  height: 16px !important;
  padding: 0 !important;
  line-height: 14px !important;
  border-radius: 3px !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
}
.stepper {
  gap: 1px !important;
  align-items: center !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Extreme micro buttons and text */
.stepper button.btn {
  font-size: 4px !important;
  width: 8px !important;
  min-width: 8px !important;
  height: 8px !important;
  padding: 0 !important;
  line-height: 6px !important;
  border-radius: 2px !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
}
.stepper .count-value {
  font-size: 4px !important;
  min-width: 8px !important;
  line-height: 6px !important;
}
.stepper {
  gap: 1px !important;
  align-items: center !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Make only counter/token labels smaller */
.stepper > div:first-child {
  font-size: 0.8em !important;
  line-height: 1.05 !important;
  margin-bottom: 1px !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Put -/+ buttons on their own line, left aligned */
.stepper {
  display: flex;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Keep label on its own line, put - 0 + all in one row below */
.stepper {
  display: flex;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px !important;
}
.stepper button.btn, 
.stepper .count-value {
  display: inline-flex !important;
  vertical-align: middle;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Force - 0 + to be in a single horizontal row */
.stepper {
  display: flex;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px !important;
}
/* Make all children after the first (label) stay in one line */
.stepper > *:not(:first-child) {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 2px;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

.stepper-controls {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 2px;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Make - 0 + group box less rounded */
.stepper-controls {
  border-radius: 3px !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Force slightly rounded (2px) corners on - 0 + container */
.stepper-controls {
  border-radius: 2px !important;
  overflow: hidden; /* ensure children respect the rounded corners */
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Give - 0 + container a visible background and smaller radius */
.stepper-controls {
  display: inline-flex;
  background: #f5f5f5;
  border: 1px solid #ccc;
  border-radius: 2px !important;
  padding: 2px;
  gap: 2px;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Make the highlight box (stepper background that turns blue) more square */
.stepper {
  border-radius: 2px !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Remove visible box around - 0 + group */
.stepper-controls {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Style - 0 + box to match normal button look */
.stepper-controls {
  display: inline-flex;
  background: var(--btn-bg, #f0f0f0);
  border: 1px solid #ccc;
  border-radius: 2px;
  padding: 2px 4px;
  gap: 2px;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Match active box background/border to normal active button */
.stepper.active .stepper-controls {
  background: var(--btn-active-bg, #007bff);
  border-color: var(--btn-active-border, #007bff);
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Remove ALL glow/shadow effects from +/- boxes and keep only border color change */

/* 1) Neutral defaults */
.card .counter,
.card .counter *,
.stepper,
.stepper * {
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
  outline: none !important;
}

/* 2) Active states: border turns blue, background stays white */
.card .counter.active,
.card .counter.active .count-value,
.card .counter.active button,
.stepper.active,
.stepper.active span[id^="val_"],
.stepper.active button,
.stepper.active .stepper-controls {
  background: #eaf0ff !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}

/* === DARK ONLY: Active counters & steppers, and raw stepper-controls === */
@media (prefers-color-scheme: dark) {
  .card .counter.active,
  .card .counter.active .count-value,
  .card .counter.active button,
  .stepper.active,
  .stepper.active span[id^="val_"],
  .stepper.active button,
  .stepper.active .stepper-controls,
  /* also cover controls even if .stepper/.active not present */
  .stepper-controls, 
  .stepper-controls button,
  span[id^="val_"] {
    background: #1e2533 !important;
    border-color: #2563eb !important;
    box-shadow: none !important;
    color: #fff !important;
  }
}

/* --------------------------------------------------------------------- */
/* Custom light theme styling for steppers
 * These rules ensure the numeric box and the ± buttons use a light gray
 * background and subtle border when inactive (value = 0).  When the
 * stepper becomes active (value > 0), the border changes to blue while
 * the background reverts to white.  The same styling applies to the
 * buttons so they match the value box. */
.stepper span[id^="val_"], .stepper-controls .btn {
  background-color: #f3f4f6 !important;
  border-color: #d1d5db !important;
  color: #111827 !important;
  box-shadow: none !important;
}
/* Highlight active stepper controls with a light blue background
 * similar to selected missions.  When a stepper value exceeds zero
 * the JavaScript logic toggles an `active` class on the wrapper
 * (.stepper-controls.active).  This rule applies a pale blue
 * background and a slightly darker border to both the numeric box and
 * its ± buttons.  The color values mirror those used for mission
 * toggles (see .toggle.on) so that selected elements share a common
 * palette.
 */
.stepper-controls.active span[id^="val_"],
.stepper-controls.active .btn,
.stepper-controls.active .count-value {
  background-color: #eaf0ff !important;
  border-color: #9bb8ff !important;
  color: #111827 !important;
}


/* Fallback class/attribute dark toggles */
:is(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme="dark" i], [data-bs-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :is(.card .counter.active, .card .counter.active .count-value, .card .counter.active button, .stepper.active, .stepper.active span[id^="val_"], .stepper.active button, .stepper.active .stepper-controls, .stepper-controls, .stepper-controls button, span[id^="val_"]) {
  background: #1e2533 !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
  color: #fff !important;
}


/* Dark-only override for active counter & stepper */
@media (prefers-color-scheme: dark) {
  .card .counter.active,
.card .counter.active .count-value,
.card .counter.active button,
.stepper.active,
.stepper.active span[id^="val_"],
.stepper.active button,
.stepper.active .stepper-controls {
    background: #1e2533 !important;
    border-color: #2563eb !important;
    box-shadow: none !important;
  }
}
.dark .card .counter.active,
.card .counter.active .count-value,
.card .counter.active button,
.stepper.active,
.stepper.active span[id^="val_"],
.stepper.active button,
.stepper.active .stepper-controls {
  background: #1e2533 !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}


/* 3) Also kill hover shadows specifically on these controls */
.card .counter:hover,
.card .counter .count-value:hover,
.card .counter button:hover,
.stepper:hover,
.stepper span[id^="val_"]:hover,
.stepper button:hover,
.stepper .stepper-controls:hover {
  box-shadow: none !important;
}

/* 4) If any framework applies focus rings, suppress them here */
.card .counter :focus,
.stepper :focus {
  box-shadow: none !important;
  outline: none !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Remove borders from box containing subtitle + buttons */
.stepper,
.stepper.active,
.card .counter,
.card .counter.active {
  border: none !important;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Smooth animate bars in the bottom chart */
.chart-bar, .chart-bar div {
  transition: height 0.3s ease, width 0.3s ease;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Per-round creation timestamp display */
.round-meta{
  display:inline-block;
  margin-top:6px;
  font-size:.8rem;
  line-height:1.2;
  color: var(--muted-foreground, #666);
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

.round-meta-notes{ opacity:0.9; }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Gray out bonus items (those with dependency unmet) */
.toggle.blocked{
  background: #e5e7eb !important; /* light gray */
  opacity: 0.7;
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

/* Blocked bonuses are not clickable and look disabled */
.toggle.blocked{
  pointer-events: none;
  filter: grayscale(0.4);
}

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

.card {
  position: relative !important;
}

/* Show only for selected missions */
.card:has(.plus-btn[data-mission="M01"])::after,
.card:has(.plus-btn[data-mission="M04"])::after,
.card:has(.plus-btn[data-mission="M05"])::after,
.card:has(.plus-btn[data-mission="M09"])::after,
.card:has(.plus-btn[data-mission="M11"])::after,
.card:has(.plus-btn[data-mission="M12"])::after,
.card:has(.plus-btn[data-mission="M13"])::after,
.card:has(.plus-btn[data-mission="M14"])::after {
  content: "";
  position: absolute;
  bottom: 28px; /* just above the + button */
  right: 6px;
  width: 20px;
  height: 20px;
  background: url('') no-repeat center/contain;
  opacity: 0.95;
}

/* === REMOVE mission info button === */
.mission-info-btn {
  display: none !important;
}

.card textarea {
  width: 85% !important;
  margin: 0 !important;
  display: block !important;
}

.chart-container { position: relative !important; }

/* Wrapper to make table scrollable if too big */
#summaryTableContainer {
  overflow: auto;
  max-width: 100%;
  /* optional: max-height if you want vertical scroll control */
}

/* General cell/padding cleanup so sticky works cleanly */
#summaryTable th,
#summaryTable td {
  background: #fff; /* Ensure no transparency */
  border: 1px solid #ccc;
}

/* Sticky header row = first row */
#summaryTable tr:first-child th {
  position: sticky;
  top: 0;
  z-index: 30;
  background: #f9f9f9; /* header style */
}

/* Sticky first column */
#summaryTable th:first-child,
#summaryTable td:first-child {
  position: sticky;
  left: 0;
  z-index: 20;
  background: #f9f9f9; /* first column style */
}

/* Top-left corner cell */
#summaryTable tr:first-child th:first-child {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 40; /* highest */
  background: #ddd; /* corner style */
}

.popup-footer{margin-top:12px;padding:10px 12px;border-top:1px solid #e5e7eb;font-family:Inter,system-ui,Arial,sans-serif;font-size:12px;color:#374151;text-align:center}
  .popup-footer .accent{color:#2563eb;font-weight:600}
  .popup-footer .popup-links{margin:6px 0;display:flex;justify-content:center;gap:10px}
  .popup-footer .popup-links a,.popup-footer .popup-extra a{color:#2563eb;font-weight:600;text-decoration:none;font-size:12px}
  .popup-footer .popup-links a:hover,.popup-footer .popup-extra a:hover{text-decoration:underline;color:#1e40af}
  .popup-footer .popup-extra{margin-top:6px;font-size:11.5px;line-height:1.4}

.mission-popup-content {
  color: #333;
}
.mission-popup-content h2,
.mission-popup-content p,
.mission-popup-content span,
.mission-popup-content li {
  color: inherit;
}

/* Hide +/- buttons in TIME card */
.card[data-id="TIME"] .stepper button {
  display: none !important;
}
/* Enlarge the displayed value in TIME card */
#val_TIME {
  font-size: 1em;
  font-weight: bold;
  display: inline-block;
  min-width: 80px;
  text-align: center;
}

#val_TIME {
  font-size: 1em !important;
  font-weight: 800 !important;
  min-width: 200px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.card[data-id="TIME"] .stepper button {
  display: none !important;
}

.card[data-id="TIME"] .thumb img {
  width: 40px !important;
  height: auto !important;
  object-fit: contain;
}

.card[data-id="TIME"] .mhead .left {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* Hide + - buttons only for the TIME (remaining seconds) card */
.card[data-id="TIME"] .stepper .btn {
    display: none !important;
}

/* Special independent TIME card controls */
.card[data-id="TIME"] .timecard-controls {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
  margin-top: 8px;
}
.card[data-id="TIME"] .timecard-controls button {
  background: #111827;
  color: #fff;
  border: none;
  border-radius: 6px;
  width: 40px;
  height: 40px;
  font-weight: bold;
  font-size: 18px;
  cursor: pointer;
}
.card[data-id="TIME"] .timecard-controls button:hover {
  background: #2563eb;
}
.card[data-id="TIME"] .timecard-controls .time-value {
  font-weight: 900;
  font-size: 20px;
  color: #1d4ed8;
  min-width: 60px;
  text-align: center;
}

#saved-time-box {
  margin: 8px 0;
  padding: 6px 8px;
  border-radius: 6px;
  background: #f3f4f6;
  border: 1px solid #cbd5e1;
  text-align: left;
  max-width: 220px;
  font-size: 13px;
  line-height: 1.4;
}
#saved-time-box .rt-header {
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 4px;
  color: #1e3a8a;
}
#saved-time-box .label {
  font-weight: 600;
  margin-right: 4px;
}
#saved-time-box .time-controls {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
#saved-time-box .time-controls button {
  background: #1e3a8a;
  color: #fff;
  border: none;
  border-radius: 3px;
  width: 24px;
  height: 24px;
  font-weight: bold;
  font-size: 13px;
  cursor: pointer;
  padding: 0;
}
#saved-time-box .time-controls button:hover {
  background: #2563eb;
}
#saved-time-box .time-controls .time-value {
  font-weight: 700;
  font-size: 13px;
  min-width: 32px;
  text-align: center;
}
#saved-time-box .total-value {
  font-weight: 700;
  font-size: 13px;
  color: #dc2626;
}

#saved-time-box {
  margin: 8px 0;
  padding: 6px 8px;
  border-radius: 6px;
  background: #f3f4f6;
  border: 1px solid #cbd5e1;
  text-align: left;
  max-width: 220px;
  font-size: 13px;
  line-height: 1.4;
}
#saved-time-box .rt-header {
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 4px;
  color: #1e3a8a;
}
#saved-time-box .label {
  font-weight: 600;
  margin-right: 4px;
}
#saved-time-box .time-controls {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
#saved-time-box .time-controls button {
  background: #1e3a8a;
  color: #fff;
  border: none;
  border-radius: 3px;
  width: 24px;
  height: 24px;
  font-weight: bold;
  font-size: 13px;
  cursor: pointer;
  padding: 0;
}
#saved-time-box .time-controls button:hover {
  background: #2563eb;
}
#saved-time-box .time-controls .time-value {
  font-weight: 700;
  font-size: 13px;
  min-width: 32px;
  text-align: center;
}
#saved-time-box .total-value {
  font-weight: 700;
  font-size: 13px;
  color: #dc2626;
}

/* Make table columns narrower */
#saved-time-box table,
#saved-time-box td,
#saved-time-box th {
  padding: 1px 2px;
}
#saved-time-box .time-value,
#saved-time-box .total-value {
  min-width: auto;
  display: inline-block;
  text-align: center;
}

#summaryTable th,
#summaryTable td {
  font-size: 12.5px !important; /* slightly smaller */
}

#saved-time-box,
#saved-time-box .rt-header,
#saved-time-box .label,
#saved-time-box .time-value,
#saved-time-box .total-value {
  font-family: Inter, system-ui, Arial, sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #111827 !important; /* uniform dark gray */
}

/* ======= Auth Modal Overlay ======= */
#auth-overlay {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.60);
  backdrop-filter: blur(2px);
  z-index: 10000;
}
#auth-overlay.show { display: flex; }

#auth-overlay .auth-card {
  width: min(480px, 92vw);
  background: #ffffff;
  border-radius: 16px;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
  padding: 24px;
  text-align: center;
  font-family: Inter, 'Segoe UI', Roboto, Arial, sans-serif;
}

#auth-overlay .brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 8px;
}
#auth-overlay .brand img {
  width: 40px; height: 40px; object-fit: contain;
}
#auth-overlay .brand .title {
  font-size: 20px; font-weight: 800; letter-spacing: .3px; color: #111827;
}
#auth-overlay .subtitle {
  margin: 0 0 14px 0;
  color: #6b7280; font-size: 14px;
}

#auth-overlay .input {
  width: 80%;
  max-width: 320px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid #d1d5db;
  margin: 6px auto;
  display: block;
  font-size: 14px;
}
#auth-overlay .input:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(37,99,235,0.20);
  border-color: #2563eb;
}

#auth-overlay .actions {
  display: flex;
  gap: 10px;
  margin-top: 10px;
  justify-content: center;
}

#auth-overlay .btn {
  padding: 10px 16px;
  border: none;
  border-radius: 10px;
  font-weight: 700;
  cursor: pointer;
}
#auth-overlay .btn.primary { background:#1e3a8a; color:#fff; }
#auth-overlay .btn.secondary { background:#3b82f6; color:#fff; }
#auth-overlay .btn.link {
  background: transparent; color:#2563eb; font-weight:600; padding: 6px 8px;
}

#auth-overlay .meta {
  font-size: 12px; color:#6b7280; margin-top: 10px;
}

body.auth-lock {
  overflow: hidden; /* prevent background scroll while login modal is open */
}

#app.app-dim { filter: blur(1.5px) brightness(0.85); pointer-events: none; user-select: none; }

#toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10001;
  display: none;
  opacity: 0;
  transition: opacity .25s ease;
}
#toast .toast-msg {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #111827;
  color: #fff;
  padding: 12px 16px;
  border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  font-family: Inter, 'Segoe UI', Roboto, Arial, sans-serif;
  font-size: 14px;
  max-width: 92vw;
  white-space: pre-line;
}
#toast .toast-msg.success { background: #065f46; }  /* green */
#toast .toast-msg.error { background: #7f1d1d; }    /* red */
#toast .toast-msg.info { background: #1e3a8a; }     /* blue */
#toast .toast-icon { font-size: 16px; }
#toast .toast-close {
  margin-left: auto;
  cursor: pointer;
  background: none;
  border: none;
  color: #fff;
  font-weight: bold;
  font-size: 16px;
}

#fllTimerBox {
  position: relative;
}
#timer-watermark {
  display: none;
  position: absolute;
  top: 1%;        /* higher */
  left: 50%;
  transform: translateX(-50%);
  width: 10%;     /* smaller */
  max-width: 120px;
  opacity: 0.65;
  z-index: 9999;
}
#fllTimerBox.fll-expanded #timer-watermark {
  display: block;
}

#fllTimerBox{
    position:fixed; bottom:20px; right:20px; width:320px;
    background:#111; color:#fff; z-index:2000; padding:20px;
    border-radius:16px; box-shadow:0 4px 20px rgba(0,0,0,0.5);
    text-align:center; font-family:Inter,Arial,sans-serif;
    transition:all .25s ease;
  }
  #fllTimerBox.hidden{ display:none; }
  #fllTimerText{ font-size:3rem; font-weight:800; line-height:1.1; }
  #fllTimerControls{ margin-top:14px; display:flex; flex-wrap:wrap; justify-content:center; gap:10px; }
  .fll-btn{
    padding:8px 16px; border:none; border-radius:10px; cursor:pointer; font-weight:700;
    color:#fff;
  }
  .fll-green{ background:#16a34a; }
  .fll-red{ background:#dc2626; }
  .fll-blue{ background:#2563eb; }
  .fll-amber{ background:#f59e0b; }
  /* Expanded (big) view */
  #fllTimerBox.fll-expanded{
    top:0; left:0; right:0; bottom:0; width:100%; height:100%;
    display:flex; align-items:center; justify-content:center; flex-direction:column;
    background:#0b0b0b;
  }

/* Make timer text 10x bigger when expanded */
#fllTimerBox.fll-expanded #fllTimerText {
  font-size: 30rem !important; /* base is 3rem → 10x */
  line-height: 1;
}

/* When truly fullscreen, also force huge text */
:fullscreen #fllTimerText,
:-webkit-full-screen #fllTimerText,
:-moz-full-screen #fllTimerText {
  font-size: 30rem !important;
  line-height: 1;
}

  /* --- Negative time toggle switch styles --- */
  .neg-switch {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: #fff;
    margin-top: 4px;
  }
  .neg-switch .neg-label {
    user-select: none;
  }
  .switch {
    position: relative;
    display: inline-block;
    width: 40px;
    height: 22px;
  }
  /* Hide default checkbox */
  .switch input {
    opacity: 0;
    width: 0;
    height: 0;
  }
  /* The slider */
  .slider-neg {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #4b5563; /* dark gray default */
    transition: 0.3s;
    border-radius: 34px;
  }
  .slider-neg:before {
    position: absolute;
    content: "";
    height: 16px;
    width: 16px;
    left: 3px;
    top: 3px;
    background-color: white;
    transition: 0.3s;
    border-radius: 50%;
  }
  input:checked + .slider-neg {
    background-color: #22c55e; /* green when on */
  }
  input:checked + .slider-neg:before {
    transform: translateX(18px);
  }

.mission-info-btn {
  position: absolute;
  bottom: 6px;
  right: 6px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #2563eb;
  color: #fff;
  font-size: 14px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mission-popup {
  display: none;
  position: fixed;
  z-index: 2000;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.4);
}
.mission-popup-content {
  background: #fff;
  margin: 10% auto;
  padding: 16px;
  border-radius: 10px;
  max-width: 400px;
  text-align: center;
}
.mission-popup-close {
  float: right;
  font-size: 20px;
  cursor: pointer;
}

#summaryGraphBox {
  margin:30px auto 160px auto;
  padding:16px;
  background:#fff;
  border-radius:8px;
  box-shadow:0 2px 8px rgba(0,0,0,0.1);
  max-width:1400px;
}
#summaryGraphBox h2 {
  margin:0 0 12px 0;
  font-family:Arial, sans-serif;
  font-size:16px;
  font-weight:600;
  color:#333;
}
#summaryTableContainer {
  overflow:auto;
  max-height:600px;
}
#summaryTable {
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:12px;
  text-align:center;
  font-family:Arial, sans-serif;
}
#summaryTable th, #summaryTable td {
  border:1px solid #ddd;
  padding:4px 6px;
  min-width:30px;
  width:30px;
}
#summaryTable th {
  position:sticky;
  top:0;
  background:#f2f4f7;
  font-weight:600;
  z-index:2;
}
#summaryTable td:first-child,
#summaryTable th:first-child {
  text-align: center;
  background: #f2f4f7;
  font-weight: 600;
  z-index: 5;
  color: #111;

  z-index: 5;
  font-weight: 700;
  color: #111;

  position:sticky;
  left:0;
  background:#f9fafb;
  z-index:3;
  font-weight:600;
}
#summaryTable tr:nth-child(even) td {
  background:#fcfcfc;
}
#summaryTable tr:hover td {
  background:#f0f7ff;
}
#summaryTable tr.averages {
  background:#e6f2ff !important;
  font-weight:bold;
}
#summaryTable tr.averages td:first-child {
  text-align:right;
}

#fll-footer-notice.footer-card {
    margin: 10px 16px 20px 16px; /* less bottom margin */
    padding: 12px 14px;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    color: #111827;
    max-width: 320px; /* narrower */
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
    font-family: Inter, system-ui, Arial, sans-serif;
  }
  #fll-footer-notice h2 {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 0.25rem;
  }
  #fll-footer-notice .accent {
    color: #2563eb;
  }
  #fll-footer-notice p {
    font-size: 0.85rem;
    margin-bottom: 0.5rem;
    color: #374151;
  }
  #fll-footer-notice .links {
    display: flex;
    gap: 8px;
  }
  #fll-footer-notice .links a {
    text-decoration: none;
    color: #2563eb;
    font-weight: 600;
    font-size: 0.8rem;
    padding: 4px 8px;
    border-radius: 6px;
    background: #f3f4f6;
    transition: all 0.2s ease;
  }
  #fll-footer-notice .links a:hover {
    background: #e0e7ff;
    color: #1e40af;
  }

.popup-footer-note{
    margin-top:16px;
    padding-top:10px;
    border-top:1px solid #e5e7eb;
    font-family: Inter, system-ui, Arial, sans-serif;
    font-size:12.5px;
    color:#374151;
    line-height:1.5;
    text-align:left;
  }
  .popup-footer-note .accent{ color:#2563eb; font-weight:600; }
  .popup-footer-note a{ color:#2563eb; font-weight:600; text-decoration:none; }
  .popup-footer-note a:hover{ text-decoration:underline; color:#1e40af; }

.mission-popup-close {
    position: absolute;
    top: 10px;
    right: 14px;
    font-size: 26px;
    font-weight: bold;
    color: #666;
    cursor: pointer;
    transition: color 0.2s ease;
    line-height: 1;
  }
  .mission-popup-close:hover {
    color: #000;
  }

.clarification {
    margin-top: 8px;
    padding: 8px 10px;
    border-left: 3px solid #2563eb;
    background: #f9fafb;
    font-size: 13px;
    font-style: italic;
    color: #374151;
  }

.fll-btn.fll-purple{background:#6b21a8;color:#fff;}

#fll-footer-notice {
    position: fixed;
    bottom: 14px;
    left: 14px;
    padding: 5px 14px;
    font-size: 12px;
    font-family: "Inter", "Segoe UI", Arial, sans-serif;
    color: #0b1220;
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(37, 99, 235, 0.25);
    border-radius: 999px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 2px 8px rgba(37, 99, 235, 0.15);
    z-index: 9999;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 8px;
  }

  #fll-footer-notice .label {
    font-weight: 500;
    opacity: 0.9;
  }

  #fll-footer-notice a {
    color: #2563eb;
    font-weight: 600;
    text-decoration: none;
    transition: color 0.2s ease, transform 0.2s ease;
  }
  #fll-footer-notice a:hover {
    color: #1d4ed8;
    transform: translateY(-1px);
  }

/* === Dark Mode v2 (Improved Contrast & Depth) === */
body {
  transition: background-color 0.4s ease, color 0.4s ease;
}
body.dark-mode {
  background: #0b1220 !important;
  color: #e2e8f0 !important;
}

/* Header, Navbar */
body.dark-mode header {
  background: #111827 !important;
  border-bottom: 1px solid #1f2937 !important;
  color: #f1f5f9 !important;
}

/* Cards / Containers */
body.dark-mode .card,
body.dark-mode .summary-box,
body.dark-mode .chart-container {
  background: #1e2533 !important;
  border-color: #2c3446 !important;
  color: #e2e8f0 !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.5) !important;
}

/* Buttons */
body.dark-mode .btn {
  background: #334155 !important;
  color: #f8fafc !important;
  border-color: #475569 !important;
  transition: background 0.2s ease;
}
body.dark-mode .btn:hover {
  background: #475569 !important;
}
body.dark-mode .btn.primary {
  background: #2563eb !important;
  color: #f8fafc !important;
}
body.dark-mode .btn.primary:hover {
  background: #1d4ed8 !important;
}

/* Input fields / textareas */
body.dark-mode input,
body.dark-mode select,
body.dark-mode textarea {
  background: #111827 !important;
  color: #f8fafc !important;
  border: 1px solid #374151 !important;
}
body.dark-mode input::placeholder,
body.dark-mode textarea::placeholder {
  color: #9ca3af !important;
}

/* Table & Charts */
body.dark-mode table {
  background: #1f2937 !important;
  color: #e5e7eb !important;
  border-color: #374151 !important;
}
body.dark-mode table th {
  background: #111827 !important;
  color: #f9fafb !important;
}
body.dark-mode table td {
  background: #1e2533 !important;
  color: #e2e8f0 !important;
}

/* Progress bar */
body.dark-mode .progress {
  background: #374151 !important;
}
body.dark-mode .progress span {
  background: linear-gradient(90deg, #3b82f6, #2563eb) !important;
  box-shadow: 0 0 6px rgba(37,99,235,0.5);
}

/* Popup overlays */
body.dark-mode #mission-popup,
body.dark-mode .mission-popup {
  background: rgba(0,0,0,0.75) !important;
}
body.dark-mode #mission-popup .mission-popup-content,
body.dark-mode .mission-popup-content {
  background: #1e2533 !important;
  color: #e2e8f0 !important;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.6);
}

/* Titles & Highlights */
body.dark-mode .title { color: #f9fafb !important; }
body.dark-mode .sum { color: #60a5fa !important; }
body.dark-mode .total.golden {
  color: #fbbf24 !important;
  text-shadow: 0 0 10px rgba(251,191,36,0.8);
}

/* Stepper, toggles */
body.dark-mode .toggle {
  background: #1e2533 !important;
  border-color: #475569 !important;
  color: #e2e8f0 !important;
}
body.dark-mode .toggle.on {
  background: #2563eb !important;
  color: #fff !important;
}

/* Lang / Logout / Theme buttons */
body.dark-mode #langBtn,
body.dark-mode #logout-btn,
body.dark-mode #themeBtn {
  background: #2563eb !important;
  color: #fff !important;
  border: none !important;
}
body.dark-mode #langBtn:hover,
body.dark-mode #logout-btn:hover,
body.dark-mode #themeBtn:hover {
  filter: brightness(1.15);
}

/* Charts and summary */
body.dark-mode .chart text,
body.dark-mode .chart tspan {
  fill: #f8fafc !important;
}

/* Scrollbar for dark mode (nicer aesthetic) */
body.dark-mode ::-webkit-scrollbar {
  width: 8px;
}
body.dark-mode ::-webkit-scrollbar-thumb {
  background: #475569;
  border-radius: 4px;
}
body.dark-mode ::-webkit-scrollbar-thumb:hover {
  background: #64748b;
}

/* === Dark Mode v2.1 – Fixes for tables, +/- buttons, auth overlay, timer === */

/* Sticky table backgrounds forced to white in base CSS — override in dark */
body.dark-mode table thead th,
body.dark-mode table th:first-child,
body.dark-mode table td:first-child,
body.dark-mode table thead th:first-child {
  background: #111827 !important;
  color: #f1f5f9 !important;
  border-color: #374151 !important;
}

/* General table cell background to avoid white islands when sticky columns overlap */
body.dark-mode table td {
  background: #1e2533 !important;
  color: #e2e8f0 !important;
  border-color: #374151 !important;
}

/*
 * Additional dark mode tweaks introduced in this patch.  These styles
 * ensure the login modal and promotional popup respect the dark theme
 * colours.  Without these rules the login card and promo would remain
 * bright even when dark mode is active.
 */
body.dark-mode #fllplannerPromo {
  background: #1e2533 !important;
  border-color: #2c3446 !important;
  color: #e2e8f0 !important;
}
body.dark-mode #fllplannerPromo .promo-header {
  background: linear-gradient(90deg,#1e3a8a,#3b82f6) !important;
  color: #fff !important;
}
body.dark-mode #fllplannerPromo .promo-btn {
  background: #2563eb !important;
  color: #fff !important;
}

body.dark-mode .auth-card {
  background: #1e2533 !important;
  border-color: #2c3446 !important;
  color: #e2e8f0 !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.6) !important;
}
body.dark-mode .auth-card input,
body.dark-mode .auth-card select,
body.dark-mode .auth-card textarea {
  background: #111827 !important;
  color: #f8fafc !important;
  border: 1px solid #374151 !important;
}
body.dark-mode .auth-card input::placeholder,
body.dark-mode .auth-card textarea::placeholder {
  color: #9ca3af !important;
}
body.dark-mode .auth-card .btn.primary {
  background: #2563eb !important;
  color: #ffffff !important;
}
body.dark-mode .auth-card .btn.secondary {
  background: #334155 !important;
  color: #ffffff !important;
}

/* Stepper and time controls buttons are not .btn — style them explicitly */
body.dark-mode .stepper button,
body.dark-mode .timecard-controls button,
body.dark-mode .time-minus,
body.dark-mode .time-plus {
  background: #334155 !important;
  color: #f8fafc !important;
  border: 1px solid #475569 !important;
  border-radius: 6px !important;
}
body.dark-mode .stepper button:hover,
body.dark-mode .timecard-controls button:hover,
body.dark-mode .time-minus:hover,
body.dark-mode .time-plus:hover {
  background: #475569 !important;
}

/* Counter numbers inside steppers */
body.dark-mode .count-value,
body.dark-mode .time-value {
  color: #f8fafc !important;
}

/* FLL timer buttons */
body.dark-mode .fll-btn {
  color: #ffffff !important;
  border-color: #0b1220 !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.6);
}

/* Negative time switch */
body.dark-mode .neg-switch .slider-neg {
  background: #334155 !important;
  border: 1px solid #475569 !important;
}
body.dark-mode .neg-label {
  color: #e2e8f0 !important;
}

/* Auth overlay & login card */
body.dark-mode #auth-overlay {
  background: rgba(0,0,0,0.7) !important;
}
body.dark-mode #auth-overlay .auth-card {
  background: #111827 !important;
  color: #e2e8f0 !important;
  border: 1px solid #1f2937 !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.6) !important;
}
body.dark-mode #auth-overlay .title,
body.dark-mode #auth-title {
  color: #f8fafc !important;
}
body.dark-mode #auth-overlay .subtitle,
body.dark-mode #auth-subtitle {
  color: #cbd5e1 !important;
}
body.dark-mode #auth-overlay .input,
body.dark-mode #auth-overlay input {
  background: #0b1220 !important;
  color: #f8fafc !important;
  border: 1px solid #334155 !important;
}
body.dark-mode #auth-overlay .btn {
  background: #334155 !important;
  color: #f8fafc !important;
  border-color: #475569 !important;
}
body.dark-mode #auth-overlay .btn.primary {
  background: #2563eb !important;
}
body.dark-mode #auth-overlay .btn.secondary {
  background: #475569 !important;
}
body.dark-mode #auth-overlay .btn.link {
  background: transparent !important;
  color: #93c5fd !important;
  border: none !important;
}

/* Mission popup close '×' */
body.dark-mode .mission-popup-close {
  color: #f8fafc !important;
}

/* Plus-button “+” popover triggers in cards */
body.dark-mode .plus-btn {
  background: #0b1220 !important;
  color: #f8fafc !important;
  border-color: #334155 !important;
}
body.dark-mode .plus-btn:hover {
  background: #1f2937 !important;
}

/* === Dark Mode v3.0 (Comprehensive Polished Version) === */

/* Global transition for smooth switching */
body {
  transition: background-color 0.4s ease, color 0.4s ease;
}

/* Base colors */
body.dark-mode {
  background: #0b1220 !important;
  color: #e2e8f0 !important;
}

/* Header and Navbar */
body.dark-mode header,
body.dark-mode .navbar {
  background: #111827 !important;
  color: #f1f5f9 !important;
  border-bottom: 1px solid #1f2937 !important;
}

/* Generic containers, cards */
body.dark-mode .card,
body.dark-mode .container,
body.dark-mode .box,
body.dark-mode .panel,
body.dark-mode .summary-box,
body.dark-mode .chart-container {
  background: #1e2533 !important;
  color: #f1f5f9 !important;
  border-color: #334155 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.4) !important;
}

/* Buttons */
body.dark-mode .btn {
  background: #334155 !important;
  color: #f8fafc !important;
  border-color: #475569 !important;
}
body.dark-mode .btn:hover {
  background: #475569 !important;
}
body.dark-mode .btn.primary {
  background: #2563eb !important;
}
body.dark-mode .btn.primary:hover {
  background: #1d4ed8 !important;
}

/* Inputs, selects, textareas */
body.dark-mode input,
body.dark-mode select,
body.dark-mode textarea {
  background: #111827 !important;
  color: #f8fafc !important;
  border: 1px solid #374151 !important;
}
body.dark-mode input::placeholder,
body.dark-mode textarea::placeholder {
  color: #9ca3af !important;
}

/* Tables, including summary tables */
body.dark-mode table {
  background: #1f2937 !important;
  color: #e5e7eb !important;
  border-color: #374151 !important;
}
body.dark-mode table th {
  background: #111827 !important;
  color: #f9fafb !important;
}
body.dark-mode table td {
  background: #1e2533 !important;
  color: #e2e8f0 !important;
  border-color: #374151 !important;
}

/* Stepper (counter) */
body.dark-mode .stepper {
  background: #1f2937 !important;
  border: 1px solid #334155 !important;
  border-radius: 8px !important;
  color: #f8fafc !important;
  box-shadow: inset 0 0 6px rgba(0,0,0,0.5);
}
body.dark-mode .stepper button {
  background: #334155 !important;
  color: #f8fafc !important;
  border: 1px solid #475569 !important;
}
body.dark-mode .stepper button:hover {
  background: #475569 !important;
}
body.dark-mode .stepper span,
body.dark-mode .stepper .val {
  color: #f8fafc !important;
}

/*
 * In dark mode, the numeric values displayed inside steppers and summary
 * fields (spans whose id begins with "val_") should have a dark
 * background and light text.  Without these overrides the values
 * remain black on white, making them unreadable.  Apply a subtle
 * border to delineate the value boxes.
 */
body.dark-mode span[id^="val_"] {
  background: #334155 !important;
  color: #f1f5f9 !important;
  border: 1px solid #475569 !important;
}

/* Summary and graph boxes */
body.dark-mode #summaryGraphBox,
body.dark-mode #summaryTableContainer,
body.dark-mode .summarygraph-box {
  background: #1e2533 !important;
  border: 1px solid #334155 !important;
  color: #f1f5f9 !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.5);
}
body.dark-mode #summaryGraphBox h2,
body.dark-mode .summarygraph-box h2 {
  color: #f9fafb !important;
}

/* In dark mode, ensure the numeric count pill and its +/- controls adopt the dark theme
 * for improved readability.  The `.count-value` element shows the current counter value
 * and sits between plus/minus buttons; it inherits a white background by default which
 * becomes unreadable on a dark background.  Override the background and border colours
 * here.  Similarly, style the plus/minus buttons inside `.counter` so they match other
 * dark-mode buttons. */
body.dark-mode .count-value {
  background: #334155 !important;
  border-color: #475569 !important;
  color: #f8fafc !important;
}
body.dark-mode .counter button.plus,
body.dark-mode .counter button.minus {
  background: #334155 !important;
  color: #f8fafc !important;
  border-color: #475569 !important;
}
body.dark-mode .counter button.plus:hover,
body.dark-mode .counter button.minus:hover {
  background: #475569 !important;
}

/* Hide the old inline base64 logo when a separate `logo.png` is provided.  The original
 * project embeds a huge base64 encoded PNG on the same `<img>` tag as the new logo.  To
 * avoid duplicating the logo we hide any image whose alt text matches and whose source
 * attribute begins with "data:image" */
img[alt="FLLPlanner Scorer"][src^="data:image"] {
  display: none !important;
}

/* Progress bars */
body.dark-mode .progress {
  background: #475569 !important;
}
body.dark-mode .progress span {
  background: linear-gradient(90deg,#3b82f6,#2563eb) !important;
}

/* Popups and overlays */
body.dark-mode #mission-popup,
body.dark-mode .mission-popup {
  background: rgba(0,0,0,0.75) !important;
}
body.dark-mode #mission-popup .mission-popup-content,
body.dark-mode .mission-popup-content {
  background: #1e2533 !important;
  color: #f1f5f9 !important;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.6);
}

/* Footer / credits / about text */
body.dark-mode footer,
body.dark-mode .footer,
body.dark-mode #footer,
body.dark-mode .credits,
body.dark-mode .about-text,
body.dark-mode .info-text {
  background: transparent !important;
  color: #e2e8f0 !important;
}
body.dark-mode footer a,
body.dark-mode .credits a,
body.dark-mode .about-text a {
  color: #93c5fd !important;
  text-decoration: underline;
}
body.dark-mode footer a:hover,
body.dark-mode .credits a:hover,
body.dark-mode .about-text a:hover {
  color: #bfdbfe !important;
}

/* Title and headings */
body.dark-mode h1,
body.dark-mode h2,
body.dark-mode h3,
body.dark-mode .title {
  color: #f9fafb !important;
}

/* Minor text, notes, links */
body.dark-mode a { color: #60a5fa !important; }
body.dark-mode a:hover { color: #93c5fd !important; }
body.dark-mode small,
body.dark-mode .small-text,
body.dark-mode .note {
  color: #cbd5e1 !important;
}

/* Scrollbar */
body.dark-mode ::-webkit-scrollbar {
  width: 8px;
}
body.dark-mode ::-webkit-scrollbar-thumb {
  background: #475569;
  border-radius: 4px;
}
body.dark-mode ::-webkit-scrollbar-thumb:hover {
  background: #64748b;
}

/* =======================
   FINAL DARK MODE OVERRIDES (high specificity, placed last)
   ======================= */

/* Prefer OS dark mode */
@media (prefers-color-scheme: dark) {
  /* Summary boxes & descendants */
  #summaryGraphBox,
  #summaryTableContainer,
  #summaryGraphBox *,
  #summaryTableContainer * {
    background: #1e2533 !important;
    color: #fff !important;
  }

  /* Active counters & steppers */
  .card .counter.active,
  .card .counter.active .count-value,
  .card .counter.active button,
  .stepper.active,
  .stepper.active span[id^="val_"],
  .stepper.active button,
  .stepper.active .stepper-controls {
    background: #1e2533 !important;
    border-color: #2563eb !important;
    box-shadow: none !important;
  }
}

/* Common class/attribute dark toggles — very broad to catch any setup */
:is(html.dark, body.dark, .dark, .theme-dark, [data-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :is(#summaryGraphBox, #summaryTableContainer) {
  background: #1e2533 !important;
}
:is(html.dark, body.dark, .dark, .theme-dark, [data-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :is(#summaryGraphBox *, #summaryTableContainer *) {
  background: #1e2533 !important;
  color: #fff !important;
}

/* Dark toggles for active counters/steppers */
:is(html.dark, body.dark, .dark, .theme-dark, [data-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :is(.card .counter.active, .card .counter.active .count-value, .card .counter.active button, .stepper.active, .stepper.active span[id^="val_"], .stepper.active button, .stepper.active .stepper-controls) {
  background: #1e2533 !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}

/* =======================
   EXPLICIT LIGHT MODE RESET (wins when not in dark)
   ======================= */

/* OS-level light preference */
@media (prefers-color-scheme: light) {
  .card .counter.active,
  .card .counter.active .count-value,
  .card .counter.active button,
  .stepper.active,
  .stepper.active span[id^="val_"],
  .stepper.active button,
  .stepper.active .stepper-controls,
  /* cover raw controls even without .active */
  .stepper-controls,
  .stepper-controls button,
  span[id^="val_"] {
    background: #eaf0ff !important;
  }
}

/* Class/attribute toggles: when NOT dark, force back to white */
:is(html, body):not(.dark):not(.dark-mode):not(.darkmode):not(.night):not(.theme-dark):not([data-theme="dark" i]):not([data-bs-theme="dark" i]):not([data-mode="dark" i]):not([theme="dark" i]) :is(
  .card .counter.active,
  .card .counter.active .count-value,
  .card .counter.active button,
  .stepper.active,
  .stepper.active span[id^="val_"],
  .stepper.active button,
  .stepper.active .stepper-controls,
  .stepper-controls,
  .stepper-controls button,
  span[id^="val_"]
) {
  background: #eaf0ff !important;
}

/* === ABSOLUTE LAST: Dark mode takes precedence over any light reset === */
@media (prefers-color-scheme: dark) {
  /* Summary areas */
  #summaryGraphBox,
  #summaryTableContainer,
  #summaryGraphBox *,
  #summaryTableContainer * {
    background: #1e2533 !important;
    color: #fff !important;
  }

  /* Stepper / Counter (active + raw controls) */
  .card .counter.active,
  .card .counter.active .count-value,
  .card .counter.active button,
  .stepper.active,
  .stepper.active span[id^="val_"],
  .stepper.active button,
  .stepper.active .stepper-controls,
  .stepper-controls,
  .stepper-controls button,
  span[id^="val_"] {
    background: #1e2533 !important;
    border-color: #2563eb !important;
    box-shadow: none !important;
    color: #fff !important;
  }
}

/* Class/attribute-based dark toggle (ensure last) */
:where(html.dark, body.dark, .dark, .theme-dark, [data-theme="dark" i], [data-bs-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :where(#summaryGraphBox, #summaryTableContainer) {
  background: #1e2533 !important;
}
:where(html.dark, body.dark, .dark, .theme-dark, [data-theme="dark" i], [data-bs-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :where(#summaryGraphBox *, #summaryTableContainer *) {
  background: #1e2533 !important;
  color: #fff !important;
}
:where(html.dark, body.dark, .dark, .theme-dark, [data-theme="dark" i], [data-bs-theme="dark" i], [data-mode="dark" i], [theme="dark" i]) :where(.card .counter.active, .card .counter.active .count-value, .card .counter.active button, .stepper.active, .stepper.active span[id^="val_"], .stepper.active button, .stepper.active .stepper-controls, .stepper-controls, .stepper-controls button, span[id^="val_"]) {
  background: #1e2533 !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
  color: #fff !important;
}

/* ===== FINAL OVERRIDE: Dark mode stepper/counter must be dark ===== */
@media (prefers-color-scheme: dark) {
  /* target containers + all descendants to defeat transparent backgrounds */
  .stepper-controls,
  .stepper-controls *,
  .stepper.active,
  .stepper.active *,
  .card .counter.active,
  .card .counter.active *,
  [id^="val_"],
  .stepper-controls .btn,
  .stepper .btn {
    background: #1e2533 !important;
    background-color: #1e2533 !important;
    color: #fff !important;
    background-image: none !important;
    border-color: #2563eb !important;
    box-shadow: none !important;
  }
}

/* Class/attribute dark toggles (super broad) */
:where(html.dark, body.dark, .dark, .theme-dark, .night, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i], [data-ui*="dark" i], body[class*="dark" i]) :where(.stepper-controls, .stepper-controls *, .stepper.active, .stepper.active *, .card .counter.active, .card .counter.active *, [id^="val_"], .stepper-controls .btn, .stepper .btn) {
  background: #1e2533 !important;
  background-color: #1e2533 !important;
  color: #fff !important;
  background-image: none !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}


/* ===== FINAL DARK MODE OVERLAY FOR STEPPER/COUNTER ===== */
/* This uses ::before overlays to visually enforce the dark background above any white bg. */

/* OS-level dark */
@media (prefers-color-scheme: dark) {
  .stepper-controls,
  .stepper-controls *,
  .stepper.active,
  .stepper.active *,
  .card .counter.active,
  .card .counter.active *,
  .stepper-controls .btn,
  .stepper .btn,
  span[id^="val_"] {
    position: relative !important;
    z-index: 0 !important; /* create a stacking context */
    background-image: none !important;
    color: #fff !important;
  }
  .stepper-controls::before,
  .stepper.active::before,
  .card .counter.active::before,
  .stepper-controls .btn::before,
  .stepper .btn::before,
  span[id^="val_"]::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    border-radius: inherit !important;
    background: #1e2533 !important;
    z-index: -1 !important; /* paint above element's background but below content */
    pointer-events: none !important;
  }
}

/* Class/attribute dark toggles (broad coverage) */
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) :where(.stepper-controls, .stepper-controls *, .stepper.active, .stepper.active *, .card .counter.active, .card .counter.active *, .stepper-controls .btn, .stepper .btn, span[id^="val_"]) {
  position: relative !important;
  z-index: 0 !important;
  background-image: none !important;
  color: #fff !important;
}
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) :where(.stepper-controls::before, .stepper.active::before, .card .counter.active::before, .stepper-controls .btn::before, .stepper .btn::before, span[id^="val_"]::before) {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  background: #1e2533 !important;
  z-index: -1 !important;
  pointer-events: none !important;
}


/* ===== FINAL: Dark mode stepper & counter override — exact selector match ===== */
/* OS-level dark preference */
@media (prefers-color-scheme: dark) {
  /* Match the same selectors that set white in light mode */
  .card button,
  .card button[data-points],
  .card .counter button,
  .card .counter .count-value,
  .card .stepper > span[id^="val_"],
  .card .stepper > span,
  .card .stepper > .label {
    background: #1e2533 !important;
    color: #fff !important;
    border-color: #2563eb !important;
    box-shadow: none !important;
  }
  /* Common hover states */
  .card button:hover,
  .card .counter button:hover {
    background: #1f2a44 !important;
    color: #fff !important;
  }
}

/* Class/attribute dark toggles */
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) 
:where(.card button, .card button[data-points], .card .counter button, .card .counter .count-value, .card .stepper > span[id^="val_"], .card .stepper > span, .card .stepper > .label) {
  background: #1e2533 !important;
  color: #fff !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) 
:where(.card button:hover, .card .counter button:hover) {
  background: #1f2a44 !important;
  color: #fff !important;
}

/* =====================
   VARIABLE-DRIVEN STEPPER BACKGROUND (Last-in-file)
   ===================== */
:root {
  --stepper-bg: #fff;
  --stepper-fg: #111;
}

/* OS-level dark mode sets variables */
@media (prefers-color-scheme: dark) {
  :root {
    --stepper-bg: #1e2533;
    --stepper-fg: #fff;
  }
}

/* Class/attribute dark toggles set variables */
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) {
  --stepper-bg: #1e2533 !important;
  --stepper-fg: #fff !important;
}

/* Apply variables to the exact elements in the stepper area */
.stepper-controls,
.stepper-controls .btn,
.stepper-controls span[id^="val_"],
.card .stepper > span[id^="val_"],
.card .counter.active .count-value,
.card .counter.active button {
  background: var(--stepper-bg) !important;
  background-color: var(--stepper-bg) !important;
  background-image: none !important;
  color: var(--stepper-fg) !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}

/* Optional hover tweak (no color change, keeps dark/light consistent) */
.stepper-controls .btn:hover {
  filter: brightness(0.95);
}


/* ===== FINAL-FINAL DARK OVERLAY (covers inline white backgrounds) ===== */
@media (prefers-color-scheme: dark) {
  /* Create a stacking context so ::after can sit above element bg but under content */
  .stepper-controls,
  .card .counter.active,
  .stepper-controls .btn,
  span[id^="val_"] {
    position: relative !important;
    z-index: 0 !important;
  }
  /* Raise actual content above the overlay */
  .stepper-controls *,
  .card .counter.active *,
  .stepper-controls .btn *,
  span[id^="val_"] * {
    position: relative !important;
    z-index: 1 !important;
  }
  /* Paint a dark layer above any white background */
  .stepper-controls::after,
  .card .counter.active::after,
  .stepper-controls .btn::after,
  span[id^="val_"]::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    border-radius: inherit !important;
    background: #1e2533 !important;
    box-shadow: none !important;
    pointer-events: none !important;
    z-index: 0 !important; /* sits above element bg, below content (which is z-index:1) */
  }
}

/* Class/attribute dark toggles */
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) :where(.stepper-controls, .card .counter.active, .stepper-controls .btn, span[id^="val_"]) {
  position: relative !important;
  z-index: 0 !important;
}
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) :where(.stepper-controls *, .card .counter.active *, .stepper-controls .btn *, span[id^="val_"] *) {
  position: relative !important;
  z-index: 1 !important;
}
:where(html.dark, body.dark, .dark, .dark-mode, .darkmode, .night, .theme-dark, [data-theme*="dark" i], [data-bs-theme*="dark" i], [data-mode*="dark" i], [theme*="dark" i]) :where(.stepper-controls::after, .card .counter.active::after, .stepper-controls .btn::after, span[id^="val_"]::after) {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  background: #1e2533 !important;
  box-shadow: none !important;
  pointer-events: none !important;
  z-index: 0 !important;
}


/* === Dark Mode Fix: keep active steppers/counters dark (override white from .active) ===
   The base stylesheet sets active controls to white via:
     .card .counter.active, .card .counter.active .count-value, .card .counter.active button,
     .stepper.active, .stepper.active span[id^="val_"], .stepper.active button, .stepper.active .stepper-controls
   That selector is more specific than our generic dark-mode rules, so in dark mode the active
   controls were flashing white. These overrides target dark mode with equal-or-higher specificity
   and !important to ensure the dark palette is kept only when body.dark-mode is present.
*/
body.dark-mode .card .counter.active,
body.dark-mode .card .counter.active .count-value,
body.dark-mode .card .counter.active button,
body.dark-mode .stepper.active,
body.dark-mode .stepper.active span[id^="val_"],
body.dark-mode .stepper.active button,
body.dark-mode .stepper.active .stepper-controls {
  background: #1e2533 !important;
  color: #fff !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}

/* In light mode, keep the intended white active state explicitly to avoid accidental overrides */
body.light-mode .card .counter.active,
body.light-mode .card .counter.active .count-value,
body.light-mode .card .counter.active button,
body.light-mode .stepper.active,
body.light-mode .stepper.active span[id^="val_"],
body.light-mode .stepper.active button,
body.light-mode .stepper.active .stepper-controls {
  background: #eaf0ff !important;
  color: #111 !important;
  border-color: #2563eb !important;
  box-shadow: none !important;
}


/* === THEME VARS: Dark mode card background fix === */
@media (prefers-color-scheme: dark) {
  :root { --card: #1e2533; }
}
body.dark-mode { --card: #1e2533 !important; }

/* Non-active steppers default to white background */
.stepper:not(.active),
.stepper:not(.active) .stepper-controls,
.stepper:not(.active) .stepper-controls button,
.stepper:not(.active) span[id^="val_"] {
  background: #fff !important;
}

/* --- Override: non-active steppers stay white --- */
:is(html, body):not(.dark):not(.dark-mode):not(.darkmode):not(.night):not(.theme-dark):not([data-theme="dark" i]):not([data-bs-theme="dark" i]):not([data-mode="dark" i]):not([theme="dark" i])
.stepper:not(.active),
:is(html, body):not(.dark):not(.dark-mode):not(.darkmode):not(.night):not(.theme-dark):not([data-theme="dark" i]):not([data-bs-theme="dark" i]):not([data-mode="dark" i]):not([theme="dark" i])
.stepper:not(.active) .stepper-controls,
:is(html, body):not(.dark):not(.dark-mode):not(.darkmode):not(.night):not(.theme-dark):not([data-theme="dark" i]):not([data-bs-theme="dark" i]):not([data-mode="dark" i]):not([theme="dark" i])
.stepper:not(.active) .stepper-controls button,
:is(html, body):not(.dark):not(.dark-mode):not(.darkmode):not(.night):not(.theme-dark):not([data-theme="dark" i]):not([data-bs-theme="dark" i]):not([data-mode="dark" i]):not([theme="dark" i])
.stepper:not(.active) span[id^="val_"] {
  background: #fff !important;
}

/* --- Force non-active steppers and inner elements to white --- */
.stepper:not(.active),
.stepper:not(.active) *,
.stepper:not(.active) .stepper-controls,
.stepper:not(.active) .stepper-controls *,
.stepper:not(.active) span[id^="val_"] {
  background: #fff !important;
}

/* === Grand Total visual emphasis (scoped) === */
.total:has(#grandTotal) {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 6px;
  font-size: 0.95rem;      /* base for slash and max */
  font-weight: 400;        /* normal for slash/max */
  color: #8a8f99;          /* soft gray for slash/max */
}

.total:has(#grandTotal) #grandTotal {
  font-size: 2.15rem;      /* larger current total */
  line-height: 1;
  font-weight: 800;        /* bold current total */
  color: #111;             /* dark for emphasis */
}

/* Toast success variant (green) */
.toast-text.toast-success{background:#16a34a !important;color:#fff !important;border-radius:10px}

/* === Toast visual style (success variant) === */
.toast-msg.success {
  background: #16a34a;
  color: #fff;
  padding: 10px 16px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  font-size: 0.95rem;
  font-weight: 600;
  opacity: 1;
  transition: opacity 0.3s ease;
}
.toast-msg.success .toast-icon {
  font-size: 1.1rem;
}
.toast-msg.success .toast-close {
  background: none;
  border: none;
  color: #fff;
  font-size: 1.1rem;
  margin-left: 8px;
  cursor: pointer;
}

/* === Popup animation for constraint === */
.constraint-popup-box {
  animation: constraintFade 0.25s ease;
}
@keyframes constraintFade {
  from { transform: scale(0.95); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}


/* Clickable overlay aligned with the ::after no-equipment badge on mission cards */
.constraint-tap-target{
  position:absolute;
  bottom:28px; right:6px;
  width:20px; height:20px;
  cursor:pointer;
  z-index: 10; /* above card content but below global modals */
  background: transparent;
}


/* === FINAL v23 styles === */
.constraint-tap-target{
  position:absolute;
  bottom:28px;
  right:6px;
  width:22px;
  height:22px;
  cursor:pointer;
  background:transparent;
  z-index:12;
}
/* Disable clicks on icons inside popup */
.constraint-popup img[alt="No Equipment"]{
  pointer-events:none !important;
}
.constraint-popup-box{
  animation:constraintFade 0.25s ease;
}
@keyframes constraintFade{
  from{transform:scale(0.95);opacity:0}
  to{transform:scale(1);opacity:1}
}

/* v24: tap target for card badge (::after) and highlight */
.constraint-tap-target{
  position:absolute;
  bottom:28px;
  right:6px;
  width:22px;
  height:22px;
  cursor:pointer;
  background:transparent;
  z-index:12;
}
.mission-popup-content img[alt="No Equipment"]{
  pointer-events:none !important;
}
.mission-popup-content .constraint.constraint-highlight{
  outline: 2px solid #3b82f6;
  border-radius: 8px;
  animation: constraintPulse 1200ms ease-out 1;
}
@keyframes constraintPulse{
  0%{ box-shadow: 0 0 0 0 rgba(59,130,246,0.6); }
  100%{ box-shadow: 0 0 0 14px rgba(59,130,246,0); }
}


/* v26: Constraint Info modal */
#constraintInfoModal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.35);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 99999;
}
#constraintInfoModal .cim-panel{
  background: #fff;
  color: #111;
  width: min(780px, calc(100% - 32px));
  max-height: 80vh;
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(0,0,0,.25);
  padding: 18px 20px 22px;
  overflow: auto;
  position: relative;
  font-family: inherit;
}
#constraintInfoModal .cim-close{
  position: absolute;
  top: 8px;
  right: 10px;
  font-size: 22px;
  line-height: 1;
  background: none;
  border: none;
  cursor: pointer;
  color: #333;
}
#constraintInfoModal h3{ margin: 0 0 8px; font-size: 18px; }
#constraintInfoModal hr{ border: 0; border-top: 1px solid #e5e7eb; margin: 10px 0 12px; }
#constraintInfoModal p{ margin: 0 0 6px; font-size: 14px; line-height: 1.5; }


/* Hide constraint tap target on blacklisted missions (redundant safety) */
.card[data-mission="EI"] .constraint-tap-target,
.card[data-mission="M02"] .constraint-tap-target,
.card[data-mission="M03"] .constraint-tap-target,
.card[data-mission="M06"] .constraint-tap-target,
.card[data-mission="M07"] .constraint-tap-target,
.card[data-mission="M08"] .constraint-tap-target,
.card[data-mission="M10"] .constraint-tap-target,
.card[data-mission="M15"] .constraint-tap-target,
.card[data-mission="PT"] .constraint-tap-target { display:none !important; }

