:root {
  --bg:          #1a1a2e;
  --bg2:         #12122a;
  --bg3:         #16213e;
  --bg4:         #0f3460;
  --accent:      #e94560;
  --accent2:     #74b9ff;
  --text:        #eee;
  --text-dim:    #888;
  --text-dimmer: #666;
  --border:      #0f3460;
  --border2:     #1e3a5c;
  --ok:          #51cf66;
  --warn:        #e9b74a;
  --err:         #ff6b6b;

  --holiday-bg:  #1e3a5c;
  --rem-bg:      #111e33;
  --rem-border:  #4a90d9;
  --rem-txt:     #a8c4e8;
  --rem-emg-bg:  #2d0a0a;
  --rem-emg-txt: #ffbbbb;
  --rem-inf-bg:  #2a1a00;
  --rem-inf-txt: #ffc877;
  --rem-ops-bg:  #2a2210;
  --rem-ops-txt: #f0d080;
  --rem-can-bg:  #1a0a2a;
  --rem-can-txt: #e0aaff;
  --rem-pre-bg:  #1e1428;
  --rem-pre-txt: #d8b4e2;

  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --planner-offset: 0px;
}

[data-theme="light"] {
  --bg:          #f0f2f5;
  --bg2:         #ffffff;
  --bg3:         #e8edf5;
  --bg4:         #c8d8f0;
  --accent:      #c0002e;
  --accent2:     #1a6bbf;
  --text:        #111;
  --text-dim:    #555;
  --text-dimmer: #888;
  --border:      #c8d8f0;
  --border2:     #b0c4de;
  --ok:          #1e8a3a;
  --warn:        #b07800;
  --err:         #c00020;

  --holiday-bg:  #e0f0ff;
  --rem-bg:      #e8eff8;
  --rem-border:  #2a6db5;
  --rem-txt:     #1a3a6a;
  --rem-emg-bg:  #fde8e8;
  --rem-emg-txt: #8b0000;
  --rem-inf-bg:  #fff3e0;
  --rem-inf-txt: #7a4000;
  --rem-ops-bg:  #fffbe6;
  --rem-ops-txt: #6a5000;
  --rem-can-bg:  #f3e8ff;
  --rem-can-txt: #5a0080;
  --rem-pre-bg:  #f8eefc;
  --rem-pre-txt: #6a2a8a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html {
  background: var(--bg);
  min-height: 100%;
  min-height: 100vh;
  min-height: 100dvh;
  overscroll-behavior-y: none;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg); color: var(--text);
  padding-top:    env(safe-area-inset-top);
  padding-bottom: calc(var(--safe-bottom) + var(--planner-offset));
  min-height: 100vh;
  min-height: 100dvh;
  overscroll-behavior-y: none;
  transition: background .2s, color .2s;
}

#topbar {
  display: flex; flex-direction: column; gap: 6px;
  padding: 2px 12px; background: var(--bg2);
  position: sticky; top: 0; z-index: 99;
  border-bottom: 1px solid var(--border);
}

#topbar-main {
  display: flex; align-items: center; gap: 6px;
  width: 100%;
}

#stn-btns { display: flex; gap: 6px; flex: 1; flex-wrap: wrap; }
.stn-btn {
  flex: 1; min-width: 70px; background: var(--bg4); color: var(--text-dim);
  border: none; padding: 7px 4px; border-radius: 8px; font-size: .82rem;
  cursor: pointer; transition: background .15s;
  -webkit-tap-highlight-color: transparent;
}
.stn-btn.active { background: var(--accent); color: #fff; font-weight: bold; }

#action-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  flex-shrink: 0;
  margin-left: auto;
}
#action-btns .action-btn {
  color: var(--text);
}
#action-btns .action-btn-wide {
  grid-column: 1 / -1;
}


.action-btn {
  min-width: 40px !important;
  padding: 2px 4px !important;
  font-size: 1.1rem !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

#reload-btn, #info-btn {
  background: none; border: none; color: var(--accent2);
  font-size: 1.1rem; cursor: pointer; padding: 0 4px;
  line-height: 1;
}

