:root{
  --blue:#232d74;
  --blue-2:#17225f;
  --yellow:#f7a600;
  --grey:#e7eaec;
  --ink:#10172a;
  --muted:#5c6478;
  --line:#dfe4eb;
  --white:#fff;
  --bg:#f5f7fb;
  --success:#178347;
  --danger:#d84a31;
  --shadow:0 18px 45px rgba(35,45,116,.10);
  --radius:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"TT Commons Pro","TT Commons Pro Medium","TT Commons",Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
}

a{color:var(--blue);font-weight:800;text-decoration:none}
a:hover{opacity:.82}

.app-shell{
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  min-height:100vh;
}

.app-header{
  grid-column:1 / -1;
  height:118px;
  background:linear-gradient(135deg,var(--blue),#0f1b58);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 34px;
  box-shadow:0 14px 30px rgba(20,30,90,.20);
}

.brand{
  display:flex;
  align-items:center;
  gap:18px;
}
.brand img{
  height:70px;
  width:auto;
  object-fit:contain;
}
.brand-title{
  font-size:42px;
  line-height:.95;
  font-weight:900;
  letter-spacing:-.04em;
}
.brand-subtitle{
  margin-top:8px;
  font-size:19px;
  font-weight:700;
  color:rgba(255,255,255,.82);
}

.header-user{
  display:flex;
  align-items:center;
  gap:18px;
  color:#fff;
}
.header-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-left:1px solid rgba(255,255,255,.35);
  padding-left:18px;
  font-weight:800;
}
.avatar{
  width:48px;
  height:48px;
  border-radius:50%;
  background:#fff;
  color:var(--blue);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:22px;
}
.user-lines b{display:block}
.user-lines span{display:block;color:rgba(255,255,255,.75);font-size:14px}

.sidebar{
  background:#fff;
  border-right:1px solid var(--line);
  padding:30px 26px;
}
.nav-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:12px;
  color:var(--blue);
  margin-bottom:7px;
  font-weight:800;
}
.nav-item.active,
.nav-item:hover{
  background:#eef1f7;
  opacity:1;
}
.nav-ico{
  width:26px;
  text-align:center;
  font-size:20px;
}
.nav-sep{
  height:1px;
  background:var(--line);
  margin:24px 0;
}
.sidebar-footer{
  position:sticky;
  top:20px;
  margin-top:30px;
  color:var(--muted);
  font-size:13px;
}

.main{
  padding:32px 34px 44px;
}
.wrap{
  width:100%;
  max-width:1500px;
  margin:0 auto;
}
.page-title,
.title{
  margin:0 0 22px;
  color:var(--blue);
  font-size:38px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.035em;
}
.page-title-logo{
  display:flex;
  align-items:center;
  gap:16px;
  margin-bottom:20px;
}
.page-title-logo img{height:52px;width:auto}
.page-title-logo .title{margin:0}

.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:22px;
  margin:18px 0;
  box-shadow:var(--shadow);
}
.card.soft{
  box-shadow:0 8px 24px rgba(35,45,116,.07);
}

h2{
  margin:0 0 16px;
  color:var(--blue);
  font-size:25px;
  line-height:1.05;
  font-weight:900;
  letter-spacing:-.02em;
}
h2:before{display:none}

.kpi-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(140px,1fr));
  gap:14px;
  margin-bottom:18px;
}
.kpi{
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:18px;
  box-shadow:0 10px 28px rgba(35,45,116,.08);
  display:flex;
  gap:14px;
  align-items:center;
  min-height:122px;
}
.kpi-icon{
  width:54px;
  height:54px;
  border-radius:12px;
  background:var(--blue);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:25px;
  flex:0 0 auto;
}
.kpi.yellow .kpi-icon{background:var(--yellow);color:#fff}
.kpi small{
  display:block;
  color:var(--muted);
  font-size:14px;
  margin-bottom:6px;
}
.kpi b{
  display:block;
  color:var(--blue);
  font-size:34px;
  line-height:1;
}
.kpi span{
  display:block;
  color:var(--muted);
  margin-top:8px;
  font-size:13px;
}

.toolbar{
  display:grid;
  grid-template-columns:minmax(260px,1fr) 200px 240px auto;
  gap:14px;
  align-items:center;
  margin-bottom:16px;
}

.tablewrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:0 0 16px 16px;
  background:#fff;
}
table{
  border-collapse:separate;
  border-spacing:0;
  width:100%;
  background:#fff;
}
th,td{
  border:0;
  border-bottom:1px solid var(--line);
  padding:14px 16px;
  vertical-align:middle;
  text-align:left;
}
th{
  background:#f1f3f7;
  color:var(--blue);
  font-size:14px;
  font-weight:900;
  white-space:nowrap;
}
tr:hover td{background:#fff9ed}
tr:last-child td{border-bottom:0}

.input,select,textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid #cdd4df;
  border-radius:10px;
  background:#fff;
  color:var(--ink);
  font:inherit;
  outline:none;
}
.input:focus,select:focus,textarea:focus{
  border-color:var(--yellow);
  box-shadow:0 0 0 4px rgba(247,166,0,.16);
}
textarea{min-height:46px;resize:vertical}

