/* ============================================================
   FilterBand component styles
   Used by the <filter-band> custom element (filter-band.js).
   Each chip receives --chip-color and --chip-bg inline,
   computed from the `color` field passed in the filters array.
   ============================================================ */


/*
 Note: Add these lines in organization's cssStyles.css to ensure the filter band fits well within the theme colors:
   :root {
    --filterband-default-active-color: #009fdf98;
  	--filterband-default-active-bgcolor: #009fdf6b;
   }
*/

filter-band {
  /* Theme tokens — override on :root or on the element to retheme */
  --filterband-surface: #222222;
  --filterband-surface-hover: #343434;
  --filterband-border: #373737;
  --filterband-text: #e6edf3;
  --filterband-text-dim: #8b949e;

  display: flex;
  gap: 8px;
  padding: 8px;
  background: var(--filterband-surface);
  border: 1px solid var(--filterband-border);
  border-radius: 5px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  font-family: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
  box-sizing: border-box;
}

filter-band *,
filter-band *::before,
filter-band *::after {
  box-sizing: border-box;
}

filter-band .filter-chip {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, transform 160ms ease;
  font-family: inherit;
  color: var(--filterband-text);
  text-align: left;
  font-weight: 400;
}

filter-band .filter-chip:hover {
  background: var(--filterband-surface-hover);
  border-color: var(--filterband-border);
}

filter-band .filter-chip:active {
  transform: translateY(1px);
}

filter-band .filter-chip:focus-visible {
  outline: 2px solid var(--chip-color);
  outline-offset: 2px;
}

filter-band .filter-chip.is-active {
  background: var(--chip-bg, rgba(255, 255, 255, 0.06));;
  border-color: var(--chip-color);
  font-weight: 600;
}

filter-band .chip-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

filter-band .status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: var(--chip-color);
  box-shadow: 0 0 0 3px var(--chip-bg);
}

filter-band .chip-label {
  font-size: 1em;
  font-weight: inherit;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

filter-band .chip-count {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 12px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgb(251 229 115 / 30%);
  color: #ffed00;
  min-width: 28px;
  text-align: center;
}

filter-band .filter-chip.is-active .chip-count {
  background: rgba(255, 255, 255, 0.08);
  color: var(--filterband-text);
}

/* ============================================================
   Warning badge
   Floats over the chip's top-right corner, half above the edge.
   Color customisable via --filterband-warning-color (default #BA0100).
   ============================================================ */

filter-band {
  --filterband-warning-color: #BA0100;
  --filterband-warning-text: #ffffff;
}

filter-band .chip-warning {
  position: absolute;
  top: -15px;
  left: 15px;
  transform: translate(35%, -50%);
  z-index: 2;
  min-width: 30px;
  height: 30px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--filterband-warning-color);
  color: var(--filterband-warning-text);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 14px;
  font-weight: 700;
  line-height: 30px;
  text-align: center;
  pointer-events: none;
  letter-spacing: 0;
}

/* Subtle pulse to draw attention without being obnoxious */
filter-band .chip-warning::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: var(--filterband-warning-color);
  opacity: 0.4;
  z-index: -1;
  animation: filterband-pulse 2s ease-in-out infinite;
}

@keyframes filterband-pulse {
  0%, 100% { transform: scale(1);   opacity: 0; }
  50%      { transform: scale(1.4); opacity: 0.3; }
}

/* Disable the pulse when the user prefers reduced motion */
@media (prefers-reduced-motion: reduce) {
  filter-band .chip-warning::before { animation: none; }
}

/* Dropdown-item variant: smaller, inline (not floating), since
   dropdown rows already have a clear hit target */
filter-band .dropdown-warning {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--filterband-warning-color);
  color: var(--filterband-warning-text);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  flex-shrink: 0;
}

/* ============================================================
   Colorless chip — when a filter has no `color` field, we render
   a neutral chip with no status dot and a lighter active state.
   ============================================================ */

filter-band .filter-chip.no-color .status-dot {
  display: none;
}

filter-band .filter-chip.no-color:focus-visible {
  outline-color: var(--filterband-text-dim);
}

filter-band .filter-chip.no-color.is-active {
  /*background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.18);*/
  border-color: var(--filterband-default-active-color, rgba(255, 255, 255, 0.65));
  background: var(--filterband-default-active-bgcolor, rgba(255, 255, 255, 0.15));
}

