:root{
  --bg:#f7f9fc;
  --surface:#ffffff;
  --line:#e4e9f2;
  --line-strong:#d3dbea;
  --text:#111827;
  --muted:#667085;
  --green:#16a34a;
  --blue:#2563eb;
  --orange:#f97316;
  --purple:#8b5cf6;
  --pink:#ec4899;
  --shadow:0 18px 45px rgba(15,23,42,.08);
  --soft-shadow:0 8px 24px rgba(15,23,42,.07);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:#fff;color:var(--text)}
a{color:inherit}.btn,button,input,textarea,select{font:inherit}.app-shell{display:grid;grid-template-columns:258px minmax(0,1fr);min-height:100vh;background:#fff}.app-shell.no-sidebar{display:block}
.sidebar{position:sticky;top:0;z-index:20;height:100vh;background:rgba(255,255,255,.96);border-right:1px solid var(--line);padding:24px 22px;display:flex;flex-direction:column}.brand{display:flex;gap:12px;align-items:center;margin-bottom:34px}.brand-icon{font-size:30px;line-height:1}.brand strong{display:block;font-size:22px;line-height:1.05;letter-spacing:-.03em}.brand span{display:block;color:var(--muted);font-size:13px;margin-top:5px}.side-nav{display:grid;gap:10px;margin-bottom:34px}.side-nav a{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:12px;text-decoration:none;color:#172033;font-weight:650}.side-nav a.active,.side-nav a:hover{background:#edf8f1;color:#087536}.side-nav a.muted-link{color:#263247}.side-nav b{min-width:26px;height:24px;display:grid;place-items:center;background:#e8eef8;border-radius:99px;color:#64748b;font-size:13px}.side-section{display:grid;gap:8px}.side-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.side-title{color:#344054;font-weight:700;font-size:14px}.side-mini-btn{width:28px;height:28px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 4px 12px rgba(15,23,42,.06);cursor:pointer;font-size:20px;line-height:1}.project-dot-link{display:flex;align-items:center;gap:12px;text-decoration:none;padding:9px 8px;border-radius:10px;font-size:14px}.project-dot-link:hover{background:#f4f7fb}.dot{width:10px;height:10px;border-radius:99px;display:inline-block;flex:0 0 auto}.dot.green{background:var(--green)}.dot.blue{background:var(--blue)}.dot.orange{background:var(--orange)}.dot.purple{background:var(--purple)}.dot.pink{background:var(--pink)}.sidebar-bottom{margin-top:auto;border-top:1px solid var(--line);padding-top:18px}.settings-link{display:flex;gap:10px;align-items:center;text-decoration:none;color:#263247;font-size:14px;padding:8px;border-radius:10px}.settings-link:hover{background:#f4f7fb}
.main{min-width:0;background:#fff}.topbar{height:88px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);position:sticky;top:0;z-index:15}.top-actions{display:flex;align-items:center;gap:14px}.searchbox{height:46px;min-width:280px;display:flex;align-items:center;gap:9px;border:1px solid #d7deea;background:#fff;border-radius:12px;padding:0 14px;box-shadow:0 5px 16px rgba(15,23,42,.035);color:#203047}.searchbox input{border:0;outline:0;background:transparent;width:100%;font-size:15px}.btn{border:0;border-radius:12px;padding:11px 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;text-decoration:none;cursor:pointer;white-space:nowrap}.btn.primary{background:#159447;color:#fff;box-shadow:0 12px 24px rgba(21,148,71,.22)}.btn.primary:hover{background:#0e813b}.btn.secondary{background:#fff;border:1px solid var(--line-strong);color:#263247}.btn.outline{background:#fff;border:1px solid #20a45a;color:#0f8a42;box-shadow:0 5px 16px rgba(15,23,42,.04)}.btn.danger{background:#fff;border:1px solid #ef4444;color:#dc2626}.icon-btn,.tool-btn{height:46px;border:1px solid var(--line);border-radius:12px;background:#fff;color:#172033;box-shadow:0 7px 18px rgba(15,23,42,.06);cursor:pointer}.icon-btn{width:46px;font-size:18px}.tool-btn{padding:0 14px;font-weight:700}.content-head{display:flex;align-items:flex-start;justify-content:space-between;gap:22px;padding:36px 28px 20px}.content-head h1{font-size:30px;letter-spacing:-.04em;margin:0}.content-head p{color:var(--muted);margin:8px 0 0}.view-tools{display:flex;align-items:center;gap:12px}.zoom-toolbar{height:46px;background:#fff;border:1px solid var(--line);border-radius:12px;display:flex;align-items:center;overflow:hidden;box-shadow:0 7px 18px rgba(15,23,42,.06)}.zoom-toolbar button{width:44px;height:44px;border:0;background:#fff;cursor:pointer;font-size:20px}.zoom-toolbar button:hover,.icon-btn:hover,.tool-btn:hover{background:#f8fafc}.zoom-toolbar span{min-width:70px;text-align:center;border-left:1px solid var(--line);border-right:1px solid var(--line);font-weight:800}
.workspace{position:relative}.mindmap-viewport{overflow:auto;margin:8px 28px 26px;border-radius:24px;background:#fff;min-height:430px}.mindmap-scale{transform-origin:0 0;transition:transform .18s ease}.mindmap-board{display:flex;align-items:flex-start;gap:58px;min-width:max-content;padding:36px 18px 18px}.project-column{position:relative;flex:0 0 246px;min-width:246px;color:var(--green)}.project-column summary{list-style:none}.project-column summary::-webkit-details-marker{display:none}.project-column details{position:relative}.project-node{position:relative;display:grid;grid-template-columns:24px minmax(0,1fr) 28px;align-items:center;gap:8px;min-height:46px;padding:9px 12px;border:1.7px solid currentColor;border-radius:12px;background:#fff;box-shadow:0 8px 22px rgba(15,23,42,.055);font-weight:900;cursor:pointer}.project-node::after{display:none}.project-title-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-icon{font-size:21px;line-height:1}.project-node small{width:25px;height:25px;border-radius:99px;display:grid;place-items:center;background:color-mix(in srgb,currentColor 13%,white);font-size:12px;color:currentColor}.project-menu{position:absolute;right:-36px;top:12px;width:28px;height:28px;border:0;background:transparent;color:#344054;cursor:pointer;font-weight:900;letter-spacing:1px}.project-branch{position:relative;margin-top:28px;padding-left:30px;display:grid;gap:14px}.project-branch::before{content:"";position:absolute;left:10px;top:-28px;bottom:35px;width:2px;background:currentColor;opacity:.55;border-radius:99px}.project-desc{margin:0 0 2px;color:var(--muted);font-size:13px;line-height:1.4}.topic-list{display:grid;gap:14px}.topic-card,.add-topic-form{position:relative}.topic-card::before,.add-topic-form::before{content:"";position:absolute;left:-20px;top:50%;width:20px;height:2px;background:currentColor;opacity:.5}.topic-card::after,.add-topic-form::after{content:"";position:absolute;left:-24px;top:calc(50% - 4px);width:8px;height:8px;border:1.5px solid currentColor;border-radius:99px;background:#fff}.topic-card{min-height:57px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 11px 22px rgba(15,23,42,.075);display:grid;grid-template-columns:28px minmax(0,1fr) 18px;align-items:center;gap:8px;padding:10px 13px;color:#172033;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.topic-card:hover{transform:translateY(-1px);border-color:#d2dae8;box-shadow:0 16px 32px rgba(15,23,42,.1)}.check-form{margin:0}.checkbox-btn{width:22px;height:22px;border:1.5px solid #c4cfdd;border-radius:6px;background:#fff;color:transparent;display:grid;place-items:center;cursor:pointer;padding:0;line-height:1;font-weight:900}.checkbox-btn:hover{background:#16a34a;color:#fff;border-color:#16a34a}.topic-title{text-decoration:none;font-weight:780;font-size:14px;line-height:1.32;overflow:hidden;text-overflow:ellipsis}.topic-title:hover{text-decoration:underline}.topic-menu{color:#8190a5;font-size:23px;line-height:1}.add-topic-form{margin-top:2px}.add-topic-form input{width:176px;min-height:48px;border:1px dashed color-mix(in srgb,currentColor 40%,white);border-radius:12px;background:#fff;color:currentColor;outline:0;font-weight:850;padding:0 17px;box-shadow:0 7px 14px rgba(15,23,42,.035)}.add-topic-form input::placeholder{color:currentColor;opacity:.9}.color-green{color:var(--green)}.color-blue{color:var(--blue)}.color-orange{color:var(--orange)}.color-purple{color:var(--purple)}.color-pink{color:var(--pink)}.color-green .project-node{background:#f0fbf4}.color-blue .project-node{background:#f0f6ff}.color-orange .project-node{background:#fff7ed}.color-purple .project-node{background:#f6f2ff}.color-pink .project-node{background:#fdf2f8}.hidden-by-search{display:none!important}.empty-state{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow);min-width:460px}.empty-state h2{margin-top:0}.empty-state p{color:var(--muted)}
.inbox-panel{margin:8px 28px 34px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:0 10px 26px rgba(15,23,42,.045);padding:20px}.inbox-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.inbox-head h2{font-size:19px;margin:0}.inbox-list{border:1px solid #f0ddaf;border-radius:12px;overflow:hidden;background:#fffaf0}.inbox-row{display:grid;grid-template-columns:26px minmax(0,1fr) 150px 34px;align-items:center;gap:10px;min-height:44px;padding:0 14px;border-bottom:1px solid #eedfbf}.inbox-row:last-child{border-bottom:0}.inbox-row strong{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inbox-row span{color:#667085;font-size:13px}.row-menu{border:0;background:transparent;color:#344054;cursor:pointer;font-weight:900}.inbox-empty{padding:18px;color:#667085;background:#fff}.floating-add{position:fixed;right:34px;bottom:34px;z-index:30;width:62px;height:62px;border:0;border-radius:99px;background:#16a34a;color:#fff;font-size:36px;line-height:1;box-shadow:0 16px 34px rgba(22,163,74,.32);cursor:pointer}.floating-add:hover{background:#0f8a42}.modal{border:0;border-radius:22px;padding:0;background:transparent}.modal::backdrop{background:rgba(15,23,42,.45)}.modal-card{position:relative;width:min(520px,calc(100vw - 28px));background:#fff;border-radius:22px;box-shadow:var(--shadow);padding:24px;display:grid;gap:14px}.modal-card h2{margin:0}.modal-hint{margin:0;color:var(--muted)}.modal-close{position:absolute;right:16px;top:14px;width:34px;height:34px;border:0;border-radius:10px;background:#f1f5f9;cursor:pointer}.modal-card label,.detail-card label{display:grid;gap:8px;font-weight:740}.modal-card input,.modal-card textarea,.modal-card select,.detail-card input,.detail-card textarea{border:1px solid #d8dee9;border-radius:12px;padding:12px;font:inherit;background:#fff}.modal-card textarea{min-height:90px}.install-body{display:grid;place-items:center;min-height:100vh;background:#f8fafc}.install-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:34px;max-width:620px;box-shadow:var(--shadow)}.logo-mark{font-size:42px}.warning{background:#fff7ed;border:1px solid #fed7aa;border-radius:14px;padding:12px}.archive-list{padding:28px;display:grid;gap:12px}.archive-row{background:#fff;border:1px solid var(--line);border-left:5px solid currentColor;border-radius:16px;padding:16px;box-shadow:var(--soft-shadow);display:flex;justify-content:space-between;align-items:center;gap:18px}.archive-row strong{display:block;color:var(--text)}.archive-row span{display:block;color:var(--muted);font-size:13px;margin-top:4px}.detail-layout{display:grid;grid-template-columns:320px minmax(0,1fr);min-height:100vh;background:#fff}.detail-side{background:#fff;border-right:1px solid var(--line);padding:24px}.back-link{text-decoration:none;color:#64748b}.detail-line{height:60px;border-left:2px solid currentColor;margin-left:28px}.project-node.compact{display:inline-flex;grid-template-columns:none}.detail-selected{color:var(--text);margin-left:20px}.detail-main{padding:42px;max-width:920px}.detail-card{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);padding:28px;display:grid;gap:18px}.eyebrow{margin:0;color:#64748b;text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:800}.button-row{display:flex;gap:12px}.done-bar{margin-top:18px}
@media(max-width:1100px){.mindmap-board{gap:38px}.project-column{flex-basis:235px;min-width:235px}.view-tools{display:none}}
@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto;border-right:0;border-bottom:1px solid var(--line)}.side-section,.sidebar-bottom{display:none}.topbar{height:auto;align-items:stretch;padding:18px}.top-actions{width:100%;display:grid;grid-template-columns:1fr;gap:10px}.searchbox{min-width:0;width:100%}.content-head{flex-direction:column;padding:26px 18px 12px}.mindmap-viewport{margin:0 14px 20px}.mindmap-board{padding:26px 8px 10px;gap:30px}.project-column{flex-basis:230px;min-width:230px}.inbox-panel{margin:10px 14px 80px}.inbox-row{grid-template-columns:26px minmax(0,1fr) 34px}.inbox-row span{display:none}.floating-add{right:22px;bottom:22px}.detail-layout{grid-template-columns:1fr}.detail-side{border-right:0;border-bottom:1px solid var(--line)}.detail-main{padding:20px}.archive-row{align-items:flex-start;flex-direction:column}}


/* ==========================================================
   v0.5 – sauberes Linien-Raster
   Ziel: Alle Projekt-Zweige haben dieselbe Achse, dieselbe
   Startposition und exakt gleiche Andockpunkte an Themenkarten.
   ========================================================== */
.mindmap-viewport{
  background:#fff !important;
}
.mindmap-board{
  align-items:flex-start !important;
  gap:64px !important;
  padding:44px 18px 18px !important;
}
.project-column{
  --axis-x:28px;
  --branch-gap:32px;
  flex:0 0 252px !important;
  min-width:252px !important;
}
.project-node{
  min-height:46px !important;
}
.project-node::after{
  left:var(--axis-x) !important;
  top:calc(100% - 1px) !important;
  height:28px !important;
  width:2px !important;
}
.project-branch{
  margin-top:28px !important;
  padding-left:calc(var(--axis-x) + var(--branch-gap)) !important;
  gap:14px !important;
}
.project-branch::before{
  left:var(--axis-x) !important;
  top:-28px !important;
  bottom:28px !important;
  width:2px !important;
  opacity:.50 !important;
}
/* Beschreibungen verschieben die Themen optisch aus der Reihe.
   Für die Arbeitsansicht werden sie daher ausgeblendet; die Detailseite
   bleibt der richtige Ort für längere Beschreibungen. */
.project-desc{
  display:none !important;
}
.topic-list{
  display:grid !important;
  gap:14px !important;
}
.topic-card{
  width:100% !important;
  min-height:56px !important;
}
.add-topic-form{
  height:56px !important;
  margin-top:0 !important;
  display:flex !important;
  align-items:center !important;
}
.add-topic-form input{
  width:100% !important;
  min-height:48px !important;
}
.topic-card::before,
.add-topic-form::before{
  left:calc(-1 * var(--branch-gap)) !important;
  width:var(--branch-gap) !important;
  top:50% !important;
}
.topic-card::after,
.add-topic-form::after{
  left:calc(-1 * var(--branch-gap) - 4px) !important;
  top:calc(50% - 4px) !important;
}
/* Bei leeren Projekten soll der + Button trotzdem sauber an derselben Achse hängen. */
.project-branch > .add-topic-form:first-child::before,
.project-branch > .topic-list:empty + .add-topic-form::before{
  opacity:.45 !important;
}
.project-menu{
  top:10px !important;
}
@media(max-width:1100px){
  .mindmap-board{gap:42px !important;}
  .project-column{flex-basis:246px !important;min-width:246px !important;}
}
@media(max-width:900px){
  .mindmap-board{padding:30px 8px 10px !important;gap:34px !important;}
  .project-column{flex-basis:238px !important;min-width:238px !important;}
}

/* ==========================================================
   v0.8 – Bedienbarkeit
   Projekt- und Themenmenüs bleiben dezent, sind aber direkt nutzbar.
   ========================================================== */
.topic-card{
  grid-template-columns:28px minmax(0,1fr) 30px !important;
}
.topic-menu{
  width:30px;
  height:30px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:#64748b;
  cursor:pointer;
  font-size:17px;
  line-height:1;
  font-weight:900;
  display:grid;
  place-items:center;
  letter-spacing:1px;
}
.topic-menu:hover,
.project-menu:hover{
  background:#f1f5f9;
  color:#0f172a;
}
.modal-form-stack{
  display:grid;
  gap:14px;
}
.modal-card .modal-form-stack label,
.modal-card .danger-zone label{
  display:grid;
  gap:8px;
  font-weight:740;
}
.modal-card .modal-form-stack input,
.modal-card .modal-form-stack textarea,
.modal-card .modal-form-stack select{
  border:1px solid #d8dee9;
  border-radius:12px;
  padding:12px;
  font:inherit;
  background:#fff;
}
.danger-zone{
  margin-top:4px;
  border-top:1px solid var(--line);
  padding-top:14px;
  display:flex;
  justify-content:flex-end;
}
.js-project-menu,.js-topic-menu{
  -webkit-tap-highlight-color:transparent;
}
.project-column details:not([open]) .project-branch,
.project-column details:not([open]) .project-menu{
  display:none;
}
.project-column details:not([open]) .project-node{
  opacity:.92;
}


/* ==========================================================
   v0.8 – Inbox/Schnellerfassung praktisch nutzbar
   Inbox-Einträge können direkt in ein Projekt einsortiert werden.
   ========================================================== */
.inbox-row{
  grid-template-columns:26px minmax(180px,1fr) 132px minmax(250px,330px) 34px !important;
  gap:10px !important;
}
.inbox-move-form{
  display:grid;
  grid-template-columns:minmax(120px,1fr) auto;
  gap:8px;
  align-items:center;
}
.inbox-move-form select{
  height:34px;
  border:1px solid #d8dee9;
  border-radius:9px;
  background:#fff;
  color:#263247;
  padding:0 9px;
  min-width:0;
}
.inbox-move-form button{
  height:34px;
  border:1px solid #20a45a;
  background:#fff;
  color:#0f8a42;
  border-radius:9px;
  padding:0 10px;
  font-weight:800;
  cursor:pointer;
}
.inbox-move-form button:hover{background:#edf8f1}
.inbox-delete-form{display:flex;justify-content:flex-end;margin:0}
.inbox-delete-form .row-menu{
  width:30px;
  height:30px;
  border-radius:9px;
  font-size:20px;
  color:#94a3b8;
}
.inbox-delete-form .row-menu:hover{background:#fef2f2;color:#dc2626}
.modal-card select{
  border:1px solid #d8dee9;
  border-radius:12px;
  padding:12px;
  background:#fff;
  font:inherit;
}
@media(max-width:900px){
  .inbox-row{
    grid-template-columns:26px minmax(0,1fr) 34px !important;
    padding:12px 14px !important;
    min-height:auto !important;
  }
  .inbox-row > span{grid-column:2 / 3}
  .inbox-move-form{grid-column:1 / -1;grid-template-columns:1fr auto;margin-top:6px}
  .inbox-delete-form{grid-column:3 / 4;grid-row:1 / 2}
}

/* ==========================================================
   v0.9 – Themenseite ausgebaut
   Status, Priorität, Fälligkeitsdatum und bessere Detail-UI.
   ========================================================== */
.v09-detail .detail-main{
  padding:38px;
  max-width:none;
  background:#fff;
}
.detail-project-mini{
  margin-top:24px;
}
.detail-project-mini .project-node.compact{
  display:inline-flex;
  min-height:44px;
  gap:8px;
  padding:9px 13px;
}
.detail-project-mini .detail-line{
  height:58px;
  border-left:2px solid currentColor;
  margin-left:26px;
  opacity:.65;
}
.detail-project-mini .detail-selected{
  margin-left:18px;
  color:#172033;
  grid-template-columns:28px minmax(0,1fr);
}
.static-box{
  pointer-events:none;
  color:transparent;
}
.detail-header-v09{
  max-width:1120px;
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
  margin-bottom:22px;
}
.detail-header-v09 h1{
  margin:4px 0 8px;
  font-size:34px;
  letter-spacing:-.04em;
}
.detail-header-v09 p:not(.eyebrow){
  color:var(--muted);
  margin:0;
}
.save-badge{
  background:#edf8f1;
  border:1px solid #b7edcb;
  color:#087536;
  border-radius:999px;
  padding:9px 13px;
  font-weight:850;
  white-space:nowrap;
}
.topic-detail-grid{
  max-width:1120px;
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:18px;
  align-items:start;
}
.topic-editor-card,
.topic-meta-card{
  box-shadow:0 14px 32px rgba(15,23,42,.06);
}
.topic-editor-card textarea{
  min-height:420px;
  line-height:1.55;
  resize:vertical;
}
.topic-meta-card{
  gap:16px;
  position:sticky;
  top:112px;
}
.topic-meta-card h2{
  margin:0 0 2px;
  font-size:18px;
}
.topic-meta-card select,
.topic-meta-card input[type="date"]{
  border:1px solid #d8dee9;
  border-radius:12px;
  padding:12px;
  font:inherit;
  background:#fff;
}
.meta-facts{
  display:grid;
  gap:10px;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:14px 0;
}
.meta-facts div{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:13px;
}
.meta-facts span{
  color:var(--muted);
}
.meta-facts strong{
  color:#172033;
  text-align:right;
}
.stacked-actions{
  display:grid;
  gap:10px;
}
.stacked-actions .btn{
  width:100%;
}
.v09-done-bar{
  max-width:1120px;
}
@media(max-width:1000px){
  .detail-layout{grid-template-columns:1fr !important;}
  .detail-side{border-right:0;border-bottom:1px solid var(--line);}
  .topic-detail-grid{grid-template-columns:1fr;}
  .topic-meta-card{position:static;}
  .v09-detail .detail-main{padding:24px;}
}

/* ==========================================================
   v1.0 – Heute-Ansicht
   Fällige Themen werden übersichtlich nach Überfällig, Heute und Kommend gruppiert.
   ========================================================== */
.today-head{align-items:center;}
.today-summary{display:flex;gap:12px;align-items:center;}
.today-summary div{
  min-width:96px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 14px;
  box-shadow:0 8px 22px rgba(15,23,42,.05);
}
.today-summary strong{display:block;font-size:22px;line-height:1;color:#111827;}
.today-summary span{display:block;color:var(--muted);font-size:12px;margin-top:2px;}
.today-page{padding:0 28px 36px;display:grid;gap:18px;max-width:1220px;}
.today-group{
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 12px 28px rgba(15,23,42,.05);
  overflow:hidden;
}
.today-group-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 22px;
  border-bottom:1px solid var(--line);
  background:#fbfcff;
}
.today-group-head h2{margin:0;font-size:20px;letter-spacing:-.02em;}
.today-group-head p{margin:5px 0 0;color:var(--muted);font-size:14px;}
.today-group-head > span{
  min-width:34px;
  height:34px;
  border-radius:99px;
  display:grid;
  place-items:center;
  background:#edf8f1;
  color:#087536;
  font-weight:900;
}
.today-topic-list{display:grid;}
.today-topic-card{
  display:grid;
  grid-template-columns:32px minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
  min-height:74px;
  padding:14px 18px;
  border-bottom:1px solid var(--line);
  border-left:5px solid currentColor;
  color:var(--green);
  background:#fff;
}
.today-topic-card:last-child{border-bottom:0;}
.today-topic-card:hover{background:#fafcff;}
.today-topic-main{min-width:0;}
.today-topic-main a{
  display:block;
  color:#172033;
  font-weight:850;
  text-decoration:none;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.today-topic-main a:hover{text-decoration:underline;}
.today-topic-main small{display:flex;align-items:center;gap:8px;color:var(--muted);margin-top:5px;}
.today-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end;}
.today-badges span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  border-radius:999px;
  padding:0 10px;
  font-size:12px;
  font-weight:850;
  white-space:nowrap;
}
.today-date{background:#f1f5f9;color:#334155;}
.status-badge{background:#eef2ff;color:#3730a3;}
.status-progress{background:#fff7ed;color:#c2410c;}
.status-waiting{background:#fef3c7;color:#92400e;}
.priority-badge{background:#f8fafc;color:#475569;border:1px solid #e2e8f0;}
.priority-high{background:#fef2f2;color:#b91c1c;border-color:#fecaca;}
.priority-low{background:#f0fdf4;color:#15803d;border-color:#bbf7d0;}
.today-empty{padding:18px 22px;color:var(--muted);background:#fff;}
@media(max-width:900px){
  .today-head{display:block;}
  .today-summary{margin-top:16px;overflow:auto;padding-bottom:3px;}
  .today-topic-card{grid-template-columns:32px minmax(0,1fr);}
  .today-badges{grid-column:2 / 3;justify-content:flex-start;}
}


/* ==========================================================
   v1.1 – Sidebar einklappbar
   Der Zustand wird per localStorage im Browser gemerkt.
   ========================================================== */
.app-shell{
  transition:grid-template-columns .22s ease;
}
.sidebar{
  transition:width .22s ease,padding .22s ease;
  overflow:hidden;
}
.side-nav-main{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.nav-icon{
  width:18px;
  min-width:18px;
  text-align:center;
  font-style:normal;
  line-height:1;
}
.settings-link{
  min-height:38px;
}
.settings-icon{
  width:18px;
  min-width:18px;
  text-align:center;
}
.sidebar-toggle{
  width:100%;
  min-height:38px;
  margin-top:8px;
  border:0;
  border-radius:10px;
  background:#fff;
  color:#263247;
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px;
  cursor:pointer;
  font-weight:700;
  text-align:left;
}
.sidebar-toggle:hover{
  background:#f4f7fb;
}
.toggle-icon{
  width:18px;
  min-width:18px;
  display:inline-grid;
  place-items:center;
  font-size:20px;
  line-height:1;
  transition:transform .2s ease;
}
.toggle-text{
  white-space:nowrap;
}
.app-shell.sidebar-collapsed{
  grid-template-columns:86px minmax(0,1fr);
}
.app-shell.sidebar-collapsed .sidebar{
  padding:24px 14px;
}
.app-shell.sidebar-collapsed .brand{
  justify-content:center;
  gap:0;
  margin-bottom:34px;
}
.app-shell.sidebar-collapsed .brand-icon{
  font-size:28px;
}
.app-shell.sidebar-collapsed .brand strong,
.app-shell.sidebar-collapsed .brand span,
.app-shell.sidebar-collapsed .nav-label,
.app-shell.sidebar-collapsed .side-title,
.app-shell.sidebar-collapsed .project-link-label,
.app-shell.sidebar-collapsed .settings-label,
.app-shell.sidebar-collapsed .toggle-text{
  display:none !important;
}
.app-shell.sidebar-collapsed .side-nav a{
  min-height:48px;
  justify-content:center;
  padding:12px;
  position:relative;
}
.app-shell.sidebar-collapsed .side-nav-main{
  justify-content:center;
}
.app-shell.sidebar-collapsed .nav-icon{
  font-size:18px;
}
.app-shell.sidebar-collapsed .side-nav b{
  position:absolute;
  right:6px;
  top:6px;
  min-width:18px;
  width:18px;
  height:18px;
  font-size:10px;
}
.app-shell.sidebar-collapsed .side-section-head{
  justify-content:center;
}
.app-shell.sidebar-collapsed .side-mini-btn{
  width:38px;
  height:38px;
  font-size:22px;
}
.app-shell.sidebar-collapsed .project-dot-link{
  justify-content:center;
  padding:12px 8px;
}
.app-shell.sidebar-collapsed .dot{
  width:11px;
  height:11px;
}
.app-shell.sidebar-collapsed .sidebar-bottom{
  display:grid;
  gap:8px;
}
.app-shell.sidebar-collapsed .settings-link,
.app-shell.sidebar-collapsed .sidebar-toggle{
  justify-content:center;
  padding:8px;
}
.app-shell.sidebar-collapsed .toggle-icon{
  transform:rotate(180deg);
}
.app-shell.sidebar-collapsed .sidebar-toggle{
  background:#f8fafc;
}
@media(max-width:760px){
  .app-shell,
  .app-shell.sidebar-collapsed{
    grid-template-columns:1fr;
  }
  .sidebar{
    position:relative;
    height:auto;
    border-right:0;
    border-bottom:1px solid var(--line);
  }
  .app-shell.sidebar-collapsed .sidebar{
    padding:18px;
  }
  .app-shell.sidebar-collapsed .brand strong,
  .app-shell.sidebar-collapsed .brand span,
  .app-shell.sidebar-collapsed .nav-label,
  .app-shell.sidebar-collapsed .side-title,
  .app-shell.sidebar-collapsed .project-link-label,
  .app-shell.sidebar-collapsed .settings-label,
  .app-shell.sidebar-collapsed .toggle-text{
    display:inline !important;
  }
  .app-shell.sidebar-collapsed .side-nav a,
  .app-shell.sidebar-collapsed .project-dot-link,
  .app-shell.sidebar-collapsed .settings-link,
  .app-shell.sidebar-collapsed .sidebar-toggle{
    justify-content:flex-start;
  }
  .app-shell.sidebar-collapsed .side-nav b{
    position:static;
    min-width:26px;
    width:26px;
    height:24px;
    font-size:13px;
  }
}