/* Modals */
.modal {
  position: fixed;
  top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0, 0, 0, 0.6);
  z-index: 2000;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px;
}

.modal-content {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  width: 100%;
  max-width: 500px;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border2);
}

.modal-header h3 {
  margin: 0;
  font-size: 1.1rem;
  color: var(--accent2);
}

.modal-close {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 1.2rem;
  cursor: pointer;
}

.modal-body {
  padding: 16px;
  overflow-y: auto;
}

#station-search-input {
  width: 100%;
  padding: 8px;
  border-radius: 6px;
  border: 1px solid var(--border2);
  background: var(--bg3);
  color: var(--text);
}

#station-add-form input[type="text"] {
  width: 100%;
  padding: 6px;
  border-radius: 4px;
  border: 1px solid var(--border2);
  background: var(--bg3);
  color: var(--text);
  margin-top: 4px;
}

.saved-view-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  padding: 7px 8px;
  border: 1px solid var(--border2);
  border-radius: 6px;
  background: var(--bg3);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.saved-view-row:focus,
.saved-view-row:hover {
  border-color: var(--accent2);
}

.saved-view-row-text {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.saved-view-title {
  color: var(--text);
  font-weight: bold;
  overflow-wrap: anywhere;
}

.saved-view-summary,
.saved-view-station,
.saved-view-mode-title {
  color: var(--text-dimmer);
  font-size: .78rem;
}

.saved-view-controls {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.saved-view-icon-btn {
  flex: 0 0 auto;
  min-width: 32px;
  padding: 3px 6px;
}

.saved-view-editor {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 8px;
  padding: 10px;
  border: 1px solid var(--accent2);
  border-radius: 6px;
  background: var(--bg3);
}

.saved-view-editor label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--text-dim);
  font-size: .86rem;
}

.saved-view-editor input[type="text"] {
  width: 100%;
  padding: 6px;
  border-radius: 4px;
  border: 1px solid var(--border2);
  background: var(--bg2);
  color: var(--text);
}

.saved-view-mode-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  margin-top: 4px;
}

.saved-view-mode-list label {
  flex-direction: row;
  align-items: center;
  color: var(--text);
  font-size: .82rem;
}

.saved-view-edit-actions {
  display: flex;
  gap: 8px;
}

input, textarea {
  font-size: 16px !important;
}

#msg-wrap { min-height: 2px; }
#msg { color: var(--text-dim); font-style: italic; padding: 20px 12px; font-size: .9rem; }
.error-txt { color: var(--err) !important; }
#dbg { font-size: .68rem; color: var(--text-dimmer); padding: 2px 12px; min-height: 4px; }

#main {
  padding-top:    8px;
  padding-bottom: 8px;
  padding-left:   12px;
  padding-right:  12px;
}

.dep-card {
  background: var(--bg3); border-radius: 10px; margin-bottom: 8px;
  padding: 11px 13px; cursor: pointer;
  border: 2px solid transparent; transition: border-color .15s;
  -webkit-tap-highlight-color: transparent;
}
.dep-card.selected { border-color: var(--accent); }
.dep-card.is-past  { opacity: .45; }

.dep-row1 { display: flex; align-items: baseline; gap: 8px; margin-bottom: 4px; }
.dep-linie    { font-weight: bold; font-size: 1rem; color: var(--accent); min-width: 50px; }
.dep-richtung { flex: 1; font-size: .95rem; color: var(--text);
                white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dep-time  { font-size: 1.05rem; font-weight: bold; color: var(--text); }
.dep-row2  { display: flex; gap: 10px; font-size: .78rem; color: var(--text-dim); }
.dep-late  { color: var(--err); font-weight: bold; }
.dep-ok    { color: var(--ok); }
.dep-gleis { color: var(--accent2); }

#comp-wrap {
  background: var(--bg2);
  border-top: 2px solid var(--accent);
  padding-top:    6px;
  padding-bottom: 12px;
  padding-left:   12px;
  padding-right:  12px;
  margin-top: 4px;
}

