/* ----------------------------- */
/* QUICKSTAND – HEADER (FINAL)   */
/* scoped to .qs-header          */
/* ----------------------------- */

/* Browser-Default-Spalt killen */
html, body{
  margin: 0;
  padding: 0;
}

:root{
  --qs-safe-left: env(safe-area-inset-left);
  --qs-safe-right: env(safe-area-inset-right);
  --qs-safe-top: env(safe-area-inset-top);
  --qs-safe-bottom: env(safe-area-inset-bottom);
}

/* verhindert Overflow (width:100% + padding) auf Seiten ohne globales box-sizing */
.qs-header,
.qs-header * ,
.qs-header *::before,
.qs-header *::after{
  box-sizing: border-box;
}

/* ----------------------------- */
/* SITE HEADER BASE              */
/* ----------------------------- */

.qs-header{
  display: flex;
  align-items: center;
  justify-content: flex-start;

  padding: 20px 40px;
  border-bottom: 1px solid #e6e6e6;

  position: sticky;
  top: 0;

  background: #fff;
  z-index: 9999;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);

  width: 100%;
  max-width: none;

  overflow: visible;

  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #003366;
}

/* NEU: rechter Cluster MUSS flex sein + nach rechts */
.qs-header .qs-header-right{
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.qs-header--public{
  background: rgba(255,255,255,0.98);
}

.qs-header--app{
  background: #fff;
}

/* ----------------------------- */
/* BRAND (Logo + Name)           */
/* ----------------------------- */

.qs-header .brand{
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}

.qs-header .brand-logo{
  display: block;
  width: auto;
  max-height: 40px;
  height: auto;
}

.qs-header .brand-name{
  font-size: 23px;
  font-weight: 700;
  color: #003366;
  font-family: inherit;
  white-space: nowrap;
  margin-left: 15px;
}

/* ----------------------------- */
/* ROLE BADGE                    */
/* ----------------------------- */

.qs-header .qs-header-right .qs-role-badge{
  margin: 0;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  background: #edf7ff;
  color: #003366;
  text-transform: uppercase;
  white-space: nowrap;
  flex: 0 0 auto;
}

/* Fallback (falls irgendwo noch altes Markup ohne .qs-header-right existiert) */
.qs-header > .qs-role-badge{
  margin-left: auto;
  margin-right: 12px;
}

.qs-header .qs-role-badge--admin{ background: #fff1d6; color: #8a4b00; }
.qs-header .qs-role-badge--staff{ background: #e9f7ef; color: #1e6b3b; }
.qs-header .qs-role-badge--viewer{ background: #f1f1f1; color: #444; }

/* ----------------------------- */
/* NAVIGATION                    */
/* ----------------------------- */

.qs-header .qs-header-right .top-nav{
  margin: 0;

  display: flex;
  gap: 20px;
  align-items: center;
  flex-wrap: nowrap;

  padding: 0;
  width: auto;
  min-width: 0;
}

/* Fallback für Legacy-Markup */
.qs-header > .top-nav{
  margin-left: auto;
}

.qs-header .top-nav a{
  text-decoration: none;
  color: #003366;
  font-weight: 500;

  transition: color 0.2s ease, background-color 0.2s ease;
  border-radius: 4px;
  padding: 8px 12px;

  white-space: nowrap;
}

.qs-header .top-nav a:hover{
  color: #0055a5;
  background-color: rgba(0, 51, 102, 0.05);
}
 .qs-header .top-nav a.is-active{
  color: #003366;
  background-color: rgba(0, 51, 102, 0.08);
  font-weight: 700;
}

.qs-header .top-nav .qs-nav-link--cta{
  background: rgba(0, 148, 255, 0.10);
  border: 1px solid rgba(0, 148, 255, 0.22);
}

.qs-header .top-nav .qs-nav-link--cta:hover{
  background: rgba(0, 148, 255, 0.16);
}

.qs-header .top-nav .qs-search-link{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(0, 51, 102, 0.12);
  background: rgba(0, 51, 102, 0.03);
}

.qs-header .top-nav .qs-search-link__icon{
  width: 18px;
  height: 18px;
  display: block;
  flex: 0 0 auto;
}

.qs-header .top-nav .qs-search-link__label{
  font-weight: 600;
}

.qs-header .top-nav .qs-search-link.is-active{
  background: rgba(0, 148, 255, 0.12);
  border-color: rgba(0, 148, 255, 0.24);
}

/* nav-form: shield gegen globale form{} Regeln */
.qs-header .top-nav .nav-form{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-direction: row;

  margin: 0;
  padding: 0;

  width: auto;
  max-width: none;
  min-width: 0;
}

/* nav buttons */
.qs-header .top-nav .nav-form button{
  all: unset;
  cursor: pointer;

  font-family: inherit;
  font-size: 1rem;
  color: #003366;
  font-weight: 500;

  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
  white-space: nowrap;

  padding: 8px 12px;
  border-radius: 4px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1.1;
}

.qs-header .top-nav .nav-form button:hover{
  background-color: rgba(0, 51, 102, 0.05);
  color: #0055a5;
}

/* ----------------------------- */
/* NOTIFICATION BUTTON           */
/* ----------------------------- */

.qs-header .qs-notif-btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 40px;
  height: 40px;
  border-radius: 999px;

  text-decoration: none;
  color: #003366;
  overflow: visible;
  isolation: isolate;

  flex: 0 0 auto;
}

.qs-header .qs-notif-btn:hover{
  background-color: rgba(0, 51, 102, 0.05);
  color: #0055a5;
}

.qs-header .qs-notif-icon{
  width: 20px;
  height: 20px;
  display: block;
}
.qs-header .qs-notif-icon path{
  fill: currentColor;
}

.qs-header .qs-notif-badge{
  position: absolute;
  top: -4px;
  right: -4px;

  min-width: 22px;
  height: 22px;
  padding: 0 6px;

  border-radius: 999px;
  border: 2px solid #fff;
  font-size: 11px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: -0.01em;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: #2d89ef;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  pointer-events: none;
  box-shadow: 0 8px 18px rgba(0, 51, 102, 0.18);
}

/* ----------------------------- */
/* PROFILE BUTTON + DROPDOWN     */
/* ----------------------------- */

.qs-header .profile-container{
  position: relative;
  display: inline-block;
  flex: 0 0 auto;
}

/* Button */
.qs-header .profile-btn{
  box-sizing: border-box;

  width: 40px;
  height: 40px;
  padding: 0;

  border: 3px solid #003366;
  border-radius: 50%;
  overflow: hidden;

  background: #edf7ff;
  cursor: pointer;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  transition: all 0.2s ease, transform 0.2s ease;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);

  line-height: 0; /* verhindert Bild-baseline “Shift” */
}

/* Hover nur auf Geräten, die wirklich Hover haben (verhindert iOS “stuck hover”) */
@media (hover: hover) and (pointer: fine){
  .qs-header .profile-btn:hover{
    transform: scale(1.05);
    border-color: #0055a5;
    background: #003366;
  }
}

/* Wenn Menü offen ist: kein Scale (sonst Rect-Messung kann springen) */
.qs-header .profile-btn[aria-expanded="true"]{ transform: none; }

/* Profilbild hart “zentrieren” + gegen Fremd-CSS abschirmen */
.qs-header .profile-pic{
  width: 100% !important;
  height: 100% !important;
  display: block !important;

  object-fit: cover !important;
  object-position: 50% 50% !important;

  border-radius: 50% !important;

  margin: 0 !important;
  padding: 0 !important;
  transform: none !important;
}

/* Dropdown (Profilmenü) – fixed + wird per JS positioniert (clamp), damit es nie off-screen ist */
#profileDropdown{
  display: none;

  position: fixed;
  left: 0;
  top: 0;
  right: auto;
  bottom: auto;

  background: #ffffff;
  border-radius: 12px;

  width: clamp(220px, 22vw, 320px);
  max-width: min(92vw, 320px);
  padding: 10px 10px;

  /* viele Menüpunkte => intern scrollen */
  max-height: min(60vh, 420px);
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;

  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
  z-index: 10050;

  transition: opacity 0.25s ease, transform 0.25s ease;
  opacity: 0;
  transform: translateY(-12px);

  pointer-events: none;

  /* falls JS es kurz in <body> verschiebt (Portal) */
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #003366;
}

#profileDropdown.show{
  display: block;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

#profileDropdown .dropdown-form{
  margin: 0;
  padding: 0;
}

