:root{--bg:#0f172a;--panel:rgba(255,255,255,.08);--border:rgba(255,255,255,.14);--text:#f8fafc;--muted:#94a3b8;--green:#22c55e;--red:#ef4444;--accent:#38bdf8;--accent2:#818cf8;--shadow:0 20px 60px rgba(0,0,0,.35)}*{box-sizing:border-box}html{color-scheme:dark}body{margin:0;min-height:100vh;color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at top left,rgba(56,189,248,.28),transparent 35%),radial-gradient(circle at top right,rgba(129,140,248,.25),transparent 30%),var(--bg)}button,input,select{font:inherit}button{border:0;border-radius:16px;padding:14px 18px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));font-weight:800;cursor:pointer;transition:transform .15s ease,opacity .15s ease}button:hover{transform:translateY(-1px)}button:disabled{opacity:.65;cursor:wait;transform:none}input,select{width:100%;border:1px solid rgba(255,255,255,.16);border-radius:16px;outline:0;padding:14px 16px;color:var(--text);background:rgba(15,23,42,.75)}input:focus,select:focus{border-color:var(--accent)}label{display:grid;gap:8px;margin-bottom:16px;color:var(--muted);font-weight:650}h1,h2,h3,p{overflow-wrap:anywhere}.eyebrow{margin:0 0 8px;color:var(--accent);font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.subtitle,.auth-subtitle{max-width:680px;margin:12px 0 0;color:var(--muted);font-size:1.02rem;line-height:1.55}.auth-page{display:grid;place-items:center;padding:24px}.auth-shell{width:min(100%,470px)}.auth-card{padding:32px;border:1px solid var(--border);border-radius:26px;background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(16px)}.auth-card h1{margin:0;font-size:clamp(2rem,8vw,3rem)}.auth-form{display:grid;gap:2px;margin-top:28px}.auth-form button{width:100%;margin-top:4px}.auth-footer{margin:24px 0 0;color:var(--muted);text-align:center}.auth-footer a{color:#bae6fd;font-weight:800;text-decoration:none}.auth-alert{margin-top:22px;padding:13px 15px;border:1px solid rgba(239,68,68,.36);border-radius:15px;color:#fecaca;background:rgba(127,29,29,.25);font-weight:650;line-height:1.4}.app{width:min(1180px,94%);margin:0 auto;padding:42px 0}.hero,.hero-actions,.list-header,.chart-heading,.chart-intro,.pot-card-top{display:flex;align-items:center;justify-content:space-between;gap:18px}.hero{align-items:flex-start;margin-bottom:28px}.hero h1{margin:0;font-size:clamp(2.2rem,6vw,4.5rem);line-height:1}.hero-actions{flex:1 1 440px;align-items:flex-end;justify-content:flex-end;flex-wrap:wrap}.header-buttons{display:flex;gap:10px;flex-wrap:wrap}.header-buttons form{margin:0}.account-chip{display:inline-flex;max-width:260px;align-items:center;gap:8px;overflow:hidden;padding:10px 13px;border:1px solid rgba(255,255,255,.13);border-radius:999px;color:var(--muted);background:rgba(15,23,42,.55);font-size:.87rem;font-weight:650;text-overflow:ellipsis;white-space:nowrap}.account-dot{width:8px;height:8px;flex:0 0 auto;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(34,197,94,.16)}.tab-switcher{display:flex;padding:4px;border:1px solid rgba(255,255,255,.13);border-radius:18px;background:rgba(15,23,42,.55)}.tab-button{border:0;border-radius:13px;padding:10px 14px;color:var(--muted);background:transparent;font-weight:800}.tab-button.active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}.cards,.chart-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}.card,.panel,.chart-stat{border:1px solid var(--border);border-radius:24px;background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(16px)}.card,.chart-stat{padding:22px}.card span,.chart-stat span{display:block;margin-bottom:10px;color:var(--muted)}.card strong,.chart-stat strong{font-size:1.7rem}.highlight{background:linear-gradient(135deg,rgba(56,189,248,.22),rgba(129,140,248,.22))}.grid{display:grid;grid-template-columns:1.15fr .85fr;gap:16px;margin-bottom:16px}.panel{padding:24px}.panel h2{margin:0;font-size:1.18rem}.two,.filters{display:grid;grid-template-columns:1fr 1fr;gap:14px}.ghost{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.1)}.danger{color:#fecaca}.result-box{margin-top:14px;padding:18px;border-radius:18px;background:rgba(15,23,42,.55)}.result-box p{margin:0 0 8px;color:var(--muted)}.result-box strong{font-size:1.45rem}.list-header{align-items:center;flex-wrap:wrap}.sort-controls{display:flex;gap:10px;flex-wrap:wrap}.list-hint{margin:8px 0 0;color:var(--muted);font-size:.92rem;line-height:1.45}.entries-toolbar{display:grid;grid-template-columns:minmax(220px,1.55fr) minmax(170px,.8fr) minmax(140px,.65fr);gap:14px;margin-top:22px;padding:16px;border:1px solid rgba(255,255,255,.09);border-radius:20px;background:rgba(15,23,42,.35)}.entries-toolbar label{margin:0}.entries-status{min-height:1.25rem;margin:16px 2px -4px;color:var(--muted);font-size:.92rem}.entries{display:grid;gap:10px;margin-top:18px}.entry{display:grid;grid-template-columns:1.2fr .7fr .7fr auto;gap:12px;align-items:center;padding:14px;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:rgba(15,23,42,.55)}.entry-title{font-weight:800}.entry-date,.entry-type{color:var(--muted)}.amount.income{color:var(--green);font-weight:900}.amount.expense{color:var(--red);font-weight:900}.delete{border:1px solid rgba(239,68,68,.3);padding:10px 12px;color:#fecaca;background:rgba(239,68,68,.15)}.empty{padding:30px;color:var(--muted);text-align:center}.load-more-wrap{display:flex;justify-content:center;margin-top:18px}#loadMoreBtn[hidden]{display:none}.tab-view{display:none}.tab-view.active{display:block}.chart-intro{align-items:end;margin-bottom:16px}.chart-year-select{min-width:205px;margin:0}.chart-stats{grid-template-columns:repeat(3,1fr)}.charts-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:16px}.chart-panel{min-width:0}.chart-heading{align-items:flex-start;margin-bottom:16px}.chart-heading p{margin:7px 0 0;color:var(--muted)}.canvas-wrap{position:relative;width:100%;overflow:hidden;border-radius:18px;background:rgba(15,23,42,.43)}.pie-wrap{height:315px}.bar-wrap{height:355px}.pot-intro{margin-bottom:16px}.pot-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}.pots-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:16px;margin-bottom:16px}.pot-guide{display:flex;flex-direction:column;justify-content:center}.optional{color:var(--muted);font-weight:500}.pot-form-error{min-height:1.25rem;margin:-6px 0 12px;color:#fca5a5;font-size:.9rem;font-weight:650}.pot-note{margin:18px 0 0;color:var(--muted);font-size:.92rem;line-height:1.5}.pots-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:18px}.pot-card{min-width:0;padding:20px;border:1px solid rgba(255,255,255,.12);border-radius:22px;background:radial-gradient(circle at top right,rgba(56,189,248,.12),transparent 42%),rgba(15,23,42,.48)}.pot-card.is-complete{border-color:rgba(34,197,94,.5)}.pot-card.is-overdue{border-color:rgba(239,68,68,.46)}.pot-card-top{align-items:flex-start}.pot-card-top h3{margin:0;font-size:1.2rem}.pot-date{margin:6px 0 0;color:var(--muted);font-size:.9rem}.pot-badge{flex:0 0 auto;padding:7px 10px;border:1px solid rgba(56,189,248,.33);border-radius:999px;color:#bae6fd;background:rgba(14,116,144,.16);font-size:.78rem;font-weight:800}.pot-card.is-complete .pot-badge{border-color:rgba(34,197,94,.4);color:#bbf7d0;background:rgba(22,163,74,.16)}.pot-card.is-overdue .pot-badge{border-color:rgba(239,68,68,.42);color:#fecaca;background:rgba(185,28,28,.16)}.pot-amounts{display:flex;align-items:baseline;gap:8px;margin:22px 0 10px}.pot-current{font-size:1.7rem;font-weight:900}.pot-target{color:var(--muted);font-size:.98rem;font-weight:650}.pot-progress-track{width:100%;height:12px;overflow:hidden;border-radius:999px;background:rgba(148,163,184,.18)}.pot-progress-bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .25s ease}.pot-card.is-complete .pot-progress-bar{background:linear-gradient(90deg,#22c55e,#86efac)}.pot-card.is-overdue .pot-progress-bar{background:linear-gradient(90deg,#ef4444,#fb7185)}.pot-progress-label{margin:10px 0 0;color:var(--muted);font-size:.9rem}.pot-metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}.pot-metric{padding:13px;border-radius:16px;background:rgba(15,23,42,.55)}.pot-metric span{display:block;margin-bottom:5px;color:var(--muted);font-size:.78rem}.pot-metric strong{font-size:1.03rem}.pot-deposit-form{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end;margin-top:18px}.pot-deposit-form label{margin:0}.pot-deposit-form input{padding:12px 14px}.pot-deposit-form button{min-height:50px;padding:12px 15px}.pot-history{margin:14px 0 0;color:var(--muted);font-size:.85rem}.pot-actions{display:flex;justify-content:flex-end;margin-top:14px}.pot-delete{padding:9px 12px;font-size:.84rem}body.modal-open{overflow:hidden}.modal[hidden],.toast[hidden]{display:none}.modal{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:20px}.modal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.74);backdrop-filter:blur(7px)}.delete-modal-card{position:relative;z-index:1;width:min(100%,490px);padding:30px;border:1px solid rgba(255,255,255,.18);border-radius:26px;background:radial-gradient(circle at top right,rgba(239,68,68,.16),transparent 38%),rgba(15,23,42,.98);box-shadow:0 28px 90px rgba(0,0,0,.55)}.delete-modal-card h2{margin-top:2px;font-size:1.55rem}.modal-text{margin:12px 0 20px;color:var(--muted);line-height:1.55}.modal-close{position:absolute;top:14px;right:14px;display:grid;width:38px;height:38px;place-items:center;padding:0;border:1px solid rgba(255,255,255,.13);border-radius:12px;color:var(--muted);background:rgba(255,255,255,.07);font-size:1.55rem;font-weight:500;line-height:1}.delete-code{margin:10px 0 20px;padding:16px;border:1px dashed rgba(56,189,248,.72);border-radius:18px;color:#e0f2fe;background:rgba(14,116,144,.18);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:clamp(1.7rem,6vw,2.35rem);font-weight:900;letter-spacing:.22em;text-align:center}.delete-code-error{min-height:1.25rem;margin:-6px 0 12px;color:#fca5a5;font-size:.9rem;font-weight:650}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}.danger-fill{background:linear-gradient(135deg,#ef4444,#e11d48)}.toast{position:fixed;right:20px;bottom:20px;z-index:1100;max-width:min(390px,calc(100vw - 40px));padding:14px 17px;border:1px solid rgba(56,189,248,.36);border-radius:16px;color:#e0f2fe;background:rgba(14,116,144,.94);box-shadow:var(--shadow);font-weight:700;line-height:1.4}.toast.error{border-color:rgba(239,68,68,.42);color:#fecaca;background:rgba(153,27,27,.94)}@media(max-width:1000px){.cards{grid-template-columns:repeat(2,1fr)}.grid,.charts-grid,.pots-layout{grid-template-columns:1fr}}@media(max-width:900px){.hero,.chart-intro{align-items:flex-start;flex-direction:column}.hero-actions{align-items:flex-start;justify-content:flex-start}.chart-stats,.pot-summary,.pots-list{grid-template-columns:1fr}.chart-year-select{width:100%}}@media(max-width:760px){.entries-toolbar{grid-template-columns:1fr}}@media(max-width:620px){.app{width:min(94%,1180px);padding:24px 0}.auth-card{padding:25px 20px}.two,.filters,.pot-metrics,.pot-deposit-form{grid-template-columns:1fr}.entry{grid-template-columns:1fr}.sort-controls,.sort-controls button{width:100%}.tab-switcher,.tab-button{width:100%}.header-buttons{width:100%}.header-buttons button{flex:1 1 auto}.pot-deposit-form button{width:100%}.modal-actions,.modal-actions button{width:100%}.modal-actions{flex-direction:column-reverse}}


/* -------------------------------------------------------
   Mobile-Optimierung
   ------------------------------------------------------- */

.mobile-nav,
.mobile-quick-add {
  display: none;
}

.mobile-nav-icon {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

@media (max-width: 740px) {
  html {
    scroll-padding-top: 16px;
  }

  body.app-page {
    padding-bottom: calc(94px + env(safe-area-inset-bottom));
  }

  .app {
    width: 100%;
    padding: 20px 14px 28px;
  }

  .hero {
    gap: 14px;
    margin-bottom: 20px;
  }

  .hero h1 {
    font-size: clamp(2rem, 10vw, 2.65rem);
  }

  .subtitle,
  .auth-subtitle {
    font-size: 0.95rem;
  }

  .hero-actions {
    width: 100%;
    gap: 10px;
  }

  .hero-actions > .tab-switcher {
    display: none;
  }

  .account-chip {
    width: 100%;
    max-width: none;
    justify-content: center;
  }

  .header-buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    gap: 8px;
  }

  .header-buttons form {
    display: contents;
  }

  .header-buttons button {
    min-width: 0;
    min-height: 46px;
    padding: 10px 12px;
    font-size: 0.84rem;
    line-height: 1.2;
  }

  button {
    min-height: 46px;
  }

  input,
  select {
    min-height: 48px;
    font-size: 16px;
  }

  label {
    gap: 7px;
    margin-bottom: 14px;
    font-size: 0.94rem;
  }

  .cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 10px;
  }

  .card,
  .chart-stat {
    min-width: 0;
    padding: 16px;
    border-radius: 20px;
  }

  .card span,
  .chart-stat span {
    min-height: 2.2em;
    margin-bottom: 8px;
    font-size: 0.82rem;
    line-height: 1.3;
  }

  .card strong,
  .chart-stat strong {
    display: block;
    overflow: hidden;
    font-size: clamp(1.1rem, 5vw, 1.45rem);
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .grid,
  .charts-grid,
  .pots-layout {
    gap: 10px;
    margin-bottom: 10px;
  }

  .panel {
    padding: 18px;
    border-radius: 20px;
  }

  .panel h2 {
    font-size: 1.1rem;
  }

  .two,
  .filters,
  .pot-metrics,
  .pot-deposit-form {
    gap: 10px;
  }

  .result-box {
    margin-top: 10px;
    padding: 15px;
    border-radius: 16px;
  }

  .result-box strong {
    font-size: 1.2rem;
  }

  .list-header {
    align-items: flex-start;
    gap: 14px;
  }

  .sort-controls {
    width: calc(100% + 4px);
    flex-wrap: nowrap;
    overflow-x: auto;
    margin: 0 -2px;
    padding: 2px 2px 8px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .sort-controls::-webkit-scrollbar {
    display: none;
  }

  .sort-controls button {
    flex: 0 0 auto;
    min-height: 42px;
    padding: 10px 13px;
    white-space: nowrap;
    font-size: 0.84rem;
  }

  .entries-toolbar {
    gap: 12px;
    margin-top: 16px;
    padding: 14px;
    border-radius: 18px;
  }

  .entries-status {
    margin: 14px 2px -4px;
  }

  .entries {
    gap: 8px;
    margin-top: 14px;
  }

  .entry {
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "info delete"
      "type amount";
    gap: 9px 12px;
    padding: 14px;
    border-radius: 17px;
  }

  .entry > div:first-child {
    grid-area: info;
    min-width: 0;
  }

  .entry-type {
    grid-area: type;
    font-size: 0.86rem;
  }

  .entry .amount {
    grid-area: amount;
    text-align: right;
    font-size: 0.95rem;
  }

  .entry .delete {
    grid-area: delete;
    min-height: 38px;
    padding: 8px 10px;
    font-size: 0.8rem;
  }

  .load-more-wrap {
    margin-top: 14px;
  }

  .load-more-wrap button {
    width: 100%;
  }

  .chart-intro {
    gap: 14px;
  }

  .chart-year-select {
    min-width: 0;
  }

  .chart-stats,
  .pot-summary,
  .pots-list {
    gap: 10px;
  }

  .pie-wrap {
    height: 270px;
  }

  .bar-wrap {
    height: 290px;
  }

  .pot-card {
    padding: 17px;
    border-radius: 20px;
  }

  .pot-card-top {
    gap: 10px;
  }

  .pot-badge {
    max-width: 48%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .pot-current {
    font-size: 1.45rem;
  }

  .pot-deposit-form button {
    min-height: 48px;
  }

  .mobile-nav {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 800;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
    padding:
      8px
      max(12px, env(safe-area-inset-right))
      calc(8px + env(safe-area-inset-bottom))
      max(12px, env(safe-area-inset-left));
    border-top: 1px solid rgba(255, 255, 255, 0.13);
    background: rgba(15, 23, 42, 0.92);
    box-shadow: 0 -12px 34px rgba(2, 6, 23, 0.34);
    backdrop-filter: blur(18px);
  }

  .mobile-tab-button {
    display: flex;
    min-width: 0;
    min-height: 58px;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 8px 6px;
    border: 1px solid transparent;
    border-radius: 16px;
    color: var(--muted);
    background: transparent;
    font-size: 0.74rem;
    font-weight: 800;
    line-height: 1.1;
  }

  .mobile-tab-button.active {
    border-color: rgba(56, 189, 248, 0.3);
    color: #e0f2fe;
    background: linear-gradient(135deg, rgba(56, 189, 248, 0.24), rgba(129, 140, 248, 0.24));
  }

  .mobile-quick-add {
    position: fixed;
    right: 16px;
    bottom: calc(82px + env(safe-area-inset-bottom));
    z-index: 801;
    display: inline-flex;
    min-height: 48px;
    align-items: center;
    gap: 8px;
    padding: 11px 15px;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    box-shadow: 0 13px 30px rgba(2, 6, 23, 0.4);
    font-size: 0.9rem;
  }

  .mobile-quick-add span:first-child {
    font-size: 1.35rem;
    font-weight: 500;
    line-height: 0.8;
  }

  .toast {
    right: 14px;
    bottom: calc(88px + env(safe-area-inset-bottom));
    left: 14px;
    max-width: none;
  }

  .modal {
    align-items: end;
    padding: 0;
  }

  .delete-modal-card {
    width: 100%;
    max-height: min(86dvh, 700px);
    overflow-y: auto;
    padding: 27px 20px calc(22px + env(safe-area-inset-bottom));
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    border-radius: 28px 28px 0 0;
  }

  .delete-code {
    font-size: clamp(1.5rem, 9vw, 2rem);
  }

  .auth-page {
    align-items: end;
    padding: max(16px, env(safe-area-inset-top)) 16px max(16px, env(safe-area-inset-bottom));
  }

  .auth-card {
    width: 100%;
    padding: 26px 20px;
    border-radius: 24px;
  }
}

@media (max-width: 390px) {
  .header-buttons button {
    padding: 10px 8px;
    font-size: 0.78rem;
  }

  .card {
    padding: 14px;
  }

  .card span,
  .chart-stat span {
    font-size: 0.76rem;
  }

  .mobile-tab-button {
    font-size: 0.68rem;
  }

  .mobile-quick-add {
    right: 12px;
    padding: 10px 13px;
  }
}


/* =======================================================
   Feature Pack: Planung, Budgets, Kategorien & PWA
   ======================================================= */

.feature-tools {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.feature-tools .ghost {
  min-height: 42px;
  padding: 10px 13px;
  font-size: .86rem;
}

.quick-widgets {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin: 0 0 16px;
}

.quick-widget {
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--panel-border);
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(56, 189, 248, .13), transparent 44%),
    var(--panel);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
}

.quick-widget .widget-label {
  display: block;
  margin-bottom: 8px;
  color: var(--muted);
  font-size: .82rem;
  font-weight: 700;
}

.quick-widget strong {
  display: block;
  overflow: hidden;
  font-size: 1.15rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.quick-widget p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.35;
}

.quick-widget.warning {
  border-color: rgba(245, 158, 11, .34);
  background:
    radial-gradient(circle at top right, rgba(245, 158, 11, .16), transparent 44%),
    var(--panel);
}

.quick-widget.danger {
  border-color: rgba(239, 68, 68, .35);
  background:
    radial-gradient(circle at top right, rgba(239, 68, 68, .16), transparent 44%),
    var(--panel);
}

.entry-extra-controls {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: -2px 0 16px;
}

.status-pill,
.category-pill,
.rule-pill {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  padding: 5px 8px;
  border: 1px solid rgba(148, 163, 184, .24);
  border-radius: 999px;
  color: #cbd5e1;
  background: rgba(15, 23, 42, .5);
  font-size: .76rem;
  font-weight: 750;
  line-height: 1;
}

.status-pill.open {
  border-color: rgba(245, 158, 11, .38);
  color: #fde68a;
  background: rgba(180, 83, 9, .15);
}

.status-pill.paid {
  border-color: rgba(34, 197, 94, .32);
  color: #bbf7d0;
  background: rgba(20, 83, 45, .2);
}

.status-button {
  border-radius: 12px;
  min-height: 38px;
  padding: 8px 10px;
  font-size: .78rem;
  white-space: nowrap;
}

.entry .entry-subline {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 7px;
}

.entry .entry-date {
  margin-top: 3px;
}

.planning-intro {
  margin-bottom: 16px;
}

.planning-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, .98fr);
  gap: 16px;
  margin-bottom: 16px;
}

