:root{
    --red:#e2001a;--red-dark:#b50015;
    --bg:#f5f5f3;--surface:#fff;--surface2:#f0efed;
    --border:#e0deda;--border2:#cccac5;
    --text:#1a1a18;--text2:#5a5a56;--text3:#999890;
    --radius:10px;--rsm:6px;
    --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 8px rgba(0,0,0,.04);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  body{padding-bottom:28px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}
  #app{max-width:920px;margin:0 auto;padding:1.5rem 1rem}
  .view{display:none}.view.active{display:block}
  .page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
  .brand{display:flex;align-items:center;gap:10px;margin-bottom:6px}
  .brand-logo{width:44px;height:44px;object-fit:contain;border-radius:6px;flex-shrink:0}
  .brand-label{font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:var(--text2);font-weight:600}
  .page-title{font-size:22px;font-weight:600}
  .page-sub{font-size:13px;color:var(--text2);margin-top:3px}
  .storage-badge{font-size:11px;margin-top:4px;display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:10px;border:1px solid transparent}
  .storage-badge.server{color:#3b6d11;background:#eaf3de;border-color:#c5e0a0}
  .storage-badge.local{color:#854f0b;background:#faeeda;border-color:#e8cb90}
  .storage-badge.checking{color:var(--text3);background:var(--surface2);border-color:var(--border)}
  .stat-big{font-size:32px;font-weight:700;line-height:1;text-align:right}
  .stat-big.done{color:#3b6d11}
  .stat-label{font-size:11px;color:var(--text3);margin-top:3px;text-align:right}
  .station-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin-bottom:1rem}
  .station-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:11px 13px;transition:border-color .15s,box-shadow .15s}
  .station-card:hover{border-color:var(--border2);box-shadow:var(--shadow)}
  .station-card.complete{border-color:#a0c96a}
  .station-card.sc-locked{border-color:#f59e0b;background:linear-gradient(135deg,var(--surface) 80%,#fffbeb 100%)}
  .station-card.sc-finallocked{border-color:#dc2626;background:linear-gradient(135deg,var(--surface) 80%,#fff5f5 100%)}
  /* Kategorie-Badge */
  .sc-category{margin-top:3px}
  .sc-cat-badge{display:inline-block;font-size:10px;font-weight:600;background:#e3f2fd;color:#1565c0;border-radius:3px;padding:1px 6px;letter-spacing:.01em}
  /* Lock-Badge (Statusanzeige oben auf der Karte) */
  .sc-lock-badge{position:absolute;top:4px;left:4px;border-radius:10px;padding:2px 7px;font-size:10px;font-weight:700;z-index:1}
  .sc-lock-mat{background:#f59e0b;color:#fff}
  .sc-lock-final{background:#dc2626;color:#fff}
  .sc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:7px}
  .sc-num-label{font-size:10px;color:var(--text3)}
  .sc-num{font-size:19px;font-weight:700;line-height:1.1}
  .sc-check{color:#3b6d11;font-size:17px}
  .sc-pct{font-size:12px;color:var(--text2)}
  .sc-name{font-size:11px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:3px}
  .sc-pos{font-size:11px;color:var(--text3);margin-top:2px}
  .sc-actions{display:flex;gap:4px;margin-top:7px;border-top:1px solid var(--border);padding-top:6px;flex-wrap:wrap}
  .sc-btn{flex:1;background:none;border:none;font-size:12px;color:var(--text3);cursor:pointer;padding:3px 0;border-radius:4px;font-family:inherit}
  .sc-btn:hover{background:var(--surface2);color:var(--text2)}
  .sc-btn.danger:hover{color:var(--red);background:#fff5f5}
  /* Schnell-Lock-Buttons */
  .sc-btn-lock{flex:none;padding:3px 8px;font-weight:600;border-radius:4px;border:none;cursor:pointer;font-size:11px;font-family:inherit}
  .sc-btn-dolock{background:#fff3cd;color:#92400e}.sc-btn-dolock:hover{background:#f59e0b;color:#fff}
  .sc-btn-unlock{background:#dcfce7;color:#166534}.sc-btn-unlock:hover{background:#16a34a;color:#fff}
  .sc-btn-final{background:#fee2e2;color:#991b1b}.sc-btn-final:hover{background:#dc2626;color:#fff}
  .sc-btn-reopen{background:#dbeafe;color:#1e40af}.sc-btn-reopen:hover{background:#2563eb;color:#fff}
  .prog-track{height:3px;background:var(--surface2);border-radius:2px;overflow:hidden}
  .prog-fill{height:3px;border-radius:2px;transition:width .3s}
  .prog-fill.red{background:var(--red)}.prog-fill.green{background:#63991a}
  .legend{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:.75rem}
  .legend-hint{margin-left:auto;font-size:11px;color:var(--text3)}
  .btn{display:inline-flex;align-items:center;gap:5px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--rsm);padding:7px 13px;font-size:13px;color:var(--text);cursor:pointer;font-family:inherit;transition:background .1s;touch-action:manipulation}
  .btn:hover{background:var(--surface2)}
  .btn-red{background:var(--red);color:#fff;border-color:var(--red)}
  .btn-red:hover{background:var(--red-dark)}
  .btn-ghost{background:transparent;border-color:transparent;padding:5px 7px;color:var(--text3)}
  .btn-ghost:hover{background:var(--surface2);color:var(--text2);border-color:transparent}
  .inp{width:100%;background:var(--surface);border:1px solid var(--border2);border-radius:var(--rsm);padding:7px 12px;font-size:16px;color:var(--text);font-family:inherit;outline:none}
  .inp:focus{border-color:var(--red)}
  .inp-row{display:flex;gap:8px}.inp-row .inp{flex:1}
  select.inp{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23aaa' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:26px;cursor:pointer}
  .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:8px;box-shadow:var(--shadow)}
  .card-row{display:flex;flex-wrap:nowrap;align-items:center;padding:7px 10px;gap:7px;border-bottom:1px solid var(--border)}
  .map-mode-btn{background:var(--surface2);color:var(--text2);border:1px solid var(--border);border-radius:var(--rsm);padding:5px 12px;font-size:12px;cursor:pointer;font-family:inherit;transition:all .15s;font-weight:500}
  .map-mode-btn:hover{border-color:var(--red)}
  .map-mode-btn.active{background:var(--red);color:#fff;border-color:var(--red);font-weight:700;box-shadow:0 1px 3px rgba(204,0,0,.3)}
  .card-row:last-child{border-bottom:none}
  .row-name{order:1;flex:1 1 auto;min-width:140px;font-size:13px;color:var(--text);line-height:1.35;word-break:break-word}
  .row-qty{order:2;width:56px;flex-shrink:0;background:var(--surface2);border:1px solid var(--border);border-radius:var(--rsm);padding:4px 6px;font-size:16px;color:var(--text);font-family:inherit;outline:none;text-align:center}
  .row-qty:focus{border-color:var(--red);background:var(--surface)}
  .row-qty::placeholder{color:var(--text3)}
  .row-qty-ro{order:2;width:56px;flex-shrink:0;text-align:center;font-size:13px;color:var(--text2);padding:4px 6px}
  .row-note{flex:0 1 220px;order:5;width:220px;min-width:120px;margin:0;font-size:12px;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:var(--rsm);padding:4px 8px;font-family:inherit;outline:none;line-height:1.4;box-sizing:border-box;resize:none;overflow:hidden;min-height:30px}
  .row-note:focus{border-color:var(--red);background:var(--surface);flex:1 1 300px}
  .row-note:focus{border-color:var(--red);background:var(--surface)}
  .row-note::placeholder{color:var(--text3)}
  .row-note-ro{flex:1 1 auto;min-width:60px;font-size:12px;color:var(--text3);font-style:italic;padding:2px 6px;line-height:1.4;order:5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .row-unit-ro{order:3;min-width:70px;max-width:110px;flex-shrink:0;font-size:12px;color:var(--text2);padding:4px 4px}
  .badge.static{pointer-events:none;cursor:default}
  .row-unit{order:3;flex-shrink:0;background:var(--surface2);border:1px solid var(--border);border-radius:var(--rsm);padding:4px 20px 4px 7px;font-size:12px;color:var(--text2);font-family:inherit;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23aaa' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 5px center;max-width:110px;min-width:70px}
  .row-unit:focus{border-color:var(--red);background:var(--surface)}
  .row-actions{order:7;display:flex;gap:2px;flex-shrink:0}
  .card-row > .badge{order:4}
  .row-header{display:flex;align-items:center;padding:2px 10px 4px;gap:7px}
  .rh-drag{width:18px;flex-shrink:0}
  .rh-name{flex:1;font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px}
  .rh-qty{width:56px;flex-shrink:0;font-size:10px;color:var(--text3);text-align:center;text-transform:uppercase;letter-spacing:.6px}
  .rh-unit{min-width:70px;max-width:110px;flex-shrink:0;font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px}
  .rh-stat{width:118px;flex-shrink:0;font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px}
  .rh-act{width:60px;flex-shrink:0}
  .badge{display:inline-flex;align-items:center;border:none;border-radius:4px;padding:3px 9px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:opacity .1s;flex-shrink:0;touch-action:manipulation;min-height:28px}
  .badge:hover{opacity:.85}
  .badge.static{cursor:default}.badge.static:hover{opacity:1}
  .section-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.7px;margin-bottom:6px;margin-top:1.25rem}
  .detail-header{display:flex;align-items:center;gap:10px;margin-bottom:1rem;flex-wrap:wrap}
  /* ── Station Lock UI ─────────────────────────────────────────── */
  .station-locked-banner{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:8px;margin-bottom:1rem;font-size:13px;animation:lockSlideIn .3s ease}
  .station-locked-banner.locked-material{background:linear-gradient(90deg,#fff8e1,#fffde7);border:1.5px solid #f59e0b;color:#7c2d12}
  .station-locked-banner.locked-final{background:linear-gradient(90deg,#fee2e2,#fef2f2);border:1.5px solid #dc2626;color:#7f1d1d;box-shadow:0 1px 3px rgba(220,38,38,.1)}
  @keyframes lockSlideIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
  .mat-section.locked,.card.locked,.station-tab-pane.locked,#info-stationsort.locked,#info-ansprechpartner.locked,#info-erreichbar.locked,#info-category-wrap.locked,#info-coords-input.locked,#info-coords-lat.locked,#info-coords-lng.locked,#detail-title-wrap.locked{opacity:.55;pointer-events:none;filter:grayscale(.5);transition:opacity .25s,filter .25s}
  .mat-section.locked .badge,.card.locked .badge,.station-tab-pane.locked .badge{cursor:not-allowed!important}
  .detail-title{font-size:18px;font-weight:600;flex:1}
  .detail-sub{font-size:12px;color:var(--text2);margin-top:2px}
  .edit-inline{display:flex;gap:6px;flex:1;align-items:center}
  .edit-inline .inp{font-size:16px;font-weight:600}
  .info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.25rem;overflow:hidden;display:grid;grid-template-columns:repeat(3,1fr)}
  .info-field{padding:10px 14px;border-right:1px solid var(--border)}
  .info-field:last-child{border-right:none}
  .info-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:4px}
  .info-inp{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border2);padding:1px 0;font-size:13px;color:var(--text);font-family:inherit;outline:none}
  .info-inp:focus{border-bottom-color:var(--red)}
  .settings-panel{background:var(--surface2);border:1px dashed var(--border2);border-radius:var(--rsm);padding:12px 14px;margin-top:8px}
  .status-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}
  .status-row:last-child{border-bottom:none}
  .status-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:1.5px solid rgba(0,0,0,.1)}
  .status-lbl{flex:1;font-size:13px}
  .status-lbl-inp{flex:1;font-size:13px;background:var(--surface);border:1px solid var(--border2);border-radius:4px;padding:2px 7px;font-family:inherit;outline:none}
  .status-lbl-inp:focus{border-color:var(--red)}
  .color-grid{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
  .color-dot{width:20px;height:20px;border-radius:50%;cursor:pointer;border:2px solid transparent;flex-shrink:0;transition:transform .1s}
  .color-dot:hover{transform:scale(1.2)}
  .color-dot.selected{border-color:var(--text);transform:scale(1.15)}
  .unit-mgr{background:var(--surface2);border:1px dashed var(--border2);border-radius:var(--rsm);padding:10px 14px;margin-top:6px}
  .unit-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:28px}
  .unit-chip{display:inline-flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:3px 10px;font-size:12px;color:var(--text2)}
  .unit-chip.def{color:var(--text3)}
  .chip-del{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;line-height:1;padding:0 0 0 2px}
  .chip-del:hover{color:var(--red)}
  .drag-handle{order:0;flex-shrink:0;color:var(--text3);cursor:grab;font-size:15px;padding:0 4px 0 2px;user-select:none;line-height:1;touch-action:none}
  .drag-handle:active{cursor:grabbing}
  .card-row.drag-over-top{border-top:2px solid var(--red)!important}
  .card-row.drag-over-bot{border-bottom:2px solid var(--red)!important}
  .card-row.dragging{opacity:.35}
  .notice{font-size:11px;color:var(--text3);margin-top:4px}
  .add-station-btn{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--surface);border:1.5px dashed var(--border2);border-radius:var(--radius);padding:12px;font-size:13px;color:var(--text2);cursor:pointer;width:100%;font-family:inherit;transition:background .1s,border-color .1s}
  .add-station-btn:hover{background:var(--surface2);border-color:var(--border);color:var(--text)}
  .print-frame{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;max-width:700px;box-shadow:var(--shadow)}
  .print-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:3px solid var(--red);margin-bottom:1rem}
  .print-header-left{display:flex;align-items:center;gap:12px}
  .print-logo{width:56px;height:56px;object-fit:contain;flex-shrink:0}
  .print-station{font-size:24px;font-weight:700}
  .print-meta{text-align:right;font-size:12px;color:var(--text2)}
  .print-info{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:1.25rem}
  .pi-cell{padding:8px 14px;border-right:1px solid var(--border)}
  .pi-cell:last-child{border-right:none}
  .pi-label{font-size:10px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.7px;margin-bottom:3px}
  .pi-val{font-size:13px}
  .print-section{font-size:11px;font-weight:600;color:#5a5a56;text-transform:uppercase;letter-spacing:.7px;margin:1rem 0 6px}
  .print-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:.5rem}
  .print-table th{font-size:10px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.6px;padding:0 0 6px;border-bottom:1px solid var(--border);text-align:left}
  .print-table th.cb,.print-table .td-cb{text-align:center;width:70px}
  .print-table td{padding:6px 0;border-bottom:1px solid var(--border);vertical-align:middle}
  .print-table tr:last-child td{border-bottom:none}
  .print-table .td-qty{text-align:center;width:55px;color:#5a5a56}
  .print-table .td-unit{width:85px;color:#5a5a56}
  .cb-wrap{display:inline-flex;align-items:center;justify-content:center}
  .cb-wrap input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--red);margin:0}
  .print-footer{font-size:10px;color:var(--text3);display:flex;justify-content:space-between;padding-top:8px;border-top:1px solid var(--border);margin-top:1.5rem}
  #modal{position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center}
  #modal.open{display:flex}
  #mbdrop{position:absolute;inset:0;background:rgba(0,0,0,.4)}
  #mbox{position:relative;background:var(--surface);border-radius:14px;padding:1.5rem;max-width:420px;width:92%;box-shadow:0 10px 40px rgba(0,0,0,.25);max-height:90vh;overflow-y:auto}
  #mtitle{font-size:16px;font-weight:600;margin-bottom:.4rem}
  #mdesc{font-size:13px;color:var(--text2);margin-bottom:1rem;line-height:1.5}
  #mbtns{display:flex;flex-direction:column;gap:8px}
  .mbtn{width:100%;text-align:left;padding:10px 14px;border-radius:var(--rsm);border:1px solid var(--border2);background:var(--surface);font-size:13px;cursor:pointer;font-family:inherit;transition:background .1s}
  .mbtn:hover{background:var(--surface2)}
  .mbtn .mbtn-sub{font-size:11px;color:var(--text3);display:block;margin-top:1px}
  .mbtn.danger{border-color:#f09595;color:var(--red)}.mbtn.danger:hover{background:#fff5f5}
  .mbtn.primary{border-color:#85b7eb;color:#185fa5}.mbtn.primary:hover{background:#e6f1fb}
  .mbtn.cancel{color:var(--text3);text-align:center}
  .modal-sep{height:1px;background:var(--border);margin:4px 0}
  .modal-inp{width:100%;margin-top:8px}
  #toast{position:fixed;bottom:20px;right:20px;background:#27500a;color:#eaf3de;font-size:12px;padding:6px 14px;border-radius:6px;opacity:0;transition:opacity .3s;pointer-events:none;z-index:9999}
  #toast.show{opacity:1}
  .flex{display:flex;gap:8px;align-items:center}.mt{margin-top:1rem}.text-muted{color:var(--text2)}
  /* ── Tablet (max 768px) ── */
  @media(max-width:768px){
    #app{padding:1rem .75rem}
    .station-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px}
    .page-title{font-size:19px}
    .stat-big{font-size:26px}
  }

  /* ── Mobile (max 580px) ── */
  @media(max-width:580px){
    #app{padding:.75rem .5rem}

    /* Header */
    .page-header{gap:.5rem}
    .page-title{font-size:17px}
    .stat-big{font-size:22px}
    .brand-logo{width:36px;height:36px}
    .storage-badge{font-size:10px;padding:2px 6px}

    /* Station grid: 2 columns on mobile */
    .station-grid{grid-template-columns:repeat(2,1fr);gap:6px}
    .sc-num{font-size:17px}
    .sc-btn{font-size:11px;padding:2px 0}

    /* Info card stacks */
    .info-card{grid-template-columns:1fr}
    .info-field{border-right:none;border-bottom:1px solid var(--border)}
    .info-field:last-child{border-bottom:none}

    /* Detail header */
    .detail-header{gap:6px}
    .detail-title{font-size:15px}
    .btn{padding:6px 10px;font-size:12px}
    .btn-red{padding:6px 10px;font-size:12px}

    /* Row headers hidden on mobile */
    .row-header{display:none!important}

    /* Material rows: 2-line mobile layout */
    .card-row{flex-wrap:wrap;padding:9px 10px;gap:6px;align-items:center}
    .drag-handle{order:0;font-size:18px;padding:0 2px}
    .row-name{order:1;flex:1;font-size:13px;font-weight:500;min-width:0}
    .badge{order:2;font-size:11px;padding:3px 8px}
    .row-qty{order:3;width:52px;flex-shrink:0;margin-top:0}
    .row-unit{order:4;flex:1;max-width:none;min-width:0;margin-top:0}
    .row-actions{order:5;gap:0;flex-shrink:0}
    .row-note,.row-note-ro{order:6;flex:1 1 100%;min-width:0;margin-top:4px}
    .btn-ghost{padding:5px 6px;font-size:14px}

    /* Second line: qty + unit + actions take full width */
    .row-qty,.row-unit,.row-actions{margin-top:2px}

    /* Section labels */
    .section-label{font-size:10px;margin-top:1rem}

    /* Input rows */
    .inp-row{flex-wrap:wrap}
    .inp-row .inp{min-width:0}
    .inp-row .btn{flex-shrink:0}

    /* Print info stacks */
    .print-info{grid-template-columns:1fr}
    .pi-cell{border-right:none;border-bottom:1px solid var(--border)}
    .pi-cell:last-child{border-bottom:none}

    /* Modal */
    #mbox{padding:1.25rem;border-radius:10px}
    #mtitle{font-size:15px}
    .mbtn{padding:10px 12px;font-size:13px}

    /* Overview export/import buttons */
    .export-row{flex-wrap:wrap;justify-content:flex-end}

    /* Unit chips */
    .unit-chips{gap:4px}
    .unit-chip{font-size:11px;padding:2px 8px}

    /* Legend */
    .legend{gap:6px}
    .badge.static{font-size:10px;padding:2px 7px}

    /* Progress bar slightly taller on mobile for touch */
    .prog-track{height:4px}
  }

  /* ── Very small phones (max 380px) ── */
  @media(max-width:380px){
    .station-grid{grid-template-columns:repeat(2,1fr)}
    .sc-num{font-size:15px}
    .page-title{font-size:15px}
  }
  @media print{
    body{background:#fff;font-size:12px}#app{padding:0;max-width:100%}
    .no-print{display:none!important}
    .print-frame{box-shadow:none;border:none;padding:0}
    .view{display:block!important}
    #view-overview,#view-station{display:none!important}
    #view-print{display:block!important}
    .cb-wrap input[type=checkbox]{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  }

  /* ── Login & Auth ── */
  #login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:none;z-index:10000;align-items:center;justify-content:center}
  #login-overlay.show{display:flex}
  .login-box{background:var(--bg);padding:2rem;border-radius:var(--radius);box-shadow:0 10px 40px rgba(0,0,0,.3);width:90%;max-width:320px}
  .login-title{font-size:20px;font-weight:700;margin-bottom:1.5rem;text-align:center;color:var(--text)}
  .login-field{margin-bottom:1.2rem}
  .login-label{display:block;font-size:12px;font-weight:600;margin-bottom:4px;color:var(--text2)}
  .login-input{width:100%;padding:8px 12px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--rsm);font-size:13px;font-family:inherit}
  .login-input:focus{outline:none;border-color:var(--red)}
  .login-error{color:var(--red);font-size:11px;margin-top:4px}
  .login-btn{width:100%;padding:10px;background:var(--red);color:#fff;border:none;border-radius:var(--rsm);font-weight:600;cursor:pointer;font-size:13px}
  .login-btn:hover{opacity:.9}
  .login-footer{font-size:11px;color:var(--text3);text-align:center;margin-top:1rem}

  /* ── Admin Panel ── */
  .admin-panel{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}
  .admin-title{font-size:14px;font-weight:700;margin-bottom:1rem;color:var(--text)}
  .admin-tabs{display:flex;gap:8px;border-bottom:1px solid var(--border);margin-bottom:1rem;flex-wrap:wrap}
  .admin-tab{padding:8px 12px;border-bottom:2px solid transparent;cursor:pointer;font-size:12px;color:var(--text2);font-weight:500}
  .admin-tab.active{color:var(--red);border-bottom-color:var(--red)}
  .admin-content{display:none}
  .admin-content.active{display:block}

  /* ── Users Management ── */
  .user-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}
  .user-item{display:flex;gap:10px;padding:10px;background:var(--surface2);border-radius:var(--rsm);border:1px solid var(--border);align-items:center}
  .user-info{flex:1}
  .user-name{font-weight:600;font-size:13px;color:var(--text)}
  .user-meta{font-size:11px;color:var(--text3)}
  .user-badge{display:inline-block;padding:2px 6px;background:var(--red);color:#fff;border-radius:3px;font-size:10px;font-weight:600;white-space:nowrap}
  .user-actions{display:flex;gap:4px}
  .user-btn{padding:4px 8px;font-size:11px;border:none;background:var(--border);cursor:pointer;border-radius:3px}
  .user-btn.danger{background:var(--red);color:#fff}

  /* ── Roles Management ── */
  .role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:1rem}
  .role-card{background:var(--surface2);border:1px solid var(--border);padding:12px;border-radius:var(--rsm)}
  .role-card-title{font-weight:700;color:var(--text);font-size:13px;margin-bottom:6px}
  .role-card-desc{font-size:11px;color:var(--text3);margin-bottom:8px;line-height:1.4}
  .role-perms{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px;max-height:80px;overflow-y:auto}
  .role-perm-tag{display:inline-block;padding:2px 6px;background:var(--surface);border:1px solid var(--border2);font-size:9px;border-radius:2px;color:var(--text2)}
  .role-actions{display:flex;gap:4px}
  .role-btn{flex:1;padding:6px 8px;font-size:10px;border:none;background:var(--border);cursor:pointer;border-radius:3px}

  /* ── Changelog / Logging ── */
  .log-table{width:100%;border-collapse:collapse;font-size:12px}
  .log-table th{background:var(--surface2);padding:8px;text-align:left;font-weight:600;color:var(--text2);border-bottom:1px solid var(--border)}
  .log-table td{padding:8px;border-bottom:1px solid var(--border)}
  .log-table tr:hover{background:var(--surface2)}
  .log-action{font-weight:600;color:var(--red)}
  .log-user{color:var(--text2);font-size:11px}
  .log-time{color:var(--text3);font-size:10px}

  /* ── Update Panel ── */
  .version-item{display:flex;justify-content:space-between;align-items:center;padding:10px;border:1px solid var(--border);border-radius:var(--rsm);margin-bottom:8px;background:var(--surface2)}
  .version-info{flex:1}
  .version-num{font-weight:700;color:var(--text)}
  .version-date{font-size:11px;color:var(--text3)}
  .version-actions{display:flex;gap:4px}

  /* ── Modals ── */
  .modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:5000;align-items:center;justify-content:center}
  .modal-overlay.show{display:flex}
  .modal-dialog{background:var(--bg);border-radius:var(--radius);padding:1.5rem;max-width:500px;width:90%;max-height:80vh;overflow-y:auto}
  .modal-title{font-size:16px;font-weight:700;margin-bottom:1rem;color:var(--text)}
  .modal-content{margin-bottom:1.5rem}
  .modal-buttons{display:flex;gap:8px;justify-content:flex-end}
  .modal-btn{padding:8px 16px;border:none;border-radius:var(--rsm);cursor:pointer;font-weight:600;font-size:13px}
  .modal-btn-primary{background:var(--red);color:#fff}
  .modal-btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text)}

  /* ── Responsive ── */
  @media(max-width:768px){
    .admin-tabs{gap:4px}
    .admin-tab{font-size:11px;padding:6px 10px}
    .role-grid{grid-template-columns:1fr}
    .login-box{width:95%;max-width:none}
  }


  /* ── Material Add Dialog ── */
  .mat-dialog{background:var(--bg);border-radius:var(--radius);padding:1.5rem;max-width:520px;width:95%;max-height:85vh;overflow-y:auto;box-shadow:0 10px 40px rgba(0,0,0,.3)}
  .mat-dialog h3{font-size:16px;font-weight:700;margin-bottom:1rem;color:var(--text)}
  .mat-dialog-field{margin-bottom:1rem}
  .mat-dialog-label{display:block;font-size:11px;font-weight:600;margin-bottom:4px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
  .mat-dialog-input{width:100%;padding:8px 12px;border:1px solid var(--border2);background:var(--surface);color:var(--text);border-radius:var(--rsm);font-size:14px;font-family:inherit}
  .mat-dialog-input:focus{outline:none;border-color:var(--red)}
  .mat-radio-group{display:flex;flex-direction:column;gap:8px;margin-top:6px}
  .mat-radio{display:flex;align-items:flex-start;gap:8px;padding:10px;border:1px solid var(--border);border-radius:var(--rsm);cursor:pointer;background:var(--surface)}
  .mat-radio:hover{background:var(--surface2)}
  .mat-radio.selected{border-color:var(--red);background:#fdf3f4}
  .mat-radio input[type=radio]{margin-top:3px;accent-color:var(--red)}
  .mat-radio-label{flex:1;font-size:13px;color:var(--text)}
  .mat-radio-sub{font-size:11px;color:var(--text3);margin-top:2px}
  .station-checks{margin-top:8px;max-height:200px;overflow-y:auto;border:1px solid var(--border);padding:8px;border-radius:var(--rsm);background:var(--surface);display:none}
  .station-checks.show{display:block}
  .station-checks label{display:flex;align-items:center;gap:6px;padding:4px 0;font-size:12px;color:var(--text2);cursor:pointer}
  .station-checks input[type=checkbox]{accent-color:var(--red)}
  .station-checks-actions{display:flex;gap:6px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border)}
  .sc-action-btn{font-size:10px;padding:2px 8px;background:none;border:1px solid var(--border2);color:var(--text2);border-radius:3px;cursor:pointer}
  .mat-dialog-buttons{display:flex;gap:8px;justify-content:flex-end;margin-top:1rem;flex-wrap:wrap}
  .mat-dialog-buttons .btn{font-size:13px;padding:8px 16px}

  /* ── Print Selector Dialog ── */
  .print-dialog{background:var(--bg);border-radius:var(--radius);padding:1.5rem;max-width:560px;width:95%;max-height:85vh;overflow-y:auto}
  .print-section-title{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;margin-top:1rem}
  .print-stations-list{border:1px solid var(--border);border-radius:var(--rsm);max-height:280px;overflow-y:auto;background:var(--surface)}
  .print-station-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border)}
  .print-station-row:last-child{border-bottom:none}
  .print-station-row label{flex:1;cursor:pointer;font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px}
  .print-station-row input[type=checkbox]{accent-color:var(--red);width:16px;height:16px}
  .print-doc-options{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
  .print-doc-card{padding:12px;border:1px solid var(--border2);border-radius:var(--rsm);cursor:pointer;background:var(--surface)}
  .print-doc-card.selected{border-color:var(--red);background:#fdf3f4}
  .print-doc-card-title{font-weight:600;color:var(--text);font-size:13px;margin-bottom:4px}
  .print-doc-card-desc{font-size:11px;color:var(--text3);line-height:1.4}

  @media(max-width:580px){
    .print-doc-options{grid-template-columns:1fr}
    .mat-dialog,.print-dialog{padding:1rem}
  }


  /* ─ Admin View ─ */
  .admin-view{max-width:900px;margin:0 auto;padding:1rem}
  .admin-page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--red)}
  .admin-page-title{font-size:20px;font-weight:700;color:var(--text);flex:1}
  .admin-nav{display:flex;gap:0;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;flex-wrap:wrap;margin-bottom:1.5rem}
  .admin-nav-btn{padding:10px 16px;background:none;border:none;border-right:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .1s}
  .admin-nav-btn:last-child{border-right:none}
  .admin-nav-btn.active{background:var(--red);color:#fff}
  .admin-nav-btn:hover:not(.active){background:var(--border)}
  .admin-section{display:none}
  .admin-section.active{display:block}
  .admin-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem;margin-bottom:1.2rem;box-shadow:var(--shadow)}
  .admin-card-title{font-size:13px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
  .admin-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--border);border-radius:0}
  .admin-row:last-child{border-bottom:none}
  .admin-row-info{flex:1;min-width:0}
  .admin-row-name{font-size:13px;color:var(--text);font-weight:500}
  .admin-row-sub{font-size:11px;color:var(--text3)}
  .admin-row-actions{display:flex;gap:4px;flex-shrink:0}
  .admin-btn{padding:4px 10px;font-size:11px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);border-radius:3px;cursor:pointer;font-family:inherit}
  .admin-btn:hover{background:var(--border)}
  .admin-btn.danger{background:#fee2e2;color:#991b1b;border-color:#fca5a5}
  .admin-btn.primary{background:var(--red);color:#fff;border-color:var(--red)}
  .color-dot{display:inline-block;width:12px;height:12px;border-radius:50%;flex-shrink:0;vertical-align:middle;margin-right:4px;border:1px solid rgba(0,0,0,.15)}

  /* Rollen-Berechtigungs-Matrix */
  .perm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:8px;margin-top:10px}
  .perm-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--surface2);border-radius:var(--rsm);border:1px solid var(--border)}
  .perm-item label{font-size:11px;color:var(--text2);cursor:pointer;flex:1}
  .perm-item input[type=checkbox]{accent-color:var(--red);flex-shrink:0}
  .perm-group-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin:10px 0 4px;grid-column:1/-1}

  /* Log-Tabelle */
  .log-scroll{max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--rsm)}
  .log-tr{display:grid;grid-template-columns:130px 100px 150px 1fr;gap:0;border-bottom:1px solid var(--border);font-size:11px}
  .log-tr:last-child{border-bottom:none}
  .log-tr.header{background:var(--surface2);font-weight:700;color:var(--text2);position:sticky;top:0}
  .log-td{padding:6px 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .log-tr:nth-child(even){background:var(--surface2)}
  .log-action-tag{padding:1px 6px;border-radius:3px;font-size:10px;font-weight:700}
  .log-action-login{background:#dcfce7;color:#166534}
  .log-action-save{background:#e0f2fe;color:#0369a1}
  .log-action-delete{background:#fee2e2;color:#991b1b}
  .log-action-other{background:#f3f4f6;color:#374151}

  @media(max-width:768px){
    .admin-nav-btn{font-size:11px;padding:8px 10px}
    .log-tr{grid-template-columns:90px 80px 1fr}
    .log-tr .log-td:nth-child(4){display:none}
  }

  /* ── Station Tabs ── */
  .station-tabs{display:flex;gap:0;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.2rem}
  .station-tab-btn{flex:1;padding:10px 16px;background:none;border:none;border-right:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit;transition:background .12s;text-align:center}
  .station-tab-btn:last-child{border-right:none}
  .station-tab-btn.active{background:var(--red);color:#fff}
  .station-tab-btn:hover:not(.active){background:var(--border)}
  .station-tab-pane{display:none}
  .station-tab-pane.active{display:block}

  /* ── Ausgabe/Rückgabe Tab Design ─────────────────────────── */
  .ausgabe-empty{padding:2rem;text-align:center;background:#fffbea;border:1px solid #f5e27a;border-radius:10px}
  .ausgabe-empty-icon{font-size:2.5rem;margin-bottom:.5rem}
  .ausgabe-empty-detail{font-size:11px;color:var(--text3);margin:.75rem auto;max-width:400px;text-align:left;background:#fff;border-radius:6px;padding:.5rem .75rem}
  .ausgabe-empty-hint{font-size:12px;color:var(--text2);margin-top:.75rem}

  .ausgabe-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06)}
  .ausgabe-card-top{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface2);flex-wrap:wrap}
  .ausgabe-card-name{font-weight:600;font-size:14px;flex:1;min-width:120px}
  .ausgabe-card-qty{display:flex;align-items:center;gap:6px;font-size:12px}
  .ausgabe-qty-lbl{color:var(--text3);white-space:nowrap}
  .ausgabe-qty-inp{width:60px;padding:3px 6px;border:1px solid var(--border2);border-radius:4px;font-size:12px;background:#fffde7;text-align:center}
  .ausgabe-qty-unit{color:var(--text3);font-size:11px}
  .ausgabe-card-checks{padding:10px 14px;display:flex;gap:16px;flex-wrap:wrap}
  .ausgabe-group-wrap{flex:1;min-width:160px}
  .ausgabe-group-hdr{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
  .ausgabe-pill-row{display:flex;flex-wrap:wrap;gap:6px}
  .ausgabe-pill{display:flex;align-items:center;gap:5px;padding:5px 10px;border:1.5px solid var(--border2);border-radius:20px;cursor:pointer;font-size:12px;background:var(--surface);transition:all .15s;user-select:none}
  .ausgabe-pill input{width:14px;height:14px;cursor:pointer;accent-color:var(--red)}
  .ausgabe-pill.active{background:#e8f5e9;border-color:#4caf50;color:#1b5e20}
  .ausgabe-pill.checked-ausgegeben.active,.ausgabe-pill.checked-verladen.active{background:#e3f2fd;border-color:#1976d2;color:#0d47a1}
  .ausgabe-pill.checked-nichtVorhanden.active{background:#fce4ec;border-color:#c62828;color:#b71c1c}
  .ausgabe-pill.checked-verbraucht.active{background:#f3e5f5;border-color:#7b1fa2;color:#4a148c}
  .ausgabe-pill.checked-rueckgabeDefekt.active{background:#fff3e0;border-color:#e65100;color:#bf360c}
  .ausgabe-pill:hover:not(.active){background:var(--surface2);border-color:var(--border2)}

  @media(max-width:580px){
    .ausgabe-card-top{flex-direction:column;align-items:flex-start}
    .ausgabe-card-checks{flex-direction:column}
    .ausgabe-group-wrap{min-width:100%}
  }

  /* ── Mobile & Cross-Browser Optimierungen ─────────────────── */
  html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}
  input:not([type=checkbox]):not([type=radio]),select,textarea,button{font-family:inherit;-webkit-appearance:none;-moz-appearance:none}
  .btn{cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
  .station-card{-webkit-tap-highlight-color:transparent;touch-action:manipulation}
  .badge{-webkit-tap-highlight-color:transparent;touch-action:manipulation}

  /* iOS Safari Fixes */
  input[type=text],input[type=password]{-webkit-appearance:none;border-radius:var(--radius-sm)}
  select{background-image:none}

  /* Touch-friendly tap targets */
  @media(pointer:coarse){
    .btn{min-height:44px;padding:10px 16px}
    .badge{min-height:36px;padding:6px 12px}
    .station-tab-btn{min-height:48px}
    .ausgabe-pill{min-height:40px;padding:8px 14px}
    .row-qty,.row-unit{min-height:36px}
    .info-inp{min-height:44px;padding:10px}
  }

  /* Firefox Fixes */
  @-moz-document url-prefix(){
    select{padding-right:20px}
    .inp{padding:6px 8px}
  }

  /* Responsive Table */
  @media(max-width:480px){
    .row-header{display:none}
    .card-row{flex-wrap:wrap;gap:4px}
    .row-name{flex:0 0 100%;font-size:13px;font-weight:600}
    .row-qty{width:70px}
    .row-unit{width:80px}
    .badge{font-size:10px;padding:3px 8px}
    .row-actions{margin-left:auto}
    .info-tbl-row{display:flex;flex-direction:column;gap:8px}
    .info-field{min-width:100%}
    .station-grid{grid-template-columns:repeat(2,1fr)}
  }

  @media(max-width:360px){
    .station-grid{grid-template-columns:1fr}
    .overview-header{flex-direction:column;gap:8px}
  }

  .trig-sw{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:14px;border:1px solid var(--border2);background:var(--surface2);user-select:none;font-size:11px;transition:all .15s}
  .trig-sw.on{background:#f1f8e9;border-color:#4caf50}
  .trig-track{width:26px;height:14px;background:#ccc;border-radius:7px;position:relative;flex-shrink:0;transition:background .15s}
  .trig-sw.on .trig-track{background:#4caf50}
  .trig-thumb{position:absolute;top:2px;left:2px;width:10px;height:10px;background:#fff;border-radius:50%;transition:left .15s;box-shadow:0 1px 2px rgba(0,0,0,.25)}
  .trig-sw.on .trig-thumb{left:14px}

  /* ── Smartphone-Optimierung ─────────────────────────────── */
  :root {
    --touch-min: 44px;       /* iOS HIG minimum */
    --font-base: clamp(13px, 3.5vw, 16px);
  }
  @media (max-width: 600px) {
    body { font-size: var(--font-base); }
    .overview-header { flex-direction: column; gap: 8px; align-items: flex-start; }
    .overview-title  { font-size: clamp(18px, 5vw, 24px); }
    .station-grid    { grid-template-columns: repeat(2, 1fr) !important; gap: 8px; }
    .station-card    { padding: 10px 8px; }
    .sc-num          { font-size: 22px; }
    /* Station-Detail */
    .info-tbl-row    { display: flex; flex-direction: column; gap: 6px; }
    .info-field      { min-width: unset; width: 100%; }
    .station-tabs    { gap: 4px; }
    .station-tab-btn { flex: 1; font-size: 12px; padding: 8px 4px; min-height: var(--touch-min); }
    /* Materialzeilen */
    .row-header      { display: none; }
    .card-row        { flex-wrap: wrap; gap: 4px; padding: 8px; }
    .row-name        { flex: 0 0 100%; font-weight: 600; font-size: 14px; padding: 0; }
    .row-qty         { width: 70px; min-height: var(--touch-min); }
    .row-unit        { width: 100px; min-height: var(--touch-min); }
    .badge           { min-height: 36px; font-size: 11px; padding: 4px 8px; }
    .row-actions     { margin-left: auto; }
    /* Ausgabe-Karten */
    .ausgabe-card-top   { flex-direction: column; align-items: flex-start; }
    .ausgabe-card-checks{ flex-direction: column; }
    .ausgabe-pill       { min-height: var(--touch-min); padding: 8px 14px; font-size: 13px; }
    /* Admin */
    .admin-nav-btn   { font-size: 11px; padding: 6px 8px; min-height: var(--touch-min); }
    .admin-row       { flex-wrap: wrap; }
    /* User-Bar */
    .user-badge      { font-size: 9px; padding: 1px 5px; }
    /* Buttons */
    .btn             { min-height: var(--touch-min); padding: 10px 14px; }
    /* Koordinaten-Feld */
    #info-coords-lat, #info-coords-lng { font-size: 16px; } /* verhindert iOS-Zoom */
    /* Print-Selector */
    .mat-dialog      { padding: 1rem; }
    .mat-dialog-title{ font-size: 16px; }
  }
  @media (max-width: 360px) {
    .station-grid    { grid-template-columns: 1fr !important; }
  }
  /* Landscape Smartphone */
  @media (max-width: 900px) and (orientation: landscape) {
    .station-grid    { grid-template-columns: repeat(3, 1fr); }
  }
  /* Hover nur auf Geräten die hover unterstützen */
  @media (hover: hover) {
    .station-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.1); }
    .btn:hover         { filter: brightness(0.95); }
  }
  /* Fokus-Styles für Accessibility */
  :focus-visible { outline: 2px solid var(--red); outline-offset: 2px; }
  /* iOS input Fixes */
  input[type=text], input[type=password], input[type=number], select, textarea {
    font-size: max(13px, 1em); /* verhindert iOS zoom */
    -webkit-appearance: none;
    border-radius: var(--radius-sm, 4px);
  }
  input[type=checkbox], input[type=radio] {
    -webkit-appearance: auto; appearance: auto;
    width: 18px; height: 18px;
    accent-color: var(--red, #e2001a);
  }

  /* ── Adaptive Station Grid ──────────────────────────────── */
  .station-grid        { display:grid; gap:12px; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); }
  .station-grid.grid-single { grid-template-columns: 1fr; max-width: 600px; margin:0 auto; }
  .station-grid.grid-two    { grid-template-columns: repeat(2, 1fr); max-width: 700px; margin:0 auto; }
  .station-grid.grid-small  { grid-template-columns: repeat(2, 1fr); }
  .station-grid.grid-medium { grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); }
  .station-grid.grid-large  { grid-template-columns: repeat(auto-fill, minmax(150px,1fr)); }

  /* Größere Kacheln wenn wenige Stationen */
  .grid-single .station-card,
  .grid-two    .station-card { min-height: 180px; padding: 18px; }
  .grid-small  .station-card { min-height: 160px; padding: 14px; }

  /* Mehr Infos sichtbar bei großen Kacheln */
  .grid-single .sc-num  { font-size: 36px; }
  .grid-two    .sc-num  { font-size: 32px; }
  .grid-single .sc-name { font-size: 15px; font-weight: 600; }
  .grid-two    .sc-name { font-size: 13px; font-weight: 600; }
  .grid-single .sc-pct, .grid-two .sc-pct { font-size: 14px; }

  /* Fortschrittsbalken bei großen Kacheln besser sichtbar */
  .grid-single .sc-prog-track,
  .grid-two    .sc-prog-track { height: 6px; margin-top: 10px; }

  @media (max-width: 600px) {
    .station-grid,
    .station-grid.grid-medium,
    .station-grid.grid-large  { grid-template-columns: repeat(2, 1fr) !important; }
    .station-grid.grid-single { grid-template-columns: 1fr !important; max-width: 100%; }
    .station-grid.grid-two    { grid-template-columns: repeat(2, 1fr) !important; max-width: 100%; }
  }
  @media (max-width: 360px) {
    .station-grid { grid-template-columns: 1fr !important; }
  }

/* ── Statistik-Overlay ───────────────────────────────────────────── */
.st-hbtn{background:rgba(255,255,255,.2);color:#fff;border:none;border-radius:6px;padding:6px 14px;cursor:pointer;font-size:12px;font-family:inherit;font-weight:600;transition:background .15s}
.st-hbtn:hover{background:rgba(255,255,255,.35)}
.st-sel{font-size:12px;padding:5px 8px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text1);font-family:inherit;cursor:pointer}
.st-sel:focus{outline:none;border-color:var(--red)}
.st-badge{display:inline-block;font-size:11px;font-weight:600;border-radius:10px;padding:2px 9px;white-space:nowrap}
.st-open{background:#f0f9f0;color:#166534}
.st-locked{background:#fff3cd;color:#92400e}
.st-final{background:#fee2e2;color:#991b1b}
