/**
 * /assets/css/gm-quests.css
 *
 * Purpose:  GM Quest-Management Tab Styles
 *           Quest-Cards, Edit-Modal, Objective-Flags, Badge-Items
 * Deps:     app.css (variables), group-quests.css (shared quest styles)
 * Load:     index.php
 * Version:  5.0.0 – Quest Detail Modal: Sections, Objectives, Participants
 * Version:  4.0.0 – Quest-Ketten: Locked-Card Styling
 * Version:  3.0.0 – Unified Type-Picker Buttons, NPC-Picker
 */

/* ============================================================================
   GM QUESTS PANEL
   ============================================================================ */
.gm-quests-panel {
  max-width: 900px;
}

/* ============================================================================
   QUEST CARD
   ============================================================================ */
.gmq-card {
  position: relative;
  background: rgba(255,255,255,.04);
  backdrop-filter: blur(12px) saturate(1.3);
  -webkit-backdrop-filter: blur(12px) saturate(1.3);
  border: 1px solid rgba(255,255,255,.08);
  border-left: 3px solid var(--quest-color, rgba(77,163,255,.35));
  border-radius: .75rem;
  padding: 1rem;
  margin-bottom: .75rem;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.gmq-card:hover {
  border-color: var(--quest-color, rgba(77,163,255,.5));
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
}
.gmq-card--completed {
  opacity: .65;
  border-left-color: rgba(255,211,107,.3);
}
.gmq-card--failed {
  opacity: .55;
  border-left-color: rgba(255,107,107,.3);
}

/* ============================================================================
   CARD HEADER
   ============================================================================ */
.gmq-card-header {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
}
.gmq-card-icon {
  width: 38px;
  height: 38px;
  border-radius: .6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1rem;
}
.gmq-card-title-wrap {
  flex: 1;
  min-width: 0;
}
.gmq-card-title {
  font-weight: 600;
  font-size: .95rem;
  line-height: 1.3;
  color: rgba(255,255,255,.95);
  margin-bottom: .2rem;
}
.gmq-card-meta {
  display: flex;
  align-items: center;
  gap: .4rem;
  flex-wrap: wrap;
}
.gmq-card-actions {
  display: flex;
  gap: .3rem;
  flex-shrink: 0;
}
.gmq-card-actions .btn {
  padding: .2rem .45rem;
  font-size: .72rem;
  border-radius: .45rem;
}

/* ============================================================================
   CARD BODY
   ============================================================================ */
.gmq-card-body {
  margin-top: .65rem;
  padding-top: .6rem;
  border-top: 1px solid rgba(255,255,255,.06);
}
.gmq-detail {
  font-size: .8rem;
  color: rgba(255,255,255,.5);
  margin-bottom: .4rem;
}
.gmq-description {
  font-size: .82rem;
  color: rgba(255,255,255,.65);
  line-height: 1.5;
  margin-bottom: .4rem;
}
.gmq-section {
  padding: .4rem .5rem;
  background: rgba(255,255,255,.02);
  border-radius: .4rem;
  border: 1px solid rgba(255,255,255,.04);
}
.gmq-reward-badge {
  font-size: .75rem;
  color: var(--rw-color, var(--gold, #ffd36b));
  display: inline-flex;
  align-items: center;
  gap: .2rem;
  padding: .25rem .5rem;
  background: color-mix(in srgb, var(--rw-color, var(--gold, #ffd36b)) 8%, transparent);
  border-radius: .35rem;
  border: 1px solid color-mix(in srgb, var(--rw-color, var(--gold, #ffd36b)) 15%, transparent);
}

/* ============================================================================
   OBJECTIVES
   ============================================================================ */
.gmq-objectives {
  margin-top: .65rem;
  padding-top: .5rem;
  border-top: 1px solid rgba(255,255,255,.06);
}
.gmq-obj-header {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: .4rem;
}
.gmq-obj-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.gmq-obj {
  display: flex;
  align-items: flex-start;
  gap: .45rem;
  padding: .25rem 0;
  font-size: .82rem;
  color: rgba(255,255,255,.8);
}
.gmq-obj--done {
  color: rgba(255,255,255,.4);
}
.gmq-obj--hidden {
  border-left: 2px solid rgba(160,120,255,.3);
  padding-left: .5rem;
}
.gmq-obj--sub {
  padding-left: 1.5rem;
  font-size: .78rem;
}
.gmq-obj-toggle,
.gmq-substep-toggle {
  background: none;
  border: none;
  color: rgba(255,255,255,.4);
  padding: 0;
  cursor: pointer;
  font-size: .85rem;
  line-height: 1;
  transition: color .2s, transform .15s;
  flex-shrink: 0;
  margin-top: .1rem;
}
.gmq-obj-toggle:hover,
.gmq-substep-toggle:hover {
  color: var(--accent, #5dd6c9);
  transform: scale(1.15);
}
.gmq-obj--done .gmq-obj-toggle,
.gmq-obj--done .gmq-substep-toggle {
  color: var(--accent, #5dd6c9);
}
.gmq-obj-check {
  color: rgba(255,255,255,.25);
  font-size: .85rem;
  flex-shrink: 0;
  margin-top: .1rem;
}
.gmq-obj--done .gmq-obj-check {
  color: var(--accent, #5dd6c9);
}
.gmq-obj-text {
  flex: 1;
  line-height: 1.4;
}
.gmq-obj-flag {
  font-size: .65rem;
  flex-shrink: 0;
  padding: .1rem .25rem;
  border-radius: 4px;
}
.gmq-obj-flag--optional {
  color: #60a5fa;
  background: rgba(96,165,250,.1);
}
.gmq-obj-flag--hidden {
  color: #a78bfa;
  background: rgba(160,120,255,.1);
}

/* ============================================================================
   NOTES / PARTICIPANTS / COMPLETED
   ============================================================================ */
.gmq-notes {
  margin-top: .6rem;
  padding-top: .4rem;
  border-top: 1px solid rgba(255,255,255,.06);
}
.gmq-notes-text {
  font-size: .8rem;
  color: rgba(255,255,255,.55);
  line-height: 1.5;
  padding: .35rem .5rem;
  background: rgba(255,255,255,.03);
  border-radius: .35rem;
  border: 1px solid rgba(255,255,255,.06);
}
.gmq-participants {
  margin-top: .6rem;
  padding-top: .4rem;
  border-top: 1px solid rgba(255,255,255,.06);
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.gmq-completed-info {
  margin-top: .4rem;
  font-size: .72rem;
  color: rgba(255,255,255,.35);
  padding-top: .4rem;
  border-top: 1px solid rgba(255,255,255,.04);
}

/* ============================================================================
   FILTERS (reuse quest-status-filter / quest-cat-filter patterns)
   ============================================================================ */
.gmq-status-filter.active,
.gmq-cat-filter.active {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.25);
  color: #fff;
}
.gmq-cat-filter.active {
  border-color: var(--cat-color);
  color: var(--cat-color);
  background: color-mix(in srgb, var(--cat-color) 12%, transparent);
}
.gmq-status-filter:hover,
.gmq-cat-filter:hover {
  background: rgba(255,255,255,.08);
}

/* ============================================================================
   EDIT MODAL – Form Controls
   ============================================================================ */
.gmq-modal-input {
  background: rgba(0,0,0,.3) !important;
  border-color: rgba(255,255,255,.1) !important;
  color: rgba(255,255,255,.85) !important;
  font-size: .82rem !important;
}
.gmq-modal-input:focus {
  border-color: var(--accent, #5dd6c9) !important;
  box-shadow: 0 0 0 .15rem rgba(93,214,201,.15) !important;
}
.gmq-modal-input::placeholder {
  color: rgba(255,255,255,.3) !important;
}

/* Category Picker Buttons */
.gmq-cat-pick-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: .4rem .7rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: .5rem;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  transition: all .2s;
  font-size: .78rem;
}
.gmq-cat-pick-btn:hover {
  border-color: var(--cat-color);
  background: color-mix(in srgb, var(--cat-color) 8%, transparent);
}
.gmq-cat-pick-btn.--active {
  border-color: var(--cat-color);
  background: color-mix(in srgb, var(--cat-color) 15%, transparent);
  color: var(--cat-color);
  font-weight: 600;
}

/* Type Picker Buttons (Reward/Prereq type selection) */
.gmq-type-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: .4rem .7rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: .5rem;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  transition: all .2s;
  font-size: .78rem;
}
.gmq-type-btn:hover {
  border-color: var(--type-color);
  background: color-mix(in srgb, var(--type-color) 8%, transparent);
  color: var(--type-color);
}
.gmq-type-btn.--active {
  border-color: var(--type-color);
  background: color-mix(in srgb, var(--type-color) 15%, transparent);
  color: var(--type-color);
  font-weight: 600;
  box-shadow: 0 0 10px color-mix(in srgb, var(--type-color) 20%, transparent);
}
.gmq-type-btn i {
  font-size: .85rem;
}

/* NPC Picker Grid */
.gmq-npc-picker .gmq-item-grid {
  max-height: 140px;
}

/* Badge Items (prerequisites, reward items, required items) */
.gmq-badge-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: .2rem .5rem;
  font-size: .72rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--badge-color, #fff) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--badge-color, #fff) 25%, transparent);
  color: var(--badge-color, #fff);
}
.gmq-badge-remove {
  background: none;
  border: none;
  color: inherit;
  padding: 0;
  cursor: pointer;
  font-size: .8rem;
  line-height: 1;
  opacity: .5;
  transition: opacity .2s;
}
.gmq-badge-remove:hover {
  opacity: 1;
}

/* Objective edit rows in modal */
.gmq-obj-edit-row {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .3rem .4rem;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: .4rem;
  margin-bottom: .3rem;
  font-size: .8rem;
}
.gmq-obj-edit-text {
  flex: 1;
  color: rgba(255,255,255,.8);
}
.gmq-obj-edit-toggle {
  background: none;
  border: none;
  padding: .15rem .25rem;
  cursor: pointer;
  font-size: .7rem;
  transition: opacity .2s;
  color: rgba(255,255,255,.5);
}
.gmq-obj-edit-toggle:hover {
  opacity: 1;
}
.gmq-obj-edit-remove {
  background: none;
  border: none;
  color: rgba(255,107,107,.5);
  padding: .15rem .25rem;
  cursor: pointer;
  font-size: .7rem;
  transition: color .2s;
}
.gmq-obj-edit-remove:hover {
  color: #ff6b6b;
}

/* Objective flag buttons (new obj input) */
.gmq-obj-flag-btn {
  font-size: .72rem !important;
  padding: .2rem .4rem !important;
  transition: background .2s, color .2s;
}
.gmq-obj-flag-btn.--active {
  background: rgba(93,214,201,.15) !important;
  border-color: var(--accent, #5dd6c9) !important;
  color: var(--accent, #5dd6c9) !important;
}

/* Hero selection buttons */
.gmq-hero-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: .35rem .6rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: .5rem;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  transition: all .2s;
  font-size: .78rem;
}
.gmq-hero-btn:hover {
  border-color: rgba(93,214,201,.4);
  background: rgba(93,214,201,.06);
}
.gmq-hero-btn.--selected {
  border-color: var(--accent, #5dd6c9);
  background: rgba(93,214,201,.12);
  color: var(--accent, #5dd6c9);
  font-weight: 600;
}
.gmq-hero-img {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.15);
}

/* ============================================================================
   WIZARD SECTIONS (Item-Picker, Skill-Picker, Fraktions-Effekte)
   ============================================================================ */
.gmq-wizard-section {
  padding: .6rem;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: .5rem;
}

/* ── Item Picker Grid ── */
.gmq-item-picker {
  margin-top: .3rem;
}
.gmq-item-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: 140px;
  overflow-y: auto;
  padding: .3rem;
  background: rgba(0,0,0,.15);
  border-radius: .4rem;
  border: 1px solid rgba(255,255,255,.04);
}
.gmq-item-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: .3rem .55rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: .4rem;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  transition: all .2s;
  font-size: .75rem;
  white-space: nowrap;
}
.gmq-item-btn:hover {
  border-color: rgba(255,211,107,.4);
  background: rgba(255,211,107,.06);
}
.gmq-item-btn.--selected {
  border-color: var(--gold, #ffd36b);
  background: rgba(255,211,107,.15);
  color: var(--gold, #ffd36b);
  font-weight: 600;
  box-shadow: 0 0 8px rgba(255,211,107,.15);
}
.gmq-item-btn i {
  font-size: .8rem;
}

/* ── Faction Effect Controls ── */
.gmq-faction-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.gmq-faction-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  padding: .35rem .5rem;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: .4rem;
}
.gmq-faction-info {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .8rem;
  color: rgba(255,255,255,.8);
  min-width: 0;
  flex: 1;
}
.gmq-faction-info i {
  font-size: .85rem;
  flex-shrink: 0;
}
.gmq-faction-info span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.gmq-faction-controls {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.gmq-faction-delta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 28px;
  padding: .15rem .35rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: .3rem;
  color: rgba(255,255,255,.6);
  cursor: pointer;
  font-size: .7rem;
  font-weight: 600;
  transition: all .15s;
}
.gmq-faction-delta-btn:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.25);
  color: #fff;
}
.gmq-faction-delta-btn[data-delta^="-"]:hover {
  border-color: rgba(255,107,107,.4);
  color: #ff6b6b;
  background: rgba(255,107,107,.08);
}
.gmq-faction-delta-btn:not([data-delta^="-"]):hover {
  border-color: rgba(40,167,69,.4);
  color: #28a745;
  background: rgba(40,167,69,.08);
}
.gmq-faction-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 28px;
  font-size: .78rem;
  font-weight: 700;
  color: rgba(255,255,255,.5);
  text-align: center;
  border-radius: .3rem;
  background: rgba(0,0,0,.2);
  border: 1px solid rgba(255,255,255,.06);
}
.gmq-faction-value.gmq-fv-pos {
  color: #28a745;
  border-color: rgba(40,167,69,.25);
  background: rgba(40,167,69,.08);
}
.gmq-faction-value.gmq-fv-neg {
  color: #ff6b6b;
  border-color: rgba(255,107,107,.25);
  background: rgba(255,107,107,.08);
}

/* ============================================================================
   QUEST DETAIL MODAL (read-only)
   ============================================================================ */
.gmq-detail-row {
  font-size: .85rem;
  color: rgba(255,255,255,.75);
  margin-bottom: .5rem;
  padding: .35rem .5rem;
  background: rgba(255,255,255,.03);
  border-radius: .4rem;
  border: 1px solid rgba(255,255,255,.05);
}
.gmq-detail-row strong {
  color: rgba(255,255,255,.5);
  font-weight: 500;
  margin-right: .3rem;
}
.gmq-detail-section {
  margin-bottom: .75rem;
  padding: .6rem .7rem;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: .5rem;
}
.gmq-detail-label {
  font-size: .75rem;
  font-weight: 600;
  color: rgba(255,255,255,.45);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: .4rem;
}
.gmq-detail-text {
  font-size: .85rem;
  color: rgba(255,255,255,.7);
  line-height: 1.6;
}
.gmq-detail-obj-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.gmq-detail-obj {
  display: flex;
  align-items: flex-start;
  gap: .3rem;
  padding: .3rem 0;
  font-size: .85rem;
  color: rgba(255,255,255,.8);
}
.gmq-detail-obj--done {
  color: rgba(255,255,255,.4);
}
.gmq-detail-obj--hidden {
  border-left: 2px solid rgba(160,120,255,.3);
  padding-left: .5rem;
}
.gmq-detail-obj--sub {
  padding-left: 1.8rem;
  font-size: .8rem;
}
.gmq-detail-participant {
  padding: .25rem .5rem;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: .5rem;
}

/* ============================================================================
   LIGHT MODE
   ============================================================================ */
[data-bs-theme="light"] .gmq-card {
  background: rgba(255,255,255,.7);
  border-color: rgba(0,0,0,.08);
}
[data-bs-theme="light"] .gmq-card:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
}
[data-bs-theme="light"] .gmq-card-title {
  color: #212529;
}
[data-bs-theme="light"] .gmq-description {
  color: rgba(0,0,0,.6);
}
[data-bs-theme="light"] .gmq-obj {
  color: rgba(0,0,0,.7);
}
[data-bs-theme="light"] .gmq-obj-toggle,
[data-bs-theme="light"] .gmq-substep-toggle {
  color: rgba(0,0,0,.3);
}
[data-bs-theme="light"] .gmq-obj--done .gmq-obj-toggle {
  color: #5dd6c9;
}
[data-bs-theme="light"] .gmq-notes-text {
  background: rgba(0,0,0,.02);
  border-color: rgba(0,0,0,.06);
  color: rgba(0,0,0,.55);
}
[data-bs-theme="light"] .gmq-status-filter.active,
[data-bs-theme="light"] .gmq-cat-filter.active {
  background: rgba(0,0,0,.06);
}
[data-bs-theme="light"] .gmq-wizard-section {
  background: rgba(0,0,0,.02);
  border-color: rgba(0,0,0,.08);
}
[data-bs-theme="light"] .gmq-item-grid {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.06);
}
[data-bs-theme="light"] .gmq-item-btn {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.1);
  color: rgba(0,0,0,.7);
}
[data-bs-theme="light"] .gmq-item-btn.--selected {
  background: rgba(255,193,7,.1);
  border-color: #ffc107;
  color: #946b00;
}
[data-bs-theme="light"] .gmq-faction-row {
  background: rgba(0,0,0,.02);
  border-color: rgba(0,0,0,.08);
}
[data-bs-theme="light"] .gmq-faction-info {
  color: #212529;
}
[data-bs-theme="light"] .gmq-faction-delta-btn {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.1);
  color: rgba(0,0,0,.5);
}
[data-bs-theme="light"] .gmq-faction-value {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.08);
  color: rgba(0,0,0,.4);
}
[data-bs-theme="light"] .gmq-type-btn {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.1);
  color: rgba(0,0,0,.7);
}
[data-bs-theme="light"] .gmq-type-btn.--active {
  background: color-mix(in srgb, var(--type-color) 10%, transparent);
  border-color: var(--type-color);
  color: var(--type-color);
}

/* ============================================================================
   RESPONSIVE — Touch-friendly buttons for mobile/tablet GM use
   ============================================================================ */

/* Tablet (≤992px): enlarge all interactive elements */
@media (max-width: 992px) {
  /* Card action buttons — large touch targets */
  .gmq-card-actions {
    gap: .4rem;
  }
  .gmq-card-actions .btn {
    padding: .5rem .7rem;
    font-size: .95rem;
    border-radius: .5rem;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* Create button */
  #gmQuestCreateBtn {
    padding: .65rem 1rem;
    font-size: 1rem;
    min-height: 48px;
  }

  /* Status + category filter buttons */
  .gmq-status-filter,
  .gmq-cat-filter {
    padding: .45rem .7rem !important;
    font-size: .9rem !important;
    min-height: 42px;
  }

  /* Objective toggles — bigger tap area */
  .gmq-obj-toggle,
  .gmq-substep-toggle {
    font-size: 1.15rem;
    padding: .3rem;
    min-width: 40px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .gmq-obj-check {
    font-size: 1.1rem;
  }

  /* Type picker — larger buttons on tablet */
  .gmq-type-btn {
    padding: .45rem .7rem;
    font-size: .85rem;
    min-height: 40px;
  }

  /* Item picker — larger buttons on tablet */
  .gmq-item-btn {
    padding: .4rem .65rem;
    font-size: .85rem;
    min-height: 38px;
  }

  /* Faction controls — bigger touch targets */
  .gmq-faction-delta-btn {
    min-width: 40px;
    height: 36px;
    font-size: .8rem;
  }
  .gmq-faction-value {
    min-width: 44px;
    height: 36px;
    font-size: .85rem;
  }
}

/* Mobile (≤576px): even larger for one-hand use */
@media (max-width: 576px) {
  .gmq-card {
    padding: .7rem;
  }
  .gmq-card-icon {
    width: 32px;
    height: 32px;
    font-size: .85rem;
  }
  .gmq-card-title {
    font-size: .85rem;
  }

  /* Card action buttons — extra large on phone */
  .gmq-card-header {
    flex-wrap: wrap;
  }
  .gmq-card-actions {
    width: 100%;
    gap: .5rem;
    margin-top: .5rem;
  }
  .gmq-card-actions .btn {
    flex: 1;
    padding: .6rem .5rem;
    font-size: 1rem;
    min-height: 48px;
  }

  /* Create button */
  #gmQuestCreateBtn {
    padding: .75rem 1rem;
    font-size: 1.05rem;
    min-height: 52px;
  }

  /* Status + category filters — wrap nicely */
  .gmq-status-filter,
  .gmq-cat-filter {
    padding: .5rem .75rem !important;
    font-size: .95rem !important;
    min-height: 44px;
  }

  /* Objective toggles */
  .gmq-obj-toggle,
  .gmq-substep-toggle {
    font-size: 1.25rem;
    min-width: 44px;
    min-height: 44px;
  }
  .gmq-obj {
    padding: .35rem 0;
  }

  /* Faction row — stack on small screens */
  .gmq-faction-row {
    flex-wrap: wrap;
  }
  .gmq-faction-info {
    width: 100%;
    margin-bottom: .25rem;
  }
  .gmq-faction-controls {
    width: 100%;
    justify-content: center;
  }
  .gmq-faction-delta-btn {
    min-width: 44px;
    height: 40px;
    font-size: .85rem;
  }
  .gmq-faction-value {
    min-width: 48px;
    height: 40px;
    font-size: .9rem;
  }
}

/* ============================================================================
   PRINT
   ============================================================================ */
@media print {
  .gmq-card-actions,
  #gmQuestCreateBtn,
  .gmq-status-filter,
  .gmq-cat-filter { display: none !important; }
  .gmq-card { break-inside: avoid; }
}

/* ============================================================================
   ACCESSIBILITY
   ============================================================================ */
/* ============================================================================
   LOCKED QUEST CARD
   ============================================================================ */
.gmq-card--locked {
  opacity: .6;
  border-left-color: rgba(255,193,7,.3) !important;
}
.gmq-card--locked .gmq-card-body,
.gmq-card--locked .gmq-objectives {
  filter: saturate(.5);
}
.gmq-card--locked .gmq-card-actions .btn[disabled] {
  opacity: .35;
  cursor: not-allowed;
  pointer-events: none;
}

/* ============================================================================
   ACCESSIBILITY
   ============================================================================ */
@media (prefers-reduced-motion: reduce) {
  .gmq-card,
  .gmq-obj-toggle,
  .gmq-substep-toggle,
  .gmq-cat-pick-btn,
  .gmq-type-btn,
  .gmq-hero-btn,
  .gmq-item-btn,
  .gmq-faction-delta-btn {
    transition: none !important;
  }
}
