/* ===================================================================
 *  Fahrrad-Treffpunkt — presentation layer
 *  Design system: Linear (VoltAgent/awesome-design-md · linear.app)
 *  Deep neutral canvas · single lavender accent · hairline borders ·
 *  surface-ladder elevation (no shadows/gradients) · Inter Tight.
 * =================================================================== */

/* ----------------------------- Tokens ----------------------------- */
:root{
  /* type */
  --font:'Inter Tight','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:'Geist Mono','SF Mono',ui-monospace,'JetBrains Mono',Menlo,monospace;

  /* spacing scale (4px base) */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px; --s-8:32px; --s-12:48px;

  /* radius scale */
  --r-xs:4px; --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:16px; --r-pill:9999px;

  /* type scale (Linear) */
  --t-display:28px; --t-headline:20px; --t-title:15px; --t-body:14px;
  --t-sm:13px; --t-caption:12px; --t-micro:11px; --t-eyebrow:11px;

  /* accent — Linear lavender-blue, the single chromatic accent */
  --accent:#5e6ad2; --accent-hover:#6e79e0; --accent-press:#5e69d1;
  --on-accent:#ffffff;

  /* timing */
  --ease:cubic-bezier(.4,0,.2,1);
}

/* Dark — primary, must be excellent */
[data-theme="dark"]{
  --canvas:#08090a;          /* page / map base — near-black neutral, faint cool tint */
  --surface-1:#0f1011;       /* cards, panels */
  --surface-2:#141516;       /* lifted: inputs track, hovered, segmented well */
  --surface-3:#18191a;       /* nested rows, active segment */
  --hairline:#23252a;        /* 1px borders, dividers */
  --hairline-strong:#34343a; /* hover / focus borders */
  --hairline-tertiary:#3e3e44;

  --ink:#f7f8f8;             /* primary text */
  --ink-muted:#d0d6e0;       /* secondary */
  --ink-subtle:#8a8f98;      /* tertiary / meta */
  --ink-tertiary:#62666d;    /* quaternary / disabled */

  --accent-tint:rgba(94,106,210,.16);
  --accent-ring:rgba(94,106,210,.45);
  /* alias used by app.js inline styles (routing "✓ aktiv") — keep defined */
  --accent-2:#27a644;
  --success:#27a644; --success-tint:rgba(39,166,68,.14);
  --warn:#d9a441; --warn-tint:rgba(217,164,65,.14);
  --danger:#e5484d; --danger-tint:rgba(229,72,77,.14);
  --pin-ring:rgba(255,255,255,.9);
  --scrim:rgba(0,0,0,.55);
}

/* Light — tasteful neutral, same restraint */
[data-theme="light"]{
  --canvas:#fbfbfa;
  --surface-1:#ffffff;
  --surface-2:#f6f6f5;
  --surface-3:#f0f0ef;
  --hairline:#e8e8e6;
  --hairline-strong:#d6d6d3;
  --hairline-tertiary:#cacac6;

  --ink:#16171a;
  --ink-muted:#3c4049;
  --ink-subtle:#6b7079;
  --ink-tertiary:#9a9ea6;

  --accent-tint:rgba(94,106,210,.10);
  --accent-ring:rgba(94,106,210,.35);
  --accent-2:#1f9d3c;
  --success:#1f9d3c; --success-tint:rgba(31,157,60,.12);
  --warn:#b9842b; --warn-tint:rgba(185,132,43,.12);
  --danger:#d33a3f; --danger-tint:rgba(211,58,63,.10);
  --pin-ring:rgba(255,255,255,.95);
  --scrim:rgba(20,22,28,.35);
}

/* ----------------------------- Base ----------------------------- */
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:var(--font); font-size:var(--t-body); line-height:1.5;
  color:var(--ink); background:var(--canvas);
  display:flex; height:100vh; overflow:hidden;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  letter-spacing:-.005em;
}
::selection{background:var(--accent-tint);color:var(--ink)}
svg{display:block}
.ic{width:16px;height:16px;stroke:currentColor;stroke-width:1.5;fill:none;
  stroke-linecap:round;stroke-linejoin:round;flex:none}

