/* ===== WahlPflicht V51 - Dark Theme CSS ===== */
/* Root-Tokens: Design-Variablen für stabiles Rendering */
:root{
  /* Font & Base Colors */
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  --primary:#0f172a;
  --border:#e2e8f0;
  --bg:#f8fafc;
  --card:#fff;
  --text:#1e293b;
  --text-muted:#64748b;
  --card-hover:#f1f5f9;
  
  /* Breakpoints: mobile < 768, tablet < 1024, desktop >= 1024 */
  --bp-tablet:768px;
  --bp-desktop:1024px;

  /* Spacing tokens */
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;

  /* Shell sizes - FINAL */
  --header-h:64px;
  --nav-h:72px;
  --sidebar-w:260px;
  
  /* Touch targets */
  --touch-min:44px;
  
  /* Radius tokens */
  --radius-1:8px;
  --radius-2:14px;
  --radius-3:16px;
}

/* ===== Dark Mode Theme (Mobile Default) ===== */
/* Mobile: automatisch Dark Mode */
@media (max-width: 1023px) {
  :root {
    /* Dark color palette */
    --primary:#e5e7eb;
    --primary-dim:#9ca3af;
    --border:rgba(255,255,255,0.10);
    --bg:#0b1220;
    --card:rgba(15,23,42,0.8);
    --card-hover:rgba(30,41,59,0.9);
    --text:#f1f5f9;
    --text-muted:#94a3b8;
    
    /* Glassmorphism effects */
    --glass-bg:rgba(15,23,42,0.6);
    --glass-border:rgba(255,255,255,0.08);
    
    /* Interactive states */
    --accent:#d4af37;
    --accent-dim:#c9a36a;
  }
}

/* Desktop: kann Hell oder Dark sein (gesteuert durch data-theme) */
@media (min-width: 1024px) {
  /* Light mode (default) */
  :root {
    --primary:#0f172a;
    --primary-dim:#64748b;
    --border:#e2e8f0;
    --bg:#f8fafc;
    --card:#fff;
    --card-hover:#f1f5f9;
    
    --glass-bg:rgba(255,255,255,0.8);
    --glass-border:rgba(0,0,0,0.05);
    
    --accent:#0f172a;
    --accent-dim:#475569;
  }
  
  /* Dark mode wenn aktiviert */
  body[data-theme="dark"] {
    --primary:#e5e7eb;
    --primary-dim:#9ca3af;
    --border:rgba(255,255,255,0.10);
    --bg:#0b1220;
    --card:rgba(15,23,42,0.8);
    --card-hover:rgba(30,41,59,0.9);
    /* V198 Fix4: Text-Farben für Dark Mode explizit setzen */
    --text:#f1f5f9;
    --text-muted:#94a3b8;
    
    --glass-bg:rgba(15,23,42,0.6);
    --glass-border:rgba(255,255,255,0.08);
    
    --accent:#d4af37;
    --accent-dim:#c9a36a;
  }
}

/* Base Styles - FINAL */
html,body{
  height:100%;
  overflow:hidden;
  margin:0;
  background:var(--bg);
  color:var(--primary);
}

#app{
  height:100%;
  overflow:hidden;
  padding:0;
  margin:0;
}

/* ===== AppShell Layout (V51-FINAL) ===== */
/* App shell base */
.app-shell{
  width:100%;
  height:100%;
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  margin:0;
  padding:0;
}

/* Header always pinned (not inside scrolling content) */
.app-shell > header{
  flex:0 0 auto;
  position:sticky;
  top:0;
  z-index:120;
}

/* Header bar - Responsive, horizontal über volle Breite */
.header-bar{
  min-height:var(--header-h);
  padding:10px var(--space-4);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-3);
  background:var(--glass-bg);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:var(--accent);
  border-bottom:1px solid var(--glass-border);
  box-shadow:0 2px 10px rgba(0,0,0,0.1);
  width:100%;
}

/* Header left side: Hamburger + Icon + Name */
.header-left{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  flex:0 0 auto;
}

/* Hamburger Menu Button */
.hamburger-btn{
  background:transparent;
  border:none;
  padding:var(--space-2);
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap:4px;
  width:32px;
  height:32px;
  justify-content:center;
  align-items:center;
  border-radius:var(--radius-1);
  transition:background 0.2s ease;
}
.hamburger-btn:hover{
  background:var(--card-hover);
}
.hamburger-line{
  width:24px;
  height:3px;
  background:var(--accent);
  border-radius:2px;
  transition:all 0.3s ease;
}
.hamburger-btn.active .hamburger-line:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}
.hamburger-btn.active .hamburger-line:nth-child(2){
  opacity:0;
}
.hamburger-btn.active .hamburger-line:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

/* Header center: Platzhalter (flex) */
.header-center{
  flex:1 1 auto;
  min-width:0;
}

/* Header right: +Neu Button */
.header-right{
  display:flex;
  align-items:center;
  gap:var(--space-2);
  flex:0 0 auto;
}

.app-icon{ 
  width:32px; 
  height:32px;
  border-radius:10px;
  flex-shrink:0;
}
.app-icon-img{ 
  width:22px; 
  height:22px;
  max-width:22px;
  max-height:22px;
}
.app-name{
  font-size:18px;
  font-weight:700;
  color:var(--accent);
  white-space:nowrap;
}

/* Hamburger-Menü (Sidebar-Overlay) */
.hamburger-menu{
  position:fixed;
  top:var(--header-h);
  left:-280px;
  width:260px;
  height:calc(100vh - var(--header-h));
  background:var(--glass-bg);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-right:1px solid var(--glass-border);
  box-shadow:4px 0 20px rgba(0,0,0,0.2);
  transition:left 0.3s ease;
  z-index:110;
  overflow-y:auto;
  padding:var(--space-4);
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
}
.hamburger-menu.open{
  left:0;
}

/* Backdrop für Hamburger-Menü */
.hamburger-backdrop{
  position:fixed;
  top:var(--header-h);
  left:0;
  right:0;
  bottom:0;
  background:rgba(0,0,0,0.5);
  backdrop-filter:blur(2px);
  z-index:109;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.3s ease;
}
.hamburger-backdrop.visible{
  opacity:1;
  pointer-events:auto;
}

/* Content scroll area */
.content{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  padding:var(--space-4);
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + var(--space-3));
}

/* Mobile bottom nav pinned - BOTH Mobile AND Desktop */
.bottom-nav{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  width:100%;
  display:flex;
  justify-content:space-around;
  align-items:center;
  height:var(--nav-h);
  padding:10px 0;
  padding-bottom:calc(10px + env(safe-area-inset-bottom));
  background:var(--glass-bg);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-top:1px solid var(--glass-border);
  box-shadow:0 -4px 20px rgba(0,0,0,0.15);
  z-index:100;
}

/* Desktop: Bottom Nav bleibt unten */
@media (min-width: 1024px){
  .bottom-nav{
    /* Bleibt am unteren Rand */
  }
  
  /* App-Name auf Desktop immer sichtbar */
  .app-name{
    display:block;
  }
}

/* Tablet/Mobile: App-Name ausblenden wenn zu eng */
@media (max-width: 600px) {
  .app-name{
    display:none;
  }
}

/* Tablet adjustments */
@media (max-width: 768px) {
  .app-icon{
    width:22px;
    height:22px;
  }
  .app-icon-img{
    width:15px;
    height:15px;
    max-width:15px;
    max-height:15px;
  }
  .bottom-nav .nav-link{
    font-size:11px;
  }
}

/* Avoid double-fixed collisions: if any view uses fixed bars, keep them inside content */
.modal-backdrop, .toast{ z-index:200; }

/* ===== Header Components (Legacy) ===== */
.header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px;
  gap:12px;
  max-width:1200px;
  margin:0 auto;
  flex-wrap:wrap; /* V66: SmartButtons bleiben im Viewport */
}
.header-text{flex:1;}
.title{font-size:20px;font-weight:700;margin:0;color:var(--primary);}
.subtitle{font-size:14px;font-weight:400;color:var(--primary-dim);margin:4px 0 0;}
.header-actions{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap; /* V66 */
  justify-content:flex-end;
  max-width:100%;
}

/* V66: Inhalts-Badges in "Alle Jahre" Tiles */
.chronicles-tile-content-badges{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:8px;
}
.chronicles-type-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  font-size:12px;
  background:rgba(255,255,255,0.18);
  color:#fff;
  border:1px solid rgba(255,255,255,0.22);
  white-space:nowrap;
}
.btn-new{
  position:sticky;
  top:12px;
  background:var(--accent);
  color:#ffffff;
  border:1px solid var(--accent);
  border-radius:12px;
  padding:10px 16px;
  font-weight:600;
  cursor:pointer;
  font-size:14px;
  text-decoration:none;
  transition:all 0.2s;
  white-space:nowrap;
  box-shadow:0 2px 6px rgba(0,0,0,0.2);
}
.btn-new:hover{
  background:var(--accent-dim);
  border-color:var(--accent-dim);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(0,0,0,0.4);
}

/* Favicon im Header */
.header-favicon {
  width: 24px;
  height: 24px;
  object-fit: contain;
  margin-right: 8px;
}

@media (max-width: 768px) {
  .header-favicon {
    width: 20px;
    height: 20px;
  }
}

/* ===== Container & Layout ===== */
.container{max-width:1200px;margin:0 auto;padding:12px 16px;}

/* Cards */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-4);
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
  margin-bottom:var(--space-3);
  transition:all 0.2s ease;
}
.card:hover{
  background:var(--card-hover);
  box-shadow:0 4px 16px rgba(0,0,0,0.12);
}

/* Layout helpers */
.row{display:flex;gap:10px;align-items:center}
.row-top{align-items:flex-start}
.grow{flex:1}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* Typography */
.small{font-size:12px;color:var(--primary-dim)}

/* ===== Buttons ===== */
.btn{
  appearance:none;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--primary);
  border-radius:var(--radius-2);
  padding:var(--space-3) var(--space-4);
  font-weight:600;
  cursor:pointer;
  font-size:14px;
  transition:all 0.2s ease;
  min-height:var(--touch-min);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--space-2);
}
.btn:hover{
  background:var(--card-hover);
  box-shadow:0 2px 8px rgba(0,0,0,0.1);
  transform:translateY(-1px);
}
.btn-primary{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
}
.btn-primary:hover{
  background:var(--accent-dim);
  border-color:var(--accent-dim);
}
.btn-danger{border-color:#fecaca;background:var(--card);color:#991b1b;}
.btn-danger:hover{background:#fef2f2;}
.btn-success{background:#10b981;color:#fff;border-color:#10b981}
.btn-success:hover{background:#059669;}
.btn-icon{
  width:36px;
  height:36px;
  min-width:36px;
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

/* ===== Form Elements ===== */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="number"],
textarea,
select{
  appearance:none;
  border:1px solid var(--border);
  border-radius:var(--radius-1);
  padding:var(--space-3) var(--space-3);
  font:inherit;
  width:100%;
  background:var(--card);
  color:var(--primary);
  transition:border-color 0.2s ease;
  min-height:var(--touch-min);
}
input:focus,textarea:focus,select:focus{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(212,175,55,0.15);
}
textarea{
  min-height:100px;
  resize:vertical;
  font-family:inherit;
}

label{
  display:block;
  font-weight:600;
  font-size:14px;
  margin-bottom:4px;
  color:var(--primary);
}

.form-group{
  margin-bottom:16px;
}

/* Checkbox & Radio */
input[type="checkbox"],
input[type="radio"]{
  width:20px;
  height:20px;
  margin:0;
  cursor:pointer;
}

/* ===== Lists & Items ===== */
.list{
  list-style:none;
  padding:0;
  margin:0;
}
.list-item{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-4);
  margin-bottom:var(--space-2);
  cursor:pointer;
  transition:all 0.2s ease;
}
.list-item:hover{
  background:var(--card-hover);
  box-shadow:0 4px 16px rgba(0,0,0,0.12);
  transform:translateY(-2px);
}
.list-item-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:var(--space-3);
  margin-bottom:var(--space-2);
}
.list-item-title{
  font-weight:600;
  font-size:15px;
  flex:1;
  color:var(--primary);
}
.list-item-meta{
  display:flex;
  gap:var(--space-2);
  flex-wrap:wrap;
  font-size:12px;
  color:var(--primary-dim);
}

/* ===== Badges & Tags ===== */
.badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 10px;
  border-radius:12px;
  font-size:12px;
  font-weight:600;
  white-space:nowrap;
}
.badge-primary{background:#dbeafe;color:#1e40af;}
.badge-success{background:#d1fae5;color:#065f46;}
.badge-warning{background:#fef3c7;color:#92400e;}
.badge-danger{background:#fee2e2;color:#991b1b;}
.badge-gray{background:#f1f5f9;color:#475569;}

.tag{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:2px 8px;
  border-radius:6px;
  font-size:11px;
  font-weight:500;
  border:1px solid currentColor;
}

/* ===== Status Indicators ===== */
.status-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  display:inline-block;
}
.status-open{background:#3b82f6;}
.status-doing{background:#f59e0b;}
.status-done{background:#10b981;}
.status-archived{background:#64748b;}

/* ===== Modals & Overlays ===== */
.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.5);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  z-index:200;
  backdrop-filter:blur(2px);
}
.modal{
  background:var(--card);
  border-radius:var(--radius-2);
  max-width:600px;
  width:100%;
  max-height:90vh;
  overflow:auto;
  box-shadow:0 20px 25px -5px rgba(0,0,0,.3);
  border:1px solid var(--border);
}
.modal-header{
  padding:var(--space-4);
  border-bottom:1px solid var(--border);
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.modal-title{
  font-size:18px;
  font-weight:700;
  color:var(--primary);
}
.modal-body{
  padding:var(--space-4);
}
.modal-footer{
  padding:var(--space-4);
  border-top:1px solid var(--border);
  display:flex;
  gap:var(--space-2);
  justify-content:flex-end;
}

/* ===== Navigation ===== */
.nav-link{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  padding:8px 12px;
  text-decoration:none;
  color:var(--primary);
  border-radius:12px;
  transition:all 0.2s;
  font-size:12px;
  font-weight:500;
  min-height:var(--touch-min);
}
.nav-link:hover{
  background:var(--card-hover);
}
.nav-link.active{
  color:var(--accent);
  font-weight:600;
  background:var(--card-hover);
}

/* Hamburger-Menü Navigation Links */
.hamburger-menu .nav-link{
  flex-direction:row;
  justify-content:flex-start;
  padding:12px 16px;
  font-size:14px;
  width:100%;
}

@media (min-width: 1024px){
  .nav-link{
    flex-direction:row;
    justify-content:center;
    padding:10px 12px;
    font-size:13px;
  }
  
  /* Desktop: Unangeklickte Links schwarz auf hellem Hintergrund */
  @media (prefers-color-scheme: light), (min-width: 1024px) {
    body:not([data-theme="dark"]) .nav-link{
      color:#0f172a;
    }
    body:not([data-theme="dark"]) .nav-link.active{
      color:var(--accent);
    }
  }
}

/* ===== Tables ===== */
.table-wrapper{
  overflow-x:auto;
  margin:0 -12px;
}
table{
  width:100%;
  border-collapse:collapse;
}
th,td{
  padding:12px;
  text-align:left;
  border-bottom:1px solid var(--border);
}
th{
  font-weight:600;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:var(--primary-dim);
}

/* ===== Toast Notifications ===== */
.toast{
  position:fixed;
  bottom:calc(var(--nav-h) + 20px);
  left:50%;
  transform:translateX(-50%);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 16px;
  box-shadow:0 10px 15px -3px rgba(0,0,0,.1);
  z-index:200;
  min-width:250px;
  max-width:400px;
  animation:slideUp 0.3s ease-out;
}
@keyframes slideUp{
  from{
    opacity:0;
    transform:translateX(-50%) translateY(20px);
  }
  to{
    opacity:1;
    transform:translateX(-50%) translateY(0);
  }
}

/* ===== Loading States ===== */
.spinner{
  width:24px;
  height:24px;
  border:3px solid var(--border);
  border-top-color:var(--primary);
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}
@keyframes spin{
  to{transform:rotate(360deg);}
}

/* V100: Pulse-Animation für aktiven TimeTracker */
@keyframes pulse{
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

.loading-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.8);
  z-index:10;
}

/* ===== Empty States ===== */
.empty-state{
  text-align:center;
  padding:60px 20px;
  color:var(--primary-dim);
}
.empty-state-icon{
  font-size:48px;
  margin-bottom:16px;
  opacity:0.5;
}
.empty-state-title{
  font-size:18px;
  font-weight:600;
  margin-bottom:8px;
  color:var(--primary);
}
.empty-state-text{
  font-size:14px;
}

/* ===== Inbox View ===== */
.filter-bar-calendar{
  background:var(--card);
  padding:var(--space-4);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
  margin-bottom:var(--space-4);
}
.filter-bar-timeline-new{
  background:var(--card);
  padding:var(--space-4);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
  margin-bottom:var(--space-4);
}
.filter-group{
  margin-bottom:var(--space-3);
}
.filter-group:last-child{
  margin-bottom:0;
}
.filter-group label{
  display:block;
  margin-bottom:var(--space-1);
  font-weight:600;
  font-size:12px;
  color:var(--primary-dim);
}
.filter-group select{
  width:100%;
}

.filter-row{
  display:flex;
  flex-direction:column;
  gap:var(--space-1);
  margin-bottom:var(--space-3);
}
.filter-row:last-child{
  margin-bottom:0;
}
.filter-row label{
  font-weight:600;
  font-size:12px;
  color:var(--primary-dim);
}
.filter-row select,
.filter-row input{
  width:100%;
}
.filter-row.zeitraum{
  display:flex;
  flex-direction:row;
  align-items:flex-end;
  gap:var(--space-2);
}
.zeitraum-group{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:var(--space-1);
}
.zeitraum-separator{
  padding:0 var(--space-2);
  padding-bottom:var(--space-2);
  color:var(--primary-dim);
  font-size:12px;
}


/* ===== Timeline FilterBar (Grid, v81) ===== */
.filter-bar-timeline-new{
  display:grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--space-3);
}
.filter-bar-timeline-new .filter-cell{
  display:flex;
  flex-direction:column;
  gap: var(--space-1);
  min-width:0;
}
.filter-bar-timeline-new .filter-cell label{
  font-weight:600;
  font-size:12px;
  color: var(--primary-dim);
}
.filter-bar-timeline-new .filter-cell select,
.filter-bar-timeline-new .filter-cell input,
.filter-bar-timeline-new .filter-cell button{
  width:100%;
  min-width:0;
}
.filter-bar-timeline-new .filter-cell-range{
  grid-column: span 2;
}
.filter-bar-timeline-new .zeitraum-row{
  display:flex;
  gap: var(--space-2);
  align-items:center;
  min-width:0;
}
.filter-bar-timeline-new .zeitraum-row input{
  flex:1;
  min-width:0;
}
.filter-bar-timeline-new .zeitraum-separator-inline{
  font-size:12px;
  color: var(--primary-dim);
  padding: 0 var(--space-1);
  white-space:nowrap;
}
.filter-bar-timeline-new .filter-cell-apply{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.filter-bar-timeline-new .timeline-filter-apply{
  background:#61993B;
  color:#fff;
}

/* Timeline Actions: Buttons -> Dropdown on small screens */
.timeline-actions{
  display:flex;
  justify-content:flex-end;
  align-items:center;
}
.timeline-actions-desktop{
  display:flex;
  gap:8px;
  align-items:center;
}
.timeline-actions-mobile{
  display:none;
  width: 100%;
  max-width: 220px;
}
@media (max-width: 520px){
  .filter-bar-timeline-new{
    grid-template-columns: 1fr;
  }
  .filter-bar-timeline-new .filter-cell-range{
    grid-column: auto;
  }
  .filter-bar-timeline-new .zeitraum-row{
    flex-direction:column;
    align-items:stretch;
  }
  .filter-bar-timeline-new .zeitraum-separator-inline{
    text-align:center;
  }
  .timeline-actions-desktop{ display:none; }
  .timeline-actions-mobile{ display:block; }
  .timeline-actions-mobile select{ width:100%; }
}

/* ===== Category Styles ===== */
.category-icon{
  font-size:18px;
  width:24px;
  height:24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.category-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  border-radius:12px;
  font-size:12px;
  font-weight:600;
}

/* ===== Priority Styles ===== */
.priority-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:12px;
  font-weight:600;
}

/* ===== Timeline View ===== */
.chronicles-year-select{
  padding:var(--space-2) var(--space-3);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-1);
  color:var(--primary);
  font-weight:600;
  cursor:pointer;
  min-height:var(--touch-min);
}

.chronicles-legend{
  background:var(--card);
  padding:var(--space-4);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
  margin-bottom:var(--space-4);
}
.chronicles-legend-row{
  display:flex;
  gap:var(--space-3);
  align-items:center;
  margin-bottom:var(--space-2);
}
.chronicles-legend-row:last-child{
  margin-bottom:0;
}
.chronicles-legend-title{
  font-weight:700;
  color:var(--primary);
  min-width:120px;
}
.phase-pill{
  display:inline-flex;
  align-items:center;
  gap:var(--space-1);
  padding:4px 12px;
  border-radius:12px;
  font-size:11px;
  font-weight:600;
  border:1px solid currentColor;
}
.heat-sample{
  display:inline-block;
  width:40px;
  height:20px;
  border-radius:4px;
  border:1px solid var(--border);
  font-size:9px;
  text-align:center;
  line-height:20px;
}
.heat-sample.low{
  background:rgba(59, 130, 246, 0.2);
  color:#1e40af;
}
.heat-sample.mid{
  background:rgba(59, 130, 246, 0.5);
  color:#1e3a8a;
}
.heat-sample.high{
  background:rgba(59, 130, 246, 0.9);
  color:#fff;
}

.chronicles-dashboard-head{
  text-align:center;
  margin-bottom:var(--space-4);
}
.dash-title{
  font-size:24px;
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-2);
}
.dash-subtitle{
  font-size:14px;
  color:var(--primary-dim);
}

.chronicles-dashboard-controls{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  justify-content:center;
  margin-bottom:var(--space-4);
  padding:var(--space-3);
  background:var(--card);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
}

.chronicles-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:2px;
  margin-bottom:var(--space-4);
}
.chronicles-month-cell{
  background:var(--card);
  padding:var(--space-2);
  border-radius:var(--radius-1);
  border:1px solid var(--border);
  text-align:center;
  cursor:pointer;
  transition:all 0.2s ease;
  min-height:80px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.chronicles-month-cell:hover{
  background:var(--card-hover);
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
}
.chronicles-month-name{
  font-size:12px;
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-1);
}
.chronicles-month-count{
  font-size:18px;
  font-weight:700;
  color:var(--accent);
}
.chronicles-month-daynum{
  font-size:14px;
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-2);
}
.chronicles-cal-items{
  display:flex;
  flex-direction:column;
  gap:4px;
  flex:1;
}
.chronicles-cal-item{
  display:flex;
  align-items:center;
  gap:4px;
  padding:4px 6px;
  border-radius:4px;
  font-size:10px;
  text-decoration:none;
  transition:all 0.2s ease;
  border-left:3px solid;
}
.chronicles-cal-item:hover{
  transform:translateX(2px);
}
.chronicles-cal-time{
  font-weight:600;
  opacity:0.8;
}
.chronicles-cal-title{
  flex:1;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.chronicles-cal-more{
  font-size:10px;
  color:var(--primary-dim);
  margin-top:4px;
}
.chronicles-month-grid{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:2px;
}
.chronicles-day-list{
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
}
.chronicles-day-item{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  padding:var(--space-3);
  border-radius:var(--radius-2);
  text-decoration:none;
  transition:all 0.2s ease;
}
.chronicles-day-item:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(0,0,0,0.2);
}
.chronicles-item-time{
  font-weight:700;
  font-size:14px;
  min-width:60px;
}
.chronicles-item-title{
  flex:1;
  font-size:15px;
  font-weight:600;
}
.chronicles-item-cat{
  font-size:12px;
  opacity:0.9;
}

/* Chronicles Listenansicht */
.chronicles-list-container{
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}
.chronicles-list-frame{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-4);
}
.chronicles-list-month-header{
  font-size:20px;
  font-weight:700;
  text-align:center;
  color:var(--primary);
  margin:var(--space-6) 0 var(--space-4) 0;
  padding-bottom:var(--space-2);
  border-bottom:2px solid var(--border);
}
.chronicles-list-month-header:first-child{
  margin-top:0;
}
.chronicles-list-day-header{
  text-align:center;
  margin:var(--space-4) 0 var(--space-3) 0;
}
.chronicles-list-day-name{
  font-size:16px;
  font-weight:700;
  color:var(--primary);
}
.chronicles-list-day-date{
  font-size:14px;
  font-weight:700;
  color:var(--primary-dim);
  margin-top:4px;
}
.chronicles-list-item{
  display:block;
  padding:var(--space-3);
  text-align:left;
  color:var(--primary);
  text-decoration:none;
  border-bottom:1px solid rgba(0,0,0,0.05);
  transition:all 0.2s ease;
}
.chronicles-list-item:hover{
  background:var(--card-hover);
  padding-left:var(--space-4);
}
.chronicles-list-item:last-child{
  border-bottom:none;
}

/* Jahr-Tiles für "Alle Jahre" */
.year-tiles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
  gap:var(--space-4);
  margin-top:var(--space-4);
}
.year-tile{
  padding:var(--space-5);
  border-radius:var(--radius-2);
  cursor:pointer;
  transition:all 0.2s ease;
  text-align:center;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
}
.year-tile:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 24px rgba(0,0,0,0.25);
}
.year-tile-year{
  font-size:32px;
  font-weight:700;
  margin-bottom:var(--space-2);
}
.year-tile-count{
  font-size:14px;
  opacity:0.9;
  margin-bottom:var(--space-3);
}
.phase-pill{
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  border-radius:12px;
  font-size:12px;
  font-weight:700;
  margin-top:var(--space-2);
}

