/* QuickStand Marketplace – UI aligned with QuickStand base styles (Grid Cards V1) */

:root{
  /* Match QuickStand palette used across Dashboard/Settings */
  --qs-bg:#ffffff;
  --qs-card:#ffffff;
  --qs-text:#003366;
  --qs-muted:#667085;
  --qs-border:#e6e6e6;

  --qs-primary:#003366;
  --qs-accent:#0094FF;

  --qs-shadow:0 5px 20px rgba(0,0,0,0.08);
  --qs-radius:16px;
  --qs-radius-sm:12px;

  --qs-success-bg:#e9f7ef;
  --qs-success-text:#1e6b3b;

  --qs-warn-bg:#fff1d6;
  --qs-warn-text:#8a4b00;

  --qs-danger-bg:#fff0f0;
  --qs-danger-text:#b00020;
}

.qs-mp-wrap,
.qs-mp-wrap *{ box-sizing:border-box; }

.qs-mp-wrap{
  max-width:960px;
  margin:0 auto;
  padding:16px;
}

.qs-mp-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.qs-mp-title{
  margin:0;
  font-size:22px;
  letter-spacing:-0.01em;
  color:var(--qs-text);
}

.qs-mp-sub{
  margin:4px 0 0 0;
  color:var(--qs-muted);
  font-size:13px;
}

.qs-mp-head-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}


.qs-context-links{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}

.qs-context-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid var(--qs-border);
  background:rgba(255,255,255,0.78);
  color:var(--qs-text);
  text-decoration:none;
  font-size:13px;
  font-weight:700;
  line-height:1;
  transition:background .12s ease, border-color .12s ease, transform .12s ease;
}

.qs-context-link:hover{
  background:rgba(0,148,255,0.07);
  border-color:rgba(0,148,255,0.24);
  transform:translateY(-1px);
}

.qs-context-link:focus-visible{
  outline:3px solid rgba(0,148,255,0.24);
  outline-offset:2px;
}

/* Tabs (dashboard-like pills) */
.qs-tabs{
  display:flex;
  gap:10px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom:2px;
  margin:12px 0;
}

.qs-tab{
  flex:0 0 auto;
  border:1px solid var(--qs-border);
  background:#f7fbff;
  color:var(--qs-text);
  border-radius:999px;
  padding:8px 12px;
  cursor:pointer;
  font-weight:700;
  white-space:nowrap;
  text-decoration:none;
  transition:background .12s ease, border-color .12s ease, transform .12s ease;
}

.qs-tab:hover{
  border-color:rgba(0,148,255,0.25);
  background:rgba(0,148,255,0.06);
  transform:translateY(-1px);
}

.qs-tab.is-active{
  border-color:rgba(0,148,255,0.35);
  background:rgba(0,148,255,0.10);
}

/* Search / Filter bar */
.qs-mp-bar{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin:10px 0 8px;
}

.qs-input,
.qs-select{
  padding:12px 14px;
  border:1px solid var(--qs-border);
  border-radius:var(--qs-radius-sm);
  background:#fff;
  color:var(--qs-text);
  font:inherit;
}

.qs-input{
  flex:1;
  min-width:220px;
}

.qs-input::placeholder{ color:var(--qs-muted); }

.qs-input:focus-visible,
.qs-select:focus-visible{
  outline:3px solid rgba(0,148,255,0.25);
  outline-offset:3px;
}

.qs-select{ cursor:pointer; }

/* Buttons */
.qs-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  border-radius:var(--qs-radius-sm);
  padding:12px 14px;
  font-weight:900;
  cursor:pointer;
  border:1px solid #cfe0ff;
  background:#f3f7ff;
  color:var(--qs-primary);
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease, background .12s ease;
}

.qs-btn:hover{
  transform:translateY(-1px);
  filter:brightness(0.98);
}

.qs-btn:focus-visible{
  outline:3px solid rgba(0,148,255,0.25);
  outline-offset:3px;
}

/* Support both naming conventions */
.qs-btn.primary,
.qs-btn-primary{
  background:var(--qs-primary);
  color:#fff;
  border-color:transparent;
}

.qs-btn.small{
  padding:9px 12px;
  font-weight:800;
  border-radius:10px;
  font-size:13px;
}

.qs-btn.is-disabled,
.qs-btn[aria-disabled="true"]{
  opacity:.6;
  }

.qs-btn.is-ghost{
  background:#fff;
  border-color:var(--qs-border);
  color:var(--qs-text);
}

/* Filter chips */
.qs-chips{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:8px 0 14px;
}

.qs-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border:1px solid var(--qs-border);
  border-radius:999px;
  background:#fff;
  font-size:13px;
  color:var(--qs-text);
  cursor:pointer;
}

.qs-chip:hover{ border-color:rgba(0,148,255,0.25); }

.qs-chip span{
  display:inline-block;
  margin-left:2px;
  color:var(--qs-muted);
  font-weight:900;
}

/* GRID: 1 col mobile, 2 tablet, 3 desktop */
.qs-grid{
  display:grid;
  gap:12px;
  grid-template-columns:1fr;
}

@media (min-width: 720px){
  .qs-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

@media (min-width: 900px){
  .qs-grid{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
}

/* Cards */
.qs-card{
  background:var(--qs-card);
  border:1px solid var(--qs-border);
  border-radius:var(--qs-radius);
  padding:16px;
  box-shadow:0 3px 12px rgba(0,0,0,0.06);
  transition:border-color .12s ease, transform .12s ease, box-shadow .12s ease;
  height:100%;
  display:flex;
  flex-direction:column;
}

.qs-card:hover{
  border-color:rgba(0,148,255,0.22);
  transform:translateY(-1px);
  box-shadow:0 10px 26px rgba(0,0,0,0.08);
}

.qs-card a{ color:inherit; text-decoration:none; }

/* FIX: .qs-card-link was missing closing brace in your paste */
.qs-card-link{
  display:flex;
  flex-direction:column;
  gap:8px;
  height:100%;
}

/* Card thumbnail */
.qs-thumb{
  width:100%;
  height:140px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,0.06);
  background:rgba(0,0,0,0.02);
  object-fit:cover;
  display:block;
}

.qs-thumb.is-empty{
  height:140px;
  background:linear-gradient(135deg, rgba(0,148,255,0.10), rgba(0,0,0,0.02));
}

@media (max-width: 480px){
  .qs-thumb,
  .qs-thumb.is-empty{ height:120px; }
}

.qs-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}