/* ----------------------------- Sidebar ----------------------------- */
.sidebar{
  width:380px; min-width:340px; height:100%; display:flex; flex-direction:column;
  background:var(--canvas);
  border-right:1px solid var(--hairline);
  z-index:1000; position:relative;
}

.brand{
  display:flex; align-items:center; gap:var(--s-3);
  padding:var(--s-5) var(--s-5) var(--s-4);
  border-bottom:1px solid var(--hairline);
}
.brand .logo{
  width:34px;height:34px;border-radius:var(--r-md);
  display:grid;place-items:center;flex:none;
  color:var(--ink);
  background:var(--surface-2);
  border:1px solid var(--hairline);
}
.brand .logo .ic{width:19px;height:19px}
.brand-txt{flex:1;min-width:0}
.brand h1{
  font-size:var(--t-title);margin:0;font-weight:600;
  letter-spacing:-.02em;line-height:1.2;
}
.brand p{
  margin:2px 0 0;font-size:var(--t-micro);color:var(--ink-subtle);
  line-height:1.3;letter-spacing:0;
}

.icon-btn{
  width:30px;height:30px;border-radius:var(--r-md);
  border:1px solid var(--hairline);background:transparent;
  color:var(--ink-subtle);cursor:pointer;flex:none;
  display:grid;place-items:center;
  transition:color .15s var(--ease),border-color .15s var(--ease),background .15s var(--ease);
}
.icon-btn:hover{color:var(--ink);border-color:var(--hairline-strong);background:var(--surface-2)}
.icon-btn:active{background:var(--surface-3)}

.scroll{
  flex:1;overflow-y:auto;
  padding:var(--s-4) var(--s-4) var(--s-5);
  display:flex;flex-direction:column;gap:var(--s-3);
}
.scroll::-webkit-scrollbar{width:10px}
.scroll::-webkit-scrollbar-thumb{
  background:var(--hairline-strong);border-radius:var(--r-pill);
  border:3px solid transparent;background-clip:content-box;
}
.scroll::-webkit-scrollbar-thumb:hover{background:var(--hairline-tertiary);background-clip:content-box}

/* ----------------------------- Cards ----------------------------- */
.card{
  background:var(--surface-1);
  border:1px solid var(--hairline);
  border-radius:var(--r-lg);
  padding:var(--s-4);
}
.card-head{display:flex;align-items:center;gap:var(--s-3);margin-bottom:var(--s-4)}
.card-head h2{
  font-size:var(--t-sm);margin:0;font-weight:600;
  letter-spacing:-.01em;flex:1;color:var(--ink);line-height:1.2;
}
.step{
  width:20px;height:20px;border-radius:var(--r-sm);
  background:var(--surface-3);border:1px solid var(--hairline);
  color:var(--ink-subtle);
  font-size:var(--t-micro);font-weight:600;font-variant-numeric:tabular-nums;
  display:grid;place-items:center;flex:none;
}
.badge{
  background:var(--surface-3);border:1px solid var(--hairline);
  color:var(--ink-muted);
  font-size:var(--t-caption);font-weight:600;font-variant-numeric:tabular-nums;
  border-radius:var(--r-pill);padding:1px 8px;min-width:22px;text-align:center;
}

/* ----------------------------- Inputs ----------------------------- */
.field{position:relative;margin-bottom:var(--s-2)}
.field:last-child{margin-bottom:0}
input[type=text]{
  width:100%;padding:9px 12px;
  background:var(--surface-2);
  border:1px solid var(--hairline);
  border-radius:var(--r-md);
  color:var(--ink);font-size:var(--t-body);font-family:var(--font);
  line-height:1.4;outline:none;letter-spacing:-.005em;
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease),background .15s var(--ease);
}
input[type=text]:hover{border-color:var(--hairline-strong)}
input[type=text]:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-ring);
  background:var(--surface-1);
}
input::placeholder{color:var(--ink-tertiary)}
.search .mini-spin{position:absolute;right:11px;top:calc(50% - 7px)}