#profileDropdown .dropdown-form button{
  width: 100%;
  padding: 10px 16px;

  background: #f4f6f8;
  border: none;
  text-align: left;

  font-size: 15px;
  color: #003366;
  font-weight: 500;

  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;

  border-radius: 8px;
  margin: 0 0 5px;
  display: block;
}

#profileDropdown .dropdown-form button:hover{
  background: #2d89ef;
  color: #fff;
  transform: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

#profileDropdown:focus-within{
  outline: 2px solid #0055a5;
  outline-offset: 2px;
}

/* ===========================================================
   RESPONSIVE
=========================================================== */

@media (max-width: 1024px){
  .qs-header{ padding: 18px 30px; }

  .qs-header .brand-logo{ max-height: 32px; }
  .qs-header .brand-name{ font-size: 18px; }

  .qs-header .qs-header-right .top-nav{ gap: 16px; }
  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button{
    padding: 6px 10px;
    font-size: 0.95rem;
  }

  .qs-header .profile-btn{ width: 38px; height: 38px; }
  #profileDropdown{ width: 170px; }
  #profileDropdown .dropdown-form button{
    font-size: 14px;
    padding: 8px 14px;
  }
}

@media (max-width: 768px){
  .qs-header{ padding: 15px 20px; }

  .qs-header .brand-logo{ max-height: 28px; }
  .qs-header .brand-name{ font-size: 17px; }

  .qs-header .qs-header-right{ gap: 10px; }

  .qs-header .qs-header-right .top-nav{ gap: 12px; }
  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button{
    padding: 5px 8px;
    font-size: 0.9rem;
  }

  .qs-header .profile-btn{ width: 36px; height: 36px; }
  #profileDropdown{ width: 160px; }
  #profileDropdown .dropdown-form button{
    font-size: 14px;
    padding: 8px 12px;
    margin: 0 0 4px;
  }
}

@media (max-width: 640px){
  .qs-header .top-nav .qs-search-link__label{
    display: none;
  }

  .qs-header .top-nav .qs-search-link{
    min-width: 40px;
    padding-inline: 10px;
  }
}

@media (max-width: 480px){
  .qs-header{
    padding: 12px 12px;
    flex-wrap: nowrap;
  }

  .qs-header .brand-name{ display: none; }
  .qs-header .brand-logo{ max-height: 26px; }

  .qs-header .qs-header-right .top-nav{
    gap: 8px;
    min-width: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button{
    padding: 4px 6px;
    font-size: 0.85rem;
  }

  .qs-header .qs-notif-btn{
    width: 36px;
    height: 36px;
  }

  .qs-header .profile-btn{
    width: 34px;
    height: 34px;
    border-width: 2px;
  }

  .qs-header .qs-header-right .qs-role-badge{
    font-size: 10px;
    padding: 4px 8px;
  }
}

@media (max-width: 360px){
  .qs-header .qs-header-right .qs-role-badge{ display: none; }
}

/* ----------------------------- */
/* ----------------------------- */
/* PROFILE COMPLETENESS BANNER   */
/* ----------------------------- */
.qs-profile-banner{
  position: sticky;
  top: calc(var(--qs-header-h, 78px) + 10px);
  z-index: 9998;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 420px);
  align-items: center;
  gap: 24px;
  width: calc(100% - 32px);
  max-width: 1400px;
  margin: 14px auto 0;
  padding: 18px 24px 18px 20px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.985), rgba(247,250,254,0.975));
  box-shadow: 0 8px 22px rgba(0, 51, 102, 0.08);
  transition: box-shadow .18s ease, transform .18s ease, opacity .18s ease;
}

.qs-profile-banner--with-shell{
  width: calc(100% - 128px);
  margin: 14px auto 0;
}
.qs-profile-banner--stand-edit .qs-profile-banner__dismiss-form{
  top: 10px;
  right: 10px;
}


.qs-profile-banner__main{
  min-width: 0;
  display: grid;
  gap: 14px;
}

.qs-profile-banner__lead{
  min-width: 0;
  display: grid;
  gap: 10px;
}

.qs-profile-banner__headline{
  min-width: 0;
  display: grid;
  gap: 10px;
}

.qs-profile-banner__eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(0,148,255,0.15);
  background: rgba(0,148,255,0.08);
  color:#0b4f95;
  font-size:11px;
  font-weight:800;
  letter-spacing:0.01em;
}

.qs-profile-banner__title{
  font-weight: 800;
  color: #003366;
  font-size: 22px;
  line-height: 1.1;
}

.qs-profile-banner__meta{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  font-size:12px;
  color:#5d728a;
  font-weight:700;
}

.qs-profile-banner__meta span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 11px;
  border-radius:999px;
  background: rgba(0,51,102,0.045);
  border:1px solid rgba(0,51,102,0.07);
}

.qs-profile-banner__bar{
  width: min(360px, 100%);
  height: 8px;
  background: rgba(214, 224, 236, 0.96);
  border-radius: 999px;
  overflow: hidden;
  box-shadow: inset 0 1px 1px rgba(255,255,255,0.7);
}

.qs-profile-banner__bar span{
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #0f7eea 0%, #2a9df6 100%);
}

.qs-profile-banner__side{
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  justify-self: end;
  align-self: end;
  margin-top: 40px;
}

.qs-profile-banner__next{
  min-width: 0;
  display:grid;
  gap:4px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(0, 51, 102, 0.08);
  background: rgba(248, 251, 255, 0.96);
  color: #5d728a;
}

.qs-profile-banner__next span{
  font-size: 11px;
  font-weight:700;
  letter-spacing:0.02em;
  text-transform: uppercase;
}

.qs-profile-banner__next strong{
  color:#003366;
  font-size:18px;
  font-weight:800;
  line-height:1.25;
  overflow-wrap:anywhere;
}


.qs-profile-banner__cta{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  align-self:center;
}