@media (max-width: 768px) {
  .chronicles-grid{
    grid-template-columns:repeat(4, 1fr);
  }
  .chronicles-month-grid{
    grid-template-columns:repeat(7, 1fr);
  }
  .chronicles-month-cell{
    min-height:60px;
  }
  .year-tiles-grid{
    grid-template-columns:repeat(auto-fill, minmax(150px, 1fr));
  }
}

/* ===== Timeline View ===== */
.timeline-nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:var(--space-4);
  padding:var(--space-3);
  background:var(--card);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
}
.timeline-range{
  font-size:16px;
  font-weight:700;
  color:var(--primary);
  text-align:center;
  flex:1;
}

/* LifeTimeLine Styles */
.lifetime-timeline-new{
  position:relative;
  padding-left:50px;
  margin-top:var(--space-4);
}
.timeline-item-new{
  position:relative;
  display:flex;
  gap:var(--space-3);
  margin-bottom:var(--space-6);
}
.timeline-line-wrapper-new{
  position:absolute;
  left:-50px;
  top:0;
  width:50px;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.timeline-line-vertical{
  width:3px;
  flex:1;
  background:var(--border);
  min-height:100%;
}
.timeline-dot-new{
  width:16px;
  height:16px;
  border-radius:50%;
  border:3px solid var(--bg);
  box-shadow:0 0 0 2px var(--border);
  flex-shrink:0;
  margin-top:8px;
  z-index:2;
}
.timeline-content-new{
  flex:1;
  min-width:0;
}
.timeline-timestamp{
  font-size:12px;
  font-weight:600;
  color:var(--primary-dim);
  margin-bottom:var(--space-2);
}
.timeline-card-new{
  display:block;
  padding:var(--space-4);
  border-radius:var(--radius-2);
  text-decoration:none;
  box-shadow:0 2px 8px rgba(0,0,0,0.15);
  transition:all 0.2s ease;
  border-left:4px solid rgba(255,255,255,0.5);
}
.timeline-card-new:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(0,0,0,0.25);
}
.timeline-card-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:var(--space-3);
  margin-bottom:var(--space-2);
}
.timeline-card-title{
  font-size:16px;
  font-weight:700;
  flex:1;
}
.timeline-card-category{
  font-size:12px;
  opacity:0.9;
  white-space:nowrap;
}
.timeline-card-text{
  font-size:13px;
  line-height:1.5;
  opacity:0.9;
  margin-bottom:var(--space-3);
}
.timeline-card-footer{
  display:flex;
  gap:var(--space-2);
  flex-wrap:wrap;
}
.timeline-type-badge,
.timeline-status-badge{
  font-size:11px;
  padding:4px 8px;
  border-radius:6px;
  background:rgba(255,255,255,0.2);
  font-weight:600;
}
.timeline-category-header{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  padding:var(--space-3);
  background:var(--card);
  border-radius:var(--radius-2);
  margin-bottom:var(--space-4);
  border-left:6px solid;
}
.timeline-category-icon{
  font-size:24px;
}
.timeline-category-name{
  font-size:18px;
  font-weight:700;
  color:var(--primary);
}
.timeline-year-info{
  text-align:center;
  padding:var(--space-3);
  opacity:0.8;
  color:var(--primary-dim);
}
.btn-add-result{
  display:inline-flex;
  align-items:center;
  gap:var(--space-2);
  padding:var(--space-3) var(--space-4);
  border-radius:var(--radius-2);
  text-decoration:none;
  font-weight:700;
  min-height:var(--touch-min);
  transition:all 0.2s ease;
}
.btn-add-result:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(0,0,0,0.2);
}
.result-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:50%;
  font-size:16px;
}

/* Old Timeline Styles (für andere Views) */
.timeline{
  position:relative;
  padding-left:30px;
}
.timeline::before{
  content:'';
  position:absolute;
  left:10px;
  top:0;
  bottom:0;
  width:2px;
  background:var(--border);
}
.timeline-item{
  position:relative;
  margin-bottom:24px;
}
.timeline-item::before{
  content:'';
  position:absolute;
  left:-24px;
  top:6px;
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--card);
  border:2px solid var(--accent);
}
.timeline-date{
  font-size:12px;
  font-weight:600;
  color:var(--primary-dim);
  margin-bottom:8px;
}

.timeline-section{
  margin-bottom:var(--space-6);
}
.timeline-section-title{
  font-size:18px;
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-4);
  padding-bottom:var(--space-2);
  border-bottom:2px solid var(--border);
}

/* ===== CALENDAR V53 - Complete Grid System ===== */

/* Month View */
.calendar-month-container{display:flex;flex-direction:column;gap:var(--space-4);}
.calendar-nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:var(--space-3);
  background:var(--card);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
}
.calendar-title{
  flex:1;
  text-align:center;
  font-size:18px;
  font-weight:700;
  color:var(--primary);
}
.month-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:2px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  overflow-x:auto;
  min-width:700px;
}
.month-header-row{
  display:contents;
}
.month-weekday{
  background:var(--bg);
  padding:var(--space-2);
  text-align:center;
  font-size:12px;
  font-weight:700;
  color:var(--primary-dim);
}
.month-day{
  background:var(--card);
  padding:var(--space-2);
  min-height:100px;
  cursor:pointer;
  transition:all 0.2s ease;
  display:flex;
  flex-direction:column;
}
.month-day:hover{background:var(--card-hover);box-shadow:0 2px 8px rgba(0,0,0,0.1);}
.month-day.today{border:2px solid var(--accent);background:rgba(212,175,55,0.1);}
.month-day.empty{background:transparent;cursor:default;}
.month-day.empty:hover{background:transparent;box-shadow:none;}
.month-day-num{
  font-size:14px;
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-2);
}
.month-items{display:flex;flex-direction:column;gap:4px;flex:1;}
.month-item{
  display:flex;
  align-items:center;
  gap:4px;
  padding:4px 6px;
  border-radius:4px;
  font-size:11px;
  text-decoration:none;
  background:var(--card);
  transition:all 0.2s ease;
  color:var(--primary);
}
.month-item:hover{background:var(--card-hover);transform:translateX(2px);}
.month-item-time{font-weight:600;opacity:0.7;min-width:40px;}
.month-item-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.month-more{font-size:10px;color:var(--primary-dim);margin-top:4px;text-align:center;}

/* Week View */
.calendar-week-container{display:flex;flex-direction:column;gap:var(--space-4);}
.week-nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:var(--space-3);
  background:var(--card);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
}
.week-title{text-align:center;flex:1;}
.week-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:50px;
  height:50px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  font-weight:700;
  font-size:14px;
  margin-bottom:var(--space-2);
}
.week-date-range{font-size:14px;font-weight:600;color:var(--primary);}
.week-grid{
  overflow:auto;
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  background:var(--border);
  max-height:calc(100vh - 350px);
}
.week-header-row{
  display:grid;
  grid-template-columns:100px repeat(7,minmax(120px,1fr));
  gap:1px;
  position:sticky;
  top:0;
  z-index:10;
  background:var(--border);
}
.week-header-time{
  background:var(--bg);
  padding:var(--space-2);
  text-align:center;
  font-weight:700;
  font-size:12px;
  color:var(--primary-dim);
}
.week-header-day{
  background:var(--bg);
  padding:var(--space-2);
  text-align:center;
  font-weight:700;
}
.week-header-day.today{background:var(--accent);color:#fff;}
.week-day-name{font-size:13px;margin-bottom:2px;}
.week-day-date{font-size:11px;opacity:0.8;}
.week-hour-row{
  display:grid;
  grid-template-columns:100px repeat(7,minmax(120px,1fr));
  gap:1px;
  background:var(--border);
  min-height:60px;
  border-top:1px solid rgba(0,0,0,0.05);
}
.week-hour-row:first-of-type{
  border-top:none;
}
.week-time-label{
  background:var(--bg);
  padding:var(--space-2);
  text-align:center;
  font-size:11px;
  font-weight:600;
  color:var(--primary-dim);
}
.week-day-cell{
  background:var(--card);
  padding:4px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.week-day-cell.today{background:rgba(212,175,55,0.1);border:2px solid var(--accent);}
.week-item-tile{
  padding:6px 8px;
  border-radius:6px;
  font-size:11px;
  font-weight:600;
  text-decoration:none;
  display:block;
  transition:all 0.2s ease;
}
.week-item-tile:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,0.3);}

/* Day View */
.calendar-day-container{display:flex;flex-direction:column;gap:var(--space-4);}
.day-nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:var(--space-3);
  background:var(--card);
  border-radius:var(--radius-2);
  border:1px solid var(--border);
}
.day-title{text-align:center;flex:1;}
.day-name{font-size:18px;font-weight:700;color:var(--primary);}
.day-date{font-size:14px;color:var(--primary-dim);margin-top:4px;}
.day-grid{
  overflow-y:auto;
  max-height:calc(100vh - 350px);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  background:var(--border);
}
.day-header-row{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:1px;
  position:sticky;
  top:0;
  z-index:10;
  background:var(--border);
}
.day-header-time,.day-header-title{
  background:var(--bg);
  padding:var(--space-3);
  font-weight:700;
  color:var(--primary);
}
.day-header-time{text-align:center;}
.day-hour-row{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:1px;
  background:var(--border);
  min-height:60px;
  border-top:1px solid rgba(0,0,0,0.05);
}
.day-hour-row:first-of-type{
  border-top:none;
}
.day-time-label{
  background:var(--bg);
  padding:var(--space-2);
  text-align:center;
  font-size:12px;
  font-weight:600;
  color:var(--primary-dim);
}
.day-content-cell{
  background:var(--card);
  padding:var(--space-2);
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
}
.day-item-tile{
  display:flex;
  align-items:center;
  gap:var(--space-2);
  padding:var(--space-2) var(--space-3);
  border-radius:var(--radius-1);
  text-decoration:none;
  transition:all 0.2s ease;
}
.day-item-tile:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,0.3);}
.day-item-time{font-weight:700;font-size:12px;min-width:50px;}
.day-item-title{flex:1;font-size:14px;font-weight:600;}


@media (max-width: 520px){
  .day-header-row,
  .day-hour-row{
    grid-template-columns:70px 1fr;
  }
  .day-grid{
    max-height:calc(100vh - 300px);
  }
  .day-name{font-size:16px;}
  .day-date{font-size:13px;}
  .day-item-time{font-size:12px;}
  .day-item-title{font-size:13px;}
}

/* Responsive */
@media (max-width: 768px) {
  .month-grid{min-width:600px;gap:1px;}
  .month-day{min-height:80px;padding:var(--space-1);}
  .week-header-row{grid-template-columns:80px repeat(7,100px);}
  .week-hour-row{grid-template-columns:80px repeat(7,100px);}
  .week-header-day,.week-day-cell{min-width:100px;}
  .day-header-row{grid-template-columns:80px 1fr;}
  .day-hour-row{grid-template-columns:80px 1fr;}
}
/* ===== Settings View ===== */
.settings-section{
  margin-bottom:32px;
}
.settings-section-title{
  font-size:16px;
  font-weight:700;
  margin-bottom:16px;
  padding-bottom:8px;
  border-bottom:2px solid var(--border);
  color:var(--primary);
}
.settings-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 0;
  border-bottom:1px solid var(--border);
}
.settings-item:last-child{
  border-bottom:none;
}
.settings-label{
  font-weight:600;
  flex:1;
  color:var(--primary);
}
.settings-value{
  color:var(--primary-dim);
  font-size:14px;
}

/* ===== File Upload ===== */
.file-input-wrapper{
  position:relative;
  display:inline-block;
}
.file-input-wrapper input[type="file"]{
  position:absolute;
  opacity:0;
  width:0;
  height:0;
}
.file-input-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  cursor:pointer;
  font-weight:600;
  font-size:14px;
  transition:all 0.2s;
}
.file-input-label:hover{
  background:var(--card-hover);
}

.attachment-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:8px;
}
.attachment-item{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:8px;
}
.attachment-name{
  flex:1;
  font-size:13px;
  color:var(--primary);
}
.attachment-size{
  font-size:11px;
  color:var(--primary-dim);
}

/* ===== Subtasks ===== */
.subtask-list{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--border);
}
.subtask-item{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 0;
}
.subtask-checkbox{
  margin:0;
}
.subtask-text{
  flex:1;
  font-size:14px;
  color:var(--primary);
}
.subtask-text.completed{
  text-decoration:line-through;
  color:var(--primary-dim);
}

/* ===== Time Tracking ===== */
.time-tracking-summary{
  display:flex;
  gap:16px;
  padding:12px;
  background:var(--bg);
  border-radius:8px;
  margin-bottom:12px;
}
.time-stat{
  flex:1;
  text-align:center;
}
.time-stat-value{
  font-size:24px;
  font-weight:700;
  color:var(--primary);
}
.time-stat-label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.05em;
  color:var(--primary-dim);
}

.time-session{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px 12px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  margin-bottom:6px;
}

/* ===== Reminders ===== */
.reminder-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 8px;
  background:#fef3c7;
  color:#92400e;
  border-radius:6px;
  font-size:11px;
  font-weight:600;
}

/* ===== Utility Classes ===== */
.hidden{display:none!important;}
.text-center{text-align:center;}
.text-right{text-align:right;}
.text-muted{color:var(--primary-dim);}
.text-danger{color:#dc2626;}
.text-success{color:#16a34a;}
.font-bold{font-weight:700;}
.font-semibold{font-weight:600;}
.mb-0{margin-bottom:0;}
.mb-1{margin-bottom:8px;}
.mb-2{margin-bottom:16px;}
.mb-3{margin-bottom:24px;}
.mt-0{margin-top:0;}
.mt-1{margin-top:8px;}
.mt-2{margin-top:16px;}
.mt-3{margin-top:24px;}
.p-0{padding:0;}
.p-1{padding:8px;}
.p-2{padding:16px;}
.p-3{padding:24px;}

/* ===== Analog Clock ===== */
.analog-clock{
  position:relative;
  width:120px;
  height:120px;
  border:3px solid var(--accent);
  border-radius:50%;
  background:var(--card);
  box-shadow:0 4px 16px rgba(0,0,0,0.2);
  margin:0 auto var(--space-4);
}
.clock-center{
  position:absolute;
  width:8px;
  height:8px;
  background:var(--accent);
  border-radius:50%;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  z-index:10;
}
.clock-hand{
  position:absolute;
  bottom:50%;
  left:50%;
  transform-origin:bottom center;
  background:var(--primary);
  border-radius:4px 4px 0 0;
}
.clock-hand.hour{
  width:4px;
  height:30px;
  margin-left:-2px;
  background:var(--accent);
}
.clock-hand.minute{
  width:3px;
  height:42px;
  margin-left:-1.5px;
  background:var(--primary);
}
.clock-hand.second{
  width:2px;
  height:45px;
  margin-left:-1px;
  background:#ef4444;
}
.clock-number{
  position:absolute;
  font-size:11px;
  font-weight:600;
  color:var(--primary-dim);
}

/* Theme Toggle Switch */
.theme-toggle{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  padding:var(--space-4);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  margin-bottom:var(--space-4);
}
.theme-toggle-label{
  flex:1;
  font-weight:600;
  color:var(--primary);
}
.toggle-switch{
  position:relative;
  width:52px;
  height:28px;
  background:var(--border);
  border-radius:14px;
  cursor:pointer;
  transition:background 0.3s ease;
}
.toggle-switch.active{
  background:var(--accent);
}
.toggle-slider{
  position:absolute;
  top:2px;
  left:2px;
  width:24px;
  height:24px;
  background:#fff;
  border-radius:50%;
  transition:transform 0.3s ease;
  box-shadow:0 2px 4px rgba(0,0,0,0.2);
}
.toggle-switch.active .toggle-slider{
  transform:translateX(24px);
}
/* Chronicles Listen-Ansicht */
.chronicles-list-container{
  padding:var(--space-4);
}
.chronicles-list{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-4);
  max-width:800px;
  margin:0 auto;
}
.chronicles-list-month{
  text-align:center;
  font-size:24px;
  font-weight:700;
  color:var(--primary);
  margin:var(--space-6) 0 var(--space-4) 0;
  padding-bottom:var(--space-3);
  border-bottom:2px solid var(--border);
}
.chronicles-list-month:first-child{
  margin-top:0;
}
.chronicles-list-day-header{
  text-align:center;
  margin:var(--space-4) 0 var(--space-3) 0;
}
.chronicles-list-day-name{
  font-size:18px;
  font-weight:700;
  color:var(--primary);
}
.chronicles-list-day-date{
  font-size:14px;
  font-weight:700;
  color:var(--primary-dim);
  margin-top:4px;
}
.chronicles-list-item{
  display:block;
  padding:var(--space-3);
  text-decoration:none;
  border-bottom:1px solid rgba(0,0,0,0.05);
  transition:all 0.2s ease;
}
.chronicles-list-item:hover{
  background:var(--card-hover);
  padding-left:var(--space-4);
}
.chronicles-list-item:last-child{
  border-bottom:none;
}

/* Chronicles Alle Jahre Grid */
.chronicles-all-years-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:var(--space-4);
  padding:var(--space-4);
}
.chronicles-year-tile{
  padding:var(--space-4);
  border-radius:var(--radius-2);
  cursor:pointer;
  transition:all 0.2s ease;
  text-align:center;
  color:#fff;
  min-height:150px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:var(--space-2);
}
.chronicles-year-tile:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
}
.chronicles-tile-year{
  font-size:32px;
  font-weight:700;
}
.chronicles-tile-count{
  font-size:16px;
  opacity:0.9;
}
.chronicles-tile-phase{
  display:inline-block;
  padding:6px 12px;
  border-radius:12px;
  font-size:12px;
  font-weight:600;
  margin-top:var(--space-2);
}

/* Chronicles Monats-Tiles mit Phasen */
.chronicles-phase-header{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:var(--space-3);
  margin-bottom:var(--space-4);
}
.chronicles-phase-badge{
  display:inline-block;
  padding:8px 16px;
  border-radius:16px;
  font-size:14px;
  font-weight:600;
  color:#fff;
}
.chronicles-year-title{
  font-size:28px;
  font-weight:700;
  color:var(--primary);
}
.chronicles-month-tiles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:var(--space-3);
}
.chronicles-month-tile{
  padding:var(--space-3);
  border-radius:var(--radius-2);
  cursor:pointer;
  transition:all 0.2s ease;
  text-align:center;
  color:#fff;
  min-height:100px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:var(--space-1);
}
.chronicles-month-tile:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(0,0,0,0.3);
}
.chronicles-tile-month{
  font-size:18px;
  font-weight:700;
}

/* Responsive */
@media (max-width: 768px) {
  .chronicles-all-years-grid{
    grid-template-columns:repeat(2,1fr);
  }
  .chronicles-month-tiles-grid{
    grid-template-columns:repeat(3,1fr);
  }
}
/* ===== V55 STYLES ===== */

/* Chronicles Legende */
.chronicles-legend{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-4);
  margin-bottom:var(--space-4);
  max-width:900px;
  margin-left:auto;
  margin-right:auto;
}
.legend-row{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:var(--space-3);
  align-items:center;
  margin-bottom:var(--space-3);
}
.legend-row:last-child{
  margin-bottom:0;
}
.legend-label{
  font-weight:700;
  color:var(--primary);
}
.legend-badges{
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
}
.legend-badge{
  display:inline-block;
  padding:6px 12px;
  border-radius:16px;
  font-size:12px;
  font-weight:600;
  white-space:nowrap;
}

/* Chronicles Year Select zentriert */
.chronicles-year-select{
  display:block;
  width:250px;
  margin:0 auto var(--space-4) auto;
  padding:var(--space-2);
  border:1px solid var(--border);
  border-radius:var(--radius-1);
  background:var(--card);
  color:var(--primary);
  font-size:14px;
}

/* Listen-Ansicht NEU */
.lists-new-container{
  max-width:1200px;
  margin:0 auto;
  padding:var(--space-4);
}
.category-select-dropdown{
  display:block;
  width:300px;
  margin:0 auto;
  padding:var(--space-3);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  background:var(--card);
  color:var(--primary);
  font-size:16px;
  text-align:center;
}
.btn-create-result{
  transition:all 0.2s ease;
}
.btn-create-result:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(0,0,0,0.2);
}
.category-header-large{
  display:grid;
  grid-template-columns:60px 1fr auto;
  align-items:center;
  gap:var(--space-4);
  padding:var(--space-4);
  border-radius:var(--radius-2);
  margin-bottom:var(--space-4);
}
.category-header-icon{
  font-size:48px;
  text-align:center;
}
.category-header-title{
  font-size:32px;
  font-weight:700;
  text-align:center;
}
.category-header-actions{
  display:flex;
  gap:var(--space-2);
}
.btn-icon{
  background:rgba(255,255,255,0.2);
  border:none;
  padding:var(--space-2);
  border-radius:var(--radius-1);
  cursor:pointer;
  font-size:20px;
  transition:all 0.2s ease;
  text-decoration:none;
  color:inherit;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
}
.btn-icon:hover{
  background:rgba(255,255,255,0.3);
  transform:scale(1.1);
}

/* Category Items List */
.category-items-list{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  overflow:hidden;
}
.category-item-row{
  display:grid;
  grid-template-columns:100px 120px 1fr 200px;
  gap:var(--space-3);
  padding:var(--space-3);
  border-bottom:1px solid rgba(0,0,0,0.05);
  transition:all 0.2s ease;
  align-items:center;
}
.category-item-row:hover{
  background:var(--card-hover);
}
.category-item-row:last-child{
  border-bottom:none;
}
.item-col-type{
  font-size:12px;
  font-weight:600;
  color:var(--primary-dim);
}
.item-col-date{
  font-size:13px;
  color:var(--primary);
}
.item-col-title{
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
}
.item-title-link{
  font-weight:700;
  font-size:15px;
  text-decoration:none;
  color:inherit;
}
.item-title-link:hover{
  text-decoration:underline;
}
.item-badges{
  display:flex;
  gap:var(--space-1);
  flex-wrap:wrap;
}
.item-col-preview{
  font-size:12px;
  color:var(--primary-dim);
  max-height:60px;
  overflow:hidden;
}
.subtasks-preview{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.subtask-item{
  font-size:11px;
  color:var(--primary-dim);
}
.subtasks-more{
  font-size:10px;
  color:var(--accent);
  font-weight:600;
}

/* Responsive Lists */
@media (max-width: 768px) {
  .category-item-row{
    grid-template-columns:1fr;
    gap:var(--space-2);
  }
  .category-header-large{
    grid-template-columns:1fr;
    text-align:center;
  }
  .category-header-actions{
    justify-content:center;
  }
  .legend-row{
    grid-template-columns:1fr;
  }
}
/* ===== V56 INBOX STYLES ===== */
.inbox-container{
  max-width:1200px;
  margin:0 auto;
  padding:var(--space-4);
}

/* Kategorie-Auswahl */
.inbox-category-select{
  display:block;
  width:300px;
  margin:0 auto var(--space-4) auto;
  padding:var(--space-3);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  background:var(--card);
  color:var(--primary);
  font-size:16px;
  text-align:center;
}

.inbox-category-card{
  display:grid;
  grid-template-columns:60px 1fr auto;
  align-items:center;
  gap:var(--space-4);
  padding:var(--space-4);
  border-radius:var(--radius-2);
  margin-bottom:var(--space-4);
  color:#fff;
}
.inbox-cat-icon{
  font-size:48px;
  text-align:center;
}
.inbox-cat-title{
  font-size:32px;
  font-weight:700;
  text-align:center;
}
.inbox-cat-actions{
  display:flex;
  gap:var(--space-2);
}
.btn-icon-inbox{
  background:rgba(255,255,255,0.2);
  border:none;
  padding:var(--space-2);
  border-radius:var(--radius-1);
  cursor:pointer;
  font-size:20px;
  transition:all 0.2s ease;
  text-decoration:none;
  color:inherit;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
}
.btn-icon-inbox:hover{
  background:rgba(255,255,255,0.3);
  transform:scale(1.1);
}

/* Tiles Grid */
.inbox-tiles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:var(--space-4);
  margin-bottom:var(--space-6);
}
.inbox-tile{
  padding:var(--space-4);
  border-radius:var(--radius-2);
  text-align:center;
  cursor:pointer;
  transition:all 0.2s ease;
  text-decoration:none;
  color:#000;
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
  min-height:120px;
  justify-content:center;
}
.inbox-tile:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
}
.inbox-tile-icon{
  font-size:48px;
}
.inbox-tile-title{
  font-size:16px;
  font-weight:700;
}
.inbox-tile-count{
  font-size:24px;
  font-weight:700;
}