.qs-card-body{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:0;
}

.qs-card-title{
  margin:0;
  font-size:16px;
  color:var(--qs-text);
  line-height:1.25;
  word-break:break-word;
}

.qs-meta{
  color:var(--qs-muted);
  font-size:13px;
}

/* Teaser + Actions (V1 helpers) */
.qs-card-teaser{
  color:var(--qs-muted);
  font-size:13px;
  line-height:1.45;
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
}

.qs-card-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
}

/* Row at bottom for event cards */
.qs-row{
  margin-top:auto;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
}

/* Status pills */
.qs-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--qs-border);
  background:#f7fbff;
  color:var(--qs-text);
  white-space:nowrap;
}

.qs-pill.free{
  border-color:rgba(30,107,59,0.25);
  background:var(--qs-success-bg);
  color:var(--qs-success-text);
}

.qs-pill.mid{
  border-color:rgba(138,75,0,0.25);
  background:var(--qs-warn-bg);
  color:var(--qs-warn-text);
}

.qs-pill.full{
  border-color:rgba(176,0,32,0.22);
  background:var(--qs-danger-bg);
  color:var(--qs-danger-text);
}

/* Backwards-compat for older markup used in some templates/JS */
.qs-card-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}

.qs-card-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--qs-border);
  background:#f7fbff;
  color:var(--qs-text);
  white-space:nowrap;
}

.qs-card-pill.is-full{
  border-color:rgba(176,0,32,0.22);
  background:var(--qs-danger-bg);
  color:var(--qs-danger-text);
}

/* Empty / loader */
.qs-empty{
  padding:30px 12px;
  color:var(--qs-muted);
  text-align:center;
}

.qs-loader{
  padding:18px 0;
  color:var(--qs-muted);
}

/* Modals */
.qs-modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.35);
  display:none;
  align-items:flex-end;
  justify-content:center;
  z-index:9999;
}

.qs-modal{
  background:var(--qs-card);
  border-radius:16px 16px 0 0;
  width:min(960px, 100%);
  padding:16px;
  border:1px solid var(--qs-border);
  box-shadow:0 18px 50px rgba(0,0,0,.18);
  max-height:calc(100vh - 60px);
  overflow:auto;
}

@media (min-width: 900px){
  .qs-modal-backdrop{ align-items:center; padding:20px; }
  .qs-modal{ border-radius:var(--qs-radius); width:min(640px, 100%); }
}

.qs-modal h3{ margin:0 0 10px 0; color:var(--qs-text); }

.qs-modal .qs-modal-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 0;
  border-top:1px solid rgba(0,0,0,0.06);
}

.qs-modal-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:12px;
}

/* Toast */
.qs-toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  background:var(--qs-primary);
  color:#fff;
  border-radius:999px;
  padding:10px 14px;
  display:none;
  gap:10px;
  align-items:center;
  z-index:10000;
  box-shadow:0 10px 30px rgba(0,0,0,0.18);
}

.qs-toast button{
  border:none;
  background:transparent;
  color:#fff;
  text-decoration:underline;
  cursor:pointer;
  font-weight:800;
}

/* Request modal textarea */
.qs-textarea{
  width:100%;
  border-radius:var(--qs-radius-sm);
  border:1px solid var(--qs-border);
  padding:12px 14px;
  font:inherit;
  color:var(--qs-text);
  resize:vertical;
}

/* Add-ons used in my_* pages */
.qs-actions-inline{
  margin-top:10px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.qs-actions-inline .qs-btn{
  padding:9px 12px;
  font-weight:800;
  border-radius:10px;
  font-size:13px;
}

/* Step 6 – Stand Details Modal (sections + badges + error) */
.qs-stand-head{
  display:flex;
  align-items:flex-start;
  gap:12px;
}

.qs-stand-avatar{
  width:56px;
  height:56px;
  flex:0 0 56px;
}

.qs-stand-avatar-img{
  width:56px;
  height:56px;
  border-radius:12px;
  object-fit:cover;
  display:block;
}

.qs-stand-fallback{
  width:56px;
  height:56px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:var(--qs-primary);
  background:rgba(0,148,255,0.10);
  border:1px solid rgba(0,148,255,0.18);
}

.qs-stand-head-main{
  flex:1;
  min-width:0;
}

.qs-stand-title{
  font-weight:900;
  font-size:18px;
  color:var(--qs-text);
  line-height:1.25;
  word-break:break-word;
}

.qs-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
}

.qs-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,0.08);
  background:rgba(0,0,0,0.03);
  font-weight:900;
  font-size:12px;
  color:var(--qs-text);
  white-space:nowrap;
}

.qs-badge.is-ok{
  background:var(--qs-success-bg);
  border-color:rgba(30,107,59,0.20);
  color:var(--qs-success-text);
}

.qs-badge.is-muted{
  background:rgba(0,0,0,0.04);
  border-color:rgba(0,0,0,0.10);
  color:var(--qs-muted);
}

.qs-badge.is-soft{
  background:rgba(0,148,255,0.08);
  border-color:rgba(0,148,255,0.18);
  color:var(--qs-primary);
}

.qs-alert{
  margin-top:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(176,0,32,0.22);
  background:var(--qs-danger-bg);
  color:var(--qs-text);
  font-weight:800;
}

.qs-alert-actions{
  margin-top:8px;
  display:flex;
  justify-content:flex-end;
}

.qs-facts{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(0,0,0,0.06);
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}

@media (min-width: 720px){
  .qs-facts{ grid-template-columns:1fr 1fr; }
}

.qs-fact{
  display:flex;
  gap:10px;
  align-items:flex-start;
}

.qs-fact-label{
  min-width:92px;
  color:var(--qs-muted);
  font-weight:900;
}

.qs-fact-value{
  color:var(--qs-text);
  font-weight:900;
  word-break:break-word;
}

.qs-section-title{
  margin-top:14px;
  font-weight:900;
  color:var(--qs-text);
}

.qs-stand-bio{
  margin-top:8px;
  color:var(--qs-text);
  font-weight:700;
  line-height:1.5;
  white-space:pre-wrap;
}

.qs-stand-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  margin-top:12px;
}

