/* ============================================================
   Piazza Studio — neue App-Shell, Dashboard & Projektansicht
   ------------------------------------------------------------
   Namespace `.ps-*` (getrennt vom alten `.cp-*`-Chrome, das während
   der Übergangszeit unangetastet bleibt). Nur `--ps--*`-Tokens; die
   wenigen Design-Literale (#1f473c/#00815d/#3bd17f …) sind über
   Tokens abgebildet, sofern vorhanden.

   Collapse-Animation (kritisch): Sidebar `position:absolute` + width-
   Transition, Content `margin-left`-Transition — NICHT flex-basis
   (friert in Chromium ein). Erste Frame ohne Transition (.no-anim).
   ============================================================ */

.ps-shell {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  background: var(--ps--neutral-50);
  font-family: var(--ps--font-sans);
  --ps-side-w: 224px;
  --ps-chrome-h: 60px;
}
.ps-shell.is-collapsed { --ps-side-w: 78px; }
/* Erste Frame: alle Transitionen aus, damit nichts „aufklappt". */
.ps-shell.no-anim,
.ps-shell.no-anim * { transition: none !important; }

/* ---- Sidebar (dunkelgrün) ---- */
.ps-side {
  position: absolute;
  left: 0; top: 0;
  height: 100vh;
  width: var(--ps-side-w);
  z-index: 20;
  background: var(--ps--bg-inverse);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: width var(--ps--duration-slow) var(--ps--ease-standard);
}