.btn,button.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  background:var(--yellow);
  color:#fff;
  border:0;
  padding:12px 18px;
  border-radius:10px;
  cursor:pointer;
  font-weight:900;
  font:inherit;
  box-shadow:0 10px 18px rgba(247,166,0,.22);
}
.btn.secondary{
  background:var(--blue);
  color:#fff;
}
.btn:hover{transform:translateY(-1px);opacity:1}

.formgrid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.wide{grid-column:span 2}

.main-grid{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(340px,.55fr);
  gap:22px;
}
.facts{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.facts > div{
  background:#f7f9fc;
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px;
}

.progress{
  position:relative;
  height:42px;
  background:#e7ebf1;
  border-radius:999px;
  overflow:hidden;
  margin-bottom:16px;
}
.bar{
  height:100%;
  background:linear-gradient(90deg,var(--yellow),#ffc44f);
  border-radius:999px;
}
.progress span{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--blue);
  font-weight:900;
}
.mini{
  position:relative;
  height:22px;
  min-width:115px;
  background:#e7ebf1;
  border-radius:999px;
  overflow:hidden;
}
.mini div{
  height:100%;
  background:linear-gradient(90deg,var(--yellow),#ffc44f);
}
.mini span{
  position:absolute;
  inset:0;
  line-height:22px;
  text-align:center;
  color:var(--blue);
  font-size:12px;
  font-weight:900;
}

.phasegrid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:10px;
}
.phase{
  background:#fff;
  border:1px solid var(--line);
  border-left:8px solid #cfd5dd;
  border-radius:14px;
  padding:12px;
  min-height:66px;
}
.phase.done{border-left-color:#168849;background:#f2fbf6}
.phase.active{border-left-color:var(--yellow);background:#fff8e8}
.phase.open{border-left-color:#cfd5dd;background:#fff}
.phase b{color:var(--blue)}
.phase span{font-size:12px;color:var(--muted)}

.section{
  background:#fff;
  margin:14px 0;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
}
.section summary{
  cursor:pointer;
  background:var(--blue);
  color:#fff;
  font-weight:900;
  padding:14px 16px;
  font-size:18px;
}
.section[open] summary{border-bottom:4px solid var(--yellow)}

.task-check,.weekly-check{
  width:24px;
  height:24px;
  cursor:pointer;
  accent-color:var(--yellow);
}
.checkcell{text-align:center}
.small,.save-state,.weekly-state,.done-date{
  font-size:13px;
  color:var(--muted);
}
.done-date{white-space:nowrap}
.note{
  border-left:6px solid var(--yellow);
  background:#fff;
  padding:12px;
  margin-top:10px;
  border-radius:0 12px 12px 0;
}
.pics img{
  max-width:100%;
  height:auto;
  border-radius:14px;
  margin-top:10px;
  box-shadow:0 8px 20px rgba(35,45,116,.12);
}
.badge{
  display:inline-block;
  padding:5px 10px;
  border-radius:999px;
  background:#eef1f7;
  color:var(--blue);
  font-size:12px;
  font-weight:900;
}
.badge.warn{background:#fff4d8;border:1px solid var(--yellow)}
.phase-dot{
  display:inline-block;
  width:11px;
  height:11px;
  border-radius:50%;
  background:var(--yellow);
  margin-right:8px;
  vertical-align:-1px;
}
.phase-dot.blue{background:var(--blue)}
.star{color:var(--yellow);font-size:18px}

.navlinks{margin-bottom:14px}
.navlinks a{
  display:inline-block;
  border:1px solid var(--line);
  background:#fff;
  color:var(--blue);
  border-radius:999px;
  padding:8px 12px;
}

.loginwrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.login-card{
  width:min(560px,100%);
  background:#fff;
  border-radius:24px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.login-head{
  background:var(--blue);
  padding:34px;
  text-align:center;
}
.login-head img{
  max-width:360px;
  width:86%;
  height:auto;
  background:#fff;
  border-radius:12px;
  padding:14px;
}
.login-body{padding:30px}
.loginbox label{
  display:block;
  margin:12px 0 6px;
  font-weight:900;
  color:var(--blue);
}
.error{
  background:#fff0ed;
  border-left:6px solid var(--danger);
  padding:10px 12px;
  margin-bottom:12px;
  border-radius:0 12px 12px 0;
}

@media(max-width:1280px){
  .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .toolbar{grid-template-columns:1fr 1fr}
}
@media(max-width:980px){
  .app-shell{display:block}
  .app-header{height:auto;padding:20px;display:block}
  .header-user{margin-top:16px}
  .sidebar{display:flex;overflow:auto;gap:8px;padding:14px}
  .nav-item{white-space:nowrap;margin:0}
  .nav-sep,.sidebar-footer{display:none}
  .main{padding:20px 14px 34px}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .toolbar{grid-template-columns:1fr}
  .main-grid{grid-template-columns:1fr}
  .formgrid,.facts{grid-template-columns:1fr}
  .wide{grid-column:span 1}
  .phasegrid{grid-template-columns:1fr}
}
@media(max-width:620px){
  .brand img{height:52px}
  .brand-title{font-size:30px}
  .brand-subtitle{font-size:15px}
  .kpi-grid{grid-template-columns:1fr}
  th,td{font-size:13px;padding:10px}
}

/* V13.1 display fixes */
.kpi{overflow:hidden}
.kpi b{
  font-size:32px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.kpi small,.kpi span{white-space:normal}
.kpi-icon{font-family:Arial,sans-serif}
.header-pill{white-space:nowrap}
.header-user{min-width:260px;justify-content:flex-end}
@media(max-width:1500px){.kpi-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}}
@media(max-width:1050px){.kpi-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}.header-user{min-width:auto}}

/* V14 Bugfixes + Projektverwaltung */
.pad{padding:18px}
.edit-section summary{background:#f1f3f7;color:var(--blue);border-bottom:0}
.danger-section summary{background:#fff0ed;color:#9b1c1c;border-bottom:0}
.deletebox{padding:18px}
.btn.danger{background:#d84a31;color:#fff}
#neu{scroll-margin-top:24px}

/* V15 Projektverwaltung */
.btn.secondary{background:var(--blue);color:#fff}
.btn.danger{background:#d84a31;color:#fff}
.card.soft{box-shadow:0 8px 24px rgba(35,45,116,.07)}
.note form{margin-top:8px;margin-right:6px}

/* V16 Dashboard */
.filter-pills{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 14px}
.pill{border:1px solid var(--line);background:#fff;color:var(--blue);border-radius:999px;padding:9px 13px;font-weight:900;cursor:pointer}
.pill.active,.pill:hover{background:var(--blue);color:#fff}
.status-chip{display:inline-block;padding:6px 10px;border-radius:999px;font-weight:900;font-size:12px;border:1px solid var(--line)}
.status-anfrage{background:#eef1f7;color:var(--blue)}
.status-angebot{background:#fff4d8;color:#7a5200}
.status-auftrag{background:#edf4ff;color:#0f4b86}
.status-material{background:#fff0df;color:#a35400}
.status-baustelle{background:#edf9f1;color:#126c3a}
.status-abnahme{background:#f2ecff;color:#5a2bb0}
.status-abschluss{background:#eceff3;color:#333}
.actions{white-space:nowrap}
.btn.tiny{padding:7px 10px;border-radius:8px;font-size:12px;box-shadow:none;margin:2px}
.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}

/* V17.1 Vorlagen und Gewerke */
.checkbox-panel{background:#f7f9fc;border:1px solid var(--line);border-radius:12px;padding:14px}
.checkgrid{display:grid;grid-template-columns:repeat(3,minmax(160px,1fr));gap:10px;margin-top:10px}
.checkgrid label{background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px;font-weight:800;color:var(--blue)}
.checkgrid input{accent-color:var(--yellow);width:18px;height:18px;vertical-align:-3px}
.gewerke-line{display:inline-block;margin-top:3px;color:var(--blue);font-weight:800;font-size:13px}
@media(max-width:900px){.checkgrid{grid-template-columns:1fr}}

/* V18 Kundenanliegen */
textarea.wide{min-height:90px}
.card.soft h2{margin-bottom:14px}

/* V18.1 Aufgaben / Verlauf */
.nav-item[href*="nur_aufgaben"]{font-weight:900}

/* V18.2 Aufgaben & Erinnerungen */
.bell{background:#fff;color:var(--blue);border-radius:999px;padding:9px 14px;font-weight:900;text-decoration:none}
.task-list-simple{display:grid;gap:10px}
.task-simple{display:grid;grid-template-columns:34px 1fr auto;gap:10px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.task-simple.overdue{border-left:7px solid #d84a31}
.reminder-modal{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:9999;align-items:center;justify-content:center}
.reminder-box{background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:24px;max-width:620px;width:calc(100% - 30px)}

/* V18.4 Aufgaben-Fix */
.field{display:flex;flex-direction:column;gap:6px}
.field span{font-size:13px;font-weight:900;color:var(--blue)}
.formhint{font-size:13px;color:#4b5570;padding:4px 0 2px}
.btn.danger{background:#d84a31;color:#fff}
.task-simple{grid-template-columns:34px 1fr auto auto}

/* V18.5 Projekt-ToDo und Aufgaben-Dateien */
#projekt-todo .note form{margin-top:8px;margin-right:6px}

/* V18.5.1 Upload-Fix */
#dateien .note{margin-top:10px}

/* V18.5.3 Datumsfelder */
.section-title{
  font-weight:900;
  color:var(--blue);
  border-top:1px solid var(--line);
  padding-top:14px;
  margin-top:6px;
}
.field span{
  font-size:13px;
  font-weight:900;
  color:var(--blue);
}

/* V19 Kommunikation */
.timeline{display:grid;gap:12px;margin-top:16px}
.timeline-item{display:grid;grid-template-columns:42px 1fr;gap:12px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.timeline-icon{font-size:24px;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f3f6fb}
.timeline-item p{white-space:pre-wrap;margin:8px 0}

/* V20 Kommunikation UI */
.comm-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.comm-tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 15px;font-weight:900;color:var(--blue);cursor:pointer}
.comm-tab.active,.comm-tab:hover{background:var(--blue);color:#fff}
.comm-form{border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:16px;margin-bottom:18px}
.big-note{min-height:170px}
.comm-list{display:grid;gap:10px}
.comm-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0;overflow:hidden}
.comm-card summary{display:grid;grid-template-columns:42px 1fr;gap:12px;align-items:start;cursor:pointer;padding:14px;list-style:none}
.comm-card summary::-webkit-details-marker{display:none}
.comm-icon{font-size:24px;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f3f6fb}
.comm-card small,.comm-card em{display:block;color:#667085;margin-top:3px}
.comm-card em{font-style:normal}
.comm-full{border-top:1px solid var(--line);padding:14px 14px 14px 68px}
.prewrap{white-space:pre-wrap}

/* V20.1 Aufraeumen: Notizen entfernt, Bilder kleiner, rechte Spalte groesser */

/* alte Notizbereiche sicher ausblenden, falls ein Template-Rest vorhanden ist */
#notizen,
.card:has(> h2:first-child:nth-last-child(n)) form[action*="/notiz"] {
  display: none !important;
}

/* Projektlayout: linke Checklisten-/Statusspalte kleiner, rechter Arbeitsbereich groesser */
.project-grid,
.projekt-grid,
.detail-grid,
.project-layout,
.projekt-layout {
  grid-template-columns: minmax(260px, 28%) 1fr !important;
  gap: 18px !important;
}

@media (max-width: 1100px) {
  .project-grid,
  .projekt-grid,
  .detail-grid,
  .project-layout,
  .projekt-layout {
    grid-template-columns: 1fr !important;
  }
}

/* Projektstand / Checklisten kompakter */
.phase-card,
.phase-box,
.checklist-card,
.task-group,
.phase {
  padding: 10px !important;
  margin-bottom: 8px !important;
}

.phase-card h3,
.phase-box h3,
.task-group h3 {
  font-size: 14px !important;
  margin-bottom: 6px !important;
}

/* Kommunikation einspaltig und lesbarer */
#kommunikation .formgrid {
  grid-template-columns: 1fr !important;
}
#kommunikation .field,
#kommunikation .wide {
  grid-column: 1 / -1 !important;
}
#kommunikation .comm-form {
  max-width: 100%;
}
#kommunikation textarea {
  min-height: 120px;
}

/* kompakte Kommunikationskarten */
.comm-card summary {
  grid-template-columns: 34px 1fr !important;
  padding: 10px 12px !important;
}
.comm-icon {
  width: 34px !important;
  height: 34px !important;
  font-size: 20px !important;
}
.comm-full {
  padding: 12px 12px 12px 52px !important;
}

/* Bildergalerie: kleine Vorschaukarten statt riesiger Bilder */
.image-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(145px, 1fr));
  gap: 12px;
  align-items: start;
}

.image-gallery img,
.gallery-thumb,
#bilder img,
.card#bilder img {
  width: 100% !important;
  max-width: 180px !important;
  height: 115px !important;
  object-fit: cover !important;
  border-radius: 12px !important;
  display: block !important;
  box-shadow: none !important;
}

#bilder .note,
.card#bilder .note {
  display: inline-block;
  vertical-align: top;
  width: 180px;
  margin: 6px 8px 12px 0 !important;
  padding: 8px !important;
  border-radius: 12px !important;
}

#bilder .note img,
.card#bilder .note img {
  width: 160px !important;
  height: 105px !important;
}

#bilder p,
.card#bilder p,
#bilder .small,
.card#bilder .small {
  font-size: 12px !important;
  line-height: 1.25 !important;
}

/* Falls Bilder ohne Note direkt untereinander stehen */
#bilder > a,
.card#bilder > a {
  display: inline-block;
  margin: 6px 8px 12px 0;
}

/* Bild-Popup */
.image-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.72);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.image-modal img {
  max-width: 92vw;
  max-height: 88vh;
  border-radius: 14px;
  background: #fff;
}
.image-modal button {
  position: fixed;
  top: 18px;
  right: 18px;
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
}

/* V20.2 Layout/Bilder-Fix */

/* Arbeitsbereich verbreitern:
   In der Projektseite liegt links der Checklistenbereich und rechts die Arbeits-/Sidebar.
   Diese Regeln greifen auf gaengige Grid/Flex-Container und ueberschreiben alte Breiten. */
.main .wrap:has(#kommunikation),
.wrap:has(#kommunikation),
.project-page,
.projekt-page {
  max-width: none !important;
}

/* Typische Projekt-Grid-Layouts */
.project-detail,
.projekt-detail,
.project-grid,
.projekt-grid,
.detail-grid,
.project-layout,
.projekt-layout,
.two-col,
.columns,
.content-grid {
  display: grid !important;
  grid-template-columns: minmax(520px, 68%) minmax(340px, 32%) !important;
  gap: 18px !important;
  align-items: start !important;
}

/* Falls das Template mit flex arbeitet */
.project-detail > .left,
.projekt-detail > .left,
.project-main,
.projekt-main,
.left-col,
.main-col {
  flex: 0 0 68% !important;
  max-width: 68% !important;
}

.project-detail > .right,
.projekt-detail > .right,
.project-side,
.projekt-side,
.right-col,
.side-col,
.sidebar-right {
  flex: 0 0 32% !important;
  max-width: 32% !important;
}

/* Rechte Spalte soll nicht riesige Formen nebeneinander quetschen */
#kommunikation .formgrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
}
#kommunikation .field,
#kommunikation .wide {
  grid-column: 1 / -1 !important;
}
#kommunikation input,
#kommunikation select,
#kommunikation textarea {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Checklistenbereich kompakter */
table.checklist-table td,
table.checklist-table th,
.checklist table td,
.checklist table th,
.card table td,
.card table th {
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}
.card textarea {
  min-height: 46px !important;
}

/* Bilderbereich: kleine Kacheln, aber nichts verstecken */
#bilder {
  overflow: visible !important;
}
#bilder .note,
.card#bilder .note {
  display: inline-block !important;
  vertical-align: top !important;
  width: 155px !important;
  margin: 6px 8px 12px 0 !important;
  padding: 8px !important;
  border-radius: 12px !important;
  background: #fff !important;
}
#bilder img,
.card#bilder img,
#bilder .note img,
.card#bilder .note img {
  width: 140px !important;
  max-width: 140px !important;
  height: 95px !important;
  object-fit: cover !important;
  border-radius: 10px !important;
  display: block !important;
}
#bilder a[href*="/uploads/"] {
  display: inline-block !important;
}
#bilder .small,
#bilder p,
.card#bilder .small,
.card#bilder p {
  font-size: 12px !important;
  line-height: 1.25 !important;
  margin: 4px 0 !important;
}

/* Falls Bilder ohne note wrapper direkt in der Card stehen */
#bilder > a[href*="/uploads/"] {
  width: 155px !important;
  margin: 6px 8px 12px 0 !important;
  vertical-align: top !important;
}

/* Bild-Popup */
.image-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.72);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.image-modal img {
  max-width: 92vw !important;
  max-height: 88vh !important;
  width: auto !important;
  height: auto !important;
  border-radius: 14px;
  background: #fff;
}
.image-modal button {
  position: fixed;
  top: 18px;
  right: 18px;
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
}

/* Mobil/klein: einspaltig */
@media (max-width: 1100px) {
  .project-detail,
  .projekt-detail,
  .project-grid,
  .projekt-grid,
  .detail-grid,
  .project-layout,
  .projekt-layout,
  .two-col,
  .columns,
  .content-grid {
    grid-template-columns: 1fr !important;
  }
  .project-detail > .left,
  .projekt-detail > .left,
  .project-main,
  .projekt-main,
  .left-col,
  .main-col,
  .project-detail > .right,
  .projekt-detail > .right,
  .project-side,
  .projekt-side,
  .right-col,
  .side-col,
  .sidebar-right {
    max-width: 100% !important;
    flex-basis: 100% !important;
  }
}

/* V20.3 Layout 55/45 + Dokumente/Bilder Fix */

/* Projektseite: Checkliste links 55%, Arbeitsbereich rechts 45%.
   Greift auf die typischen Container der Projektansicht. */
.project-detail,
.projekt-detail,
.project-grid,
.projekt-grid,
.detail-grid,
.project-layout,
.projekt-layout,
.two-col,
.columns,
.content-grid,
.projekt-content,
.project-content {
  display: grid !important;
  grid-template-columns: 55% 45% !important;
  gap: 18px !important;
  align-items: start !important;
}

/* Falls flex statt grid verwendet wird */
.project-main,
.projekt-main,
.main-col,
.left-col,
.checklist-col,
.checklist-column {
  flex: 0 0 55% !important;
  max-width: 55% !important;
}

.project-side,
.projekt-side,
.side-col,
.right-col,
.sidebar-right,
.work-col,
.work-column {
  flex: 0 0 45% !important;
  max-width: 45% !important;
}

/* Die rechte Spalte darf die volle Breite nutzen */
#termine,
#kommunikation,
#dokumente,
#bilder,
#projekt-todo {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

/* Formulare rechts einspaltig, damit nichts gequetscht wird */
#termine .formgrid,
#kommunikation .formgrid,
#dokumente .formgrid,
#bilder .formgrid,
#projekt-todo .formgrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
}

#termine .field,
#kommunikation .field,
#dokumente .field,
#bilder .field,
#projekt-todo .field,
#termine .wide,
#kommunikation .wide,
#dokumente .wide,
#bilder .wide,
#projekt-todo .wide {
  grid-column: 1 / -1 !important;
}

#termine input,
#termine select,
#termine textarea,
#kommunikation input,
#kommunikation select,
#kommunikation textarea,
#dokumente input,
#dokumente select,
#dokumente textarea,
#bilder input,
#bilder select,
#bilder textarea,
#projekt-todo input,
#projekt-todo select,
#projekt-todo textarea {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Checklisten etwas kompakter halten */
.card table td,
.card table th {
  padding: 8px 10px !important;
}
.card table textarea {
  min-height: 44px !important;
}

/* Dokumente als klare Liste */
.doc-row,
#dokumente .note {
  display: flex !important;
  justify-content: space-between !important;
  gap: 10px !important;
  align-items: center !important;
  padding: 10px !important;
  border: 1px solid var(--line);
  border-radius: 12px;
  margin: 8px 0 !important;
  background: #fff;
}

/* Bilder kompakt als Kacheln */
.bilder-grid,
#bilder .image-gallery {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(135px, 1fr)) !important;
  gap: 10px !important;
}

.bild-card,
#bilder .note {
  width: auto !important;
  margin: 0 !important;
  padding: 8px !important;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}

.bild-card img,
#bilder img,
.card#bilder img,
#bilder .note img,
.card#bilder .note img {
  width: 100% !important;
  max-width: 160px !important;
  height: 95px !important;
  object-fit: cover !important;
  border-radius: 10px !important;
  display: block !important;
}