/* Step 3 – Empty States (append-only, minimal) */
.qs-empty-title{
  font-weight:800;
  color:var(--qs-text);
  margin-bottom:6px;
}
.qs-empty-text{
  margin:0 auto;
  max-width:520px;
}
.qs-empty-actions{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}

/* Step 4 – Pagination (Load more) */
.qs-pager{
  margin-top:14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}
.qs-pager .qs-meta{ margin-top:0; }

/* -------------------------------------------------
   Bewerbungen-Management (Event Detail) – Styles
------------------------------------------------- */

.qs-info{
  border:1px solid var(--qs-border);
  background:#f7fbff;
  border-radius:var(--qs-radius);
  padding:12px 14px;
  color:var(--qs-text);
  margin:12px 0;
}

.qs-kpi{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  color:var(--qs-muted);
  font-size:13px;
  font-weight:700;
}
.qs-kpi strong{
  color:var(--qs-text);
  font-weight:900;
}

.qs-card.qs-app-card{ cursor:pointer; }

.qs-app-card .qs-app-top{
  display:flex;
  gap:12px;
  align-items:flex-start;
}

.qs-avatar{
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid var(--qs-border);
  object-fit:cover;
  background:#fff;
  flex:0 0 auto;
}

.qs-app-main{
  flex:1;
  min-width:0;
}

.qs-app-title{
  font-weight:900;
  font-size:14px;
  color:var(--qs-text);
}

.qs-app-sub{
  margin-top:3px;
  color:var(--qs-muted);
  font-size:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}

.qs-tag{
  display:inline-flex;
  align-items:center;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid var(--qs-border);
  background:#fff;
  color:var(--qs-text);
  font-weight:800;
  font-size:12px;
}

.qs-snippet{
  margin-top:8px;
  color:rgba(0,0,0,0.72);
  font-size:13px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.qs-mini-chips{
  margin-top:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.qs-mini-chip{
  font-size:12px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid var(--qs-border);
  background:#fff;
  color:var(--qs-text);
  font-weight:800;
}

.qs-mini-chip.is-on{
  border-color: rgba(0,148,255,0.28);
  background: rgba(0,148,255,0.06);
}

.qs-app-side{
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:flex-end;
}

.qs-app-actions-note{
  color:var(--qs-muted);
  font-size:12px;
  margin-top:8px;
}

/* Modal: detail header + close button */
.qs-modal .qs-modal-header{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:flex-start;
}

.qs-modal .qs-modal-close{
  border:none;
  background:transparent;
  font-size:20px;
  cursor:pointer;
  line-height:1;
  padding:6px 8px;
  border-radius:10px;
}

.qs-modal .qs-modal-close:hover{
  background: rgba(0,0,0,0.04);
}

/* Responsive: application card stacks nicer on small screens */
@media (max-width: 720px){
  .qs-app-card{
    flex-direction: column;
  }
  .qs-app-side{
    align-items: stretch;
    width: 100%;
  }
  .qs-actions-inline{
    justify-content: flex-start;
  }
}


/* -------------------------------------------------
   Step 11 – Accessibility polish (focus-visible)
   (append-only, no removals)
------------------------------------------------- */
.qs-tab:focus-visible,
.qs-chip:focus-visible{
  outline:3px solid rgba(0,148,255,0.25);
  outline-offset:3px;
}

.qs-modal .qs-btn:focus-visible,
.qs-modal button:focus-visible{
  outline:3px solid rgba(0,148,255,0.25);
  outline-offset:3px;
}


/* -------------------------------------------------
   Step 12 – Validation + Alerts (Request Modal)
   (append-only, no removals)
------------------------------------------------- */

/* Hint / helper text under fields */
.qs-help{
  margin-top:6px;
  color:var(--qs-muted);
  font-size:12px;
  font-weight:700;
  line-height:1.3;
}

/* Counter row under textarea */
.qs-form-meta{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:flex-start;
  margin-top:6px;
}

/* Field errors */
.qs-input.is-error,
.qs-select.is-error,
.qs-textarea.is-error,
.qs-input[aria-invalid="true"],
.qs-select[aria-invalid="true"],
.qs-textarea[aria-invalid="true"]{
  border-color: rgba(176,0,32,0.35);
  background: rgba(176,0,32,0.04);
}

/* Alert variants */
.qs-alert.is-info{
  border-color: rgba(0,148,255,0.22);
  background: rgba(0,148,255,0.08);
}

.qs-alert.is-success{
  border-color: rgba(30,107,59,0.25);
  background: var(--qs-success-bg);
  color: var(--qs-success-text);
}

/* -------------------------------------------------
   Step 13 – Request CTA polish (no active events)
   (append-only, no removals)
------------------------------------------------- */

/* Disabled form fields look intentional */
.qs-input:disabled,
.qs-select:disabled,
.qs-textarea:disabled{
  opacity:0.7;
  cursor:not-allowed;
  background:rgba(0,0,0,0.02);
}

/* Make modal actions wrap nicely when two buttons exist */
.qs-modal-actions{
  flex-wrap:wrap;
}

/* -------------------------------------------------
   Step 18 – Gate banner (compact, less "empty" look)
   (append-only, keeps existing markup)
------------------------------------------------- */
.qs-gate{
  padding:12px 14px;
  text-align:left;
  border:1px solid var(--qs-border);
  background:#f7fbff;
  border-radius:var(--qs-radius);
  margin:10px 0 12px;
}

.qs-gate .qs-gate-title{
  margin:0;
  color:var(--qs-text);
  font-size:14px;
}

.qs-gate .qs-meta{
  margin-top:4px;
}

.qs-gate .qs-gate-actions{
  margin-top:10px;
}

@media (min-width: 720px){
  .qs-gate{
    display:grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "title actions"
      "meta  actions";
    gap:6px 12px;
    align-items:center;
  }
  .qs-gate .qs-gate-title{ grid-area:title; }
  .qs-gate .qs-meta{ grid-area:meta; }
  .qs-gate .qs-gate-actions{
    grid-area:actions;
    margin-top:0 !important; /* overrides inline margin-top */
    justify-content:flex-end;
  }
}



/* Step 32 – Alert spacing (create/edit forms) */
.qs-alert{ margin-bottom:12px; }

/* =========================
   Marketplace Forms Helpers
========================= */

.qs-mp-wrap .qs-field{
  margin-top:14px;
}

.qs-mp-wrap .qs-field > label{
  display:block;
  font-weight:900;
  margin:0 0 6px 0;
  color:var(--qs-text);
}

.qs-mp-wrap .qs-form-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:14px;
}

.qs-mp-wrap .qs-form-row > .qs-field{
  flex:1 1 320px;
  min-width:240px;
  margin-top:0;
}

.qs-mp-wrap .qs-check-row{
  display:flex;
  align-items:center;
  gap:10px;
}

/* Event-Edit: etwas breiter + Cover-Row */
.qs-mp-wrap.qs-ee-wrap{
  max-width:1120px;
}

.qs-ee-wrap .qs-cover-row{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:flex-start;
}

.qs-ee-wrap .qs-cover-preview{
  flex:0 0 420px;
  max-width:480px;
  width:100%;
}

.qs-ee-wrap .qs-cover-preview-inner{
  aspect-ratio:16/9;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,0.06);
  background:rgba(0,0,0,0.02);
}

