/* ───────── SPOT! — Design tokens & base ───────── */
:root{
  --blue:#3470C8; --blue-pressed:#2A5BA3; --blue-tint:#EAF1FB;
  --bg:#FFFFFF; --surface:#F5F7FA; --card:#FFFFFF; --border:#E6E9EF;
  --t1:#14223A; --t2:#6B7689; --t3:#9AA3B2;
  --c-unfall:#E5484D; --c-feuer:#F76808; --c-polizei:#3470C8; --c-blitzer:#F5A623;
  --c-frage:#8E4EC6; --c-tipp:#30A46C; --c-person:#E93D82; --c-sonst:#8B93A1;
  --success:#30A46C; --warning:#F5A623; --danger:#E5484D;
  --shadow-sm:0 1px 2px rgba(20,34,58,0.05);
  --shadow:0 1px 2px rgba(20,34,58,0.04), 0 6px 16px rgba(20,34,58,0.06);
  --shadow-lg:0 8px 28px rgba(20,34,58,0.12);
  --r-card:22px; --r-input:13px; --r-btn:13px;
}
*{box-sizing:border-box}
.spot-app, .spot-app *{
  font-family:'Inter',-apple-system,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
}
.spot-app{
  height:100%;display:flex;flex-direction:column;background:var(--bg);
  color:var(--t1);position:relative;overflow:hidden;
}
.mono{font-family:'JetBrains Mono','SF Mono',monospace}

/* scroll region — clears status bar / sits above tab bar */
.screen{flex:1;overflow-y:auto;overflow-x:hidden;position:relative;-webkit-overflow-scrolling:touch}
.screen::-webkit-scrollbar{width:0;display:none}
.pad-status{padding-top:58px}
.pad-home{padding-bottom:34px}

/* top bar */
.topbar{
  position:sticky;top:0;z-index:30;background:rgba(255,255,255,0.86);
  backdrop-filter:blur(18px) saturate(180%);-webkit-backdrop-filter:blur(18px) saturate(180%);
  padding:54px 18px 12px;display:flex;align-items:center;gap:12px;
  border-bottom:1px solid transparent;transition:border-color .2s;
}
.topbar.scrolled{border-bottom-color:var(--border)}
.topbar h1{font-size:24px;font-weight:800;letter-spacing:-.02em}
.iconbtn{
  width:42px;height:42px;border-radius:13px;border:none;background:var(--surface);
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;
  color:var(--t1);transition:background .15s,transform .1s;
}
.iconbtn:active{transform:scale(.92);background:#EBEEF3}
.iconbtn.ghost{background:transparent}

/* buttons */
.btn{
  border:none;font-family:inherit;font-weight:600;font-size:16px;border-radius:var(--r-btn);
  padding:15px 20px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  gap:8px;transition:transform .1s,background .15s,box-shadow .15s;width:100%;
}
.btn:active{transform:scale(.985)}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 4px 14px rgba(52,112,200,.32)}
.btn-primary:active{background:var(--blue-pressed)}
.btn-secondary{background:var(--blue-tint);color:var(--blue)}
.btn-ghost{background:transparent;color:var(--t2);box-shadow:inset 0 0 0 1.5px var(--border)}
.btn-social{background:#fff;color:var(--t1);box-shadow:inset 0 0 0 1.5px var(--border);font-weight:600}
.btn-dark{background:var(--t1);color:#fff}
.btn-sm{padding:10px 16px;font-size:14px;width:auto}

/* inputs */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}
.field label{font-size:13px;font-weight:600;color:var(--t2);padding-left:2px}
.input{
  background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-input);
  padding:14px 16px;font-family:inherit;font-size:16px;color:var(--t1);width:100%;
  display:flex;align-items:center;gap:10px;transition:border-color .15s,box-shadow .15s;
}
.input:focus-within{border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-tint)}
.input input{border:none;outline:none;background:transparent;font-family:inherit;font-size:16px;color:var(--t1);width:100%}
.input input::placeholder{color:var(--t3)}
.input textarea{border:none;outline:none;background:transparent;font-family:inherit;font-size:16px;color:var(--t1);width:100%;resize:none;line-height:1.5}