/* Sections */
.inbox-section{
  margin-bottom:var(--space-6);
}
.inbox-section-title{
  font-size:24px;
  font-weight:700;
  color:var(--primary);
  text-align:center;
  margin-bottom:var(--space-4);
}

.inbox-table{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  overflow:hidden;
}
.inbox-item-row{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  padding:var(--space-3);
  border-bottom:1px solid rgba(0,0,0,0.05);
  transition:all 0.2s ease;
}
.inbox-item-row:hover{
  background:var(--card-hover);
}
.inbox-item-row:last-child{
  border-bottom:none;
}
.inbox-checkbox{
  width:24px;
  height:24px;
  cursor:pointer;
  border:3px solid var(--border);
  border-radius:4px;
  accent-color:#22c55e;
}
.inbox-checkbox:checked{
  background:#22c55e;
}
.inbox-event-date{
  font-size:13px;
  font-weight:700;
  color:var(--accent);
  min-width:100px;
}
.inbox-item-link{
  flex:1;
  text-decoration:none;
  color:inherit;
}
.inbox-item-title{
  font-weight:700;
  font-size:15px;
  color:inherit;
}
body[data-theme="dark"] .inbox-item-title{
  color:#fff;
}
body:not([data-theme="dark"]) .inbox-item-title{
  color:#000;
}
.inbox-item-preview{
  font-size:12px;
  margin-top:4px;
}
body[data-theme="dark"] .inbox-item-preview{
  color:#fff;
  opacity:0.8;
}
body:not([data-theme="dark"]) .inbox-item-preview{
  color:#000;
  opacity:0.7;
}

/* Inbox Items Header */
.inbox-items-header{
  background:rgba(237,171,86,0.6);
  border:1px solid #fff;
  border-radius:var(--radius-2);
  padding:var(--space-4);
  text-align:center;
  margin-bottom:var(--space-4);
}
.inbox-items-title{
  font-size:32px;
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-3);
}
.inbox-show-all{
  display:inline-block;
  padding:var(--space-2) var(--space-4);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-1);
  text-decoration:none;
  color:var(--primary);
  font-weight:600;
  transition:all 0.2s ease;
}
.inbox-show-all:hover{
  background:var(--card-hover);
  transform:translateY(-2px);
}

/* Items Liste */
.inbox-items-list{
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
  margin-bottom:var(--space-4);
}
.inbox-item-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  border-left:4px solid;
  padding:var(--space-3);
  transition:all 0.2s ease;
}
/* Mobile: heller Hintergrund, dunkle Schrift */
@media (max-width: 768px) {
  .inbox-item-card{
    background:#f9fafb !important;
    color:#1f2937 !important;
  }
  .inbox-item-card .inbox-item-title{
    color:#1f2937 !important;
    font-weight:700;
  }
  .inbox-item-card .inbox-item-preview{
    color:#4b5563 !important;
  }
  /* Override Dark-Theme für mobile */
  body[data-theme="dark"] .inbox-item-card{
    background:#f9fafb !important;
  }
  body[data-theme="dark"] .inbox-item-card *{
    color:#1f2937 !important;
  }
  body[data-theme="dark"] .inbox-item-card .inbox-item-preview{
    color:#4b5563 !important;
  }
}
.inbox-item-card:hover{
  background:var(--card-hover);
  transform:translateX(4px);
}
.inbox-card-link{
  text-decoration:none;
  color:inherit;
  display:block;
}
.inbox-card-title{
  font-weight:700;
  font-size:16px;
  margin-bottom:var(--space-1);
}
body[data-theme="dark"] .inbox-card-title{
  color:#fff;
}
body:not([data-theme="dark"]) .inbox-card-title{
  color:#000;
}
.inbox-card-preview{
  font-size:13px;
}
body[data-theme="dark"] .inbox-card-preview{
  color:#fff;
  opacity:0.8;
}
body:not([data-theme="dark"]) .inbox-card-preview{
  color:#000;
  opacity:0.7;
}

/* Projektmappe */
.projektmappe-section{
  background:#f9fafb;
  padding:16px;
  margin:16px 0;
  border-radius:12px;
}
.projektmappe-notes-field{
  background:#fff;
  padding:12px;
  border-radius:8px;
  border:2px solid #6A93B0;
  color:#000;
  white-space:pre-wrap;
  min-height:120px;
}
.projektmappe-notes-field *{
  color:#1f2937 !important;
}
.projektmappe-section strong{
  color:#1f2937 !important;
}

/* Pagination */
.inbox-pagination{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:var(--space-4);
  padding:var(--space-4);
}
.btn-page{
  padding:var(--space-2) var(--space-3);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-1);
  cursor:pointer;
  font-size:16px;
  transition:all 0.2s ease;
  color:var(--primary);
}
.btn-page:hover:not(:disabled){
  background:var(--card-hover);
  transform:translateY(-2px);
}
.btn-page:disabled{
  opacity:0.3;
  cursor:not-allowed;
}
.inbox-page-info{
  font-size:14px;
  font-weight:600;
  color:var(--primary);
}

/* ===== CATEGORIES PAGE ===== */
.categories-page-container{
  max-width:1000px;
  margin:0 auto;
  padding:var(--space-4);
}
.section-title-centered{
  font-size:28px;
  font-weight:700;
  color:var(--primary);
  text-align:center;
  margin-bottom:var(--space-4);
}
.new-category-section{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-6);
  margin-bottom:var(--space-6);
}
.new-cat-form{
  max-width:600px;
  margin:0 auto;
}
.form-label{
  display:block;
  font-weight:600;
  color:var(--primary);
  margin-bottom:var(--space-2);
}
.color-picker-new{
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
  margin-top:var(--space-2);
}
.color-dot-new{
  width:40px;
  height:40px;
  border-radius:50%;
  cursor:pointer;
  border:3px solid transparent;
  transition:all 0.2s ease;
}
.color-dot-new:hover{
  transform:scale(1.1);
}
.color-dot-new.active{
  border-color:var(--accent);
  transform:scale(1.2);
}
.icon-picker-new{
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
  margin-top:var(--space-2);
}
.icon-dot-new{
  width:50px;
  height:50px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:28px;
  cursor:pointer;
  border:2px solid transparent;
  border-radius:var(--radius-1);
  transition:all 0.2s ease;
  background:var(--card-hover);
}
.icon-dot-new:hover{
  transform:scale(1.1);
}
.icon-dot-new.active{
  border-color:var(--accent);
  background:var(--accent);
}

.existing-categories-section{
  margin-top:var(--space-6);
}
.categories-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:var(--space-4);
}
.category-card-full{
  display:grid;
  grid-template-columns:60px 1fr auto;
  align-items:center;
  gap:var(--space-3);
  padding:var(--space-3);
  border-radius:var(--radius-2);
  color:#fff;
  transition:all 0.2s ease;
}
.category-card-full:hover{
  transform:translateY(-2px);
  box-shadow:0 4px 16px rgba(0,0,0,0.3);
}
.cat-card-icon{
  font-size:40px;
  text-align:center;
}
.cat-card-title{
  font-size:20px;
  font-weight:700;
}
.cat-card-actions{
  display:flex;
  gap:var(--space-2);
}
.btn-icon-cat{
  background:rgba(255,255,255,0.2);
  border:none;
  padding:var(--space-2);
  border-radius:var(--radius-1);
  cursor:pointer;
  font-size:18px;
  transition:all 0.2s ease;
  color:#fff;
  width:36px;
  height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.btn-icon-cat:hover{
  background:rgba(255,255,255,0.3);
  transform:scale(1.1);
}

/* Responsive */
@media (max-width: 768px) {
  .inbox-tiles-grid{
    grid-template-columns:repeat(2,1fr);
  }
  .inbox-category-card{
    grid-template-columns:1fr;
    text-align:center;
  }
  .inbox-cat-actions{
    justify-content:center;
  }
  .categories-grid{
    grid-template-columns:1fr;
  }
  .category-card-full{
    grid-template-columns:1fr;
    text-align:center;
  }
  .cat-card-actions{
    justify-content:center;
  }
}
/* ===== V57 INBOX REORGANIZED ===== */
.inbox-container{
  max-width:1000px;
  margin:0 auto;
  padding:var(--space-4);
}

/* Clock Section */
.inbox-clock-section{
  text-align:center;
  margin-bottom:var(--space-6);
}

/* Sections */
.inbox-section{
  margin-bottom:var(--space-6);
}
.inbox-section-title{
  font-size:24px;
  font-weight:700;
  color:var(--primary);
  text-align:center;
  margin-bottom:var(--space-4);
}
.inbox-empty{
  text-align:center;
  color:var(--primary-dim);
  font-style:italic;
  padding:var(--space-4);
}

/* Tables */
.inbox-table-styled{
  width:100%;
  border-collapse:collapse;
  background:var(--card);
  border-radius:var(--radius-2);
  overflow:hidden;
}
.inbox-table-row{
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background 0.2s;
}
.inbox-table-row:hover{
  background:var(--card-hover);
}
.inbox-table-row:last-child{
  border-bottom:none;
}
.inbox-td-date,.inbox-td-time,.inbox-td-type{
  padding:var(--space-3);
  font-weight:600;
  color:var(--primary-dim);
  white-space:nowrap;
}
.inbox-td-title,.inbox-td-content{
  padding:var(--space-3);
  color:var(--primary);
}
.inbox-td-preview{
  padding:var(--space-3);
  color:var(--primary-dim);
  font-size:13px;
  max-width:300px;
}
.task-title{
  font-weight:700;
  margin-bottom:var(--space-1);
}
.task-badges{
  display:flex;
  gap:var(--space-1);
  flex-wrap:wrap;
  margin-top:var(--space-1);
}
.badge-status,.badge-prio,.badge-cat,.badge-type{
  padding:4px 8px;
  border-radius:6px;
  font-size:11px;
  font-weight:600;
  color:#fff;
}
.task-preview{
  font-size:12px;
  color:var(--primary-dim);
}
.preview-subtask{
  margin-bottom:2px;
}

/* Inbox Items Header */
.inbox-items-header{
  background:rgba(237,171,86,0.6);
  border:1px solid #fff;
  border-radius:var(--radius-2);
  padding:var(--space-4);
  text-align:center;
  margin-bottom:var(--space-4);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--space-3);
}
.inbox-items-title{
  font-size:32px;
  font-weight:700;
  color:var(--primary);
  margin:0;
}
.btn-show-all{
  padding:var(--space-2) var(--space-4);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-1);
  text-decoration:none;
  color:var(--primary);
  font-weight:600;
  transition:all 0.2s;
}
.btn-show-all:hover{
  background:var(--card-hover);
  transform:translateY(-2px);
}

/* Inbox Items List */
.inbox-items-list{
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
  margin-bottom:var(--space-6);
}
.inbox-item-card{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-3);
  transition:all 0.2s;
}
.inbox-item-card:hover{
  background:var(--card-hover);
  transform:translateX(4px);
}
.inbox-item-main{
  flex:1;
}
.inbox-item-title{
  font-size:16px;
  font-weight:700;
  color:var(--primary);
  text-decoration:none;
  display:block;
  margin-bottom:var(--space-1);
}
.inbox-item-title:hover{
  text-decoration:underline;
}
.inbox-item-preview{
  font-size:13px;
  color:var(--primary-dim);
  margin-bottom:var(--space-2);
}
.inbox-item-badges{
  display:flex;
  gap:var(--space-1);
  flex-wrap:wrap;
}
.inbox-result-checkbox{
  width:32px;
  height:32px;
  cursor:pointer;
  accent-color:#22c55e;
  flex-shrink:0;
}

/* Category Section */
.inbox-category-section{
  margin-bottom:var(--space-6);
}
.category-dropdown{
  display:block;
  width:100%;
  max-width:400px;
  margin:0 auto var(--space-4) auto;
  padding:var(--space-3);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  background:var(--card);
  color:var(--primary);
  font-size:16px;
}
.inbox-category-card{
  display:grid;
  grid-template-columns:60px 1fr auto;
  align-items:center;
  gap:var(--space-3);
  padding:var(--space-4);
  border-radius:var(--radius-2);
  margin-bottom:var(--space-4);
  color:#fff;
}
.cat-card-icon{
  font-size:48px;
  text-align:center;
}
.cat-card-name{
  font-size:28px;
  font-weight:700;
  text-align:center;
}
.cat-card-actions{
  display:flex;
  gap:var(--space-2);
}
.btn-cat-action{
  background:rgba(255,255,255,0.2);
  border:none;
  padding:var(--space-2);
  border-radius:var(--radius-1);
  cursor:pointer;
  font-size:20px;
  color:#fff;
  text-decoration:none;
  width:40px;
  height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all 0.2s;
}
.btn-cat-action:hover{
  background:rgba(255,255,255,0.3);
  transform:scale(1.1);
}
.category-items-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:var(--space-3);
}
.cat-item-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-3);
  text-decoration:none;
  transition:all 0.2s;
}
.cat-item-card:hover{
  background:var(--card-hover);
  transform:translateY(-2px);
}
.cat-item-title{
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-1);
}
.cat-item-type{
  font-size:12px;
  color:var(--primary-dim);
  margin-bottom:var(--space-1);
}
.cat-item-status{
  display:inline-block;
  padding:4px 8px;
  border-radius:6px;
  font-size:11px;
  font-weight:600;
  color:#fff;
}

/* Tiles Grid */
.inbox-tiles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:var(--space-3);
}
.inbox-tile{
  padding:var(--space-4);
  border-radius:var(--radius-2);
  text-align:center;
  text-decoration:none;
  color:#fff;
  transition:all 0.2s;
  display:flex;
  flex-direction:column;
  gap:var(--space-2);
  min-height:120px;
  justify-content:center;
}
.inbox-tile:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
}
.tile-icon{
  font-size:48px;
}
.tile-title{
  font-size:16px;
  font-weight:700;
}

/* Inbox All View */
.inbox-all-container{
  max-width:1000px;
  margin:0 auto;
  padding:var(--space-4);
}
.page-title{
  font-size:32px;
  font-weight:700;
  color:var(--primary);
  text-align:center;
  margin-bottom:var(--space-4);
}
.inbox-all-list{
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
  margin-top:var(--space-4);
}
.inbox-all-item{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-4);
  transition:all 0.2s;
}
.inbox-all-item:hover{
  background:var(--card-hover);
}
.inbox-all-main{
  flex:1;
}
.inbox-all-title{
  font-size:18px;
  font-weight:700;
  color:var(--primary);
  text-decoration:none;
  display:block;
  margin-bottom:var(--space-2);
}
.inbox-all-title:hover{
  text-decoration:underline;
}
.inbox-all-preview{
  font-size:14px;
  color:var(--primary-dim);
  margin-bottom:var(--space-2);
}
.inbox-all-badges{
  display:flex;
  gap:var(--space-1);
  flex-wrap:wrap;
  margin-bottom:var(--space-1);
}
.inbox-all-due{
  font-size:12px;
  font-weight:600;
  color:var(--accent);
}

/* Responsive */
@media (max-width: 768px) {
  .inbox-tiles-grid{
    grid-template-columns:repeat(2,1fr);
  }
  .category-items-grid{
    grid-template-columns:1fr;
  }
  .inbox-category-card{
    grid-template-columns:1fr;
    text-align:center;
  }
  .cat-card-actions{
    justify-content:center;
  }
  .inbox-table-styled{
    font-size:14px;
  }
  .inbox-td-preview{
    display:none;
  }
}
/* ===== V58 USER SETTINGS ===== */

/* Drawer Avatar rund */
.drawer-avatar-img{
  width:50px;
  height:50px;
  border-radius:50%;
  object-fit:cover;
}

/* User Settings Page */
.user-settings-container{
  max-width:600px;
  margin:0 auto;
  padding:var(--space-4);
}

.user-settings-form{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-6);
  margin-top:var(--space-4);
}

.form-section{
  margin-bottom:var(--space-6);
}

.form-label{
  display:block;
  font-size:16px;
  font-weight:700;
  color:var(--primary);
  margin-bottom:var(--space-2);
}

.avatar-upload-section{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--space-3);
}

.user-avatar-display{
  width:150px;
  height:150px;
  border-radius:50%;
  overflow:hidden;
  background:var(--card-hover);
  display:flex;
  align-items:center;
  justify-content:center;
  border:3px solid var(--border);
}

.user-avatar-preview{
  width:100%;
  height:100%;
  object-fit:cover;
}

.user-avatar-placeholder{
  font-size:80px;
  color:var(--primary-dim);
}

.form-actions{
  display:flex;
  justify-content:center;
  gap:var(--space-2);
}

.btn-primary{
  background:var(--accent);
  color:#fff;
  border:none;
}

.btn-primary:hover{
  opacity:0.9;
}

/* Responsive */
@media (max-width: 768px) {
  .user-settings-form{
    padding:var(--space-4);
  }
  .user-avatar-display{
    width:120px;
    height:120px;
  }
  .user-avatar-placeholder{
    font-size:60px;
  }
}
/* ===== V59 TIMELINE THUMBNAILS + SMARTVIEW ===== */

/* Timeline Thumbnails */
.timeline-thumbnail{
  max-width:300px;
  max-height:200px;
  border-radius:var(--radius-2);
  margin:var(--space-2) 0;
  object-fit:cover;
  cursor:pointer;
}
.timeline-thumbnail:hover{
  opacity:0.9;
}

.timeline-item-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:var(--space-2);
}

.timeline-item-time{
  font-size:12px;
  color:var(--primary-dim);
  font-weight:600;
}

/* SmartView */
.smartview-container{
  max-width:700px;
  margin:0 auto;
  padding:var(--space-4);
}

.smartview-form{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:var(--space-6);
  margin-top:var(--space-4);
}

.textarea{
  width:100%;
  padding:var(--space-3);
  border:1px solid var(--border);
  border-radius:var(--radius-1);
  background:var(--card);
  color:var(--primary);
  font-family:inherit;
  font-size:14px;
  resize:vertical;
}

.textarea:focus{
  outline:none;
  border-color:var(--accent);
}

/* Responsive */
@media (max-width: 768px) {
  .timeline-thumbnail{
    max-width:100%;
  }
  .smartview-form{
    padding:var(--space-4);
  }
}
/* ===== V60 FIXES & SIDEBAR USER ===== */

/* Inbox Items - Weiße Schrift auf dunklem Hintergrund */
body[data-theme="dark"] .inbox-item-title,
body[data-theme="dark"] .inbox-item-preview,
body[data-theme="dark"] .inbox-card-title,
body[data-theme="dark"] .inbox-card-preview,
body[data-theme="dark"] .inbox-all-title,
body[data-theme="dark"] .inbox-all-preview,
body[data-theme="dark"] .cat-item-title,
body[data-theme="dark"] .task-title,
body[data-theme="dark"] .inbox-td-title,
body[data-theme="dark"] .inbox-td-content{
  color:#fff !important;
}

/* Sidebar User Section */
.sidebar-user-section{
  padding:var(--space-4);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:var(--space-3);
  cursor:pointer;
  transition:all 0.2s ease;
}

.sidebar-user-section:hover{
  background:var(--card-hover);
}

.sidebar-user-avatar{
  width:50px;
  height:50px;
  border-radius:50%;
  object-fit:cover;
  border:2px solid var(--accent);
  flex-shrink:0;
}

.sidebar-user-info{
  flex:1;
  min-width:0;
}

.sidebar-user-name{
  font-size:16px;
  font-weight:700;
  color:var(--primary);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.sidebar-user-label{
  font-size:12px;
  color:var(--primary-dim);
}

/* Desktop Sidebar erweitert */
.sidebar{
  display:flex;
  flex-direction:column;
}

.sidebar-header{
  padding:var(--space-4);
  border-bottom:1px solid var(--border);
}

.sidebar-brand{
  font-size:24px;
  font-weight:700;
  color:var(--primary);
  text-align:center;
}

.sidebar-nav{
  flex:1;
  overflow-y:auto;
}

/* Tablet/Desktop Sidebar */
@media (min-width: 1024px) {
  .sidebar{
    width:250px;
    border-right:1px solid var(--border);
    background:var(--card);
  }
  
  .sidebar-user-section{
    padding:var(--space-4);
  }
}

/* Mobile - User im Drawer bleibt */
@media (max-width: 1023px) {
  .sidebar-user-section{
    display:none;
  }
}

/* ===== V61 CRITICAL FIXES ===== */

/* Inbox Items - Force white on dark (Mobile + Desktop) */
body[data-theme="dark"] .inbox-item-title,
body[data-theme="dark"] .inbox-item-preview,
body[data-theme="dark"] .inbox-card-title,
body[data-theme="dark"] .inbox-card-preview{
  color:#fff !important;
}

/* Uhr ohne Rahmen */
.inbox-clock-section canvas{
  border:none !important;
  box-shadow:none !important;
}

/* Drawer Avatar immer sichtbar */
.drawer-avatar-img{
  width:50px;
  height:50px;
  border-radius:50%;
  object-fit:cover;
  display:block !important;
}

.drawer-avatar{
  width:50px;
  height:50px;
  border-radius:50%;
  background:var(--card-hover);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:30px;
}

/* ===== V63 TEXT FIX FINAL ===== */
body[data-theme="dark"] .inbox-items-list *,
body[data-theme="dark"] .inbox-item-card *,
body[data-theme="dark"] .inbox-item-main *{
  color:#ffffff !important;
}


/* ===== V68: Statistik ===== */
.stats-page{ padding:12px; }
.stats-card{ background:var(--card); border:1px solid var(--border); border-radius:12px; padding:10px; }
.stats-row{ display:flex; justify-content:space-between; gap:12px; padding:10px 8px; border-bottom:1px solid var(--border); }
.stats-row:last-child{ border-bottom:none; }
.stats-label{ font-weight:600; }
.stats-value{ text-align:right; opacity:0.95; }
.stats-row.clickable{ cursor:pointer; }
.stats-row.clickable:hover{ background:rgba(255,255,255,0.04); }

/* V88.0.26 – Stats: 2-spaltige Tabelle in Sektion 1 */
.stats-table{ width:100%; border-collapse:collapse; }
.stats-table td{ padding:10px 8px; border-bottom:1px solid var(--border); vertical-align:top; }
.stats-table tr:last-child td{ border-bottom:none; }
.stats-table td:first-child{ font-weight:600; }
.stats-table td:last-child{ text-align:right; opacity:0.95; }
.stats-table tr.clickable{ cursor:pointer; }
.stats-table tr.clickable:hover{ background:rgba(255,255,255,0.04); }


.drag-handle{cursor:grab; user-select:none; padding:6px 10px; border-radius:10px; opacity:0.8;}
.drag-handle:active{cursor:grabbing;}


/* ===== Chronicles Actions (Responsive) ===== */
.chronicles-actions-wrap{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  width:100%;
}
.chronicles-actions-desktop{
  display:flex;
  gap:8px;
  align-items:center;
}
.chronicles-actions-mobile{
  display:none;
  width: 100%;
  max-width: 220px;
}
@media (max-width: 520px){
  .chronicles-actions-desktop{ display:none; }
  .chronicles-actions-mobile{ display:block; }
  .chronicles-actions-mobile select{ width:100%; }
}

/* Legend badge buttons */
.legend-badge-btn{
  border:none;
  cursor:pointer;
}
.legend-badge-btn.active{
  outline:2px solid rgba(255,255,255,0.95);
  outline-offset:2px;
}


/* v83->v84: Collapsible FilterBar + responsive header actions */
.filterbar-collapsible{
  width:100%;
  margin-bottom: var(--space-2);
}
.filterbar-collapsible-head{
  display:flex;
  justify-content:flex-end;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.filterbar-toggle{
  padding: 8px 10px;
  font-size: 14px;
}
.filterbar-collapsible-body{
  width:100%;
}
@media (max-width: 520px){
  /* In Portrait: only dropdown for view selection, hide smart buttons */
  .timeline-actions-desktop{ display:none !important; }
  .timeline-actions-mobile{ display:block !important; width:100%; }
  .chronicles-actions-desktop{ display:none !important; }
  .chronicles-actions-mobile{ display:block !important; width:100%; }
  .chronicles-actions-select,
  .timeline-view-select{ width:100% !important; max-width:100% !important; }
  .filter-bar-timeline-new{ grid-template-columns: 1fr !important; }
  .zeitraum-row{ flex-direction: column !important; align-items: stretch !important; }
  .zeitraum-separator-inline{ display:none !important; }
}


/* ===== Timeline Month View ===== */
.timeline-month-list{
  display:flex;
  flex-direction:column;
  gap:14px;
  padding: 6px 0 24px;
}
.timeline-month-block{
  border:1px solid rgba(148,163,184,0.25);
  border-radius:16px;
  overflow:hidden;
  background: rgba(255,255,255,0.02);
}
.timeline-month-header{
  padding:12px 14px;
  font-weight:700;
  text-transform:capitalize;
  border-bottom:1px solid rgba(148,163,184,0.25);
}
.timeline-month-items{
  display:flex;
  flex-direction:column;
}
.timeline-month-item{
  text-align:left;
  padding:12px 14px;
  border:0;
  border-bottom:1px solid rgba(148,163,184,0.18);
  background: transparent;
  cursor:pointer;
}
.timeline-month-item:last-child{
  border-bottom:0;
}
.timeline-month-item-top{
  display:flex;
  gap:10px;
  align-items:baseline;
  justify-content:space-between;
  opacity:0.85;
  font-size: 13px;
}
.timeline-month-item-title{
  margin-top:6px;
  font-weight:700;
}
.timeline-month-item-snippet{
  margin-top:6px;
  opacity:0.8;
  font-size: 13px;
  line-height:1.35;
}


/* V88.0.20 – FilterBar actions: Anzeigen + Reset side-by-side */
.filter-actions-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  width:100%;
}
@media (max-width: 520px){
  .filter-actions-grid{ grid-template-columns: 1fr; }
}

/* V88.0.30 – Statistik Dashboard Charts */
.stats-chart-container{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
  padding:20px 0;
}
.stats-chart-title{
  font-size:18px;
  font-weight:700;
  color:var(--primary);
  text-align:center;
}
.stats-chart-subtitle{
  font-size:14px;
  font-weight:600;
  color:var(--primary-dim);
  text-align:center;
  margin-top:-8px;
}
.stats-pie-chart{
  width:100%;
  max-width:280px;
  height:auto;
}
.stats-chart-empty{
  padding:40px;
  text-align:center;
  color:var(--primary-dim);
  font-size:14px;
}
.chart-legend{
  display:flex;
  flex-direction:column;
  gap:8px;
  width:100%;
  max-width:400px;
}
.chart-legend-item{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
}
.chart-legend-color{
  width:20px;
  height:20px;
  border-radius:4px;
  flex-shrink:0;
}
.chart-legend-label{
  flex:1;
  font-weight:500;
}

/* V88.0.31 – 7-Tage-Trend Display mit differenzierten Pfeilfarben */
.trend-display{
  padding:20px;
  background:var(--card);
  border-radius:12px;
  border:1px solid var(--border);
}
.trend-comparison{
  display:flex;
  align-items:center;
  justify-content:space-around;
  gap:20px;
  flex-wrap:wrap;
}
.trend-period{
  flex:1;
  min-width:140px;
  text-align:center;
}
.trend-label{
  font-size:13px;
  color:var(--primary-dim);
  margin-bottom:8px;
  font-weight:500;
}
.trend-value{
  font-size:24px;
  font-weight:700;
  color:var(--primary);
}
.trend-arrow{
  font-size:48px;
  line-height:1;
  flex-shrink:0;
}
.trend-summary{
  text-align:center;
  font-size:18px;
}
@media (max-width: 520px){
  .trend-comparison{
    flex-direction:column;
  }
  /* V88.0.31: Pfeil bleibt horizontal (keine Rotation mehr) */
  .trend-arrow{
    font-size:36px;
  }
}

/* V88.0.34 – Statistik Popups */
.stats-popup-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.6);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10000;
  padding:20px;
}
.stats-popup{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  max-width:600px;
  width:100%;
  max-height:80vh;
  display:flex;
  flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,0.3);
}
.stats-popup-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px;
  border-bottom:1px solid var(--border);
}
.stats-popup-content{
  overflow-y:auto;
  flex:1;
  min-height:0;
}
.popup-list-item{
  transition:background 0.2s ease;
}
.popup-list-item:hover{
  background:var(--card-hover);
}
.popup-list-item:last-child{
  border-bottom:none;
}