#comp-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0px; }
#comp-title  { font-size: .95rem; color: var(--accent2); font-weight: bold; }
#comp-status { font-size: .82rem; color: var(--text-dim); font-style: italic;
               margin-bottom: 0px; min-height: 0; }
#comp-status:not(:empty) { margin-bottom: 4px; min-height: 1.2em; }
.composition-force-reload {
  margin-left: 8px;
  padding: 2px 8px;
  border: 1px solid var(--accent2);
  border-radius: 4px;
  background: transparent;
  color: var(--accent2);
  font: inherit;
  font-style: normal;
  cursor: pointer;
}
.composition-force-reload:hover {
  background: var(--bg3);
}

.gleis-badge {
  display: inline-block; background: var(--bg4); color: var(--accent2);
  border: 1px solid var(--accent2); border-radius: 6px;
  padding: 2px 12px; font-size: .85rem;
}
.direction-row {
  display: flex; align-items: center;
  margin-bottom: 0; padding: 0 2px;
}
.wagen-count { font-size: .75rem; color: var(--text-dimmer); }

#train-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
#train-flex   { display: flex; gap: 8px; align-items: flex-start;
                width: max-content; padding: 4px 0; }

.wagen-wrap     { display: flex; flex-direction: column; align-items: center; gap: 3px; }
.wagen-img      { width: 160px; height: 56px; display: block;
                  border-radius: 4px; border: 1px solid var(--border2); }
.wagen-info     { text-align: center; max-width: 160px; }
.wagen-label    { font-size: .7rem;  color: var(--accent2); }
.wagen-number   { font-size: .72rem; color: var(--text); font-weight: 700; }
.wagen-baureihe { font-size: .68rem; color: var(--text-dim); }
.wagen-pos      { font-size: .62rem; color: var(--warn); }
.amenity-tag {
  display: inline-block; background: var(--bg3); color: var(--accent2);
  border-radius: 3px; padding: 1px 4px; margin: 1px; font-size: .6rem;
}

/* ── Remarks ──────────────────────────────────────────────────────────── */

#remarks-wrap {
  margin-top: 14px;
  border-top: 1px solid var(--border2);
  padding-top: 10px;
}
#remarks-title {
  font-size: .78rem; color: var(--warn); font-weight: bold;
  margin-bottom: 6px; display: flex; align-items: center; gap: 5px;
}

.remark-item {
  font-size: .78rem; border-radius: 0 5px 5px 0;
  padding: 5px 8px; margin-bottom: 5px; line-height: 1.4;
  display: flex; align-items: flex-start; gap: 6px;
  background: var(--rem-bg); border-left: 3px solid var(--rem-border);
  color: var(--rem-txt);
}
.remark-item.type-emergency {
  background: var(--rem-emg-bg); border-left: 4px solid #ff2222;
  color: var(--rem-emg-txt); font-weight: 600;
}
.remark-item.type-infra {
  background: var(--rem-inf-bg); border-left: 3px solid #ff8800;
  color: var(--rem-inf-txt);
}
.remark-item.type-ops {
  background: var(--rem-ops-bg); border-left: 3px solid var(--warn);
  color: var(--rem-ops-txt);
}
.remark-item.type-cancel {
  background: var(--rem-can-bg); border-left: 4px solid #cc44ff;
  color: var(--rem-can-txt); font-weight: bold;
}
.remark-item.type-preinfo {
  background: var(--rem-pre-bg); border-left: 3px solid #aa55cc;
  color: var(--rem-pre-txt);
}
.remark-icon { flex-shrink: 0; font-size: .9rem; }