/* chips */
.chips{display:flex;gap:8px;overflow-x:auto;padding:2px 18px 2px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{
  flex-shrink:0;display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;
  padding:9px 14px;border-radius:11px;border:1.5px solid var(--border);background:#fff;color:var(--t2);
  cursor:pointer;white-space:nowrap;transition:all .15s;
}
.chip.active{background:var(--t1);color:#fff;border-color:var(--t1)}
.chip .dot{width:8px;height:8px;border-radius:50%}

/* category badge */
.cat-badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;padding:6px 11px;border-radius:10px;color:#fff;white-space:nowrap}

/* avatar */
.av{border-radius:50%;background:#D7DEE9;display:flex;align-items:center;justify-content:center;font-weight:700;color:#5A6B85;flex-shrink:0;overflow:hidden}
.av-ring{border-radius:50%;padding:2.5px;flex-shrink:0;background:conic-gradient(from 210deg,#3470C8,#7CA7E6,#30A46C,#3470C8)}
.av-ring .av{border:2.5px solid #fff}

/* cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-card);box-shadow:var(--shadow-sm)}
.list-row{display:flex;align-items:center;gap:14px;padding:15px 18px;cursor:pointer}
.list-row:active{background:var(--surface)}
.divider{height:1px;background:var(--border)}

/* tab bar */
.tabbar{
  position:relative;z-index:40;display:flex;align-items:flex-end;justify-content:space-around;
  background:rgba(255,255,255,0.92);backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--border);
  padding:10px 12px 30px;
}
.tabitem{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;flex:1;padding:6px 0;color:var(--t3);font-family:inherit}
.tabitem.active{color:var(--blue)}
.tabitem .lbl{font-size:10.5px;font-weight:600}
.tab-center{position:relative;flex:1;display:flex;justify-content:center}
.tab-fab{
  width:62px;height:62px;border-radius:21px;background:linear-gradient(150deg,#3D7BD4,#2A5BA3);
  display:flex;align-items:center;justify-content:center;margin-top:-30px;
  box-shadow:0 8px 20px rgba(52,112,200,.42), 0 0 0 5px #fff;cursor:pointer;
  transition:transform .12s;
}
.tab-fab:active{transform:scale(.93)}

/* fab */
.fab{
  position:absolute;z-index:35;display:inline-flex;align-items:center;gap:9px;
  background:var(--blue);color:#fff;font-weight:700;font-size:15px;padding:14px 20px;border-radius:16px;
  border:none;cursor:pointer;box-shadow:0 8px 22px rgba(52,112,200,.42);white-space:nowrap;
}
.fab:active{transform:scale(.96)}

/* media placeholder */
.media-ph{
  background:repeating-linear-gradient(135deg,#E6EBF2,#E6EBF2 12px,#EEF2F7 12px,#EEF2F7 24px);
  display:flex;align-items:center;justify-content:center;position:relative;
}
.media-ph .tag{font-size:11.5px;color:#8B97A8;background:rgba(255,255,255,.7);padding:4px 10px;border-radius:8px}

/* toast */
.toast{
  position:absolute;left:18px;right:18px;bottom:108px;z-index:60;background:var(--t1);color:#fff;
  border-radius:15px;padding:14px 18px;font-size:14.5px;font-weight:500;display:flex;align-items:center;gap:11px;
  box-shadow:var(--shadow-lg);animation:toastIn .3s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes toastIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* screen transitions — resting state is ALWAYS the visible end state; from-frames never hide content (no opacity:0, no full-width translate) so a throttled/paused animation can never blank the screen */
.fade-in{animation:fadeIn .3s ease both}
@keyframes fadeIn{from{transform:translateY(8px)}to{transform:none}}
.slide-in{animation:slideIn .32s cubic-bezier(.3,.8,.3,1) both}
@keyframes slideIn{from{transform:translateX(14px)}to{transform:none}}

/* sheet */
.sheet-backdrop{position:absolute;inset:0;z-index:50;background:rgba(20,34,58,.32);animation:fadeIn .2s ease}
.sheet{
  position:absolute;left:0;right:0;bottom:0;z-index:55;background:#fff;border-radius:26px 26px 0 0;
  box-shadow:0 -8px 40px rgba(20,34,58,.18);animation:sheetUp .32s cubic-bezier(.2,.9,.3,1);
  max-height:88%;display:flex;flex-direction:column;
}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-grab{width:38px;height:5px;border-radius:9999px;background:var(--border);margin:10px auto 4px}

/* badge dot */
.badge-num{background:var(--danger);color:#fff;font-size:10.5px;font-weight:700;border-radius:9999px;min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}

/* toggle */
.switch{width:50px;height:30px;border-radius:9999px;background:var(--border);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.switch.on{background:var(--blue)}
.switch::after{content:"";position:absolute;width:24px;height:24px;border-radius:50%;background:#fff;top:3px;left:3px;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:left .2s}
.switch.on::after{left:23px}

/* level ring progress */
.xpbar{height:10px;border-radius:9999px;background:var(--border);overflow:hidden}
.xpbar > div{height:100%;border-radius:9999px;background:linear-gradient(90deg,#3470C8,#5A93E0)}

/* skeleton */
.skel{background:linear-gradient(100deg,#EEF1F6 30%,#F6F8FB 50%,#EEF1F6 70%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:8px}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}

.empty-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 32px;gap:14px}
.empty-wrap h3{font-size:18px;font-weight:700}
.empty-wrap p{font-size:14.5px;color:var(--t2);line-height:1.5;max-width:260px}

/* dark mode — override tokens so every var()-based inline style flips automatically */
.spot-app.dark{
  --bg:#0E1626; --surface:#131D2E; --card:#172234; --border:#26344A;
  --t1:#EAF0F8; --t2:#9FB0C8; --t3:#6A7B93;
  --blue-tint:#1B2C46;
  background:#0E1626;color:#EAF0F8;
}
.dark .topbar{background:rgba(14,22,38,0.84)}
.dark .tabbar{background:rgba(14,22,38,0.92)}
.dark .av .,.dark .btn-social{color:#EAF0F8}
.dark .btn-social{background:#172234;box-shadow:inset 0 0 0 1.5px #26344A}
.dark .media-ph{background:repeating-linear-gradient(135deg,#1A2638,#1A2638 12px,#1F2D42 12px,#1F2D42 24px)}
.dark .skel{background:linear-gradient(100deg,#1A2638 30%,#22324A 50%,#1A2638 70%);background-size:200% 100%}