/* ===== Chronicles Mini Calendar (HeaderBar) - V88.0.34 ===== */
.chronicles-mini-cal{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  padding:10px;
  overflow:hidden;
}

/* make the month grid responsive inside header (no fixed min-width) */
.chronicles-mini-cal .month-grid{
  min-width:0 !important;
  width:100%;
  overflow:hidden;
}

/* smaller nav in mini mode */
.calendar-nav.mini{
  padding:6px 8px;
  border-radius:12px;
}
.calendar-nav.mini .calendar-title{
  font-size:14px;
}

/* compact cells */
.chronicles-mini-cal .month-day.mini{
  min-height:44px;
  padding:6px;
}
.chronicles-mini-cal .month-day-num{
  font-size:12px;
  margin-bottom:0;
}
.chronicles-mini-cal .mini-count{
  margin-top:6px;
  width:20px;
  height:20px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:700;
  background:rgba(59,130,246,0.15);
  border:1px solid rgba(59,130,246,0.35);
}
@media (max-width: 768px){
  .chronicles-mini-cal .month-day.mini{
    min-height:38px;
    padding:4px;
  }
  .chronicles-mini-cal .mini-count{
    width:18px;
    height:18px;
    font-size:10px;
  }
}



/* ===== Timeline: Attachment badges + Thumbnails ===== */
.timeline-attach-badge,
.timeline-link-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:2px 8px;
  border-radius:999px;
  font-size:12px;
  background:rgba(255,255,255,0.16);
  color:#fff;
  margin-left:6px;
}

.timeline-thumb-frame{
  display:flex;
  gap:8px;
  padding:8px;
  margin:8px 0 10px;
  border:1px solid rgba(255,255,255,0.22);
  border-radius:12px;
  background:rgba(0,0,0,0.12);
  overflow-x:auto;
}
.timeline-thumb{
  border:none;
  padding:0;
  background:transparent;
  cursor:pointer;
}
.timeline-thumb-img{
  width:44px;
  height:44px;
  object-fit:cover;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.22);
  display:block;
}
.timeline-thumb-file{
  width:44px;
  height:44px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.22);
  background:rgba(255,255,255,0.14);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:12px;
  color:#fff;
}

/* ===== Thumb modal (responsive + swipe) ===== */
.thumb-modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.72);
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
}
.thumb-modal{
  width:min(920px, 96vw);
  height:min(86vh, 720px);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.thumb-modal-close{
  position:absolute;
  top:10px;
  right:10px;
  border:none;
  background:rgba(0,0,0,0.14);
  color:var(--primary);
  border-radius:999px;
  padding:8px 12px;
  cursor:pointer;
  z-index:2;
}
.thumb-modal-title{
  padding:14px 16px 8px;
  font-weight:800;
  color:var(--primary);
}
.thumb-modal-body{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px;
}
.thumb-modal-img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  border-radius:14px;
  border:1px solid var(--border);
}
.thumb-modal-file{
  width:100%;
  max-width:520px;
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px;
  background:var(--bg);
  text-align:center;
}
.thumb-modal-file-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:72px;
  height:72px;
  border-radius:18px;
  background:var(--card);
  border:1px solid var(--border);
  font-weight:900;
  font-size:16px;
  margin:0 auto 12px;
}
.thumb-modal-file-name{
  font-weight:800;
  color:var(--primary);
  margin-bottom:6px;
  word-break:break-word;
}
.thumb-modal-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:none;
  background:rgba(0,0,0,0.14);
  color:var(--primary);
  border-radius:999px;
  padding:10px 12px;
  cursor:pointer;
  z-index:2;
}
.thumb-modal-prev{ left:10px; }
.thumb-modal-next{ right:10px; }

/* V92: Modal Footer */
.thumb-modal-footer{
  padding:12px 20px;
  background:rgba(0,0,0,.03);
  border-top:1px solid rgba(0,0,0,.08);
  min-height:50px;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* V92: Overflow-Indikator */
.timeline-thumb-overflow{
  opacity:0.85;
}
.timeline-thumb-overflow .timeline-thumb-file{
  background:linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  color:#fff;
  font-weight:700;
  font-size:14px;
}
.timeline-thumb-overflow:hover{
  opacity:1;
  transform:scale(1.05);
}

@media (max-width: 520px){
  .timeline-thumb-frame{ padding:6px; gap:6px; }
  .timeline-thumb-img,.timeline-thumb-file{ width:40px; height:40px; border-radius:10px; }
  .thumb-modal{ width:96vw; height:88vh; }
  .thumb-modal-footer{ padding:8px 12px; min-height:40px; }
}


/* =====================================================
   V103 EditEntry Refactor – Dark UI CSS
   All new classes prefixed ep- to avoid collisions
   ===================================================== */

/* ── Dark container ── */
.ep-dark {
  background: var(--bg);
  color: var(--primary);
  min-height: 100%;
}

/* ── Header section ── */
.ep-header {
  border-radius: var(--radius-2);
  padding: var(--space-5) var(--space-5) var(--space-4);
  margin-bottom: var(--space-4);
}

/* ── Responsive 2-column grid ── */
.ep-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 1024px) {
  .ep-grid {
    grid-template-columns: 340px 1fr;
    align-items: start;
  }
}

/* ── Column wrappers ── */
.ep-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* ── Section card (dark) ── */
.ep-section {
  border-radius: var(--radius-2);
  padding: var(--space-4);
  margin-bottom: 0;
}
.ep-section-dark {
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: 0 1px 6px rgba(0,0,0,0.12);
}
.ep-section-title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--primary-dim);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--border);
}
.ep-section-subtitle {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--primary-dim);
  margin: var(--space-3) 0 var(--space-2);
  opacity: 0.7;
}

/* ── Collapsible extended section ── */
.ep-section-collapsible {
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--border);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--primary-dim);
}
.ep-section-collapsible:hover { color: var(--primary); }
.ep-section-extended { margin-top: var(--space-3); }
.ep-extended-body { }

/* ── Field group ── */
.ep-field-group {
  margin-bottom: var(--space-3);
}
.ep-field-group:last-child { margin-bottom: 0; }
.ep-field-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--primary-dim);
  margin-bottom: 5px;
  display: block;
}

/* ── Title input ── */
.ep-title-input {
  font-size: 18px;
  font-weight: 600;
  min-height: 48px;
}
.ep-title-group { margin-top: var(--space-2); }

/* ── Quick Chips ── */
.ep-chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: var(--space-2);
}
.ep-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  border-radius: 20px;
  border: 1.5px solid var(--border);
  background: transparent;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  transition: all 0.15s ease;
  min-height: 32px;
  color: var(--primary-dim);
}
.ep-chip:hover { transform: translateY(-1px); box-shadow: 0 2px 8px rgba(0,0,0,0.15); }
.ep-chip-active { font-weight: 700; }

/* Fallback dropdowns (hidden visually but accessible) */
.ep-chips-fallback {
  display: none;
}
/* Show fallback on no-JS or explicit fallback mode */
.ep-show-fallback .ep-chips-fallback { display: block; }
.ep-show-fallback .ep-chips-row { display: none; }

/* Hidden type btn fallback */
.ep-hidden-btn {
  display: none !important;
}

/* ── Validation hint ── */
.ep-validation-hint {
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.4);
  border-radius: var(--radius-1);
  padding: var(--space-3) var(--space-4);
  font-size: 13px;
  color: #f59e0b;
  margin-top: var(--space-2);
}

/* ── Sync conflict banner ── */
.ep-sync-conflict {
  background: rgba(59, 130, 246, 0.10);
  border: 1px solid rgba(59, 130, 246, 0.35);
  border-radius: var(--radius-1);
  padding: var(--space-2) var(--space-4);
  font-size: 12px;
  color: #3b82f6;
  margin-bottom: var(--space-3);
}

/* ── Markdown toolbar ── */
.ep-md-toolbar-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  flex-wrap: wrap;
}
.ep-md-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  flex: 1;
}
.ep-md-btn {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  color: var(--primary);
  min-height: 28px;
  min-width: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.1s ease;
  font-family: monospace;
}
.ep-md-btn:hover {
  background: var(--card-hover);
  border-color: var(--accent);
  color: var(--accent);
}

/* ── Emoji Picker ── */
.ep-emoji-wrap { position: relative; }
.ep-emoji-toggle { font-size: 16px; min-width: 32px; }
.ep-emoji-picker {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  z-index: 500;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-2);
  padding: var(--space-3);
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  width: 220px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.ep-emoji-btn {
  background: none;
  border: none;
  font-size: 18px;
  cursor: pointer;
  padding: 3px;
  border-radius: 4px;
  min-height: 30px;
  min-width: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.1s;
}
.ep-emoji-btn:hover { background: var(--card-hover); }

/* ── Notes textarea ── */
.ep-notes-textarea {
  min-height: 180px;
  font-size: 14px;
  font-family: 'SF Mono', 'Consolas', monospace;
  resize: vertical;
}

/* ── Subtasks ── */
.ep-subtasks-box { }
.ep-subtasks-header {
  font-weight: 600;
  margin-bottom: var(--space-2);
  opacity: 0.8;
}
.ep-subtasks-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.ep-subtask-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-1);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  flex-wrap: wrap;
}
.ep-subtask-linked {
  border-color: rgba(59, 130, 246, 0.35);
  background: rgba(59, 130, 246, 0.05);
}
.ep-subtask-text {
  flex: 1;
  font-size: 13px;
  min-width: 80px;
}
.ep-subtask-itemcard {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 80px;
}
.ep-subtask-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 8px;
  background: rgba(59, 130, 246, 0.15);
  color: #3b82f6;
  display: inline-block;
}
.ep-subtask-link {
  font-size: 11px;
  color: var(--accent);
  text-decoration: none;
  opacity: 0.8;
}
.ep-subtask-link:hover { opacity: 1; text-decoration: underline; }
.ep-subtask-inbox-btn {
  padding: 4px 10px;
  font-size: 11px;
  min-height: 28px;
  white-space: nowrap;
}
.ep-subtask-batch-btn {
  width: 100%;
  margin-bottom: var(--space-2);
  font-size: 12px;
  background: rgba(34, 197, 94, 0.1);
  border-color: rgba(34, 197, 94, 0.35);
  color: #22c55e;
}
.ep-subtask-batch-btn:hover { background: rgba(34, 197, 94, 0.2); }

/* ── Links preview ── */
.ep-links-preview {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: var(--space-2);
}
.ep-link-preview-item {
  display: block;
  font-size: 12px;
  color: #3b82f6;
  text-decoration: none;
  word-break: break-all;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(59, 130, 246, 0.06);
  border: 1px solid rgba(59, 130, 246, 0.15);
}
.ep-link-preview-item:hover {
  background: rgba(59, 130, 246, 0.12);
  text-decoration: underline;
}

/* ── Attachment Gallery ── */
.ep-att-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.ep-att-gallery-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  border-radius: var(--radius-1);
  padding: var(--space-2);
  border: 1px solid var(--border);
  background: var(--card);
  transition: all 0.15s ease;
}
.ep-att-gallery-tile:hover {
  background: var(--card-hover);
  border-color: var(--accent);
  transform: translateY(-2px);
}
.ep-att-gallery-thumb {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: 6px;
  cursor: pointer;
}
.ep-att-gallery-icon {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  border-radius: 6px;
  background: rgba(100,116,139,0.15);
  color: var(--primary-dim);
  text-align: center;
  cursor: pointer;
}
.ep-att-gallery-name {
  font-size: 10px;
  text-align: center;
  word-break: break-all;
  color: var(--primary-dim);
  max-width: 80px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ep-att-gallery-del {
  position: absolute;
  top: -5px;
  right: -5px;
  width: 20px;
  height: 20px;
  min-height: 20px;
  padding: 0;
  background: #ef4444;
  color: #fff;
  border: none;
  border-radius: 50%;
  font-size: 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.15s;
}
.ep-att-gallery-tile:hover .ep-att-gallery-del { opacity: 1; }

/* ── Lightbox/Modal ── */
.ep-lightbox-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9000;
  padding: 20px;
  backdrop-filter: blur(4px);
}
.ep-lightbox-content {
  max-width: min(90vw, 800px);
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  overflow-y: auto;
}
.ep-lightbox-img {
  max-width: 100%;
  max-height: 75vh;
  object-fit: contain;
  border-radius: var(--radius-2);
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.ep-lightbox-icon {
  font-size: 48px;
  text-align: center;
}
.ep-lightbox-name {
  color: #fff;
  font-size: 14px;
  text-align: center;
}
.ep-lightbox-close {
  position: fixed;
  top: 20px;
  right: 20px;
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.25);
  color: #fff;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9001;
  transition: background 0.15s;
}
.ep-lightbox-close:hover { background: rgba(255,255,255,0.3); }

/* ── Modals container (above page, below global modals) ── */
.ep-modals { position: relative; z-index: 200; }

/* ── Actions bar (desktop) ── */
.ep-actions-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-4);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-2);
  margin-top: var(--space-4);
}
.ep-save-btn { flex-shrink: 0; }
.ep-undo-btn { flex-shrink: 0; }
.ep-back-btn { flex-shrink: 0; }

/* ── Sticky Action Bar (mobile) ── */
/* ── Mobile Action Bar ──────────────────────────────────────────────
   V107: Die Bar wird als direktes Kind von .app-shell gerendert
   (via window.__layoutFooter in layout()). Kein overflow:auto Clipping!
   Position: fixed, direkt über der bottom-nav  */

.ep-sticky-action-bar {
  display: none; /* Desktop: ausgeblendet */
  order: 10;
}

/* ── Mobile FAB Action Menu ──────────────────────────────────────── */
/* Floating Action Button mit aufgeklapptem Menü (mobile EditEntry) */
.ep-fab-container {
  display: none; /* Desktop: versteckt */
  position: fixed;
  bottom: calc(var(--nav-h) + 14px);
  right: 16px;
  z-index: 300;
  flex-direction: column-reverse;
  align-items: flex-end;
  gap: 10px;
}
.ep-fab-main {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #1d4ed8;
  color: #fff;
  border: none;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(29,78,216,0.55);
  transition: transform 0.2s, background 0.2s;
  -webkit-tap-highlight-color: transparent;
  flex-shrink: 0;
}
.ep-fab-main:active { transform: scale(0.92); }
.ep-fab-main.open { background: #374151; transform: rotate(45deg); }
.ep-fab-menu {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end;
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.28s cubic-bezier(0.4,0,0.2,1), opacity 0.22s ease;
  opacity: 0;
  pointer-events: none;
}
.ep-fab-menu.open {
  max-height: 420px;
  opacity: 1;
  pointer-events: auto;
}
.ep-fab-item {
  display: flex;
  align-items: center;
  gap: 10px;
  background: none;
  border: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
}
.ep-fab-item-label {
  background: rgba(15,23,42,0.95);
  color: #e2e8f0;
  font-size: 13px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.18);
  white-space: nowrap;
  backdrop-filter: blur(8px);
  box-shadow: 0 2px 10px rgba(0,0,0,0.4);
}
.ep-fab-item-btn {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.35);
  flex-shrink: 0;
  background: rgba(30,41,59,0.96);
  color: #e2e8f0;
  border: 1px solid rgba(255,255,255,0.15);
}
.ep-fab-item-btn.ep-fab-save { background: #1d4ed8; border-color: #2563eb; color: #fff; }
.ep-fab-item-btn.ep-fab-delete { background: rgba(239,68,68,0.22); border-color: rgba(239,68,68,0.5); color: #fca5a5; }
.ep-fab-item-btn.ep-fab-back { background: rgba(255,255,255,0.07); }
.ep-fab-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 295;
}
.ep-fab-backdrop.open { display: block; }

@media (max-width: 1023px) {
  .ep-actions-bar {
    display: none !important;
  }
  .ep-sticky-action-bar {
    display: none !important; /* replaced by FAB on mobile */
  }
  .ep-fab-container {
    display: flex;
  }
  .ep-main {
    padding-bottom: 8px;
  }
}

/* ── Accordion mobile (using CSS-only for section-collapsible) ── */
@media (max-width: 1023px) {
  .ep-section-notes .ep-notes-textarea { min-height: 130px; }
}

/* ── Stamp boxes ── */
.stamp-box {
  background: rgba(255,255,255,0.04);
  border-radius: var(--radius-1);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--border);
  flex: 1;
}
.stamp-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--primary-dim);
  font-weight: 600;
  margin-bottom: 3px;
}
.stamp-value {
  font-size: 11px;
  color: var(--primary);
  word-break: break-all;
}

/* ── Meta box ── */
.meta-box {
  background: var(--card);
  border-radius: var(--radius-2);
  border: 1px solid var(--border);
  padding: var(--space-3);
  flex: 1;
}
.meta-label {
  font-size: 11px;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--primary-dim);
  margin-bottom: var(--space-2);
}
.meta-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--primary);
}
.stats-label { }
.stats-subheading {
  font-size: 11px;
  font-weight: 600;
  margin: var(--space-2) 0 var(--space-1);
  color: var(--primary-dim);
}

/* ── kv-grid ── */
.kv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
@media (max-width: 600px) {
  .kv-grid { grid-template-columns: 1fr; }
}

/* ── col helper ── */
.col {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

/* ── cat-option (modal list items) ── */
.cat-option {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: var(--card);
  border: none;
  border-radius: var(--radius-1);
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  width: 100%;
  text-align: left;
  color: var(--primary);
  transition: background 0.15s;
  margin-bottom: 3px;
}
.cat-option:hover { background: var(--card-hover); }
.cat-dot {
  width: 12px; height: 12px; border-radius: 50%;
  display: inline-block; flex-shrink: 0;
}
.cat-label { font-size: 14px; font-weight: 500; }

/* ── dropzone ── */
.dropzone {
  border: 2px dashed var(--border);
  border-radius: var(--radius-2);
  padding: var(--space-5);
  text-align: center;
  font-size: 13px;
  color: var(--primary-dim);
  cursor: pointer;
  transition: all 0.15s;
  margin-top: var(--space-2);
}
.dropzone.dragover {
  border-color: var(--accent);
  background: rgba(212,175,55,0.07);
  color: var(--accent);
}

/* ── Tags input ── */
.ep-tags-input { font-size: 13px; }

/* ── Event date row ── */
.ep-event-date-row { margin-bottom: 0; }

/* ── Section stamps (compact) ── */
.ep-section-stamps .kv-grid { grid-template-columns: 1fr 1fr; gap: var(--space-2); }

/* ── Input/Select/Textarea base (existing .input/.select/.textarea classes) ── */
/* These are already defined in base CSS; just ensure no conflicts */
.input { box-sizing: border-box; }
.select { box-sizing: border-box; }
.textarea { box-sizing: border-box; }
.btn-wide { width: 100%; }
.btn-ghost {
  background: transparent;
  border-color: var(--border);
  color: var(--primary-dim);
}
.btn-ghost:hover { background: var(--card-hover); color: var(--primary); }

/* ── Section top margin for epMain ── */
.ep-main > * + * { margin-top: 0; }


/* =============================================================================
   PROJEKTMAPPE V2 - Dunkle Grid-Ansicht (V104)
   ============================================================================= */

/* ---- Page Wrapper ---- */
/* V105: PV2 läuft innerhalb layout().content → scroll von .content */
.pv2-content-shell {
  padding: 0 !important;
  background: #08101e;
}

.pv2-page-wrap {
  min-height: unset;
  background: #08101e;
  color: #e2e8f0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  display: flex;
  flex-direction: column;
  width: 100%;
}

.pv2-page-body {
  flex: 1;
  padding: 16px 16px calc(var(--nav-h) + 24px);
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}

/* ---- Sticky Header ---- */
.pv2-sticky-header {
  position: sticky;
  top: -16px; /* compensate for .content padding */
  z-index: 80; /* below global modals/nav */
  background: rgba(8, 16, 30, 0.97);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  /* V108: 2vw seitlicher Innenabstand */
  padding: 10px 2vw 8px;
  margin: -16px -16px 16px -16px; /* fill content horizontal padding */
  box-sizing: border-box;
}

.pv2-header-top {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.pv2-header-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}

.pv2-cat-icon {
  font-size: 26px;
  line-height: 1;
}

.pv2-cat-name {
  font-size: 20px;
  font-weight: 700;
  color: #f1f5f9;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pv2-cat-select {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
  color: #94a3b8;
  padding: 4px 8px;
  font-size: 13px;
  cursor: pointer;
  max-width: 200px;
}

.pv2-header-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.pv2-meta-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 500;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  color: #94a3b8;
  white-space: nowrap;
}