.qs-profile-banner__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 20px;
  border-radius:999px;
  background: linear-gradient(180deg, #1483f5 0%, #0f72de 100%);
  color:#ffffff;
  text-decoration:none;
  font-size:14px;
  font-weight:800;
  border: 1px solid rgba(9, 97, 196, 0.22);
  white-space: nowrap;
  box-shadow: 0 8px 18px rgba(15, 114, 222, 0.18);
  transition: background-color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.qs-profile-banner__btn:visited,
.qs-profile-banner__btn:hover,
.qs-profile-banner__btn:focus-visible{
  color:#ffffff;
  text-decoration:none;
}

.qs-profile-banner__btn:hover,
.qs-profile-banner__btn:focus-visible{
  background: linear-gradient(180deg, #1179e6 0%, #0c67c8 100%);
  box-shadow: 0 10px 20px rgba(15, 114, 222, 0.22);
  transform: translateY(-1px);
  outline: none;
}

.qs-profile-banner__dismiss-form{
  position: absolute;
  top: 14px;
  right: 14px;
  margin: 0;
}

.qs-profile-banner__dismiss{
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(0, 51, 102, 0.09);
  background: rgba(255, 255, 255, 0.92);
  color: #62778f;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  transition: background-color .16s ease, color .16s ease, transform .16s ease;
}

.qs-profile-banner__dismiss:hover,
.qs-profile-banner__dismiss:focus-visible{
  background: rgba(236, 244, 252, 0.98);
  color: #003366;
  transform: translateY(-1px);
  outline: none;
}

@media (max-width: 1180px){
  .qs-profile-banner{
    grid-template-columns: 1fr;
    gap: 16px;
    align-items:flex-start;
  }

  .qs-profile-banner--with-shell{
    width: calc(100% - 112px);
    margin: 14px auto 0;
  }

  .qs-profile-banner__side{
    width: 100%;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    justify-self: stretch;
    align-self: end;
    margin-top: 20px;
  }
}


@media (max-width: 720px){
  .qs-profile-banner,
  .qs-profile-banner--with-shell{
    max-width: none;
    width: calc(100% - 24px);
    margin: 10px 12px 0;
    padding: 16px 20px 16px 15px;
    gap: 14px;
  }

  .qs-profile-banner__title{
    font-size: 20px;
  }

  .qs-profile-banner__bar{
    width: min(100%, 320px);
  }

  .qs-profile-banner__side{
    grid-template-columns: 1fr;
    gap: 10px;
    align-items: stretch;
    margin-top: 4px;
  }

  .qs-profile-banner__cta{
    width: auto;
    justify-content: flex-end;
  }

  .qs-profile-banner__btn{
    width: auto;
    min-width: 120px;
  }

  .qs-profile-banner__dismiss-form{
    top: 12px;
    right: 12px;
  }
}


/* ----------------------------- */
/* TOAST                         */
/* ----------------------------- */
#qsToast,
#qsToast.qs-toast--header{
  position: fixed;
  top: calc(var(--qs-header-h, 78px) + 18px);
  left: 50%;
  right: auto;
  bottom: auto;
  width: min(360px, calc(100vw - 32px));
  max-width: 360px;
  min-height: 0;
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid rgba(0, 148, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,250,255,0.98)),
    radial-gradient(circle at top right, rgba(0,148,255,0.12), transparent 56%);
  color: #003366;
  box-shadow: 0 20px 44px rgba(0, 51, 102, 0.18);
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(-8px) scale(.98);
  transition: opacity 0.2s ease, transform 0.2s ease;
  z-index: 10050;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
#qsToast.show,
#qsToast.qs-toast--header.show{
  opacity: 1;
  transform: translateX(-50%) translateY(0) scale(1);
  pointer-events: auto;
}
#qsToast .qs-toast__row{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}
#qsToast .qs-toast__icon{
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: rgba(31, 157, 99, 0.14);
  color: #157347;
  font-size: 15px;
  font-weight: 900;
  flex: 0 0 auto;
}
#qsToast .qs-toast__body{
  min-width:0;
  display:grid;
  gap:4px;
}
#qsToast .qs-toast__title{
  margin:0;
  font-size:14px;
  font-weight:800;
  color:#003366;
  line-height:1.4;
}
#qsToast .qs-toast__text{
  margin:0;
  font-size:13px;
  color: rgba(0, 51, 102, 0.72);
  line-height:1.5;
}
#qsToast .qs-toast__actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-top:2px;
}
#qsToast .qs-toast__link,
#qsToast .qs-toast__close{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:0 12px;
  border-radius:999px;
  text-decoration:none;
  font-size:13px;
  font-weight:800;
  cursor:pointer;
  transition:background-color .16s ease, border-color .16s ease, transform .16s ease;
}
#qsToast .qs-toast__link{
  border:1px solid rgba(0,148,255,0.20);
  background: rgba(0,148,255,0.10);
  color:#003366;
}
#qsToast .qs-toast__close{
  border:1px solid rgba(0,51,102,0.10);
  background: rgba(255,255,255,0.82);
  color:#003366;
}
#qsToast .qs-toast__link:hover,
#qsToast .qs-toast__close:hover{
  background: rgba(237,247,255,0.98);
  border-color: rgba(0,148,255,0.24);
  transform: translateY(-1px);
}
@media (max-width: 640px){
  #qsToast,
  #qsToast.qs-toast--header{
    top: calc(var(--qs-header-h, 72px) + 12px);
    left: auto;
    right: 14px;
    width: min(340px, calc(100vw - 28px));
    max-width: calc(100vw - 28px);
  }
  #qsToast .qs-toast__row{
    grid-template-columns:auto minmax(0,1fr);
  }
  #qsToast .qs-toast__close{
    grid-column: 1 / -1;
    justify-self: flex-end;
  }
}

/* ===========================================================
   QS HEADER SHIELD – damit Seitencss nichts zerstört
=========================================================== */

.qs-header .top-nav .nav-form{
  max-width: none !important;
  width: auto !important;
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 !important;
}


/* ===== Milestone 1: Shell/Header Polish ===== */
.qs-header {
  min-height: 72px;
  gap: 18px;
  padding: 16px 28px;
}

.qs-header .brand {
  gap: 14px;
}

.qs-header .brand-name {
  margin-left: 0;
  font-size: 20px;
  letter-spacing: -0.01em;
}

.qs-header .qs-header-right {
  gap: 14px;
}

.qs-header .top-nav {
  gap: 10px;
}

.qs-header .top-nav a,
.qs-header .top-nav .nav-form button {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  font-weight: 650;
}

.qs-header--public .top-nav a,
.qs-header--public .top-nav .qs-search-link {
  border: 1px solid rgba(0, 51, 102, 0.10);
  background: rgba(255, 255, 255, 0.88);
}

.qs-header--public .top-nav a.is-active,
.qs-header--public .top-nav .qs-search-link.is-active {
  background: rgba(0, 51, 102, 0.08);
  border-color: rgba(0, 51, 102, 0.16);
  color: #003366;
}

.qs-header--public .top-nav .qs-nav-link--cta {
  background: rgba(0, 148, 255, 0.08);
  border-color: rgba(0, 148, 255, 0.20);
}

.qs-header--app .top-nav .nav-link {
  border: 1px solid transparent;
  background: transparent;
}

.qs-header--app .top-nav .nav-link.is-active {
  background: rgba(0, 51, 102, 0.08);
  border-color: rgba(0, 51, 102, 0.10);
}

.qs-header--app .top-nav .qs-search-link,
.qs-header--app .qs-notif-btn {
  min-width: 42px;
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  background: rgba(0, 51, 102, 0.03);
}