.qs-ee-wrap .qs-cover-preview-inner img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.qs-ee-wrap .qs-cover-empty{
  width:100%;
  height:100%;
  background:linear-gradient(135deg, rgba(0,148,255,0.12), rgba(0,0,0,0.02));
}

.qs-ee-wrap .qs-cover-controls{
  flex:1 1 320px;
  min-width:240px;
}

@media (max-width: 720px){
  .qs-ee-wrap .qs-cover-preview{
    flex:1 1 100%;
    max-width:none;
  }
}
/* =========================
   FIXES: Event Edit Layout
   - index.css globale form-Regeln sollen Marketplace nicht zerstören
   - Cover Preview muss fix im 16:9 sein
========================= */

/* Neutralisiert globale Regeln aus index.css wie z.B. form{max-width:600px; display:flex;} */
.qs-mp-wrap form{
  max-width:none !important;
  width:100% !important;
  display:block !important;
}

/* Forms sollen im Edit nicht “hover-liften” */
.qs-mp-wrap form.qs-card:hover{
  transform:none;
  box-shadow:0 3px 12px rgba(0,0,0,0.06);
  border-color:var(--qs-border);
}

/* Event Cover Block (passt zu deinem Markup: qs-ee-cover / qs-ee-cover-preview) */
.qs-ee-wrap .qs-ee-cover{ flex:1 1 420px; min-width:260px; }
.qs-ee-wrap .qs-ee-cover-hints{ flex:1 1 260px; min-width:220px; }

/* Preview fix: 16:9 + nichts darf die Seite sprengen */
.qs-ee-wrap .qs-ee-cover-preview{
  width:100%;
  aspect-ratio:16/9;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,0.06);
  background:rgba(0,0,0,0.02);
  display:flex;
  align-items:center;
  justify-content:center;
}

.qs-ee-wrap .qs-ee-cover-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.qs-ee-wrap .qs-ee-cover-preview span{
  color:var(--qs-muted);
  font-weight:800;
}

/* File input soll volle Breite haben */
.qs-ee-wrap input[type="file"].qs-input{
  width:100%;
  flex:initial;
  min-width:0;
}

/* =================================================
   Event-Edit V2 – Layout & Spacing Fixes
   - nicer cover layout (preview left, controls right)
   - better file button + filename
   - extra bottom padding (footer overlay)
================================================= */

.qs-mp-wrap.qs-ee-wrap{
  padding-bottom: 110px; /* prevent footer overlap */
}

/* Direct children cards: consistent spacing */
.qs-ee-wrap > .qs-card{
  margin-top: 14px;
}

/* Cover grid */
.qs-ee-wrap .qs-ee-cover-grid{
  display:grid;
  grid-template-columns: minmax(0, 560px) 1fr;
  gap:16px;
  align-items:start;
  margin-top: 6px;
}

@media (max-width: 900px){
  .qs-ee-wrap .qs-ee-cover-grid{
    grid-template-columns: 1fr;
  }
}

/* Cover preview */
.qs-ee-wrap .qs-ee-cover-preview{
  width:100%;
  aspect-ratio:16/9;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,0.06);
  background:rgba(0,0,0,0.02);
  display:flex;
  align-items:center;
  justify-content:center;
}

.qs-ee-wrap .qs-ee-cover-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.qs-ee-wrap .qs-ee-cover-preview span{
  color:var(--qs-muted);
  font-weight:800;
}

/* Hide the native file input but keep it functional */
.qs-ee-wrap .qs-ee-cover-controls{ position:relative; }
.qs-ee-wrap .qs-ee-file-input{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  }

/* File row (button + filename) */
.qs-ee-wrap .qs-ee-file-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.qs-ee-wrap .qs-ee-file-name{
  font-size:13px;
  color:var(--qs-muted);
  font-weight:800;
}

/* Remove row */
.qs-ee-wrap .qs-ee-remove-row{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(0,0,0,0.06);
}

.qs-ee-wrap .qs-ee-remove-label{
  display:inline-flex;
  gap:10px;
  align-items:center;
  font-weight:900;
  color:var(--qs-text);
}

/* =================================================
   Event-Edit V3 – Button/Checkbox Fixes
   - label-based file picker (always works)
   - remove checkbox aligned + nicer size
================================================= */

.qs-ee-wrap .qs-ee-file-input{
  /* keep hidden but clickable via <label for="cover_image"> */
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
}

.qs-ee-wrap .qs-ee-remove-row{
  display:flex;
  align-items:center;
  gap:10px;
}

.qs-ee-wrap .qs-ee-remove-row input[type="checkbox"]{
  width:18px;
  height:18px;
  accent-color: var(--qs-primary);
}

.qs-ee-wrap .qs-ee-remove-row label{
  margin:0;
  font-weight:900;
  color:var(--qs-text);
}


/* =================================================
   Event-Create V2 – Cropper + Footer Spacing
   - cropper UI on create (same as edit)
   - extra bottom padding so footer doesn't overlap
================================================= */

.qs-mp-wrap.qs-ec-wrap{
  padding-bottom: 110px;
}

/* Cover layout on create */
.qs-ec-wrap .qs-ec-cover{
  display:grid;
  grid-template-columns: minmax(0, 560px) 1fr;
  gap:16px;
  align-items:start;
  margin-top: 6px;
}

@media (max-width: 900px){
  .qs-ec-wrap .qs-ec-cover{
    grid-template-columns: 1fr;
  }
}

.qs-ec-wrap .qs-ec-cover-controls{ position:relative; }