.planning-section {
  min-width: 0;
}

.plan-list {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.budget-row,
.rule-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  background: rgba(15,23,42,.53);
}

.budget-row.warning {
  border-color: rgba(245,158,11,.38);
}

.budget-row.over {
  border-color: rgba(239,68,68,.42);
}

.plan-row-title {
  min-width: 0;
  font-weight: 850;
}

.plan-row-subtitle {
  margin-top: 4px;
  color: var(--muted);
  font-size: .84rem;
}

.plan-row-value {
  color: var(--text);
  font-weight: 850;
  text-align: right;
}

.plan-progress {
  grid-column: 1 / -1;
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(148,163,184,.17);
}

.plan-progress > span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
}

.budget-row.warning .plan-progress > span {
  background: linear-gradient(90deg, #f59e0b, #fbbf24);
}

.budget-row.over .plan-progress > span {
  background: linear-gradient(90deg, #ef4444, #fb7185);
}

.rule-row.inactive {
  opacity: .55;
}

.rule-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.rule-actions button {
  min-height: 38px;
  padding: 8px 10px;
  border-radius: 12px;
  font-size: .78rem;
}

.feature-empty {
  padding: 22px;
  border: 1px dashed rgba(148,163,184,.26);
  border-radius: 17px;
  color: var(--muted);
  text-align: center;
}

.planning-small-note {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: .83rem;
  line-height: 1.45;
}

.install-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(56,189,248,.28);
  border-radius: 19px;
  color: #dbeafe;
  background: rgba(14,116,144,.16);
}

.install-banner p {
  margin: 0;
  font-size: .9rem;
  line-height: 1.4;
}

@media (max-width: 1000px) {
  .quick-widgets {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .planning-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 740px) {
  .quick-widgets {
    gap: 10px;
    margin-bottom: 10px;
  }

  .quick-widget {
    padding: 15px;
    border-radius: 19px;
  }

  .quick-widget .widget-label {
    min-height: 2.3em;
    font-size: .76rem;
    line-height: 1.25;
  }

  .quick-widget strong {
    font-size: 1rem;
  }

  .quick-widget p {
    font-size: .78rem;
  }

  .feature-tools {
    width: 100%;
  }

  .feature-tools .ghost {
    flex: 1 1 auto;
  }

  .entry-extra-controls {
    grid-template-columns: 1fr;
    gap: 10px;
    margin-bottom: 14px;
  }

  .budget-row,
  .rule-row {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 9px 12px;
    padding: 13px;
  }

  .plan-row-value {
    grid-column: 2;
    grid-row: 1;
    align-self: start;
  }

  .budget-row .delete,
  .rule-actions {
    grid-column: 1 / -1;
    justify-content: stretch;
  }

  .rule-actions button {
    flex: 1 1 auto;
  }

  .install-banner {
    align-items: flex-start;
    flex-direction: column;
  }

  .install-banner button {
    width: 100%;
  }
}

@media (max-width: 390px) {
  .quick-widget strong {
    font-size: .92rem;
  }

  .status-button {
    padding: 7px 8px;
    font-size: .73rem;
  }
}


.entries-toolbar.feature-expanded {
  grid-template-columns: minmax(190px, 1.5fr) repeat(4, minmax(135px, .75fr));
}

.entry-actions {
  display: flex;
  justify-content: flex-end;
  gap: 7px;
  flex-wrap: wrap;
}

.disabled-control {
  opacity: .58;
}

@media (max-width: 900px) {
  .entries-toolbar.feature-expanded {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 740px) {
  .entries-toolbar.feature-expanded {
    grid-template-columns: 1fr;
  }

  .entry {
    grid-template-areas:
      "info actions"
      "type amount";
  }

  .entry-actions {
    grid-area: actions;
    align-items: flex-start;
    justify-content: flex-end;
    flex-direction: column;
  }

  .entry .entry-actions .delete,
  .entry .entry-actions .status-button {
    grid-area: auto;
    min-height: 34px;
    padding: 7px 9px;
  }

  .mobile-nav.has-planning {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .mobile-nav.has-planning .mobile-tab-button {
    min-height: 57px;
    font-size: .67rem;
  }
}


/* Account, security and monthly-review update */

.account-link {
  text-decoration: none;
  transition: border-color .15s ease, color .15s ease, transform .15s ease;
}

.account-link:hover {
  border-color: rgba(56, 189, 248, .52);
  color: #e0f2fe;
  transform: translateY(-1px);
}

.account-caret {
  color: #7dd3fc;
  font-size: 1.25rem;
  line-height: .7;
}

.monthly-overview {
  margin: 16px 0;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(129, 140, 248, .16), transparent 36%),
    var(--panel);
}

.monthly-overview-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.monthly-overview-head h2 {
  margin: 0;
}

.monthly-overview-badge {
  flex: 0 0 auto;
  padding: 9px 12px;
  border: 1px solid rgba(148, 163, 184, .28);
  border-radius: 999px;
  color: #e2e8f0;
  background: rgba(15, 23, 42, .55);
  font-weight: 900;
}

.monthly-overview-badge.positive {
  border-color: rgba(34, 197, 94, .38);
  color: #bbf7d0;
  background: rgba(20, 83, 45, .23);
}

.monthly-overview-badge.negative {
  border-color: rgba(239, 68, 68, .38);
  color: #fecaca;
  background: rgba(127, 29, 29, .22);
}

.monthly-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 20px;
}

.monthly-metric {
  min-width: 0;
  padding: 15px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 17px;
  background: rgba(15, 23, 42, .45);
}

.monthly-metric span {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: .8rem;
  line-height: 1.35;
}

.monthly-metric strong {
  display: block;
  overflow: hidden;
  font-size: 1.05rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.monthly-overview-insight {
  margin: 16px 0 0;
  color: #cbd5e1;
  line-height: 1.5;
}

.edit-button {
  padding: 9px 12px;
  color: #dbeafe;
  font-size: .84rem;
}

.edit-modal-card {
  position: relative;
  z-index: 1;
  width: min(100%, 610px);
  max-height: min(88vh, 760px);
  overflow-y: auto;
  padding: 30px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 26px;
  background:
    radial-gradient(circle at top right, rgba(56,189,248,.15), transparent 38%),
    rgba(15,23,42,.98);
  box-shadow: 0 28px 90px rgba(0,0,0,.55);
}

.edit-modal-card h2 {
  margin-top: 2px;
  font-size: 1.55rem;
}

.settings-page {
  min-height: 100vh;
  padding: 38px 0;
}

.settings-shell {
  width: min(1040px, 94%);
  margin: 0 auto;
}

.settings-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
}

.back-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #bae6fd;
  font-weight: 800;
  text-decoration: none;
}

.back-link:hover {
  text-decoration: underline;
}

.settings-hero {
  margin-bottom: 20px;
}

.settings-hero h1 {
  margin: 0;
  font-size: clamp(2rem, 6vw, 3.35rem);
}

.settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}