#bilder .small,
#bilder p,
#bilder .note,
.bild-card .small {
  font-size: 12px !important;
  line-height: 1.25 !important;
}

/* Bild-Popup */
.image-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.72);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.image-modal img {
  max-width: 92vw !important;
  max-height: 88vh !important;
  width: auto !important;
  height: auto !important;
  border-radius: 14px;
  background: #fff;
}
.image-modal button {
  position: fixed;
  top: 18px;
  right: 18px;
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
}

@media (max-width: 1100px) {
  .project-detail,
  .projekt-detail,
  .project-grid,
  .projekt-grid,
  .detail-grid,
  .project-layout,
  .projekt-layout,
  .two-col,
  .columns,
  .content-grid,
  .projekt-content,
  .project-content {
    grid-template-columns: 1fr !important;
  }
  .project-main,
  .projekt-main,
  .main-col,
  .left-col,
  .checklist-col,
  .checklist-column,
  .project-side,
  .projekt-side,
  .side-col,
  .right-col,
  .sidebar-right,
  .work-col,
  .work-column {
    max-width: 100% !important;
    flex-basis: 100% !important;
  }
}

/* V20.4 Dokumente/Bilder wie Mockup */

/* Projektlayout 55/45 stabiler erzwingen */
.project-detail,
.projekt-detail,
.project-grid,
.projekt-grid,
.detail-grid,
.project-layout,
.projekt-layout,
.two-col,
.columns,
.content-grid,
.projekt-content,
.project-content {
  display: grid !important;
  grid-template-columns: 55% 45% !important;
  gap: 18px !important;
  align-items: start !important;
}