/* Reuse edit helpers on create */
.qs-ec-wrap .qs-ee-cover-preview{
  width:100%;
  aspect-ratio:16/9;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,0.06);
  background:rgba(0,0,0,0.02);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

.qs-ec-wrap .qs-ee-cover-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.qs-ec-wrap .qs-ee-cover-preview span{
  color:var(--qs-muted);
  font-weight:800;
}

/* Hide real file input but keep it working */
.qs-ec-wrap .qs-ee-file-input{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
}

/* File row */
.qs-ec-wrap .qs-ee-file-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.qs-ec-wrap .qs-ee-file-name{
  font-size:13px;
  color:var(--qs-muted);
  font-weight:800;
}

/* =================================================
   Marketplace UI Polish – Less Flat (Event Create/Edit)
   - page background tint so white cards pop
   - stronger separators + nicer checkbox layout
   - extra bottom padding for fixed footer
================================================= */

:root{
  --qs-page-bg:#f7fbff;
}

/* Marketplace pages: give the page a subtle tint */
html, body{
  background: var(--qs-page-bg);
}

/* Slightly stronger card separation */
.qs-card{
  border-color: rgba(0, 51, 102, 0.10);
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
}

/* Make labels + helpers easier to scan */
.qs-mp-title{
  letter-spacing: -0.01em;
}
.qs-mp-sub{
  font-weight: 700;
}

/* Checkbox rows: keep checkbox + text on one line */
.qs-check-row label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:0;
}
.qs-check-row input[type="checkbox"]{
  width:18px;
  height:18px;
  accent-color: var(--qs-primary);
}

/* Footer overlap safety (if footer is fixed) */
.qs-mp-wrap.qs-ec-wrap,
.qs-mp-wrap.qs-ee-wrap{
  padding-bottom: 160px;
}


/* =================================================
   Marketplace UI V2 – Contrast & Form Polish
   - Fix nested checkbox labels (display/spacing)
   - Add more contrast to Event Create page (less “white on white”)
================================================= */

/* Checkbox rows look like real controls */
.qs-mp-wrap .qs-check-row label{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0;
  font-weight:900;
  color:var(--qs-text);
}

.qs-mp-wrap .qs-check-row input[type="checkbox"]{
  width:18px;
  height:18px;
  accent-color: var(--qs-primary);
}

/* Event Create: make page less colorless */
.qs-mp-wrap.qs-ec-wrap{
  background: linear-gradient(180deg, rgba(0,148,255,0.06), rgba(0,148,255,0.02));
  border: 1px solid rgba(0,148,255,0.10);
  border-radius: 22px;
  padding: 20px;
}

@media (max-width: 520px){
  .qs-mp-wrap.qs-ec-wrap{ padding: 14px; border-radius: 18px; }
}

/* Inside create: stronger card separation */
.qs-ec-wrap .qs-card{
  border-color: rgba(0,51,102,0.10);
  box-shadow: 0 10px 28px rgba(0,0,0,0.07);
}

/* Head looks a bit more “header-like” */
.qs-ec-wrap .qs-mp-head{
  padding: 10px 10px 14px 10px;
  border-bottom: 1px solid rgba(0,51,102,0.08);
  margin: 0 0 14px 0;
}

/* Labels get a subtle accent bar (more scannable) */
.qs-ec-wrap .qs-field > label{
  position:relative;
  padding-left:12px;
}

.qs-ec-wrap .qs-field > label::before{
  content:"";
  position:absolute;
  left:0;
  top:0.35em;
  width:4px;
  height:1.1em;
  border-radius:999px;
  background: rgba(0,148,255,0.65);
}

/* Empty cover preview: nicer than flat grey */
.qs-ec-wrap .qs-ee-cover-preview{
  background: linear-gradient(135deg, rgba(0,148,255,0.10), rgba(0,0,0,0.02));
  border-color: rgba(0,148,255,0.14);
}

/* Keep footer safe space */
.qs-mp-wrap.qs-ec-wrap{
  padding-bottom: 130px;
}

/* ==========================================================================
   Milestone F6 — Marketplace Visual System & Listing Refresh
   ========================================================================== */
.qs-sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.qs-mp-wrap{
  max-width:1240px;
  padding:20px 18px 32px;
}

.qs-mp-hero{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.qs-mp-head{
  gap:18px;
  align-items:stretch;
}

.qs-mp-hero-copy{
  flex:1 1 620px;
  min-width:0;
}

.qs-mp-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:30px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(0, 148, 255, 0.10);
  border:1px solid rgba(0, 148, 255, 0.16);
  color:var(--qs-primary);
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  text-transform:uppercase;
}

.qs-mp-title{
  margin:14px 0 0;
  font-size:clamp(28px, 4vw, 40px);
  line-height:1.05;
}

.qs-mp-sub{
  margin:10px 0 0;
  max-width:760px;
  font-size:15px;
  line-height:1.55;
  color:#4c627b;
}

.qs-mp-head-actions{
  gap:10px;
  align-self:flex-start;
}

.qs-mp-hero-pills{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.qs-mp-hero-pill{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 12px;
  border-radius:999px;
  background:#f8fbff;
  border:1px solid rgba(0, 51, 102, 0.10);
  color:var(--qs-text);
  font-size:13px;
  font-weight:800;
}

.qs-mp-hero-pill.is-accent{
  background:rgba(0,148,255,0.10);
  border-color:rgba(0,148,255,0.22);
}

.qs-mp-surface{
  border:1px solid rgba(0, 51, 102, 0.10);
  background:
    radial-gradient(circle at top right, rgba(0,148,255,0.12), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,255,0.98));
  border-radius:24px;
  padding:16px;
  box-shadow:0 16px 36px rgba(0, 31, 63, 0.08);
}

.qs-tabs{
  margin:0;
  gap:8px;
}

.qs-tab{
  min-height:40px;
  padding:9px 14px;
  background:#fff;
  border-color:rgba(0, 51, 102, 0.10);
}

.qs-tab.is-active{
  background:var(--qs-primary);
  color:#fff;
  border-color:transparent;
  box-shadow:0 10px 24px rgba(0, 51, 102, 0.18);
}

.qs-mp-bar{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto auto;
  gap:12px;
  align-items:stretch;
  margin:14px 0 0;
}

.qs-mp-search{
  min-width:0;
}