.settings-card {
  min-width: 0;
}

.settings-card.full {
  grid-column: 1 / -1;
}

.settings-card h2 {
  margin-bottom: 8px;
}

.settings-card > p {
  color: var(--muted);
  line-height: 1.55;
}

.settings-alert {
  margin: 0 0 16px;
  padding: 14px 16px;
  border: 1px solid rgba(56,189,248,.35);
  border-radius: 16px;
  color: #e0f2fe;
  background: rgba(14,116,144,.17);
  line-height: 1.45;
}

.settings-alert.error {
  border-color: rgba(239,68,68,.4);
  color: #fecaca;
  background: rgba(127,29,29,.25);
}

.settings-alert.success {
  border-color: rgba(34,197,94,.38);
  color: #bbf7d0;
  background: rgba(20,83,45,.25);
}

.settings-status {
  display: inline-flex;
  margin: 12px 0 4px;
  padding: 7px 10px;
  border: 1px solid rgba(148,163,184,.28);
  border-radius: 999px;
  color: #cbd5e1;
  background: rgba(15,23,42,.5);
  font-size: .84rem;
  font-weight: 800;
}

.settings-status.enabled {
  border-color: rgba(34,197,94,.4);
  color: #bbf7d0;
  background: rgba(20,83,45,.23);
}

.setup-secret {
  margin: 16px 0;
  padding: 14px;
  overflow-wrap: anywhere;
  border: 1px dashed rgba(56,189,248,.62);
  border-radius: 16px;
  color: #e0f2fe;
  background: rgba(14,116,144,.15);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 1.04rem;
  font-weight: 800;
  letter-spacing: .08em;
}

.setup-steps {
  margin: 14px 0 20px;
  padding-left: 21px;
  color: #cbd5e1;
  line-height: 1.55;
}

.recovery-codes {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 16px 0;
}

.recovery-code {
  padding: 11px 13px;
  border-radius: 12px;
  color: #e0f2fe;
  background: rgba(15,23,42,.64);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-weight: 800;
  letter-spacing: .08em;
}

.security-warning {
  margin-top: 16px;
  padding: 13px;
  border-left: 3px solid #f59e0b;
  color: #fef3c7;
  background: rgba(146,64,14,.16);
  line-height: 1.5;
}

.twofactor-page .auth-card {
  width: min(100%, 520px);
}

.twofactor-page .auth-card code {
  color: #bae6fd;
}