.project-main,
.projekt-main,
.main-col,
.left-col,
.checklist-col,
.checklist-column {
  flex: 0 0 55% !important;
  max-width: 55% !important;
}

.project-side,
.projekt-side,
.side-col,
.right-col,
.sidebar-right,
.work-col,
.work-column {
  flex: 0 0 45% !important;
  max-width: 45% !important;
}

/* Rechte Arbeitskarten */
#termine,
#kommunikation,
#dokumente,
#bilder,
#projekt-todo {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

/* Formulare rechts kompakt */
#termine .formgrid,
#kommunikation .formgrid,
#dokumente .formgrid,
#bilder .formgrid,
#projekt-todo .formgrid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
}

#termine .field,
#kommunikation .field,
#dokumente .field,
#bilder .field,
#projekt-todo .field,
#termine .wide,
#kommunikation .wide,
#dokumente .wide,
#bilder .wide,
#projekt-todo .wide {
  grid-column: 1 / -1 !important;
}

/* Dokumente: kompakte Listenansicht statt langer Vorschau */
#dokumente .note,
#dokumente .doc-row {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  gap: 10px !important;
  align-items: center !important;
  padding: 9px 10px !important;
  margin: 6px 0 !important;
  border: 1px solid var(--line) !important;
  border-radius: 10px !important;
  background: #fff !important;
  font-size: 13px !important;
}