.qs-mp-bar .qs-input,
.qs-mp-bar .qs-select,
.qs-mp-bar .qs-btn{
  min-height:48px;
}

.qs-input,
.qs-select{
  border-color:rgba(0, 51, 102, 0.12);
  background:#fff;
}

.qs-select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  padding-right:42px;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(0, 51, 102, 0.55) 50%),
    linear-gradient(135deg, rgba(0, 51, 102, 0.55) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
}

.qs-chips{
  margin:14px 0 0;
  min-height:34px;
}

.qs-chip{
  min-height:34px;
  border-color:rgba(0, 51, 102, 0.12);
  background:#fff;
  font-weight:700;
}

.qs-chip span:first-child{
  color:var(--qs-text);
  font-weight:800;
}

.qs-chip span:last-child{
  margin-left:4px;
}

.qs-mp-results-meta{
  display:grid;
  gap:4px;
  margin-top:12px;
  padding:12px 14px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(0, 51, 102, 0.08);
}

.qs-mp-results-meta__title{
  color:var(--qs-text);
  font-size:14px;
  font-weight:900;
}

.qs-mp-results-meta__text{
  color:#5e738b;
  font-size:13px;
  line-height:1.45;
}

.qs-loader{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:96px;
  margin-top:16px;
  border-radius:18px;
  border:1px dashed rgba(0, 51, 102, 0.12);
  background:linear-gradient(180deg, rgba(255,255,255,0.92), rgba(247,250,255,0.95));
  font-weight:800;
}

.qs-empty{
  display:grid;
  gap:10px;
  margin-top:16px;
  padding:20px;
  border-radius:20px;
  border:1px solid rgba(0, 51, 102, 0.10);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,255,0.98));
  box-shadow:0 12px 30px rgba(0, 31, 63, 0.06);
}

.qs-empty-title{
  color:var(--qs-text);
  font-size:18px;
  font-weight:900;
}

.qs-empty-text{
  color:#5e738b;
  line-height:1.55;
}

.qs-empty-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:4px;
}

.qs-gate{
  margin-top:16px;
  background:
    radial-gradient(circle at top right, rgba(0,148,255,0.10), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,255,0.98));
  border-color:rgba(0, 51, 102, 0.10);
  border-radius:20px;
  padding:18px 18px;
}

.qs-gate .qs-gate-title{
  font-size:15px;
  font-weight:900;
}

.qs-gate .qs-meta{
  color:#5e738b;
}

#qsList.qs-grid{
  grid-template-columns:1fr;
  gap:16px;
  margin-top:16px;
}

.qs-discovery-card{
  display:flex;
  flex-direction:column;
  min-width:0;
  height:100%;
  border-radius:22px;
  border:1px solid rgba(0, 51, 102, 0.10);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98));
  box-shadow:0 14px 32px rgba(0, 31, 63, 0.08);
  overflow:hidden;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.qs-discovery-card:hover{
  transform:translateY(-2px);
  border-color:rgba(0,148,255,0.22);
  box-shadow:0 20px 42px rgba(0, 31, 63, 0.12);
}

.qs-discovery-card__media-link{
  display:block;
  text-decoration:none;
  color:inherit;
}

.qs-thumb{
  display:block;
  width:100%;
}

.qs-thumb--cover{
  height:210px;
  border:none;
  border-radius:0;
  background:linear-gradient(135deg, rgba(0,148,255,0.16), rgba(0, 51, 102, 0.04));
}

.qs-thumb--avatar{
  width:72px;
  height:72px;
  border-radius:50%;
  border:2px solid rgba(0, 51, 102, 0.08);
  background:linear-gradient(135deg, rgba(0,148,255,0.16), rgba(0, 51, 102, 0.04));
  object-fit:cover;
  flex:0 0 72px;
}

.qs-thumb--avatar.is-empty{
  display:flex;
  align-items:center;
  justify-content:center;
}

.qs-discovery-card__body{
  display:flex;
  flex-direction:column;
  gap:14px;
  height:100%;
  padding:18px;
}

.qs-discovery-card__eyebrow{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}

.qs-discovery-card__type,
.qs-discovery-card__eyebrow-text{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
}

.qs-discovery-card__type{
  background:rgba(0,148,255,0.10);
  color:var(--qs-primary);
}

.qs-discovery-card__eyebrow-text{
  background:#fff;
  border:1px solid rgba(0, 51, 102, 0.10);
  color:#536a83;
}

.qs-discovery-card__header{
  display:flex;
  gap:12px;
  justify-content:space-between;
  align-items:flex-start;
}

.qs-discovery-card__header--stand{
  align-items:flex-start;
}

.qs-discovery-card__title-wrap{
  min-width:0;
  display:grid;
  gap:6px;
}

.qs-discovery-card__title{
  margin:0;
  color:var(--qs-text);
  font-size:20px;
  line-height:1.2;
  word-break:break-word;
}

.qs-discovery-card__title-link{
  color:inherit;
  text-decoration:none;
}

.qs-discovery-card__title-link:hover{
  text-decoration:underline;
}

.qs-discovery-card__sub{
  color:#536a83;
  font-size:14px;
  line-height:1.45;
}

.qs-discovery-card__teaser{
  margin:0;
  color:#4e6278;
  font-size:14px;
  line-height:1.6;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.qs-discovery-card__chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.qs-discovery-card__chip{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  max-width:100%;
  padding:6px 10px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(0, 51, 102, 0.10);
  color:var(--qs-text);
  font-size:12px;
  font-weight:800;
  overflow-wrap:anywhere;
}

.qs-discovery-card__chip.is-accent{
  background:rgba(0,148,255,0.10);
  border-color:rgba(0,148,255,0.20);
}

.qs-discovery-card__chip.is-danger{
  background:rgba(176, 0, 32, 0.08);
  border-color:rgba(176, 0, 32, 0.14);
  color:#8f1834;
}

.qs-discovery-card__footer{
  margin-top:auto;
  display:flex;
  gap:12px;
  align-items:flex-end;
  justify-content:space-between;
  border-top:1px solid rgba(0, 51, 102, 0.08);
  padding-top:14px;
}

.qs-discovery-card__hint{
  flex:1;
  min-width:0;
  color:#5e738b;
  font-size:13px;
  line-height:1.5;
}

.qs-discovery-card__actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
  align-items:center;
}

.qs-stand-card__identity{
  display:flex;
  gap:14px;
  align-items:center;
  min-width:0;
}