.qs-header--app .top-nav .qs-search-link:hover,
.qs-header--app .qs-notif-btn:hover,
.qs-header--app .qs-notif-btn.is-active {
  background: rgba(0, 148, 255, 0.12);
  border-color: rgba(0, 148, 255, 0.20);
}

html.qs-has-app-bottomnav .qs-header--app {
  width: calc(100% + var(--qs-shell-offset, 0px));
  margin-left: calc(var(--qs-shell-offset, 0px) * -1);
  padding-left: calc(var(--qs-shell-offset, 0px) + 28px);
}

.dropdown-summary {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 6px 12px;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(0, 51, 102, 0.08);
}

.dropdown-summary__avatar {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  object-fit: cover;
  display: block;
  border: 1px solid rgba(0, 51, 102, 0.12);
  background: rgba(0, 148, 255, 0.06);
}

.dropdown-summary__copy {
  min-width: 0;
}

.dropdown-summary__title {
  font-size: 15px;
  font-weight: 750;
  color: #003366;
  line-height: 1.2;
}

.dropdown-summary__sub {
  margin-top: 3px;
  font-size: 12px;
  color: #667085;
  line-height: 1.35;
}

#profileDropdown {
  width: clamp(240px, 24vw, 320px);
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  box-shadow: 0 18px 40px rgba(0, 24, 58, 0.16);
}

#profileDropdown .dropdown-link,
#profileDropdown .dropdown-form button {
  min-height: 44px;
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0 14px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 650;
  color: #003366;
}

#profileDropdown .dropdown-link {
  text-decoration: none;
}

#profileDropdown .dropdown-link:hover,
#profileDropdown .dropdown-form button:hover {
  background: rgba(0, 148, 255, 0.10);
  color: #003366;
  box-shadow: none;
}

#profileDropdown .dropdown-form button {
  margin: 0;
  background: rgba(0, 51, 102, 0.04);
}

#profileDropdown .dropdown-sep {
  margin: 8px 6px;
  background: rgba(0, 51, 102, 0.08);
}

@media (min-width: 1000px) {
  html.qs-has-app-bottomnav .qs-header--app {
    padding-right: 30px;
  }
}

@media (max-width: 768px) {
  .qs-header {
    padding: 14px 18px;
    gap: 12px;
  }

  .qs-header .top-nav {
    gap: 8px;
  }

  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button {
    min-height: 38px;
    padding: 0 12px;
  }

  #profileDropdown {
    width: min(88vw, 300px);
  }

  .dropdown-summary__sub {
    font-size: 11px;
  }
}

@media (max-width: 480px) {
  .qs-header .brand-name {
    display: none;
  }

  .qs-header .top-nav .qs-search-link,
  .qs-header .qs-notif-btn,
  .qs-header .profile-btn {
    width: 38px;
    height: 38px;
  }

  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button {
    min-height: 36px;
    padding: 0 10px;
  }
}


/* ===== Milestone 1 refresh: shell / header / landing coherence ===== */
.qs-header {
  min-height: 78px;
  gap: 20px;
  padding: 16px 28px;
}

.qs-header .brand {
  min-width: 0;
  gap: 14px;
}

.qs-header .brand-name {
  margin-left: 0;
  font-size: 20px;
  letter-spacing: -0.02em;
}

.qs-header .qs-header-right {
  flex: 1 1 auto;
  justify-content: flex-end;
  gap: 12px;
  min-width: 0;
}

.qs-header .qs-role-badge {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(0, 51, 102, 0.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.qs-header .top-nav {
  gap: 10px;
  flex: 0 1 auto;
  min-width: 0;
}

.qs-header .top-nav a,
.qs-header .top-nav .nav-form button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

.qs-header .top-nav a.is-active,
.qs-header .top-nav .nav-form button.is-active {
  border-color: rgba(0, 51, 102, 0.10);
  box-shadow: 0 8px 18px rgba(0, 51, 102, 0.06);
}

.qs-header .top-nav .qs-search-link {
  min-width: 44px;
  padding: 0 14px;
  border-radius: 999px;
}

.qs-header .top-nav .qs-search-link__label {
  line-height: 1;
}

.qs-header .qs-notif-btn {
  width: 44px;
  height: 44px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  background: rgba(0, 51, 102, 0.03);
  box-shadow: 0 6px 16px rgba(0, 51, 102, 0.06);
}

.qs-header .qs-notif-btn.is-active,
.qs-header .qs-notif-btn:hover {
  background: rgba(0, 148, 255, 0.10);
  border-color: rgba(0, 148, 255, 0.18);
  color: #003366;
}

.qs-header .profile-btn {
  width: 44px;
  height: 44px;
  border-width: 2px;
  box-shadow: 0 8px 18px rgba(0, 51, 102, 0.10);
}

.qs-header .profile-btn[aria-expanded="true"] {
  border-color: rgba(0, 148, 255, 0.46);
  background: rgba(0, 148, 255, 0.08);
}

.qs-header--public,
.qs-header--landing {
  background: rgba(255,255,255,0.98);
}

.qs-header--public .top-nav a,
.qs-header--landing .top-nav a {
  background: rgba(255,255,255,0.92);
  border-color: rgba(0, 51, 102, 0.10);
}

.qs-header--public .top-nav a.is-active,
.qs-header--landing .top-nav a.is-active {
  background: rgba(0, 51, 102, 0.08);
  border-color: rgba(0, 51, 102, 0.14);
}

.qs-header--public .top-nav .qs-nav-link--cta {
  background: rgba(0, 148, 255, 0.08);
  border-color: rgba(0, 148, 255, 0.20);
}

.qs-header--landing {
  box-shadow: 0 8px 22px rgba(0, 29, 61, 0.06);
}

.qs-header--app .top-nav .nav-link {
  background: transparent;
}

.qs-header--app .top-nav .nav-link.is-active {
  background: rgba(0, 51, 102, 0.08);
}

html.qs-has-app-bottomnav .qs-header.qs-header--app,
html.qs-has-app-bottomnav .qs-header.qs-header--landing {
  width: calc(100% + var(--qs-shell-offset, 0px));
  margin-left: calc(var(--qs-shell-offset, 0px) * -1);
  padding-left: calc(var(--qs-shell-offset, 0px) + 26px);
  padding-right: 26px;
}

html.qs-has-app-bottomnav .qs-header.qs-header--landing {
  width: 100%;
  margin-left: 0;
  padding-left: 26px;
}

#profileDropdown {
  width: clamp(250px, 24vw, 330px);
  border-radius: 20px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  box-shadow: 0 24px 46px rgba(0, 24, 58, 0.16);
  padding: 12px;
}

#profileDropdown .dropdown-summary {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 4px 4px 12px;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(0, 51, 102, 0.08);
}

#profileDropdown .dropdown-summary__avatar {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid rgba(0, 51, 102, 0.10);
}

#profileDropdown .dropdown-summary__title {
  font-size: 15px;
  font-weight: 760;
  line-height: 1.25;
}

#profileDropdown .dropdown-summary__sub {
  margin-top: 3px;
  font-size: 12px;
  color: #667085;
}

#profileDropdown .dropdown-link,
#profileDropdown .dropdown-form button {
  min-height: 46px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  width: 100%;
  border-radius: 14px;
}