@media (max-width: 900px) {
  .monthly-overview-grid,
  .settings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 740px) {
  .monthly-overview {
    margin: 10px 0;
  }

  .monthly-overview-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .monthly-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .monthly-metric {
    padding: 13px;
  }

  .entry .entry-actions .edit-button {
    grid-area: auto;
    min-height: 34px;
    padding: 7px 9px;
  }

  .settings-page {
    padding: 22px 0 calc(92px + env(safe-area-inset-bottom));
  }

  .settings-topbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .settings-grid {
    grid-template-columns: 1fr;
  }

  .settings-card.full {
    grid-column: auto;
  }

  .edit-modal-card {
    width: 100%;
    max-height: min(88dvh, 760px);
    padding: 27px 20px calc(22px + env(safe-area-inset-bottom));
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    border-radius: 28px 28px 0 0;
  }

  .edit-entry-modal {
    align-items: end;
    padding: 0;
  }

  .recovery-codes {
    grid-template-columns: 1fr;
  }
}


/* -------------------------------------------------------
   Account UI + QR setup refinement
   ------------------------------------------------------- */

.monthly-overview {
  margin: 22px 0 30px;
  border-color: rgba(129, 140, 248, .26);
}

.monthly-overview + .grid {
  margin-top: 0;
}

.settings-page {
  background:
    radial-gradient(circle at 12% 2%, rgba(56, 189, 248, .18), transparent 28%),
    radial-gradient(circle at 90% 8%, rgba(129, 140, 248, .17), transparent 25%),
    var(--bg);
}

.settings-shell {
  width: min(1120px, 94%);
}

.settings-topbar {
  margin-bottom: 18px;
}

.settings-top-note {
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  color: var(--muted);
  background: rgba(15, 23, 42, .5);
  font-size: .82rem;
  font-weight: 800;
}

.back-link {
  padding: 10px 0;
}

.back-link-arrow {
  display: inline-grid;
  width: 29px;
  height: 29px;
  place-items: center;
  border: 1px solid rgba(56,189,248,.25);
  border-radius: 10px;
  background: rgba(14,116,144,.14);
}

.account-profile-hero {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 22px;
  align-items: center;
  margin-bottom: 22px;
  padding: 28px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 28px;
  background:
    radial-gradient(circle at 85% 12%, rgba(56,189,248,.2), transparent 26%),
    linear-gradient(135deg, rgba(30,41,59,.96), rgba(15,23,42,.83));
  box-shadow: var(--shadow);
}

.profile-avatar {
  display: grid;
  width: 76px;
  height: 76px;
  place-items: center;
  border: 1px solid rgba(125,211,252,.45);
  border-radius: 24px;
  color: #e0f2fe;
  background: linear-gradient(135deg, rgba(56,189,248,.45), rgba(129,140,248,.52));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.2);
  font-size: 2rem;
  font-weight: 900;
}

.profile-hero-copy h1 {
  margin: 0;
  font-size: clamp(1.65rem, 4vw, 2.65rem);
  word-break: break-word;
}

.profile-hero-copy > p:last-child {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.5;
}

.profile-security-state {
  display: flex;
  min-width: 210px;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid rgba(245,158,11,.34);
  border-radius: 18px;
  color: #fef3c7;
  background: rgba(146,64,14,.13);
}

.profile-security-state.secured {
  border-color: rgba(34,197,94,.35);
  color: #bbf7d0;
  background: rgba(20,83,45,.17);
}

.profile-security-icon {
  display: grid;
  width: 28px;
  height: 28px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 50%;
  color: #0f172a;
  background: #fbbf24;
  font-weight: 900;
}

.profile-security-state.secured .profile-security-icon {
  color: #052e16;
  background: #86efac;
}

.profile-security-state strong,
.profile-security-state span {
  display: block;
}

.profile-security-state strong {
  font-size: .9rem;
}

.profile-security-state span:not(.profile-security-icon) {
  margin-top: 2px;
  font-size: .78rem;
  opacity: .88;
}

.settings-card {
  position: relative;
  overflow: hidden;
  padding: 26px;
}

.settings-card::after {
  position: absolute;
  top: 0;
  right: 0;
  width: 120px;
  height: 120px;
  content: "";
  pointer-events: none;
  background: radial-gradient(circle at top right, rgba(56,189,248,.1), transparent 70%);
}