#dokumente .note a,
#dokumente .doc-row a {
  font-weight: 800 !important;
  text-decoration: none !important;
}

#dokumente .btn.tiny,
#dokumente button.btn.tiny {
  padding: 5px 8px !important;
  font-size: 11px !important;
}

/* Bilder: Uploadbereich kompakt */
#bilder form.formgrid {
  margin-bottom: 14px !important;
}

#bilder form.formgrid input,
#bilder form.formgrid select,
#bilder form.formgrid textarea {
  width: 100% !important;
  max-width: 100% !important;
}

/* Bilder: 3-Spalten-Galerie in der rechten Spalte */
#bilder {
  overflow: visible !important;
}

#bilder .bilder-grid,
#bilder .image-gallery {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  align-items: start !important;
}

/* Falls Template keine Galerie-Wrapper hat: die alten .note-Elemente als Kacheln nebeneinander */
#bilder .note,
.card#bilder .note {
  display: inline-block !important;
  vertical-align: top !important;
  width: calc(33.333% - 10px) !important;
  min-width: 0 !important;
  margin: 0 8px 12px 0 !important;
  padding: 6px !important;
  border: 1px solid var(--line) !important;
  border-radius: 10px !important;
  background: #fff !important;
  box-sizing: border-box !important;
}

/* Bilder selbst */
#bilder img,
.card#bilder img,
#bilder .note img,
.card#bilder .note img,
#bilder .bild-card img {
  width: 100% !important;
  max-width: none !important;
  height: 82px !important;
  object-fit: cover !important;
  border-radius: 8px !important;
  display: block !important;
}