.lbl{
  display:block;font-size:var(--t-eyebrow);text-transform:uppercase;
  letter-spacing:.06em;color:var(--ink-subtle);
  margin:var(--s-4) 0 var(--s-2);font-weight:600;
}
.hint{
  font-size:var(--t-caption);color:var(--ink-subtle);
  margin:var(--s-3) 0 0;line-height:1.5;letter-spacing:0;
}
.hint b{color:var(--ink-muted);font-weight:600}

/* search results */
.results{display:flex;flex-direction:column;gap:4px;margin-top:var(--s-2)}
.results:empty{margin-top:0}
.result{
  text-align:left;background:transparent;
  border:1px solid var(--hairline);color:var(--ink);
  padding:8px 11px;border-radius:var(--r-md);cursor:pointer;
  line-height:1.35;font-size:var(--t-sm);font-weight:500;
  display:block;width:100%;font-family:var(--font);
  transition:border-color .12s var(--ease),background .12s var(--ease);
}
.result:hover{border-color:var(--hairline-strong);background:var(--surface-2)}
.result small{
  display:block;color:var(--ink-subtle);font-weight:400;
  font-size:var(--t-micro);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ----------------------------- People list ----------------------------- */
.people{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.people:empty{display:none}
.person{
  display:flex;align-items:center;gap:var(--s-3);
  background:var(--surface-2);
  border:1px solid var(--hairline);
  padding:8px 10px;border-radius:var(--r-md);
  transition:border-color .12s var(--ease),background .12s var(--ease);
  animation:rise .18s var(--ease);
}
.person:hover{border-color:var(--hairline-strong)}
@keyframes rise{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
.dot{
  width:9px;height:9px;border-radius:50%;flex:none;
  box-shadow:0 0 0 3px var(--surface-2),0 0 0 4px var(--hairline-strong);
}
.person .info{flex:1;min-width:0;cursor:pointer}
.person .nm{
  font-weight:600;font-size:var(--t-sm);color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;
}
.person .ad{
  font-size:var(--t-micro);color:var(--ink-subtle);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;
}
.person .dist{text-align:right;font-family:var(--mono);font-variant-numeric:tabular-nums;line-height:1.2}
.person .dist b{font-size:var(--t-sm);color:var(--ink);font-weight:600;letter-spacing:-.02em}
.person .dist span{display:block;font-size:var(--t-micro);color:var(--ink-subtle);margin-top:1px}
/* remove button — app.js injects a "✕" text glyph; hide it and paint a
   Lucide-style "x" via mask so the control reads as a crisp 1.5px icon */
.person .rm{
  width:24px;height:24px;border-radius:var(--r-sm);
  border:1px solid transparent;background:transparent;
  font-size:0;color:transparent;
  cursor:pointer;flex:none;position:relative;
  transition:background .12s var(--ease);
}
.person .rm::before{
  content:'';position:absolute;inset:0;margin:auto;
  width:14px;height:14px;background:var(--ink-tertiary);
  -webkit-mask:var(--x-mask) center/contain no-repeat;
  mask:var(--x-mask) center/contain no-repeat;
  transition:background .12s var(--ease);
}
.person .rm:hover{background:var(--danger-tint)}
.person .rm:hover::before{background:var(--danger)}
:root{
  --x-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}

/* empty state */
.empty{
  text-align:center;color:var(--ink-subtle);font-size:var(--t-sm);
  padding:var(--s-6) var(--s-3) var(--s-5);line-height:1.6;letter-spacing:0;
}
.empty-ic{
  width:40px;height:40px;margin:0 auto var(--s-3);
  display:grid;place-items:center;
  border-radius:var(--r-lg);
  background:var(--surface-2);border:1px solid var(--hairline);
  color:var(--ink-tertiary);
}
.empty-ic .ic{width:20px;height:20px;stroke-width:1.5}
.empty b{color:var(--ink-muted);font-weight:600}

/* ----------------------------- Segmented controls ----------------------------- */
.seg{
  display:flex;background:var(--surface-2);
  border:1px solid var(--hairline);border-radius:var(--r-md);
  padding:3px;gap:2px;
}
.seg-btn{
  flex:1;border:1px solid transparent;background:transparent;
  color:var(--ink-subtle);font-size:var(--t-caption);font-weight:500;
  padding:6px 4px;border-radius:var(--r-sm);cursor:pointer;
  font-family:var(--font);letter-spacing:-.005em;
  transition:color .15s var(--ease),background .15s var(--ease),border-color .15s var(--ease);
}
.seg-btn:hover{color:var(--ink-muted)}
.seg-btn.active{
  background:var(--surface-1);
  color:var(--ink);
  border-color:var(--hairline-strong);
}

/* switch */
.switch{
  display:flex;align-items:center;gap:var(--s-3);
  margin:var(--s-4) 0 0;cursor:pointer;
  font-size:var(--t-sm);font-weight:500;color:var(--ink-muted);user-select:none;
}
.switch input{display:none}
.switch .track{
  width:34px;height:20px;border-radius:var(--r-pill);
  background:var(--surface-3);border:1px solid var(--hairline-strong);
  position:relative;transition:.2s var(--ease);flex:none;
}
.switch .thumb{
  position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;
  background:var(--ink-subtle);transition:.2s var(--ease);
}
.switch input:checked + .track{background:var(--accent);border-color:var(--accent)}
.switch input:checked + .track .thumb{transform:translateX(14px);background:var(--on-accent)}
.switch small{display:block;color:var(--ink-subtle);font-size:var(--t-micro);font-weight:500;margin-top:1px}

/* ----------------------------- Buttons ----------------------------- */
button.primary{
  width:100%;margin-top:var(--s-4);
  border:1px solid var(--accent);border-radius:var(--r-md);padding:10px 14px;
  background:var(--accent);color:var(--on-accent);
  font-size:var(--t-body);font-weight:600;cursor:pointer;font-family:var(--font);
  letter-spacing:-.01em;
  display:flex;align-items:center;justify-content:center;gap:var(--s-2);
  transition:background .15s var(--ease),border-color .15s var(--ease),opacity .15s var(--ease);
}
button.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}
button.primary:active:not(:disabled){background:var(--accent-press);border-color:var(--accent-press)}
button.primary:disabled{
  opacity:1;cursor:not-allowed;
  background:var(--surface-2);border-color:var(--hairline);color:var(--ink-tertiary);
}

.ghost{
  background:transparent;border:1px solid var(--hairline);color:var(--ink-subtle);
  border-radius:var(--r-md);padding:7px 11px;
  font-size:var(--t-caption);font-weight:500;cursor:pointer;font-family:var(--font);
  display:inline-flex;align-items:center;justify-content:center;gap:6px;letter-spacing:-.005em;
  transition:color .12s var(--ease),border-color .12s var(--ease),background .12s var(--ease);
}
.ghost .ic{width:14px;height:14px}
.ghost:hover{color:var(--ink);border-color:var(--hairline-strong);background:var(--surface-2)}
.ghost.danger:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-tint)}
.foot-actions{display:flex;gap:var(--s-2);margin-top:var(--s-1)}
.foot-actions .ghost{flex:1}