filter-band .filter-chip.no-color.is-active .chip-count {
  background: rgb(251 229 115 / 82%);
  color: #000000;
}

filter-band .filter-chip.no-color.is-dropdown-trigger[aria-expanded="true"] .chip-caret,
filter-band .filter-chip.no-color.is-active .chip-caret {
  color: var(--filterband-text);
}

/* ============================================================
   Responsive behavior
   - Tablet (≤ 820px): tighter padding & gaps, keep horizontal
   - Narrow (≤ 600px): wrap into a 2-column grid
   - Very narrow (≤ 380px): stack into a single column
   ============================================================ */

@media (max-width: 820px) {
  filter-band {
    gap: 6px;
    padding: 6px;
  }
  filter-band .filter-chip {
    padding: 10px 12px;
    gap: 8px;
  }
  filter-band .chip-label {
    font-size: 12px;
  }
}

@media (max-width: 600px) {
  filter-band {
    flex-wrap: wrap;
  }
  filter-band .filter-chip {
    /* Two per row, accounting for the 6px gap */
    flex: 1 1 calc(50% - 3px);
    min-width: 0;
  }
  filter-band .chip-label {
    white-space: normal;       /* allow wrapping if a label is long */
    line-height: 1.2;
  }
}

@media (max-width: 380px) {
  filter-band .filter-chip {
    flex: 1 1 100%;            /* one per row on very small screens */
  }
}

/* Touch devices: kill hover-state flicker on tap */
@media (hover: none) {
  filter-band .filter-chip:hover {
    background: transparent;
    border-color: transparent;
  }
}

/* ============================================================
   Dropdown chip
   A chip whose data has an `options` array becomes a trigger
   that opens a menu of sub-options beneath it.
   ============================================================ */

filter-band .chip-wrap {
  flex: 1;
  position: relative;
  display: flex;
  /*min-width: 0;*/
}

filter-band .chip-wrap .filter-chip {
  flex: 1;
  width: 100%;
}

filter-band .chip-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

filter-band .chip-caret {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  color: var(--filterband-text);
  transition: transform 160ms ease, color 160ms ease;
  line-height: 1;
  flex-shrink: 0;
}

filter-band .chip-caret svg {
  width: 14px;
  height: 14px;
  display: block;
}

filter-band .filter-chip.is-dropdown-trigger[aria-expanded="true"] .chip-caret {
  transform: rotate(180deg);
  color: var(--chip-color);
}

filter-band .filter-chip.is-active .chip-caret {
  color: var(--chip-color);
}

filter-band .filter-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  min-width: 180px;
  z-index: 100;
  display: none;
  flex-direction: column;
  gap: 2px;
  padding: 6px;
  background: var(--filterband-surface);
  border: 1px solid var(--filterband-border);
  border-radius: 8px;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.4);
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 140ms ease, transform 140ms ease;
}

filter-band .filter-dropdown[data-open="true"] {
  display: flex;
  opacity: 1;
  transform: translateY(0);
}

filter-band .dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  color: var(--filterband-text);
  text-align: left;
  white-space: nowrap;
  transition: background 120ms ease;
}

filter-band .dropdown-item-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

filter-band .dropdown-item:hover,
filter-band .dropdown-item:focus-visible {
  background: var(--filterband-surface-hover);
  outline: none;
}

filter-band .dropdown-item.is-active {
  background: var(--chip-bg, rgba(255, 255, 255, 0.06));
  color: var(--chip-color, var(--filterband-text));
}

filter-band .dropdown-item.is-active::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--chip-color);
  flex-shrink: 0;
}

filter-band .dropdown-count {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px;
  font-weight: 500;
  color: var(--filterband-text-dim);
  padding: 1px 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
}

/* On narrow screens the dropdown should span its row, not just its column */
@media (max-width: 600px) {
  filter-band .filter-dropdown {
    left: 0;
    right: 0;
  }
}