/* Konfig-Menü Ausklapp-Pfeile */
.config-toggle-btn {
  background: none; border: none; color: var(--text-dim);
  font-size: 1rem; font-weight: bold; cursor: pointer; width: 100%;
  text-align: left; padding: 4px 0;
  display: flex; align-items: center; gap: 6px;
  -webkit-tap-highlight-color: transparent;
}
.config-toggle-btn .arrow {
  display: inline-block;
  transition: transform .2s;
  font-style: normal;
}
.config-toggle-btn.open .arrow { transform: rotate(90deg); }

/* Ausklappbare "weitere Hinweise" */
#remarks-other-wrap {
  margin-top: 5px;
}
#remarks-other-toggle {
  background: none; border: none; color: var(--text-dim);
  font-size: .78rem; cursor: pointer; padding: 4px 0;
  display: flex; align-items: center; gap: 6px;
  width: 100%;
  -webkit-tap-highlight-color: transparent;
}
#remarks-other-toggle .arrow {
  display: inline-block;
  transition: transform .2s;
  font-style: normal;
}
#remarks-other-toggle.open .arrow { transform: rotate(90deg); }

#remarks-other-list { margin-top: 4px; }

/* ── Zwischenstationen ────────────────────────────────────────────────── */

#stops-wrap {
  margin-top: 10px;
  border-top: 1px solid var(--border2);
  padding-top: 8px;
}
#stops-toggle {
  background: none; border: none; color: var(--accent2);
  font-size: .82rem; cursor: pointer; padding: 4px 0;
  display: flex; align-items: center; gap: 6px;
  width: 100%;
}
#stops-toggle .arrow {
  display: inline-block;
  transition: transform .2s;
  font-style: normal;
}
#stops-toggle.open .arrow { transform: rotate(90deg); }

#stops-list { display: none; margin-top: 6px; }
#stops-list.open { display: block; }

.stop-row {
  display: flex; align-items: baseline;
  gap: 8px; padding: 4px 0;
  border-bottom: 1px solid var(--border2);
  font-size: .78rem;
}
.stop-row:last-child { border-bottom: none; }
.stop-row.is-origin  { color: var(--accent2); font-weight: bold; }
.stop-row.cancelled  { text-decoration: line-through; color: var(--text-dimmer); }

.stop-name { flex: 1; color: var(--text); }
.stop-row.is-origin .stop-name { color: var(--accent2); }

.stop-time  { font-variant-numeric: tabular-nums; color: var(--text-dim); min-width: 38px; text-align: right; }
.stop-delay { color: var(--err); font-size: .7rem; min-width: 28px; }
.stop-ok    { color: var(--ok);  font-size: .7rem; min-width: 28px; }

#std-remarks-wrap {
  margin-top: 8px;
  border-top: 1px solid var(--border2);
  padding-top: 6px;
}
#std-remarks-toggle {
  background: none; border: none; color: var(--text-dim);
  font-size: .80rem; cursor: pointer; padding: 4px 0;
  display: flex; align-items: center; gap: 6px;
  width: 100%;
}
#std-remarks-toggle .arrow { display: inline-block; transition: transform .2s; font-style: normal; }
#std-remarks-toggle.open .arrow { transform: rotate(90deg); }

#std-remarks-list { display: none; margin-top: 4px; }
#std-remarks-list.open { display: block; }

.std-rem-row {
  display: flex; gap: 8px; align-items: flex-start;
  padding: 4px 0; border-bottom: 1px solid var(--border2);
  font-size: .78rem;
}
.std-rem-row:last-child { border-bottom: none; }
.rem-text  { color: var(--text-dim); flex: 1; }
.rem-badge {
  font-size: .65rem; padding: 1px 5px; border-radius: 4px;
  background: var(--border2); color: var(--text-dim);
  white-space: nowrap; align-self: center;
}
.rem-loading, .rem-empty { color: var(--text-dimmer); font-size: .78rem; padding: 4px 0; }