.pv2-chip-red { background: rgba(239,68,68,0.12) !important; color: #f87171 !important; border-color: rgba(239,68,68,0.25) !important; }
.pv2-chip-time { background: rgba(100,116,139,0.15) !important; color: #94a3b8 !important; }

.pv2-header-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-shrink: 0;
}

/* ---- Action Buttons ---- */
.pv2-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.07);
  color: #e2e8f0;
  text-decoration: none;
  transition: all 0.15s ease;
}
.pv2-action-btn:hover { background: rgba(255,255,255,0.13); transform: translateY(-1px); }
.pv2-add-btn { background: rgba(59,130,246,0.18); border-color: rgba(59,130,246,0.35); color: #93c5fd; }
.pv2-print-btn { background: rgba(100,116,139,0.18); }
.pv2-back-btn { background: transparent; color: #64748b; }
.pv2-gen-btn { background: rgba(212,175,55,0.15); border-color: rgba(212,175,55,0.3); color: #d4af37; }

/* ---- Presets + Filters ---- */
.pv2-header-bottom {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.pv2-presets, .pv2-filters {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.pv2-preset-btn, .pv2-filter-chip {
  padding: 4px 12px;
  border-radius: 16px;
  font-size: 12px;
  font-weight: 500;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.05);
  color: #94a3b8;
  cursor: pointer;
  transition: all 0.15s ease;
}
.pv2-preset-btn.active, .pv2-filter-chip.active {
  background: rgba(212,175,55,0.2);
  border-color: rgba(212,175,55,0.4);
  color: #d4af37;
}
.pv2-preset-btn:hover, .pv2-filter-chip:hover { background: rgba(255,255,255,0.1); color: #e2e8f0; }
.pv2-focus-chip.active { background: rgba(239,68,68,0.18); border-color: rgba(239,68,68,0.4); color: #f87171; }

/* ── V108: Gemeinsame Select-Basis (Desktop + Mobile) ─────────────────────── */
.pv2-sel {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 8px;
  color: #e2e8f0;
  padding: 6px 10px;
  font-size: 13px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  min-height: 34px;
  box-sizing: border-box;
  transition: border-color 0.15s;
}
.pv2-sel:focus { outline: none; border-color: rgba(59,130,246,0.6); }
.pv2-sel:hover { border-color: rgba(255,255,255,0.28); }
.pv2-sel option { background: #1e293b; color: #e2e8f0; }

/* Desktop-Zeile 2: Preset-Select + Status-Select + Legacy-Chip-Container */
.pv2-desk-select-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0 4px;
  flex-wrap: wrap;
}
/* Desktop-Selects in Reihe 2 – volle Breite ohne Legacy-Chips */
.pv2-sel-desk {
  min-width: 160px;
  flex-shrink: 0;
}

/* Legacy-Chip-Wrapper: auf Desktop nicht mehr angezeigt (V109) */
.pv2-desk-chip-legacy { display: none !important; }

/* ── V108: Mobile ActionBar (ausgeblendet auf Desktop) ───────────────────── */
.pv2-mob-actionbar { display: none; }

/* ── V108: Mobile-Toolbar aus V107 (nicht mehr genutzt, sicherheitshalber ausgeblendet) ── */
.pv2-mobile-toolbar { display: none; }

/* ---- Progress Bar ---- */
.pv2-progress-wrap {
  margin: 16px 0 20px;
}

.pv2-progress-label {
  display: flex;
  gap: 12px;
  font-size: 13px;
  color: #94a3b8;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.pv2-prog-subtask { color: #64748b; }
.pv2-prog-time { color: #64748b; }

.pv2-progress-bar-bg {
  height: 6px;
  background: rgba(255,255,255,0.07);
  border-radius: 3px;
  overflow: hidden;
}

.pv2-progress-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.4s ease;
  min-width: 2px;
}

/* ---- Focus Banner ---- */
.pv2-focus-banner {
  background: rgba(239,68,68,0.1);
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: 8px;
  padding: 8px 16px;
  font-size: 13px;
  color: #f87171;
  margin-bottom: 16px;
  text-align: center;
}

/* ---- Sections ---- */
.pv2-section {
  margin-bottom: 32px;
}

.pv2-section-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.pv2-section-icon { font-size: 18px; }

.pv2-section-title {
  font-size: 17px;
  font-weight: 700;
  color: #f1f5f9;
  margin: 0;
  flex: 1;
}

.pv2-section-actions {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}

/* ---- Cockpit ---- */
.pv2-cockpit {
  background: rgba(15,23,42,0.6);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 14px;
  padding: 16px 18px;
}

.pv2-cockpit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.pv2-cockpit-group {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  padding: 12px 14px;
}

.pv2-cockpit-group-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #64748b;
  margin-bottom: 8px;
}
.pv2-label-red { color: #f87171 !important; }

.pv2-cockpit-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 13px;
}
.pv2-cockpit-row:last-child { border-bottom: none; }
.pv2-cockpit-overdue .pv2-cockpit-link { color: #f87171; }
.pv2-cockpit-info { color: #64748b; }

.pv2-cockpit-icon { font-size: 14px; flex-shrink: 0; }
.pv2-cockpit-link { color: #93c5fd; text-decoration: none; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pv2-cockpit-link:hover { text-decoration: underline; }
.pv2-cockpit-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: #cbd5e1; }
.pv2-cockpit-parent { color: #475569; font-size: 11px; flex-shrink: 0; }
.pv2-cockpit-date { color: #64748b; font-size: 11px; flex-shrink: 0; }
.pv2-cockpit-qa { color: #3b82f6; text-decoration: none; font-size: 14px; flex-shrink: 0; padding: 0 4px; }

/* ---- Items Grid ---- */
.pv2-grid {
  display: grid;
  gap: 14px;
  margin-bottom: 28px;
}
.pv2-grid-1 { grid-template-columns: 1fr; }
.pv2-grid-2 { grid-template-columns: repeat(2, 1fr); }
.pv2-grid-3 { grid-template-columns: repeat(3, 1fr); }

@media (max-width: 900px) { .pv2-grid-2, .pv2-grid-3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .pv2-grid-1, .pv2-grid-2, .pv2-grid-3 { grid-template-columns: 1fr; } }

/* ---- Item Card ---- */
.pv2-item-card {
  background: rgba(15,23,42,0.85);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px;
  overflow: hidden;
  transition: all 0.15s ease;
}
.pv2-item-card:hover { border-color: rgba(255,255,255,0.14); transform: translateY(-1px); box-shadow: 0 4px 20px rgba(0,0,0,0.3); }
.pv2-card-done { opacity: 0.55; border-color: rgba(34,197,94,0.15); }
.pv2-card-overdue { border-color: rgba(239,68,68,0.3) !important; background: rgba(239,68,68,0.04) !important; }
.pv2-card-critical { border-color: rgba(249,115,22,0.25) !important; }
.pv2-card-compact { border-radius: 8px; }

.pv2-card-header {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px 8px;
}

.pv2-status-toggle {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: transparent;
  border: 2px solid;
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s ease;
  margin-top: 2px;
}
.pv2-status-toggle:hover { opacity: 0.7; transform: scale(1.1); }

.pv2-card-title-group {
  flex: 1;
  min-width: 0;
}

.pv2-card-title {
  font-size: 14px;
  font-weight: 600;
  color: #f1f5f9;
  text-decoration: none;
  display: block;
  margin-bottom: 6px;
  line-height: 1.35;
}
.pv2-card-title:hover { color: #93c5fd; text-decoration: underline; }
.pv2-card-done .pv2-card-title { text-decoration: line-through; color: #64748b; }

.pv2-card-badges {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}

.pv2-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  white-space: nowrap;
}
.pv2-badge-sub { background: rgba(100,116,139,0.15); color: #94a3b8; border: 1px solid rgba(100,116,139,0.2); }
.pv2-badge-time { background: rgba(100,116,139,0.1); color: #64748b; border: 1px solid rgba(100,116,139,0.15); }
.pv2-badge-overdue { background: rgba(239,68,68,0.15); color: #f87171; border: 1px solid rgba(239,68,68,0.25); }

.pv2-card-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}

.pv2-card-due {
  font-size: 11px;
  color: #64748b;
  white-space: nowrap;
}
.pv2-card-due.overdue { color: #f87171; font-weight: 600; }

.pv2-collapse-btn {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 4px;
  color: #64748b;
  cursor: pointer;
  font-size: 10px;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s ease;
}
.pv2-collapse-btn:hover { background: rgba(255,255,255,0.1); color: #94a3b8; }

.pv2-card-body {
  padding: 0 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pv2-card-content-preview {
  font-size: 12px;
  color: #64748b;
  line-height: 1.5;
  border-left: 2px solid rgba(255,255,255,0.06);
  padding-left: 8px;
}

.pv2-card-subtasks { display: flex; flex-direction: column; gap: 3px; }

.pv2-card-subtask {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: #94a3b8;
  padding: 3px 0;
}
.pv2-card-subtask.done { color: #475569; text-decoration: line-through; }
.pv2-subtask-check { font-size: 11px; flex-shrink: 0; color: #64748b; }
.pv2-subtask-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pv2-subtask-link { color: #3b82f6; text-decoration: none; font-size: 12px; padding: 0 4px; flex-shrink: 0; }

.pv2-card-att-row { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.pv2-att-thumb { width: 44px; height: 44px; object-fit: cover; border-radius: 6px; border: 1px solid rgba(255,255,255,0.08); cursor: pointer; }
.pv2-att-icon { font-size: 22px; text-decoration: none; }
.pv2-att-more { font-size: 11px; color: #64748b; }

.pv2-card-meta-row { display: flex; gap: 6px; flex-wrap: wrap; }
.pv2-meta-tag { font-size: 11px; color: #64748b; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); border-radius: 4px; padding: 2px 7px; }
.pv2-tag-resurface { color: #818cf8; }

.pv2-more { font-size: 10px; color: #d4af37; }

.pv2-empty {
  text-align: center;
  padding: 40px;
  color: #475569;
  font-size: 15px;
  grid-column: 1 / -1;
}

/* ---- Notes Section ---- */
.pv2-notes-section {
  background: rgba(15,23,42,0.5);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 16px 18px;
}

.pv2-note-sort-btn {
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 11px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
  color: #64748b;
  cursor: pointer;
  transition: all 0.15s ease;
}
.pv2-note-sort-btn.active { background: rgba(212,175,55,0.15); border-color: rgba(212,175,55,0.3); color: #d4af37; }
.pv2-note-sort-btn:hover { background: rgba(255,255,255,0.08); color: #94a3b8; }

.pv2-notes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
  max-height: 420px;
  overflow-y: auto;
  padding-right: 4px;
}
.pv2-notes-grid::-webkit-scrollbar { width: 4px; }
.pv2-notes-grid::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }

.pv2-note-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  padding: 12px 14px;
  transition: all 0.15s ease;
  position: relative;
}
.pv2-note-card:hover { border-color: rgba(255,255,255,0.12); }
.pv2-note-card.pinned { border-color: rgba(212,175,55,0.35); background: rgba(212,175,55,0.06); }

.pv2-note-header { display: flex; align-items: flex-start; gap: 8px; margin-bottom: 7px; }
.pv2-note-title { font-size: 13px; font-weight: 600; color: #93c5fd; text-decoration: none; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pv2-note-title:hover { text-decoration: underline; }
.pv2-pin-btn { background: transparent; border: none; cursor: pointer; font-size: 14px; opacity: 0.4; transition: all 0.15s ease; flex-shrink: 0; padding: 0; }
.pv2-pin-btn:hover, .pv2-pin-btn.active { opacity: 1; }

.pv2-note-text { font-size: 12px; color: #64748b; line-height: 1.5; margin-bottom: 8px; }
.pv2-note-footer { }
.pv2-note-date { font-size: 10px; color: #334155; }

/* ---- Gallery Section ---- */
.pv2-gallery-section {
  background: rgba(15,23,42,0.5);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 16px 18px;
}

.pv2-att-filter-btn {
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 11px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
  color: #64748b;
  cursor: pointer;
  transition: all 0.15s ease;
}
.pv2-att-filter-btn.active { background: rgba(59,130,246,0.18); border-color: rgba(59,130,246,0.35); color: #93c5fd; }
.pv2-att-filter-btn:hover { background: rgba(255,255,255,0.08); color: #94a3b8; }

.pv2-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 10px;
}

.pv2-gallery-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-radius: 8px;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  transition: all 0.15s ease;
}
.pv2-gallery-item:hover { border-color: rgba(255,255,255,0.14); }

.pv2-gallery-link { display: block; }
.pv2-gallery-thumb { width: 100%; height: 80px; object-fit: cover; display: block; }
.pv2-gallery-icon-wrap { display: flex; align-items: center; justify-content: center; height: 80px; }
.pv2-gallery-icon { font-size: 32px; }

.pv2-gallery-caption {
  padding: 4px 6px 6px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pv2-gallery-name { font-size: 10px; color: #94a3b8; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pv2-gallery-parent { font-size: 9px; color: #475569; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---- Generator Section ---- */
.pv2-generator-section {
  background: rgba(212,175,55,0.05);
  border: 1px solid rgba(212,175,55,0.15);
  border-radius: 14px;
  padding: 16px 18px;
}

.pv2-generator-info { font-size: 13px; color: #78716c; line-height: 1.5; }

/* =============================================================================
   @MEDIA PRINT - Projektmappe V2
   ============================================================================= */
@media print {
  /* Verstecke alles außer V2 Print-Inhalt */
  .pv2-sticky-header { display: none !important; }
  .pv2-page-wrap { background: #fff !important; color: #111 !important; }
  .pv2-page-body { padding: 0 !important; max-width: 100% !important; }
  
  /* Alle Cards expanded (wichtig: collapse ignorieren) */
  .pv2-card-body { display: flex !important; }
  .pv2-collapse-btn, .pv2-pin-btn, .pv2-gen-btn { display: none !important; }
  .pv2-status-toggle { border-color: #333 !important; color: #333 !important; }
  
  /* Grid: 1 Spalte, alle Cards sichtbar */
  .pv2-grid, .pv2-grid-1, .pv2-grid-2, .pv2-grid-3 {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  
  .pv2-item-card {
    background: #fff !important;
    border: 1px solid #ddd !important;
    border-radius: 6px !important;
    page-break-inside: avoid;
    break-inside: avoid;
    box-shadow: none !important;
    transform: none !important;
  }
  .pv2-card-done { opacity: 1 !important; }
  
  /* Farbanpassungen Print */
  .pv2-card-title { color: #111 !important; }
  .pv2-card-content-preview { color: #444 !important; border-left-color: #ccc !important; }
  .pv2-card-subtask { color: #444 !important; }
  .pv2-badge { color: #333 !important; border-color: #ccc !important; }
  
  /* Cockpit kompakter Print */
  .pv2-cockpit { background: #f9f9f9 !important; border-color: #ddd !important; page-break-inside: avoid; }
  .pv2-cockpit-group { background: #fff !important; }
  .pv2-cockpit-text, .pv2-cockpit-parent { color: #333 !important; }
  
  /* Progress + Notes + Gallery: kompakter */
  .pv2-notes-grid { grid-template-columns: repeat(2, 1fr) !important; max-height: none !important; }
  .pv2-gallery-grid { grid-template-columns: repeat(4, 1fr) !important; }
  .pv2-note-card { background: #f9f9f9 !important; border-color: #ddd !important; page-break-inside: avoid; }
  .pv2-note-text, .pv2-note-title { color: #333 !important; }
  
  /* Seitenumbruch nach Sections */
  .pv2-cockpit, .pv2-notes-section, .pv2-gallery-section { page-break-before: auto; }
  .pv2-generator-section { display: none !important; }
  
  /* Subtask-Tabelle (kompakt) */
  .pv2-card-subtasks {
    font-size: 11px !important;
  }
  
  /* keine Navigation drucken */
  .nav, header, .drawer-backdrop, .toast, #boot { display: none !important; }
}

/* ============================================================= */
/* V2 Responsive Overrides - V108                                */
/* ============================================================= */

/* ── Tablet (769px – 1023px): Leicht kompaktere Desktop-Ansicht ── */
@media (max-width: 1023px) {
  /* Desktop-Header ausblenden, Mobile-ActionBar einblenden */
  .pv2-header-top   { display: none !important; }
  .pv2-desk-select-row { display: none !important; }
  .pv2-mob-actionbar {
    display: flex !important;
    flex-direction: column;
    gap: 8px;
    /* 4vw seitlicher Innenabstand (mobile) */
    padding: 10px 4vw 8px;
    width: 100%;
    box-sizing: border-box;
  }

  /* Sticky-Header: Padding via mob-actionbar, kein doppeltes Padding */
  .pv2-sticky-header {
    padding: 0 !important;
    overflow-x: hidden;
  }

  /* Zeile 1: Icon + Name + Badges (eine Zeile, kein Umbruch) */
  .pv2-mob-row1 {
    display: flex;
    align-items: center;
    gap: 7px;
    flex-wrap: nowrap;
    overflow: hidden;
    min-height: 32px;
  }
  .pv2-mob-cat-icon {
    font-size: 22px;
    line-height: 1;
    flex-shrink: 0;
  }
  .pv2-mob-cat-name {
    font-size: 16px;
    font-weight: 700;
    color: #f1f5f9;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1 1 auto;
    min-width: 0;
  }
  .pv2-mob-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 9px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
    flex-shrink: 0;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    color: #94a3b8;
  }

  /* Zeile 2 + 3: 2-Spalten-Grid */
  .pv2-mob-grid2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    width: 100%;
  }

  /* Alle Selects im Mobile-ActionBar: gleiches Aussehen */
  .pv2-mob-actionbar .pv2-sel {
    width: 100%;
    font-size: 13px;
    padding: 8px 10px;
    min-height: 40px;
    border-radius: 9px;
  }

  /* Seitenbreite Einschränkung */
  .pv2-page-body {
    padding: 12px 4vw calc(var(--nav-h) + 20px);
    max-width: 100%;
    box-sizing: border-box;
  }
}

/* ── Mobile klein (≤480px): Kompaktere Variante ── */
@media (max-width: 480px) {
  .pv2-mob-cat-name { font-size: 14px; }
  .pv2-mob-cat-icon { font-size: 19px; }
  .pv2-mob-badge    { font-size: 10px; padding: 2px 7px; }

  .pv2-mob-actionbar .pv2-sel {
    font-size: 12px;
    padding: 7px 8px;
    min-height: 38px;
  }
  .pv2-mob-grid2 { gap: 5px; }
  .pv2-mob-actionbar { gap: 6px; padding: 8px 4vw 6px; }

  /* Grid 1-Spalte für Karten */
  .pv2-cockpit-grid { grid-template-columns: 1fr; }
  .pv2-notes-grid   { grid-template-columns: 1fr; }
  .pv2-gallery-grid { grid-template-columns: repeat(2, 1fr); }

  /* Karten kompakter */
  .pv2-card-header { padding: 9px 10px 5px; }
  .pv2-card-body   { padding: 0 10px 10px; }
  .pv2-item-title  { font-size: 13px; }
  .pv2-page-body   { padding: 10px 4vw calc(var(--nav-h) + 16px); }
}

/* ── Desktop (≥1024px): 2vw Seitenabstand, nur Select-Toolbar (V109) ── */
@media (min-width: 1024px) {
  /* Desktop-Header wieder einblenden */
  .pv2-header-top { display: flex !important; }
  .pv2-desk-select-row { display: flex !important; }
  /* Mobile-ActionBar sicher ausblenden */
  .pv2-mob-actionbar { display: none !important; }

  /* 2vw Seitenabstand – Header bereits durch padding:10px 2vw */
  .pv2-page-body {
    padding: 16px 2vw calc(var(--nav-h) + 24px);
    max-width: 1400px;
    margin: 0 auto;
    box-sizing: border-box;
  }
}


/* ===== V110: STATISTIK-SEITE REDESIGN – Dark UI, Responsive Grid, KPI Cards ===== */

/* Page Layout */
.stats-page-v110{
  padding: 12px 14px 32px;
  max-width: 1200px;
  margin: 0 auto;
}
.stats-page-header{
  margin-bottom: 14px;
}
.stats-page-title{
  margin: 0 0 4px 0;
  font-size: 22px;
  font-weight: 700;
  color: var(--primary);
}
.stats-page-meta{
  font-size: 11px;
  opacity: .55;
}

/* ---- Filter Bar ---- */
.stats-filter-bar{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px 12px;
  margin-bottom: 14px;
}
.stats-filter-row{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.stats-filter-label{
  font-size: 11px;
  font-weight: 600;
  opacity: .7;
  white-space: nowrap;
}
.stats-filter-select{
  font-size: 12px;
  padding: 5px 8px;
  min-width: 100px;
  max-width: 160px;
}
.stats-filter-reset{
  font-size: 12px;
  padding: 5px 10px;
  background: rgba(239,68,68,.15);
  border-color: rgba(239,68,68,.3);
  color: #ef4444;
  margin-left: auto;
}
.stats-filter-reset:hover{ background: rgba(239,68,68,.25); }
@media (max-width: 520px){
  .stats-filter-row{ flex-direction: column; align-items: stretch; }
  .stats-filter-select{ max-width: 100%; }
  .stats-filter-reset{ margin-left: 0; }
}

/* ---- KPI Cards Grid ---- */
.stats-kpi-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}
@media (max-width: 768px){
  .stats-kpi-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 420px){
  .stats-kpi-grid{ grid-template-columns: 1fr 1fr; gap: 8px; }
}

.stats-kpi-card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px 12px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  transition: background .15s, transform .1s;
  position: relative;
  overflow: hidden;
}
.stats-kpi-card::before{
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, #3b82f6, #6366f1);
  opacity: 0;
  transition: opacity .2s;
}
.stats-kpi-card.clickable{ cursor: pointer; }
.stats-kpi-card.clickable:hover{ background: var(--card-hover); transform: translateY(-1px); }
.stats-kpi-card.clickable:hover::before{ opacity: 1; }
.stats-kpi-icon{
  font-size: 22px;
  flex-shrink: 0;
  margin-top: 2px;
}
.stats-kpi-main{
  flex: 1;
  min-width: 0;
}
.stats-kpi-value{
  font-size: 24px;
  font-weight: 700;
  line-height: 1.1;
  color: var(--primary);
}
.stats-kpi-label{
  font-size: 11px;
  opacity: .65;
  margin-top: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.stats-kpi-side{
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  flex-shrink: 0;
}
.stats-kpi-sub{
  font-size: 11px;
  opacity: .7;
  white-space: nowrap;
}
.stats-kpi-trend{
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

/* ---- Responsive Grid 2-col for Charts ---- */
.stats-grid-2col{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 14px;
}
@media (max-width: 768px){
  .stats-grid-2col{ grid-template-columns: 1fr; }
}

/* ---- Chart Cards ---- */
.stats-chart-card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 14px 14px 16px;
}
.stats-chart-card-title{
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

/* ---- Bar Chart ---- */
.stats-bar-chart{
  display: flex;
  align-items: flex-end;
  justify-content: space-around;
  height: 90px;
  gap: 4px;
}
.stats-bar-col{
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  height: 100%;
  gap: 3px;
}
.stats-bar-value{
  font-size: 10px;
  opacity: .7;
  height: 14px;
  line-height: 14px;
}
.stats-bar-track{
  flex: 1;
  width: 100%;
  max-width: 28px;
  background: rgba(255,255,255,.06);
  border-radius: 4px 4px 0 0;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.stats-bar-fill{
  width: 100%;
  border-radius: 4px 4px 0 0;
  min-height: 4px;
  transition: height .3s ease;
}
.stats-bar-label{
  font-size: 10px;
  opacity: .6;
  text-align: center;
}

/* ---- Donut Chart ---- */
.stats-donut-container{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.stats-donut-svg{
  width: 110px;
  height: 110px;
  flex-shrink: 0;
  transform: rotate(-90deg);
}
.stats-donut-legend{
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.stats-donut-legend-item{
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
}
.stats-donut-dot{
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ---- Category Progress ---- */
.stats-cat-progress-list{
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.stats-cat-progress-item{}
.stats-cat-progress-header{
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  margin-bottom: 4px;
}
.stats-cat-progress-name{
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 65%;
}
.stats-cat-progress-pct{
  opacity: .65;
  white-space: nowrap;
  font-size: 11px;
}
.stats-cat-progress-bar{
  height: 7px;
  background: rgba(255,255,255,.08);
  border-radius: 4px;
  overflow: hidden;
}
.stats-cat-progress-fill{
  height: 100%;
  border-radius: 4px;
  transition: width .4s ease;
  min-width: 2px;
}

/* ---- Trend Card ---- */
.stats-trend-row{
  display: flex;
  align-items: center;
  justify-content: space-around;
  gap: 12px;
  margin: 4px 0 6px;
  flex-wrap: wrap;
}
.stats-trend-box{
  text-align: center;
}
.stats-trend-label{
  font-size: 11px;
  opacity: .6;
  margin-bottom: 4px;
}
.stats-trend-val{
  font-size: 20px;
  font-weight: 700;
}
.stats-trend-arrow{
  font-size: 36px;
  line-height: 1;
  flex-shrink: 0;
}
.stats-trend-delta{
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  margin: 4px 0 2px;
}
.stats-trend-sublabel{
  font-size: 10px;
  opacity: .5;
  text-align: center;
}

/* ---- Insights ---- */
.stats-insights-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
@media (max-width: 420px){
  .stats-insights-grid{ grid-template-columns: 1fr; }
}
.stats-insight-item{
  display: flex;
  align-items: flex-start;
  gap: 8px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
}
.stats-insight-icon{
  font-size: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}
.stats-insight-body{}
.stats-insight-label{
  font-size: 10px;
  opacity: .6;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.stats-insight-val{
  font-size: 13px;
  font-weight: 600;
  margin-top: 3px;
  color: var(--primary);
}

/* ---- Goals ---- */
.stats-goals-list{
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}
.stats-goal-item{
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  transition: background .15s;
}
.stats-goal-item:hover{ background: rgba(255,255,255,.07); }
.stats-goal-header{
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 6px;
}
.stats-goal-title{
  font-weight: 600;
  font-size: 14px;
}
.stats-goal-period{
  font-size: 11px;
  opacity: .6;
}
.stats-goal-progress-bar{
  height: 8px;
  background: rgba(255,255,255,.08);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 5px;
}
.stats-goal-progress-fill{
  height: 100%;
  border-radius: 4px;
  transition: width .4s ease;
  min-width: 3px;
}
.stats-goal-footer{
  font-size: 11px;
  opacity: .65;
}
.stats-goals-empty{
  margin-bottom: 14px;
}

/* ---- Drilldown ---- */
.stats-drilldown-section{ margin-bottom: 8px; }
.stats-drilldown-label{
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  opacity: .6;
  padding: 4px 8px;
}
.stats-drilldown-item{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  color: var(--primary);
  text-decoration: none;
}
a.stats-drilldown-item:hover{ background: rgba(255,255,255,.04); }
.stats-drilldown-item.done-item{ opacity: .6; }

/* ---- Link Popup ---- */
.stats-link-row{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
}
.stats-link-info{ flex: 1; min-width: 0; }
.stats-link-url{
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #60a5fa;
}
.stats-link-source{
  font-size: 11px;
  opacity: .55;
  margin-top: 2px;
}
.stats-link-actions{
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.btn-icon{
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 5px 7px;
  cursor: pointer;
  font-size: 13px;
  color: var(--primary);
  text-decoration: none;
  line-height: 1;
  display: inline-flex;
  align-items: center;
}
.btn-icon:hover{ background: rgba(255,255,255,.07); }

/* ---- Export Buttons ---- */
.stats-export-buttons{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

/* ---- Hints ---- */
.stats-hint{
  font-size: 11px;
  opacity: .6;
  padding: 6px 12px;
  font-style: italic;
}

/* ---- Btn-sm ---- */
.btn-sm{
  padding: 4px 10px;
  font-size: 12px;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--primary);
  cursor: pointer;
}
.btn-sm:hover{ background: rgba(255,255,255,.08); }

/* Dark mode overrides for stats */
@media (max-width: 1023px) {
  .stats-kpi-card{ background: rgba(15,23,42,0.85); }
  .stats-chart-card{ background: rgba(15,23,42,0.85); }
  .stats-insight-item{ background: rgba(255,255,255,.04); }
  .stats-goal-item{ background: rgba(255,255,255,.03); }
}
@media (min-width: 1024px){
  body[data-theme="dark"] .stats-kpi-card{ background: rgba(15,23,42,0.85); }
  body[data-theme="dark"] .stats-chart-card{ background: rgba(15,23,42,0.85); }
}

/* Ensure stats page has a dark bg canvas */
.stats-page-v110{ background: transparent; }

/* Print-safe: minimal */
@media print{
  .stats-filter-bar, .stats-export-buttons, .stats-filter-reset{ display: none; }
  .stats-kpi-grid{ grid-template-columns: repeat(3,1fr); }
  .stats-grid-2col{ grid-template-columns: 1fr 1fr; }
}


/* ---------- V110.1 Projektmappe UI ---------- */
.btn-chip{padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);color:#fff;font-weight:800;cursor:pointer;}
.btn-chip:hover{background:rgba(255,255,255,.18);}
.btn-mini{padding:4px 8px;border-radius:10px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.12);color:#fff;cursor:pointer;font-weight:800;}
.btn-mini:hover{background:rgba(255,255,255,.18);}
.project-title-h1{text-align:center;font-weight:900;margin:10px 0 6px;color:var(--primary);letter-spacing:.2px;}
.folder-tiles-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:10px 0;}
@media (min-width: 720px){.folder-tiles-grid{grid-template-columns:repeat(4,minmax(0,1fr));}}
.folder-tile{border-radius:14px;padding:14px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.18);}
.folder-tile:hover{transform:translateY(-1px);}
.folder-tile-icon{font-size:22px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25));}
/* V199: hyphens+break-word statt break-all; JS setzt font-size inline */
.folder-tile-title{color:#fff;font-weight:900;font-size:13px;line-height:1.2;overflow-wrap:break-word;hyphens:auto;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.folder-panel{margin-top:10px;border-radius:14px;padding:12px;background:var(--card);border:1px solid var(--border);}
.folder-item-row{margin-top:10px;padding:10px;border-radius:12px;border:1px solid var(--border);background:rgba(15,23,42,.04);cursor:pointer;}
.thumb-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.thumb{width:64px;height:64px;object-fit:cover;border-radius:12px;border:1px solid var(--border);cursor:pointer;}
.modal-gallery{max-width:920px;}
.gallery-image{width:100%;max-height:70vh;object-fit:contain;border-radius:14px;border:1px solid rgba(0,0,0,.12);background:rgba(0,0,0,.06);}
.timeline-title{text-align:center;font-weight:900;color:var(--primary);opacity:.9;margin:8px 0 8px;}
.timeline-wrap{border-radius:14px;border:1px solid var(--border);background:var(--card);overflow:auto;padding:10px;max-height:520px;}
.timeline-row{display:flex;gap:10px;min-height:320px;}
.timeline-day{min-width:240px;max-width:320px;border-radius:14px;border:1px solid var(--border);background:var(--bg);padding:10px;display:flex;flex-direction:column;gap:8px;}
.timeline-day-title{font-weight:900;color:var(--primary);opacity:.95;font-size:13px;}
.timeline-day-top,.timeline-day-bottom{display:flex;flex-direction:column;gap:6px;}
.timeline-divider{height:1px;background:var(--border);margin:6px 0;}
.timeline-item{display:flex;gap:8px;align-items:flex-start;padding:6px 8px;border-radius:12px;background:rgba(15,23,42,.04);border:1px solid var(--border);cursor:pointer;}
.timeline-item:hover{background:rgba(15,23,42,.06);}
.timeline-icon{width:18px;flex:0 0 18px;margin-top:1px;}
.timeline-text{color:var(--primary);font-weight:700;font-size:12px;line-height:1.2;}

/* V110.3 Project dates */
.project-dates-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:6px 0 10px;}
.project-date-frame{padding:8px 12px;border-radius:12px;font-weight:900;font-size:12px;letter-spacing:.2px;box-shadow:0 8px 18px rgba(0,0,0,.10);}
.project-date-start{background:#16a34a;color:#fff;}
.project-date-end{background:#dc2626;color:#fff;}


/* --- V110.4: Projektmappe Desktop hell/dunkel Anpassungen + Timeline Achse --- */
.projektmappe-label{display:block;font-weight:600;margin-bottom:6px;color:var(--primary);}

.timeline-row{position:relative;}
.timeline-axis-line{position:absolute;left:10px;right:10px;top:152px;height:3px;background:rgba(100,116,139,.35);border-radius:999px;pointer-events:none;}
.timeline-divider{height:3px;background:rgba(100,116,139,.35);margin:8px 0;border-radius:999px;}

.timeline-folder-badge{display:inline-flex;align-items:center;gap:6px;margin-left:8px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:900;color:#fff;line-height:1;white-space:nowrap;box-shadow:0 6px 16px rgba(0,0,0,.12);}

@media (min-width: 900px){
  /* Desktop: heller Hintergrund → dunkle Schrift in Projektmappen-Ansicht */
  .project-title-h1{color:#0f172a;}
  .projektmappe-label{color:#0f172a;}
  .projektmappe-section .small, .projektmappe-section label, .projektmappe-section .timeline-title{color:#0f172a !important;}
  .timeline-day-title{color:#0f172a;}
  .btn-chip{background:transparent;color:#0f172a;border:1px solid #334155;}
  .btn-chip.btn-primary{background:transparent;color:#0f172a;border:1px solid #334155;}
  .btn-chip:hover{background:rgba(15,23,42,.06);}
}


/* ===== V138: Projektmappen-Styles aus v122 ===== */
.project-title-h1{text-align:center;font-weight:900;margin:10px 0 6px;color:var(--primary);letter-spacing:.2px;}
.folder-tiles-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:10px 0;}
@media (min-width: 720px){.folder-tiles-grid{grid-template-columns:repeat(4,minmax(0,1fr));}}
.folder-tile{border-radius:14px;padding:14px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.18);}
.folder-tile:hover{transform:translateY(-1px);}
.folder-tile-icon{font-size:22px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25));}
/* V199: hyphens+break-word statt break-all; JS setzt font-size inline */
.folder-tile-title{color:#fff;font-weight:900;font-size:13px;line-height:1.2;overflow-wrap:break-word;hyphens:auto;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.folder-panel{margin-top:10px;border-radius:14px;padding:12px;background:var(--card);border:1px solid var(--border);}
.folder-item-row{margin-top:10px;padding:10px;border-radius:12px;border:1px solid var(--border);background:rgba(15,23,42,.04);cursor:pointer;}
.thumb-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.thumb{width:64px;height:64px;object-fit:cover;border-radius:12px;border:1px solid var(--border);cursor:pointer;}
.modal-gallery{max-width:920px;}
.gallery-image{width:100%;max-height:70vh;object-fit:contain;border-radius:14px;border:1px solid rgba(0,0,0,.12);background:rgba(0,0,0,.06);}
.timeline-title{text-align:center;font-weight:900;color:var(--primary);opacity:.9;margin:8px 0 8px;}
.timeline-wrap{border-radius:14px;border:1px solid var(--border);background:var(--card);overflow:auto;padding:10px;max-height:520px;}
.timeline-row{display:flex;gap:10px;min-height:320px;}
.timeline-day{min-width:240px;max-width:320px;border-radius:14px;border:1px solid var(--border);background:var(--bg);padding:10px;display:flex;flex-direction:column;gap:8px;}
.timeline-day-title{font-weight:900;color:var(--primary);opacity:.95;font-size:13px;}
.timeline-day-top,.timeline-day-bottom{display:flex;flex-direction:column;gap:6px;}
.timeline-divider{height:1px;background:var(--border);margin:6px 0;}
.timeline-item{display:flex;gap:8px;align-items:flex-start;padding:6px 8px;border-radius:12px;background:rgba(15,23,42,.04);border:1px solid var(--border);cursor:pointer;}
.timeline-item:hover{background:rgba(15,23,42,.06);}
.timeline-icon{width:18px;flex:0 0 18px;margin-top:1px;}
.timeline-text{color:var(--primary);font-weight:700;font-size:12px;line-height:1.2;}

/* V110.3 Project dates */
.project-dates-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:6px 0 10px;}
.project-date-frame{padding:8px 12px;border-radius:12px;font-weight:900;font-size:12px;letter-spacing:.2px;box-shadow:0 8px 18px rgba(0,0,0,.10);}
.project-date-start{background:#16a34a;color:#fff;}
.project-date-end{background:#dc2626;color:#fff;}


/* --- V110.4: Projektmappe Desktop hell/dunkel Anpassungen + Timeline Achse --- */
.projektmappe-label{display:block;font-weight:600;margin-bottom:6px;color:var(--primary);}

.timeline-row{position:relative;}
.timeline-axis-line{position:absolute;left:10px;right:10px;top:152px;height:3px;background:rgba(100,116,139,.35);border-radius:999px;pointer-events:none;}
.timeline-divider{height:3px;background:rgba(100,116,139,.35);margin:8px 0;border-radius:999px;}

.timeline-folder-badge{display:inline-flex;align-items:center;gap:6px;margin-left:8px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:900;color:#fff;line-height:1;white-space:nowrap;box-shadow:0 6px 16px rgba(0,0,0,.12);}

@media (min-width: 900px){
  /* Desktop: heller Hintergrund → dunkle Schrift in Projektmappen-Ansicht */
  .project-title-h1{color:#0f172a;}
  .projektmappe-label{color:#0f172a;}
  .projektmappe-section .small, .projektmappe-section label, .projektmappe-section .timeline-title{color:#0f172a !important;}
  .timeline-day-title{color:#0f172a;}
  .btn-chip{background:transparent;color:#0f172a;border:1px solid #334155;}
  .btn-chip.btn-primary{background:transparent;color:#0f172a;border:1px solid #334155;}
  .btn-chip:hover{background:rgba(15,23,42,.06);}
}

/* ===== V111: New Features ===== */

/* Project badge in category item list */
.item-project-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:999px;
  font-size:11px;font-weight:800;color:#fff;
  white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.item-project-badge-icon{font-size:12px;}
.item-project-badge-text{letter-spacing:.2px;}

/* Horizontal Project Progress Line */
.pm-progress-wrap{margin:8px 0 14px;padding:8px 0;}
.pm-progress-labels{display:flex;justify-content:space-between;margin-bottom:6px;}
.pm-progress-label-start{font-size:12px;font-weight:900;padding:4px 10px;border-radius:8px;background:#16a34a;color:#fff;}
.pm-progress-label-end{font-size:12px;font-weight:900;padding:4px 10px;border-radius:8px;background:#dc2626;color:#fff;}
.pm-progress-track{position:relative;height:8px;background:rgba(100,116,139,.3);border-radius:999px;overflow:visible;}
.pm-progress-fill{height:100%;background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:999px;transition:width .5s ease;min-width:4px;}
.pm-progress-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid #22c55e;box-shadow:0 2px 8px rgba(0,0,0,.25);}
.pm-progress-pct{text-align:center;font-size:11px;opacity:.7;margin-top:5px;color:var(--primary);}

/* PM Timeline item checkbox */
.pm-item-check{
  cursor:pointer;font-size:16px;margin-right:4px;flex-shrink:0;
  transition:transform .15s;display:inline-block;
}
.pm-item-check:hover{transform:scale(1.2);}
.pm-item-check-done{color:#22c55e;}
.timeline-item-done .timeline-text{text-decoration:line-through;opacity:.55;}
.timeline-item-done{opacity:.75;}

/* PM thumbnail gallery inside timeline items */
.pm-thumb-gallery{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px;}
.pm-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;cursor:zoom-in;border:2px solid rgba(255,255,255,.2);transition:transform .15s;}
.pm-thumb:hover{transform:scale(1.1);}

/* Video/Audio attachment tiles */
.ep-att-video-thumb,.ep-att-audio-thumb{
  background:linear-gradient(135deg,#1e293b,#334155);
  color:#fff;font-size:28px;
}

/* Mobile color scheme for Projektmappe (match desktop) */
@media (max-width: 899px){
  .project-title-h1{color:var(--primary);}
  .projektmappe-label{color:var(--primary);}
  .projektmappe-section .timeline-title{color:var(--primary);}
  .timeline-day{background:#00387B !important;}
  .timeline-day-title{color:#90caf9 !important;}
  .btn-chip{
    background:#334155;
    color:#fff !important;
    border:1px solid #475569;
  }
  .btn-chip.btn-primary{
    background:#16a34a;
    color:#fff !important;
    border:1px solid #22c55e;
  }
  .pm-progress-pct{color:var(--primary);}
}

/* btn-danger for delete */
.btn-danger{background:#ef4444;color:#fff;border:none;}
.btn-danger:hover{background:#dc2626;}

/* Folder items in PM list also clickable */
.folder-item-row{cursor:pointer;}


/* ===== V112: Mobile Projektmappe colors, progress chart, gallery, list fixes ===== */

/* --- PM field labels: dark on light, light on dark --- */
.pm-field-label{
  display:block;font-weight:600;margin-bottom:6px;color:#0f172a;
}
@media (prefers-color-scheme: dark){
  .pm-field-label{ color:#f1f5f9; }
}
/* Mobile overrides for projektmappe */
@media (max-width:899px){
  .pm-field-label{ color:#0f172a; }
  .project-title-h1{ color:#0f172a !important; }
  .pm-section-title{ color:#0f172a !important; }
  .projektmappe-section .small,
  .projektmappe-section label{ color:#0f172a !important; }
  .pm-progress-label-start,.pm-progress-label-end{ font-size:11px; }
  .pm-progress-track{ background:rgba(15,23,42,.15); }
  .pm-progress-legend-label{ color:#0f172a; }
  /* Buttons light-themed */
  .pm-btn-chip{
    background:#f1f5f9;
    color:#0f172a;
    border:1px solid #cbd5e1;
    font-weight:700;
  }
  .pm-btn-chip:hover{ background:#e2e8f0; }
  .pm-btn-chip-blue{
    background:#dbeafe;
    color:#1d4ed8;
    border-color:#93c5fd;
  }
  .pm-btn-chip-green{
    background:#dcfce7;
    color:#15803d;
    border-color:#86efac;
  }
}
/* Desktop: keep btn-chip styling from existing rules, add semantic variants */
@media (min-width:900px){
  .pm-btn-chip{ color:#0f172a; background:transparent; border:1px solid #334155; }
  .pm-btn-chip-blue{ color:#1d4ed8; border-color:#93c5fd; background:rgba(59,130,246,.08); }
  .pm-btn-chip-green{ color:#15803d; border-color:#86efac; background:rgba(34,197,94,.08); }
}

/* --- Progress chart row --- */
.pm-progress-chart-row{
  display:flex;align-items:center;gap:14px;margin-top:10px;
  padding:8px 10px;border-radius:12px;
  background:rgba(0,0,0,.18);
}
@media (max-width:899px){
  .pm-progress-chart-row{ background:rgba(15,23,42,.07); }
}
.pm-progress-legend{ display:flex;flex-direction:column;gap:5px;flex:1; }
.pm-progress-legend-row{ display:flex;align-items:center;gap:7px; }
.pm-progress-legend-dot{ width:10px;height:10px;border-radius:50%;flex-shrink:0; }
.pm-progress-legend-label{ font-size:12px;color:#fff; }
@media (max-width:899px){
  .pm-progress-legend-label{ color:#0f172a; }
}

/* --- Timeline item date --- */
.timeline-item-date{
  font-size:10px;font-weight:600;
  color:rgba(255,255,255,.6);
  white-space:nowrap;margin-right:4px;
}

/* --- PM Gallery Modal (swipe, responsive) --- */
.pm-gallery-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9000;
  display:flex;align-items:center;justify-content:center;
  touch-action:pan-y;
}
.pm-gallery-modal{
  position:relative;max-width:min(92vw,700px);width:100%;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:16px;
}
.pm-gallery-close{
  position:absolute;top:0;right:0;
  background:rgba(255,255,255,.12);
  border:2px solid rgba(255,255,255,.35);
  border-radius:10px;
  color:#fff;font-size:18px;font-weight:900;
  width:40px;height:40px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  line-height:1;z-index:1;
}
.pm-gallery-close:hover{ background:rgba(255,255,255,.25); }
.pm-gallery-img-wrap{ width:100%;display:flex;justify-content:center; }
.pm-gallery-img{
  max-width:100%;max-height:70vh;
  border-radius:12px;object-fit:contain;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.pm-gallery-icon{ font-size:64px;color:rgba(255,255,255,.5); }
.pm-gallery-nav{
  display:flex;align-items:center;gap:14px;
}
.pm-gallery-nav-btn{
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;font-size:22px;font-weight:900;
  width:44px;height:44px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.pm-gallery-nav-btn:disabled{ opacity:.3;cursor:default; }
.pm-gallery-nav-btn:hover:not(:disabled){ background:rgba(255,255,255,.28); }
.pm-gallery-counter{ color:#fff;font-size:13px;opacity:.8; }
.pm-gallery-name{ color:rgba(255,255,255,.7);font-size:12px; }

/* --- Folder attachment badge --- */
.folder-att-badge{
  font-size:12px;opacity:.8;
}

/* --- Item attachment badge in list --- */
.item-att-badge{
  font-size:12px;padding:2px 5px;border-radius:4px;
  background:rgba(167,139,250,.2);
  color:#a78bfa;
}

/* --- List project sub-header (non-PM view) --- */
.list-project-subheader{
  display:flex;align-items:center;gap:7px;
  font-size:15px;font-weight:900;
  padding:10px 12px 6px;
  border-bottom:2px solid currentColor;
  margin:12px 0 2px;
  opacity:.95;
}
.list-project-subheader-icon{ font-size:16px; }

/* --- PM list project header colored --- */
.pm-list-project-header{ margin:14px 0 6px;font-weight:900;font-size:16px; }


/* === V113: SmartAssign Button ===*/
.smart-assign-btn{
  display:inline-flex;align-items:center;gap:4px;
  background:linear-gradient(135deg,#8b5cf6,#6366f1);
  color:#fff;border:none;border-radius:20px;
  padding:3px 10px;font-size:12px;font-weight:700;
  cursor:pointer;margin-top:5px;
  box-shadow:0 2px 6px rgba(99,102,241,.35);
  transition:transform .15s,box-shadow .15s;
}
.smart-assign-btn:hover{
  transform:scale(1.06);
  box-shadow:0 4px 12px rgba(99,102,241,.5);
}
.smart-assign-btn:active{ transform:scale(.97); }

/* === V113: SmartAssign Modal extra ===*/
.smart-assign-modal{ text-align:left; }

/* === V113: PM thumb fallback for broken images ===*/
.pm-thumb-broken{
  width:48px;height:48px;border-radius:6px;
  background:rgba(255,255,255,.08);border:2px dashed rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;cursor:pointer;opacity:.6;
}

/* === V113: Improved pm-thumb with error fallback ===*/
.pm-thumb{ background:rgba(0,0,0,.15); }

/* ===== V115: SmartButton Sammelliste ===== */
.pm-btn-chip-sammelliste{
  background:linear-gradient(135deg,#f97316,#fb923c);
  color:#fff;
  border:2px solid #fdba74;
  font-weight:800;
}
.pm-btn-chip-sammelliste:hover{ background:linear-gradient(135deg,#ea6c09,#f97316); }

/* ===== V115: SmartButton Drucken ===== */
.pm-btn-chip-print{
  background:linear-gradient(135deg,#0f172a,#1e293b);
  color:#e2e8f0;
  border:2px solid #475569;
  font-weight:800;
}
.pm-btn-chip-print:hover{ background:linear-gradient(135deg,#1e293b,#334155); }

/* ===== V115: Sammelliste Modal ===== */
.sammelliste-modal{
  position:fixed;top:0;right:0;bottom:0;
  width:min(460px,100vw);
  background:#0f172a;
  display:flex;flex-direction:column;
  z-index:2100;
  box-shadow:-8px 0 32px rgba(0,0,0,.5);
  overflow:hidden;
  animation:slideInRight .22s ease;
}
@keyframes slideInRight{
  from{transform:translateX(100%);}
  to{transform:translateX(0);}
}
.sammelliste-header{
  padding:14px 16px;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
}
.sammelliste-header-title{
  display:flex;align-items:center;
  color:#fff;
  flex:1;
}
.sammelliste-count-badge{
  background:rgba(255,255,255,.18);
  color:#fff;
  border-radius:12px;
  padding:2px 10px;
  font-size:12px;
  font-weight:700;
  white-space:nowrap;
}
.sammelliste-body{
  flex:1;overflow-y:auto;padding:12px;
  display:flex;flex-direction:column;gap:8px;
}
.sammelliste-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px;
  padding:10px 12px;
  cursor:pointer;
  transition:background .15s;
}
.sammelliste-card:hover{ background:rgba(255,255,255,.09); }
.sammelliste-card-done{ opacity:.5; }
.sammelliste-card-top{ display:flex;align-items:flex-start;gap:10px; }
.sammelliste-card-content{ flex:1; }
.sammelliste-card-title{
  font-size:14px;font-weight:700;color:#e2e8f0;
  line-height:1.4;margin-bottom:4px;
}
.sammelliste-done-text{ text-decoration:line-through;opacity:.6; }
.sammelliste-badges{
  display:flex;flex-wrap:wrap;align-items:center;gap:4px;margin-top:2px;
}
.sammelliste-check{
  font-size:18px;flex-shrink:0;cursor:pointer;
  line-height:1;padding-top:1px;
  user-select:none;
}
.sammelliste-check-done{ opacity:.7; }
.sammelliste-thumbs{
  display:flex;gap:4px;flex-wrap:wrap;margin-top:8px;
}
.sammelliste-thumb{
  width:44px;height:44px;object-fit:cover;
  border-radius:6px;cursor:zoom-in;
  border:2px solid rgba(255,255,255,.15);
  transition:transform .15s;
}
.sammelliste-thumb:hover{ transform:scale(1.08); }

/* V117: Bild-Thumbnails in Projektmappe-Listenseite (renderCategoryRow) */
.list-item-img-frame {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 8px;
  padding: 6px;
  background: rgba(0,0,0,.04);
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,.07);
}
.list-item-img-thumb {
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 6px;
  border: 1.5px solid rgba(0,0,0,.1);
  cursor: zoom-in;
  transition: transform .15s, box-shadow .15s;
  flex-shrink: 0;
}
.list-item-img-thumb:hover {
  transform: scale(1.08);
  box-shadow: 0 2px 8px rgba(0,0,0,.18);
  z-index: 2;
  position: relative;
}
.list-item-img-more {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: #f1f5f9;
  font-size: 12px;
  font-weight: 700;
  color: #64748b;
  border: 1.5px solid #e2e8f0;
  flex-shrink: 0;
}

/* V117: Bild-Thumbnails in Card-Ansicht (renderCard) */
.card-img-frame {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.card-img-thumb {
  width: 52px;
  height: 52px;
  object-fit: cover;
  border-radius: 6px;
  border: 1px solid rgba(0,0,0,.1);
  cursor: zoom-in;
  transition: transform .15s, box-shadow .15s;
}
.card-img-thumb:hover {
  transform: scale(1.07);
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
  position: relative;
  z-index: 2;
}

/* V117: Pull-to-refresh Indikator */
#ptr-indicator {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(30,41,59,.92);
  color: #fff;
  padding: 10px 20px;
  border-radius: 0 0 16px 16px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .02em;
  z-index: 99999;
  pointer-events: none;
  transition: opacity .2s;
  opacity: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

/* V118: Unified Gallery Modal – Video + Play-Button */
.gal-video-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: #000;
  border-radius: 10px;
  overflow: hidden;
}
.gal-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: transform .15s, opacity .15s;
}
.gal-play-btn:hover { transform: translate(-50%,-50%) scale(1.12); }

/* V118: Thumbnail strip in gallery */
.gal-thumb-strip {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 10px;
  padding: 6px 0 2px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.gal-strip-thumb {
  width: 44px;
  height: 44px;
  border-radius: 5px;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  flex-shrink: 0;
  background: rgba(255,255,255,.08);
  transition: border-color .15s, transform .15s;
}
.gal-strip-thumb:hover { transform: scale(1.08); border-color: rgba(255,255,255,.5); }
.gal-strip-thumb-active { border-color: #60a5fa !important; }

/* V118: Video thumbnail wrapper in lists/cards */
.list-item-vid-wrap {
  position: relative;
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  cursor: zoom-in;
  border-radius: 6px;
  overflow: hidden;
  border: 1.5px solid rgba(0,0,0,.1);
  background: #000;
}
.list-item-vid-play-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

/* V118: Video tile in edit-page attachment gallery */
.ep-att-video-tile {
  position: relative;
  width: 80px;
  height: 80px;
  cursor: pointer;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
}
.ep-att-video-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ===== V119: PM Timetracker Modal ===== */
.pm-tracker-modal {
  background: #1e293b;
  border-radius: 18px;
  max-width: 680px;
  width: 96%;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,.5);
}
.pm-tracker-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  color: #fff;
  border-radius: 18px 18px 0 0;
}
.pm-tracker-summary {
  display: flex;
  gap: 12px;
  padding: 14px 20px;
  background: rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.pm-tracker-stat {
  flex: 1;
  text-align: center;
  padding: 8px;
  background: rgba(255,255,255,.06);
  border-radius: 10px;
}
.pm-tracker-stat-value {
  font-size: 22px;
  font-weight: 900;
  line-height: 1.2;
}
.pm-tracker-stat-label {
  font-size: 10px;
  color: rgba(255,255,255,.6);
  margin-top: 2px;
}
.pm-tracker-body {
  flex: 1;
  overflow-y: auto;
  padding: 16px 20px;
}
.pm-tracker-section-title {
  font-weight: 800;
  font-size: 13px;
  color: rgba(255,255,255,.7);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 8px;
}
.pm-tracker-scroll {
  overflow-x: auto;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.1);
}
.pm-tracker-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  min-width: 400px;
}
.pm-tracker-th {
  text-align: left;
  padding: 7px 10px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.7);
  font-weight: 700;
  font-size: 11px;
}
.pm-tracker-td {
  padding: 6px 10px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  color: #e2e8f0;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pm-tracker-empty {
  text-align: center;
  padding: 20px;
  color: rgba(255,255,255,.4);
  font-size: 13px;
  font-style: italic;
}
.pm-btn-chip-tracker {
  background: linear-gradient(135deg, #06b6d4, #0284c7);
  color: #fff !important;
  border-color: #06b6d4 !important;
}

/* ===== V119: Etappe Button ===== */
.pm-btn-chip-etappe {
  background: linear-gradient(135deg, #f97316, #ea580c);
  color: #fff !important;
  border-color: #f97316 !important;
}

/* ===== V119: Meilenstein Item-Titel ===== */
.milestone-title {
  color: #f59e0b;
  font-weight: 800;
}
.ep-milestone-row label {
  user-select: none;
}

/* ===== V119: Etappe Folder-Panel Badge ===== */
.pm-list-folder-header .etappe-badge {
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 10px;
  font-weight: 700;
}

/* ===== V178: SmartTiles (Projektmappen / Timer / Reminder / Wiedervorlage) ===== */
.inbox-smart-tiles-section {
  margin-bottom: var(--space-6);
}
.inbox-smart-tiles-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
@media (max-width: 600px) {
  .inbox-smart-tiles-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.inbox-smart-tile {
  border-radius: var(--radius-2);
  padding: var(--space-3) var(--space-2);
  text-align: center;
  cursor: pointer;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-height: 90px;
  justify-content: center;
  transition: all 0.2s ease;
  user-select: none;
}
.inbox-smart-tile:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
}
.smart-tile-icon {
  font-size: 28px;
  line-height: 1;
}
.smart-tile-label {
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
}
.smart-tile-count {
  font-size: 20px;
  font-weight: 900;
  line-height: 1;
}

/* SmartPanel (aufgeklappte Liste) */
.smart-panel-container {
  border-radius: var(--radius-2);
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0,0,0,0.18);
  margin-bottom: var(--space-3);
}
.smart-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-2) var(--space-4);
  color: #fff;
  font-weight: 700;
  font-size: 15px;
}
.smart-panel-close {
  background: rgba(255,255,255,0.25);
  border: none;
  color: #fff;
  font-size: 18px;
  line-height: 1;
  border-radius: 50%;
  width: 28px;
  height: 28px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.smart-panel-list {
  background: var(--card);
  max-height: 340px;
  overflow-y: auto;
}
.smart-panel-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.15s;
}
.smart-panel-row:hover {
  background: var(--card-hover);
}
.smart-panel-row:last-child {
  border-bottom: none;
}
.smart-panel-icon {
  font-size: 20px;
  flex-shrink: 0;
}
.smart-panel-title {
  font-weight: 600;
  font-size: 14px;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.smart-panel-sub {
  font-size: 11px;
  color: var(--muted);
  flex-shrink: 0;
  white-space: nowrap;
}
.smart-panel-empty {
  padding: var(--space-4);
  text-align: center;
  color: var(--muted);
  font-size: 14px;
}

/* ── V187: Subtask-Progress + interaktive Checkboxen ── */
.ep-subtask-progress-wrap {
  margin-bottom: 8px;
}
.ep-subtask-progress-top {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  opacity: 0.75;
  margin-bottom: 4px;
}
.ep-subtask-progress-label { font-weight: 600; }
.ep-subtask-progress-pct { opacity: 0.8; }
.ep-subtask-progress-bar {
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.1);
  overflow: hidden;
}
.ep-subtask-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #3b82f6, #06b6d4);
  border-radius: 3px;
  transition: width 0.3s ease;
  min-width: 4px;
}
.ep-subtask-progress-fill.ep-subtask-progress-done {
  background: linear-gradient(90deg, #22c55e, #16a34a);
}
.ep-subtask-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
  gap: 8px;
}
.ep-subtask-reset-btn {
  padding: 3px 9px;
  font-size: 11px;
  min-height: 24px;
  white-space: nowrap;
  background: rgba(249,115,22,0.1);
  border-color: rgba(249,115,22,0.3);
  color: #f97316;
  flex-shrink: 0;
}
.ep-subtask-reset-btn:hover {
  background: rgba(249,115,22,0.2);
}
/* Interaktive Checkbox */
.ep-subtask-cb {
  cursor: pointer;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  accent-color: #22c55e;
}
/* Erledigte Zeile */
.ep-subtask-done-row {
  opacity: 0.65;
  background: rgba(34,197,94,0.05) !important;
  border-color: rgba(34,197,94,0.2) !important;
}
.ep-subtask-text-done {
  text-decoration: line-through;
  opacity: 0.7;
}
.ep-subtask-itemcard-done {
  opacity: 0.7;
}
/* doneAt Zeitstempel */
.ep-subtask-doneat {
  font-size: 10px;
  opacity: 0.55;
  margin-left: 4px;
  white-space: nowrap;
}
/* Text-Wrap für nicht verknüpfte Subtasks */
.ep-subtask-text-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  min-width: 80px;
}

/* ===== V188: Meilenstein-Badges auf Progress-Bar (#5) ===== */
.pm-milestone-pin{
  position:absolute;top:50%;transform:translate(-50%,-50%);
  display:flex;flex-direction:column;align-items:center;
  cursor:default;z-index:5;
}
.pm-milestone-pin-icon{
  font-size:16px;line-height:1;
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.4));
  transition:transform .15s;
}
.pm-milestone-pin:hover .pm-milestone-pin-icon{ transform:scale(1.25); }
/* V200 Fix A: PM-Milestone PIN — Light-Mode-Default (Desktop). Dark-Override separat. */
.pm-milestone-pin-label{
  display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:#fff;border:1px solid rgba(0,0,0,.15);
  border-radius:6px;padding:4px 8px;white-space:nowrap;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
  flex-direction:column;align-items:center;gap:1px;min-width:80px;
}
.pm-milestone-pin:hover .pm-milestone-pin-label{ display:flex; }
.pm-milestone-pin-title{
  font-size:11px;font-weight:700;color:#1e293b;text-align:center;
}
.pm-milestone-pin-date{
  font-size:10px;color:#64748b;text-align:center;
}
.pm-milestone-pin-done .pm-milestone-pin-icon{ opacity:1; }
.pm-milestone-legend{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px;
  margin:6px 0 2px;padding:4px 0;
}
/* V202 FIX FINAL: .projektmappe-section hat hardcoded background:#f9fafb — immer hell!
   → Legend braucht IMMER dunkle Schrift. Kein prefers-color-scheme-Override nötig/erlaubt. */
.pm-milestone-legend-label{
  font-size:11px;font-weight:700;color:#374151 !important;
}
.pm-milestone-legend-item{
  font-size:11px;background:rgba(0,0,0,.09);
  border-radius:4px;padding:2px 7px;color:#1e293b !important;
}
/* Dark-Mode: Pin-Tooltip auf Mobile dunkel (schwimmt über beliebigem Hintergrund) */
/* WICHTIG: Legend KEIN Dark-Override — PM-Section hat immer #f9fafb Hintergrund! */
@media (max-width:1023px){
  .pm-milestone-pin-label{ background:#1e293b;border-color:rgba(255,255,255,.2);box-shadow:0 4px 12px rgba(0,0,0,.4); }
  .pm-milestone-pin-title{ color:#f8fafc; }
  .pm-milestone-pin-date{ color:rgba(248,250,252,.65); }
  /* Legend NICHT überschreiben! */
}
/* Desktop expliziter Dark Mode — NUR Pin-Tooltip anpassen, Legend bleibt dunkel */
[data-theme="dark"] .pm-milestone-pin-label{ background:#1e293b;border-color:rgba(255,255,255,.2);box-shadow:0 4px 12px rgba(0,0,0,.4); }
[data-theme="dark"] .pm-milestone-pin-title{ color:#f8fafc; }
[data-theme="dark"] .pm-milestone-pin-date{ color:rgba(248,250,252,.65); }
.pm-milestone-legend-done{
  /* V205 Fix: kein Durchstreichen — Klasse bleibt für Rückwärtskompatibilität */
  opacity:1;
}
/* V205: Grüner Chip für abgeschlossene Etappe in der Meilenstein-Legende */
.pm-milestone-legend-item-done{
  background:rgba(34,197,94,0.15) !important;
  border:1px solid rgba(34,197,94,0.4) !important;
  color:#15803d !important;
  font-weight:700 !important;
}

/* ===== V188: Sammelliste verfeinert (#10) ===== */
.sammelliste-group{
  margin-bottom:4px;
}
.sammelliste-group-header{
  display:flex;align-items:center;
  padding:6px 14px;
  border-radius:6px;
  margin:6px 12px 2px;
  backdrop-filter:blur(4px);
}
.sammelliste-filter-btn{
  background:rgba(255,255,255,.15);
  color:#fff;border:1px solid rgba(255,255,255,.3);
  border-radius:6px;padding:3px 9px;font-size:11px;
  cursor:pointer;transition:background .15s;
}
.sammelliste-filter-btn:hover{ background:rgba(255,255,255,.28); }
.sammelliste-filter-active{
  background:rgba(255,255,255,.3);
  border-color:rgba(255,255,255,.6);
  font-weight:700;
}

/* ===== V189: Notizblock Anhang-Buttons — Light+Dark ===== */
.pm-note-att-section{
  margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;
}
.pm-note-att-btn{
  display:inline-flex;align-items:center;gap:5px;
  background:#e0e9ff;border:1px solid #93c5fd;
  border-radius:6px;padding:3px 9px;font-size:11px;
  color:#1e3a5f;cursor:pointer;transition:background .15s;font-weight:600;
}
.pm-note-att-btn:hover{ background:#bfdbfe; }
.pm-note-att-btn-open{ background:#bfdbfe;border-color:#3b82f6; }
.pm-note-att-label{ font-weight:700; }
.pm-note-att-chevron{ font-size:10px;display:inline-block;transition:transform .18s; }
.pm-note-att-files{
  display:flex;flex-wrap:wrap;gap:6px;margin:6px 0 2px;padding:6px 0;
}
.pm-note-att-thumb{
  width:56px;height:56px;border-radius:7px;overflow:hidden;cursor:zoom-in;flex-shrink:0;
  border:1px solid #e2e8f0;
}
.pm-note-att-file{
  width:56px;height:56px;border-radius:7px;background:#fee2e2;border:1px solid #fca5a5;
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;font-size:18px;text-decoration:none;
  color:#991b1b;flex-shrink:0;padding:4px;text-align:center;
}
.pm-note-att-links{ display:flex;flex-direction:column;gap:4px;margin:6px 0 2px; }
.pm-note-att-link{
  display:flex;align-items:flex-start;gap:6px;
  font-size:11px;text-decoration:none;color:#1d4ed8;
  padding:3px 0;border-bottom:1px solid #e2e8f0;word-break:break-all;
}
.pm-note-att-link:last-child{ border-bottom:none; }
.pm-note-att-link-icon{ flex-shrink:0; }
.pm-note-att-link-text{ opacity:.85; }
.pm-note-att-link:hover .pm-note-att-link-text{ opacity:1;text-decoration:underline; }

/* Dark Mode overrides — Anhang-Buttons */
@media (max-width:1023px){
  .pm-note-att-btn{ background:rgba(59,130,246,.18);border-color:rgba(59,130,246,.4);color:#bfdbfe; }
  .pm-note-att-btn:hover{ background:rgba(59,130,246,.32); }
  .pm-note-att-btn-open{ background:rgba(59,130,246,.32);border-color:#3b82f6; }
  .pm-note-att-thumb{ border-color:rgba(255,255,255,.12); }
  .pm-note-att-file{ background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:#fca5a5; }
  .pm-note-att-link{ color:#93c5fd;border-bottom-color:rgba(255,255,255,.08); }
}
@media (prefers-color-scheme:dark){
  :root{
    --border:rgba(255,255,255,0.10);
    --bg:#0b1220;
    --card:rgba(15,23,42,0.8);
    --card-hover:rgba(30,41,59,0.9);
    --text:#f1f5f9;
    --text-muted:#94a3b8;
  }
  .pm-note-att-btn{ background:rgba(59,130,246,.18);border-color:rgba(59,130,246,.4);color:#bfdbfe; }
  .pm-note-att-btn:hover{ background:rgba(59,130,246,.32); }
  .pm-note-att-btn-open{ background:rgba(59,130,246,.32);border-color:#3b82f6; }
  .pm-note-att-thumb{ border-color:rgba(255,255,255,.12); }
  .pm-note-att-file{ background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:#fca5a5; }
  .pm-note-att-link{ color:#93c5fd;border-bottom-color:rgba(255,255,255,.08); }
}

/* ===== V189: Sammelliste Inline — Light+Dark ===== */
.pm-sammelliste-inline{
  margin:14px 0;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;
  background:#fff;
}
.pm-sammelliste-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:11px 14px;cursor:pointer;
  background:#fff3e8;
  border-bottom:1px solid transparent;
  transition:background .15s;
  color:#7c2d12;
  flex-wrap:wrap;gap:6px;
}
.pm-sammelliste-inline:has(.pm-sammelliste-body) .pm-sammelliste-header{
  border-bottom-color:#fde8d0;
}
.pm-sammelliste-header:hover{ background:#ffe5cc; }
.pm-sammelliste-header-left{ display:flex;align-items:center;gap:8px; }
.pm-sammelliste-icon{ font-size:18px; }
.pm-sammelliste-title{ font-weight:900;font-size:14px;color:#7c2d12; }
.pm-sammelliste-count{
  font-size:11px;font-weight:700;
  background:#f97316;color:#fff;
  padding:2px 8px;border-radius:999px;
}
.pm-sammelliste-header-right{ display:flex;align-items:center;gap:6px; }
.pm-sammelliste-chevron{
  font-size:14px;display:inline-block;transition:transform .2s;margin-left:4px;color:#9a3412;
}
.pm-sl-tool-btn{
  background:#fff;border:1px solid #fed7aa;border-radius:6px;
  padding:3px 9px;font-size:11px;color:#9a3412;
  cursor:pointer;transition:background .15s;font-weight:600;
}
.pm-sl-tool-btn:hover{ background:#ffedd5;border-color:#f97316; }
.pm-sammelliste-body{
  padding:8px 0;max-height:60vh;overflow-y:auto;
  background:#fff;color:#1e293b;
}
.pm-sl-empty{ text-align:center;padding:24px;color:#64748b;font-size:13px; }
.pm-sl-group{ padding:0 0 8px; }
.pm-sl-group-title{
  display:flex;align-items:baseline;gap:6px;
  padding:7px 14px 4px;font-weight:800;font-size:12px;
  border-bottom:2px solid #f1f5f9;margin-bottom:2px;
  color:#1e293b;text-decoration:underline;text-underline-offset:3px;
}
.pm-sl-group-name{ font-size:12px;font-weight:800;color:#1e293b; }
.pm-sl-group-date{ font-size:10px;color:#94a3b8;font-weight:400; }
.pm-sl-group-edit{ font-size:11px;text-decoration:none;color:#94a3b8;opacity:.6;margin-left:auto; }
.pm-sl-group-edit:hover{ opacity:1;color:#f97316; }
.pm-sl-row{
  display:flex;align-items:flex-start;gap:10px;
  padding:5px 14px;transition:background .1s;color:#1e293b;
}
.pm-sl-row:hover{ background:#f8fafc; }
.pm-sl-row-done{ opacity:.5; }
.pm-sl-check{
  font-size:16px;cursor:pointer;flex-shrink:0;
  line-height:1.4;user-select:none;color:#374151;
}
.pm-sl-check:hover{ transform:scale(1.15); }
.pm-sl-content{ flex:1;min-width:0; }
.pm-sl-text{ display:block;font-size:12px;line-height:1.45;color:#1e293b; }
.pm-sl-text-done{ text-decoration:line-through;color:#94a3b8; }
.pm-sl-badges{ display:flex;flex-wrap:wrap;gap:4px;margin-top:3px; }
.pm-sl-badge{ font-size:10px;color:#fff;padding:1px 6px;border-radius:4px;font-weight:600; }

/* Dark Mode overrides — Sammelliste */
@media (max-width:1023px){
  .pm-sammelliste-inline{ background:rgba(15,23,42,.85);border-color:rgba(255,255,255,.12);
    box-shadow:0 4px 16px rgba(0,0,0,.3); }
  .pm-sammelliste-header{ background:rgba(249,115,22,.18);color:#fed7aa; }
  .pm-sammelliste-inline:has(.pm-sammelliste-body) .pm-sammelliste-header{ border-bottom:1px solid rgba(249,115,22,.3); }
  .pm-sammelliste-header:hover{ background:rgba(249,115,22,.28); }
  .pm-sammelliste-title{ color:#fed7aa; }
  .pm-sammelliste-chevron{ color:#fdba74; }
  .pm-sl-tool-btn{ background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#fed7aa; }
  .pm-sl-tool-btn:hover{ background:rgba(255,255,255,.16);border-color:#f97316; }
  .pm-sammelliste-body{ background:rgba(15,23,42,.6);color:#f8fafc;
    border-top:1px solid rgba(255,255,255,.07); }
  .pm-sl-group-title{ border-bottom-color:rgba(255,255,255,.1);color:#f1f5f9;
    background:rgba(255,255,255,.04);padding:8px 14px 5px;margin:0; }
  .pm-sl-group-name{ color:#f1f5f9; }
  .pm-sl-group-date{ color:rgba(248,250,252,.45); }
  .pm-sl-group-edit{ color:rgba(248,250,252,.4); }
  .pm-sl-row{ color:#f8fafc;border-bottom:1px solid rgba(255,255,255,.04); }
  .pm-sl-row:last-child{ border-bottom:none; }
  .pm-sl-row:hover{ background:rgba(255,255,255,.05); }
  .pm-sl-check{ color:#f8fafc; }
  .pm-sl-text{ color:#f1f5f9; }
  .pm-sl-text-done{ color:rgba(248,250,252,.4); }
  .pm-sl-empty{ color:rgba(248,250,252,.5); }
}
@media (prefers-color-scheme:dark){
  .pm-sammelliste-inline{ background:rgba(15,23,42,.8);border-color:rgba(255,255,255,.1); }
  .pm-sammelliste-header{ background:rgba(249,115,22,.15);color:#fed7aa; }
  .pm-sammelliste-inline:has(.pm-sammelliste-body) .pm-sammelliste-header{ border-bottom-color:rgba(249,115,22,.2); }
  .pm-sammelliste-header:hover{ background:rgba(249,115,22,.25); }
  .pm-sammelliste-title{ color:#fed7aa; }
  .pm-sammelliste-chevron{ color:#fdba74; }
  .pm-sl-tool-btn{ background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#fed7aa; }
  .pm-sl-tool-btn:hover{ background:rgba(255,255,255,.16);border-color:#f97316; }
  .pm-sammelliste-body{ background:transparent;color:#f8fafc; }
  .pm-sl-group-title{ border-bottom-color:rgba(255,255,255,.08);color:#f1f5f9; }
  .pm-sl-group-name{ color:#f1f5f9; }
  .pm-sl-group-date{ color:rgba(248,250,252,.45); }
  .pm-sl-group-edit{ color:rgba(248,250,252,.4); }
  .pm-sl-row{ color:#f8fafc; }
  .pm-sl-row:hover{ background:rgba(255,255,255,.04); }
  .pm-sl-check{ color:#f8fafc; }
  .pm-sl-text{ color:#f1f5f9; }
  .pm-sl-text-done{ color:rgba(248,250,252,.4); }
  .pm-sl-empty{ color:rgba(248,250,252,.5); }
}

/* ===== V189: Statistik-Popup (Σ) ===== */
.pm-stats-popup-backdrop{
  position:fixed;inset:0;z-index:1200;
  background:rgba(0,0,0,.35);backdrop-filter:blur(2px);
  display:flex;align-items:flex-end;justify-content:center;
}
@media(min-width:600px){
  .pm-stats-popup-backdrop{ align-items:center; }
}
.pm-stats-popup{
  background:#fff;color:#1e293b;
  border-radius:16px 16px 0 0;width:100%;max-width:560px;
  max-height:80vh;overflow-y:auto;
  box-shadow:0 -4px 32px rgba(0,0,0,.18);
  padding:0 0 24px;
}
@media(min-width:600px){
  .pm-stats-popup{ border-radius:16px; }
}
.pm-stats-popup-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 10px;
  border-bottom:1px solid #f1f5f9;
  position:sticky;top:0;background:#fff;z-index:2;
}
.pm-stats-popup-title{
  font-weight:900;font-size:15px;color:#1e293b;
}
.pm-stats-popup-close{
  background:none;border:none;font-size:20px;
  cursor:pointer;color:#94a3b8;line-height:1;padding:2px 6px;
}
.pm-stats-popup-close:hover{ color:#1e293b; }
.pm-stats-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  padding:14px 16px 8px;
}
.pm-stats-tile{
  background:#f8fafc;border:1px solid #e2e8f0;
  border-radius:10px;padding:12px 10px;text-align:center;
}
.pm-stats-tile-val{
  font-size:26px;font-weight:900;color:#1e293b;line-height:1;
}
.pm-stats-tile-label{
  font-size:11px;color:#64748b;margin-top:3px;font-weight:600;
}
.pm-stats-section{
  padding:8px 16px 4px;
}
.pm-stats-section-title{
  font-size:11px;font-weight:800;text-transform:uppercase;
  letter-spacing:.05em;color:#94a3b8;margin-bottom:6px;
}
.pm-stats-bar-row{
  display:flex;align-items:center;gap:8px;margin-bottom:5px;
}
.pm-stats-bar-label{
  font-size:11px;color:#374151;font-weight:600;min-width:64px;
}
.pm-stats-bar-track{
  flex:1;height:7px;background:#f1f5f9;border-radius:999px;overflow:hidden;
}
.pm-stats-bar-fill{
  height:100%;border-radius:999px;transition:width .4s;
}
.pm-stats-bar-count{
  font-size:11px;color:#64748b;min-width:28px;text-align:right;font-weight:700;
}
.pm-stats-link{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin:14px 16px 0;padding:10px;border-radius:10px;
  background:#f0f9ff;border:1px solid #bae6fd;
  color:#0369a1;font-size:12px;font-weight:700;text-decoration:none;
  cursor:pointer;
}
.pm-stats-link:hover{ background:#e0f2fe; }
/* V191: Stats-Links Container — nebeneinander */
.pm-stats-links{
  display:flex;gap:8px;margin:14px 16px 0;
}
.pm-stats-links .pm-stats-link{
  flex:1;margin:0;
}
.pm-stats-link-export{
  background:#f0fdf4;border-color:#bbf7d0;color:#15803d;
}
.pm-stats-link-export:hover{ background:#dcfce7; }
/* V191: Sekundär-Kacheln (kleiner) */
.pm-stats-grid-sm{
  padding-top:0;
}
.pm-stats-tile-sm{
  padding:8px 6px;
}
.pm-stats-tile-val-sm{
  font-size:20px;font-weight:900;color:#1e293b;line-height:1;
}
/* V191: Unterordner-Zeile */
.pm-stats-folder-row{
  display:flex;align-items:center;gap:8px;margin-bottom:5px;
}
.pm-stats-folder-dot{
  width:10px;height:10px;border-radius:50%;flex-shrink:0;
}
.pm-stats-folder-name{
  font-size:11px;color:#374151;font-weight:600;min-width:80px;max-width:120px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pm-stats-folder-counts{
  font-size:11px;color:#64748b;min-width:36px;text-align:right;font-weight:700;
}
/* V191: Top Items */
.pm-stats-top-item{
  display:flex;align-items:center;gap:8px;
  padding:5px 0;border-bottom:1px solid #f1f5f9;
}
.pm-stats-top-item:last-child{ border-bottom:none; }
.pm-stats-top-rank{
  font-size:10px;font-weight:800;color:#94a3b8;min-width:20px;
}
.pm-stats-top-title{
  flex:1;font-size:12px;color:#1e293b;font-weight:600;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pm-stats-top-badge{
  font-size:10px;font-weight:700;background:#fff7ed;color:#ea580c;
  border:1px solid #fed7aa;border-radius:5px;padding:2px 6px;white-space:nowrap;
}

/* Dark Mode — Statistik-Popup */
@media(max-width:1023px){
  .pm-stats-popup{ background:#1e293b;color:#f8fafc; }
  .pm-stats-popup-header{ background:#1e293b;border-bottom-color:rgba(255,255,255,.08); }
  .pm-stats-popup-title{ color:#f8fafc; }
  .pm-stats-popup-close{ color:#64748b; }
  .pm-stats-popup-close:hover{ color:#f8fafc; }
  .pm-stats-tile{ background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1); }
  .pm-stats-tile-val{ color:#f8fafc; }
  .pm-stats-tile-label{ color:#94a3b8; }
  .pm-stats-bar-label{ color:#cbd5e1; }
  .pm-stats-bar-track{ background:rgba(255,255,255,.1); }
  .pm-stats-bar-count{ color:#94a3b8; }
  .pm-stats-link{ background:rgba(3,105,161,.15);border-color:rgba(186,230,253,.2);color:#7dd3fc; }
  .pm-stats-link:hover{ background:rgba(3,105,161,.25); }
  .pm-stats-link-export{ background:rgba(21,128,61,.15);border-color:rgba(187,247,208,.2);color:#4ade80; }
  .pm-stats-link-export:hover{ background:rgba(21,128,61,.25); }
  .pm-stats-tile-val-sm{ color:#f8fafc; }
  .pm-stats-folder-name{ color:#cbd5e1; }
  .pm-stats-folder-counts{ color:#94a3b8; }
  .pm-stats-top-item{ border-bottom-color:rgba(255,255,255,.06); }
  .pm-stats-top-rank{ color:#64748b; }
  .pm-stats-top-title{ color:#f1f5f9; }
  .pm-stats-top-badge{ background:rgba(234,88,12,.15);color:#fb923c;border-color:rgba(254,215,170,.2); }
}
  .pm-stats-popup{ background:#1e293b;color:#f8fafc; }
  .pm-stats-popup-header{ background:#1e293b;border-bottom-color:rgba(255,255,255,.08); }
  .pm-stats-popup-title{ color:#f8fafc; }
  .pm-stats-popup-close{ color:#64748b; }
  .pm-stats-popup-close:hover{ color:#f8fafc; }
  .pm-stats-tile{ background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1); }
  .pm-stats-tile-val{ color:#f8fafc; }
  .pm-stats-tile-label{ color:#94a3b8; }
  .pm-stats-bar-label{ color:#cbd5e1; }
  .pm-stats-bar-track{ background:rgba(255,255,255,.1); }
  .pm-stats-bar-count{ color:#94a3b8; }
  .pm-stats-link{ background:rgba(3,105,161,.15);border-color:rgba(186,230,253,.2);color:#7dd3fc; }
  .pm-stats-link:hover{ background:rgba(3,105,161,.25); }
  .pm-stats-link-export{ background:rgba(21,128,61,.15);border-color:rgba(187,247,208,.2);color:#4ade80; }
  .pm-stats-link-export:hover{ background:rgba(21,128,61,.25); }
  .pm-stats-tile-val-sm{ color:#f8fafc; }
  .pm-stats-folder-name{ color:#cbd5e1; }
  .pm-stats-folder-counts{ color:#94a3b8; }
  .pm-stats-top-item{ border-bottom-color:rgba(255,255,255,.06); }
  .pm-stats-top-rank{ color:#64748b; }
  .pm-stats-top-title{ color:#f1f5f9; }
  .pm-stats-top-badge{ background:rgba(234,88,12,.15);color:#fb923c;border-color:rgba(254,215,170,.2); }
}


/* ============================================================
   V193: pagePMStats — Projektstatistik-Seite
   Nutzt App-eigene CSS-Tokens: --card, --border, --bg, --radius-2
   ============================================================ */

/* Σ Stats Button */
.pm-sl-tool-btn-stats{
  background:#ede9fe;border-color:#8b5cf6;color:#6d28d9;font-weight:800;
  padding:5px 10px;font-size:12px;
}
.pm-sl-tool-btn-stats:hover{ background:#ddd6fe; }
/* V199 Fix3: Sammelliste-Inline Header auf Mobile kompakter — Buttons passen in eine Zeile */
@media (max-width:480px){
  /* PM Action Buttons auf Mobile: volle Breite, 2-zeilig */
  .pm-sammelliste-header{ padding:9px 10px;flex-direction:column;align-items:flex-start;gap:8px; }
  .pm-sammelliste-header-left{ gap:6px;width:100%; }
  .pm-sammelliste-header-right{ gap:4px;width:100%;justify-content:flex-start;flex-wrap:wrap; }
  .pm-sammelliste-icon{ font-size:16px; }
  .pm-sammelliste-title{ font-size:13px; }
  .pm-sammelliste-count{ font-size:11px;padding:2px 7px; }
  .pm-sammelliste-chevron{ position:absolute;right:14px;top:12px; }
  .pm-sammelliste-inline{ position:relative; }
  .pm-sl-tool-btn{ font-size:11px;padding:4px 8px; }
  .pm-sl-tool-btn-stats{ font-size:11px;padding:4px 8px; }
}

/* Zurück-Button im Header */
.pmstats-back-btn{
  background:none;border:1px solid rgba(255,255,255,.4);
  color:#fff;font-size:12px;font-weight:700;
  cursor:pointer;padding:5px 12px;border-radius:8px;
  white-space:nowrap;
}
.pmstats-back-btn:hover{ background:rgba(255,255,255,.15); }

/* ── Seiten-Wrapper ─────────────────────────────────── */
.pmstats-page{
  padding:0 0 48px;
  max-width:760px;
  margin:0 auto;
}

/* ── Projekt-Header-Banner ──────────────────────────── */
.pmstats-proj-header{
  padding:14px 16px 12px;
  color:#fff;
  border-radius:0 0 14px 14px;
  margin-bottom:16px;
}
.pmstats-proj-label{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;
  opacity:.75;margin-bottom:2px;
}
.pmstats-proj-name{
  font-size:20px;font-weight:900;line-height:1.2;
}

/* ── Abschnitts-Karten ──────────────────────────────── */
.pmstats-section{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-2);
  margin:0 12px 10px;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.07);
}

/* ── Abschnitts-Header (kollabierbar) ───────────────── */
.pmstats-section-header{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  cursor:pointer;user-select:none;
  border-bottom:2px solid transparent; /* wird durch style= überschrieben */
  background:var(--card);
  transition:background .15s;
}
.pmstats-section-header:active{ background:var(--card-hover); }
.pmstats-section-icon{ font-size:20px;flex-shrink:0; }
.pmstats-section-title{
  flex:1;font-size:14px;font-weight:800;
  color:var(--text,#1e293b);
  letter-spacing:-.01em;
}
.pmstats-chevron{
  font-size:10px;color:var(--text-muted,#94a3b8);
  transition:transform .2s;flex-shrink:0;
}
.pmstats-section-body{
  padding:14px 14px 16px;
  border-top:1px solid var(--border);
}

/* ── Inline-Sektion (innerhalb Section-Body) ────────── */
.pmstats-subsection{
  margin-top:12px;
  padding-top:10px;
  border-top:1px solid var(--border);
}
.pmstats-subsection-title{
  font-size:11px;font-weight:800;
  color:var(--text-muted,#94a3b8);
  text-transform:uppercase;letter-spacing:.06em;
  margin-bottom:8px;
}

/* ── § 1 Projektübersicht ───────────────────────────── */
.pmstats-donut-wrap{ flex-shrink:0; }
.pmstats-donut-wrap svg{ display:block; }

.pmstats-overview-row{
  display:flex;align-items:center;gap:14px;margin-bottom:12px;
}
.pmstats-kpi-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:8px;flex:1;
}
.pmstats-kpi{
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:10px;padding:9px 6px;text-align:center;
}
.pmstats-kpi-val{
  font-size:20px;font-weight:900;
  color:var(--text,#1e293b);line-height:1;
}
.pmstats-kpi-label{
  font-size:10px;color:var(--text-muted,#94a3b8);
  margin-top:3px;font-weight:600;
}

.pmstats-legend{
  display:flex;align-items:center;gap:5px;
  font-size:11px;color:var(--text-muted,#94a3b8);margin-bottom:8px;
}
.pmstats-legend-dot{
  width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0;
}
.pmstats-legend-txt{ font-weight:600; }

.pmstats-timeline{ margin-top:2px; }
.pmstats-timeline-bar{
  position:relative;height:10px;
  background:var(--border);
  border-radius:999px;overflow:hidden;margin-bottom:5px;
}
.pmstats-timeline-fill{
  height:100%;background:#22c55e;border-radius:999px;transition:width .4s;
}
.pmstats-timeline-label{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-size:9px;font-weight:800;color:#fff;
}
.pmstats-timeline-dates{
  display:flex;justify-content:space-between;
  font-size:10px;color:var(--text-muted,#94a3b8);font-weight:600;
}

/* ── § 2 Etappen & Meilensteine ─────────────────────── */
.pmstats-folder-card{
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;margin-bottom:8px;
}
.pmstats-folder-header{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;cursor:pointer;
  transition:background .15s;
}
.pmstats-folder-header:active{ background:var(--card-hover); }
.pmstats-folder-dot{
  width:12px;height:12px;border-radius:50%;flex-shrink:0;
}
.pmstats-folder-htitle{
  flex:1;font-size:13px;font-weight:700;
  color:var(--text,#1e293b);
}
.pmstats-folder-pct{
  font-size:12px;font-weight:800;
  color:var(--text,#1e293b);
}
.pmstats-etappe-badge{
  font-size:10px;background:#fff7ed;color:#c2410c;
  border:1px solid #fed7aa;border-radius:5px;
  padding:1px 6px;font-weight:700;
}
.pmstats-mini-bar{ height:4px;background:var(--border); }
.pmstats-mini-bar-fill{ height:100%;transition:width .4s; }
.pmstats-folder-body{ padding:10px 12px; }
.pmstats-folder-counts{
  display:flex;flex-wrap:wrap;gap:10px;
  font-size:11px;color:var(--text-muted,#64748b);
  margin-bottom:6px;
}
.pmstats-etappe-dates{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;
}
.pmstats-date-chip{
  font-size:10px;font-weight:700;
  padding:3px 9px;border-radius:99px;border:1px solid;
}
.pmstats-chip-start{ background:#f0fdf4;color:#15803d;border-color:#bbf7d0; }
.pmstats-chip-end{ background:#fff1f2;color:#be123c;border-color:#fecdd3; }

/* Meilensteine */
.pmstats-milestones{ margin-top:10px; }
.pmstats-milestones-title{
  font-size:10px;font-weight:800;
  color:var(--text-muted,#94a3b8);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;
}
.pmstats-milestone-item{
  display:flex;align-items:center;gap:8px;
  padding:9px 10px;border-radius:9px;cursor:pointer;
  border:1px solid var(--border);margin-bottom:5px;
  background:var(--card);transition:background .15s;
}
.pmstats-milestone-item:active{ background:var(--card-hover); }
.pmstats-milestone-done{ background:#f0fdf4;border-color:#bbf7d0; }
.pmstats-milestone-star{ font-size:16px;flex-shrink:0; }
.pmstats-milestone-title{
  flex:1;font-size:12px;font-weight:700;
  color:var(--text,#1e293b);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pmstats-milestone-date{
  font-size:10px;color:var(--text-muted,#94a3b8);font-weight:600;white-space:nowrap;
}
.pmstats-milestone-subs{ font-size:10px;font-weight:700;white-space:nowrap; }

/* ── § 3 TimeTracker ────────────────────────────────── */
.pmstats-tracker-table{ display:flex;flex-direction:column;gap:0; }
.pmstats-tracker-row{
  display:flex;align-items:center;gap:8px;
  padding:9px 0;border-bottom:1px solid var(--border);
}
.pmstats-tracker-row:last-child{ border-bottom:none; }
.pmstats-tracker-name{
  flex:1;font-size:12px;font-weight:700;
  color:var(--text,#1e293b);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.pmstats-tracker-val{ font-size:11px;font-weight:700;color:#06b6d4;white-space:nowrap; }
.pmstats-tracker-edits{ font-size:10px;color:var(--text-muted,#94a3b8);font-weight:600; }
.pmstats-tracker-work{ font-size:10px;color:#8b5cf6;font-weight:700; }

/* ── § 4 Subtask — nutzt bestehende pm-stats-* Klassen ─ */
/* (pm-stats-grid, pm-stats-tile, pm-stats-bar-* sind bereits definiert) */

/* ── § 5 Finanzcontrolling ──────────────────────────── */
.pmstats-budget-edit{
  display:flex;flex-direction:column;gap:10px;
}
.pmstats-budget-label{
  font-size:11px;font-weight:700;
  color:var(--text-muted,#374151);margin-bottom:-6px;
}
.pmstats-budget-input{
  width:100%;padding:10px 12px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:9px;font-size:14px;
  color:var(--text,#1e293b);box-sizing:border-box;
}
.pmstats-budget-input:focus{ border-color:#3b82f6;outline:none; }
.pmstats-budget-actions{ display:flex;margin-top:4px; }
.pmstats-budget-edit-btn{ margin-top:10px;font-size:12px; }
.pmstats-budget-bar-wrap{ margin:10px 0 2px; }
.pmstats-finanz-body{ display:flex;flex-direction:column; }
.pmstats-finanz-empty{
  color:var(--text-muted,#94a3b8);font-size:13px;padding:6px 0;
}
.pmstats-finanz-note{
  font-size:10px;color:var(--text-muted,#94a3b8);
  margin-top:10px;font-style:italic;
  padding:8px 10px;background:var(--bg);
  border-radius:8px;border:1px solid var(--border);
}

/* ── § 6 Vollständigkeit ────────────────────────────── */
.pmstats-bue-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:8px;margin-bottom:14px;
}
.pmstats-bue-item{
  text-align:center;padding:10px 6px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:10px;
}
.pmstats-bue-val{
  font-size:22px;font-weight:900;
  color:var(--text,#1e293b);
}
.pmstats-bue-label{
  font-size:10px;color:var(--text-muted,#94a3b8);
  margin-top:2px;font-weight:600;
}
.pmstats-link-item{
  display:flex;align-items:flex-start;gap:8px;
  padding:8px 0;border-bottom:1px solid var(--border);
}
.pmstats-link-item:last-child{ border-bottom:none; }
.pmstats-link-url{
  flex:1;font-size:12px;color:#3b82f6;
  text-decoration:none;font-weight:600;
  word-break:break-all; /* kein Overflow bei langen URLs */
  line-height:1.4;
}
.pmstats-link-url:hover{ text-decoration:underline; }
.pmstats-link-parent{
  font-size:10px;color:var(--text-muted,#94a3b8);
  max-width:90px;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap;flex-shrink:0;padding-top:1px;
}
.pmstats-att-name{
  font-size:12px;color:var(--text,#374151);font-weight:600;padding:4px 0;
}

/* ── Footer Links ───────────────────────────────────── */
.pmstats-footer{ margin:16px 12px 0; }

/* ── V194: Aktions-Strip ─────────────────────────────── */
.pmstats-action-strip{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:10px 12px 2px;
}
.pmstats-action-btn{
  display:flex;align-items:center;gap:5px;
  padding:7px 13px;border-radius:20px;
  font-size:12px;font-weight:700;cursor:pointer;
  background:var(--card);border:1px solid var(--border);
  color:var(--text,#1e293b);
  transition:background .15s;white-space:nowrap;
}
.pmstats-action-btn:active{ background:var(--card-hover); }
.pmstats-action-btn-active{
  background:#ede9fe;border-color:#8b5cf6;color:#6d28d9;
}

/* ── V194: Thumbnail-Galerie ─────────────────────────── */
.pmstats-thumb-gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:6px;margin-bottom:8px;
}
.pmstats-thumb-cell{
  aspect-ratio:1;border-radius:8px;overflow:hidden;
  background:var(--bg);border:1px solid var(--border);
  cursor:pointer;position:relative;
}
.pmstats-thumb-img{
  width:100%;height:100%;object-fit:cover;
  display:block;transition:opacity .2s;
}
.pmstats-thumb-img:hover{ opacity:.85; }
.pmstats-thumb-noimg{
  width:100%;height:100%;display:flex;
  align-items:center;justify-content:center;
  font-size:22px;color:var(--text-muted,#94a3b8);
}
.pmstats-thumb-more{
  aspect-ratio:1;border-radius:8px;
  background:var(--bg);border:1px dashed var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;
  color:var(--text-muted,#94a3b8);
}
.pmstats-file-list{ margin-top:4px; }

/* ── V194: Lightbox ─────────────────────────────────── */
.pmstats-lightbox{
  position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.88);
  display:flex;align-items:center;justify-content:center;
  cursor:zoom-out;padding:16px;box-sizing:border-box;
}
.pmstats-lightbox-img{
  max-width:100%;max-height:100%;
  border-radius:10px;object-fit:contain;
  box-shadow:0 8px 32px rgba(0,0,0,.6);
}

/* ── V194: Subsection-Titel (verbessert) ─────────────── */
.pmstats-subsection-title{
  font-size:10px;font-weight:800;
  color:var(--text-muted,#94a3b8);
  text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:8px;
  padding:4px 0 4px 8px;
  border-left:3px solid var(--border);
}

/* ============================================================
   V196: pmstats Dark Mode — explizit (Fallback für var(--text))
   Wirkt wenn prefers-color-scheme:dark ODER max-width:1023px
   ============================================================ */
@media (prefers-color-scheme:dark),(max-width:1023px){
  /* Abschnitts-Karten */
  .pmstats-section{ background:rgba(15,23,42,.85);border-color:rgba(255,255,255,.1); }
  .pmstats-section-header{ background:rgba(255,255,255,.04); }
  .pmstats-section-header:active{ background:rgba(255,255,255,.1); }
  .pmstats-section-title{ color:#f1f5f9; }
  .pmstats-chevron{ color:#94a3b8; }
  /* Projekt-Header: bleibt farbig (catColor) — kein Override nötig */
  /* KPI-Kacheln */
  .pmstats-kpi{ background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1); }
  .pmstats-kpi-val{ color:#f1f5f9; }
  .pmstats-kpi-label{ color:#94a3b8; }
  /* Timeline */
  .pmstats-timeline-bar{ background:rgba(255,255,255,.1); }
  .pmstats-timeline-dates{ color:#94a3b8; }
  /* Legende */
  .pmstats-legend{ color:#94a3b8; }
  /* Unterordner-Karten */
  .pmstats-folder-card{ background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1); }
  .pmstats-folder-header{ background:transparent; }
  .pmstats-folder-htitle{ color:#f1f5f9; }
  .pmstats-folder-pct{ color:#e2e8f0; }
  .pmstats-folder-counts{ color:#94a3b8; }
  .pmstats-mini-bar{ background:rgba(255,255,255,.1); }
  /* Meilensteine */
  .pmstats-milestone-item{ background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1); }
  .pmstats-milestone-item:active{ background:rgba(255,255,255,.1); }
  .pmstats-milestone-done{ background:rgba(21,128,61,.2);border-color:rgba(187,247,208,.2); }
  .pmstats-milestone-title{ color:#f1f5f9; }
  .pmstats-milestone-date{ color:#94a3b8; }
  .pmstats-milestones-title{ color:#64748b; }
  /* Subsection-Titel */
  .pmstats-subsection-title{ color:#94a3b8;border-left-color:rgba(255,255,255,.15); }
  .pmstats-subsection{ border-top-color:rgba(255,255,255,.08); }
  /* TimeTracker */
  .pmstats-tracker-row{ border-bottom-color:rgba(255,255,255,.08); }
  .pmstats-tracker-name{ color:#f1f5f9; }
  .pmstats-tracker-edits{ color:#64748b; }
  .pmstats-tracker-summary{ background:rgba(6,182,212,.1);border-color:rgba(6,182,212,.25); }
  .pmstats-tracker-total-time{ color:#22d3ee; }
  .pmstats-tracker-total-label{ color:#94a3b8; }
  .pmstats-tracker-total-sub{ color:#64748b; }
  /* Vollständigkeit */
  .pmstats-bue-item{ background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1); }
  .pmstats-bue-val{ color:#f1f5f9; }
  .pmstats-bue-label{ color:#94a3b8; }
  .pmstats-link-item{ border-bottom-color:rgba(255,255,255,.07); }
  /* Finanzcontrolling */
  .pmstats-finanz-empty{ color:#64748b; }
  .pmstats-finanz-note{ background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08);color:#64748b; }
  .pmstats-budget-input{ background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#f1f5f9; }
  .pmstats-budget-label{ color:#94a3b8; }
  /* Thumbnails */
  .pmstats-thumb-cell{ background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1); }
  .pmstats-thumb-more{ background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.15);color:#94a3b8; }
  /* Aktions-Strip */
  .pmstats-action-btn{ background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12);color:#e2e8f0; }
  .pmstats-action-btn:active{ background:rgba(255,255,255,.14); }
  .pmstats-action-btn-active{ background:rgba(139,92,246,.25);border-color:#8b5cf6;color:#c4b5fd; }
}

/* ── V196: TimeTracker Gesamt-Summary ──────────────────── */
.pmstats-tracker-summary{
  background:#ecfeff;
  border:1px solid #a5f3fc;
  border-radius:10px;
  padding:12px 14px;
  margin-bottom:8px;
  text-align:center;
}
.pmstats-tracker-total-time{
  font-size:28px;font-weight:900;color:#0e7490;
  letter-spacing:.02em;font-variant-numeric:tabular-nums;
  line-height:1.1;margin-bottom:2px;
}
.pmstats-tracker-total-label{
  font-size:10px;font-weight:700;color:#64748b;
  text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px;
}
.pmstats-tracker-total-sub{
  display:flex;gap:14px;justify-content:center;
  font-size:11px;color:#64748b;font-weight:600;
}
