/* ===== Verkauf — extrahiert aus index.html <style> ===== */
  @import url('/shared/fonts/inter.css');
  *{margin:0;padding:0;box-sizing:border-box}
  :root{--bg:linear-gradient(145deg,#eef2f7 0%,#e4ecf4 25%,#dfe8f0 50%,#e8eef5 75%,#f0f4f8 100%);--nav-bg:rgba(255,255,255,0.55);--nav-border:rgba(255,255,255,0.5);--card-bg:rgba(255,255,255,0.45);--card-border:rgba(255,255,255,0.6);--card-hover-bg:rgba(255,255,255,0.65);--card-shadow:0 2px 16px rgba(0,0,0,0.04);--card-hover-shadow:0 12px 44px rgba(0,0,0,0.08);--text-primary:#1c1c1e;--text-secondary:#636366;--text-tertiary:#8e8e93;--badge-bg:rgba(4,179,214,0.1);--badge-color:#04b3d6;--toggle-bg:rgba(0,0,0,0.06);--toggle-knob:#fff;--accent:#04b3d6;--red:#ff453a;--green:#30d158;--yellow:#ffd60a;--orange:#ff9f0a}
  [data-theme="dark"]{--bg:linear-gradient(145deg,#0a0a1a 0%,#0f1528 20%,#151022 40%,#1a0f1e 60%,#12111a 80%,#0d1318 100%);--nav-bg:rgba(255,255,255,0.05);--nav-border:rgba(255,255,255,0.09);--card-bg:rgba(255,255,255,0.06);--card-border:rgba(255,255,255,0.1);--card-hover-bg:rgba(255,255,255,0.1);--card-shadow:0 2px 16px rgba(0,0,0,0.2);--card-hover-shadow:0 12px 44px rgba(0,0,0,0.3);--text-primary:#f5f5f7;--text-secondary:#a1a1a6;--text-tertiary:#636366;--badge-bg:rgba(4,179,214,0.15);--badge-color:#2cc5e4;--toggle-bg:rgba(255,255,255,0.1);--toggle-knob:#1c1c1e}
  body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'SF Pro Display',sans-serif;min-height:100vh;background:var(--bg);background-size:400% 400%;animation:gs 20s ease infinite;-webkit-font-smoothing:antialiased;transition:background .4s}
  @keyframes gs{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

  nav{position:sticky;top:0;z-index:200;background:var(--nav-bg);backdrop-filter:blur(44px) saturate(180%);-webkit-backdrop-filter:blur(44px) saturate(180%);border-bottom:1px solid var(--nav-border);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;transition:background .3s}
  .nav-left{display:flex;align-items:center;gap:10px;min-width:0;flex-shrink:1;overflow:hidden}
  .nav-logo{height:28px;width:auto}
  [data-theme="dark"] .nav-logo{filter:brightness(2.2) contrast(0.85)}
  .nav-brand{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px}
  .nav-divider{width:1px;height:18px;background:var(--nav-border);margin:0 2px}
  .nav-subtitle{font-size:12px;color:var(--text-secondary);font-weight:500}
  .nav-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
  .nav-back{font-size:13px;font-weight:500;color:var(--badge-color);text-decoration:none;padding:5px 10px;border-radius:8px;transition:all .2s}
  .nav-back:hover{background:var(--badge-bg)}
  .user-info{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:var(--text-secondary)}
  .user-dot{width:7px;height:7px;border-radius:50%;background:#30d158;flex-shrink:0}
  .logout-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:8px;border:1px solid var(--card-border);background:var(--toggle-bg);backdrop-filter:blur(20px);color:var(--text-secondary);font-size:12.5px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s}
  .logout-btn:hover{background:var(--card-hover-bg);color:var(--text-primary)}
  .theme-toggle{display:flex;align-items:center;gap:6px;cursor:pointer}
  .toggle-icon{font-size:14px;line-height:1}
  .toggle-track{width:44px;height:26px;border-radius:13px;background:var(--toggle-bg);backdrop-filter:blur(20px);border:1px solid var(--card-border);position:relative;transition:all .3s}
  .toggle-knob{width:20px;height:20px;border-radius:10px;background:var(--toggle-knob);position:absolute;top:2px;left:3px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 4px rgba(0,0,0,.15)}
  [data-theme="dark"] .toggle-knob{left:21px;background:#f5f5f7}

  .container{max-width:1200px;margin:0 auto;padding:32px 24px 60px}

  /* Tabs */
  .tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--toggle-bg);border-radius:12px;padding:3px;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tab{padding:8px 20px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
  .tab.active{background:var(--card-bg);backdrop-filter:blur(20px);color:var(--text-primary);box-shadow:var(--card-shadow)}
  .tab-content{display:none}
  .tab-content.active{display:block}

  /* Modul-Kacheln (analog Einkauf) */
  .section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
  .section-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;transition:color .3s}
  .modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:32px}
  .module-card{background:var(--card-bg);backdrop-filter:blur(60px) saturate(180%);-webkit-backdrop-filter:blur(60px) saturate(180%);border:1px solid var(--card-border);border-radius:18px;padding:22px 20px;box-shadow:var(--card-shadow);cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden;text-decoration:none;display:flex;flex-direction:column;gap:10px}
  .module-card::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 100%);border-radius:18px 18px 0 0;pointer-events:none}
  [data-theme="dark"] .module-card::before{background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,transparent 100%)}
  .module-card:hover{transform:translateY(-3px);box-shadow:var(--card-hover-shadow);background:var(--card-hover-bg)}
  .module-card:active{transform:translateY(-1px)}
  .module-card-icon{font-size:32px;line-height:1}
  .module-card-body{position:relative;z-index:1}
  .module-card-name{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:-.3px;margin-bottom:3px;transition:color .3s}
  .module-card-sub{font-size:12px;color:var(--text-secondary);transition:color .3s}
  .module-card-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:7px;font-size:11.5px;font-weight:600;background:var(--badge-bg);color:var(--badge-color);align-self:flex-start;position:relative;z-index:1}
  @media(max-width:768px){.modules-grid{grid-template-columns:repeat(2,1fr);gap:10px}.module-card{padding:18px 14px}}

  /* Stat Cards */
  .status-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
  .stat-card{background:var(--card-bg);backdrop-filter:blur(60px) saturate(180%);border:1px solid var(--card-border);border-radius:16px;padding:18px 20px;box-shadow:var(--card-shadow);position:relative;overflow:hidden;cursor:pointer;transition:all .2s}
  .stat-card:hover{box-shadow:var(--card-hover-shadow);transform:translateY(-1px)}
  .stat-card.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}
  .stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,transparent 100%);border-radius:16px 16px 0 0;pointer-events:none}
  [data-theme="dark"] .stat-card::before{background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,transparent 100%)}
  .stat-label{font-size:12px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
  .stat-value{font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-1px;line-height:1}

  /* Toolbar */
  .toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}
  .search-box{flex:1;min-width:200px;max-width:400px;padding:8px 14px;border-radius:12px;border:1px solid var(--card-border);background:var(--card-bg);backdrop-filter:blur(20px);color:var(--text-primary);font-size:13px;font-family:inherit;outline:none;transition:all .2s}
  .search-box:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(4,179,214,.15)}
  .btn{padding:8px 16px;border-radius:10px;border:1px solid var(--card-border);background:var(--card-bg);backdrop-filter:blur(20px);color:var(--text-primary);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}
  .btn:hover{background:var(--card-hover-bg);box-shadow:var(--card-shadow)}
  .btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
  .btn.primary:hover{opacity:.9}
  .btn.danger{color:var(--red);border-color:rgba(255,69,58,.3)}
  .btn.danger:hover{background:rgba(255,69,58,.1)}
  .btn-group{display:flex;gap:8px;flex-wrap:wrap}

  /* Table */
  .table-wrap{background:var(--card-bg);backdrop-filter:blur(60px) saturate(180%);border:1px solid var(--card-border);border-radius:16px;overflow:hidden;box-shadow:var(--card-shadow)}
  table{width:100%;border-collapse:collapse}
  th{padding:12px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--card-border);background:var(--toggle-bg)}
  td{padding:12px 16px;font-size:13px;color:var(--text-primary);border-bottom:1px solid rgba(0,0,0,.03)}
  [data-theme="dark"] td{border-bottom-color:rgba(255,255,255,.04)}
  tr:hover td{background:var(--card-hover-bg)}
  tr.clickable{cursor:pointer}
  .geo-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px}
  .geo-dot.exact,.geo-dot.manual{background:var(--green)}
  .geo-dot.interpolated,.geo-dot.approximate{background:var(--yellow)}
  .geo-dot.failed,.geo-dot.none{background:var(--red)}
  .geo-dot.incomplete{background:var(--orange)}
  .tour-chip{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:600;color:#fff}

  /* Progress */
  .progress-wrap{margin:16px 0;display:none}
  .progress-bar{width:100%;height:8px;border-radius:4px;background:var(--toggle-bg);overflow:hidden}
  .progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s}
  .progress-text{font-size:12px;color:var(--text-secondary);margin-top:6px}

  /* Touren Layout */
  .touren-layout{display:flex;gap:20px;min-height:400px}
  .touren-list{width:300px;flex-shrink:0}
  .touren-detail{flex:1;min-width:0}
  .tour-item{background:var(--card-bg);backdrop-filter:blur(20px);border:1px solid var(--card-border);border-radius:12px;padding:14px 16px;margin-bottom:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:12px}
  .tour-item:hover{background:var(--card-hover-bg)}
  .tour-item.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}
  .tour-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}
  .tour-meta{flex:1;min-width:0}
  .tour-name{font-size:14px;font-weight:600;color:var(--text-primary)}
  .tour-info{font-size:11px;color:var(--text-tertiary);margin-top:2px}
  .wochentag-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:600;background:var(--badge-bg);color:var(--badge-color);margin-right:3px}

  /* Stop List */
  .stop-list{background:var(--card-bg);backdrop-filter:blur(60px);border:1px solid var(--card-border);border-radius:16px;overflow:hidden}
  .stop-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.03);transition:background .2s}
  [data-theme="dark"] .stop-item{border-bottom-color:rgba(255,255,255,.04)}
  .stop-item:last-child{border-bottom:none}
  .stop-pos{font-size:13px;font-weight:700;color:var(--accent);width:24px;text-align:center;flex-shrink:0}
  .stop-info{flex:1;min-width:0}
  .stop-name{font-size:13px;font-weight:600;color:var(--text-primary)}
  .stop-addr{font-size:11px;color:var(--text-tertiary);margin-top:2px}
  .stop-actions{display:flex;gap:4px;flex-shrink:0}
  .stop-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--card-border);background:var(--toggle-bg);color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
  .stop-btn:hover{background:var(--card-hover-bg);color:var(--text-primary)}
  .stop-btn.remove:hover{color:var(--red);border-color:rgba(255,69,58,.3)}

  /* Map */
  #kunden-map{width:100%;height:500px;border-radius:16px;border:1px solid var(--card-border);overflow:hidden}
  .map-controls{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;align-items:center}
  .map-legend{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--text-secondary)}
  .map-legend-item{display:flex;align-items:center;gap:4px}
  .legend-dot{width:10px;height:10px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.2)}

  /* Auswertung */
  .chart-container{background:var(--card-bg);backdrop-filter:blur(60px);border:1px solid var(--card-border);border-radius:16px;padding:20px;margin-top:20px}
  #verweildauer-chart{max-height:300px}

  /* Modal */
  .modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(8px);z-index:1000;align-items:center;justify-content:center}
  .modal-overlay.open{display:flex}
  .modal{background:var(--card-bg);backdrop-filter:blur(60px) saturate(200%);border:1px solid var(--card-border);border-radius:20px;padding:28px;max-width:480px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 24px 80px rgba(0,0,0,.2)}
  .modal h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:20px}
  .form-group{margin-bottom:16px}
  .form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
  .form-input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--card-border);background:var(--toggle-bg);color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;transition:all .2s}
  .form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(4,179,214,.15)}
  select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23636366' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
  .color-picker{display:flex;gap:6px;flex-wrap:wrap}
  .color-opt{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all .2s}
  .color-opt:hover,.color-opt.active{border-color:var(--text-primary);transform:scale(1.15)}
  .weekday-picker{display:flex;gap:4px}
  .weekday-btn{padding:6px 10px;border-radius:8px;border:1px solid var(--card-border);background:var(--toggle-bg);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
  .weekday-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}

  /* Toast */
  .toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);padding:12px 24px;border-radius:12px;font-size:13px;font-weight:500;color:#fff;z-index:2000;opacity:0;transition:opacity .3s;pointer-events:none}
  .toast.show{opacity:1}
  .toast.success{background:#30d158}
  .toast.error{background:#ff453a}
  .toast.info{background:var(--accent)}

  /* Mobile */
  @media(max-width:768px){
    .container{padding:20px 16px 60px}
    .status-grid{grid-template-columns:repeat(2,1fr);gap:10px}
    .toolbar{flex-direction:column;align-items:stretch}
    .search-box{max-width:none}
    table{font-size:12px}
    th,td{padding:8px 10px}
    .touren-layout{flex-direction:column}
    .touren-list{width:100%}
    .touren-detail.hidden-mobile{display:none}
    .touren-list.hidden-mobile{display:none}
    .back-to-list{display:inline-flex!important}
    #kunden-map{height:350px}
    .stat-value{font-size:22px}
    .stop-btn{width:40px;height:40px;font-size:16px}
  }
  .back-to-list{display:none;margin-bottom:12px}
  @media(min-width:769px){.back-to-list{display:none!important}}


/* CSP-Helper-Klassen (loesen inline style="..." ab) */
.btn-cancel-spaced { margin-top: 8px; }
.map-edit-label {
  font-size: 12px;
  color: var(--text-secondary);
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 4px;
}
.kunden-tabelle-empty {
  text-align: center;
  color: var(--text-tertiary);
  padding: 40px;
}
.kunden-tour-empty { color: var(--text-tertiary); }
.kunden-geo-label {
  font-size: 11px;
  color: var(--text-tertiary);
}
.tour-chip-dyn { background: var(--tour-color, #888); }
.legend-dot-dyn { background: var(--legend-color, #888); }
.stat-value.color-green { color: var(--green); }
.stat-value.color-red { color: var(--red); }
.stat-value.color-orange { color: var(--orange); }

/* Hinweis-Zeile */
.hint-line {
  font-size: 12px;
  color: var(--text-tertiary);
  margin: 6px 0 14px;
}

/* Klickbare Liste */
tr.clickable { cursor: pointer; transition: background .15s; }
tr.clickable:hover { background: var(--card-hover-bg); }
.popup-link { color: var(--accent); text-decoration: none; font-weight: 600; }
.popup-link:hover { text-decoration: underline; }

/* ===== Kunden-Detail ===== */
.kunde-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.kunde-titel {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -.4px;
  margin-bottom: 4px;
}
.kunde-sub {
  font-size: 13px;
  color: var(--text-secondary);
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.kunde-id {
  font-family: 'SF Mono', Menlo, monospace;
  font-size: 12px;
  background: var(--badge-bg);
  color: var(--badge-color);
  padding: 2px 8px;
  border-radius: 6px;
}
.kunde-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.kunde-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 18px;
}
@media (max-width: 900px) {
  .kunde-grid { grid-template-columns: 1fr; }
}
.kunde-card {
  background: var(--card-bg);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 1px solid var(--card-border);
  border-radius: 16px;
  padding: 18px 20px;
  box-shadow: var(--card-shadow);
}
.kunde-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--card-border);
}
.kunde-card-title { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.kunde-card-tag {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 3px 9px;
  border-radius: 6px;
  background: var(--toggle-bg);
  color: var(--text-tertiary);
}
.kunde-card-tag.ok { background: rgba(48,209,88,.15); color: var(--green); }
.kunde-card-tag.warn { background: rgba(255,159,10,.15); color: var(--orange); }

.kunde-card-body { font-size: 13px; color: var(--text-primary); }
.kunde-card-body .muted { color: var(--text-tertiary); font-style: italic; }
.kunde-card-body .error { color: var(--red); }

dl.kv {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 8px 14px;
}
@media (max-width: 480px) {
  dl.kv { grid-template-columns: 105px 1fr; gap: 6px 10px; }
}
dl.kv dt {
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 500;
}
dl.kv dd {
  color: var(--text-primary);
  font-size: 13px;
  word-break: break-word;
}

/* Sync-Diff-Tabelle */
.sync-card { margin-bottom: 24px; overflow-x: auto; }
.diff-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  min-width: 480px;
}
.diff-table th, .diff-table td {
  padding: 8px 10px;
  text-align: left;
  border-bottom: 1px solid var(--card-border);
}
.diff-table th {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-secondary);
  font-weight: 600;
}
.diff-table tr.ok td:last-child { color: var(--green); }
.diff-table tr.diff td:last-child { color: var(--orange); font-weight: 600; }
.diff-table tr.muted td { color: var(--text-tertiary); }