@media screen and (orientation: landscape) {
  #main, #comp-wrap {
    padding-left:  calc(env(safe-area-inset-left,  0px) + 12px);
    padding-right: calc(env(safe-area-inset-right, 0px) + 12px);
  }
}
.chunk-pager {
  margin: 8px 0 8px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.chunk-pager-top {
  margin-top: 2px;
}
.chunk-pager-bottom {
  margin-bottom: 2px;
}

.chunk-btn {
  width: 100%;
  min-height: 28px;
  padding: 4px 10px;
  border: 1px solid var(--border2);
  border-radius: 999px;
  background: var(--bg3);
  color: var(--text-dim);
  font-size: .82rem;
  line-height: 1.1;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
}

.chunk-btn:hover {
  background: var(--bg4);
  color: var(--text);
  border-color: var(--accent2);
}
.chunk-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  font-weight: bold;
}

.line-map-filter-chip {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  color: var(--text-dim);
  background: var(--bg2);
  border: 1px solid var(--border2);
  padding: 3px 7px;
  border-radius: 10px;
  cursor: pointer;
  pointer-events: auto;
  max-width: min(92vw, 360px);
  min-width: 0;
  line-height: 1.2;
  text-align: left;
}
.line-map-filter-chip span {
  min-width: 0;
  overflow-wrap: anywhere;
}
.line-map-filter-chip.active {
  color: #fff;
  background: var(--accent);
  border-color: var(--accent);
  font-weight: bold;
}

.line-map-filter-search {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: min(100%, 340px);
  pointer-events: auto;
}

.line-map-filter-search input {
  width: 100%;
  min-height: 30px;
  box-sizing: border-box;
  border: 1px solid var(--border2);
  border-radius: 8px;
  background: var(--bg2);
  color: var(--text);
  padding: 5px 8px;
  font-size: 0.85rem;
}

.line-map-filter-suggestions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5px;
}

.line-map-filter-suggestion {
  font-size: 0.72rem;
}

.stop-row.clickable {
  cursor: pointer;
}

.stop-row.clickable:hover {
  background: var(--bg3);
}
#filter-bar {
  display: flex;
  background: var(--bg2);
  padding: 2px 0 6px;
  gap: 6px;
  width: 100%;
  overflow-x: auto;
  -ms-overflow-style: none; 
  scrollbar-width: none;
}
#filter-bar::-webkit-scrollbar { 
  display: none; 
}
#filter-bar label {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg3);
  color: var(--text-dim);
  border: 1px solid var(--border2);
  border-radius: 999px;
  padding: 3px 12px;
  font-size: 0.82rem;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
}
#filter-bar input[type="radio"] { 
  display: none; 
}
#filter-bar label.active {
  background: var(--bg4);
  border-color: var(--accent2);
  color: var(--text);
  font-weight: 500;
}
/* Pull-to-Refresh: Dynamic Island Style */
#ptr-indicator {
  position: fixed;
  top: 11px; /* Position direkt auf/hinter der Dynamic Island */
  left: 50%;
  transform: translateX(-50%) translateY(0) scaleX(0.8);
  width: 120px;
  height: 36px;
  background: #000; /* Tiefschwarz wie die Island */
  border-radius: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  opacity: 0;
  transition: transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.2s;
  pointer-events: none;
  box-shadow: 0 4px 15px rgba(0,0,0,0.5);
}

/* Das Icon innerhalb der Kapsel */
#ptr-icon {
  color: #fff;
  transition: transform 0.2s ease;
}

/* Wenn gezogen wird, wird die Kapsel sichtbar */
#ptr-indicator.active {
  opacity: 1;
}

@keyframes ptr-spin {
  100% { transform: rotate(360deg); }
}
.ptr-spinning {
  animation: ptr-spin 1s linear infinite;
  color: var(--accent2) !important;
}

/* Styling für die Ferien-Info in den Details (Farbige Version) */
.rem-holiday-box {
  margin-top: 8px;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 0.82rem; /* Gleiche Größe wie Remarks */
  line-height: 1.4;
  
  /* ÄNDERUNG: Nutze die neue Hintergrundvariable */
  background: var(--holiday-bg); 
  
  /* ÄNDERUNG: Nutze die Haupt-Akzentfarbe (Blau) für die Seitenlinie */
  border-left: 3px solid var(--accent2); 
  
  /* Textfarbe leicht anpassen, damit sie auf dem Blau gut lesbar ist */
  color: var(--text); 
}