/*********  Widget Band (like the  Mission Selector One ) **********/
.dms {
    --dms-ink: #0c1015;
    --dms-panel: #222222;
    --dms-panel-2: #343434;
    --dms-line: #373737;
    --dms-line-soft: #1f2731;
    --dms-text: #e7eef6;
    --dms-muted: #8c8c8c;
    --dms-faint: #acacac;
    --dms-accent: #ffed00;
    --dms-amber: #f6b545;
    --dms-green: #41d191;
    --dms-red: #ff4d4f;
    --dms-blue: #7aa2ff;
    --dms-radius: 5px;

    margin: 0;
    background:
      radial-gradient(900px 500px at 85% -10%, rgba(56,189,248,.10), transparent 60%),
      var(--dms-panel);
    padding: 2px 2px;
    box-sizing: border-box;

    width: 100%;
    background: var(--dms-panel);
    border: 1px solid var(--dms-line);
    border-radius: var(--dms-radius);
    overflow: hidden;
    font-family: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--dms-text);
    box-shadow: 0 24px 60px -24px rgba(0,0,0,.6);
  }

  .dms *,
  .dms *::before,
  .dms *::after { box-sizing: border-box; }

  .dms-mono { font-family: "JetBrains Mono", ui-monospace, monospace; }

  /* ---------- Header band ---------- */
  .dms-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--dms-line);
    background: var(--dms-panel);
  }
  .dms-dot {
    width: 9px; height: 9px; border-radius: 50%;
    background: var(--dms-green);
    box-shadow: 0 0 0 4px rgba(65,209,145,.15);
    animation: dms-pulse 2.4s ease-in-out infinite;
  }
  @keyframes dms-pulse { 50% { opacity: .45; } }
  .dms-title { font-size: 1.1em; font-weight: 400; letter-spacing: 1.3px; margin: 0; text-transform: uppercase;}
  .dms-sub {
    margin: 2px 0 0; font-size: 11px; letter-spacing: 1.4px;
    text-transform: uppercase; color: var(--dms-faint);
  }
  .dms-count { margin-left: auto; font-size: 1.2em; color: #dbdbdb; }
  .dms-count b { color: var(--dms-accent); font-weight: 600; }

  /* ---------- Two-column band ---------- */
  .dms-grid {
    display: grid;
    grid-template-columns: minmax(300px, 340px) 1fr;
  }

  /* ---------- Left: filters ---------- */
  .dms-aside {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 20px;
    border-right: 1px solid var(--dms-line);
    background: var(--dms-panel);
  }
  .dms-field { display: flex; flex-direction: column; gap: 7px; }
  .dms-row { display: flex; gap: 12px; }
  .dms-row .dms-field { flex: 1; min-width: 0; }
  .dms-label {
    font-size: 10px; letter-spacing: 1.3px; text-transform: uppercase;
    color: var(--dms-faint); font-weight: 600;
  }

  /* select dropdowns */
  .dms-select {
    width: 100%;
    appearance: none; -webkit-appearance: none;
    background-color: var(--dms-ink);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a97a8' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 11px center;
    border: 1px solid var(--dms-line);
    color: var(--dms-text);
    font: inherit; font-size: 13px;
    padding: 2px 32px 2px 11px !important;
    border-radius: 9px;
    cursor: pointer;
    color-scheme: dark;
    transition: border-color .15s ease;
  }
  .dms-select:hover { border-color: var(--dms-faint); }
  .dms-select:focus-visible { outline: 2px solid var(--dms-accent); outline-offset: 1px; }

  /* date period */
  .dms-dates { display: flex; align-items: center; gap: 8px; }
  .dms-date {
    flex: 1; min-width: 0;
    background: var(--dms-ink);
    border: 1px solid var(--dms-line);
    color: var(--dms-text);
    font-family: "JetBrains Mono", ui-monospace, monospace;
    font-size: 12px;
    padding: 7px 9px;
    border-radius: 8px;
    color-scheme: dark;
  }
  .dms-date:focus-visible { outline: 2px solid var(--dms-accent); outline-offset: 1px; }
  .dms-arrow { color: var(--dms-faint); font-size: 12px; }

  .dms-secondary-button {
    margin-top: auto;
    appearance: none; border: 1px solid var(--dms-line);
    background: transparent; color: var(--dms-muted);
    font: inherit; font-size: 0.9em; cursor: pointer;
    padding: 8px 12px; border-radius: 8px;
    transition: color .15s, border-color .15s;
  }
  .dms-secondary-button:hover { color: var(--dms-text); border-color: var(--dms-faint); }

  /* ---------- Right: mission scroller + footer ---------- */
  .dms-main { display: flex; flex-direction: column; min-width: 0; }

  .dms-list {
    list-style: none; margin: 0; padding: 10px;
    /*max-height: 178px;*/
    overflow-y: auto;
    flex: 1;
    display: flex; flex-direction: column; gap: 8px;
  }
  .dms-list::-webkit-scrollbar { width: 10px; }
  .dms-list::-webkit-scrollbar-thumb { background: var(--dms-line); border-radius: 8px; border: 3px solid var(--dms-panel); }

  .dms-item {
    position: relative;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 13px 15px 13px 18px;
    background: var(--dms-panel-2);
    border: 1px solid var(--dms-line-soft);
    border-radius: 11px;
    cursor: pointer;
    transition: border-color .15s ease, background .15s ease, transform .05s ease;
  }
  .dms-item::before {
    content: ""; position: absolute; left: 0; top: 10px; bottom: 10px;
    width: 3px; border-radius: 3px; background: var(--dms-faint);
  }
  .dms-item[data-approval="PENDING"]::before { background: var(--dms-amber); }
  .dms-item[data-approval="APPROVED"]::before { background: var(--dms-green); }
  .dms-item[data-approval="DISAPPROVED"]::before { background: var(--dms-red); }

  .dms-item:hover { border-color: var(--dms-line); }
  .dms-item:active { transform: translateY(1px); }
  .dms-item.is-selected {
    border: #fff359 3px solid;
    background: #7070706e;
    /*box-shadow: inset 0 0 0 1px rgba(56,189,248,.4);*/
  }

  .dms-body { min-width: 0; }
  .dms-name-row { display: flex; align-items: baseline; gap: 10px; }
  .dms-id { font-size: 11px; color: var(--dms-accent); letter-spacing: .5px; }
  .dms-name {
    font-size: 14px; font-weight: 600; white-space: nowrap;
    overflow: hidden; text-overflow: ellipsis;
  }
  .dms-meta {
    margin-top: 4px; display: flex; flex-wrap: wrap; gap: 4px 14px;
    font-size: 0.8em;
    color: #b0b0b0;
  }
  .dms-meta span::before { content: " > "; color: var(--dms-faint); }
  .dms-meta span:first-child::before { content: ""; }

  .dms-tags { display: flex; flex-direction: row; gap: 5px; align-items: flex-end; justify-content: flex-end; flex-wrap: wrap; }
  .dms-chip {
    font-size: 10px; font-weight: 600; letter-spacing: .5px; text-transform: uppercase;
    padding: 3px 8px; border-radius: 999px; white-space: nowrap;
    border: 1px solid transparent;
  }
  .dms-chip[data-v="NONE"]      { color: var(--dms-faint); border-color: var(--dms-line); }
  .dms-chip[data-v="PENDING"]   { color: var(--dms-amber); background: rgba(246,181,69,.10); border-color: rgba(246,181,69,.3); }
  .dms-chip[data-v="DISAPPROVED"] { color: var(--dms-red); background: rgba(255,69,58,.10); border-color: rgba(255,69,58,.3); }
  .dms-chip[data-v="CANCELED"] { color: var(--dms-red); background: rgba(255,69,58,.10); border-color: rgba(255,69,58,.3); }
  .dms-chip[data-v="APPROVED"]  { color: var(--dms-green); background: rgba(65,209,145,.10); border-color: rgba(65,209,145,.3); }
  .dms-chip[data-v="COMPLETED"] { color: var(--dms-blue); background: rgba(122,162,255,.10); border-color: rgba(122,162,255,.3); }
  .dms-chip[data-v="ACTIVE"]    { color: #3ab1ca; border-color: #0fabef6b; }
  
  /* empty state */
  .dms-empty { padding: 44px 20px; text-align: center; color: var(--dms-muted); }
  .dms-empty b { display: block; color: var(--dms-text); font-size: 14px; margin-bottom: 5px; }
  .dms-empty span { font-size: 12.5px; }

  .dms :focus-visible { outline: 2px solid var(--dms-accent); outline-offset: 2px; border-radius: 8px; }

  @media (prefers-reduced-motion: reduce) {
    .dms * { animation: none !important; transition: none !important; }
  }
  /* stack the band on narrow screens */
  @media (max-width: 720px) {
    .dms-grid { grid-template-columns: 1fr; }
    .dms-aside { border-right: 0; border-bottom: 1px solid var(--dms-line); }
    .dms-secondary-button { margin-top: 4px; }
  }
  @media (max-width: 560px) {
    .dms-item { grid-template-columns: 1fr; }
    .dms-tags { flex-direction: row; flex-wrap: wrap; }
  }