@media (max-width: 1100px) {
  .qs-header {
    padding: 14px 20px;
  }

  .qs-header .brand-name {
    font-size: 18px;
  }

  .qs-header .top-nav {
    gap: 8px;
  }

  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button {
    min-height: 40px;
    padding: 0 13px;
  }

  .qs-header .qs-role-badge {
    display: none;
  }
}

@media (max-width: 768px) {
  .qs-header {
    min-height: 68px;
    padding: 12px 14px;
    gap: 12px;
  }

  .qs-header .brand {
    gap: 10px;
  }

  .qs-header .brand-name {
    font-size: 18px;
  }

  .qs-header .qs-header-right {
    gap: 8px;
  }

  .qs-header .top-nav {
    gap: 8px;
  }

  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button {
    min-height: 38px;
    padding: 0 11px;
  }

  .qs-header .qs-notif-btn,
  .qs-header .profile-btn {
    width: 40px;
    height: 40px;
  }
}

@media (max-width: 560px) {
  .qs-header .brand-name {
    display: none;
  }

  .qs-header .top-nav .nav-link {
    padding-inline: 12px;
  }

  #profileDropdown {
    width: min(88vw, 320px);
  }
}


/* ===== Milestone 1 final shell pass ===== */
.qs-header {
  position: relative;
  gap: 16px;
}

.qs-header .brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: #003366;
  flex: 0 0 auto;
}

.qs-header .brand-logo {
  height: 42px;
}

.qs-header .qs-header-right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: 0;
}

.qs-header .top-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: 0;
}

.qs-header .top-nav a,
.qs-header .top-nav .nav-form button {
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  font-weight: 700;
  line-height: 1;
  box-sizing: border-box;
}

.qs-header--app .top-nav .nav-link {
  border: 1px solid rgba(0, 51, 102, 0.10);
  background: rgba(255, 255, 255, 0.92);
}

.qs-header--app .top-nav .nav-link:hover,
.qs-header--app .top-nav .nav-link.is-active {
  border-color: rgba(0, 51, 102, 0.14);
  background: rgba(0, 51, 102, 0.08);
  box-shadow: 0 8px 18px rgba(0, 51, 102, 0.06);
}

.qs-header--app .top-nav .qs-search-link {
  width: auto !important;
  min-width: 44px !important;
  height: 44px;
  padding: 0 14px 0 12px !important;
  border-radius: 999px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 8px 18px rgba(0, 51, 102, 0.06);
}

.qs-header--app .top-nav .qs-search-link:hover,
.qs-header--app .top-nav .qs-search-link.is-active {
  border-color: rgba(0, 148, 255, 0.22);
  background: rgba(0, 148, 255, 0.08);
}

.qs-header--app .top-nav .qs-search-link__icon {
  width: 18px;
  height: 18px;
}

.qs-header--app .top-nav .qs-search-link__label {
  display: inline-block;
  line-height: 1;
  font-weight: 700;
}

.qs-header .qs-notif-btn {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 8px 18px rgba(0, 51, 102, 0.06);
}

.qs-header .qs-notif-btn:hover,
.qs-header .qs-notif-btn.is-active {
  border-color: rgba(0, 148, 255, 0.22);
  background: rgba(0, 148, 255, 0.08);
}

.qs-header .profile-btn {
  width: 44px !important;
  height: 44px !important;
  border: 1px solid rgba(0, 51, 102, 0.16);
  background: #ffffff;
  box-shadow: 0 10px 22px rgba(0, 51, 102, 0.10);
}

.qs-header .profile-btn:hover,
.qs-header .profile-btn[aria-expanded="true"] {
  border-color: rgba(0, 148, 255, 0.28);
  background: rgba(0, 148, 255, 0.08);
}

html.qs-has-app-bottomnav .qs-header.qs-header--app {
  width: calc(100% + var(--qs-shell-offset, 0px));
  margin-left: calc(var(--qs-shell-offset, 0px) * -1);
  padding-left: 18px;
  padding-right: 18px;
}

#profileDropdown {
  width: clamp(252px, 24vw, 340px);
  border-radius: 24px;
  border: 1px solid rgba(0, 51, 102, 0.10);
  box-shadow: 0 26px 50px rgba(0, 24, 58, 0.18);
  padding: 12px;
  overflow-x: hidden;
}

#profileDropdown .dropdown-summary {
  padding: 4px 6px 12px;
  margin-bottom: 8px;
}

#profileDropdown .dropdown-link,
#profileDropdown .dropdown-form button {
  box-sizing: border-box;
  width: 100%;
  min-height: 48px;
  padding: 0 14px;
  border-radius: 14px;
  margin: 0 0 2px;
  text-decoration: none;
  font-weight: 700;
}

#profileDropdown .dropdown-link:hover,
#profileDropdown .dropdown-link:focus-visible,
#profileDropdown .dropdown-form button:hover,
#profileDropdown .dropdown-form button:focus-visible {
  background: rgba(0, 148, 255, 0.10);
  outline: none;
}

#profileDropdown .dropdown-form button {
  background: rgba(0, 51, 102, 0.04);
}

#profileDropdown .dropdown-sep {
  margin: 8px 6px 10px;
}

@media (min-width: 1000px) {
  html.qs-has-app-bottomnav .qs-header.qs-header--app {
    padding-left: 20px;
    padding-right: 22px;
  }
}

@media (max-width: 1100px) {
  .qs-header .top-nav {
    gap: 8px;
  }

  .qs-header .top-nav a,
  .qs-header .top-nav .nav-form button {
    padding: 0 14px;
  }
}

@media (max-width: 880px) {
  .qs-header--app .top-nav .qs-search-link__label {
    display: none;
  }

  .qs-header--app .top-nav .qs-search-link {
    padding: 0 12px !important;
  }
}

@media (max-width: 768px) {
  .qs-header {
    min-height: 70px;
    padding: 12px 14px;
  }

  .qs-header .qs-notif-btn,
  .qs-header .profile-btn {
    width: 40px !important;
    height: 40px !important;
  }

  #profileDropdown {
    width: min(86vw, 320px);
  }
}


/* ===== Milestone: Public Landing vs Hub ===== */
.qs-header--landing {
  padding: 18px 28px;
  background: rgba(255,255,255,0.98);
}

.qs-header--landing .qs-header-right {
  gap: 12px;
}

.qs-header--landing .qs-role-badge {
  background: rgba(0, 148, 255, 0.08);
  color: #003366;
}

.qs-header--landing .top-nav {
  gap: 12px;
}

.qs-header--landing .top-nav .nav-link {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border-radius: 999px;
}

.qs-header--landing .top-nav.qs-top-nav--landing-preview .nav-link.is-active {
  background: rgba(0, 51, 102, 0.08);
  border-color: rgba(0, 51, 102, 0.12);
}

@media (max-width: 720px) {
  .qs-header--landing {
    padding: 14px 18px;
  }

  .qs-header--landing .qs-header-right {
    gap: 8px;
  }

  .qs-header--landing .top-nav.qs-top-nav--landing-preview .nav-link {
    min-height: 38px;
    padding: 0 14px;
  }
}


/* ===== Milestone B2: Header rechts & globale Controls ===== */
.qs-header .profile-container{
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
}

.qs-header .qs-notif-btn,
.qs-header .profile-btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(0, 51, 102, 0.14);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(245,249,253,0.95));
  color: #003366;
  box-shadow: 0 10px 24px rgba(0, 51, 102, 0.08);
  transition:
    background-color 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
}