.ps-side__brand {
  position: relative;
  flex: 0 0 auto;
  height: var(--ps-chrome-h);
  border-bottom: 1px solid rgba(255, 255, 255, 0.10);
  overflow: hidden;
}
.ps-side__logo {
  position: absolute;
  left: 16px; top: 50%;
  transform: translateY(-50%);
  width: 160px; height: auto; max-height: 42px;
  object-fit: contain; object-position: left center;
  opacity: 1;
  transition: opacity var(--ps--duration-base);
  cursor: pointer;
}
.ps-side__signet {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  height: 32px; width: auto;
  opacity: 0;
  transition: opacity var(--ps--duration-base);
  cursor: pointer;
  pointer-events: none;
}
.ps-shell.is-collapsed .ps-side__signet { pointer-events: auto; }
.ps-shell.is-collapsed .ps-side__logo { pointer-events: none; }
.ps-side__toggle {
  position: absolute;
  top: 50%; right: 12px;
  transform: translateY(-50%);
  width: 32px; height: 32px;
  border: 0; background: transparent;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255, 255, 255, 0.82);
  cursor: pointer;
  opacity: 1;
  transition: opacity var(--ps--duration-base), background var(--ps--duration-fast);
}
.ps-side__toggle:hover { background: rgba(255, 255, 255, 0.12); color: #fff; }
.ps-side__toggle i { width: 18px; height: 18px; }

/* eingeklappt: Logo aus, Signet an, Toggle verborgen (zentriert) */
.ps-shell.is-collapsed .ps-side__logo { opacity: 0; }
.ps-shell.is-collapsed .ps-side__signet { opacity: 1; }
.ps-shell.is-collapsed .ps-side__toggle {
  right: auto; left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
}
/* eingeklappt + Hover über den Kopf: Signet aus, Toggle an */
.ps-shell.is-collapsed .ps-side__brand:hover .ps-side__signet { opacity: 0; }
.ps-shell.is-collapsed .ps-side__brand:hover .ps-side__toggle { opacity: 1; }

.ps-side__nav {
  flex: 1; min-height: 0;
  padding: 14px 12px;
  display: flex; flex-direction: column; gap: 2px;
  overflow: hidden;
}
.ps-side__label {
  flex: 0 0 auto;
  font-weight: 700; font-size: 10px; letter-spacing: 0.10em;
  color: rgba(255, 255, 255, 0.42);
  padding: 4px 10px 6px;
  white-space: nowrap; overflow: hidden;
  max-height: 26px; opacity: 1;
  transition: opacity var(--ps--duration-base),
              max-height var(--ps--duration-slow) var(--ps--ease-standard);
}
.ps-side__hr {
  flex: 0 0 auto;
  margin: 14px 4px 10px;
  height: 1px; background: rgba(255, 255, 255, 0.12);
}
.ps-side__item {
  flex: 0 0 auto;
  display: flex; align-items: center;
  gap: 12px; justify-content: flex-start;
  padding: 9px 10px;
  border: 0; background: transparent;
  border-radius: 6px;
  color: rgba(255, 255, 255, 0.82);
  font-weight: 600; font-size: 14px; text-align: left;
  cursor: pointer; overflow: hidden;
  transition: padding var(--ps--duration-slow) var(--ps--ease-standard),
              background var(--ps--duration-fast);
}
.ps-side__item i { width: 18px; height: 18px; flex: 0 0 auto; }
.ps-side__item span {
  white-space: nowrap; overflow: hidden;
  opacity: 1; max-width: 200px;
  transition: opacity var(--ps--duration-base),
              max-width var(--ps--duration-slow) var(--ps--ease-standard);
}
.ps-side__item:hover { background: rgba(255, 255, 255, 0.08); color: #fff; }
.ps-side__item.is-active { background: var(--ps--primary); color: #fff; }
.ps-side__item.is-disabled { opacity: 0.42; cursor: default; }
.ps-side__item.is-disabled:hover { background: transparent; }

/* Projekt-Umschalter */
.ps-side__switch {
  flex: 0 0 auto;
  display: flex; align-items: center; gap: 11px;
  padding: 10px 11px;
  border: 0;
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.10);
  cursor: pointer; overflow: hidden;
  margin-bottom: 10px; width: 100%;
  text-align: left;
}
.ps-side__switch i { flex: 0 0 auto; color: #fff; }
.ps-side__switch .ps-side__switchName {
  flex: 1; min-width: 0;
  color: #fff; font-weight: 700; font-size: 13px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  opacity: 1; max-width: 200px;
  transition: opacity var(--ps--duration-base), max-width var(--ps--duration-slow);
}
.ps-side__switch .ps-side__switchCaret {
  flex: 0 0 auto; color: rgba(255, 255, 255, 0.6);
  opacity: 1; transition: opacity var(--ps--duration-base);
}
/* Ordner-Icon im Umschalter: NUR eingeklappt sichtbar (smooth eingeblendet). */
.ps-side__switchIcon {
  flex: 0 0 auto; width: 18px; height: 18px; color: #fff;
  opacity: 0; max-width: 0; overflow: hidden;
  transition: opacity var(--ps--duration-base), max-width var(--ps--duration-slow) var(--ps--ease-standard);
}
.ps-shell.is-collapsed .ps-side__switchIcon { opacity: 1; max-width: 24px; }

/* eingeklappt: Texte/Labels ausblenden + Items zentrieren */
.ps-shell.is-collapsed .ps-side__label { opacity: 0; max-height: 0; }
.ps-shell.is-collapsed .ps-side__item { gap: 0; padding: 9px 0; justify-content: center; }
.ps-shell.is-collapsed .ps-side__item span { opacity: 0; max-width: 0; }
.ps-shell.is-collapsed .ps-side__switch { justify-content: center; gap: 0; }
.ps-shell.is-collapsed .ps-side__switch .ps-side__switchName,
.ps-shell.is-collapsed .ps-side__switch .ps-side__switchCaret { opacity: 0; max-width: 0; }
.ps-shell.is-collapsed .ps-side__foot span { opacity: 0; max-width: 0; }

/* Custom-Tooltip (eingeklappte Sidebar): dunkelgrau, weißer Text, fixed → wird
   nicht vom overflow:hidden der Sidebar abgeschnitten. */
.ps-tip {
  position: fixed; z-index: 90;
  transform: translateY(-50%);
  background: var(--ps--surface-dark); color: #fff;
  font-size: 12px; font-weight: 600; line-height: 1; white-space: nowrap;
  padding: 7px 10px; border-radius: 7px;
  box-shadow: var(--ps--shadow-md); pointer-events: none;
  animation: ps-tip-in 0.12s var(--ps--ease-out);
}
@keyframes ps-tip-in {
  from { opacity: 0; transform: translateY(-50%) translateX(-4px); }
  to   { opacity: 1; transform: translateY(-50%); }
}

.ps-side__foot {
  flex: 0 0 auto;
  padding: 14px 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.10);
  display: flex; align-items: center; gap: 8px;
  justify-content: flex-start;
  color: rgba(255, 255, 255, 0.55);
  font-weight: 600; font-size: 12px;
  background: transparent; border-left: 0; border-right: 0; border-bottom: 0;
  cursor: pointer; width: 100%; text-align: left;
}
.ps-shell.is-collapsed .ps-side__foot { justify-content: center; }
.ps-side__foot span {
  white-space: nowrap; overflow: hidden; max-width: 200px;
  transition: opacity var(--ps--duration-base), max-width var(--ps--duration-slow);
}
.ps-side__foot:hover { color: rgba(255, 255, 255, 0.85); }

/* Projektwechsler-Dropdown — position:fixed, damit es aus dem overflow:hidden
   der Sidebar ausbricht; left/top/min-width werden inline aus dem Button-Rect
   gesetzt. */
.ps-switchMenu {
  position: fixed;
  z-index: 60;
  min-width: 220px;
  background: #fff;
  border: 1px solid var(--ps--border);
  border-radius: 10px;
  box-shadow: var(--ps--shadow-lg);
  padding: 6px;
  max-height: 60vh; overflow-y: auto;
}
.ps-switchMenu__item {
  display: block; width: 100%; text-align: left;
  padding: 9px 10px; border: 0; background: transparent;
  border-radius: 7px; cursor: pointer;
  font-size: 13px; font-weight: 600; color: var(--ps--fg);
}
.ps-switchMenu__item:hover { background: var(--ps--bg-soft); }
.ps-switchMenu__item.is-active { background: var(--ps--primary-soft); color: var(--ps--primary); }
.ps-switchMenu__empty { padding: 12px; font-size: 13px; color: var(--ps--fg-muted); }

/* ---- Content-Bereich (rechts der Sidebar) ---- */
.ps-content {
  margin-left: var(--ps-side-w);
  height: 100vh;
  display: flex; flex-direction: column;
  transition: margin-left var(--ps--duration-slow) var(--ps--ease-standard);
}
.ps-content--builder { display: block; }
/* Builder-Topbar-Zeile an die 60px-Shell-Chrome angleichen. */
.ps-content--builder .bd-shell { --cp-chrome-h: var(--ps-chrome-h); }

/* ---- Topbar ---- */
.ps-top {
  flex: 0 0 auto;
  height: var(--ps-chrome-h);
  border-bottom: 1px solid var(--ps--border);
  background: #fff;
  display: flex; align-items: center;
  padding: 0 24px; gap: 16px;
}
.ps-top__pos { display: flex; align-items: baseline; gap: 9px; min-width: 0; }
.ps-top__posMain { font-weight: 900; font-size: 16px; color: var(--ps--fg); letter-spacing: -0.01em; }
.ps-top__posSub { font-size: 13px; color: var(--ps--neutral-400); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ps-top__spacer { flex: 1; }
.ps-top__export {
  display: flex; align-items: center; gap: 8px;
  height: 40px; padding: 0 18px;
  border: 0; border-radius: 9px;
  background: var(--ps--primary); color: #fff;
  font-weight: 700; font-size: 14px; cursor: pointer;
  box-shadow: 0 2px 8px rgba(0, 129, 93, 0.28);
}
.ps-top__export:hover { background: var(--ps--primary-hover); }
.ps-top__export i { width: 16px; height: 16px; }
.ps-top__divider { width: 1px; height: 30px; background: var(--ps--border); }
.ps-top__iconbtn {
  width: 40px; height: 40px;
  border: 1px solid var(--ps--border); border-radius: 9px;
  background: #fff; color: var(--ps--fg-muted);
  display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.ps-top__iconbtn:hover { border-color: var(--ps--border-strong); color: var(--ps--fg); }
.ps-top__iconbtn i { width: 16px; height: 16px; }

/* ---- Account-Menü ---- */
.ps-account { position: relative; }
.ps-account__btn {
  display: flex; align-items: center; gap: 10px;
  border: 0; background: transparent; cursor: pointer; padding: 0;
}
.ps-account__avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--ps--bg-inverse); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 13px; flex: 0 0 auto;
  background-size: cover; background-position: center;
}
.ps-account__meta { display: flex; flex-direction: column; line-height: 1.2; align-items: flex-start; }
.ps-account__name { font-weight: 700; font-size: 13px; color: var(--ps--fg); }
.ps-account__role { font-size: 11px; color: var(--ps--neutral-400); }
.ps-account__caret { width: 15px; height: 15px; color: var(--ps--neutral-400); }
.ps-account__menu {
  position: absolute; right: 0; top: calc(100% + 8px);
  min-width: 200px; z-index: 50;
  background: #fff; border: 1px solid var(--ps--border);
  border-radius: 10px; box-shadow: var(--ps--shadow-lg);
  padding: 6px;
}
.ps-account__item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 9px 10px;
  border: 0; background: transparent; border-radius: 7px;
  font-size: 13px; font-weight: 600; color: var(--ps--fg);
  text-align: left; cursor: pointer;
}
.ps-account__item:hover { background: var(--ps--bg-soft); }
.ps-account__item i { width: 15px; height: 15px; color: var(--ps--fg-muted); }
.ps-account__sep { height: 1px; background: var(--ps--border); margin: 6px 4px; }

/* ---- Body (unter der Topbar): optionale SubNav + Hauptfläche ---- */
.ps-below { flex: 1; min-height: 0; display: flex; }

/* SubNav (wiederverwendete .cp-subnav) im neuen Shell positionieren */
.ps-below .cp-subnav {
  position: static;
  height: auto;
  align-self: stretch;
  width: 240px;
  flex: 0 0 auto;
}
.ps-below .cp-subnav__head {
  height: auto;
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--ps--border);
}