.settings-card-heading {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.settings-card-heading h2 {
  margin: 0;
  font-size: 1.3rem;
}

.settings-card-heading .eyebrow {
  margin-bottom: 6px;
}

.card-icon {
  display: grid;
  width: 40px;
  height: 40px;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid rgba(56,189,248,.28);
  border-radius: 14px;
  color: #bae6fd;
  background: rgba(14,116,144,.14);
  font-size: 1.05rem;
  font-weight: 900;
}

.current-value-label {
  margin: 20px 0 7px !important;
  color: var(--muted) !important;
  font-size: .82rem;
  font-weight: 700;
}

.current-value {
  overflow: hidden;
  padding: 13px 14px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 15px;
  color: #e0f2fe;
  background: rgba(15,23,42,.55);
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.settings-details {
  position: relative;
  z-index: 1;
  margin-top: 18px;
  border-top: 1px solid rgba(255,255,255,.09);
}

.settings-details summary {
  padding: 15px 0 2px;
  color: #bae6fd;
  cursor: pointer;
  font-weight: 850;
  list-style: none;
}

.settings-details summary::-webkit-details-marker {
  display: none;
}

.settings-details summary::after {
  float: right;
  content: "+";
  font-size: 1.2rem;
}

.settings-details[open] summary::after {
  content: "−";
}

.settings-form {
  margin-top: 16px;
}

.settings-card-lead {
  margin: 8px 0 0 !important;
  color: var(--muted);
  line-height: 1.5;
}

.security-mini-badge {
  flex: 0 0 auto;
  padding: 7px 10px;
  border: 1px solid rgba(148,163,184,.28);
  border-radius: 999px;
  color: #cbd5e1;
  background: rgba(15,23,42,.52);
  font-size: .78rem;
  font-weight: 850;
}

.security-mini-badge.success {
  border-color: rgba(34,197,94,.4);
  color: #bbf7d0;
  background: rgba(20,83,45,.2);
}

.security-mini-badge.warning {
  border-color: rgba(245,158,11,.4);
  color: #fef3c7;
  background: rgba(146,64,14,.18);
}

.twofactor-intro-grid {
  display: grid;
  grid-template-columns: minmax(0,1.2fr) minmax(220px,.8fr);
  gap: 18px;
  margin: 18px 0;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 20px;
  background: rgba(15,23,42,.4);
}

.twofactor-intro-grid p {
  margin: 12px 0 0;
  color: #cbd5e1;
  line-height: 1.5;
}

.twofactor-benefit-list {
  display: grid;
  align-content: center;
  gap: 10px;
  color: #bbf7d0;
  font-size: .9rem;
  font-weight: 750;
}

.setup-start-form {
  max-width: 530px;
  margin-top: 18px;
}

.twofactor-setup-banner {
  margin: 18px 0;
  padding: 17px 18px;
  border: 1px solid rgba(56,189,248,.3);
  border-radius: 18px;
  background: rgba(14,116,144,.12);
}

.twofactor-setup-banner p {
  margin: 9px 0 0;
  color: #cbd5e1;
  line-height: 1.5;
}

.totp-setup-layout {
  display: grid;
  grid-template-columns: minmax(260px,.85fr) minmax(0,1.15fr);
  gap: 18px;
  align-items: stretch;
}

.qr-setup-card,
.manual-setup-card {
  padding: 20px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 22px;
  background: rgba(15,23,42,.48);
}

.totp-qr {
  display: grid;
  min-height: 248px;
  place-items: center;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 18px;
  color: var(--muted);
  background: #fff;
}

.totp-qr svg {
  display: block;
  width: min(100%, 270px);
  height: auto;
}

.totp-qr.is-error {
  color: #fecaca;
  background: rgba(127,29,29,.3);
}

.qr-caption {
  margin: 14px 0 0;
  color: #cbd5e1;
  line-height: 1.5;
  text-align: center;
}

.manual-setup-title {
  margin: 0;
  color: #e0f2fe;
  font-weight: 850;
}

.manual-secret-details {
  margin-top: 18px;
}

.manual-secret-details summary {
  color: #bae6fd;
  cursor: pointer;
  font-weight: 800;
}

.manual-secret-details[open] summary {
  margin-bottom: 10px;
}

.confirm-2fa-form {
  max-width: 540px;
  margin: 18px auto 0;
  padding: 20px;
  border: 1px solid rgba(56,189,248,.22);
  border-radius: 20px;
  background: rgba(14,116,144,.1);
}

.inline-cancel-form {
  display: flex;
  justify-content: center;
  margin-top: 14px;
}

.twofactor-enabled-box {
  margin: 18px 0;
  padding: 17px;
  border: 1px solid rgba(34,197,94,.28);
  border-radius: 18px;
  background: rgba(20,83,45,.13);
}

.twofactor-enabled-box p {
  margin: 10px 0 0;
  color: #cbd5e1;
  line-height: 1.5;
}

.twofactor-actions-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
  margin-top: 18px;
}

.twofactor-action-card {
  padding: 20px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px;
  background: rgba(15,23,42,.46);
}

.twofactor-action-card h3 {
  margin: 0;
  font-size: 1.05rem;
}

.twofactor-action-card p {
  margin: 8px 0 17px;
  color: var(--muted);
  line-height: 1.45;
}

.danger-action-card {
  border-color: rgba(239,68,68,.22);
}

.recovery-card {
  margin-bottom: 16px;
  border-color: rgba(245,158,11,.28);
  background:
    radial-gradient(circle at top right, rgba(245,158,11,.12), transparent 35%),
    var(--panel);
}

@media (max-width: 900px) {
  .account-profile-hero {
    grid-template-columns: auto minmax(0,1fr);
  }

  .profile-security-state {
    grid-column: 1 / -1;
    min-width: 0;
  }

  .totp-setup-layout,
  .twofactor-intro-grid,
  .twofactor-actions-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 740px) {
  .monthly-overview {
    margin: 14px 0 25px;
  }

  .settings-shell {
    width: min(94%, 1120px);
  }

  .settings-top-note {
    display: none;
  }

  .account-profile-hero {
    grid-template-columns: auto minmax(0,1fr);
    gap: 15px;
    padding: 20px;
    border-radius: 22px;
  }

  .profile-avatar {
    width: 58px;
    height: 58px;
    border-radius: 19px;
    font-size: 1.45rem;
  }

  .profile-hero-copy h1 {
    font-size: 1.3rem;
  }

  .profile-hero-copy > p:last-child {
    grid-column: 1 / -1;
    margin-top: 6px;
    font-size: .9rem;
  }

  .profile-security-state {
    padding: 11px 12px;
  }

  .settings-card {
    padding: 20px;
  }

  .totp-qr {
    min-height: 225px;
  }

  .confirm-2fa-form {
    padding: 16px;
  }
}


/* -------------------------------------------------------
   Entspannt ausgebbar / freies Geld
   ------------------------------------------------------- */

.spendable-money {
  position: relative;
  overflow: hidden;
  margin: 18px 0 20px;
  padding: 26px;
  border: 1px solid rgba(125, 211, 252, .32);
  border-radius: 26px;
  background:
    radial-gradient(circle at 89% 2%, rgba(56, 189, 248, .24), transparent 31%),
    radial-gradient(circle at 10% 100%, rgba(129, 140, 248, .16), transparent 36%),
    linear-gradient(135deg, rgba(15, 23, 42, .95), rgba(30, 41, 59, .82));
  box-shadow: var(--shadow);
}

.spendable-money::after {
  position: absolute;
  right: -48px;
  bottom: -72px;
  width: 230px;
  height: 230px;
  content: "";
  pointer-events: none;
  border: 1px solid rgba(125, 211, 252, .12);
  border-radius: 50%;
  box-shadow:
    0 0 0 25px rgba(125, 211, 252, .035),
    0 0 0 52px rgba(125, 211, 252, .025);
}

.spendable-money-main {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.spendable-money h2 {
  margin: 0;
  font-size: clamp(1.3rem, 3vw, 1.65rem);
}

.spendable-period {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: .92rem;
}

.spendable-status {
  flex: 0 0 auto;
  padding: 8px 11px;
  border: 1px solid rgba(148, 163, 184, .3);
  border-radius: 999px;
  color: #e2e8f0;
  background: rgba(15, 23, 42, .55);
  font-size: .79rem;
  font-weight: 900;
}

.spendable-value-wrap {
  position: relative;
  z-index: 1;
  margin: 26px 0 20px;
}

.spendable-amount {
  display: block;
  color: #e0f2fe;
  font-size: clamp(2.15rem, 7vw, 3.8rem);
  letter-spacing: -.055em;
  line-height: .98;
}

.spendable-headline {
  max-width: 670px;
  margin: 12px 0 0;
  color: #cbd5e1;
  line-height: 1.55;
}

.spendable-breakdown {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.spendable-line {
  min-width: 0;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 17px;
  background: rgba(15, 23, 42, .48);
}

.spendable-line span {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: .78rem;
  line-height: 1.35;
}

.spendable-line strong {
  display: block;
  overflow: hidden;
  color: #e2e8f0;
  font-size: 1rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.spendable-line:not(:first-child) strong {
  color: #fecaca;
}

.spendable-note {
  position: relative;
  z-index: 1;
  margin: 16px 0 0;
  color: #94a3b8;
  font-size: .82rem;
  line-height: 1.45;
}

.spendable-money.is-positive {
  border-color: rgba(34, 197, 94, .34);
}

.spendable-money.is-positive .spendable-status {
  border-color: rgba(34, 197, 94, .38);
  color: #bbf7d0;
  background: rgba(20, 83, 45, .22);
}

.spendable-money.is-positive .spendable-amount {
  color: #bbf7d0;
}

.spendable-money.is-tight {
  border-color: rgba(245, 158, 11, .36);
}

.spendable-money.is-tight .spendable-status {
  border-color: rgba(245, 158, 11, .4);
  color: #fef3c7;
  background: rgba(146, 64, 14, .2);
}

.spendable-money.is-tight .spendable-amount {
  color: #fef3c7;
}

.spendable-money.is-negative {
  border-color: rgba(239, 68, 68, .42);
}

.spendable-money.is-negative .spendable-status {
  border-color: rgba(239, 68, 68, .42);
  color: #fecaca;
  background: rgba(127, 29, 29, .23);
}

.spendable-money.is-negative .spendable-amount {
  color: #fecaca;
}

@media (max-width: 900px) {
  .spendable-breakdown {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 740px) {
  .spendable-money {
    margin: 12px 0 22px;
    padding: 20px;
    border-radius: 22px;
  }

  .spendable-money-main {
    gap: 10px;
  }

  .spendable-status {
    padding: 7px 9px;
    font-size: .72rem;
  }

  .spendable-value-wrap {
    margin: 22px 0 17px;
  }

  .spendable-amount {
    font-size: 2.45rem;
  }

  .spendable-breakdown {
    gap: 8px;
  }

  .spendable-line {
    padding: 12px;
    border-radius: 15px;
  }

  .spendable-line strong {
    font-size: .92rem;
  }

  .spendable-note {
    margin-top: 13px;
    font-size: .76rem;
  }
}


/* -------------------------------------------------------
   Abo- & Fixkosten-Radar
   ------------------------------------------------------- */

.subscription-intro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 16px;
  background:
    radial-gradient(circle at 92% 5%, rgba(129,140,248,.18), transparent 32%),
    var(--panel);
}

.subscription-intro h2 {
  margin: 0;
  font-size: clamp(1.45rem, 3vw, 1.9rem);
}

.subscription-intro-badge {
  display: grid;
  min-width: 185px;
  grid-template-columns: auto 1fr;
  gap: 1px 9px;
  align-items: center;
  padding: 13px 15px;
  border: 1px solid rgba(129,140,248,.32);
  border-radius: 18px;
  color: #ddd6fe;
  background: rgba(76,29,149,.13);
}

.subscription-intro-badge > span {
  grid-row: span 2;
  display: grid;
  width: 31px;
  height: 31px;
  place-items: center;
  border-radius: 11px;
  color: #ede9fe;
  background: rgba(129,140,248,.25);
  font-size: 1.1rem;
  font-weight: 900;
}

.subscription-intro-badge strong {
  font-size: .86rem;
}

.subscription-intro-badge small {
  color: #c4b5fd;
  font-size: .72rem;
  line-height: 1.35;
}

.subscription-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}

.subscription-stat {
  min-width: 0;
  padding: 19px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(129,140,248,.13), transparent 42%),
    rgba(255,255,255,.07);
  box-shadow: var(--shadow);
}

.subscription-stat span {
  display: block;
  margin-bottom: 10px;
  color: var(--muted);
  font-size: .82rem;
}

.subscription-stat strong {
  display: block;
  overflow: hidden;
  color: #e0e7ff;
  font-size: 1.45rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.subscription-stat p {
  overflow: hidden;
  margin: 8px 0 0;
  color: var(--muted);
  font-size: .8rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.subscription-alerts {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}

.subscription-alert {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid rgba(245,158,11,.34);
  border-radius: 18px;
  color: #fef3c7;
  background: rgba(146,64,14,.14);
}

.subscription-alert.danger {
  border-color: rgba(239,68,68,.36);
  color: #fecaca;
  background: rgba(127,29,29,.18);
}

.subscription-alert.success {
  border-color: rgba(34,197,94,.32);
  color: #bbf7d0;
  background: rgba(20,83,45,.16);
}

.subscription-alert > span {
  display: grid;
  width: 25px;
  height: 25px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 50%;
  color: #0f172a;
  background: #fbbf24;
  font-size: .88rem;
  font-weight: 900;
}

.subscription-alert.danger > span {
  color: #fff;
  background: #ef4444;
}

.subscription-alert.success > span {
  color: #052e16;
  background: #86efac;
}

.subscription-alert strong,
.subscription-alert p {
  display: block;
}

.subscription-alert p {
  margin: 3px 0 0;
  opacity: .86;
  font-size: .88rem;
}

.subscription-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .95fr);
  gap: 16px;
  margin-bottom: 16px;
}

.subscription-form,
.subscription-guide,
.subscription-list-panel {
  min-width: 0;
}

.subscription-form-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}

.subscription-form-heading h2 {
  margin: 0;
  font-size: 1.25rem;
}

.subscription-form textarea {
  width: 100%;
  min-height: 92px;
  resize: vertical;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 16px;
  outline: 0;
  padding: 14px 16px;
  color: var(--text);
  background: rgba(15,23,42,.75);
  font: inherit;
}

.subscription-form textarea:focus {
  border-color: var(--accent);
}

.subscription-reserve {
  grid-template-columns: auto 1fr;
  align-items: flex-start;
  gap: 11px;
  padding: 14px;
  border: 1px solid rgba(56,189,248,.22);
  border-radius: 17px;
  background: rgba(14,116,144,.1);
  cursor: pointer;
}

.subscription-reserve input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  padding: 0;
  accent-color: var(--accent);
}

.subscription-reserve strong,
.subscription-reserve small {
  display: block;
}

.subscription-reserve strong {
  color: #e0f2fe;
  font-size: .91rem;
}

.subscription-reserve small {
  margin-top: 4px;
  color: var(--muted);
  font-size: .78rem;
  font-weight: 550;
  line-height: 1.4;
}

.subscription-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.subscription-guide {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background:
    radial-gradient(circle at top right, rgba(56,189,248,.12), transparent 38%),
    var(--panel);
}

.subscription-guide h2 {
  margin-top: 0;
}

.subscription-guide-list {
  display: grid;
  gap: 12px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.subscription-guide-list li {
  display: grid;
  grid-template-columns: 31px 1fr;
  gap: 11px;
  align-items: start;
}

.subscription-guide-list li > span {
  display: grid;
  width: 31px;
  height: 31px;
  place-items: center;
  border: 1px solid rgba(56,189,248,.3);
  border-radius: 11px;
  color: #bae6fd;
  background: rgba(14,116,144,.14);
  font-size: .83rem;
  font-weight: 900;
}

.subscription-guide-list strong,
.subscription-guide-list small {
  display: block;
}

.subscription-guide-list strong {
  color: #e2e8f0;
  font-size: .9rem;
}

.subscription-guide-list small {
  margin-top: 3px;
  color: var(--muted);
  font-size: .8rem;
  line-height: 1.4;
}

.subscription-guide-note {
  margin: 20px 0 0;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.09);
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.48;
}