.qs-header .qs-notif-btn{
  overflow: visible;
}

.qs-header .qs-notif-btn .qs-notif-icon{
  width: 18px;
  height: 18px;
  display: block;
  opacity: 0.96;
}

.qs-header .qs-notif-btn .qs-notif-icon path{
  fill: currentColor;
}

.qs-header .qs-notif-btn::before,
.qs-header .profile-btn::before{
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background: rgba(255, 255, 255, 0.72);
  pointer-events: none;
}

.qs-header .qs-notif-btn > *,
.qs-header .profile-btn > *{
  position: relative;
  z-index: 1;
}

.qs-header .qs-notif-btn:hover,
.qs-header .qs-notif-btn.is-active,
.qs-header .qs-notif-btn[aria-expanded="true"],
.qs-header .profile-btn:hover,
.qs-header .profile-btn[aria-expanded="true"]{
  color: #003366;
  border-color: rgba(0, 148, 255, 0.24);
  background: linear-gradient(180deg, rgba(244,250,255,0.98), rgba(226,241,255,0.96));
  box-shadow: 0 14px 28px rgba(0, 51, 102, 0.12);
}

.qs-header .qs-notif-btn:active,
.qs-header .profile-btn:active{
  transform: translateY(1px);
}

.qs-header .qs-notif-btn:focus-visible,
.qs-header .profile-btn:focus-visible{
  outline: 2px solid rgba(0, 85, 165, 0.38);
  outline-offset: 2px;
}

.qs-header .qs-notif-badge{
  top: -2px;
  right: -2px;
  min-width: 19px;
  height: 19px;
  padding: 0 5px;
  border: 2px solid #fff;
  box-shadow: 0 6px 16px rgba(45, 137, 239, 0.28);
}

.qs-header .profile-btn{
  overflow: hidden;
  padding: 2px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(237,247,255,0.96));
}

.qs-header .profile-btn::after{
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,0.82);
  pointer-events: none;
}

.qs-header .profile-pic{
  position: relative;
  z-index: 1;
  width: 100% !important;
  height: 100% !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: 50% 50% !important;
  background: rgba(0, 51, 102, 0.04);
}

.qs-header .profile-btn[aria-expanded="true"]{
  border-color: rgba(0, 148, 255, 0.30);
  box-shadow: 0 16px 32px rgba(0, 51, 102, 0.14);
}

@media (hover: hover) and (pointer: fine){
  .qs-header .qs-notif-btn:hover,
  .qs-header .profile-btn:hover{
    transform: translateY(-1px);
  }
}

@media (max-width: 768px){
  .qs-header .qs-notif-btn,
  .qs-header .profile-btn{
    width: 40px;
    height: 40px;
  }

  .qs-header .qs-notif-btn .qs-notif-icon{
    width: 17px;
    height: 17px;
  }
}


/* ===== Milestone B3: Logged-in Landing Preview ===== */
.qs-header--landing .top-nav.qs-top-nav--landing-preview {
  gap: 10px;
}

.qs-header--landing .top-nav.qs-top-nav--landing-preview .qs-nav-context-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(0, 51, 102, 0.08);
  background: rgba(0, 51, 102, 0.04);
  color: #33506f;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.qs-header--landing .top-nav.qs-top-nav--landing-preview .qs-nav-link--cta {
  box-shadow: 0 10px 20px rgba(0, 51, 102, 0.08);
}

@media (max-width: 880px) {
  .qs-header--landing .top-nav.qs-top-nav--landing-preview .qs-nav-context-pill {
    display: none;
  }
}

@media (max-width: 720px) {
  .qs-header--landing .top-nav.qs-top-nav--landing-preview {
    gap: 8px;
  }

  .qs-header--landing .top-nav.qs-top-nav--landing-preview .qs-nav-link--cta {
    min-height: 38px;
    padding: 0 14px;
  }
}


/* ============================= */
/* C1 – APP SHELL STABILIZATION  */
/* ============================= */

:root{
  --qs-header-h: 78px;
}

html{
  scrollbar-gutter: stable;
}

body{
  padding-top: calc(var(--qs-header-h, 78px) + var(--qs-safe-top, 0px));
}

.qs-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  max-width: none;
  min-height: var(--qs-header-h, 78px);
  padding: 16px 22px;
  overflow: visible;
  contain: none;
  transform: translateZ(0);
  backface-visibility: hidden;
}

.qs-header .brand{
  min-width: 0;
  gap: 14px;
}

.qs-header .brand-name{
  margin-left: 0;
}

.qs-header .qs-header-right{
  flex: 1 1 auto;
  justify-content: flex-end;
  min-width: 0;
}

.qs-profile-banner{
  top: calc(var(--qs-header-h, 78px) + 8px);
}

html.qs-has-app-bottomnav .qs-header.qs-header--app,
html.qs-has-app-bottomnav .qs-header.qs-header--landing,
html.qs-has-app-bottomnav .qs-header--app,
html.qs-has-app-bottomnav .qs-header--landing{
  width: 100% !important;
  margin-left: 0 !important;
  padding-left: 22px !important;
  padding-right: 22px !important;
}

@media (min-width: 1000px){
  .qs-header{
    padding: 16px 28px;
  }

  html.qs-has-app-bottomnav .qs-header.qs-header--app,
  html.qs-has-app-bottomnav .qs-header.qs-header--landing,
  html.qs-has-app-bottomnav .qs-header--app,
  html.qs-has-app-bottomnav .qs-header--landing{
    padding-left: 28px !important;
    padding-right: 28px !important;
  }
}

@media (max-width: 768px){
  :root{
    --qs-header-h: 72px;
  }

  .qs-header{
    padding: 14px 18px;
  }
}

@media (max-width: 560px){
  :root{
    --qs-header-h: 68px;
  }

  .qs-header{
    padding: 12px 14px;
  }
}


/* ===== D3 final shell lock ===== */
html{
  scrollbar-gutter: stable;
}

body{
  margin: 0;
  padding-top: calc(var(--qs-header-h, 78px) + var(--qs-safe-top, 0px));
}

.qs-header{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  margin: 0 !important;
  transform: translateZ(0);
  backface-visibility: hidden;
  contain: none;
}

html.qs-has-app-bottomnav .qs-header.qs-header--app,
html.qs-has-app-bottomnav .qs-header.qs-header--landing{
  padding-left: 22px !important;
  padding-right: 22px !important;
}

@media (min-width: 1000px){
  html.qs-has-app-bottomnav .qs-header.qs-header--app,
  html.qs-has-app-bottomnav .qs-header.qs-header--landing{
    padding-left: 28px !important;
    padding-right: 28px !important;
  }
}


/* ===== E3 retry – definitive shell/header lock (current ZIP scope only) ===== */
html{
  scrollbar-gutter: stable;
}

body{
  margin: 0;
  padding-top: calc(var(--qs-header-h, 78px) + var(--qs-safe-top, 0px));
}

.qs-header{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  transform: translateZ(0);
  backface-visibility: hidden;
  contain: none;
}

html.qs-has-app-bottomnav .qs-header.qs-header--app,
html.qs-has-app-bottomnav .qs-header.qs-header--landing{
  padding-left: 22px !important;
  padding-right: 22px !important;
}