.ps-main { flex: 1; min-width: 0; min-height: 0; overflow: auto; }
.ps-main__body { padding: 32px 36px 44px; }

/* ===========================================================
   Dashboard (globale Projektliste)
   =========================================================== */
.ps-dash__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; }
.ps-dash__eyebrow { font-weight: 700; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ps--primary); margin-bottom: 10px; }
.ps-dash__title { font-family: var(--ps--font-display); font-weight: 900; font-size: 42px; line-height: 0.98; color: var(--ps--fg); margin: 0; text-transform: uppercase; letter-spacing: -0.02em; }
.ps-dash__headActions { display: flex; align-items: center; gap: 10px; }
.ps-dash__search { position: relative; display: flex; align-items: center; }
/* Lucide ersetzt das <i data-lucide> zur Laufzeit durch ein <svg> — deshalb muss
   die Positionierung das svg treffen, sonst rutscht die Lupe als Flex-Element
   aus dem Feld. */
.ps-dash__search > svg, .ps-dash__search > i { width: 17px; height: 17px; color: var(--ps--neutral-400); position: absolute; left: 16px; pointer-events: none; }
.ps-dash__search input { width: 300px; height: 44px; padding: 0 18px 0 44px; border: 1px solid var(--ps--border); border-radius: 12px; background: #fff; font: 400 14px var(--ps--font-sans); color: var(--ps--fg); outline: none; transition: border-color .15s, box-shadow .15s; }
.ps-dash__search input::placeholder { color: var(--ps--neutral-400); }
.ps-dash__search input:hover { border-color: var(--ps--border-strong); }
.ps-dash__search input:focus { border-color: var(--ps--primary); box-shadow: 0 0 0 3px var(--ps--focus-ring); }
.ps-btn {
  display: flex; align-items: center; gap: 8px;
  height: 44px; padding: 0 18px;
  border: 1px solid var(--ps--border); border-radius: 10px;
  background: #fff; color: var(--ps--neutral-700);
  font-weight: 700; font-size: 14px; cursor: pointer;
}
.ps-btn:hover { border-color: var(--ps--border-strong); }
.ps-btn i { width: 16px; height: 16px; }
.ps-btn--primary { background: var(--ps--primary); border-color: var(--ps--primary); color: #fff; }
.ps-btn--primary:hover { background: var(--ps--primary-hover); border-color: var(--ps--primary-hover); }

.ps-dash__kpis { display: flex; gap: 16px; margin-top: 26px; }
.ps-kpi { flex: 1; background: #fff; border: 1px solid var(--ps--border); border-radius: 14px; padding: 18px 20px; }
.ps-kpi__top { display: flex; align-items: center; justify-content: space-between; }
.ps-kpi__label { font-weight: 700; font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ps--neutral-400); }
.ps-kpi__icon { width: 16px; height: 16px; }
.ps-kpi__value { font-weight: 900; font-size: 34px; margin-top: 8px; letter-spacing: -0.02em; }

.ps-dash__folders { display: flex; align-items: center; gap: 10px; margin-top: 24px; overflow-x: auto; padding-bottom: 2px; }
.ps-chip {
  display: flex; align-items: center; gap: 9px; flex: 0 0 auto;
  height: 42px; padding: 0 16px;
  border: 1px solid var(--ps--border); border-radius: 10px;
  background: #fff; color: var(--ps--neutral-600);
  font-weight: 700; font-size: 13px; cursor: pointer;
}
.ps-chip i { width: 16px; height: 16px; }
.ps-chip .ps-chip__count { opacity: 0.55; }
.ps-chip.is-active { background: var(--ps--bg-inverse); color: #fff; border-color: var(--ps--bg-inverse); }
.ps-chip--add { border-style: dashed; border-color: var(--ps--border-strong); color: var(--ps--neutral-500); }

.ps-dash__listHead { display: flex; align-items: center; justify-content: space-between; margin-top: 30px; margin-bottom: 14px; }
.ps-dash__listHead h2 { font-weight: 900; font-size: 18px; color: var(--ps--fg); margin: 0; letter-spacing: -0.01em; }
.ps-dash__listHead h2 span { font-weight: 400; color: var(--ps--neutral-400); }

.ps-tableWrap { overflow-x: auto; background: #fff; border: 1px solid var(--ps--border); border-radius: 14px; }
.ps-table { min-width: 1246px; }
.ps-table__head {
  display: flex; align-items: center; gap: 16px;
  padding: 12px 22px; border-bottom: 1px solid var(--ps--border);
  background: var(--ps--neutral-50);
  font-weight: 700; font-size: 11px; letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--ps--neutral-400);
}
/* Kopf-Zellen erben Kopf-Typo (sonst gewönnen die Daten-Spalten-Fonts). */
.ps-table__head > div { font: inherit; color: inherit; }
.ps-row { display: flex; align-items: center; gap: 16px; padding: 14px 22px; border-bottom: 1px solid #eef0ef; position: relative; }
.ps-row:last-child { border-bottom: 0; }
.ps-row:hover { background: var(--ps--neutral-50); }
.ps-row__name { font-weight: 700; font-size: 15px; color: var(--ps--fg); }
.ps-row__domain { font-size: 12px; color: var(--ps--neutral-400); margin-top: 3px; display: flex; align-items: center; gap: 5px; }
.ps-row__domain i { width: 11px; height: 11px; }
.ps-col-prev { width: 128px; flex: 0 0 auto; border-radius: 7px; overflow: hidden; border: 1px solid #eef0ef; }
.ps-col-proj { flex: 1; min-width: 0; cursor: pointer; }
.ps-col-status { width: 104px; flex: 0 0 auto; }
.ps-col-plat { width: 200px; flex: 0 0 auto; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.ps-col-pages { width: 62px; flex: 0 0 auto; text-align: right; font-weight: 700; font-size: 15px; color: var(--ps--neutral-700); }
.ps-col-comp { width: 96px; flex: 0 0 auto; text-align: right; font-weight: 700; font-size: 15px; color: var(--ps--neutral-700); }
.ps-col-upd { width: 104px; flex: 0 0 auto; font-size: 12px; color: var(--ps--neutral-500); }
.ps-col-pm { width: 84px; flex: 0 0 auto; }
.ps-col-act { width: 112px; flex: 0 0 auto; display: flex; gap: 6px; justify-content: flex-end; }

.ps-pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; font-weight: 700; font-size: 11px; }
.ps-pill__dot { width: 6px; height: 6px; border-radius: 50%; }
.ps-tag { display: inline-flex; align-items: center; gap: 5px; padding: 3px 9px; border-radius: 6px; font-weight: 700; font-size: 11px; }
.ps-tag i { width: 11px; height: 11px; }

.ps-iconbtn { width: 30px; height: 30px; border-radius: 8px; border: 1px solid var(--ps--border); background: #fff; display: flex; align-items: center; justify-content: center; color: var(--ps--fg); cursor: pointer; transition: border-color .15s, color .15s, background .15s; }
.ps-iconbtn:hover { border-color: var(--ps--border-strong); }
.ps-iconbtn i { width: 14px; height: 14px; }
.ps-iconbtn--danger:hover { border-color: #dc2626; color: #dc2626; background: rgba(220,38,38,0.06); }

.ps-pm { display: flex; align-items: center; gap: 7px; }
.ps-pm__ph { width: 26px; height: 26px; border-radius: 50%; border: 1px dashed var(--ps--border-strong); display: flex; align-items: center; justify-content: center; color: var(--ps--neutral-300); }
.ps-pm__ph i { width: 13px; height: 13px; }
.ps-pm__avatar { width: 26px; height: 26px; border-radius: 50%; background: var(--ps--bg-inverse); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; background-size: cover; background-position: center; }
.ps-pm__label { font-size: 11px; color: var(--ps--neutral-400); }

.ps-popover {
  position: absolute; right: 86px; top: 50%; transform: translateY(-50%);
  width: 236px; background: var(--ps--bg-inverse); color: #fff;
  border-radius: 10px; padding: 13px 14px;
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.28); z-index: 6;
}
/* Klick-Variante: position:fixed (bricht aus der Tabellen-overflow aus),
   rechts unter dem Info-Icon verankert (top/right inline), animiert. */
.ps-popover--float {
  position: fixed; right: auto; top: auto; transform: none;
  width: 248px; z-index: 80;
  transform-origin: top right;
  animation: ps-pop-in 0.16s var(--ps--ease-out);
}
@keyframes ps-pop-in {
  from { opacity: 0; transform: translateY(-6px) scale(0.97); }
  to   { opacity: 1; transform: none; }
}
.ps-iconbtn.is-active { border-color: var(--ps--primary); color: var(--ps--primary); background: var(--ps--primary-soft); }
.ps-popover__title { font-weight: 700; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: #8fb9ab; margin-bottom: 9px; }
.ps-popover__row { display: flex; justify-content: space-between; gap: 12px; padding: 3px 0; font-size: 12px; }
.ps-popover__row span:first-child { color: rgba(255, 255, 255, 0.6); }
.ps-popover__row span:last-child { font-weight: 700; color: #fff; text-align: right; }

.ps-dash__empty { padding: 60px 20px; text-align: center; color: var(--ps--fg-muted); }

/* ===========================================================
   Projekt-Übersicht
   =========================================================== */
.ps-ov__eyebrow { font-weight: 700; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ps--primary); margin-bottom: 8px; }
.ps-ov__title { font-family: var(--ps--font-display); font-weight: 900; font-size: 34px; color: var(--ps--fg); margin: 0 0 10px; text-transform: uppercase; letter-spacing: -0.02em; }
.ps-ov__sub { display: flex; align-items: center; gap: 14px; color: var(--ps--neutral-500); font-size: 14px; margin-bottom: 22px; flex-wrap: wrap; }
.ps-ov__sub a { color: inherit; text-decoration: none; display: flex; align-items: center; gap: 6px; }
.ps-ov__sub a:hover { color: var(--ps--primary); }
.ps-ov__sub i { width: 14px; height: 14px; }
.ps-ov__metrics { display: flex; gap: 36px; padding: 16px 20px; background: #fff; border: 1px solid var(--ps--border); border-radius: 12px; margin-bottom: 26px; flex-wrap: wrap; }
.ps-ov__metric { display: flex; flex-direction: column; }
.ps-ov__metricVal { font-weight: 900; font-size: 22px; color: var(--ps--fg); }
.ps-ov__metricLabel { font-size: 11px; color: var(--ps--neutral-400); margin-top: 2px; }
.ps-ov__h2 { font-weight: 900; font-size: 16px; color: var(--ps--fg); margin: 0 0 14px; letter-spacing: -0.01em; }
.ps-ov__grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
@media (max-width: 1000px) { .ps-ov__grid { grid-template-columns: 1fr 1fr; } }
.ps-tile {
  background: #fff; border: 1px solid var(--ps--border); border-radius: 12px;
  padding: 16px; display: flex; flex-direction: column;
  cursor: pointer; box-shadow: var(--ps--shadow-xs); text-align: left;
}
.ps-tile:hover { border-color: var(--ps--border-strong); box-shadow: var(--ps--shadow-sm); }
.ps-tile__icon { width: 38px; height: 38px; border-radius: 9px; background: var(--ps--primary-soft); color: var(--ps--primary); display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.ps-tile__icon i { width: 19px; height: 19px; }
.ps-tile__name { font-weight: 900; font-size: 16px; color: var(--ps--fg); letter-spacing: -0.01em; }
.ps-tile__desc { font-size: 12.5px; color: var(--ps--neutral-500); margin-top: 3px; line-height: 1.45; }
.ps-tile__meta { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; }
.ps-tile__metaText { font-size: 11px; font-weight: 700; color: var(--ps--neutral-400); }
.ps-tile__arrow { width: 15px; height: 15px; color: var(--ps--primary); }

/* ===========================================================
   Login / Invite / Reset
   =========================================================== */
.ps-auth {
  position: fixed; inset: 0; z-index: 100;
  display: grid; grid-template-columns: 1fr 1fr;
  font-family: var(--ps--font-sans); background: var(--ps--neutral-50);
}
.ps-auth--splash { grid-template-columns: 1fr; place-items: center; background: var(--ps--bg-inverse); }
.ps-auth--splash .ps-auth__brand span,
.ps-auth--splash .ps-auth__brand b { color: #fff; }
.ps-auth--splash .ps-auth__brand b { color: var(--ps--accent); }
.ps-auth__panel {
  background: var(--ps--bg-inverse);
  color: #fff;
  padding: 48px 56px;
  display: flex; flex-direction: column;
  background-image: radial-gradient(circle at 20% 20%, rgba(255,255,255,.06), transparent 40%);
}
.ps-auth__panelMain { flex: 1; display: flex; align-items: center; }
.ps-auth__by { display: flex; flex-direction: column; gap: 12px; }
.ps-auth__byLogo { width: 250px; height: auto; max-width: 80%; opacity: 0.92; }
.ps-auth__by span { font-size: 11px; line-height: 1.4; color: rgba(255, 255, 255, 0.5); }
.ps-auth__brand { font-size: 30px; font-weight: 800; letter-spacing: -0.02em; }
.ps-auth__brand span { color: #fff; }
.ps-auth__brand b { color: var(--ps--accent); font-weight: 800; }
.ps-auth__logo { width: 420px; height: auto; max-width: 100%; display: block; }
.ps-auth--splash .ps-auth__logo { width: 260px; max-width: 70vw; }
.ps-auth__tag { font-size: 16px; color: rgba(255,255,255,.7); max-width: 360px; line-height: 1.5; margin: 0; }
.ps-auth__formWrap { display: flex; align-items: center; justify-content: center; padding: 40px; }
.ps-auth__form { width: 100%; max-width: 360px; display: flex; flex-direction: column; }
.ps-auth__title { font-size: 26px; font-weight: 900; color: var(--ps--fg); margin: 0 0 6px; letter-spacing: -0.01em; }
.ps-auth__sub { font-size: 14px; color: var(--ps--neutral-500); margin: 0 0 24px; }
.ps-auth__field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.ps-auth__field span { font-size: 12px; font-weight: 700; color: var(--ps--neutral-600); }
.ps-auth__field input {
  height: 44px; padding: 0 14px; border: 1px solid var(--ps--border); border-radius: 10px;
  background: #fff; font: 400 14px var(--ps--font-sans); color: var(--ps--fg); outline: none;
}
.ps-auth__field input:focus { border-color: var(--ps--primary); }
.ps-auth__submit {
  height: 46px; margin-top: 8px; border: 0; border-radius: 10px;
  background: var(--ps--primary); color: #fff; font-weight: 700; font-size: 15px; cursor: pointer;
}
.ps-auth__submit:hover { background: var(--ps--primary-hover); }
.ps-auth__submit:disabled { opacity: .6; cursor: default; }
.ps-auth__passkey {
  height: 44px; margin-top: 10px; border: 1px solid var(--ps--border-strong); border-radius: 10px;
  background: #fff; color: var(--ps--fg); font-weight: 700; font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.ps-auth__passkey:hover { border-color: var(--ps--fg); }
.ps-auth__passkey i { width: 16px; height: 16px; }
.ps-auth__links { margin-top: 16px; text-align: center; }
.ps-auth__links button { background: none; border: 0; color: var(--ps--primary); font-size: 13px; font-weight: 600; cursor: pointer; }
.ps-auth__err { background: rgba(220,38,38,.08); color: var(--ps--danger); font-size: 13px; padding: 10px 12px; border-radius: 8px; margin-bottom: 12px; }
.ps-auth__info { background: var(--ps--primary-soft); color: var(--ps--primary); font-size: 13px; padding: 10px 12px; border-radius: 8px; margin-bottom: 12px; }
@media (max-width: 820px) { .ps-auth { grid-template-columns: 1fr; } .ps-auth__panel { display: none; } }

/* ===========================================================
   Benutzer / Profil
   =========================================================== */
.ps-seg {
  height: 34px; padding: 0 12px; border: 1px solid var(--ps--border); border-radius: 8px;
  background: #fff; color: var(--ps--neutral-600); font-weight: 700; font-size: 13px; cursor: pointer;
}
.ps-seg.is-active { background: var(--ps--primary); border-color: var(--ps--primary); color: #fff; }
.ps-link { background: none; border: 0; color: var(--ps--primary); font-size: 12px; font-weight: 600; cursor: pointer; text-align: left; }

/* Hübsches Dropdown (Trigger wie ein Eingabefeld, Menü als Karte) */
.ps-select { position: relative; }
.ps-select__btn {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  width: 100%; height: 40px; padding: 0 10px 0 12px;
  border: 1px solid var(--ps--border-strong); border-radius: var(--ps--radius-sm);
  background: var(--ps--neutral-0); color: var(--ps--fg);
  font: 400 14px var(--ps--font-sans); text-align: left; cursor: pointer;
  transition: border-color var(--ps--duration-fast), box-shadow var(--ps--duration-fast);
}
.ps-select__btn:hover { border-color: var(--ps--fg); }
.ps-select__btn.is-open { border-color: var(--ps--primary); box-shadow: 0 0 0 3px var(--ps--focus-ring); }
.ps-select__btn > span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ps-select__ph { color: var(--ps--fg-subtle); }
.ps-select__caret { width: 16px; height: 16px; color: var(--ps--fg-muted); flex: 0 0 auto; }
.ps-select__menu {
  position: fixed; z-index: 70;
  background: #fff; border: 1px solid var(--ps--border); border-radius: 10px;
  box-shadow: var(--ps--shadow-lg); padding: 6px; max-height: 260px; overflow-y: auto;
  animation: ps-pop-in 0.14s var(--ps--ease-out); transform-origin: top center;
}
.ps-select__opt {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  width: 100%; padding: 9px 10px; border: 0; background: transparent; border-radius: 7px;
  font-size: 14px; font-weight: 600; color: var(--ps--fg); text-align: left; cursor: pointer;
}
.ps-select__opt:hover { background: var(--ps--bg-soft); }
.ps-select__opt.is-active { background: var(--ps--primary-soft); color: var(--ps--primary); }
.ps-select__check { width: 15px; height: 15px; flex: 0 0 auto; }

/* Passwort-Feld mit Generator + Stärkeanzeige */
.ps-pw__row { display: flex; gap: 8px; align-items: stretch; }
.ps-pw__input { flex: 1; min-width: 0; }
.ps-pw__gen { height: 40px; flex: 0 0 auto; white-space: nowrap; }
.ps-pw__meter { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.ps-pw__bars { display: flex; gap: 4px; flex: 1; }
.ps-pw__seg { flex: 1; height: 5px; border-radius: 999px; transition: background var(--ps--duration-fast); }
.ps-pw__label { font-size: 12px; font-weight: 700; flex: 0 0 auto; }

.ps-card { background: #fff; border: 1px solid var(--ps--border); border-radius: 14px; padding: 22px 24px; margin-bottom: 18px; max-width: 720px; }
.ps-card__h { font-size: 16px; font-weight: 900; color: var(--ps--fg); margin: 0 0 4px; letter-spacing: -0.01em; }
.ps-card__sub { font-size: 13px; color: var(--ps--neutral-500); margin: 0 0 16px; }
.ps-card .cp-modal__field { margin-bottom: 14px; }

.ps-profile__row { display: flex; align-items: center; gap: 18px; margin-bottom: 18px; }
.ps-profile__avatar {
  width: 72px; height: 72px; border-radius: 50%; flex: 0 0 auto;
  background: var(--ps--bg-inverse); color: #fff;
  display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 24px;
  background-size: cover; background-position: center;
}
.ps-profile__keys { display: flex; flex-direction: column; gap: 8px; }
.ps-profile__key { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border: 1px solid var(--ps--border); border-radius: 10px; }
.ps-profile__key i { width: 18px; height: 18px; color: var(--ps--primary); flex: 0 0 auto; }
.ps-profile__nokeys { font-size: 13px; color: var(--ps--neutral-500); padding: 8px 0; }