/* Bilder ohne note wrapper */
#bilder > a[href*="/uploads/"] {
  display: inline-block !important;
  width: calc(33.333% - 10px) !important;
  margin: 0 8px 12px 0 !important;
  vertical-align: top !important;
}

#bilder > a[href*="/uploads/"] img {
  width: 100% !important;
  height: 82px !important;
  object-fit: cover !important;
}

/* Bildbeschriftung kompakt */
#bilder .small,
#bilder p,
#bilder .note,
#bilder .bild-card .small {
  font-size: 11px !important;
  line-height: 1.2 !important;
}

#bilder .note br + * {
  font-size: 11px !important;
}

/* Löschen/Öffnen in Bildkarten kleiner */
#bilder .btn.tiny,
#bilder button.btn.tiny {
  padding: 4px 7px !important;
  font-size: 10px !important;
  margin-top: 4px !important;
}

/* Kommunikation etwas luftiger im 45%-Bereich */
#kommunikation .comm-tabs {
  gap: 8px !important;
}
#kommunikation .comm-tab {
  padding: 8px 12px !important;
}
#kommunikation .comm-card summary {
  grid-template-columns: 32px 1fr !important;
  padding: 10px !important;
}
#kommunikation .comm-icon {
  width: 32px !important;
  height: 32px !important;
  font-size: 18px !important;
}