@media (min-width: 1000px){
  html.qs-has-app-bottomnav .qs-header.qs-header--app,
  html.qs-has-app-bottomnav .qs-header.qs-header--landing{
    padding-left: 28px !important;
    padding-right: 28px !important;
  }
}


/* ===== Milestone B1: public desktop shell hygiene ===== */
.qs-header .top-nav .qs-nav-link--desktop-only,
.qs-header .top-nav .qs-search-link--desktop-utility{
  display:none;
}

@media (min-width: 1000px){
  .qs-header--public .top-nav,
  .qs-header--landing .top-nav{
    gap:12px;
  }

  .qs-header--public .top-nav .qs-nav-link--desktop-only,
  .qs-header--public .top-nav .qs-search-link--desktop-utility{
    display:inline-flex;
  }

  .qs-header--public .top-nav .qs-search-link--desktop-utility{
    width:auto;
    min-width:44px;
    height:44px;
    padding:0 14px 0 12px;
    border-radius:999px;
    background:rgba(255,255,255,0.92);
    border:1px solid rgba(0, 51, 102, 0.10);
    box-shadow:0 8px 18px rgba(0, 51, 102, 0.06);
  }

  .qs-header--public .top-nav .qs-search-link--desktop-utility:hover,
  .qs-header--public .top-nav .qs-search-link--desktop-utility.is-active,
  .qs-header--public .top-nav .qs-nav-link--desktop-only:hover,
  .qs-header--public .top-nav .qs-nav-link--desktop-only.is-active{
    border-color:rgba(0, 51, 102, 0.14);
    background:rgba(0, 51, 102, 0.08);
  }
}


/* --- Milestone: Notifications vereinheitlichen --- */
.qs-header .qs-notif-btn{
  width:46px;
  height:46px;
  border:1px solid rgba(0, 51, 102, 0.12);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(237,247,255,0.96));
  box-shadow:0 8px 18px rgba(0, 24, 58, 0.08);
}
.qs-header .qs-notif-btn:hover{
  background:rgba(237,247,255,0.98);
  border-color:rgba(0, 51, 102, 0.16);
}
.qs-header .qs-notif-btn.is-active{
  background:linear-gradient(180deg, rgba(0,148,255,0.14), rgba(0,148,255,0.08));
  border-color:rgba(0, 148, 255, 0.24);
}
.qs-header .qs-notif-icon{
  width:22px;
  height:22px;
}
.qs-header .qs-notif-badge{
  top:-5px;
  right:-6px;
  min-width:24px;
  height:24px;
  padding:0 7px;
  font-size:11px;
  font-weight:900;
  box-shadow:0 10px 18px rgba(0, 51, 102, 0.18);
}


/* ===== Milestone rerun: header-only notifications refresh ===== */
.qs-header .qs-notif-btn{
  width:46px;
  height:46px;
  border-color:rgba(0, 51, 102, 0.12);
  background:linear-gradient(180deg, rgba(255,255,255,0.98), rgba(237,247,255,0.96));
  box-shadow:0 8px 18px rgba(0, 24, 58, 0.08);
}

.qs-header .qs-notif-btn .qs-notif-icon,
.qs-header .qs-notif-icon{
  width:22px;
  height:22px;
  display:block;
  opacity:0.98;
}

.qs-header .qs-notif-badge{
  top:-5px;
  right:-6px;
  min-width:24px;
  height:24px;
  padding:0 7px;
  font-size:11px;
  font-weight:900;
  box-shadow:0 10px 18px rgba(0, 51, 102, 0.18);
}

.qs-notif-panel .qsN-content{
  transition:opacity .16s ease;
}

.qs-notif-panel.is-switching .qsN-content{
  opacity:.72;
}

.qs-notif-panel.is-switching .qsN-tabs,
.qs-notif-panel.is-switching .qsN-list,
.qs-notif-panel.is-switching .qsN-actions{
  pointer-events:none;
}

@media (max-width: 768px){
  .qs-header .qs-notif-btn,
  .qs-header .profile-btn{
    width:42px;
    height:42px;
  }

  .qs-header .qs-notif-btn .qs-notif-icon,
  .qs-header .qs-notif-icon{
    width:20px;
    height:20px;
  }

  .qs-header .qs-notif-badge{
    min-width:22px;
    height:22px;
    top:-4px;
    right:-5px;
  }
}

/* =================================================================
   STAND-PROFIL — HEADER VIEWPORT-KONSISTENZ
   Milestone 1.4
   Scope: nur öffentliches Stand-Profil
================================================================= */

body.qs-profile-page.qs-profile-page--stand .qs-header{
  margin-bottom: 0 !important;
}