/* WICHTIG: Text innerhalb der Box, der standardmäßig gedimmt ist, wiederherstellen */
.rem-holiday-box strong {
  color: var(--accent2); /* "Heute:" in Blau hervorheben */
}

/* Die Warnung für kommende Ferien bleibt gelb */
.holiday-upcoming-warn {
  color: var(--warn);
  display: block;
  font-weight: bold;
  margin-top: 4px;
}
/* ── Toast Notifications ──────────────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--bg2);
  color: var(--text);
  padding: 10px 20px;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  z-index: 2000;
  opacity: 0;
  transition: opacity 0.3s, transform 0.3s;
  pointer-events: none;
  font-size: 0.9rem;
  border: 1px solid var(--border1);
  white-space: nowrap;
}
.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.toast.toast-error {
  border-left: 4px solid var(--err);
}

/* ── Reiseplaner (Bottom Bar) ────────────────────────────────────────── */
#planner-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--bg2);
  border-top: 2px solid var(--accent2);
  z-index: 1000;
  padding-bottom: var(--safe-bottom);
  box-shadow: 0 -4px 15px rgba(0,0,0,0.3);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  transform: translateY(0);
}

#planner-bar.visual-viewport-anchored {
  top: var(--planner-top);
  bottom: auto;
}

#planner-header {
  padding: 12px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: bold;
  color: var(--accent2);

  -webkit-tap-highlight-color: transparent;
}

#planner-header .icon {
  transition: transform 0.3s;
}

#planner-content {
  max-height: 50vh;
  overflow-y: auto;
  padding: 0 12px 12px 12px;
  display: block;
}

#planner-bar.minimized #planner-content {
  display: none;
}
#planner-bar.minimized #planner-header .icon {
  transform: rotate(180deg);
}