.credit{
  text-align:center;font-size:var(--t-micro);color:var(--ink-tertiary);
  margin:var(--s-2) 0 0;letter-spacing:0;line-height:1.5;
}

/* ----------------------------- Summary / start info ----------------------------- */
.summary{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:var(--s-4)}
.stat{
  background:var(--surface-2);border:1px solid var(--hairline);
  border-radius:var(--r-md);padding:9px 11px;
}
.stat .k{
  display:block;font-size:var(--t-micro);text-transform:uppercase;
  letter-spacing:.05em;color:var(--ink-subtle);font-weight:600;
}
.stat .v{
  font-size:var(--t-headline);font-weight:600;font-family:var(--mono);
  font-variant-numeric:tabular-nums;letter-spacing:-.03em;
  margin-top:2px;display:block;color:var(--ink);line-height:1.1;
}
.start-info{
  margin-top:var(--s-3);font-size:var(--t-caption);color:var(--ink-subtle);
  background:var(--surface-2);border:1px solid var(--hairline);
  border-radius:var(--r-md);padding:9px 11px;line-height:1.6;letter-spacing:0;
}
.start-info a{color:var(--ink);text-decoration:none;font-weight:600;border-bottom:1px solid var(--hairline-strong)}
.start-info a:hover{border-bottom-color:var(--accent);color:var(--accent)}
.start-info .mono{font-family:var(--mono);font-size:var(--t-micro);color:var(--ink-subtle)}
.tag{
  display:inline-block;font-size:var(--t-micro);font-weight:600;
  padding:1px 7px;border-radius:var(--r-pill);vertical-align:middle;
  border:1px solid transparent;letter-spacing:0;
}
.tag.route{background:var(--success-tint);color:var(--success);border-color:var(--success-tint)}
.tag.air{background:var(--warn-tint);color:var(--warn);border-color:var(--warn-tint)}