.subscription-list-panel {
  margin-bottom: 20px;
}

.subscription-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.subscription-card {
  min-width: 0;
  padding: 19px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  background:
    radial-gradient(circle at top right, rgba(129,140,248,.14), transparent 42%),
    rgba(15,23,42,.46);
}

.subscription-card.inactive {
  opacity: .58;
}

.subscription-card.has-deadline {
  border-color: rgba(245,158,11,.38);
}

.subscription-card.is-overdue {
  border-color: rgba(239,68,68,.42);
}

.subscription-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.subscription-name-wrap {
  min-width: 0;
}

.subscription-name-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.subscription-name-line h3 {
  margin: 0;
  font-size: 1.13rem;
}

.subscription-name-wrap > p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.4;
}

.subscription-category,
.subscription-date-tag,
.subscription-due {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 800;
}

.subscription-category {
  padding: 5px 8px;
  border: 1px solid rgba(56,189,248,.26);
  color: #bae6fd;
  background: rgba(14,116,144,.13);
}

.subscription-due {
  flex: 0 0 auto;
  padding: 7px 9px;
  border: 1px solid rgba(56,189,248,.3);
  color: #bae6fd;
  background: rgba(14,116,144,.15);
  white-space: nowrap;
}

.subscription-due.warning {
  border-color: rgba(245,158,11,.36);
  color: #fef3c7;
  background: rgba(146,64,14,.18);
}

.subscription-due.danger {
  border-color: rgba(239,68,68,.38);
  color: #fecaca;
  background: rgba(127,29,29,.2);
}

.subscription-amounts {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
  margin: 20px 0 10px;
}

.subscription-amounts strong {
  color: #e0e7ff;
  font-size: 1.55rem;
}

.subscription-amounts span {
  color: var(--muted);
  font-size: .83rem;
}

.subscription-note {
  min-height: 1.2em;
  margin: 0 0 13px;
  color: #cbd5e1;
  font-size: .85rem;
  line-height: 1.45;
}

.subscription-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.subscription-date-tag {
  padding: 6px 8px;
  border: 1px solid rgba(148,163,184,.25);
  color: #cbd5e1;
  background: rgba(15,23,42,.46);
}

.subscription-date-tag.warning {
  border-color: rgba(245,158,11,.34);
  color: #fef3c7;
  background: rgba(146,64,14,.16);
}

.subscription-date-tag.reserve {
  border-color: rgba(34,197,94,.3);
  color: #bbf7d0;
  background: rgba(20,83,45,.16);
}

.subscription-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 17px;
}

.subscription-actions button {
  min-height: 37px;
  padding: 8px 10px;
  font-size: .78rem;
}

@media (max-width: 1000px) {
  .subscription-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .subscription-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 740px) {
  .subscription-intro {
    align-items: flex-start;
    flex-direction: column;
    gap: 14px;
  }

  .subscription-intro-badge {
    width: 100%;
  }

  .subscription-summary {
    gap: 10px;
  }

  .subscription-stat {
    padding: 15px;
    border-radius: 19px;
  }

  .subscription-stat strong {
    font-size: 1.18rem;
  }

  .subscription-list {
    grid-template-columns: 1fr;
  }

  .subscription-card {
    padding: 17px;
    border-radius: 20px;
  }

  .subscription-card-top {
    flex-direction: column;
  }

  .subscription-due {
    align-self: flex-start;
  }

  .subscription-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .subscription-actions button {
    width: 100%;
  }

  .mobile-nav.has-radar {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .mobile-nav.has-radar .mobile-tab-button {
    min-height: 55px;
    padding: 7px 2px;
    font-size: .61rem;
  }
}

@media (max-width: 390px) {
  .subscription-summary {
    grid-template-columns: 1fr;
  }

  .subscription-actions {
    grid-template-columns: 1fr;
  }

  .mobile-nav.has-radar .mobile-tab-button {
    font-size: .56rem;
  }
}

/* Free spend card now has a fifth reserved amount. */
@media (min-width: 1001px) {
  .spendable-breakdown {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}


/* -------------------------------------------------------
   Profil-Dashboard: Status, Geräte, Datenschutz und Erfolge
   ------------------------------------------------------- */

.profile-plus-page .settings-shell {
  padding-bottom: 54px;
}

.profile-plus-hero {
  margin-bottom: 18px;
}

.profile-overview-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 11px;
  margin: 0 0 18px;
}

.profile-overview-card {
  min-width: 0;
  padding: 15px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 18px;
  background: rgba(15,23,42,.48);
}

.profile-overview-card span {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: .72rem;
  line-height: 1.3;
}

.profile-overview-card strong {
  display: block;
  overflow: hidden;
  color: #e0f2fe;
  font-size: .95rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-plus-grid {
  align-items: start;
}

.profile-achievements-card {
  background:
    radial-gradient(circle at top right, rgba(129,140,248,.15), transparent 33%),
    var(--panel);
}

.profile-status-row {
  display: grid;
  grid-template-columns: minmax(240px,.86fr) minmax(0,1.14fr);
  gap: 12px;
  margin: 19px 0 14px;
}

.profile-streak-badge,
.profile-budget-status {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 76px;
  padding: 14px;
  border: 1px solid rgba(56,189,248,.22);
  border-radius: 18px;
  background: rgba(14,116,144,.1);
}

.profile-streak-number {
  display: grid;
  width: 48px;
  height: 48px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 16px;
  color: #e0f2fe;
  background: linear-gradient(135deg, rgba(56,189,248,.55), rgba(129,140,248,.58));
  font-size: 1.25rem;
  font-weight: 950;
}

.profile-streak-badge strong,
.profile-streak-badge small,
.profile-budget-status strong,
.profile-budget-status small {
  display: block;
}

.profile-streak-badge strong,
.profile-budget-status strong {
  color: #e2e8f0;
  font-size: .91rem;
}

.profile-streak-badge small,
.profile-budget-status small {
  margin-top: 3px;
  color: var(--muted);
  font-size: .78rem;
  line-height: 1.35;
}

.profile-budget-status.good {
  border-color: rgba(34,197,94,.28);
  background: rgba(20,83,45,.14);
}

.profile-budget-status.good strong {
  color: #bbf7d0;
}

.profile-budget-status.attention {
  border-color: rgba(245,158,11,.32);
  background: rgba(146,64,14,.15);
}

.profile-budget-status.attention strong {
  color: #fef3c7;
}

.achievement-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.achievement-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 9px;
  align-items: center;
  min-width: 0;
  padding: 13px;
  border: 1px solid rgba(148,163,184,.17);
  border-radius: 17px;
  color: #94a3b8;
  background: rgba(15,23,42,.42);
}

.achievement-card.done {
  border-color: rgba(34,197,94,.28);
  color: #bbf7d0;
  background: rgba(20,83,45,.13);
}

.achievement-icon {
  display: grid;
  width: 29px;
  height: 29px;
  place-items: center;
  border: 1px solid currentColor;
  border-radius: 10px;
  font-weight: 900;
}

.achievement-card strong,
.achievement-card small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.achievement-card strong {
  color: inherit;
  font-size: .82rem;
}

.achievement-card small {
  margin-top: 3px;
  color: var(--muted);
  font-size: .7rem;
}

.achievement-state {
  grid-column: 2;
  color: currentColor;
  font-size: .68rem;
  font-weight: 900;
}

.sessions-card,
.notification-card {
  background:
    radial-gradient(circle at top right, rgba(56,189,248,.1), transparent 35%),
    var(--panel);
}

.session-list {
  display: grid;
  gap: 9px;
  margin-top: 17px;
}

.session-item {
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 13px 14px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 16px;
  background: rgba(15,23,42,.43);
}

.session-item.current {
  border-color: rgba(34,197,94,.28);
  background: rgba(20,83,45,.13);
}

.session-device-icon {
  display: grid;
  width: 29px;
  height: 29px;
  place-items: center;
  border-radius: 10px;
  color: #bae6fd;
  background: rgba(14,116,144,.16);
}

.session-item.current .session-device-icon {
  color: #bbf7d0;
  background: rgba(20,83,45,.27);
}

.session-item strong,
.session-item small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.session-item strong {
  color: #e2e8f0;
  font-size: .9rem;
}

.session-item small {
  margin-top: 3px;
  color: var(--muted);
  font-size: .76rem;
}

.session-state {
  padding: 6px 8px;
  border: 1px solid rgba(148,163,184,.24);
  border-radius: 999px;
  color: #cbd5e1;
  font-size: .7rem;
  font-weight: 900;
}

.session-item.current .session-state {
  border-color: rgba(34,197,94,.3);
  color: #bbf7d0;
  background: rgba(20,83,45,.16);
}

.session-action-details {
  margin-top: 16px;
}

.compact-settings-form {
  max-width: 460px;
}

.notification-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  margin-top: 18px;
}

.notification-choice {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 11px;
  align-items: start;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 17px;
  background: rgba(15,23,42,.4);
  cursor: pointer;
}

.notification-choice input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  padding: 0;
  accent-color: var(--accent);
}

.notification-choice strong,
.notification-choice small {
  display: block;
}

.notification-choice strong {
  color: #e2e8f0;
  font-size: .9rem;
}

.notification-choice small {
  margin-top: 4px;
  color: var(--muted);
  font-size: .77rem;
  line-height: 1.4;
}

.notification-actions {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
}

.browser-notification-state {
  color: var(--muted);
  font-size: .8rem;
}

.data-card,
.security-summary-card {
  min-height: 100%;
}