.qs-stand-card__avatar-wrap{
  flex:0 0 auto;
}

.qs-pill{
  flex:0 0 auto;
  max-width:100%;
}

.qs-btn{
  border-radius:14px;
  font-weight:900;
}

.qs-btn.small{
  min-height:40px;
  padding:10px 13px;
}

.qs-pager{
  margin-top:18px;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(0, 51, 102, 0.08);
  background:#fff;
}

.qs-pager .qs-meta{
  color:#536a83;
  font-weight:800;
}

.qs-modal{
  border-radius:24px 24px 0 0;
}

.qs-modal h3{
  font-size:20px;
}

.qs-check{
  display:inline-flex;
  gap:10px;
  align-items:center;
  font-weight:700;
  color:var(--qs-text);
}

@media (min-width: 860px){
  #qsList.qs-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1360px){
  #qsList.qs-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 959px){
  .qs-mp-wrap{
    padding:16px 14px 28px;
  }

  .qs-mp-bar{
    grid-template-columns:1fr;
  }

  .qs-mp-head-actions{
    width:100%;
  }

  .qs-mp-head-actions .qs-btn{
    flex:1 1 auto;
  }
}

@media (max-width: 720px){
  .qs-mp-title{
    font-size:30px;
  }

  .qs-mp-surface{
    border-radius:20px;
    padding:14px;
  }

  .qs-thumb--cover{
    height:190px;
  }

  .qs-discovery-card__header,
  .qs-discovery-card__footer{
    flex-direction:column;
    align-items:stretch;
  }

  .qs-discovery-card__actions{
    justify-content:stretch;
  }

  .qs-discovery-card__actions .qs-btn,
  .qs-discovery-card__footer > .qs-btn{
    width:100%;
  }

  .qs-stand-card__identity{
    align-items:flex-start;
  }

  .qs-thumb--avatar{
    width:60px;
    height:60px;
    flex-basis:60px;
  }
}

@media (max-width: 480px){
  .qs-mp-wrap{
    padding-left:12px;
    padding-right:12px;
  }

  .qs-thumb--cover{
    height:168px;
  }

  .qs-discovery-card__body{
    padding:16px;
    gap:12px;
  }

  .qs-discovery-card__title{
    font-size:18px;
  }

  .qs-chip,
  .qs-discovery-card__chip,
  .qs-mp-hero-pill,
  .qs-discovery-card__type,
  .qs-discovery-card__eyebrow-text{
    font-size:11px;
  }
}



/* =================================================
   F7 – Organizer / Marktplatz Unterseiten Refresh
   - My Events visual alignment
   - Event create/edit hierarchy
   - Custom select controls for marketplace pages
================================================= */

.qs-mp-wrap.qs-me-wrap,
.qs-mp-wrap.qs-ec-wrap,
.qs-mp-wrap.qs-ee-wrap,
.qs-mp-wrap.qs-ed-wrap{
  max-width: 1120px;
}

.qs-org-form{
  position: relative;
  overflow: hidden;
  border-color: rgba(0, 51, 102, 0.12);
  box-shadow: 0 18px 42px rgba(0, 31, 73, 0.08);
  background:
    linear-gradient(180deg, rgba(0,148,255,0.06) 0%, rgba(0,148,255,0.02) 110px, #fff 110px, #fff 100%);
}

.qs-org-form::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height: 112px;
  background:
    radial-gradient(circle at top right, rgba(0,148,255,0.14), transparent 52%),
    linear-gradient(135deg, rgba(0,51,102,0.08), rgba(0,148,255,0.03));
  pointer-events:none;
}

.qs-org-form > *{
  position: relative;
  z-index: 1;
}

.qs-org-form-section-head{
  margin: 18px 0 12px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(0, 51, 102, 0.08);
  background: rgba(255,255,255,0.82);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.qs-org-form-section-head:first-of-type{
  margin-top: 4px;
}

.qs-org-form-section-head--compact{
  margin-top: 20px;
}

.qs-org-form-section-eyebrow{
  display:inline-flex;
  align-items:center;
  min-height: 28px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,148,255,0.09);
  border: 1px solid rgba(0,148,255,0.18);
  color: #0069d9;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.qs-org-form-section-title{
  margin: 10px 0 6px;
  color: var(--qs-text);
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.qs-org-form-section-sub{
  margin: 0;
  color: rgba(0, 31, 73, 0.72);
  line-height: 1.5;
  font-size: 14px;
}

.qs-org-form .qs-field,
.qs-org-form .qs-form-row{
  position: relative;
  z-index: 1;
}

.qs-org-form .qs-field + .qs-field,
.qs-org-form .qs-form-row + .qs-field,
.qs-org-form .qs-form-row + .qs-form-row{
  margin-top: 12px;
}

.qs-org-form .qs-input,
.qs-org-form .qs-textarea,
.qs-org-form .qs-cselect__trigger{
  min-height: 52px;
  border-radius: 16px;
  border-color: rgba(0, 51, 102, 0.12);
  background: rgba(255,255,255,0.94);
  box-shadow: 0 1px 0 rgba(255,255,255,0.65);
}

.qs-org-form .qs-textarea{
  min-height: 138px;
}

.qs-org-form .qs-help{
  max-width: 68ch;
}

.qs-org-form-actions{
  padding-top: 4px;
  border-top: 1px solid rgba(0,51,102,0.08);
}

.qs-org-sidecard{
  border-color: rgba(0,51,102,0.12);
  box-shadow: 0 14px 34px rgba(0,31,73,0.07);
}

.qs-me-summary{
  display:grid;
  gap:12px;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  margin: 0 0 14px;
}

.qs-me-summary-card{
  position:relative;
  overflow:hidden;
  padding:16px 18px;
  border-radius: 20px;
  border:1px solid rgba(0,51,102,0.10);
  background:
    radial-gradient(circle at top right, rgba(0,148,255,0.12), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,249,255,0.95));
  box-shadow: 0 12px 30px rgba(0,31,73,0.08);
}

.qs-me-summary-card::after{
  content:"";
  position:absolute;
  inset:auto 18px 0 18px;
  height:3px;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(0,51,102,0.95), rgba(0,148,255,0.75));
}

.qs-me-summary-eyebrow{
  display:block;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:#0069d9;
}