/* Planer-Karten */
.plan-card {
  background: var(--bg3);
  border-radius: 8px;
  padding: 10px;
  margin-bottom: 8px;
  border: 1px solid var(--border2);
}
.plan-card.permanent {
  background: var(--bg4);
  border-color: var(--accent2);
}
.plan-card.permanent.missing {
  background: #351827;
  border-color: #a84b5f;
}
.plan-card.permanent.partial {
  background: #332617;
  border-color: #b57933;
}
[data-theme="light"] .plan-card.permanent.missing {
  background: #fdebed;
  border-color: #d88995;
}
[data-theme="light"] .plan-card.permanent.partial {
  background: #fff3df;
  border-color: #d8a15f;
}
.plan-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 8px; border-bottom: 1px solid var(--border2); padding-bottom: 6px;
}
.plan-route { font-size: .9rem; font-weight: bold; color: var(--text); flex: 1; display: flex; align-items: center; flex-wrap: wrap; gap: 4px; }
.plan-date-badge {
  font-size: 0.75rem; background: var(--bg2); color: var(--text-dim);
  padding: 2px 6px; border-radius: 4px; border: 1px solid var(--border2);
}
.perm-indicator { font-size: 0.85rem; margin-left: 2px; }
.plan-status-badge {
  font-size: 0.72rem;
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: bold;
}
.plan-status-badge.missing {
  background: rgba(255, 107, 107, 0.16);
  border: 1px solid rgba(255, 107, 107, 0.45);
  color: #ffb3b3;
}
.plan-status-badge.partial {
  background: rgba(233, 183, 74, 0.18);
  border: 1px solid rgba(233, 183, 74, 0.5);
  color: #ffd58a;
}
[data-theme="light"] .plan-status-badge.missing {
  background: #fff5f5;
  border-color: #e3a5ad;
  color: #9e2338;
}
[data-theme="light"] .plan-status-badge.partial {
  background: #fff8eb;
  border-color: #e1bb7a;
  color: #8b560d;
}
.plan-line { font-size: .75rem; background: var(--bg4); padding: 2px 6px; border-radius: 4px; color: var(--accent2); font-weight: bold; margin-left: 8px; }
.plan-times { display: flex; justify-content: space-between; font-size: .85rem; margin-bottom: 8px; color: var(--text-dim); }
.plan-wagon-seq { display: flex; gap: 2px; height: 3px; align-items: center; margin-bottom: 2px; width: 100%; max-width: 200px; margin-left: auto; margin-right: auto; }
.plan-wagon-item { flex: 1; height: 3px; border-radius: 2px; background: #111; }
.plan-wagon-lok { flex: 1; height: 3px; border-radius: 2px; background: #888; }
[data-theme="light"] .plan-wagon-item { background: #333; }
[data-theme="light"] .plan-wagon-lok { background: #aaa; }
.plan-actions { display: flex; justify-content: space-between; gap: 6px; flex-wrap: wrap; }
.plan-btn {
  flex: 1; background: var(--bg4); color: var(--text); border: none;
  padding: 6px 0; border-radius: 4px; font-size: .8rem; cursor: pointer; transition: background 0.2s;
  min-width: 36px;
}
.plan-btn:hover { background: var(--bg2); }
.plan-btn.remove { color: var(--err); flex: 0.5; }
.plan-btn.active {
  background: var(--accent);
  color: white;
  font-weight: bold;
}

.plan-tab-btn {
  flex: 1;
  background: var(--bg3);
  color: var(--text-dim);
  border: 1px solid var(--border2);
  padding: 4px 0;
  border-radius: 6px;
  font-size: .80rem;
  cursor: pointer;
  transition: all 0.2s;
}

.plan-tab-btn.active {
  background: var(--bg4);
  color: var(--text);
  border-color: var(--accent2);
  font-weight: bold;
}

/* Plus-Button für Haltestellen */
.add-plan-btn {
  background: var(--bg4); color: var(--accent2); border: 1px solid var(--accent2);
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-weight: bold; margin-left: auto; font-size: 1rem;
  line-height: 1; transition: all 0.2s;
}
.add-plan-btn:active { background: var(--accent2); color: #fff; transform: scale(0.9); }

/* GPS Marker */
.gps-marker-icon {
  background: transparent;
  border: none;
}
.gps-svg {
  display: block;
}
.gps-svg path {
  fill: #3b82f6; /* Bright blue */
  stroke: #ffffff;
  stroke-width: 2px;
  stroke-linejoin: round;
}
[data-theme="dark"] .gps-svg path {
  fill: #60a5fa; /* Lighter blue for dark mode */
  stroke: #1a1a2e; /* Match background for contrast */
}

/* Button um vorherige Halte anzuzeigen */
.show-past-stops-btn {
  background: var(--bg4); color: var(--accent2); border: 1px solid var(--accent2);
  border-radius: 12px; padding: 2px 10px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-weight: bold; margin-left: auto; font-size: 0.8rem;
  line-height: 1; transition: all 0.2s;
}
.show-past-stops-btn:active { background: var(--accent2); color: #fff; transform: scale(0.9); }
/* Leaflet Tooltip Dark Mode Fixes */
[data-theme="dark"] .leaflet-tooltip {
  background-color: var(--bg) !important;
  border: 1px solid var(--border2) !important;
  color: var(--text) !important;
}
[data-theme="dark"] .leaflet-tooltip-top:before {
  border-top-color: var(--bg) !important;
}
[data-theme="dark"] .leaflet-tooltip-bottom:before {
  border-bottom-color: var(--bg) !important;
}
[data-theme="dark"] .leaflet-tooltip-left:before {
  border-left-color: var(--bg) !important;
}
[data-theme="dark"] .leaflet-tooltip-right:before {
  border-right-color: var(--bg) !important;
}

/* Paused permanent journeys */
.plan-card.permanent.paused {
  opacity: 0.6;
  border-color: var(--border2);
  filter: grayscale(0.5);
}
.plan-btn.paused-btn {
  background: transparent;
  font-size: 1.2rem;
}

/* ── Tagebuch ─────────────────────────────────────────────────────────── */
.diary-entry-content,
.diary-list-content {
  max-width: 720px;
}

.diary-entry-summary {
  margin-bottom: 12px;
  padding: 10px;
  border: 1px solid var(--border2);
  border-radius: 6px;
  background: var(--bg3);
}

.diary-summary-line {
  margin-bottom: 8px;
  color: var(--text);
}

.diary-summary-grid {
  display: grid;
  grid-template-columns: minmax(76px, 0.35fr) minmax(0, 1fr);
  gap: 5px 10px;
  font-size: .84rem;
}

.diary-summary-grid span:nth-child(odd) {
  color: var(--text-dimmer);
}

.diary-summary-grid span:nth-child(even) {
  min-width: 0;
  overflow-wrap: anywhere;
}

.diary-edit-label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 10px;
  color: var(--text-dim);
  font-size: .86rem;
}

.diary-edit-label input,
.diary-edit-label textarea,
.diary-pagination select {
  width: 100%;
  border: 1px solid var(--border2);
  border-radius: 6px;
  background: var(--bg3);
  color: var(--text);
  padding: 7px;
}

.diary-entry-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}

.diary-category-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(42px, 1fr));
  gap: 6px;
}

.diary-category-btn {
  min-height: 34px;
  border: 1px solid var(--border2);
  border-radius: 6px;
  background: var(--bg3);
  color: var(--text-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}

.diary-category-btn.active {
  background: var(--bg4);
  color: var(--text);
  border-color: var(--accent2);
}

.diary-category-btn:hover {
  color: var(--text);
  border-color: var(--accent2);
}

.diary-category-neutral {
  font-size: .72rem;
  line-height: 1;
}

.diary-category-svg {
  flex-shrink: 0;
}

.diary-card {
  margin-bottom: 8px;
  border: 1px solid var(--border2);
  border-radius: 8px;
  background: var(--bg3);
  overflow: hidden;
}

.diary-card-header {
  width: 100%;
  border: none;
  background: transparent;
  color: var(--text);
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  padding: 10px;
  cursor: pointer;
  text-align: left;
}

.diary-card-title-wrap {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.diary-card-title-row {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
}

.diary-card-category-icon {
  width: 20px;
  min-width: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent2);
}

.diary-card-category-icon:empty {
  display: none;
}

.diary-card-header strong {
  overflow-wrap: anywhere;
}

.diary-card-header small {
  color: var(--text-dimmer);
  font-size: .76rem;
}

.diary-card-line {
  flex-shrink: 0;
  max-width: 35%;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--bg4);
  color: var(--accent2);
  font-size: .74rem;
  font-weight: bold;
  overflow-wrap: anywhere;
  text-align: right;
}

.diary-card-detail {
  padding: 10px;
  border-top: 1px solid var(--border2);
  background: var(--bg2);
}

.diary-card-detail h4 {
  margin: 12px 0 5px;
  font-size: .9rem;
  color: var(--accent2);
}

.diary-wagon-list {
  margin-left: 18px;
  color: var(--text-dim);
  font-size: .82rem;
  line-height: 1.45;
}

.diary-empty {
  padding: 16px;
  text-align: center;
  color: var(--text-dimmer);
}

.diary-pagination {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 8px;
  align-items: center;
  margin-top: 12px;
  color: var(--text-dim);
  font-size: .82rem;
}

.diary-pagination label {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 8px;
}

.diary-pagination select {
  width: auto;
  min-width: 70px;
}

/* UI Icons */
.ui-icon {
  width: 1em;
  height: 1em;
  vertical-align: -0.125em;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.ui-icon-fill {
  fill: currentColor;
  stroke: none;
}