.button-link {
  display: inline-flex;
  min-height: 43px;
  align-items: center;
  justify-content: center;
  margin-top: 15px;
  padding: 10px 14px;
  border: 1px solid transparent;
  border-radius: 13px;
  color: #fff;
  background: linear-gradient(135deg,var(--accent),#818cf8);
  font-weight: 850;
  text-decoration: none;
}

.button-link:hover {
  filter: brightness(1.07);
}

.ghost-link {
  margin: 0;
  border-color: rgba(255,255,255,.15);
  color: #e2e8f0;
  background: rgba(255,255,255,.05);
}

.last-backup-info {
  margin: 17px 0 0 !important;
  color: var(--muted) !important;
  font-size: .83rem;
}

.last-backup-info strong {
  color: #e2e8f0;
}

.security-check-list {
  display: grid;
  gap: 11px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.security-check-list li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 9px;
  align-items: center;
  color: #fef3c7;
  font-size: .88rem;
}

.security-check-list li > span {
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
  border-radius: 50%;
  color: #0f172a;
  background: #fbbf24;
  font-weight: 950;
}

.security-check-list li.done {
  color: #bbf7d0;
}

.security-check-list li.done > span {
  color: #052e16;
  background: #86efac;
}

.danger-zone-card {
  border-color: rgba(239,68,68,.3);
  background:
    radial-gradient(circle at top right, rgba(239,68,68,.1), transparent 35%),
    var(--panel);
}

.danger-zone-icon {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid rgba(239,68,68,.37);
  border-radius: 14px;
  color: #fecaca;
  background: rgba(127,29,29,.21);
  font-size: 1.2rem;
  font-weight: 950;
}

.danger-zone-backup {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 18px 0 0;
  padding: 15px;
  border: 1px solid rgba(245,158,11,.28);
  border-radius: 18px;
  background: rgba(146,64,14,.13);
}

.danger-zone-backup strong,
.danger-zone-backup small {
  display: block;
}

.danger-zone-backup strong {
  color: #fef3c7;
  font-size: .9rem;
}

.danger-zone-backup small {
  margin-top: 3px;
  color: #fde68a;
  font-size: .78rem;
}

.danger-details {
  margin-top: 16px;
  border-top: 1px solid rgba(239,68,68,.19);
}

.danger-details summary {
  padding: 15px 0 2px;
  color: #fecaca;
  cursor: pointer;
  font-weight: 900;
  list-style: none;
}

.danger-details summary::-webkit-details-marker {
  display: none;
}

.danger-details summary::after {
  float: right;
  content: "+";
  font-size: 1.25rem;
}

.danger-details[open] summary::after {
  content: "−";
}

.delete-account-form {
  max-width: 560px;
}

.delete-acknowledgement {
  grid-template-columns: auto 1fr;
  align-items: flex-start;
  gap: 10px;
  padding: 13px;
  border: 1px solid rgba(239,68,68,.26);
  border-radius: 15px;
  color: #fecaca;
  background: rgba(127,29,29,.15);
  cursor: pointer;
}

.delete-acknowledgement input {
  width: 17px;
  height: 17px;
  margin-top: 2px;
  padding: 0;
  accent-color: #ef4444;
}

@media (max-width: 1120px) {
  .profile-overview-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .achievement-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .profile-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
  }

  .profile-overview-card {
    padding: 13px;
  }

  .profile-status-row,
  .notification-form,
  .achievement-grid {
    grid-template-columns: 1fr;
  }

  .achievement-card {
    grid-template-columns: auto 1fr auto;
  }

  .achievement-state {
    grid-column: auto;
  }

  .session-item {
    grid-template-columns: auto minmax(0,1fr);
  }

  .session-state {
    grid-column: 2;
    justify-self: start;
  }

  .notification-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .notification-actions button {
    width: 100%;
  }

  .danger-zone-backup {
    align-items: flex-start;
    flex-direction: column;
  }

  .danger-zone-backup .button-link {
    width: 100%;
  }
}


/* -------------------------------------------------------
   Mein Bereich: Personalisation, Notizen, Gewohnheiten
   ------------------------------------------------------- */

body[data-accent-theme="violet"] {
  --accent: #a78bfa;
  --accent2: #ec4899;
  background:
    radial-gradient(circle at top left, rgba(167,139,250,.27), transparent 35%),
    radial-gradient(circle at top right, rgba(236,72,153,.18), transparent 30%),
    var(--bg);
}

body[data-accent-theme="emerald"] {
  --accent: #34d399;
  --accent2: #22c55e;
  background:
    radial-gradient(circle at top left, rgba(52,211,153,.25), transparent 35%),
    radial-gradient(circle at top right, rgba(34,197,94,.17), transparent 30%),
    var(--bg);
}

body[data-accent-theme="rose"] {
  --accent: #fb7185;
  --accent2: #c084fc;
  background:
    radial-gradient(circle at top left, rgba(251,113,133,.25), transparent 35%),
    radial-gradient(circle at top right, rgba(192,132,252,.18), transparent 30%),
    var(--bg);
}

body.dashboard-compact .card,
body.dashboard-compact .chart-stat {
  padding: 16px;
}

body.dashboard-compact .panel {
  padding: 18px;
}

body.dashboard-compact .cards,
body.dashboard-compact .chart-stats,
body.dashboard-compact .grid,
body.dashboard-compact .pots-layout {
  gap: 12px;
  margin-bottom: 12px;
}

.personal-glance {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 18px;
  align-items: center;
  margin: 0 0 18px;
  padding: 22px 24px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 25px;
  background:
    radial-gradient(circle at 90% 0%, color-mix(in srgb, var(--accent) 24%, transparent), transparent 35%),
    radial-gradient(circle at 0% 100%, color-mix(in srgb, var(--accent2) 18%, transparent), transparent 35%),
    rgba(15,23,42,.5);
  box-shadow: var(--shadow);
}

.personal-glance h2 {
  margin: 0;
  font-size: clamp(1.25rem, 3vw, 1.72rem);
}

.personal-glance p:not(.eyebrow) {
  margin: 8px 0 0;
  color: #cbd5e1;
  line-height: 1.45;
}

.personal-glance-progress {
  min-width: 112px;
  padding: 11px 13px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 17px;
  text-align: center;
  background: rgba(15,23,42,.42);
}

.personal-glance-progress span,
.personal-glance-progress small {
  display: block;
}

.personal-glance-progress span {
  color: #e0f2fe;
  font-size: 1.15rem;
  font-weight: 950;
}

.personal-glance-progress small {
  margin-top: 3px;
  color: var(--muted);
  font-size: .72rem;
}

.personal-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 16px;
  background:
    radial-gradient(circle at 92% 5%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 34%),
    var(--panel);
}

.personal-hero h2 {
  margin: 0;
  font-size: clamp(1.6rem, 4vw, 2.2rem);
}

.personal-hero-stats {
  display: grid;
  min-width: 132px;
  place-items: center;
  padding: 16px;
  border: 1px solid color-mix(in srgb, var(--accent) 36%, transparent);
  border-radius: 20px;
  background: color-mix(in srgb, var(--accent) 11%, transparent);
  text-align: center;
}

.personal-hero-stats span,
.personal-hero-stats small {
  display: block;
}

.personal-hero-stats span {
  color: #e0f2fe;
  font-size: 1.45rem;
  font-weight: 950;
}

.personal-hero-stats small {
  margin-top: 3px;
  color: #cbd5e1;
  font-size: .74rem;
}

.personal-migration-hint {
  display: grid;
  gap: 4px;
  margin-bottom: 16px;
  padding: 15px 17px;
  border: 1px solid rgba(245,158,11,.36);
  border-radius: 18px;
  color: #fef3c7;
  background: rgba(146,64,14,.15);
  line-height: 1.45;
}

.personal-migration-hint span {
  color: #fde68a;
  font-size: .87rem;
}

.personal-today-grid,
.personal-board-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}

.personal-panel-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 17px;
}

.personal-panel-heading h2 {
  margin: 0;
  font-size: 1.28rem;
}

.personal-heading-icon {
  display: grid;
  width: 39px;
  height: 39px;
  flex: 0 0 auto;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  border-radius: 14px;
  color: #e0f2fe;
  background: color-mix(in srgb, var(--accent) 13%, transparent);
  font-weight: 950;
}

.habit-today-list,
.personal-goals-list,
.personal-notes-list,
.quick-links-list {
  display: grid;
  gap: 10px;
}

.habit-row {
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 17px;
  background: rgba(15,23,42,.45);
}

.habit-row.done {
  border-color: rgba(34,197,94,.3);
  background: rgba(20,83,45,.14);
}

.habit-check {
  display: grid;
  width: 29px;
  height: 29px;
  place-items: center;
  padding: 0;
  border: 1px solid rgba(148,163,184,.36);
  border-radius: 10px;
  color: #052e16;
  background: transparent;
  font-size: .95rem;
}

.habit-row.done .habit-check {
  border-color: rgba(34,197,94,.45);
  background: #86efac;
}

.habit-icon {
  display: grid;
  width: 31px;
  height: 31px;
  place-items: center;
  border-radius: 11px;
  background: rgba(56,189,248,.14);
  font-size: 1rem;
}

.habit-row[data-color="violet"] .habit-icon { background: rgba(167,139,250,.17); }
.habit-row[data-color="mint"] .habit-icon { background: rgba(52,211,153,.16); }
.habit-row[data-color="amber"] .habit-icon { background: rgba(251,191,36,.16); }
.habit-row[data-color="rose"] .habit-icon { background: rgba(251,113,133,.16); }

.habit-copy {
  min-width: 0;
}

.habit-copy strong,
.habit-copy small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.habit-copy strong {
  color: #e2e8f0;
  font-size: .9rem;
}

.habit-copy small {
  margin-top: 3px;
  color: var(--muted);
  font-size: .74rem;
}

.icon-text-button {
  min-height: 34px;
  padding: 7px 9px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  color: var(--muted);
  background: rgba(255,255,255,.04);
  font-size: .72rem;
}

.personal-details {
  margin-top: 16px;
  border-top: 1px solid rgba(255,255,255,.09);
}

.personal-details summary {
  padding: 14px 0 1px;
  color: #cbd5e1;
  cursor: pointer;
  font-size: .88rem;
  font-weight: 850;
  list-style: none;
}

.personal-details summary::-webkit-details-marker {
  display: none;
}

.personal-details summary::after {
  float: right;
  content: "+";
  color: var(--accent);
  font-size: 1.15rem;
}

.personal-details[open] summary::after {
  content: "−";
}

.personal-form {
  display: grid;
  gap: 0;
  margin-top: 12px;
}

.personal-form textarea {
  width: 100%;
  min-height: 94px;
  resize: vertical;
  padding: 13px 15px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 16px;
  outline: 0;
  color: var(--text);
  background: rgba(15,23,42,.75);
  font: inherit;
}

.personal-form textarea:focus {
  border-color: var(--accent);
}

.personal-form .three {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
}

.personal-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.personal-checkbox {
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 9px;
  margin-bottom: 0;
  cursor: pointer;
}

.personal-checkbox input {
  width: 18px;
  height: 18px;
  padding: 0;
  accent-color: var(--accent);
}

.personal-checkbox strong,
.personal-checkbox small {
  display: block;
}