/* Bild-Popup */
.image-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.72);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.image-modal img {
  max-width: 92vw !important;
  max-height: 88vh !important;
  width: auto !important;
  height: auto !important;
  border-radius: 14px;
  background: #fff;
}
.image-modal button {
  position: fixed;
  top: 18px;
  right: 18px;
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
}

/* Bei sehr schmaler rechter Spalte nur 2 Spalten */
@media (max-width: 1300px) {
  #bilder .bilder-grid,
  #bilder .image-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  #bilder .note,
  .card#bilder .note,
  #bilder > a[href*="/uploads/"] {
    width: calc(50% - 10px) !important;
  }
}

/* Mobil/Tablet */
@media (max-width: 1100px) {
  .project-detail,
  .projekt-detail,
  .project-grid,
  .projekt-grid,
  .detail-grid,
  .project-layout,
  .projekt-layout,
  .two-col,
  .columns,
  .content-grid,
  .projekt-content,
  .project-content {
    grid-template-columns: 1fr !important;
  }

  .project-main,
  .projekt-main,
  .main-col,
  .left-col,
  .checklist-col,
  .checklist-column,
  .project-side,
  .projekt-side,
  .side-col,
  .right-col,
  .sidebar-right,
  .work-col,
  .work-column {
    max-width: 100% !important;
    flex-basis: 100% !important;
  }

  #bilder .bilder-grid,
  #bilder .image-gallery {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  #bilder .note,
  .card#bilder .note,
  #bilder > a[href*="/uploads/"] {
    width: calc(33.333% - 10px) !important;
  }
}

