:root{
  --green:#9bc321;
  --gray-50:#f6f6f6;
  --gray-100:#ececec;
  --gray-300:#d4d4d4;
  --gray-500:#a8aaac;
  --gray-900:#171717;
  --bg:var(--gray-50);
  --surface:#fff;
  --text:var(--gray-900);
  --muted:#666;
  --radius:12px;
  --shadow:0 20px 60px rgba(0,0,0,.08);
}
body.theme-dark{
  --green:#9bc321;
  --gray-50:#0f1115;
  --gray-100:#1a1f2a;
  --gray-300:#2b3344;
  --gray-500:#9ca3af;
  --gray-900:#f4f4f5;
  --bg:#0b0d12;
  --surface:#161b24;
  --text:#f9fafb;
  --muted:#d1d5db;
  --shadow:0 20px 60px rgba(0,0,0,.5);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Montserrat', system-ui, -apple-system, 'Segoe UI', Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
}
a{color:var(--gray-900);text-underline-offset:3px}
.container{width:min(1080px,92vw);margin:0 auto;padding:28px}
.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
header.site{background:linear-gradient(180deg,#fff,#fafafa);border-bottom:1px solid var(--gray-100)}
header.site .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px}
.header-actions{display:flex;align-items:center;gap:10px}
.settings-dropdown{position:relative}
.icon-button{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border-radius:10px;border:1px solid var(--gray-300);background:#fff;font-size:18px;cursor:pointer;color:var(--green);padding:12px 16px}
.icon-button .icon{width:28px;height:28px;display:block}
.settings-button{gap:8px;min-width:auto;min-height:auto;padding:12px}
.settings-button .icon{width:22px;height:22px}
.settings-menu{position:absolute;top:calc(100% + 10px);right:0;min-width:180px;background:#fff;border:1px solid var(--gray-100);border-radius:10px;box-shadow:var(--shadow);padding:8px;display:none;z-index:20;color:var(--text)}
.settings-menu.open{display:block}
.settings-menu-item{display:flex;width:100%;background:none;border:none;padding:10px 12px;border-radius:8px;justify-content:flex-start;text-align:left;font-weight:700;cursor:pointer;color:var(--text)}
.settings-menu-item:hover,.settings-menu-item:focus{background:var(--gray-50);outline:none}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.06em}
.brand span{font-size:28px}
.brand .brand-logo{height:64px;width:auto;display:block}
.brand .mark{width:22px;height:22px;background:var(--green);border-radius:6px;box-shadow:0 0 0 3px rgba(155,195,33,.15)}
.brand-block{display:flex;flex-direction:column;gap:4px}
.brand-title{}
.brand-greeting{margin:0;font-weight:700;letter-spacing:.01em}
h1{font-weight:900;letter-spacing:.01em;margin:0 0 8px}
.auth-title{font-weight:900;letter-spacing:.01em;margin:0 0 8px;font-size:2em}
h2{font-weight:700;margin:16px 0 8px}
label{display:block;margin:14px 0 6px;font-weight:600}
input[type=text],input[type=password],input[type=email]{
  width:100%;padding:12px 14px;border:1px solid var(--gray-300);border-radius:10px;font-size:16px;outline:none
}
button,.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 16px;border-radius:10px;border:1px solid transparent;font-weight:700;cursor:pointer
}
.btn[aria-disabled="true"],.btn.is-disabled{opacity:.6;cursor:not-allowed}
.btn-stack{
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:4px;
}
.btn-stack .btn-label{font-size:inherit;}
.btn-stack .btn-count{font-size:inherit;color:#d00000;font-weight:700;line-height:1.2;}
.btn-primary{background:var(--green);color:#fff}
.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--gray-300)}
.tab-active{background:rgba(155,195,33,.25);border-color:var(--green);box-shadow:0 0 0 2px rgba(155,195,33,.18)}
body.theme-dark .tab-active{background:rgba(155,195,33,.35);}
.btn-danger{background:#b91c1c;color:#fff;border-color:#b91c1c}
.modal{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(0,0,0,.35);
  opacity:0;
  pointer-events:none;
  transition:opacity .15s ease-in-out;
  z-index:60;
}
.modal[aria-hidden="false"]{opacity:1;pointer-events:auto}
.modal-backdrop{position:absolute;inset:0}
.modal-dialog{
  position:relative;
  width:min(480px,100%);
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  z-index:1;
}
.modal-header,.modal-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px;border-bottom:1px solid var(--gray-100)}
.modal-footer{border-top:1px solid var(--gray-100);border-bottom:none;justify-content:flex-end}
.modal-body{padding:16px;font-size:15px}
.modal-close{background:none;border:none;font-size:22px;line-height:1;cursor:pointer;padding:4px;color:var(--muted)}
.modal-title{margin:0;font-size:18px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
#btn-capacity,#btn-orders,#btn-complaints,#btn-appointments{
  background:var(--surface);
  color:var(--text);
  border:2px solid var(--green);
}
#btn-orders .btn-count,#btn-complaints .btn-count,#btn-appointments .btn-count{color:var(--text)}
#btn-orders.tab-active,#btn-complaints.tab-active,#btn-appointments.tab-active,#btn-capacity.tab-active{
  background:rgba(155,195,33,.25);
  border-color:var(--green);
  box-shadow:0 0 0 2px rgba(155,195,33,.18);
}
.btn-meta{color:var(--muted);font-weight:600;}
.msg{margin-top:12px;color:#b91c1c;font-weight:600}
.muted{color:var(--muted)}
.auth{display:grid;place-items:center;min-height:100vh;
  background: linear-gradient(180deg,#fff 0,#f7f8f8 100%)
}
.auth-card{width:min(440px,92vw)}
/* dezente Solarform-Anmutung (abgerundete Kacheln) */
.solarform{
  --s:20px;
  background:none
}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:12px;border-bottom:1px solid var(--gray-100)}
.orders-table th,.orders-table td{padding:12px 18px}
.table th{text-align:left;color:var(--gray-500);font-size:14px}
.portal-table th{text-align:center}
.portal-table td{text-align:left}
.portal-table .sticky-left{position:sticky;left:0;background:var(--surface);z-index:2;box-shadow:2px 0 4px rgba(0,0,0,.04)}
.portal-table .sticky-right{position:sticky;right:0;background:var(--surface);z-index:2;box-shadow:-2px 0 4px rgba(0,0,0,.04)}
.portal-table .chat-cell{min-width:96px;display:flex;align-items:center;justify-content:flex-end;padding-right:12px}
.orders-table .toggle-cell{width:52px;text-align:center}
.toggle-details{border:none;background:none;cursor:pointer;font-size:18px;line-height:1;transition:transform .2s ease;transform:rotate(0deg);color:var(--text)}
.toggle-details.open{transform:rotate(-180deg)}
.order-details-row td{background:linear-gradient(90deg,rgba(0,0,0,.02),rgba(0,0,0,.02));padding:16px 12px;text-align:left}
.order-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 16px;text-align:left}
.order-detail-label{font-weight:700;color:var(--gray-500);margin-bottom:4px;font-size:14px;text-align:left}
.order-detail-value{white-space:pre-wrap;word-break:break-word;text-align:left}
.orders-table tbody tr:nth-child(even){background:linear-gradient(90deg,rgba(0,0,0,.015),rgba(0,0,0,.015))}
.glow{ text-shadow:0 0 22px rgba(155,195,33,.55) }
/* Floating Chat-Button */
.chat-button{
  position:fixed;
  right:24px;
  bottom:24px;
  width:56px;
  height:56px;
  border-radius:999px;
  border:none;
  background:var(--green);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:var(--shadow);
  cursor:pointer;
  font-size:24px;
  z-index:40;
}
.chat-button:hover{
  filter:brightness(1.05);
  transform:translateY(-1px);
}
.chat-button:disabled{
  opacity:.4;
  cursor:not-allowed;
}
.theme-dark header.site{background:linear-gradient(180deg,#1e2632,#161c24);border-bottom:1px solid var(--gray-300)}
.theme-dark .card,.theme-dark .settings-menu,.theme-dark .modal-dialog,.theme-dark .chat-modal-dialog{background:var(--surface);color:var(--text);border-color:var(--gray-300)}
.theme-dark .settings-menu{border:1px solid var(--gray-300)}
.theme-dark .modal-header,.theme-dark .modal-footer,.theme-dark .chat-header{border-color:var(--gray-300)}
.theme-dark .chat-modal-backdrop{background:rgba(0,0,0,.5)}
.theme-dark .chat-bubble{background:#1f2937;color:var(--text)}
.theme-dark .chat-message-me .chat-bubble{background:#0f172a;color:#fff}
.theme-dark .chat-system{color:var(--muted)}
.theme-dark .portal-table .sticky-left,.theme-dark .portal-table .sticky-right{background:var(--surface)}

/* Chat-Overlay */
.chat-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:flex-end;
  justify-content:flex-end;
  z-index:39;
  pointer-events:none;
}
.chat-modal.open{
  display:flex;
  pointer-events:auto;
}
.chat-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.25);
}
.chat-modal-dialog{
  position:relative;
  margin:0 24px 96px;
  width:min(420px,calc(100% - 48px));
  max-height:70vh;
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.chat-header{
  padding:10px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid var(--gray-100);
}
.chat-title{
  margin:0;
  font-size:15px;
}
.chat-close{
  border:none;
  background:transparent;
  font-size:20px;
  line-height:1;
  cursor:pointer;
}
.chat-messages{
  padding:12px 14px;
  background:var(--gray-50);
  overflow-y:auto;
  flex:1;
  font-size:14px;
}
.chat-system{
  margin:0;
  color:var(--muted);
  font-size:13px;
}
.chat-message{
  margin-bottom:10px;
}
.chat-message-me .chat-bubble{
  background:#e7f4ce;
}
.chat-meta{
  font-size:11px;
  color:var(--muted);
  margin-bottom:2px;
}
.chat-bubble{
  display:inline-block;
  padding:8px 12px;
  border-radius:16px;
  background:#fff;
  max-width:100%;
  word-wrap:break-word;
}
.chat-bubble a{
  color:var(--green);
  word-break:break-all;
}
.chat-image{
  margin-top:8px;
}
.chat-image img{
  max-width:100%;
  border-radius:12px;
  display:block;
}
.chat-form{
  display:flex;
  align-items:flex-end;
  gap:8px;
  padding:8px 10px 10px;
  border-top:1px solid var(--gray-100);
  background:#fff;
}
.chat-input{
  flex:1;
  min-height:40px;
  max-height:80px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--gray-300);
  font-family:inherit;
  font-size:14px;
  resize:vertical;
}
.chat-send-btn{
  border:none;
  border-radius:999px;
  padding:8px 16px;
  background:var(--green);
  color:#fff;
  font-weight:600;
  cursor:pointer;
}
.chat-send-btn:disabled{
  opacity:.6;
  cursor:not-allowed;
}
.order-chat-btn{position:relative;font-size:18px;padding:8px 12px;border:1px solid var(--green);border-radius:10px;background:var(--green);color:#fff;cursor:pointer}
.order-chat-btn.order-chat-unread::after{
  content:'';
  position:absolute;
  top:4px;
  right:4px;
  width:10px;
  height:10px;
  border-radius:50%;
  background:#d00000;
  box-shadow:0 0 0 2px #fff;
}
.orders-table th:last-child,
.orders-table td:last-child,
.complaints-table th:last-child,
.complaints-table td:last-child{ text-align:right }
.capacity-list{margin-top:16px;display:flex;flex-direction:column;gap:12px}
.capacity-partner{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--gray-200);border-radius:8px;background:var(--gray-50)}
.capacity-partner-info{flex:1;min-width:0}
.capacity-partner-name{font-weight:700}
.capacity-partner-meta{color:var(--muted);font-size:14px}
.capacity-calendar-wrapper{margin:0 0 12px 36px}
.capacity-layout{display:grid;grid-template-columns:minmax(120px,160px) 1fr;gap:12px;align-items:start}
.capacity-legend{border:1px solid var(--gray-200);border-radius:10px;padding:10px;background:#fff;display:flex;flex-direction:column;gap:10px}
.capacity-legend-title{font-weight:700;text-transform:uppercase;font-size:12px;color:var(--muted);letter-spacing:.4px}
.capacity-legend-list{display:flex;flex-direction:column;gap:6px}
.orders-legend .capacity-legend-list{flex-direction:row;flex-wrap:wrap}
.orders-legend .capacity-legend-item{text-align:center}
.capacity-legend-item{font-weight:700;border:1px solid var(--green);border-radius:8px;padding:10px;text-align:left;background:var(--green);color:#fff;cursor:pointer;transition:all .15s ease;box-shadow:0 6px 12px rgba(0,0,0,.08)}
.capacity-legend-item:hover,.capacity-legend-item:focus{outline:none;filter:brightness(1.05);box-shadow:0 8px 16px rgba(0,0,0,.1)}
.capacity-legend-item.active{background:#7d9e1c;border-color:var(--green);box-shadow:0 0 0 2px rgba(155,195,33,.25)}
.capacity-calendar{border:1px solid var(--gray-200);border-radius:10px;padding:10px;background:#fff}
.capacity-calendar-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.capacity-month{text-transform:capitalize;font-weight:700}
.capacity-weekdays,.capacity-grid{display:grid;grid-template-columns:repeat(6, minmax(80px,1fr));gap:6px}
.capacity-weekday{font-weight:700;text-align:center;color:var(--muted)}
.capacity-day{min-height:120px;border:1px solid var(--gray-200);border-radius:8px;padding:6px;display:flex;flex-direction:column;gap:6px;background:var(--gray-50)}
.capacity-day.empty{background:transparent;border-style:dashed}
.capacity-day-head{font-weight:700}
.capacity-day-values{display:flex;flex-direction:column;gap:8px}
.capacity-value-row{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:8px;align-items:flex-start}
.capacity-value-row.single-trade{grid-template-columns:1fr 1fr}
.capacity-cell.label{display:flex;align-items:center;font-size:13px;font-weight:600}
.capacity-cell.label.partner{color:var(--primary)}
.capacity-cell.label.admin{color:var(--danger);justify-content:flex-end;text-align:right}
.capacity-cell.value{display:flex;align-items:stretch}
.capacity-input{width:100%;border:1px solid var(--gray-300);border-radius:6px;padding:6px 8px;font-size:15px}
.capacity-input.partner{color:var(--primary);background:#f0f6ff;border-color:var(--primary)}
.capacity-input.admin{color:var(--danger);background:#fff5f5;border-color:var(--danger)}
.capacity-admin-value{padding:8px;border:1px solid var(--gray-200);border-radius:6px;color:var(--danger);background:#fff;width:100%}
.capacity-calendar .btn-icon{padding:6px 10px}
.session-timer{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--muted);flex-wrap:wrap}
.session-timer-value{font-variant-numeric:tabular-nums;font-weight:700;color:var(--danger)}
.order-action-bar{margin-top:12px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.order-action-bar .btn{min-width:220px}