/* Desktop/Laptop: Header verkleinert sich mit dem Viewport, statt überall gleich groß zu bleiben. */
@media (min-width: 1000px) and (max-width: 1599.98px){
  body.qs-profile-page.qs-profile-page--stand .qs-header{
    min-height: var(--qs-stand-header-h, 62px) !important;
    padding: var(--qs-stand-header-pad-y, 12px) var(--qs-stand-header-pad-x, 28px) !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .brand{
    gap: var(--qs-stand-header-brand-gap, 8px) !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .brand-logo{
    max-height: var(--qs-stand-header-logo, 34px) !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .brand-name{
    font-size: var(--qs-stand-header-brand, 18px) !important;
    line-height: 1.15 !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .qs-header-right{
    gap: var(--qs-stand-header-gap, 10px) !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .qs-header-right .top-nav,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav{
    gap: var(--qs-stand-header-nav-gap, 10px) !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav a,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav .nav-form button{
    min-height: var(--qs-stand-header-nav-h, 36px) !important;
    padding: var(--qs-stand-header-nav-pad-y, 6px) var(--qs-stand-header-nav-pad-x, 11px) !important;
    font-size: var(--qs-stand-header-nav-font, 0.9rem) !important;
    line-height: 1.1 !important;
    border-radius: 999px !important;
  }
}

@media (min-width: 1280px) and (max-width: 1439.98px){
  body.qs-profile-page.qs-profile-page--stand{
    --qs-stand-header-h: 58px;
    --qs-stand-header-pad-y: 10px;
    --qs-stand-header-pad-x: 24px;
    --qs-stand-header-logo: 31px;
    --qs-stand-header-brand: 17px;
    --qs-stand-header-gap: 8px;
    --qs-stand-header-nav-gap: 8px;
    --qs-stand-header-nav-h: 34px;
    --qs-stand-header-nav-font: 0.84rem;
    --qs-stand-header-nav-pad-x: 10px;
  }
}

@media (min-width: 1180px) and (max-width: 1279.98px){
  body.qs-profile-page.qs-profile-page--stand{
    --qs-stand-header-h: 54px;
    --qs-stand-header-pad-y: 9px;
    --qs-stand-header-pad-x: 22px;
    --qs-stand-header-logo: 29px;
    --qs-stand-header-brand: 16px;
    --qs-stand-header-brand-gap: 7px;
    --qs-stand-header-gap: 7px;
    --qs-stand-header-nav-gap: 7px;
    --qs-stand-header-nav-h: 32px;
    --qs-stand-header-nav-font: 0.8rem;
    --qs-stand-header-nav-pad-y: 5px;
    --qs-stand-header-nav-pad-x: 9px;
  }
}

@media (min-width: 1000px) and (max-width: 1179.98px){
  body.qs-profile-page.qs-profile-page--stand{
    --qs-stand-header-h: 50px;
    --qs-stand-header-pad-y: 8px;
    --qs-stand-header-pad-x: 20px;
    --qs-stand-header-logo: 27px;
    --qs-stand-header-brand: 15px;
    --qs-stand-header-brand-gap: 6px;
    --qs-stand-header-gap: 6px;
    --qs-stand-header-nav-gap: 6px;
    --qs-stand-header-nav-h: 30px;
    --qs-stand-header-nav-font: 0.76rem;
    --qs-stand-header-nav-pad-y: 4px;
    --qs-stand-header-nav-pad-x: 8px;
  }
}

/* Mobile: Header direkt an den Banner anschließen und nicht unnötig hoch wirken lassen. */
@media (max-width: 480px){
  body.qs-profile-page.qs-profile-page--stand .qs-header{
    min-height: 48px !important;
    padding-top: 6px !important;
    padding-bottom: 6px !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav a,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav .nav-form button{
    min-height: 28px !important;
    padding-top: 4px !important;
    padding-bottom: 4px !important;
  }
}

@media (max-width: 360px){
  body.qs-profile-page.qs-profile-page--stand .qs-header{
    min-height: 46px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav a,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav .nav-form button{
    font-size: 0.72rem !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
}



/* =================================================================
   STAND-PROFIL — MOBILE HEADER-HÖHE FIX
   Milestone 1.5
   Scope: nur öffentliches Stand-Profil (.qs-profile-page--stand)

   Ziel:
   - Der Abstand zwischen Mobile-Header und Banner entsteht nicht mehr,
     weil Header-Höhe und Body-Offset wieder zusammenpassen.
   - Header-Inhalte werden vertikal mittig geführt statt nach oben gedrückt.
================================================================= */

@media (max-width: 999.98px){
  body.qs-profile-page.qs-profile-page--stand{
    --qs-stand-m15-header-h: 68px;
    padding-top: calc(var(--qs-stand-m15-header-h) + var(--qs-safe-top, 0px)) !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header{
    height: var(--qs-stand-m15-header-h) !important;
    min-height: var(--qs-stand-m15-header-h) !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    align-items: center !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .brand,
  body.qs-profile-page.qs-profile-page--stand .qs-header .qs-header-right,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav{
    align-items: center !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .brand-logo{
    max-height: 30px !important;
    height: auto !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav a,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav .nav-form button{
    min-height: 32px !important;
    height: 32px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
}

@media (max-width: 480px){
  body.qs-profile-page.qs-profile-page--stand{
    --qs-stand-m15-header-h: 66px;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header{
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .qs-header-right{
    gap: 7px !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav{
    gap: 6px !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav a,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav .nav-form button{
    min-height: 31px !important;
    height: 31px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    font-size: 0.78rem !important;
  }
}

@media (max-width: 360px){
  body.qs-profile-page.qs-profile-page--stand{
    --qs-stand-m15-header-h: 62px;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .brand-logo{
    max-height: 27px !important;
  }

  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav a,
  body.qs-profile-page.qs-profile-page--stand .qs-header .top-nav .nav-form button{
    min-height: 29px !important;
    height: 29px !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
    font-size: 0.72rem !important;
  }
}


/* =================================================================
   ORDER-SEITE — HEADER RESPONSIVE POLISH
   Milestone 2
   Scope: nur /order/{slug} (.qs-orderpage)
================================================================= */

/* Header-Höhe und Body-Abstand für die Order-Seite synchron halten. */
body.qs-orderpage{
  --qs-order-header-h: 72px;
  padding-top: calc(var(--qs-order-header-h) + var(--qs-safe-top, 0px)) !important;
}

body.qs-orderpage .qs-header{
  min-height: var(--qs-order-header-h) !important;
  height: var(--qs-order-header-h) !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  align-items: center !important;
}

body.qs-orderpage .qs-header .brand,
body.qs-orderpage .qs-header .qs-header-right,
body.qs-orderpage .qs-header .top-nav{
  align-items: center !important;
}

body.qs-orderpage .qs-header .top-nav a,
body.qs-orderpage .qs-header .top-nav .nav-form button{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 36px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Laptops: Header kompakter, damit 100%-Zoom nicht riesig wirkt. */
@media (min-width: 1000px) and (max-width: 1366.98px){
  body.qs-orderpage{
    --qs-order-header-h: 62px;
  }

  body.qs-orderpage .qs-header{
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  body.qs-orderpage .qs-header .brand-logo{
    max-height: 31px !important;
  }

  body.qs-orderpage .qs-header .brand-name{
    font-size: 17px !important;
  }

  body.qs-orderpage .qs-header .qs-header-right,
  body.qs-orderpage .qs-header .top-nav{
    gap: 8px !important;
  }

  body.qs-orderpage .qs-header .top-nav a,
  body.qs-orderpage .qs-header .top-nav .nav-form button{
    min-height: 33px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
    font-size: 0.84rem !important;
  }
}

@media (min-width: 1000px) and (max-width: 1100.98px){
  body.qs-orderpage{
    --qs-order-header-h: 58px;
  }

  body.qs-orderpage .qs-header .brand-logo{
    max-height: 29px !important;
  }

  body.qs-orderpage .qs-header .brand-name{
    font-size: 16px !important;
  }

  body.qs-orderpage .qs-header .top-nav a,
  body.qs-orderpage .qs-header .top-nav .nav-form button{
    min-height: 31px !important;
    font-size: 0.79rem !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

/* Mobile: sichtbar, nicht gequetscht, und kein Spalt über dem Content. */
@media (max-width: 999.98px){
  body.qs-orderpage{
    --qs-order-header-h: 68px;
  }

  body.qs-orderpage .qs-header{
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  body.qs-orderpage .qs-header .brand-logo{
    max-height: 30px !important;
  }

  body.qs-orderpage .qs-header .qs-header-right{
    gap: 8px !important;
  }

  body.qs-orderpage .qs-header .top-nav{
    gap: 7px !important;
  }

  body.qs-orderpage .qs-header .top-nav a,
  body.qs-orderpage .qs-header .top-nav .nav-form button{
    min-height: 32px !important;
    height: 32px !important;
    padding-left: 9px !important;
    padding-right: 9px !important;
    font-size: 0.8rem !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
  }
}

@media (max-width: 480px){
  body.qs-orderpage{
    --qs-order-header-h: 66px;
  }

  body.qs-orderpage .qs-header{
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  body.qs-orderpage .qs-header .brand-logo{
    max-height: 28px !important;
  }

  body.qs-orderpage .qs-header .brand-name{
    font-size: 0.95rem !important;
  }

  body.qs-orderpage .qs-header .top-nav{
    gap: 6px !important;
  }

  body.qs-orderpage .qs-header .top-nav a,
  body.qs-orderpage .qs-header .top-nav .nav-form button{
    min-height: 31px !important;
    height: 31px !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    font-size: 0.76rem !important;
  }
}

@media (max-width: 360px){
  body.qs-orderpage{
    --qs-order-header-h: 62px;
  }

  body.qs-orderpage .qs-header{
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  body.qs-orderpage .qs-header .brand-logo{
    max-height: 26px !important;
  }

  body.qs-orderpage .qs-header .top-nav a,
  body.qs-orderpage .qs-header .top-nav .nav-form button{
    min-height: 29px !important;
    height: 29px !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
    font-size: 0.7rem !important;
  }
}