@media (max-width: 700px) {
  #bilder .bilder-grid,
  #bilder .image-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  #bilder .note,
  .card#bilder .note,
  #bilder > a[href*="/uploads/"] {
    width: calc(50% - 10px) !important;
  }
}

/* V20.4.1 nur Loeschen */
.btn.danger{background:#d84a31!important;color:#fff!important}
.btn.tiny{padding:5px 8px!important;font-size:11px!important;border-radius:8px!important}

/* V20.5 Tagesliste */
.tages-head{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}
.tages-date{display:flex;gap:8px;align-items:center}
.tages-actions{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.progress{height:14px;background:#e8ebf2;border-radius:999px;overflow:hidden;margin:10px 0 16px}
.progress>div{height:100%;background:var(--gold, #e8b12c)}
.tages-list{display:grid;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
.tages-row{display:grid;grid-template-columns:42px 1fr;align-items:center;gap:8px;padding:9px 12px;border-bottom:1px solid var(--line);margin:0;background:#fff}
.tages-row:last-child{border-bottom:0}
.inline-row{display:grid;grid-template-columns:42px 1fr;align-items:center;gap:8px;margin:0}
.extra-row{grid-template-columns:1fr auto}
.check-btn{width:22px;height:22px;border:1px solid #8cc5de;background:#fff;border-radius:3px;color:#d84a31;font-weight:900;line-height:1;cursor:pointer}
.check-btn.checked{background:#fff}
.done{text-decoration:line-through;color:#667085}
.btn.danger{background:#d84a31!important;color:#fff!important}

/* V20.5.6 Kundenanliegen Kopfdaten Fix */
.ka-detail-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
}
.ka-note-box{
  white-space:pre-wrap;
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px;
  margin-top:8px;
}
#kopfdaten h3{
  margin-top:18px;
}

/* V20.5.8 Kundenanliegen Final */
.ka-edit-form{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:12px!important;
}
.ka-edit-form .wide{
  grid-column:1 / -1!important;
}
.ka-edit-form textarea{
  min-height:90px;
}
@media(max-width:1000px){
  .ka-edit-form{grid-template-columns:1fr!important}
}
