/* =============================================================================
   Kuendigungscenter - App-Shell (Komponenten)
   Layout aus design/kuendigungscenter_apple_v2.html: Sidebar + Topbar + Content.
   Nutzt ausschliesslich die Tokens aus design-system.css.
   ============================================================================= */

/* -- Grundgeruest ---------------------------------------------------------- */
.app {
  display: grid;
  grid-template-columns: 248px 1fr;
  height: 100vh;
}

/* -- Sidebar --------------------------------------------------------------- */
.side {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 18px 14px;
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border-right: 1px solid var(--hair-2);
  overflow-y: auto;
}

.brand {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 6px 8px 16px;
}

.brand .mark {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 800;
  font-size: 16px;
  background: linear-gradient(140deg, var(--accent), var(--accent-2));
  box-shadow: 0 6px 16px -4px rgba(47, 107, 255, .6),
    inset 0 1px 0 rgba(255, 255, 255, .4);
}

.brand b {
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -.02em;
}

.brand small {
  display: block;
  color: var(--ink-3);
  font-size: 11px;
  font-weight: 450;
  letter-spacing: .01em;
}

.loc {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 10px 11px;
  margin-bottom: 8px;
  cursor: pointer;
  background: var(--glass-2);
  border: 1px solid var(--edge);
  border-radius: 13px;
  box-shadow: inset 0 1px 0 var(--edge);
  transition: transform .3s var(--ease-spring);
}

.loc:hover {
  transform: translateY(-1px);
}

.loc .pin {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 0 4px var(--ok-soft);
}

.loc b {
  font-size: 12.5px;
  font-weight: 600;
}

.loc small {
  display: block;
  color: var(--ink-3);
  font-size: 11px;
}

.loc .cx {
  margin-left: auto;
  color: var(--ink-3);
}

.nlabel {
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--ink-3);
  font-weight: 700;
  padding: 12px 10px 5px;
}

.nav {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 9px 11px;
  border-radius: 11px;
  color: var(--ink-2);
  font-weight: 450;
  font-size: 13.5px;
  cursor: pointer;
  position: relative;
  transition: color .25s var(--ease-soft), background .25s var(--ease-soft),
    transform .3s var(--ease-spring);
}

.nav svg {
  width: 18px;
  height: 18px;
  stroke-width: 1.7;
  flex: none;
}

.nav:hover {
  background: var(--glass-2);
  color: var(--ink);
  transform: translateX(2px);
}

.nav.on {
  color: var(--accent);
  font-weight: 600;
  background: var(--accent-soft);
}

.nav.on::before {
  content: "";
  position: absolute;
  left: -14px;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 20px;
  border-radius: 0 4px 4px 0;
  background: var(--accent);
}

.nav .pill {
  margin-left: auto;
  font-size: 11px;
  font-weight: 700;
  padding: 1px 8px;
  border-radius: 20px;
  background: var(--accent);
  color: #fff;
}

.side .spring {
  margin-top: auto;
}

.upsell {
  padding: 13px;
  border-radius: 15px;
  background: linear-gradient(150deg, var(--accent-soft), transparent);
  border: 1px solid var(--hair);
  font-size: 12px;
  color: var(--ink-2);
}

.upsell b {
  color: var(--ink);
  font-weight: 600;
  display: block;
  margin-bottom: 3px;
  font-size: 12.5px;
}

/* -- Hauptbereich ---------------------------------------------------------- */
.main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
}

.top {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 26px;
  border-bottom: 1px solid var(--hair-2);
  background: var(--glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
}

.search {
  flex: 1;
  max-width: 440px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  color: var(--ink-3);
  font-size: 13px;
  background: var(--glass-2);
  border: 1px solid var(--edge);
  border-radius: 12px;
  box-shadow: inset 0 1px 0 var(--edge);
  transition: box-shadow .3s var(--ease-soft), transform .3s var(--ease-spring);
  cursor: text;
}

.search:hover {
  transform: translateY(-1px);
}

.search input {
  flex: 1;
  border: 0;
  background: transparent;
  color: var(--ink);
  font-family: inherit;
  font-size: 13px;
}

.search input:focus {
  outline: none;
}

.search input::placeholder {
  color: var(--ink-3);
}

.search .kbd {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 11px;
  background: var(--hair);
  border-radius: 6px;
  padding: 2px 7px;
  color: var(--ink-2);
}

.grow {
  flex: 1;
}

/* Runde Topbar-Buttons (Theme-Toggle, Glocke ...) */
.tbtn {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  color: var(--ink-2);
  cursor: pointer;
  background: var(--glass-2);
  border: 1px solid var(--edge);
  box-shadow: inset 0 1px 0 var(--edge);
  transition: transform .35s var(--ease-spring), color .25s;
}

.tbtn:hover {
  transform: translateY(-2px);
  color: var(--ink);
}

.tbtn:active {
  transform: scale(.92);
}

.tbtn svg {
  width: 18px;
  height: 18px;
  stroke-width: 1.8;
}

.avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  background: linear-gradient(140deg, #1fbf75, #2f6bff);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .4);
}

/* Profil-Menue (Dropdown mit Abmelden). */
.profil {
  position: relative;
}

.profil-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 200px;
  padding: 8px;
  border-radius: 14px;
  background: var(--glass);
  border: 1px solid var(--edge);
  box-shadow: var(--shadow);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  z-index: 20;
  display: none;
}

.profil-menu.open {
  display: block;
  animation: pop .35s var(--ease-spring);
}

.profil-menu .who {
  padding: 8px 10px 10px;
  border-bottom: 1px solid var(--hair-2);
  margin-bottom: 6px;
}

