:root{
  --bg:#f4f6f8; --panel:#ffffff; --text:#1c2529; --muted:#66737a; --line:#dfe5e8;
  --accent:#0f5960; --accent-dark:#0b4247; --green:#2e9d58; --yellow:#d99a18; --red:#c9473d; --gray:#8b969c;
  --shadow:0 12px 30px rgba(20,35,45,.08); --radius:18px;
}
*{box-sizing:border-box} body{margin:0;font-family:Calibri,Arial,sans-serif;background:var(--bg);color:var(--text)}
.app-shell{display:flex;min-height:100vh}.sidebar{width:250px;background:#fff;border-right:1px solid var(--line);padding:24px 18px;position:sticky;top:0;height:100vh}.brand-small{font-weight:800;letter-spacing:.04em;margin-bottom:20px;color:var(--accent-dark);line-height:1.05}.brand-small span{font-weight:500;color:var(--muted)}
button,a{font:inherit}.primary{background:var(--accent);color:white;border:0;border-radius:12px;padding:11px 14px;cursor:pointer;font-weight:700}.primary:hover{background:var(--accent-dark)}.ghost{background:#eef2f4;border:1px solid var(--line);border-radius:12px;padding:10px 14px;cursor:pointer;color:var(--text)}
.sidebar .primary{width:100%;margin-bottom:26px} nav p{font-size:12px;text-transform:uppercase;color:var(--muted);margin:22px 0 8px;font-weight:700} nav a{display:block;padding:10px 12px;border-radius:11px;color:#2d3a40;text-decoration:none;cursor:pointer;margin-bottom:3px} nav a.active, nav a:hover{background:#edf6f7;color:var(--accent-dark);font-weight:700}.main{flex:1;min-width:0}.topbar{height:96px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:16px 34px}.topbar h1{margin:0;font-size:26px}.topbar p{margin:3px 0 0;color:var(--muted)}.logo{max-height:58px;max-width:310px;object-fit:contain}
#content{padding:30px 34px}.toolbar{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:18px}.toolbar h2{margin:0;font-size:28px}.filters{display:flex;gap:10px;flex-wrap:wrap}.filters input,.filters select{border:1px solid var(--line);border-radius:12px;padding:10px 12px;background:white;min-width:180px}.metrics{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px;margin-bottom:22px}.metric{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.metric span{display:block;color:var(--muted);font-size:13px}.metric strong{font-size:22px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:18px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.card h3{margin:0 0 4px;font-size:21px}.card .sub{color:var(--muted);margin:0 0 14px}.row{display:flex;justify-content:space-between;border-top:1px solid #edf1f3;padding:9px 0;gap:12px}.row span:first-child{color:var(--muted)}.actions{display:flex;gap:10px;margin-top:15px}.status{display:inline-flex;align-items:center;gap:6px;font-weight:700}.dot{width:10px;height:10px;border-radius:50%;display:inline-block}.dot.grün{background:var(--green)}.dot.gelb{background:var(--yellow)}.dot.rot{background:var(--red)}.dot.grau{background:var(--gray)}.empty{background:#fff;border:1px dashed #bac5ca;border-radius:var(--radius);padding:36px;text-align:center;color:var(--muted)}.empty h3{color:var(--text)}
dialog{border:0;border-radius:22px;box-shadow:0 30px 80px rgba(0,0,0,.22);padding:0;max-width:640px;width:92vw}.dialog-card{padding:24px;background:white}.dialog-card.wide{max-width:860px}.dialog-card h2{margin:0 0 16px}.dialog-card label{display:block;font-weight:700;margin:12px 0;color:#314047}.dialog-card input,.dialog-card select,.dialog-card textarea{display:block;width:100%;margin-top:6px;border:1px solid var(--line);border-radius:12px;padding:11px 12px;font:inherit;background:#fff}.grid.two{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.backlink{display:inline-block;margin-bottom:15px;color:var(--accent);font-weight:700;cursor:pointer}.notice{background:#fff7e5;border:1px solid #f1d28e;border-radius:14px;padding:12px 14px;margin-bottom:16px}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0}.tab{border:1px solid var(--line);background:white;border-radius:999px;padding:9px 12px}.tab.active{background:var(--accent);color:white}.placeholder{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;color:var(--muted)}
@media(max-width:850px){.sidebar{display:none}.metrics{grid-template-columns:1fr}.topbar{padding:14px 18px}.logo{max-width:180px}#content{padding:20px}.grid.two{grid-template-columns:1fr}}
.sidebar{display:flex;flex-direction:column}.sidebar nav:first-of-type{flex:1;overflow:auto}.sidebar .admin-nav{flex:0 0 auto;overflow:visible;border-top:1px solid var(--line);padding-top:10px;margin-top:12px}.sidebar .admin-nav p{margin-top:0}.danger{background:#fff3f1;color:#a8342c;border:1px solid #f0c5c0;border-radius:12px;padding:11px 14px;cursor:pointer;font-weight:700;margin-top:18px;width:100%}.danger:hover{background:#ffe7e3}.readonly{background:#f2f5f6!important;color:#39464b}.toolbar.compact{justify-content:flex-start;margin-top:2px}.toolbar.compact .filters input{min-width:360px}.sub{color:var(--muted)}
.edit-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);max-width:1100px}.edit-card h3{margin:0 0 6px}.edit-card label{display:block;font-weight:700;margin:12px 0;color:#314047}.edit-card input,.edit-card select,.edit-card textarea{display:block;width:100%;margin-top:6px;border:1px solid var(--line);border-radius:12px;padding:11px 12px;font:inherit;background:#fff}.tab:disabled{opacity:.45;cursor:not-allowed}
.open-item-list{display:grid;gap:14px;margin-top:16px}.open-item-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.open-item-card h3{margin:0 0 4px}.open-item-card p{line-height:1.35}.grid.two.mini,.grid.three.mini,.grid.four.mini{gap:10px 16px;margin:12px 0}.grid.two.mini{display:grid;grid-template-columns:1fr 1fr}.grid.three.mini{display:grid;grid-template-columns:repeat(3,1fr)}.grid.four.mini{display:grid;grid-template-columns:repeat(4,1fr)}.grid.two.mini>div,.grid.three.mini>div,.grid.four.mini>div{border-top:1px solid #edf1f3;padding-top:8px}.grid.two.mini span,.grid.three.mini span,.grid.four.mini span,.next-action span{display:block;color:var(--muted);font-size:13px}.grid.two.mini strong,.grid.three.mini strong,.grid.four.mini strong{display:block;margin-top:2px}.next-action{background:#f7fafb;border:1px solid #edf1f3;border-radius:14px;padding:10px 12px;margin:10px 0}.next-action p{margin:3px 0 0}.badge{display:inline-block;border-radius:999px;padding:2px 7px;font-size:12px;font-weight:700;margin-left:6px}.badge.red{background:#ffe8e4;color:#a8342c}.badge.yellow{background:#fff2d7;color:#946111}.compact-form{margin-bottom:18px}.danger.small{width:auto;margin:0;padding:9px 12px}.tab:not(:disabled){cursor:pointer}
.table-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow);overflow:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{border-bottom:1px solid #edf1f3;padding:10px 9px;text-align:left;vertical-align:top}.data-table th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em;background:#f8fafb}.data-table tr:hover td{background:#fbfdfe}.data-table small{color:var(--muted)}
.top-tabs{background:#f4f6f8;position:sticky;top:0;z-index:2;padding:8px 0;margin:10px 0 18px}.display-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);max-width:1100px}.one-line-list{display:grid;gap:9px;margin-top:14px}.one-line-item{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}.one-line-item summary{display:grid;grid-template-columns:78px 78px 120px minmax(220px,1fr) 150px 130px 130px 135px auto;gap:10px;align-items:center;padding:11px 14px;cursor:pointer;list-style:none}.one-line-item summary::-webkit-details-marker{display:none}.one-line-item summary:hover{background:#f8fbfc}.one-line-item .mono{font-family:Consolas,monospace;font-weight:700}.details-body{padding:14px 18px;border-top:1px solid var(--line);background:#fbfdfe}.details-body p{margin:0 0 10px}.table-wrap table{width:100%;border-collapse:collapse;font-size:14px}.table-wrap th,.table-wrap td{border-bottom:1px solid #edf1f3;padding:10px 9px;text-align:left;vertical-align:top}.table-wrap th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em;background:#f8fafb}.table-wrap tr:hover td{background:#fbfdfe}
@media(max-width:1100px){.one-line-item summary{grid-template-columns:1fr;gap:5px}.one-line-item summary span,.one-line-item summary strong{display:block}}
.cost-cockpit{margin:18px 0 28px}.cost-metrics{grid-template-columns:repeat(4,minmax(180px,1fr))}.cost-table-wrap{margin-bottom:24px}.num-red{color:var(--red)}.num-green{color:var(--green)}.sum-row td{font-weight:700;background:#f8fafb}.cost-table small .status{margin-right:6px}
@media(max-width:1100px){.cost-metrics{grid-template-columns:repeat(2,minmax(180px,1fr))}}
.budget-group-row td{font-weight:700;background:#eef2f4!important}.budget-position-row .indent{padding-left:28px}.budget-total-row td{font-weight:800;background:#dfe5e8!important}.budget-list-table td:nth-child(n+3),.budget-list-table th:nth-child(n+3){text-align:right}.budget-list-table td:last-child,.budget-list-table th:last-child{text-align:left;white-space:nowrap}
.project-actions-card{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-top:18px}.project-actions-card h3{margin:0 0 4px}.budget-tabs{margin-top:6px;margin-bottom:18px}.chart-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:22px}.chart-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);overflow:auto}.chart-card h3{margin:0 0 4px}.chart-bars{display:grid;gap:16px;margin-top:14px}.chart-row{display:grid;grid-template-columns:220px 1fr;gap:14px;border-top:1px solid #edf1f3;padding-top:12px}.chart-label strong{display:block}.chart-label small{display:block;color:var(--muted);margin-top:3px}.chart-series{display:grid;gap:6px}.mini-bar{display:grid;grid-template-columns:90px 1fr 130px;gap:10px;align-items:center;font-size:13px}.bar-track{height:12px;border-radius:999px;background:#edf1f3;overflow:hidden}.bar-fill{height:100%;border-radius:999px;background:var(--accent)}.delta-chart{display:grid;gap:10px;margin-top:14px}.delta-row{display:grid;grid-template-columns:220px 1fr 140px;gap:14px;align-items:center;border-top:1px solid #edf1f3;padding-top:9px}.delta-track{height:14px;border-radius:999px;background:#edf1f3;overflow:hidden}.delta-fill{height:100%;border-radius:999px}.delta-track.positive .delta-fill{background:var(--red)}.delta-track.negative .delta-fill{background:var(--green)}.pie-layout{display:flex;gap:24px;align-items:center;flex-wrap:wrap;margin-top:14px}.pie{width:210px;height:210px;border-radius:50%;border:1px solid var(--line);box-shadow:inset 0 0 0 1px rgba(255,255,255,.5)}.pie-legend{display:grid;gap:9px;min-width:260px;flex:1}.pie-legend div{display:grid;grid-template-columns:16px 1fr;gap:8px;align-items:start}.pie-legend small{grid-column:2;color:var(--muted)}.legend-dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-top:3px}@media(max-width:900px){.chart-row,.delta-row{grid-template-columns:1fr}.mini-bar{grid-template-columns:1fr}.project-actions-card{display:block}.project-actions-card .actions{margin-top:12px}}

.budget-view-bar{display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin:10px 0 14px;padding:12px;background:#f8fafb;border:1px solid #e1e8ea;border-radius:14px}
.budget-view-bar label{display:flex;flex-direction:column;gap:6px;font-size:.86rem;color:#4f5d63;min-width:260px}
.budget-view-select-list{max-height:50vh;overflow:auto;border:1px solid #dfe7e9;border-radius:12px;padding:12px;background:#fff;margin-top:8px}
.budget-view-group{border-bottom:1px solid #edf1f2;padding:8px 0}.budget-view-group:last-child{border-bottom:none}
.checkline{display:flex;align-items:center;gap:8px;margin:6px 0;color:#263238}.checkline small{color:#6d7a80}
.group-check{margin-bottom:6px}.budget-view-positions{padding-left:24px}
button:disabled{opacity:.45;cursor:not-allowed}

.internal-todo-table td:nth-child(6),.internal-todo-table td:nth-child(7){white-space:nowrap}.internal-todo-table td:nth-child(9){white-space:nowrap}.internal-todo-table .status{min-width:68px}.top-tabs .badge{margin-left:5px}
.badge.green{background:#e7f6ec;color:#177245}.form-card label{display:block;margin:12px 0}.form-card input{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:12px;padding:10px 12px}

.form-msg{min-height:1.3em;margin:6px 0 0;color:#b42318;font-weight:700;}

/* Rollen: Bauherr = Nur-Lese-Ansicht */
body.role-client #newProjectMenu,
body.role-client #emptyNewProject,
body.role-client #addTrade,
body.role-client #addTrade2,
body.role-client #addTradeFromList,
body.role-client #emptyAddTrade,
body.role-client #editProjectData,
body.role-client #addBudgetGroup,
body.role-client #addBudgetPosition,
body.role-client #addBudgetView,
body.role-client #editBudgetView,
body.role-client #deleteBudgetView,
body.role-client #addOpenItem,
body.role-client #addDefect,
body.role-client #addInvoice,
body.role-client #addChangeOrder,
body.role-client #addCorrespondence,
body.role-client #editMasterData,
body.role-client #addTimesheet,
body.role-client #addInternalTodo,
body.role-client #resetInvoiceReminder,
body.role-client [data-edit-budget-group],
body.role-client [data-delete-budget-group],
body.role-client [data-edit-budget-position],
body.role-client [data-delete-budget-position],
body.role-client [data-edit-open-item],
body.role-client [data-delete-open-item],
body.role-client [data-complete-open-item],
body.role-client [data-edit-defect],
body.role-client [data-delete-defect],
body.role-client [data-complete-defect],
body.role-client [data-edit-invoice],
body.role-client [data-delete-invoice],
body.role-client [data-edit-reminder],
body.role-client [data-delete-reminder],
body.role-client [data-edit-change-order],
body.role-client [data-delete-change-order],
body.role-client [data-edit-correspondence],
body.role-client [data-delete-correspondence],
body.role-client [data-complete-correspondence],
body.role-client [data-edit-timesheet],
body.role-client [data-delete-timesheet],
body.role-client [data-edit-internal-todo],
body.role-client [data-delete-internal-todo] {
  display: none !important;
}
.project-access-list {
  max-height: 220px;
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px;
  background: #fff;
}
.form-section {
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 12px;
  background: #f8fafc;
}

/* Terminmodul */
.schedule-timeline-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin:0 0 22px;overflow:auto}
.schedule-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:12px}.schedule-head h3{margin:0 0 4px}.schedule-range{font-weight:700;color:var(--muted);white-space:nowrap}.timeline-wrap{min-width:900px}.timeline-axis{position:relative;height:42px;margin-left:260px;border-bottom:1px solid var(--line);color:var(--muted);font-size:12px}.timeline-axis>span:first-child{position:absolute;left:0;bottom:19px}.timeline-axis>span:nth-child(2){position:absolute;right:0;bottom:19px}.timeline-axis i{position:absolute;bottom:0;transform:translateX(-50%);font-style:normal;border-left:1px solid #dfe7e9;padding-left:4px;height:18px;white-space:nowrap}.timeline-axis b{position:absolute;top:0;transform:translateX(-50%);font-size:12px;color:#0b6870;background:#e9f7f8;border:1px solid #bfe3e6;border-radius:999px;padding:2px 7px;white-space:nowrap}.timeline-group{margin:10px 0 0}.timeline-group .timeline-row{padding-left:18px}.timeline-group .timeline-row .timeline-label{padding-left:6px}.timeline-group>summary,.schedule-list-group>summary{cursor:pointer;list-style:none;font-weight:700;padding:10px 0;color:#17333c}.timeline-group>summary::-webkit-details-marker,.schedule-list-group>summary::-webkit-details-marker{display:none}.timeline-group>summary small,.schedule-list-group>summary small{font-weight:400;color:var(--muted)}.timeline-row{display:grid;grid-template-columns:245px minmax(600px,1fr);gap:15px;align-items:center;min-height:42px;border-bottom:1px solid #edf1f3;cursor:pointer}.timeline-row:hover{background:#f8fbfc}.timeline-label strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-label small{display:block;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-track{position:relative;height:24px;background:linear-gradient(to right,#f2f5f6,#f8fafb);border-radius:999px;overflow:hidden}.timeline-bar{position:absolute;height:7px;border-radius:999px;box-shadow:0 1px 2px rgba(0,0,0,.14)}.timeline-bar-soll{top:4px;background:#111}.timeline-bar-ist{top:13px}.timeline-bar-ist.grau{background:#8e9aa0}.timeline-bar-ist.grün{background:#1f9d55}.timeline-bar-ist.gelb{background:#d99a00}.timeline-bar-ist.rot{background:#d63d33}.today-line{position:absolute;top:0;bottom:0;width:2px;background:#0b6870;z-index:2}.schedule-card summary{grid-template-columns:90px 150px 150px minmax(220px,1fr) minmax(240px,1fr) 140px 140px 120px 100px}.schedule-detail-inline{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-toggle{justify-self:end;color:var(--muted);font-weight:700}.schedule-list-group{margin:0 0 8px}.schedule-completed-group{margin-top:12px}.schedule-group-list{display:grid;gap:8px;padding-left:18px}.schedule-meta-grid{grid-template-columns:repeat(4,minmax(160px,1fr));align-items:start}.schedule-section-grid{grid-template-columns:repeat(3,minmax(160px,1fr));align-items:start}.timeline-group .timeline-row .timeline-label{padding-left:16px}.timeline-group .timeline-row .timeline-label strong{display:block}.timeline-group .timeline-row .timeline-label small{padding-left:18px}.project-module-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.detail-section{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}.detail-section h4{margin:0 0 10px}.section-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px}.section-head h4{margin:0}.history-box{margin-top:10px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px}.history-box summary{cursor:pointer;font-weight:700}.history-box pre{white-space:pre-wrap;font-family:inherit;margin:10px 0 0;color:#34464d}.empty.small{padding:22px}
@media(max-width:1100px){.schedule-card summary{grid-template-columns:1fr}.timeline-wrap{min-width:760px}.timeline-axis{margin-left:220px}.timeline-row{grid-template-columns:205px minmax(520px,1fr)}.section-head{flex-direction:column;align-items:flex-start}}

@media(max-width:1100px){.schedule-meta-grid,.schedule-section-grid{grid-template-columns:1fr 1fr}.schedule-card summary{grid-template-columns:1fr}}
@media(max-width:700px){.schedule-meta-grid,.schedule-section-grid{grid-template-columns:1fr}}
.budget-trade-assign-list{max-height:55vh;overflow:auto;border:1px solid var(--line);border-radius:14px;background:#fff;padding:12px;margin-top:12px}
.budget-trade-line{align-items:flex-start;border-bottom:1px solid #edf1f3;padding:9px 0}
.budget-trade-line:last-child{border-bottom:none}
.budget-trade-line span{display:block}.budget-trade-line small{display:block;color:var(--muted);margin-top:3px}
.budget-list-table td:last-child{white-space:nowrap}

.dialog-card{position:relative}
.dialog-close{position:absolute;top:14px;right:16px;width:32px;height:32px;border:1px solid var(--line);border-radius:999px;background:#f4f7f8;color:var(--muted);font-size:22px;line-height:1;cursor:pointer}
.dialog-close:hover{background:#eaf1f2;color:var(--accent-dark)}
.project-top-actions{align-items:center}
.project-dashboard-tiles{display:grid;grid-template-columns:repeat(3,minmax(260px,1fr));gap:16px;margin:18px 0 22px}
.dashboard-tile{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;box-shadow:var(--shadow);min-height:260px}
.tile-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.tile-head h3{margin:0;font-size:20px}
.segmented.mini{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#f4f7f8}
.segmented.mini button{border:0;background:transparent;padding:6px 10px;cursor:pointer;font-weight:700;color:var(--muted)}
.segmented.mini button.active{background:var(--accent);color:#fff}
.cost-tile-layout{display:grid;grid-template-columns:94px 1fr;gap:14px;align-items:start}
.tile-ampel{border-radius:16px;border:1px solid var(--line);padding:12px;text-align:center;background:#f8fafb}
.tile-ampel span{display:block;width:30px;height:30px;border-radius:50%;margin:0 auto 8px}
.tile-ampel.grün span{background:var(--green)}.tile-ampel.gelb span{background:var(--yellow)}.tile-ampel.rot span{background:var(--red)}
.tile-ampel strong{display:block;text-transform:capitalize}.tile-ampel small{display:block;color:var(--muted);margin-top:4px}
.tile-diagrams{display:grid;gap:12px}.mini-chart h4{margin:0 0 8px;color:#20343b}
.pie-mini-layout{display:grid;grid-template-columns:115px 1fr;gap:12px;align-items:center}.pie-mini{width:110px;height:110px;border-radius:50%;border:1px solid var(--line)}
.pie-mini-legend{display:grid;gap:5px;max-height:122px;overflow:auto}.pie-mini-legend div{display:grid;grid-template-columns:12px 1fr;gap:6px;align-items:start}.pie-mini-legend i{width:10px;height:10px;border-radius:50%;margin-top:4px}.pie-mini-legend small{display:block;color:var(--muted)}
.budget-bar-row{display:grid;grid-template-columns:105px 105px 1fr;gap:8px;align-items:center;margin:6px 0;font-size:13px}.budget-bar-row b{font-size:12px}.budget-bar-track{height:10px;background:#edf1f3;border-radius:999px;overflow:hidden}.budget-bar-track i{display:block;height:100%;background:var(--accent);border-radius:999px}
.tile-placeholder{height:185px;border:1px dashed #cbd5d9;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);gap:6px;text-align:center}
.empty-inline{border:1px dashed #cbd5d9;border-radius:14px;padding:18px;color:var(--muted);text-align:center}
@media(max-width:1200px){.project-dashboard-tiles{grid-template-columns:1fr}.cost-tile-layout{grid-template-columns:1fr}.pie-mini-layout{grid-template-columns:1fr}.budget-bar-row{grid-template-columns:1fr}}

.schedule-metrics .metric strong .dot{vertical-align:middle}
.project-phase-timeline{display:grid;gap:10px;padding:8px 0 4px}
.timeline-scale{display:flex;justify-content:space-between;color:var(--muted);font-size:12px;margin-left:220px;margin-bottom:4px}
.project-phase-row{display:grid;grid-template-columns:210px 1fr;gap:12px;align-items:center;min-height:50px}
.phase-label strong{display:block;color:#20343b}.phase-label small{display:block;color:var(--muted);margin-top:2px}
.phase-bars{position:relative;height:34px;background:linear-gradient(90deg, rgba(15,89,96,.08) 1px, transparent 1px);background-size:10% 100%;border-radius:12px;border:1px solid var(--line);overflow:hidden}
.phase-bar{position:absolute;height:8px;border-radius:999px;min-width:3px}
.phase-bar.soll{top:8px;background:#18272d}
.phase-bar.ist{bottom:8px}.phase-bar.ist.grün{background:var(--green)}.phase-bar.ist.gelb{background:var(--yellow)}.phase-bar.ist.rot{background:var(--red)}.phase-bar.ist.grau{background:#8b969c}
@media(max-width:900px){.timeline-scale{margin-left:0}.project-phase-row{grid-template-columns:1fr}.phase-bars{height:40px}}

.time-punch-card{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:12px 0}
.time-punch-card .actions button:disabled{opacity:.45;cursor:not-allowed}
.badge{display:inline-block}
.management-only{display:block}
.role-client .management-only{display:none}
.form-section{border:1px solid var(--line);border-radius:14px;padding:12px;margin:10px 0;background:#f8fafb}

.trade-overview-head{display:grid;gap:10px;margin:18px 0 14px}
.trade-overview-head h3{margin:0}
.trade-overview-tools{display:grid;grid-template-columns:minmax(260px,420px) 1fr auto;gap:12px;align-items:center}
.trade-overview-tools input{width:100%}
.sort-buttons{display:flex;gap:8px;flex-wrap:wrap}
.sort-buttons button{border:1px solid var(--line);background:#f4f7f8;border-radius:12px;padding:10px 12px;font-weight:700;color:#24343a;cursor:pointer}
.sort-buttons button.active{background:var(--accent);border-color:var(--accent);color:#fff}
.hidden{display:none!important}
.compact-trade-card .card-head.no-ampel{align-items:flex-start}
.compact-trade-card .card-head.no-ampel h3{font-size:18px;line-height:1.2}
.compact-trade-card .contractor-line{font-weight:700;color:#20343b;margin-top:6px}
.compact-trade-card .trade-card-mini{margin-top:14px}
@media(max-width:1100px){.trade-overview-tools{grid-template-columns:1fr}.sort-buttons{justify-content:flex-start}}

.schedule-valid-cards{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:14px;margin:14px 0}.valid-plan{border-left:5px solid var(--accent)}.valid-plan.blue{border-left-color:#2f76c7}.valid-plan.green{border-left-color:var(--green)}.valid-plan strong{display:block;margin-bottom:6px}.valid-plan span{font-weight:800}.schedule-tiles{display:grid;grid-template-columns:repeat(3,minmax(260px,1fr));gap:14px}.schedule-tile{min-height:160px}.tile-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.tile-head h3{margin:0}.tile-plan-select{max-width:210px}.big-ampel{display:flex;align-items:center;gap:10px;font-size:18px;margin:14px 0}.row.critical strong{color:var(--red)}.schedule-tile.muted{border-style:dashed}.checkline{display:flex;align-items:center;gap:8px;font-weight:700}@media(max-width:1100px){.schedule-valid-cards,.schedule-tiles{grid-template-columns:1fr}.tile-head{display:grid}.tile-plan-select{max-width:none;width:100%}}

.area-tree-table .area-tree-cell{line-height:1.35}.area-tree-table .area-tree-marker{display:inline-block;width:20px;color:var(--muted)}.area-level-1 .area-tree-cell strong{font-size:15px}.area-level-1{background:#fbfcfd}.schedule-area-label{margin-top:4px;color:var(--muted);font-size:12px;font-weight:700}

.amount-mode-row{display:grid;grid-template-columns:1fr 110px;gap:8px;align-items:center}.amount-mode-row select{min-width:100px}.construction-table .area-expand{margin-right:8px}.area-term-list{display:grid;gap:8px;padding:10px 16px;background:#f7fafb;border-radius:12px}.area-term{display:grid;grid-template-columns:220px 1fr 180px 120px;gap:12px;align-items:center;border-top:1px solid var(--line);padding-top:8px}.area-term:first-of-type{border-top:0}.area-terms-row td{background:#fbfdfe}@media(max-width:900px){.area-term{grid-template-columns:1fr}}


.tile-schedule{cursor:pointer;}
.tile-schedule:hover{box-shadow:0 14px 34px rgba(15,89,96,.16); transform:translateY(-1px);}
.tile-placeholder small{display:block;margin-top:.35rem;color:#697276;}
.mini-label{display:flex;flex-direction:column;gap:.25rem;min-width:260px;font-size:.85rem;color:#596368;}
.rahmen-table{width:100%;border-collapse:collapse;}
.rahmen-table th,.rahmen-table td{border-bottom:1px solid #e7ecef;padding:.65rem .55rem;text-align:left;vertical-align:top;}
.rahmen-table th{font-size:.82rem;color:#596368;background:#f7fafb;}
.rahmen-table input{width:100%;}
.rahmen-table .phase-locked{background:#f8fafb;}
.rahmen-table .phase-locked small{color:#697276;}
.notice.slim{margin-top:.75rem;padding:.65rem .8rem;}


.schedule-module-grid{grid-template-columns:repeat(3,minmax(220px,1fr));}
.tile-schedule-module{min-height:170px;cursor:pointer;}
.tile-schedule-module.disabled{cursor:not-allowed;opacity:.72;}
.tile-schedule-module.active:hover{box-shadow:0 14px 34px rgba(15,89,96,.16);transform:translateY(-1px);}
button.danger{background:#fff1ef;border:1px solid #f2beb7;color:#b83428;border-radius:14px;padding:.7rem 1rem;font-weight:700;cursor:pointer;}
button.danger:hover{background:#ffe4e0;}
.rahmen-chart-card{margin-top:1rem;}
.chart-scale{font-size:.85rem;color:#596368;}
.rahmen-chart{display:flex;flex-direction:column;gap:.85rem;margin-top:.75rem;}
.rahmen-chart-row{display:grid;grid-template-columns:230px 1fr;gap:1rem;align-items:center;}
.rahmen-chart-label strong{display:block;}
.rahmen-chart-label span{display:block;color:#596368;font-size:.85rem;}
.rahmen-chart-bars{display:flex;flex-direction:column;gap:.25rem;}
.barline{display:grid;grid-template-columns:38px 1fr;gap:.5rem;align-items:center;}
.bar-caption{font-size:.75rem;color:#697276;text-transform:uppercase;font-weight:700;}
.bar-track{height:12px;border-radius:99px;background:#eef3f5;position:relative;overflow:hidden;border:1px solid #dfe7eb;}
.bar-fill{position:absolute;top:2px;height:6px;border-radius:99px;display:block;}
.bar-fill.target{background:#1d2d32;}
.bar-fill.actual.grau{background:#8b969c;}
.bar-fill.actual.grün{background:#2e9d58;}
.bar-fill.actual.gelb{background:#d99a18;}
.bar-fill.actual.rot{background:#c9473d;}
.phase-dialog-title{margin:.4rem 0 1rem 0;padding:.8rem;}
.rahmen-table td{vertical-align:middle;}
.rahmen-table .dot{white-space:nowrap;}
@media(max-width:900px){
  .schedule-module-grid{grid-template-columns:1fr;}
  .rahmen-chart-row{grid-template-columns:1fr;}
}


/* V4.1.6 Rahmenterminplan Feinschliff */
.rahmen-full-card{max-width:none;width:100%;box-sizing:border-box;}
.rahmen-topbar{align-items:flex-start;}
.rahmen-actions{display:flex;align-items:stretch;gap:12px;flex-wrap:wrap;}
.rahmen-actions .action-standard{min-height:58px;min-width:145px;display:inline-flex;align-items:center;justify-content:center;text-align:center;line-height:1.15;padding:.75rem 1rem;box-sizing:border-box;}
.rahmen-actions .primary.action-standard{background:var(--accent);border:1px solid var(--accent);color:white;border-radius:14px;font-weight:700;}
.rahmen-actions .danger.action-standard{background:#fff1ef;border:1px solid #f2beb7;color:#b83428;border-radius:14px;font-weight:700;}
.rahmen-chart-card{max-width:none;width:100%;box-sizing:border-box;}
.rahmen-chart-row{grid-template-columns:260px 1fr;}
.phase-complete-check{align-self:end;min-height:46px;display:flex;align-items:center;gap:.55rem;padding:.7rem .75rem;border:1px solid var(--line);border-radius:12px;background:#fbfdfe;}
.phase-dialog-title.compact{max-width:none;}
@media(max-width:1100px){
  .rahmen-topbar{flex-direction:column;}
  .rahmen-actions{width:100%;}
  .rahmen-actions .action-standard{flex:1 1 160px;}
}


/* V4.1.7 Terminmodule */
.rahmen-actions{display:flex;align-items:stretch;gap:12px;flex-wrap:nowrap;justify-content:flex-end;margin-top:0;}
.rahmen-actions .action-standard{min-height:46px;min-width:145px;width:auto!important;margin-top:0!important;display:inline-flex;align-items:center;justify-content:center;text-align:center;line-height:1.15;padding:.72rem 1rem;box-sizing:border-box;}
.rahmen-actions .danger.action-standard{min-width:100px;width:auto!important;background:#fff1ef;border:1px solid #f2beb7;color:#b83428;border-radius:14px;font-weight:700;}
.overview-phase-bars{display:grid;gap:.65rem;width:100%;margin:.6rem 0;}
.overview-phase-row{display:grid;grid-template-columns:minmax(150px,230px) 1fr;gap:.8rem;align-items:center;text-align:left;}
.overview-phase-title strong{display:block;font-size:.92rem;}
.overview-phase-title span{display:block;color:#596368;font-size:.82rem;}
.overview-phase-title small{display:inline-block;margin-top:.15rem;color:#697276;font-weight:700;}
.overview-phase-lines{display:grid;gap:.25rem;}
.area-indent{display:flex;flex-direction:column;gap:2px;}
.area-indent small{color:#697276;font-weight:600;}
.inline-actions{display:flex;gap:.5rem;align-items:center;}
.bzp-area-table td{vertical-align:middle;}
@media(max-width:900px){
  .rahmen-actions{flex-wrap:wrap;justify-content:flex-start;}
  .overview-phase-row{grid-template-columns:1fr;}
}


.schedule-type{display:inline-flex;align-items:center;border-radius:999px;padding:.15rem .55rem;font-size:.78rem;font-weight:700;border:1px solid #d9e2e6;background:#f6fafb;color:#314248;white-space:nowrap;}
.schedule-type.ref{background:#eef3f5;color:#1d2d32;border-color:#d5dee3;}
.schedule-type.call{background:#edf8f2;color:#226b3f;border-color:#cce8d7;}
.schedule-type.defect{background:#fff6e6;color:#8a5a00;border-color:#f1d79a;}
.schedule-type.other{background:#f4f2fb;color:#524481;border-color:#ded8f2;}
.schedule-area-label{margin:.4rem 0 .8rem 0;color:#596368;font-weight:700;}


.bzp-summary-card .compact-metrics{margin-bottom:1rem;}
.bzp-tree{display:flex;flex-direction:column;gap:.55rem;}
.bzp-area{border:1px solid #dfe7eb;border-radius:16px;background:#fff;overflow:hidden;}
.bzp-area>summary{display:flex;align-items:center;gap:.65rem;padding:.8rem 1rem;cursor:pointer;background:#f8fafb;}
.bzp-area>summary strong{min-width:180px;}
.bzp-area>summary small{color:#596368;}
.bzp-area>summary em{margin-left:auto;font-style:normal;color:#596368;font-size:.86rem;}
.bzp-area.level-2{margin-left:1.25rem;}
.bzp-area.level-3{margin-left:1.75rem;}
.bzp-area-children{display:flex;flex-direction:column;gap:.55rem;padding:.65rem;}
.bzp-trades{display:flex;flex-direction:column;gap:.5rem;margin-left:2.25rem;}
.bzp-trade{border:1px solid #e7ecef;border-radius:14px;background:#fcfdfd;overflow:hidden;}
.bzp-trade>summary{display:flex;gap:.65rem;align-items:center;cursor:pointer;padding:.7rem .85rem;}
.bzp-trade>summary small{margin-left:auto;color:#596368;}
.bzp-term-list{display:flex;flex-direction:column;gap:.35rem;padding:.55rem .65rem .7rem .65rem;border-top:1px solid #edf2f4;}
.bzp-term-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.55rem .65rem;border:1px solid #eef3f5;border-radius:12px;background:#fff;}
.bzp-term-main{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem;min-width:0;}
.bzp-term-main strong{min-width:180px;}
.bzp-term-main small{color:#596368;}
.check.inline{display:flex;align-items:center;gap:.35rem;background:#fff;border:1px solid #dfe7eb;border-radius:12px;padding:.55rem .7rem;}
.highlight-card{outline:3px solid rgba(15,89,96,.35);}
@media(max-width:900px){
  .bzp-area.level-2,.bzp-area.level-3,.bzp-trades{margin-left:.5rem;}
  .bzp-term-row{align-items:flex-start;flex-direction:column;}
}


.backlink-row{display:flex;align-items:center;gap:.65rem;margin:0 0 1rem 0;}
.backlink-row .backlink{margin:0;}
.back-last-page{height:32px;}
.page-capture-actions{justify-content:flex-end;}
.central-capture-row{display:flex;justify-content:space-between;align-items:center;margin:.5rem 0 1rem 0;min-height:44px;}
.central-capture-row .actions,.page-capture-actions{display:flex;gap:.6rem;flex-wrap:wrap;}
.budget-capture-row{margin-top:-.35rem;margin-bottom:1rem;}
.central-schedule-defect{display:none;}
.dialog-card .full{grid-column:1/-1;}
@media(max-width:900px){.backlink-row,.central-capture-row{align-items:flex-start;flex-direction:column}.central-capture-row .actions,.page-capture-actions{justify-content:flex-start}.toolbar .page-capture-actions{margin-top:.75rem}}


.todo-tile-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;margin:.6rem 0;}
.todo-tile-metrics span{background:#f4f7f8;border:1px solid #e2eaed;border-radius:12px;padding:.55rem;display:flex;justify-content:space-between;gap:.5rem;}
.todo-tile-preview{display:flex;flex-direction:column;gap:.4rem;margin-top:.4rem;}
.todo-tile-preview>div{border:1px solid #edf2f4;border-radius:12px;background:#fff;padding:.5rem;display:grid;grid-template-columns:auto 1fr;gap:.35rem .5rem;align-items:center;}
.todo-tile-preview small{grid-column:2;color:#5e6a70;}
.central-capture-row,.budget-capture-row{display:flex;justify-content:space-between;align-items:center;margin:.75rem 0 1rem;}
.budget-trade-line small{display:block;color:#8a5b00;margin-left:1.6rem;}


.year-select{display:flex;align-items:center;gap:.4rem;background:#fff;border:1px solid #dfe7eb;border-radius:12px;padding:.35rem .55rem;font-weight:700;color:#385057;}
.personnel-tabs{margin:1rem 0;}
.personnel-metrics{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));}
.personnel-timeline{display:grid;grid-template-columns:repeat(12,minmax(92px,1fr));gap:.55rem;overflow:auto;padding-bottom:.25rem;}
.personnel-month{border:1px solid #dfe7eb;border-radius:14px;background:#fff;padding:.6rem;min-width:92px;}
.personnel-month>strong{display:block;margin-bottom:.45rem;color:#0b2a33;}
.personnel-month.grün{box-shadow:inset 0 3px 0 #2fa266;}
.personnel-month.gelb{box-shadow:inset 0 3px 0 #d89a17;}
.personnel-month.rot{box-shadow:inset 0 3px 0 #c94747;}
.personnel-month.grau{box-shadow:inset 0 3px 0 #9ba8ad;}
.pbar{height:26px;background:#eef3f5;border-radius:999px;position:relative;margin:.32rem 0;overflow:hidden;}
.pbar span{display:block;height:100%;border-radius:999px;background:#0e6369;}
.pbar.commissioned span{background:#243b40;}
.pbar.allocated span{background:#6b8790;}
.pbar.internal span{background:#b7c4c9;}
.pbar small{position:absolute;left:.45rem;top:50%;transform:translateY(-50%);font-size:.72rem;font-weight:700;color:#0b2a33;white-space:nowrap;}
.free-line{font-weight:800;font-size:.82rem;color:#2fa266;margin-top:.4rem;}
.free-line.neg{color:#c94747;}
.personnel-matrix-wrap{overflow:auto;max-width:100%;}
.personnel-matrix th,.personnel-matrix td{min-width:84px;}
.personnel-matrix th:first-child,.personnel-matrix td:first-child{min-width:220px;position:sticky;left:0;background:#fff;z-index:1;}
.personnel-matrix input{width:72px;padding:.35rem;border:1px solid #dfe7eb;border-radius:8px;}
.order-dist-row td{background:#f8fafb;}
.order-check-row td{font-weight:800;}
@media(max-width:1200px){.personnel-timeline{grid-template-columns:repeat(6,minmax(120px,1fr));}}

.weekday-grid{grid-template-columns:repeat(7,minmax(70px,1fr));gap:.5rem}.personnel-timeline .pbar.actual span{background:#4a6670}.notice.slim{padding:.65rem .8rem;margin:.5rem 0}


/* V4.2.4 */
nav a.disabled-nav{opacity:.35; pointer-events:none; cursor:not-allowed;}
.personal-dashboard-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin:1rem 0 1.25rem;}
.personal-card{background:#fff;border:1px solid #dfe7eb;border-radius:18px;box-shadow:0 10px 26px rgba(8,36,45,.08);padding:1rem;min-height:180px;}
.personal-card h3{margin-top:0;}
.stamp-card{background:#0f6070;color:#fff;}
.stamp-card .ghost{background:rgba(255,255,255,.92);}
.stamp-card .danger{background:#fff0ed;color:#9e2f25;border:1px solid #ffd1c9;}
.stamp-actions,.quick-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.85rem;}
.mini-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;}
.mini-metrics div{background:#f5f8fa;border:1px solid #e2eaee;border-radius:12px;padding:.65rem;}
.mini-metrics span{display:block;color:#53636b;font-size:.82rem;}
.mini-metrics strong{font-size:1.2rem;}
@media(max-width:1000px){.personal-dashboard-grid{grid-template-columns:1fr;}}


.finance-dashboard .metric small{display:block;color:#6b7f86;margin-top:.25rem}.finance-placeholder-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.placeholder-box{border:1px dashed #b9c8ce;border-radius:14px;background:#f7fafb;padding:2rem;text-align:center;color:#60747c;font-weight:700}.finance-master-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.notice.slim{padding:.65rem .8rem;margin:.5rem 0}.num-red{color:#b91c1c}.check{display:flex;gap:.5rem;align-items:center}

/* V4.2.6 Finanzmodul */
.search-field{display:flex;align-items:center;gap:.6rem;font-weight:600;min-width:320px}
.search-field input{min-width:360px;max-width:560px}
tfoot .sum-row td{border-top:2px solid var(--line);background:#f8fafc}
.muted{color:var(--muted)}


/* V4.2.7 Responsives Anzeigeupdate: Desktop, Tablet und Mobile */
html{font-size:clamp(14px,0.82vw,16px);}
img,svg,video{max-width:100%;height:auto;}
.mobile-menu-toggle,.sidebar-backdrop{display:none;}
.topbar-title{min-width:0;}
.main{min-width:0;width:100%;}
.table-wrap,.personnel-month-matrix,.cost-table-wrap,.finance-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.data-table,.table-wrap table,.rahmen-table{min-width:760px;}
.tabs.top-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;}
.tabs.top-tabs .tab{white-space:nowrap;}
.actions{flex-wrap:wrap;}
.toolbar{gap:1rem;}
.dialog-card{max-height:90vh;overflow:auto;}
.dialog-card.wide{width:min(96vw,1100px);max-width:min(96vw,1100px);}

@media(max-width:1280px){
  .sidebar{width:220px;padding:18px 14px;}
  .topbar{padding:14px 24px;}
  #content{padding:24px;}
  .metrics{grid-template-columns:repeat(2,minmax(180px,1fr));}
  .cards{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));}
  .finance-master-grid{grid-template-columns:1fr;}
}

@media(max-width:1024px){
  body.mobile-nav-open{overflow:hidden;}
  .app-shell{display:block;min-height:100vh;}
  .main{width:100%;}
  .mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;background:#eef4f5;border:1px solid var(--line);color:var(--accent-dark);border-radius:12px;padding:10px 12px;font-weight:800;cursor:pointer;white-space:nowrap;}
  .sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(12,25,30,.38);z-index:79;opacity:0;pointer-events:none;transition:opacity .18s ease;}
  body.mobile-nav-open .sidebar-backdrop{opacity:1;pointer-events:auto;}
  .sidebar{display:flex!important;position:fixed;z-index:80;left:0;top:0;bottom:0;width:min(340px,86vw);height:100vh;max-height:100vh;overflow-y:auto;padding:18px 16px;transform:translateX(-105%);transition:transform .2s ease;box-shadow:20px 0 40px rgba(0,0,0,.18);}
  body.mobile-nav-open .sidebar{transform:translateX(0);}
  .sidebar .brand-small{margin-bottom:14px;}
  .sidebar .primary{margin-bottom:16px;}
  .topbar{position:sticky;top:0;z-index:60;height:auto;min-height:74px;padding:12px 16px;gap:12px;align-items:center;}
  .topbar h1{font-size:1.35rem;line-height:1.15;}
  .topbar p{font-size:.92rem;}
  .logo{max-height:42px;max-width:190px;}
  #content{padding:18px 16px 28px;}
  .toolbar{align-items:flex-start;flex-direction:column;}
  .toolbar h2{font-size:1.55rem;}
  .toolbar .actions,.toolbar .filters{width:100%;justify-content:flex-start;}
  .filters input,.filters select,.toolbar.compact .filters input{min-width:0;width:100%;}
  .metrics{grid-template-columns:repeat(2,minmax(0,1fr));}
  .grid.two{grid-template-columns:1fr!important;}
  .one-line-item summary{grid-template-columns:1fr;gap:4px;}
  .rahmen-chart-row,.overview-phase-row{grid-template-columns:1fr!important;}
  .trade-overview-tools{grid-template-columns:1fr!important;}
  .schedule-valid-cards,.schedule-tiles,.schedule-module-grid{grid-template-columns:1fr!important;}
}

@media(max-width:700px){
  html{font-size:14px;}
  .topbar{align-items:flex-start;}
  .topbar-title{flex:1 1 auto;}
  .topbar h1{font-size:1.15rem;}
  .topbar p:first-of-type{display:none;}
  .logo{display:none;}
  #content{padding:14px 12px 24px;}
  .metrics,.cards,.finance-placeholder-grid,.finance-master-grid,.schedule-valid-cards,.schedule-tiles{grid-template-columns:1fr!important;}
  .metric,.card,.display-card,.edit-card,.placeholder,.table-wrap{border-radius:14px;padding:14px;}
  .toolbar .actions button,.actions button,.primary,.ghost,.danger{width:100%;justify-content:center;text-align:center;}
  .tabs{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;}
  .tab{flex:0 0 auto;}
  dialog{width:96vw;max-width:96vw;}
  .dialog-card{padding:16px;max-height:88vh;}
  .dialog-actions{flex-direction:column-reverse;}
  .dialog-actions button{width:100%;}
  .data-table,.table-wrap table,.rahmen-table{font-size:13px;min-width:680px;}
  .data-table th,.data-table td,.table-wrap th,.table-wrap td{padding:8px 7px;}
}

@media(max-width:420px){
  .mobile-menu-toggle{padding:9px 10px;font-size:.92rem;}
  .topbar{gap:8px;}
  .topbar h1{font-size:1.05rem;}
  #currentUserBox{font-size:.78rem;}
  .data-table,.table-wrap table,.rahmen-table{min-width:620px;}
}

/* V4.2.8 interne Struktur */
.quick-grid.management-quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:12px}
.clickable-card{border:1px solid var(--border);text-align:left;cursor:pointer;background:#fff;padding:18px;border-radius:16px}
.clickable-card strong{display:block;font-size:1.05rem;margin-bottom:8px}
.clickable-card span{display:block;color:var(--muted);line-height:1.35}
.clickable-card:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(15,23,42,.08)}
.workspace-tabs{margin:10px 0 18px}
.notice.slim{margin:10px 0 16px;padding:10px 12px;border-radius:12px;background:#fff7e6;border:1px solid #f1d39a;color:#5f4300}
@media(max-width:720px){.quick-grid.management-quick-grid{grid-template-columns:1fr}.clickable-card{padding:14px}}

/* V4.2.9 ToDo-Übersicht: einzeilige Tabellenansicht + Kartenansicht */
.open-item-table{display:grid;gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.open-item-table-row{display:grid;grid-template-columns:62px 130px minmax(180px,1.1fr) minmax(240px,1.3fr) minmax(150px,.8fr) minmax(160px,.9fr) minmax(160px,.9fr) 105px 120px;gap:10px;align-items:center;padding:11px 14px;border-bottom:1px solid #edf1f3;min-width:0}
.open-item-table-row:last-child{border-bottom:0}.open-item-table-row:not(.open-item-table-head){cursor:pointer}.open-item-table-row:not(.open-item-table-head):hover{background:#f8fbfc}.open-item-table-head{background:#f8fafb;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;cursor:default}.open-item-table-row .truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.open-item-table-row .ampel-cell{display:flex;align-items:center;justify-content:flex-start}.task-detail-card h2{margin:0 0 4px}.task-card-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:14px}.task-card-meta{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 16px}.task-card-meta span{background:#f6f8fa;border:1px solid var(--line);border-radius:999px;padding:5px 9px;font-size:13px}.task-detail-card h3{margin:18px 0 6px}.task-detail-card p{line-height:1.45;white-space:pre-wrap}.task-form-card .grid.two{align-items:start}dialog .dialog-card{max-height:88vh;overflow-y:auto;overflow-x:hidden}dialog{max-width:min(96vw,1120px)}
@media(max-width:1200px){.open-item-table{overflow-x:auto}.open-item-table-row{grid-template-columns:62px 130px 180px 240px 150px 160px 160px 105px 120px}}
@media(max-width:760px){.open-item-table{display:block;overflow-x:hidden}.open-item-table-head{display:none}.open-item-table-row{display:grid;grid-template-columns:24px 1fr;gap:6px 10px;padding:13px}.open-item-table-row span,.open-item-table-row strong{white-space:normal}.open-item-table-row span:nth-child(n+2)::before,.open-item-table-row strong::before{display:block;color:var(--muted);font-size:11px;text-transform:uppercase}.open-item-table-row span:nth-child(2)::before{content:'Kategorie'}.open-item-table-row strong::before{content:'Titel'}.open-item-table-row span:nth-child(4)::before{content:'Kurzbeschreibung'}.open-item-table-row span:nth-child(5)::before{content:'Gewerk'}.open-item-table-row span:nth-child(6)::before{content:'Fachlicher Bearbeiter'}.open-item-table-row span:nth-child(7)::before{content:'Intern verantwortlich'}.open-item-table-row span:nth-child(8)::before{content:'Frist'}.open-item-table-row span:nth-child(9)::before{content:'Wiedervorlage'}}

/* V4.3.0 Komfortupdate */
.menu-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;margin-left:8px;padding:0 5px;border-radius:999px;background:#d92d20;color:#fff;font-size:11px;font-weight:700;line-height:1;vertical-align:middle;}
.action-dialog-card{max-width:560px;}
.action-dialog-card p{font-size:15px;line-height:1.45;margin:12px 0 18px;}
.task-checklist{display:grid;gap:10px;margin:10px 0 16px;}
.task-checklist label{display:flex;gap:10px;align-items:center;padding:8px 10px;border:1px solid var(--line);border-radius:10px;background:#fff;}
.checklist-edit-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;margin:8px 0;}
.checklist-edit-row input[type="text"]{width:100%;}
.gf-task-row{cursor:pointer;}
.gf-task-row:hover{background:#f6fafb;}
dialog .dialog-card{max-height:88vh;overflow-y:auto;overflow-x:hidden;}
dialog .dialog-card.wide{width:min(980px, 94vw);}
dialog .dialog-card .grid.two{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
@media (max-width: 800px){ dialog .dialog-card.wide, dialog .dialog-card{width:94vw;max-width:94vw;} .checklist-edit-row{grid-template-columns:auto 1fr auto;} }


/* V4.3.1 Komfortkorrekturen */
.employee-row-click,
.mini-task-row,
.open-item-table-row[data-open-item-row]{ cursor:pointer; }
.employee-row-click:hover,
.mini-task-row:hover,
.open-item-table-row[data-open-item-row]:hover{ background:rgba(0,96,110,.06); }
.employee-table th:last-child,
.employee-table td:last-child{ white-space:nowrap; }
.stacked-form{display:block;}
.stacked-form .dialog-actions{justify-content:flex-end;margin-top:1rem;}
.std-hours-section[style*="display: none"]{display:none!important;}
@media (max-width: 900px){
  .employee-table{min-width:760px;}
}

/* V4.3.2 Mitarbeiterseite / Auswertungen */
.pie-wrap{display:flex;gap:1.25rem;align-items:center;flex-wrap:wrap;margin:1rem 0}.pie-chart{width:150px;height:150px;border-radius:50%;background:conic-gradient(var(--accent) 0 var(--p1), #6b7280 var(--p1) calc(var(--p1) + var(--p2)), #e5e7eb calc(var(--p1) + var(--p2)) 100%);box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}.pie-legend{display:flex;flex-direction:column;gap:.35rem}.swatch{display:inline-block;width:.8rem;height:.8rem;border-radius:3px;margin-right:.35rem;vertical-align:-1px}.sw-project{background:var(--accent)}.sw-internal{background:#6b7280}.sw-open{background:#e5e7eb;border:1px solid #cbd5e1}.metric.warn strong{color:#b91c1c}.stacked-form.compact{margin-top:1rem}.project-task-field{transition:.15s ease}.toolbar .actions{margin-left:auto}.dialog-card{max-width:min(920px,94vw);max-height:88vh;overflow-y:auto;overflow-x:hidden}.dialog-card .grid{min-width:0}.table-wrap{overflow-x:auto}.rahmen-full-card .table-wrap{max-width:100%}

/* V4.3.3 Layoutverbesserungen */
.employee-overview-layout{display:grid;grid-template-columns:minmax(0,2fr) minmax(260px,1fr);gap:16px;align-items:stretch}.employee-metrics.metrics{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:0}.employee-pie-panel{display:flex;align-items:center;justify-content:center;background:#f8fafc;border:1px solid var(--border);border-radius:14px;padding:14px}.mini-metrics.clean{margin-top:14px}.month-filter select{min-width:150px}.absence-year-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px}.absence-month-card{border:1px solid var(--border);border-radius:12px;padding:10px;background:#fff;display:flex;flex-direction:column;gap:4px}.absence-month-card strong{color:#0f172a}.absence-month-card span{font-size:12px;color:#475569}.order-stack{display:grid;grid-template-columns:1fr;gap:16px}.card-list{display:grid;gap:8px}.data-card{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:12px;align-items:center;border:1px solid var(--border);border-radius:12px;padding:10px;background:#fff}.data-card small{display:block;color:#64748b;margin-top:2px}.card-list.wide .data-card{grid-template-columns:minmax(220px,1.5fr) repeat(5,auto)}.accounting-card{grid-template-columns:minmax(220px,1.6fr) repeat(7,auto)!important}.button-label{display:flex;align-items:end}.finance-orders-v433 .table-wrap{overflow-x:visible}@media(max-width:900px){.employee-overview-layout{grid-template-columns:1fr}.data-card,.card-list.wide .data-card,.accounting-card{grid-template-columns:1fr!important;align-items:start}.button-label{align-items:start}}


/* V4.3.4 Qualitätsupdate: kein horizontales Scrollen in Kernbereichen, bessere Mitarbeiterseite */
.month-chooser{display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}.month-chooser select{min-width:170px}.month-chooser .ghost.small{padding:.45rem .6rem;min-width:34px}.employee-summary-grid-v434{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin:14px 0}.employee-summary-grid-v434 .metric.main{box-shadow:inset 0 4px 0 var(--accent)}.employee-chart-row-v434{display:grid;grid-template-columns:minmax(300px,1fr) minmax(240px,.8fr);gap:14px;align-items:stretch}.absence-mini-panel{display:grid;grid-template-columns:1fr;gap:10px}.absence-mini-panel>div{background:#f8fafc;border:1px solid var(--border);border-radius:14px;padding:14px}.absence-mini-panel span{display:block;color:#64748b;font-size:.85rem}.absence-mini-panel strong{font-size:1.15rem}.work-account-card-v434 .start-balance-details{margin-top:14px;border:1px solid var(--border);border-radius:14px;background:#f8fafc;padding:10px 14px}.work-account-card-v434 .start-balance-details summary{font-weight:800;cursor:pointer}.absence-year-grid.compact-v434{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.finance-order-sections{display:grid;grid-template-columns:1fr;gap:16px}.finance-orders-v434 .data-card,.finance-orders-v434 .order-card-v434{grid-template-columns:minmax(0,1.4fr) auto auto auto auto auto;overflow:hidden}.finance-orders-v434 .data-card>div{min-width:0}.finance-orders-v434 .data-card strong,.finance-orders-v434 .data-card small{overflow:hidden;text-overflow:ellipsis}.accounting-grid-v434{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:12px}.accounting-tile{border:1px solid var(--border);border-radius:14px;background:#fff;padding:14px;display:grid;gap:7px}.accounting-tile small{color:#64748b}.tax-report-cards .data-card{grid-template-columns:minmax(0,1fr) auto auto}.finance-orders-v434 .table-wrap,.employee-overview-card .table-wrap,.work-account-card-v434 .table-wrap{overflow-x:visible}.button-label{align-items:end}.projectTimesheetMonth{min-width:0}@media(max-width:1100px){.employee-chart-row-v434{grid-template-columns:1fr}.finance-orders-v434 .data-card,.finance-orders-v434 .order-card-v434,.tax-report-cards .data-card{grid-template-columns:1fr!important;align-items:start}.button-label{align-items:start}}@media(max-width:740px){.month-chooser{width:100%}.month-chooser select{flex:1;min-width:0}.employee-summary-grid-v434{grid-template-columns:1fr}.pie-wrap{align-items:flex-start}.pie-chart{width:130px;height:130px}}

/* V4.3.6 Nachfassen / Ausschreibungen */
.followup-group{ margin: 14px 0; }
.followup-item-list{ display:grid; gap:8px; margin:12px 0; }
.followup-check{ display:flex; gap:10px; align-items:flex-start; padding:10px 12px; border:1px solid var(--line); border-radius:12px; background:#fff; }
.followup-check input{ margin-top:4px; width:auto; }
.followup-check span{ display:flex; flex-direction:column; gap:3px; }
.followup-check small{ color:var(--muted); font-size:.82rem; }
.hint-box{ border:1px solid #dbe5e8; background:#f3f8f9; border-radius:12px; padding:10px 12px; color:#445; margin:8px 0; }
.card-list.wide .tender-card{ cursor:pointer; }


/* V4.3.7 Aufgaben-Badges und Checklistenlayout */
.task-action-cell{display:flex;gap:8px;align-items:center;justify-content:flex-end;min-width:120px;white-space:nowrap;}
.task-new-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;background:#f59e0b;color:#fff;font-size:11px;font-weight:800;letter-spacing:.02em;line-height:1;}
.task-new-badge.placeholder{visibility:hidden;}
.mini-task-row.is-new td{background:rgba(245,158,11,.045);}
.personal-task-table th:last-child,.personal-task-table td:last-child{text-align:right;}
.task-checklist{display:grid;gap:8px;margin:10px 0 16px;}
.task-checklist .task-checklist-row{display:grid!important;grid-template-columns:24px minmax(0,1fr);gap:10px;align-items:start;padding:9px 10px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;text-align:left;}
.task-checklist .task-checklist-row:hover{background:#f8fbfc;}
.task-checklist .task-checklist-row input[type="checkbox"]{margin:2px 0 0 0;justify-self:start;}
.task-checklist .task-checklist-text{display:block;min-width:0;white-space:normal;line-height:1.35;text-align:left;}
@media(max-width:720px){.task-action-cell{justify-content:flex-start}.personal-task-table{min-width:760px;}}


/* V4.3.8 Aufgaben, Checklisten, Monatsauswahl */
.personal-task-table th:last-child,.personal-task-table td:last-child{text-align:right;width:160px;}
.task-action-cell{display:flex;gap:8px;align-items:center;justify-content:flex-end;white-space:nowrap;}
.task-new-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border-radius:999px;background:#f59e0b;color:#fff;font-size:11px;font-weight:800;line-height:1;}
.task-new-badge.placeholder{visibility:hidden;}
.mini-task-row.is-new td{background:rgba(245,158,11,.055);}
.task-checklist.task-checklist-v438,.task-checklist-v438{display:grid!important;gap:8px!important;margin:10px 0 16px!important;}
.task-checklist .task-checklist-row,.task-checklist-v438 .task-checklist-row{display:grid!important;grid-template-columns:26px minmax(0,1fr)!important;gap:10px!important;align-items:start!important;text-align:left!important;padding:10px 12px!important;border:1px solid var(--line)!important;border-radius:10px!important;background:#fff!important;cursor:pointer!important;}
.task-checklist .task-checklist-row:hover{background:#f8fbfc!important;}
.task-checklist .task-checklist-row input[type="checkbox"]{grid-column:1!important;margin:2px 0 0 0!important;justify-self:start!important;align-self:start!important;width:16px!important;height:16px!important;}
.task-checklist .task-checklist-text{grid-column:2!important;display:block!important;min-width:0!important;white-space:normal!important;line-height:1.35!important;text-align:left!important;justify-self:stretch!important;}
select[id$="Month"],select[name="month"],select[name="service_month"],#timeMonthFilter,#empMonthSelect,#employeeTimeMonth,#projectTimesheetMonth{min-width:180px;}
@media(max-width:720px){.task-action-cell{justify-content:flex-start}.personal-task-table{min-width:760px}.personal-task-table th:last-child,.personal-task-table td:last-child{text-align:left;}}


/* V5 Reisekosten und Fotos */
.travel-module .metrics,.photo-module .metrics{margin:12px 0;}
.travel-module .data-table small,.photo-module .data-table small{display:block;color:var(--muted);}
.card-list.compact .data-card{padding:10px 12px;}
.photo-module input[type="file"]{padding:8px;background:#fff;}
.notice.slim{margin:10px 0;}
@media(max-width:720px){.travel-module .data-table,.photo-module .data-table{min-width:900px}.workspace-tabs{overflow-x:auto;white-space:nowrap;}}


/* V5.0.1 Korrekturen */
.segmented{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.segmented .active{background:var(--accent);color:#fff;border-color:var(--accent)}
.timesheet-month-table .ts-weekend td{background:#eef2f4}.timesheet-month-table .sum-row td{background:#f8fafc;border-top:2px solid var(--line)}.ts-month-line{padding:3px 0}.ts-month-line+ .ts-month-line{border-top:1px dashed #dbe5e8;margin-top:4px;padding-top:6px}.timesheet-month-table th:nth-child(1),.timesheet-month-table td:nth-child(1){width:46px}.timesheet-month-table th:nth-child(2),.timesheet-month-table td:nth-child(2){width:70px}.timesheet-month-table th:last-child,.timesheet-month-table td:last-child{text-align:right;width:100px}
.finance-master-grid-v501{grid-template-columns:minmax(0,1.1fr) minmax(0,1.1fr) minmax(360px,.9fr);align-items:start}.travel-settings-card{margin-top:18px;border:1px solid var(--line);border-radius:16px;background:#fff;padding:14px;box-shadow:0 6px 20px rgba(15,34,51,.05)}.travel-settings-grid{display:grid;grid-template-columns:1fr;gap:10px}.travel-settings-grid label{display:grid;gap:4px;font-weight:700}.travel-settings-grid small{color:var(--muted);font-weight:500}.travel-settings-grid input{width:100%;box-sizing:border-box}.travel-settings-card .toolbar{margin-bottom:8px}.travel-settings-card h4{margin:0}.travel-settings-card .primary.small{white-space:nowrap}
.photo-capture-card{display:grid;gap:16px}.photo-main-button{font-size:1.05rem;padding:16px 18px}.photo-empty{border:1px dashed var(--line);border-radius:16px;padding:22px;background:#f8fafc;display:grid;gap:5px;text-align:center;color:#64748b}.photo-preview{display:grid;gap:12px}.photo-preview img{width:100%;max-height:420px;object-fit:contain;border-radius:16px;border:1px solid var(--line);background:#0f172a}.photo-meta-panel{margin-top:18px;border-top:1px solid var(--line);padding-top:18px}.photo-meta-panel[hidden]{display:none!important}.photo-module-v501 .dialog-actions{justify-content:flex-end;margin-top:12px}
@media(max-width:900px){.finance-master-grid-v501{grid-template-columns:1fr}.travel-settings-card{margin-top:14px}}
@media(max-width:720px){.photo-module-v501 .grid.two{grid-template-columns:1fr}.photo-main-button{width:100%;min-height:58px}.photo-preview .actions,.photo-module-v501 .dialog-actions{display:grid;grid-template-columns:1fr;gap:10px}.photo-module-v501 select,.photo-module-v501 input{font-size:16px;min-height:44px}.timesheet-month-table{min-width:640px}}