.qs-me-summary-value{
  display:block;
  margin-top:10px;
  color:var(--qs-text);
  font-size: clamp(26px, 4vw, 34px);
  line-height: 1;
}

.qs-me-summary-label{
  display:block;
  margin-top:8px;
  color: rgba(0,31,73,0.72);
  line-height:1.45;
  font-size: 14px;
}

.qs-me-callout{
  border-color: rgba(0,51,102,0.10);
  background: linear-gradient(180deg, rgba(248,252,255,0.96), rgba(255,255,255,0.98));
}

.qs-me-callout--danger{
  background: linear-gradient(180deg, rgba(255,244,247,0.98), rgba(255,255,255,0.98)) !important;
}

.qs-me-grid{
  gap:16px;
}

.qs-me-event-card{
  padding: 0;
  overflow: hidden;
}

.qs-me-card-link{
  display:flex;
  flex-direction:column;
  gap:0;
}

.qs-me-event-card .qs-thumb{
  height: 188px;
  border-radius: 0;
  border: 0;
}

.qs-me-event-card .qs-thumb.is-empty{
  background:
    radial-gradient(circle at top right, rgba(0,148,255,0.18), transparent 44%),
    linear-gradient(135deg, rgba(0,51,102,0.12), rgba(0,148,255,0.05));
}

.qs-me-event-card .qs-card-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  padding: 18px 18px 4px;
}

.qs-me-event-card .qs-card-body{
  min-width: 0;
}

.qs-me-event-card .qs-card-title{
  margin: 0;
  font-size: 20px;
  line-height: 1.12;
  letter-spacing: -0.02em;
}

.qs-me-event-card .qs-meta{
  color: rgba(0,31,73,0.72);
}

.qs-me-event-card .qs-pill{
  flex:0 0 auto;
}

.qs-me-event-card .qs-actions-split{
  padding: 0 18px 18px;
  margin-top: 0;
  border-top: 1px solid rgba(0,51,102,0.08);
  background: linear-gradient(180deg, rgba(247,251,255,0.4), rgba(255,255,255,0.98));
}

.qs-me-actions-split .qs-actions-left,
.qs-me-actions-split .qs-actions-right{
  gap: 8px;
}

.qs-me-actions-split .qs-btn.small{
  min-height: 40px;
}

.qs-ed-wrap .qs-mp-bar{
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.qs-ed-wrap .qs-card{
  border-color: rgba(0,51,102,0.10);
  box-shadow: 0 12px 28px rgba(0,31,73,0.07);
}

.qs-ed-wrap .qs-app-card{
  border: 1px solid rgba(0,51,102,0.08);
  border-radius: 18px;
  padding: 14px;
  background: linear-gradient(180deg, rgba(247,251,255,0.7), rgba(255,255,255,0.98));
}

.qs-ed-wrap .qs-app-card + .qs-app-card{
  margin-top: 12px;
}

/* ---------- Custom Select ---------- */
.qs-cselect{
  position: relative;
  width: 100%;
}

.qs-cselect .qs-select--native{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  pointer-events:none;
}

.qs-cselect__trigger{
  width:100%;
  min-height: 50px;
  padding: 12px 46px 12px 16px;
  border-radius: 16px;
  border: 1px solid rgba(0,51,102,0.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(244,249,255,0.96));
  color: var(--qs-text);
  font: inherit;
  font-weight: 800;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(0,31,73,0.06);
}

.qs-cselect__trigger:hover{
  border-color: rgba(0,148,255,0.24);
  transform: translateY(-1px);
}

.qs-cselect__trigger:focus-visible{
  outline: 3px solid rgba(0,148,255,0.22);
  outline-offset: 3px;
}

.qs-cselect__trigger-label{
  display:block;
  padding-right: 8px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.qs-cselect__trigger-icon{
  position:absolute;
  top:50%;
  right:16px;
  transform: translateY(-50%);
  color: rgba(0,51,102,0.58);
  font-size: 14px;
  transition: transform .14s ease;
}

.qs-cselect.is-open .qs-cselect__trigger-icon{
  transform: translateY(-50%) rotate(180deg);
}

.qs-cselect.is-disabled .qs-cselect__trigger{
  opacity: .65;
  cursor: not-allowed;
  transform:none;
}

.qs-cselect__dropdown{
  position:absolute;
  top: calc(100% + 8px);
  left:0;
  right:0;
  z-index: 40;
  display:none;
  border-radius: 18px;
  border: 1px solid rgba(0,51,102,0.10);
  background: rgba(255,255,255,0.98);
  box-shadow: 0 22px 38px rgba(0,31,73,0.18);
  overflow: hidden;
  backdrop-filter: blur(12px);
}

.qs-cselect.is-open .qs-cselect__dropdown{
  display:block;
}

.qs-cselect__list{
  max-height: 280px;
  overflow:auto;
  padding: 8px;
}

.qs-cselect__option{
  display:block;
  width:100%;
  border:0;
  background: transparent;
  border-radius: 14px;
  padding: 12px 14px;
  text-align:left;
  color: var(--qs-text);
  font: inherit;
  font-weight: 800;
  cursor:pointer;
}

.qs-cselect__option:hover,
.qs-cselect__option:focus-visible{
  background: rgba(0,148,255,0.08);
  outline:none;
}

.qs-cselect__option.is-selected{
  background: rgba(0,51,102,0.08);
  color: #0069d9;
}

.qs-cselect__empty{
  padding: 14px;
  color: var(--qs-muted);
  font-weight: 700;
}

@media (max-width: 1024px){
  .qs-me-summary{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px){
  .qs-me-event-card .qs-card-head{
    flex-direction: column;
  }

  .qs-org-form{
    background:
      linear-gradient(180deg, rgba(0,148,255,0.06) 0%, rgba(0,148,255,0.02) 88px, #fff 88px, #fff 100%);
  }
}

@media (max-width: 640px){
  .qs-me-event-card .qs-thumb{
    height: 162px;
  }

  .qs-me-event-card .qs-actions-split,
  .qs-me-actions-split .qs-actions-left,
  .qs-me-actions-split .qs-actions-right{
    width: 100%;
  }

  .qs-me-actions-split .qs-actions-right{
    justify-content: flex-start;
  }

  .qs-org-form-section-head{
    padding: 14px 14px;
    border-radius: 16px;
  }

  .qs-cselect__trigger{
    min-height: 48px;
    padding-left: 14px;
    padding-right: 42px;
  }
}