/* ----------------------------- Map ----------------------------- */
#map{flex:1;height:100%;background:var(--canvas)}
.leaflet-container{font-family:var(--font);background:var(--canvas)}
.leaflet-control-zoom a{
  background:var(--surface-1)!important;color:var(--ink-muted)!important;
  border-color:var(--hairline)!important;
}
.leaflet-control-zoom a:hover{background:var(--surface-2)!important;color:var(--ink)!important}
.leaflet-bar{
  border:1px solid var(--hairline)!important;border-radius:var(--r-md)!important;
  overflow:hidden;box-shadow:none!important;
}
.leaflet-control-attribution{
  background:var(--scrim)!important;color:var(--ink-tertiary)!important;
  font-size:10px!important;backdrop-filter:blur(4px);
}
.leaflet-control-attribution a{color:var(--ink-subtle)!important}
.leaflet-tooltip{
  background:var(--surface-1);color:var(--ink);
  border:1px solid var(--hairline);border-radius:var(--r-sm);
  box-shadow:none;font-weight:500;font-size:var(--t-caption);padding:3px 8px;
}
.leaflet-tooltip-top:before{border-top-color:var(--hairline)}

/* participant pin — teardrop */
.pin{
  width:22px;height:22px;border-radius:50% 50% 50% 0;
  transform:rotate(-45deg);
  border:2px solid var(--pin-ring);
  box-shadow:0 2px 6px var(--scrim);
}
/* meeting-point flag — accent, intentional SVG via mask */
.pin.start{
  width:30px;height:30px;border-radius:50% 50% 50% 0;
  background:var(--accent);
  border:2px solid var(--pin-ring);
  display:grid;place-items:center;
}
.pin.start::after{
  content:'';
  width:13px;height:13px;transform:rotate(45deg);
  background:var(--on-accent);
  -webkit-mask:var(--flag-mask) center/contain no-repeat;
  mask:var(--flag-mask) center/contain no-repeat;
}
:root{
  /* Lucide-style "flag" icon as a mask so the marker reads as a real glyph */
  --flag-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 15s1-1 4-1 5 2 8 2 4-1 4-1V3s-1 1-4 1-5-2-8-2-4 1-4 1z'/%3E%3Cline x1='4' y1='22' x2='4' y2='15'/%3E%3C/svg%3E");
}

/* ----------------------------- Toasts ----------------------------- */
.toasts{
  position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:9999;
  display:flex;flex-direction:column;gap:var(--s-2);align-items:center;
}
.toast{
  background:var(--surface-1);color:var(--ink);
  border:1px solid var(--hairline-strong);
  padding:10px 16px;border-radius:var(--r-md);
  font-weight:500;font-size:var(--t-sm);letter-spacing:-.005em;
  box-shadow:0 8px 24px var(--scrim);
  animation:toastin .22s var(--ease);max-width:80vw;
}
.toast.err{border-color:var(--danger)}
.toast.ok{border-color:var(--success)}
@keyframes toastin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ----------------------------- Spinner ----------------------------- */
.mini-spin{
  display:inline-block;width:14px;height:14px;
  border:2px solid var(--hairline-tertiary);border-top-color:var(--accent);
  border-radius:50%;animation:spin .7s linear infinite;
}
.btn-spin{border:2px solid rgba(255,255,255,.35);border-top-color:#fff}
@keyframes spin{to{transform:rotate(360deg)}}

/* ----------------------------- Mobile ----------------------------- */
@media (max-width:820px){
  body{flex-direction:column}
  .sidebar{
    width:100%;min-width:0;height:auto;max-height:62vh;
    border-right:none;border-bottom:1px solid var(--hairline);
  }
  #map{min-height:38vh}
}