.profil-menu .who b {
  font-size: 13px;
  font-weight: 600;
  display: block;
}

.profil-menu .who small {
  color: var(--ink-3);
  font-size: 11.5px;
}

.profil-menu form {
  margin: 0;
}

.profil-menu button.exit {
  width: 100%;
  text-align: left;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  color: var(--ink-2);
  padding: 9px 10px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 9px;
  transition: background .2s var(--ease-soft), color .2s;
}

.profil-menu button.exit:hover {
  background: var(--urgent-soft);
  color: var(--urgent);
}

.profil-menu button.exit svg {
  width: 16px;
  height: 16px;
}

@keyframes pop {
  0% {
    opacity: 0;
    transform: scale(.95) translateY(-6px);
  }

  100% {
    opacity: 1;
    transform: none;
  }
}

/* -- Scroll-Content -------------------------------------------------------- */
.scroll {
  flex: 1;
  overflow-y: auto;
  padding: 26px 26px 40px;
}

.head {
  display: flex;
  align-items: flex-end;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.head h1 {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -.03em;
}

.head p {
  color: var(--ink-2);
  font-size: 14px;
  margin-top: 4px;
}

/* -- Karten ---------------------------------------------------------------- */
.card {
  background: var(--glass);
  border: 1px solid var(--edge);
  border-radius: 22px;
  box-shadow: var(--shadow);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  position: relative;
  overflow: hidden;
}

.card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 22px;
  pointer-events: none;
  box-shadow: inset 0 1px 0 var(--edge);
}

.sec {
  padding: 20px 22px;
}

.sec + .sec {
  border-top: 1px solid var(--hair-2);
}

/* -- Primaer-/Ghost-Buttons ------------------------------------------------ */
.cta {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 13px 22px;
  border-radius: 14px;
  border: 0;
  cursor: pointer;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(140deg, var(--accent), var(--accent-2));
  box-shadow: 0 10px 24px -8px rgba(47, 107, 255, .65),
    inset 0 1px 0 rgba(255, 255, 255, .35);
  transition: transform .35s var(--ease-spring), box-shadow .35s;
}

.cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 32px -8px rgba(47, 107, 255, .75),
    inset 0 1px 0 rgba(255, 255, 255, .35);
}

.cta:active {
  transform: scale(.96);
}

.cta svg {
  width: 17px;
  height: 17px;
  stroke-width: 2;
}

.ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 15px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-2);
  cursor: pointer;
  background: var(--glass-2);
  border: 1px solid var(--edge);
  transition: transform .3s var(--ease-spring), color .2s;
}

.ghost:hover {
  transform: translateY(-2px);
  color: var(--ink);
}

.ghost:active {
  transform: scale(.95);
}

/* -- Platzhalter-Seite (Modul folgt) --------------------------------------- */
.stub {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 14px;
  padding: 60px 30px;
}

.stub .glyph {
  width: 64px;
  height: 64px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  color: var(--accent);
  background: var(--accent-soft);
}

.stub .glyph svg {
  width: 30px;
  height: 30px;
  stroke-width: 1.6;
}

.stub h2 {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -.02em;
}

.stub p {
  color: var(--ink-2);
  max-width: 440px;
}

/* -- Login ----------------------------------------------------------------- */
.login-wrap {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
}

.login-card {
  width: 100%;
  max-width: 400px;
  padding: 34px 30px;
  border-radius: 24px;
  background: var(--glass);
  border: 1px solid var(--edge);
  box-shadow: var(--shadow);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
}

.login-card .brand {
  justify-content: center;
  padding: 0 0 18px;
  text-align: center;
}

.login-card h1 {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: -.02em;
  text-align: center;
}

.login-card .lead {
  color: var(--ink-2);
  text-align: center;
  margin: 6px 0 22px;
  font-size: 13px;
}

.field {
  margin-bottom: 14px;
}

.field label {
  display: block;
  font-size: 11.5px;
  color: var(--ink-2);
  font-weight: 500;
  margin-bottom: 6px;
}

.field label .req {
  color: var(--urgent);
  font-weight: 800;
  margin-left: 3px;
}

.inp {
  width: 100%;
  padding: 11px 13px;
  border-radius: 11px;
  font-size: 13.5px;
  color: var(--ink);
  font-family: inherit;
  background: var(--glass-2);
  border: 1px solid var(--hair);
  box-shadow: inset 0 1px 0 var(--edge);
  transition: border-color .25s, box-shadow .25s;
}

.inp::placeholder {
  color: var(--ink-3);
}

.inp:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft);
}

.login-card .cta {
  width: 100%;
  justify-content: center;
  margin-top: 6px;
}

.formerror {
  display: flex;
  gap: 9px;
  align-items: flex-start;
  padding: 11px 13px;
  border-radius: 12px;
  background: var(--urgent-soft);
  border: 1px solid rgba(245, 72, 74, .3);
  color: var(--ink);
  font-size: 12.5px;
  margin-bottom: 16px;
  line-height: 1.45;
}

.formerror svg {
  width: 17px;
  height: 17px;
  color: var(--urgent);
  flex: none;
  margin-top: 1px;
}

.login-foot {
  margin-top: 18px;
  text-align: center;
  font-size: 11.5px;
  color: var(--ink-3);
}

.login-foot .toggle {
  cursor: pointer;
  color: var(--ink-2);
}

/* -- Responsiv ------------------------------------------------------------- */
@media (max-width: 960px) {
  .app {
    grid-template-columns: 1fr;
  }

  .side {
    display: none;
  }

  .search .kbd {
    display: none;
  }
}