.personal-checkbox strong {
  color: #e2e8f0;
  font-size: .88rem;
}

.personal-checkbox small {
  margin-top: 3px;
  color: var(--muted);
  font-size: .75rem;
  line-height: 1.35;
}

.personal-note-form {
  padding-bottom: 17px;
  border-bottom: 1px solid rgba(255,255,255,.09);
}

.personal-note-card {
  padding: 15px;
  border: 1px solid rgba(56,189,248,.23);
  border-radius: 18px;
  background: rgba(14,116,144,.1);
}

.personal-note-card[data-color="violet"] {
  border-color: rgba(167,139,250,.27);
  background: rgba(91,33,182,.12);
}

.personal-note-card[data-color="mint"] {
  border-color: rgba(52,211,153,.25);
  background: rgba(6,95,70,.12);
}

.personal-note-card[data-color="amber"] {
  border-color: rgba(251,191,36,.26);
  background: rgba(146,64,14,.13);
}

.personal-note-card[data-color="rose"] {
  border-color: rgba(251,113,133,.28);
  background: rgba(159,18,57,.12);
}

.personal-note-card.pinned {
  box-shadow: inset 3px 0 0 var(--accent);
}

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

.note-card-head strong {
  color: #f8fafc;
  font-size: .92rem;
}

.note-pinned {
  padding: 5px 7px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 999px;
  color: #e0f2fe;
  background: rgba(15,23,42,.36);
  font-size: .67rem;
  font-weight: 850;
}

.personal-note-card p {
  margin: 10px 0 0;
  color: #dbeafe;
  font-size: .85rem;
  line-height: 1.5;
}

.note-card-actions,
.goal-card-actions,
.quick-link-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 13px;
}

.note-card-actions button,
.goal-card-actions button,
.quick-link-actions button {
  min-height: 34px;
  padding: 7px 9px;
  border-radius: 10px;
  font-size: .72rem;
}

.personal-goal-card {
  padding: 15px;
  border: 1px solid rgba(167,139,250,.26);
  border-radius: 18px;
  background: rgba(91,33,182,.1);
}

.personal-goal-card[data-color="sky"] {
  border-color: rgba(56,189,248,.24);
  background: rgba(14,116,144,.1);
}

.personal-goal-card[data-color="mint"] {
  border-color: rgba(52,211,153,.25);
  background: rgba(6,95,70,.12);
}

.personal-goal-card[data-color="amber"] {
  border-color: rgba(251,191,36,.26);
  background: rgba(146,64,14,.13);
}

.personal-goal-card[data-color="rose"] {
  border-color: rgba(251,113,133,.27);
  background: rgba(159,18,57,.12);
}

.personal-goal-card.done {
  border-color: rgba(34,197,94,.32);
  background: rgba(20,83,45,.14);
}

.goal-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.goal-card-top h3 {
  margin: 0;
  color: #f8fafc;
  font-size: .95rem;
}

.goal-card-top p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: .77rem;
  line-height: 1.4;
}

.goal-card-top > span {
  flex: 0 0 auto;
  padding: 5px 7px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  color: #e9d5ff;
  background: rgba(15,23,42,.38);
  font-size: .7rem;
  font-weight: 900;
}

.personal-goal-card.done .goal-card-top > span {
  border-color: rgba(34,197,94,.28);
  color: #bbf7d0;
  background: rgba(20,83,45,.2);
}

.goal-progress {
  height: 9px;
  overflow: hidden;
  margin-top: 15px;
  border-radius: 999px;
  background: rgba(148,163,184,.18);
}

.goal-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg,var(--accent),var(--accent2));
}

.personal-goal-card.done .goal-progress i {
  background: linear-gradient(90deg,#22c55e,#86efac);
}

.quick-link-card {
  overflow: hidden;
  border: 1px solid rgba(56,189,248,.22);
  border-radius: 17px;
  background: rgba(14,116,144,.1);
}

.quick-link-card[data-color="violet"] { border-color: rgba(167,139,250,.26); background: rgba(91,33,182,.1); }
.quick-link-card[data-color="mint"] { border-color: rgba(52,211,153,.25); background: rgba(6,95,70,.12); }
.quick-link-card[data-color="amber"] { border-color: rgba(251,191,36,.26); background: rgba(146,64,14,.13); }
.quick-link-card[data-color="rose"] { border-color: rgba(251,113,133,.27); background: rgba(159,18,57,.12); }

.quick-link-card a {
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 13px 14px 8px;
  color: #e0f2fe;
  font-weight: 850;
  text-decoration: none;
}

.quick-link-icon {
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 10px;
  background: rgba(15,23,42,.35);
}

.quick-link-card a > span:nth-child(2) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.quick-link-card a b {
  font-size: .9rem;
}

.quick-link-actions {
  margin: 0;
  padding: 0 14px 13px;
}

.personal-settings-panel {
  margin-bottom: 20px;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 12%, transparent), transparent 34%),
    var(--panel);
}

.personalization-form {
  display: grid;
  grid-template-columns: minmax(250px,.9fr) minmax(0,1.1fr);
  gap: 14px 16px;
  margin-top: 16px;
}

.personalization-form > label:first-child,
.personalization-form > .two,
.personal-widget-toggles,
.personalization-form > button {
  min-width: 0;
}

.personal-widget-toggles {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px;
}

.personal-widget-toggles .personal-checkbox {
  align-items: start;
  padding: 13px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  background: rgba(15,23,42,.36);
}

.personalization-form > button {
  grid-column: 1 / -1;
  justify-self: start;
}

.personal-empty {
  padding: 18px;
  border: 1px dashed rgba(148,163,184,.24);
  border-radius: 16px;
  color: var(--muted);
  background: rgba(15,23,42,.28);
  font-size: .85rem;
  line-height: 1.5;
}

.mobile-nav.has-personal {
  grid-template-columns: repeat(6, minmax(0,1fr));
}

@media (max-width: 1100px) {
  .personal-widget-toggles {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 820px) {
  .personal-glance {
    grid-template-columns: minmax(0,1fr) auto;
  }

  .personal-glance > button {
    grid-column: 1 / -1;
    width: 100%;
  }

  .personal-today-grid,
  .personal-board-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 740px) {
  .personal-hero {
    align-items: flex-start;
    flex-direction: column;
  }

  .personal-hero-stats {
    width: 100%;
    grid-template-columns: auto 1fr;
    gap: 9px;
    text-align: left;
  }

  .personal-hero-stats small {
    align-self: center;
  }

  .personalization-form,
  .personal-widget-toggles {
    grid-template-columns: 1fr;
  }

  .personal-form .three {
    grid-template-columns: 1fr;
  }

  .mobile-nav.has-personal .mobile-tab-button {
    min-height: 54px;
    padding: 6px 1px;
    font-size: .55rem;
  }
}

@media (max-width: 400px) {
  .personal-glance {
    grid-template-columns: 1fr;
  }

  .personal-glance-progress {
    width: 100%;
  }

  .habit-row {
    grid-template-columns: auto auto minmax(0,1fr);
  }

  .habit-row .icon-text-button {
    grid-column: 3;
    justify-self: start;
  }

  .personal-form-actions,
  .personal-form-actions button {
    width: 100%;
  }

  .personal-form-actions {
    flex-direction: column;
  }
}


/* Mein-Bereich Anzeige-Hotfix:
   Die eigene display:grid-Regel darf das HTML-Attribut hidden nicht überstimmen. */
#personalMigrationHint[hidden] {
  display: none !important;
}


/* -------------------------------------------------------
   Kontoeinstellungen: Daten verwalten
   ------------------------------------------------------- */

.account-data-management-card {
  background:
    radial-gradient(circle at top right, rgba(56,189,248,.11), transparent 34%),
    var(--panel);
}

.account-data-management-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 19px;
}

.account-data-action {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  min-width: 0;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 19px;
  background: rgba(15,23,42,.42);
}

.account-data-action.backup {
  border-color: rgba(56,189,248,.25);
  background: rgba(14,116,144,.1);
}

.account-data-action.import {
  border-color: rgba(167,139,250,.26);
  background: rgba(91,33,182,.1);
}

.account-data-action.danger {
  border-color: rgba(239,68,68,.28);
  background: rgba(127,29,29,.13);
}

.account-data-action-icon {
  display: grid;
  width: 36px;
  height: 36px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 13px;
  color: #e0f2fe;
  background: rgba(15,23,42,.38);
  font-size: 1.08rem;
  font-weight: 950;
}

.account-data-action h3 {
  margin: 1px 0 0;
  color: #f8fafc;
  font-size: .98rem;
}

.account-data-action p {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: .8rem;
  line-height: 1.46;
}

.account-data-action .button-link,
.account-data-action button {
  width: 100%;
  margin-top: 14px;
}

.account-data-action .button-link {
  min-height: 42px;
}

.account-data-action .last-backup-info {
  margin-top: 12px !important;
  font-size: .73rem;
}

.account-delete-entries-challenge {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, .8fr);
  gap: 18px;
  align-items: end;
  margin-top: 15px;
  padding: 18px;
  border: 1px solid rgba(239,68,68,.31);
  border-radius: 19px;
  background: rgba(127,29,29,.15);
}

.account-delete-entries-challenge[hidden] {
  display: none !important;
}

.account-delete-entries-challenge h3 {
  margin: 0;
  color: #fecaca;
  font-size: 1.05rem;
}

.account-delete-entries-challenge p:not(.eyebrow) {
  margin: 7px 0 0;
  color: #fecaca;
  font-size: .83rem;
  line-height: 1.45;
}

.account-delete-code {
  display: inline-block;
  margin-top: 12px;
  padding: 9px 13px;
  border: 1px dashed rgba(254,202,202,.48);
  border-radius: 11px;
  color: #fff;
  background: rgba(15,23,42,.45);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 1.1rem;
  letter-spacing: .13em;
}

.account-delete-form {
  display: grid;
  gap: 0;
}

.account-delete-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.account-delete-form-actions > * {
  flex: 1 1 130px;
}

.account-data-tool-status {
  min-height: 1.25rem;
  margin: 15px 2px 0;
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.45;
}

.account-data-tool-status.success {
  color: #bbf7d0;
}

.account-data-tool-status.error {
  color: #fecaca;
}

@media (max-width: 980px) {
  .account-data-management-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .account-delete-entries-challenge {
    grid-template-columns: 1fr;
  }

  .account-data-action {
    padding: 14px;
  }
}
