
  :root{
    --bg:#0E1217; --surface:#171C23; --surface2:#1F2630; --surface3:#283140;
    --border:#2A323D; --border2:#39434f;
    --text:#E7ECF2; --muted:#8A95A3; --faint:#5d6976;
    --accent:#FF6A2B;          /* Rettungs-Orange  */
    --flight:#38D39F;          /* Flugzeit (gewertet) */
    --refuel:#FFB02B;          /* Tankzeit (gewertet) */
    --pause:#5B7FB0;           /* Pause (nicht gewertet) */
    --danger:#E5484D;
    --mono:ui-monospace,"SF Mono","Cascadia Code","JetBrains Mono",Consolas,monospace;
    --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  }
  *{box-sizing:border-box}
  html,body{margin:0}
  body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
  .wrap{max-width:1180px;margin:0 auto;padding:0 20px 80px}

  /* ---------- Header ---------- */
  header.app{position:sticky;top:0;z-index:30;background:linear-gradient(180deg,#10151c, #10151cee);backdrop-filter:blur(6px);border-bottom:1px solid var(--border)}
  .head-inner{max-width:1180px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
  .brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:inherit}
  .rotor{height:32px;width:auto;flex:0 0 auto;color:var(--accent);filter:drop-shadow(0 1px 1px rgba(0,0,0,.35))}
  .brand h1{font-size:15px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:0}
  .brand .sub{font-size:11px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase}
  .toolbar{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}

  button{font-family:var(--sans);cursor:pointer;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);padding:8px 12px;font-size:13px;font-weight:600;transition:.12s background,.12s border-color,.12s transform}
  button:hover{background:var(--surface3);border-color:#4a5666}
  button:active{transform:translateY(1px)}
  button.primary{background:var(--accent);border-color:var(--accent);color:#1a0f08}
  button.primary:hover{background:#ff7d45}
  button.ghost{background:transparent}
  button.danger{color:#ffb4b6;border-color:#5a2b2d}
  button.danger:hover{background:#3a1f20}
  button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
  button:disabled{cursor:not-allowed}
  button.danger.locked{color:var(--muted);border-color:var(--border2);background:var(--surface2);opacity:1}
  button.danger.locked:hover{background:var(--surface2)}

  /* ---------- Mission meta ---------- */
  .mission{display:grid;grid-template-columns:1fr 1fr auto;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:22px 0 6px}
  .mfield{background:var(--surface);padding:12px 14px}
  .mfield label{display:block;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
  .mfield input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:16px;font-weight:600;font-family:var(--sans);padding:8px 10px}
  .mfield input[type=time]{font-family:var(--mono)}
  .mfield input:hover{border-color:var(--border2)}
  .mfield input:focus{outline:none;border-color:var(--accent);background:var(--surface)}

  .einsatzdauer{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;padding:11px 16px;margin:-7px 0 0}
  .einsatzdauer .ic{width:18px;height:18px;color:var(--accent);flex:0 0 auto}
  .einsatzdauer .l{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
  .einsatzdauer .span{font-family:var(--mono);color:var(--muted);font-size:13px}
  .einsatzdauer .v{margin-left:auto;font-family:var(--mono);font-size:22px;font-weight:700;color:var(--accent)}

  /* ---------- Tabs ---------- */
  .tabs{display:flex;gap:4px;align-items:flex-end;margin:24px 0 0;border-bottom:1px solid var(--border);flex-wrap:wrap}
  .tab{padding:9px 16px;border:1px solid var(--border);border-bottom:none;background:var(--surface);color:var(--muted);border-radius:9px 9px 0 0;font-weight:600;font-size:13px;position:relative;top:1px;display:flex;align-items:center;gap:8px}
  .tab:hover{color:var(--text)}
  .tab.active{background:var(--surface2);color:var(--text);border-color:var(--border2)}
  .tab.active::after{content:"";position:absolute;left:0;right:0;top:-1px;height:2px;background:var(--accent);border-radius:2px}
  .tab.sum{margin-left:auto}
  .tab.add{color:var(--accent);border-style:dashed}
  .tab .dot{width:8px;height:8px;border-radius:50%;background:var(--flight)}

  /* ---------- Panels ---------- */
  .panel{background:var(--surface2);border:1px solid var(--border2);border-top:none;border-radius:0 0 12px 12px;padding:20px}
  .heli-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
  .heli-head .tag{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700}
  .heli-name{flex:1 1 220px;min-width:180px}
  .heli-name input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:9px;color:var(--text);font-size:20px;font-weight:700;padding:9px 12px;font-family:var(--sans)}

  .sec-title{display:flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:24px 0 10px}
  .sec-title .line{flex:1;height:1px;background:var(--border)}

  .heli-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin-top:4px}
  .hm-field label{display:block;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
  .hm-field input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:9px;color:var(--text);font-size:15px;font-weight:600;padding:9px 12px;font-family:var(--sans)}
  .hm-field input[type=time]{font-family:var(--mono)}
  .hm-field input:focus{outline:none;border-color:var(--accent)}
  .ea-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;cursor:pointer;user-select:none;font-weight:600;font-size:14px;width:100%}
  .ea-toggle:hover{border-color:var(--border2)}
  .ea-toggle input{width:17px;height:17px;accent-color:var(--accent);flex:0 0 auto}
  .modal-ov{position:fixed;inset:0;z-index:300;background:rgba(8,10,14,.66);display:flex;align-items:center;justify-content:center;padding:20px}
  .modal-box{background:var(--surface2);border:1px solid var(--border2);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.55);max-width:420px;width:100%;padding:20px}
  .modal-msg{margin:0 0 18px;font-size:15px;line-height:1.5;white-space:pre-line;color:var(--text)}
  .modal-row{display:flex;justify-content:flex-end;gap:10px}
  .hm-field .tinput{width:100%}
  .hm-field .tinput input{width:auto;flex:1}
  .heli-times{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px 14px;margin-top:12px;padding:12px 16px 14px;background:rgba(255,106,43,.06);border:1px solid var(--border2);border-left:3px solid var(--accent);border-radius:11px}
  .heli-times .ht-cap{grid-column:1/-1;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:-2px}
  .heli-times .hm-field input{background:var(--surface2)}
  .hm-value{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:9px;font-size:15px;font-weight:700;padding:9px 12px;font-family:var(--mono);min-height:40px;display:flex;align-items:center}
  .hm-value.val-einsatz{color:var(--accent)}
  .hm-value.val-pilot{color:var(--flight)}
  .hm-value.val-pilot.neg{color:#ff7d7f}
  .pilot-timer{display:flex;align-items:center;gap:16px;margin-top:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border2);border-radius:11px}
  .pilot-timer.over{border-color:var(--danger);background:#2a1416}
  .pt-info{flex:1;min-width:0}
  .pt-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700}
  .pt-sub{font-size:11px;color:var(--faint);font-family:var(--mono);margin-top:2px}
  .pt-clock{display:flex;align-items:baseline;gap:2px;font-family:var(--mono)}
  .pt-big{font-size:30px;font-weight:700;color:var(--flight);line-height:1}
  .pt-unit{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-left:6px}
  .pilot-timer.over .pt-big{color:#ff7d7f}
  .pt-btn{font-size:12px;padding:7px 12px}
  .einsatzzeit{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;padding:11px 16px;margin-top:14px}
  .einsatzzeit .ic{width:18px;height:18px;color:var(--accent);flex:0 0 auto}
  .einsatzzeit .l{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
  .einsatzzeit .span{font-family:var(--mono);color:var(--muted);font-size:13px}
  .einsatzzeit .v{margin-left:auto;font-family:var(--mono);font-size:22px;font-weight:700;color:var(--accent)}
  .sumtable td.accent{color:var(--accent)}
  .rot select.liter{min-width:100px}
  .rot select.easel{min-width:60px}
  .sum-heli{font-weight:700}
  .sum-sub{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:2px}

  /* ---------- Rotations table ---------- */
  table{width:100%;border-collapse:collapse}
  .rot th{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:left;font-weight:600;padding:6px 8px;border-bottom:1px solid var(--border)}
  .rot td{padding:4px 8px;border-bottom:1px solid #20262f;vertical-align:middle}
  .rot tr:hover td{background:#1b212b}
  .rot td.num{color:var(--faint);font-family:var(--mono);width:34px;text-align:right;padding-right:12px}
  .rot input[type=time]{font-family:var(--mono);background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:6px 8px;font-size:14px;width:110px}
  .rot select{font-family:var(--sans);background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:6px 8px;font-size:13px}
  .rot input.liter{font-family:var(--mono);background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:6px 8px;font-size:14px;width:80px;text-align:right}
  .rot td.dur{font-family:var(--mono);color:var(--flight);font-weight:600;text-align:right;width:78px}
  .rot td.dur.bad{color:var(--danger)}
  .iconbtn{background:transparent;border:none;color:var(--faint);padding:4px 6px;font-size:16px;line-height:1;border-radius:6px}
  .iconbtn:hover{color:var(--danger);background:#2a1c1d}
  .addrow{margin-top:10px}

  .rot-scroll{overflow-x:auto;margin:0 -4px;padding:0 4px}
  .ptext{font-family:var(--sans);background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:6px 8px;font-size:13px;width:130px}
  .ptext:focus{outline:none;border-color:var(--accent)}
  .tabcount{font-family:var(--mono);font-size:11px;background:var(--surface3);color:var(--muted);border-radius:20px;padding:1px 7px;margin-left:6px}

  /* person picker button */
  .ppick{font-family:var(--sans);font-size:12px;font-weight:600;background:var(--surface);border:1px dashed var(--border2);color:var(--muted);border-radius:7px;padding:6px 9px;min-width:120px;max-width:160px;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ppick:hover{border-color:var(--accent);color:var(--text);background:var(--surface2)}
  .ppick.has{border-style:solid;border-color:#3a6e5c;background:#13241d;color:var(--flight)}

  /* floating panel */
  .ppanel{position:fixed;z-index:200;width:280px;max-height:340px;display:flex;flex-direction:column;background:var(--surface2);border:1px solid var(--border2);border-radius:11px;box-shadow:0 16px 40px rgba(0,0,0,.5);overflow:hidden}
  .pp-head{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}
  .pp-title{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
  .pp-actions{margin-left:auto;display:flex;gap:6px}
  .pp-mini{padding:3px 8px;font-size:11px;border-radius:6px;background:var(--surface3);border:1px solid var(--border2);color:var(--text)}
  .pp-search{margin:10px 12px 6px;background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:7px 9px;font-size:13px;font-family:var(--sans)}
  .pp-search:focus{outline:none;border-color:var(--accent)}
  .pp-list{overflow-y:auto;padding:4px 6px 8px}
  .pp-item{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:7px;cursor:pointer}
  .pp-item:hover{background:var(--surface3)}
  .pp-item input{width:16px;height:16px;accent-color:var(--accent);flex:0 0 auto}
  .pp-name{font-size:13px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .pp-name b{font-weight:700}
  .pp-fw{font-size:10px;color:var(--muted);background:var(--surface);padding:2px 6px;border-radius:10px}
  .pp-empty{padding:14px;text-align:center;color:var(--muted);font-size:12px}

  /* ---------- Event blocks (Tanken / Pause) ---------- */
  .events{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:6px}
  .ev{border:1px solid var(--border);border-radius:11px;padding:14px;background:var(--surface)}
  .ev.refuel{border-left:3px solid var(--refuel)}
  .ev.pause{border-left:3px solid var(--pause)}
  .ev-head{display:flex;align-items:center;gap:10px;margin-bottom:4px}
  .ev-head .name{font-weight:700;font-size:14px}
  .ev-head .badge{margin-left:auto;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:3px 8px;border-radius:20px}
  .ev.refuel .badge{background:#3a2c10;color:var(--refuel)}
  .ev.pause .badge{background:#1c2738;color:var(--pause)}
  .ev .hint{font-size:11px;color:var(--muted);margin:0 0 12px}
  .ev-list{display:flex;flex-direction:column;gap:8px}
  .ev-row{display:flex;align-items:center;gap:8px}
  .ev-idx{font-family:var(--mono);color:var(--faint);font-size:12px;width:18px;flex:0 0 auto}
  .ev-row input[type=time]{font-family:var(--mono);background:var(--surface2);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:6px 8px;font-size:14px;width:108px}
  .ev-arrow{color:var(--faint);flex:0 0 auto}
  .ev-dur{font-family:var(--mono);font-size:13px;font-weight:600;margin-left:auto;min-width:54px;text-align:right}
  .rotor-chk{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);cursor:pointer;user-select:none;white-space:nowrap;flex:0 0 auto}
  .rotor-chk input{width:15px;height:15px;accent-color:var(--accent);flex:0 0 auto}
  .ev-row.as-pause .ev-dur{color:var(--pause)}
  .as-pause-badge{font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--pause);background:#1c2738;border:1px solid #2c3a52;border-radius:20px;padding:2px 8px;flex:0 0 auto}
  .ev.refuel .ev-dur{color:var(--refuel)} .ev.pause .ev-dur{color:var(--pause)}
  .ev-empty{font-size:12px;color:var(--faint);padding:4px 0}
  .ev-foot{display:flex;align-items:center;gap:12px;margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
  .ev-add{font-size:12px;padding:6px 11px}
  .ev.refuel .ev-add:hover{border-color:var(--refuel);color:var(--refuel)}
  .ev.pause .ev-add:hover{border-color:var(--pause);color:var(--pause)}
  .ev-sum{margin-left:auto;display:flex;align-items:baseline;gap:8px}
  .ev-sum-l{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
  .ev-sum-v{font-family:var(--mono);font-size:18px;font-weight:700}
  .ev.refuel .ev-sum-v{color:var(--refuel)} .ev.pause .ev-sum-v{color:var(--pause)}
  .rot input.liter:disabled{opacity:.3;cursor:not-allowed;background:#12161c}
  .cell-na{color:var(--faint);font-family:var(--mono);padding-left:6px}
  .rot tbody tr.rowOffen td{background:#2a1416 !important}
  .rowOffen .ptext{color:#ff9ea0}
  .cell-offen{color:#ff9ea0 !important;font-weight:700}
  .badge-warn{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:#ffb4b6;background:#3a1f20;border:1px solid #5a2b2d;border-radius:20px;padding:3px 10px;white-space:nowrap}
  .badge-ok{font-size:12px;color:var(--flight);font-weight:600;white-space:nowrap}
  .warnbanner{display:flex;align-items:center;gap:10px;background:#2a1416;border:1px solid #5a2b2d;color:#ffb4b6;border-radius:11px;padding:11px 14px;margin:6px 0 16px;font-size:13px}
  .warnbanner svg{flex:0 0 auto;color:#ff7d7f}
  .tinput{display:inline-flex;align-items:center;gap:5px}
  .mfield .tinput{width:100%}
  .mfield .tinput input{width:auto;flex:1}
  .nowbtn{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border-radius:7px;background:var(--surface3);border:1px solid var(--border2);color:var(--muted);cursor:pointer}
  .nowbtn:hover{color:var(--accent);border-color:var(--accent);background:var(--surface2)}
  .nowbtn:active{transform:translateY(1px)}
  .switch{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
  .switch input{position:absolute;opacity:0;width:0;height:0}
  .track{width:38px;height:22px;border-radius:20px;background:var(--surface3);position:relative;transition:.15s;flex:0 0 auto}
  .track::after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#aeb7c2;top:3px;left:3px;transition:.15s}
  .switch input:checked + .track{background:var(--accent)}
  .switch input:checked + .track::after{left:19px;background:#fff}
  .ev-times{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
  .ev-times.disabled{opacity:.4;pointer-events:none}
  .tfield label{display:block;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
  .tfield input{font-family:var(--mono);background:var(--surface2);border:1px solid var(--border);border-radius:7px;color:var(--text);padding:7px 9px;font-size:15px}
  .ev-res{margin-left:auto;text-align:right}
  .ev-res .v{font-family:var(--mono);font-size:20px;font-weight:700}
  .ev.refuel .ev-res .v{color:var(--refuel)}
  .ev.pause .ev-res .v{color:var(--pause)}
  .ev-res .l{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

  /* ---------- Zeitbilanz signature bar ---------- */
  .balance{margin-top:22px;background:var(--surface);border:1px solid var(--border2);border-radius:12px;padding:18px}
  .balance-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;flex-wrap:wrap;gap:10px}
  .balance-top .tot .v{font-family:var(--mono);font-size:32px;font-weight:700;color:var(--text)}
  .balance-top .tot .l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
  .balance-top .formula{font-size:12px;color:var(--muted);font-family:var(--mono)}
  .balance-top .formula b{color:var(--text)}
  .bar{display:flex;height:34px;border-radius:8px;overflow:hidden;background:#10151c;border:1px solid var(--border)}
  .seg{display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:700;color:#0c1116;min-width:0;overflow:hidden;white-space:nowrap;transition:flex-basis .3s}
  .seg.flight{background:var(--flight)}
  .seg.refuel{background:var(--refuel)}
  .seg.pause{background:repeating-linear-gradient(45deg,#34465e,#34465e 7px,#2b3a4f 7px,#2b3a4f 14px);color:#cdd9e8;position:relative}
  .seg.pause::after{content:"";position:absolute;inset:0;border-left:1px dashed #6f8bad}
  .legend{display:flex;gap:18px;margin-top:12px;flex-wrap:wrap;font-size:12px}
  .legend .it{display:flex;align-items:center;gap:7px;color:var(--muted)}
  .legend .sw{width:12px;height:12px;border-radius:3px}
  .legend .sw.flight{background:var(--flight)}
  .legend .sw.refuel{background:var(--refuel)}
  .legend .sw.pause{background:repeating-linear-gradient(45deg,#34465e,#34465e 4px,#2b3a4f 4px,#2b3a4f 8px)}
  .legend .it b{color:var(--text);font-family:var(--mono)}
  .legend .strike{text-decoration:line-through;text-decoration-color:var(--pause)}

  /* ---------- Summary ---------- */
  .kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:22px}
  .kpi{background:var(--surface);padding:16px}
  .kpi .v{font-family:var(--mono);font-size:26px;font-weight:700}
  .kpi .l{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:2px}
  .kpi.accent .v{color:var(--accent)}
  .kpi.flight .v{color:var(--flight)}
  .kpi.refuel .v{color:var(--refuel)}
  .kpi.pause .v{color:var(--pause)}
  .sumtable{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:12px;overflow:hidden}
  .sumtable th{background:var(--surface);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:right;padding:11px 14px;font-weight:600}
  .sumtable th:first-child{text-align:left}
  .sumtable td{padding:11px 14px;border-top:1px solid var(--border);text-align:right;font-family:var(--mono);font-size:14px}
  .sumtable td:first-child{text-align:left;font-family:var(--sans);font-weight:600}
  .sumtable tr:nth-child(even) td{background:#1a212b}
  .sumtable tfoot td{background:var(--surface3);font-weight:700;border-top:2px solid var(--border2)}
  .sumtable .flight{color:var(--flight)} .sumtable .refuel{color:var(--refuel)} .sumtable .pause{color:var(--pause)} .sumtable .total{color:var(--text)}
  .sumtable td.txt{text-align:left;font-family:var(--sans);color:var(--muted)}
  .sumtable th.txt{text-align:left}

  .empty{color:var(--muted);text-align:center;padding:40px;font-size:14px}
  .filewrap{position:absolute;left:-9999px}
  footer{margin-top:30px;color:var(--faint);font-size:11px;text-align:center}

  @media (max-width:1000px){ .kpis{grid-template-columns:repeat(3,1fr)} }
  @media (max-width:820px){
    .mission{grid-template-columns:repeat(2,1fr)}
    .events{grid-template-columns:1fr}
    .tab.sum{margin-left:0}
    .kpis{grid-template-columns:repeat(2,1fr)}
  }
  .sum-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:6px}
  .sum-toolbar .sec-title{margin:0;flex:1}
  .print-head{display:none}

  @media print{
    @page{ size:A4 landscape; margin:12mm; }
    header.app{position:static} .toolbar,.tab.add,.addrow,.iconbtn,.delheli,.nowbtn,.ev-add,.pt-btn{display:none!important}
    body{background:#fff;color:#000} .panel,.ev,.balance,.kpi,.surface{background:#fff!important}
    *{color:#000!important;border-color:#bbb!important}
    .seg{color:#000!important}

    /* ---- A4-Druck der Zusammenfassung ---- */
    body.print-summary header.app,
    body.print-summary #mission,
    body.print-summary #tabs,
    body.print-summary .wrap > footer,
    body.print-summary .sum-toolbar{ display:none!important; }
    body.print-summary .wrap{ padding:0!important; max-width:none!important; }
    body.print-summary .panel{ border:none!important; padding:0!important; }
    body.print-summary .rot-scroll{ overflow:visible!important; margin:0!important; padding:0!important; }

    body.print-summary .print-head{ display:block; margin-bottom:10px; border-bottom:1.5px solid #000; padding-bottom:6px; }
    body.print-summary .print-head h2{ margin:0; font-size:17pt; letter-spacing:.02em; }
    body.print-summary .print-head .ph-meta{ font-size:10pt; margin-top:3px; }
    body.print-summary .sec-title{ font-size:8.5pt; letter-spacing:.12em; margin:10px 0 6px; }

    body.print-summary .kpis{ grid-template-columns:repeat(4,1fr)!important; gap:0!important; background:#fff!important; border:1px solid #999!important; }
    body.print-summary .kpi{ padding:6px 9px!important; border:0.5px solid #ccc!important; background:#fff!important; }
    body.print-summary .kpi .v{ font-size:13pt!important; color:#000!important; }
    body.print-summary .kpi .l{ font-size:6.5pt!important; letter-spacing:.08em; }

    body.print-summary .sumtable{ width:100%!important; }
    body.print-summary .sumtable th, body.print-summary .sumtable td{ padding:4px 6px!important; font-size:8pt!important; }
    body.print-summary .sumtable tr{ page-break-inside:avoid; }
    body.print-summary .sumtable td.txt{ color:#000!important; }
    body.print-summary .hint{ font-size:7.5pt!important; margin-top:8px!important; }

    /* ---- A4-Druck der Personenliste ---- */
    body.print-personen header.app,
    body.print-personen #mission,
    body.print-personen #tabs,
    body.print-personen .wrap > footer,
    body.print-personen .heli-head,
    body.print-personen .warnbanner{ display:none!important; }
    body.print-personen .wrap{ padding:0!important; max-width:none!important; }
    body.print-personen .panel{ border:none!important; padding:0!important; }
    body.print-personen .rot-scroll{ overflow:visible!important; margin:0!important; padding:0!important; }

    body.print-personen .print-head{ display:block; margin-bottom:10px; border-bottom:1.5px solid #000; padding-bottom:6px; }
    body.print-personen .print-head h2{ margin:0; font-size:17pt; letter-spacing:.02em; }
    body.print-personen .print-head .ph-meta{ font-size:10pt; margin-top:3px; }

    body.print-personen table.rot{ width:100%!important; }
    body.print-personen table.rot th, body.print-personen table.rot td{ padding:4px 6px!important; font-size:8pt!important; }
    body.print-personen table.rot tr{ page-break-inside:avoid; }
    body.print-personen input.ptext{ border:none!important; background:transparent!important; padding:0!important; font-size:8pt!important; color:#000!important; }
    body.print-personen .badge-warn,body.print-personen .badge-ok,body.print-personen .cell-na{ color:#000!important; }
    body.print-personen .hint{ font-size:7.5pt!important; margin-top:8px!important; }
  }

/* =====================================================================
   Ergänzungen für die PHP-Anwendung: Navigation, Login/MFA, Dashboard,
   Adminbereich, Flash-Meldungen. Nutzt dieselben CSS-Variablen wie oben.
   ===================================================================== */

.navlink{display:inline-flex;align-items:center;gap:7px;color:var(--muted);text-decoration:none;font-size:13px;font-weight:600;padding:8px 13px;border-radius:9px;transition:.14s background,.14s color;border:1px solid transparent}
.navlink svg{width:15px;height:15px;flex:0 0 auto}
.navlink:hover{color:var(--text);background:var(--surface2)}
.navlink.active{color:#1a0f08;background:var(--accent);border-color:var(--accent)}
.navdivider{width:1px;align-self:stretch;background:var(--border2);margin:2px 4px}
.navuser{color:var(--faint);font-size:12px;margin:0 4px;display:inline-flex;align-items:center;gap:6px}
.navrole{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--surface2);border:1px solid var(--border2);border-radius:5px;padding:2px 6px}

.flash{border-radius:10px;padding:12px 16px;margin:16px 0;font-size:13px;border:1px solid var(--border2)}
.flash-error{background:#2a1416;border-color:#5a2b2d;color:#ffb4b6}
.flash-success{background:#0f2a1e;border-color:#2b5a3f;color:#8de8b4}

.authbox{max-width:380px;margin:80px auto;background:var(--surface2);border:1px solid var(--border2);border-radius:14px;padding:28px}
.authbox-wide{max-width:560px}
.authbox h2{margin:0 0 18px;font-size:18px}
.authbox label{display:block;font-size:12px;color:var(--muted);margin-bottom:14px}
.authbox input,.authbox select{display:block;width:100%;margin-top:6px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:10px 12px;font-size:15px;font-family:var(--sans)}
.authbox input:focus{outline:none;border-color:var(--accent)}
.authbox .hint{font-size:12px;color:var(--muted);margin:-6px 0 16px}
.authbox button{width:100%}

.mfa-setup-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:18px}
.mfa-field{margin-bottom:12px}
.mfa-field label{display:block;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.mfa-value{font-size:14px;word-break:break-all}
.mfa-value.mono{font-family:var(--mono);background:var(--surface2);padding:8px 10px;border-radius:7px}
.mfa-value.small{font-size:11px;color:var(--muted)}

.dash-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:26px 0 18px;flex-wrap:wrap}
.dash-head h2{margin:0}
.dash-new{display:flex;gap:8px;flex-wrap:wrap}
.dash-new input{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:8px 10px;font-size:13px}

.editor-topbar{display:flex;align-items:center;justify-content:space-between;margin:20px 0 4px}
.editor-toolbar{margin:0 0 0}
.save-indicator{font-size:11px;color:var(--muted);font-family:var(--mono)}
.save-indicator.saving{color:var(--refuel)}
.save-indicator.error{color:var(--danger)}
.save-indicator.saved{color:var(--flight)}

.panel{margin:20px 0}
.admin-new-form{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.admin-new-form label{font-size:11px;color:var(--muted)}
.admin-new-form input,.admin-new-form select{display:block;margin-top:4px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:8px 10px;font-size:13px}
.admin-actions{display:flex;gap:6px;flex-wrap:wrap}
.admin-actions form{display:inline}
.admin-actions button{font-size:11px;padding:6px 9px}

.archive-banner{display:flex;align-items:center;gap:10px;background:#241a10;border:1px solid #5a4426;color:#f0c98a;border-radius:10px;padding:12px 16px;margin:14px 0;font-size:13px}
.archive-banner svg{flex:0 0 auto;color:#f0c98a}
.archive-btn{color:var(--refuel);border-color:#5a4426}

.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;padding:3px 8px;border-radius:6px}
.status-badge.offen{background:rgba(56,211,159,.12);color:var(--flight);border:1px solid rgba(56,211,159,.3)}
.status-badge.archiviert{background:rgba(255,176,43,.12);color:var(--refuel);border:1px solid rgba(255,176,43,.3)}

/* Read-Only-Modus: greift nur, wenn der Server data-can-write="0" liefert
   (archivierter Einsatz + Rolle "editor"). Admins sind davon nie betroffen,
   da sie serverseitig immer canWrite=true erhalten. */
body.read-only .ptext,body.read-only input,body.read-only select,body.read-only textarea{
  pointer-events:none!important; background:var(--surface)!important; opacity:.72;
}
body.read-only .iconbtn,body.read-only .addrow,body.read-only .tab.add,
body.read-only .delheli,body.read-only .ev-add,body.read-only .pt-btn,
body.read-only .nowbtn,body.read-only #btnAddHeli,body.read-only #btnImport{
  display:none!important;
}
