/* Wave Bite – Captain's Run · styles/main.css
   Maritime Premium-UI: Navy/Gold, Glas, ruhige Mikroanimationen. */

:root {
  --navy-0: #081627;
  --navy-1: #0B1E3B;
  --navy-2: #123A63;
  --gold: #C9A24B;
  --gold-2: #E7CE8B;
  --cream: #F5F0E1;
  --danger: #C9462F;
  --good: #5BB98B;
  --glass: rgba(255, 255, 255, 0.07);
  --glass-line: rgba(201, 162, 75, 0.28);
  --txt: #EAF0F6;
  --muted: #9DB0C4;
  --shadow: 0 14px 40px rgba(0, 0, 0, 0.45);
  --r: 18px;
  --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, system-ui, sans-serif;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; height: 100%; }
body {
  font-family: var(--font);
  color: var(--txt);
  background: radial-gradient(120% 80% at 50% -10%, #15406e 0%, var(--navy-1) 45%, var(--navy-0) 100%);
  overflow: hidden;
  user-select: none;
  -webkit-user-select: none;
}

#app {
  position: relative;
  width: 100%; max-width: 480px;
  height: 100%; height: 100dvh; max-height: 980px;
  margin: 0 auto;
  display: flex; flex-direction: column;
  overflow: hidden;
  background: linear-gradient(180deg, var(--navy-1), var(--navy-0));
}
@media (min-width: 520px) {
  #app { height: 96dvh; margin-top: 2vh; border-radius: 26px; box-shadow: var(--shadow);
         border: 1px solid rgba(201,162,75,0.18); }
}

/* ---- Topbar ---- */
#topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: calc(14px + env(safe-area-inset-top)) 18px 10px;
  flex: 0 0 auto;
  z-index: 5;
}
#topbar.hidden { display: none; }
.brand { display: flex; align-items: center; gap: 9px; font-weight: 700; letter-spacing: .4px; }
.brand .mark { width: 26px; height: 26px; border-radius: 8px;
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  display: grid; place-items: center; color: var(--navy-0); font-size: 15px; box-shadow: 0 4px 12px rgba(201,162,75,.4); }
.brand small { color: var(--muted); font-weight: 500; font-size: 11px; display:block; margin-top:-2px;}
.top-stats { display: flex; gap: 8px; align-items: center; }
.chip { background: var(--glass); border: 1px solid var(--glass-line); border-radius: 999px;
  padding: 6px 12px; font-size: 13px; font-weight: 600; backdrop-filter: blur(8px); }
.chip.gold { color: var(--gold-2); }

/* ---- Screens ---- */
.screen { position: absolute; inset: 0; display: none; flex-direction: column;
  padding-top: 64px; }
.screen.active { display: flex; animation: fade .25s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.scroll { flex: 1; overflow-y: auto; padding: 6px 16px 26px; -webkit-overflow-scrolling: touch; }
.screen-head { display: flex; align-items: center; gap: 12px; padding: 8px 16px 12px; }
.screen-head h2 { margin: 0; font-size: 20px; letter-spacing: .3px; }
.icon-btn { width: 40px; height: 40px; border-radius: 12px; border: 1px solid var(--glass-line);
  background: var(--glass); color: var(--txt); font-size: 18px; cursor: pointer; flex: 0 0 auto; }
.icon-btn:active { transform: scale(.94); }

/* ---- Start screen ---- */
#screen-start { justify-content: flex-start; }
.start-scroll { position: relative; z-index: 1; flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column;
  overflow-y: auto; -webkit-overflow-scrolling: touch; padding-bottom: calc(12px + env(safe-area-inset-bottom)); }
.start-scroll .hero { flex: 1 0 auto; }
.hero { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 30px 24px 10px; position: relative; }
.hero-mark { width: 92px; height: 92px; border-radius: 26px;
  background: linear-gradient(135deg, var(--gold), var(--gold-2));
  display: grid; place-items: center; font-size: 46px; color: var(--navy-0);
  box-shadow: 0 16px 44px rgba(201,162,75,.45); margin-bottom: 22px;
  animation: float 4s ease-in-out infinite; }
@keyframes float { 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-8px);} }
.hero h1 { margin: 0; font-size: 30px; letter-spacing: .5px; line-height: 1.1; }
.hero .sub { color: var(--gold-2); font-weight: 600; letter-spacing: 3px; font-size: 12px; margin-top: 8px; text-transform: uppercase; }
.hero p { color: var(--muted); max-width: 300px; margin: 14px auto 0; font-size: 14px; line-height: 1.5; }
.menu { padding: 0 22px calc(30px + env(safe-area-inset-bottom)); display: grid; gap: 11px; }
.menu .btn-big { padding: 17px; font-size: 16px; }
.menu-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }

/* ---- Buttons ---- */
.btn { font-family: var(--font); font-weight: 600; font-size: 15px; cursor: pointer;
  border-radius: 14px; padding: 13px 16px; border: 1px solid transparent; color: var(--txt);
  transition: transform .08s ease, filter .15s ease; width: 100%; }
.btn:active { transform: scale(.97); }
.btn-gold { background: linear-gradient(135deg, var(--gold), var(--gold-2)); color: var(--navy-0);
  box-shadow: 0 8px 22px rgba(201,162,75,.35); }
.btn-line { background: var(--glass); border-color: var(--glass-line); color: var(--txt); backdrop-filter: blur(8px); }
.btn-danger { background: rgba(201,70,47,.16); border: 1px solid rgba(201,70,47,.5); color: #F2B5A8; }
.btn-mini { width: auto; padding: 8px 12px; font-size: 13px; border-radius: 10px; }
.btn.off, .btn:disabled { opacity: .45; pointer-events: none; }

/* ---- Cards ---- */
.card { background: var(--glass); border: 1px solid rgba(255,255,255,.08); border-radius: var(--r);
  padding: 15px; margin-bottom: 12px; backdrop-filter: blur(10px); box-shadow: 0 6px 18px rgba(0,0,0,.25); }
.card h3 { margin: 0 0 8px; font-size: 16px; }
.card p { margin: 0 0 10px; color: var(--muted); font-size: 13px; line-height: 1.45; }
.card.glow { border-color: var(--glass-line); box-shadow: 0 6px 26px rgba(201,162,75,.18); }

/* Mission cards */
.card.mission { display: flex; align-items: center; gap: 12px; }
.card.mission .card-icon { width: 50px; height: 50px; border-radius: 14px; flex: 0 0 auto;
  background: linear-gradient(135deg, rgba(201,162,75,.25), rgba(201,162,75,.08));
  border: 1px solid var(--glass-line); display: grid; place-items: center; font-size: 24px; }
.card.mission .card-body { flex: 1; min-width: 0; }
.card.mission h3 { margin: 0 0 3px; font-size: 15px; }
.card.mission p { margin: 0 0 7px; font-size: 12px; }
.tags { display: flex; flex-wrap: wrap; gap: 5px; }
.tags span { font-size: 11px; color: var(--gold-2); background: rgba(201,162,75,.1);
  border: 1px solid rgba(201,162,75,.2); border-radius: 8px; padding: 3px 7px; }
.card-action { flex: 0 0 auto; }
.card.locked { opacity: .6; }
.lock { font-size: 12px; color: var(--muted); }

/* Boat cards */
.card.boat.sel { border-color: var(--gold); box-shadow: 0 6px 24px rgba(201,162,75,.28); }
.boat-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.boat-head h3 { margin: 0; font-size: 15px; }
.badge { font-size: 11px; padding: 4px 9px; border-radius: 999px; font-weight: 600; }
.badge-on { background: rgba(91,185,139,.18); color: #9CE3BE; border: 1px solid rgba(91,185,139,.4); }
.stats { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 14px; margin-top: 8px; }
.stat { display: flex; align-items: center; gap: 8px; font-size: 11px; }
.stat-l { width: 64px; color: var(--muted); }
.stat-track { flex: 1; height: 6px; background: rgba(255,255,255,.08); border-radius: 99px; overflow: hidden; }
.stat-fill { display: block; height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold-2)); border-radius: 99px; }
.upgrades { margin-top: 12px; border-top: 1px solid rgba(255,255,255,.07); padding-top: 10px; display: grid; gap: 8px; }
.upg { display: flex; align-items: center; gap: 10px; }
.upg-name { width: 90px; font-size: 12px; color: var(--muted); }
.upg-dots { flex: 1; display: flex; gap: 4px; }
.dot { width: 12px; height: 6px; border-radius: 3px; background: rgba(255,255,255,.12); }
.dot.on { background: linear-gradient(90deg, var(--gold), var(--gold-2)); }

/* Progress screen */
.prog-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.big { font-size: 30px; font-weight: 800; line-height: 1; }
.rank { color: var(--gold-2); font-weight: 600; font-size: 13px; margin-top: 4px; letter-spacing: 1px; }
.coins-big { font-size: 20px; font-weight: 700; color: var(--gold-2); }
.xp-track { height: 9px; background: rgba(255,255,255,.1); border-radius: 99px; overflow: hidden; margin: 8px 0 6px; }
.xp-track.sm { height: 5px; margin: 6px 0 0; }
.xp-fill { display: block; height: 100%; background: linear-gradient(90deg, var(--gold), var(--gold-2)); border-radius: 99px; transition: width .4s ease; }
.muted { color: var(--muted); font-size: 12px; }
.center { text-align: center; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid2 div { display: flex; flex-direction: column; gap: 2px; }
.grid2 b { font-size: 18px; }
.row-between { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 8px; }
.ach-list { display: grid; gap: 10px; }
.ach { display: flex; align-items: center; gap: 11px; opacity: .7; }
.ach.on { opacity: 1; }
.ach-ic { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; font-size: 19px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); flex: 0 0 auto; }
.ach.on .ach-ic { background: rgba(201,162,75,.18); border-color: var(--glass-line); }
.ach-b { flex: 1; display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.ach-b b { font-size: 13px; }

/* Settings */
.toggle-row { padding: 4px 0; }
.toggle-row + .toggle-row { border-top: 1px solid rgba(255,255,255,.06); }
.switch { width: 50px; height: 28px; border-radius: 99px; background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.12); position: relative; cursor: pointer; padding: 0; }
.switch span { position: absolute; top: 2px; left: 2px; width: 22px; height: 22px; border-radius: 50%;
  background: #fff; transition: transform .2s ease, background .2s; }
.switch.on { background: linear-gradient(90deg, var(--gold), var(--gold-2)); border-color: transparent; }
.switch.on span { transform: translateX(22px); background: var(--navy-0); }

/* ---- Game screen ---- */
#screen-game { padding: 0; }
.game-wrap { position: absolute; inset: 0; }
#game-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }

/* Game HUD */
.hud-top { position: absolute; top: 0; left: 0; right: 0; padding: calc(12px + env(safe-area-inset-top)) 14px 12px; display: flex;
  align-items: flex-start; justify-content: space-between; gap: 10px; pointer-events: none; z-index: 3; }
.hud-pill { background: rgba(8,18,30,.5); border: 1px solid var(--glass-line); border-radius: 12px;
  padding: 8px 11px; backdrop-filter: blur(8px); pointer-events: none; }
.hud-mission { display: flex; align-items: center; gap: 8px; }
.hud-mission .mi { font-size: 20px; }
.hud-mission .mt { font-size: 13px; font-weight: 600; }
.hud-mission .ml { font-size: 11px; color: var(--muted); }
.hud-right { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.hud-row { display: flex; gap: 6px; }
.hud-mini { font-size: 12px; font-weight: 700; }
.hud-mini.gold { color: var(--gold-2); }
#btn-pause { pointer-events: auto; width: 38px; height: 38px; border-radius: 11px; border: 1px solid var(--glass-line);
  background: rgba(8,18,30,.5); color: var(--txt); font-size: 14px; backdrop-filter: blur(8px); cursor: pointer; }
.hud-bar-wrap { display: flex; flex-direction: column; gap: 3px; min-width: 120px; }
.hud-bar-label { font-size: 10px; color: var(--muted); display: flex; justify-content: space-between; }
.hud-bar { height: 7px; border-radius: 99px; background: rgba(0,0,0,.35); overflow: hidden; }
.hud-bar > span { display: block; height: 100%; width: 50%; background: linear-gradient(90deg,#C9A24B,#E7CE8B); border-radius: 99px; }

#hud-timer { display: flex; align-items: center; gap: 5px; color: #F2B5A8; }

/* Progress (distance) bar bottom-of-top */
.hud-progress { position: absolute; top: calc(70px + env(safe-area-inset-top)); left: 14px; right: 14px; z-index: 3; }
.hud-progress .lbl { font-size: 10px; color: var(--muted); margin-bottom: 3px; display:flex; align-items:center; gap:5px;}

/* Touch controls */
.controls { position: absolute; left: 0; right: 0; bottom: 0; padding: 0 20px calc(26px + env(safe-area-inset-bottom));
  display: flex; align-items: flex-end; justify-content: space-between; z-index: 3; pointer-events: none; }
.ctrl-cluster { display: flex; gap: 14px; pointer-events: auto; }
.ctrl { width: 70px; height: 70px; border-radius: 50%; border: 1px solid var(--glass-line);
  background: rgba(8,18,30,.42); color: var(--cream); font-size: 26px; backdrop-filter: blur(10px);
  display: grid; place-items: center; touch-action: none; cursor: pointer; box-shadow: 0 8px 20px rgba(0,0,0,.3); }
.ctrl:active, .ctrl.act { transform: scale(.93); background: rgba(201,162,75,.3); }
.ctrl.gas { background: rgba(91,185,139,.2); border-color: rgba(91,185,139,.5); }
.ctrl.boost { width: 80px; height: 80px; font-size: 15px; font-weight: 700; letter-spacing: .5px;
  background: linear-gradient(135deg, rgba(201,162,75,.4), rgba(201,162,75,.18)); border-color: var(--gold); color: var(--gold-2); }
.ctrl-right { display: flex; flex-direction: column; gap: 12px; align-items: center; pointer-events: auto; }

/* ---- Overlays ---- */
.overlay { position: absolute; inset: 0; background: rgba(5,12,22,.72); backdrop-filter: blur(6px);
  display: none; align-items: center; justify-content: center; overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding: max(24px, env(safe-area-inset-top)) 20px max(24px, env(safe-area-inset-bottom)); z-index: 20; }
.overlay.show { display: flex; animation: fade .2s ease; }
.panel { background: linear-gradient(180deg, rgba(18,40,70,.96), rgba(8,18,30,.96));
  border: 1px solid var(--glass-line); border-radius: 22px; padding: 24px; width: 100%; max-width: 360px;
  text-align: center; box-shadow: var(--shadow); }
.panel h2 { margin: 4px 0 12px; }
.panel .row { display: grid; gap: 10px; margin-top: 8px; }

.result-card { text-align: center; }
.result-card .result-icon { font-size: 52px; margin-bottom: 6px; }
.result-card h2 { margin: 0 0 6px; }
.result-card.win h2 { color: var(--gold-2); }
.result-card.lose h2 { color: #F2B5A8; }
.stars { font-size: 34px; letter-spacing: 6px; color: var(--gold); margin: 6px 0 12px;
  text-shadow: 0 4px 16px rgba(201,162,75,.5); }
.rewards { display: flex; justify-content: center; gap: 16px; font-size: 16px; font-weight: 700; color: var(--gold-2); margin-bottom: 8px; }
.lvlup { color: var(--good); font-weight: 700; margin: 6px 0; }
.ach-pop { margin: 8px 0; font-size: 13px; color: var(--gold-2); display: grid; gap: 4px; }
.result-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 16px; }

/* Boot loader */
#boot-loader { position: absolute; inset: 0; display: grid; place-items: center; z-index: 50;
  background: var(--navy-0); }
.spinner { width: 42px; height: 42px; border-radius: 50%; border: 3px solid rgba(201,162,75,.25);
  border-top-color: var(--gold); animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ---- WSP-Laufbahn / Rang-Insignien ---- */
.career-top { display: flex; gap: 14px; align-items: center; margin-bottom: 10px; }
.insig-wrap { flex: 0 0 auto; filter: drop-shadow(0 8px 18px rgba(201,162,75,.35)); }
.insignia { display: block; }
.career-meta { flex: 1; min-width: 0; }
.ribbon { display: inline-block; font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--gold-2); background: rgba(201,162,75,.12); border: 1px solid rgba(201,162,75,.3);
  border-radius: 999px; padding: 3px 9px; margin-bottom: 7px; }
.career-meta h3 { margin: 0; font-size: 17px; line-height: 1.15; }
.rp { font-size: 22px; font-weight: 800; color: var(--gold-2); margin-top: 7px; }
.rp span { font-size: 12px; color: var(--muted); font-weight: 600; }
.ladder-title { margin: 12px 0 8px; font-size: 11px; letter-spacing: 1.5px; color: var(--muted); text-transform: uppercase; }
.ladder { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 6px; -webkit-overflow-scrolling: touch; }
.ladder::-webkit-scrollbar { height: 4px; }
.ladder::-webkit-scrollbar-thumb { background: rgba(201,162,75,.3); border-radius: 4px; }
.ladder-item { flex: 0 0 auto; width: 54px; display: flex; flex-direction: column; align-items: center; gap: 3px; }
.ladder-item.lock { opacity: .3; filter: grayscale(.55); }
.ladder-item.cur { transform: translateY(-3px); }
.ladder-item.cur .li-name { color: var(--gold-2); }
.li-name { font-size: 11px; font-weight: 700; }
.li-rp { font-size: 9px; color: var(--muted); }

/* Beförderung im Ergebnis-Overlay */
.promo { display: flex; align-items: center; gap: 12px; justify-content: center; margin: 12px auto;
  padding: 12px 14px; max-width: 300px; border-radius: 16px; border: 1px solid var(--gold);
  background: linear-gradient(135deg, rgba(201,162,75,.22), rgba(201,162,75,.06));
  box-shadow: 0 8px 26px rgba(201,162,75,.3); animation: promoPop .55s ease; }
.promo .insignia { filter: drop-shadow(0 6px 14px rgba(201,162,75,.55)); }
.promo-txt { text-align: left; }
.promo-k { font-size: 11px; letter-spacing: 2px; color: var(--gold-2); text-transform: uppercase; }
.promo-txt b { display: block; font-size: 15px; }
.promo-txt span { font-size: 11px; color: var(--muted); }
@keyframes promoPop { 0% { transform: scale(.8); opacity: 0; } 60% { transform: scale(1.05); } 100% { transform: scale(1); opacity: 1; } }

/* ---- Cockpit-Hero auf dem Startscreen ---- */
#start-hero-bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center;
  opacity: 0; transition: opacity 1s ease; }
#start-hero-bg.on { opacity: .82; animation: heroDrift 26s ease-in-out infinite alternate; }
@keyframes heroDrift { from { transform: scale(1.08) translate(0,0); } to { transform: scale(1.16) translate(-2.2%, -2.4%); } }
#start-hero-bg::after { content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(8,18,30,.10) 0%, rgba(11,30,59,.50) 55%, rgba(8,18,30,.95) 100%); }
#screen-start .hero, #screen-start .menu { position: relative; z-index: 1; }

/* ---- Einsatz-Briefing ---- */
.briefing { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.bf-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.bf-scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,12,22,.5), rgba(5,12,22,.92)); }
.bf-panel { position: relative; z-index: 1; width: 100%; max-width: 380px; margin: 0 16px;
  background: linear-gradient(180deg, rgba(18,40,70,.93), rgba(8,18,30,.96)); border: 1px solid var(--glass-line);
  border-radius: 20px; padding: 18px; box-shadow: var(--shadow); animation: fade .25s ease; }
.bf-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.bf-funk { font-size: 11px; letter-spacing: 1.5px; color: #7CE0A3; font-weight: 700; animation: funkblink 1.4s infinite; }
@keyframes funkblink { 0%,100% { opacity: 1; } 50% { opacity: .5; } }
.bf-rank { font-size: 11px; font-weight: 700; color: var(--gold-2); background: rgba(201,162,75,.14);
  border: 1px solid rgba(201,162,75,.3); border-radius: 999px; padding: 3px 9px; }
.bf-row { display: flex; gap: 12px; align-items: stretch; }
.bf-port { width: 86px; flex: 0 0 auto; border-radius: 14px; background-size: cover; background-position: center top;
  border: 1px solid var(--glass-line); min-height: 110px; box-shadow: 0 6px 16px rgba(0,0,0,.4); }
.bf-msg { flex: 1; min-width: 0; }
.bf-title { font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.bf-brief { font-size: 13px; line-height: 1.5; color: #D6E2EF; font-style: italic; margin: 0; }
.bf-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 14px 0; }
.bf-tag { font-size: 11px; color: var(--gold-2); background: rgba(201,162,75,.1);
  border: 1px solid rgba(201,162,75,.22); border-radius: 8px; padding: 4px 8px; }
.bf-tag.warn { color: #F2B5A8; background: rgba(201,70,47,.14); border-color: rgba(201,70,47,.4); }
.bf-actions { display: grid; grid-template-columns: 1fr auto; gap: 10px; margin-top: 4px; }

/* Prominenter Einsatz-Timer (F1-Feeling) */
#hud-timer { font-size: 15px; font-weight: 800; color: #F2B5A8; border-color: rgba(201,70,47,.5); }
#hud-timer-val { font-variant-numeric: tabular-nums; }

/* ---- Cinematische Belohnungs-Sequenz ---- */
.cine-overlay { position: absolute; inset: 0; z-index: 60; display: none; background: #04080f;
  opacity: 0; transition: opacity .3s ease; }
.cine-overlay.show { display: block; opacity: 1; }
.cine-stage { position: absolute; inset: 0; overflow: hidden; }
.cine-bg { position: absolute; inset: -6%; background-size: cover; background-position: center;
  opacity: .72; transform: scale(1.06); animation: kenburns 5.2s ease-out forwards; }
.cine-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: .82; transform: none; animation: none; }

/* ---- Minispiel: Radar-Scan ---- */
.mg-overlay { position: absolute; inset: 0; z-index: 55; display: none; align-items: center; justify-content: center;
  background: rgba(5,12,22,.82); backdrop-filter: blur(6px); }
.mg-overlay.show { display: flex; animation: fade .2s ease; }
.mg-panel { width: 100%; max-width: 340px; text-align: center; padding: 18px; }
.mg-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.mg-title { font-weight: 800; letter-spacing: 1px; color: var(--gold-2); }
.mg-score { font-weight: 800; color: var(--cream); }
.mg-sub { font-size: 12px; color: var(--muted); margin-bottom: 14px; }
.radar { position: relative; width: 280px; height: 280px; margin: 0 auto; border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(91,185,139,.12), rgba(8,18,30,.6) 70%);
  border: 2px solid rgba(91,185,139,.4); overflow: hidden;
  box-shadow: 0 8px 30px rgba(0,0,0,.5), inset 0 0 30px rgba(91,185,139,.15); }
.radar-rings::before, .radar-rings::after { content: ''; position: absolute; border: 1px solid rgba(91,185,139,.25);
  border-radius: 50%; top: 50%; left: 50%; transform: translate(-50%,-50%); }
.radar-rings::before { width: 66%; height: 66%; }
.radar-rings::after { width: 33%; height: 33%; }
.radar-cross { position: absolute; inset: 0;
  background: linear-gradient(rgba(91,185,139,.2),rgba(91,185,139,.2)) 50% 0/1px 100% no-repeat,
    linear-gradient(rgba(91,185,139,.2),rgba(91,185,139,.2)) 0 50%/100% 1px no-repeat; }
.radar-sweep { position: absolute; top: 50%; left: 50%; width: 50%; height: 50%; transform-origin: 0 0;
  background: conic-gradient(from 0deg, rgba(91,185,139,.45), rgba(91,185,139,0) 40%); animation: sweep 2.4s linear infinite; }
@keyframes sweep { to { transform: rotate(360deg); } }
.rad-blip { position: absolute; width: 28px; height: 28px; border-radius: 50%; cursor: pointer; z-index: 3;
  background: radial-gradient(circle, #F4DC9A, #C9A24B); box-shadow: 0 0 14px rgba(201,162,75,.8);
  animation: blipIn .2s ease; touch-action: none; }
.rad-blip.decoy { background: radial-gradient(circle, #9AA6B3, #566270); box-shadow: 0 0 8px rgba(120,130,140,.5); }
.rad-blip.hit { background: radial-gradient(circle, #9CE3BE, #5BB98B); transform: scale(1.4); opacity: 0; transition: all .18s; }
.rad-blip.miss { background: radial-gradient(circle, #F2B5A8, #C9462F); transform: scale(.6); opacity: 0; transition: all .18s; }
.rad-blip.fade { opacity: 0; transition: opacity .2s; }
@keyframes blipIn { from { transform: scale(.2); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.mg-timer { height: 8px; border-radius: 99px; background: rgba(255,255,255,.1); margin-top: 16px; overflow: hidden; }
.mg-timer-fill { display: block; height: 100%; width: 100%; background: linear-gradient(90deg,#C9A24B,#E7CE8B); border-radius: 99px; }

/* Endless Streak-Badge */
.streak-badge { display: inline-block; font-size: 12px; font-weight: 800; letter-spacing: 1px; color: #7CE0A3;
  background: rgba(91,185,139,.14); border: 1px solid rgba(91,185,139,.4); border-radius: 999px; padding: 5px 12px; margin-bottom: 8px; }

/* ---- Rechtliches / Onboarding ---- */
.legal-panel { max-width: 380px; }
.legal-scroll { max-height: 56vh; overflow-y: auto; text-align: left; padding-right: 6px; margin-bottom: 14px; }
.legal-scroll h4 { margin: 16px 0 6px; color: var(--gold-2); font-size: 14px; }
.legal-scroll h4:first-child { margin-top: 0; }
.legal-scroll p { font-size: 12.5px; line-height: 1.5; color: #D6E2EF; margin: 0 0 8px; }
.legal-scroll b { color: #fff; }
.onb { max-width: 360px; text-align: center; }
.onb-port { width: 92px; height: 92px; border-radius: 50%; margin: 0 auto 10px; background-size: cover;
  background-position: center top; border: 2px solid var(--glass-line); box-shadow: 0 8px 20px rgba(0,0,0,.4); }
.onb .bf-funk { display: block; margin-bottom: 6px; }
.onb p { text-align: left; }

/* ---- Story-Dialog ---- */
.dlg { position: absolute; inset: 0; }
.dlg-bg { position: absolute; inset: 0; background-size: cover; background-position: center; animation: kenburns 9s ease-out forwards; }
.dlg-scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(5,12,22,.3) 0%, rgba(5,12,22,.55) 45%, rgba(5,12,22,.96) 100%); }
.dlg-port { position: absolute; left: 50%; bottom: 186px; transform: translateX(-50%); width: 148px; height: 200px;
  background-size: cover; background-position: center top; border-radius: 16px; border: 1px solid var(--glass-line);
  box-shadow: 0 12px 30px rgba(0,0,0,.55); animation: fadeUp .35s ease; }
.dlg-box { position: absolute; left: 16px; right: 16px; bottom: 24px;
  background: linear-gradient(180deg, rgba(18,40,70,.93), rgba(8,18,30,.96)); border: 1px solid var(--glass-line);
  border-radius: 18px; padding: 16px 16px 14px; box-shadow: var(--shadow); animation: fadeUp .3s ease; }
.dlg-name { font-size: 13px; font-weight: 800; letter-spacing: 1px; color: var(--gold-2); margin-bottom: 6px; }
.dlg-text { font-size: 15px; line-height: 1.5; color: #EAF0F6; min-height: 46px; }
.dlg-next { text-align: right; font-size: 12px; color: var(--muted); margin-top: 8px; animation: blinkSkip 1.4s infinite; }
.dlg-q { font-size: 14px; color: #D6E2EF; margin-bottom: 12px; font-weight: 600; }
.dlg-opts { display: grid; gap: 8px; }
.dlg-opt { text-align: left; }

/* ---- Fail-Cinematic (rot) ---- */
.cine-stage.fail .cine-grade { background: radial-gradient(120% 90% at 50% 38%, rgba(40,4,8,0) 25%, rgba(40,4,8,.78) 100%), linear-gradient(180deg, rgba(60,10,12,.5), rgba(4,8,15,.92)); }
.cine-stage.fail .cine-title { color: #F2B5A8; text-shadow: 0 6px 30px rgba(201,70,47,.6); }
.cine-stage.fail .cine-kicker { color: #F2B5A8; }
.cine-stage.fail .cine-p { background: radial-gradient(circle, #F2B5A8, #C9462F); box-shadow: 0 0 6px rgba(201,70,47,.7); }

/* ---- WOW-Intro ---- */
.intro-stage { position: absolute; inset: 0; overflow: hidden; }
.intro-vid { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .9; animation: introZoom 18s ease-out forwards; }
.intro-vid.fallback { background: radial-gradient(120% 100% at 50% 30%, #15406e, #081627); opacity: 1; }
@keyframes introZoom { from { transform: scale(1.08); } to { transform: scale(1.22); } }
.intro-grade { position: absolute; inset: 0; background: radial-gradient(120% 90% at 50% 30%, rgba(8,18,30,0) 30%, rgba(8,18,30,.85) 100%), linear-gradient(180deg, rgba(8,18,30,.5), rgba(4,8,15,.2) 40%, rgba(4,8,15,.95)); }
.intro-logo { position: absolute; top: 15%; left: 0; right: 0; text-align: center; z-index: 4; }
.il-mark { width: 78px; height: 78px; border-radius: 22px; margin: 0 auto 14px; display: grid; place-items: center; font-size: 40px; color: var(--navy-0);
  background: linear-gradient(135deg, var(--gold), var(--gold-2)); box-shadow: 0 16px 44px rgba(201,162,75,.5); animation: badgeIn .8s cubic-bezier(.2,.9,.3,1.2) .3s both; }
.il-title { font-size: 40px; font-weight: 800; letter-spacing: 6px; color: #fff; text-shadow: 0 6px 30px rgba(201,162,75,.45); animation: titleIn .9s ease .5s both; }
.il-sub { font-size: 15px; letter-spacing: 8px; color: var(--gold-2); margin-top: 6px; animation: fadeUp .8s ease 1s both; }
.intro-mentor { position: absolute; left: 16px; right: 16px; bottom: 104px; display: flex; gap: 12px; align-items: flex-end; z-index: 4; animation: fadeUp .6s ease 1.3s both; }
.im-port { width: 84px; height: 108px; flex: 0 0 auto; border-radius: 14px; background-size: cover; background-position: center top; border: 1px solid var(--glass-line); box-shadow: 0 8px 22px rgba(0,0,0,.5); }
.im-box { flex: 1; background: linear-gradient(180deg, rgba(18,40,70,.92), rgba(8,18,30,.95)); border: 1px solid var(--glass-line); border-radius: 16px; padding: 12px 14px; box-shadow: var(--shadow); }
.im-name { font-size: 11px; letter-spacing: 1px; color: #7CE0A3; font-weight: 700; margin-bottom: 6px; }
.im-text { font-size: 14px; line-height: 1.5; color: #EAF0F6; min-height: 60px; }
.intro-go { position: absolute; left: 24px; right: 24px; bottom: 46px; width: auto; z-index: 5; animation: fadeUp .6s ease 2s both; }
.intro-skip { position: absolute; bottom: 18px; left: 0; right: 0; text-align: center; font-size: 12px; color: var(--muted); z-index: 5; animation: blinkSkip 1.6s 2s infinite; }

/* ---- In-Game: Kapitän, Blaulicht, Polizei-Aktionen ---- */
.hud-captain { position: absolute; top: calc(58px + env(safe-area-inset-top)); left: 14px; z-index: 3; display: flex; align-items: center; gap: 8px;
  background: rgba(8,18,30,.5); border: 1px solid var(--glass-line); border-radius: 12px; padding: 5px 10px 5px 5px; backdrop-filter: blur(8px); pointer-events: none; }
.hc-port { width: 34px; height: 34px; border-radius: 9px; background-size: cover; background-position: center top; background-color: #1a2c3e; border: 1px solid var(--glass-line); }
.hc-meta { display: flex; flex-direction: column; line-height: 1.1; }
.hc-meta b { font-size: 12px; }
.hc-meta span { font-size: 10px; color: var(--gold-2); }
.bluelight { position: absolute; inset: 0; z-index: 2; pointer-events: none; opacity: 0; }
.bluelight.on { animation: blaulicht 1s linear infinite; }
@keyframes blaulicht { 0%,100% { box-shadow: inset 0 0 0 rgba(0,0,0,0); opacity: 0; } 25% { box-shadow: inset 0 70px 130px rgba(40,90,220,.5); opacity: 1; } 50% { opacity: 0; } 75% { box-shadow: inset 0 70px 130px rgba(220,40,40,.45); opacity: 1; } }
.actions-bar { position: absolute; left: 0; right: 0; bottom: calc(120px + env(safe-area-inset-bottom)); z-index: 3; display: flex; gap: 8px; justify-content: center; padding: 0 14px; }
.act { flex: 1; max-width: 84px; display: flex; flex-direction: column; align-items: center; gap: 2px; font-size: 18px;
  background: rgba(8,18,30,.5); border: 1px solid var(--glass-line); border-radius: 12px; padding: 8px 4px; color: var(--cream); backdrop-filter: blur(8px); cursor: pointer; }
.act small { font-size: 9px; color: var(--muted); letter-spacing: .3px; }
.act:active { transform: scale(.94); background: rgba(201,162,75,.25); }
.game-wrap.spot::after { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(60% 40% at 50% 42%, rgba(255,250,230,.22), rgba(0,0,0,0) 70%); }

/* ---- Bewertung (Zwischenfunk-Feedback) ---- */
.rate-panel { max-width: 360px; text-align: center; }
.rate-head { display: flex; align-items: center; gap: 12px; text-align: left; margin-bottom: 6px; }
.rate-head h3 { margin: 4px 0 0; font-size: 17px; }
.rate-port { width: 56px; height: 56px; flex: 0 0 auto; border-radius: 50%; background-size: cover; background-position: center top; border: 1px solid var(--glass-line); }
.rate-stars { display: flex; justify-content: center; gap: 6px; margin: 14px 0 12px; }
.rate-stars button { background: none; border: none; font-size: 34px; color: var(--gold); cursor: pointer; line-height: 1; padding: 2px; transition: transform .1s; }
.rate-stars button:active { transform: scale(1.2); }
.rate-comment { width: 100%; box-sizing: border-box; resize: none; border-radius: 12px; border: 1px solid var(--glass-line);
  background: rgba(8,18,30,.5); color: var(--txt); padding: 10px 12px; font-family: var(--font); font-size: 13px; margin-bottom: 12px; }
.rate-secondary { display: flex; justify-content: center; gap: 18px; margin-top: 12px; }
.rate-link { background: none; border: none; color: var(--muted); font-size: 12px; cursor: pointer; text-decoration: underline; }
.cine-grade { position: absolute; inset: 0;
  background: radial-gradient(120% 90% at 50% 38%, rgba(4,8,15,0) 30%, rgba(4,8,15,.7) 100%),
    linear-gradient(180deg, rgba(8,18,30,.5) 0%, rgba(4,8,15,.2) 40%, rgba(4,8,15,.85) 100%); }
.cine-bar { position: absolute; left: 0; right: 0; height: 0; background: #000; z-index: 3; animation: barsIn .6s ease forwards; }
.cine-bar.top { top: 0; } .cine-bar.bottom { bottom: 0; }
.cine-particles { position: absolute; inset: 0; pointer-events: none; z-index: 2; overflow: hidden; }
.cine-p { position: absolute; bottom: -10px; width: 5px; height: 5px; border-radius: 50%;
  background: radial-gradient(circle, #F4DC9A, #C9A24B); opacity: 0; transform: scale(var(--sc, 1));
  animation: floatUp 3s linear infinite; box-shadow: 0 0 6px rgba(201,162,75,.7); }
.cine-content { position: absolute; left: 0; right: 0; top: 50%; transform: translateY(-50%);
  z-index: 4; text-align: center; padding: 0 24px; }
.cine-kicker { font-size: 12px; letter-spacing: 2px; color: #7CE0A3; font-weight: 700; margin-bottom: 14px;
  opacity: 0; animation: fadeUp .5s ease .2s forwards; }
.cine-badge { display: flex; justify-content: center; margin-bottom: 12px; opacity: 0;
  animation: badgeIn .7s cubic-bezier(.2,.9,.3,1.2) .35s forwards; }
.cine-badge .insignia { filter: drop-shadow(0 8px 24px rgba(201,162,75,.6)); }
.cine-title { font-size: 30px; font-weight: 800; letter-spacing: 4px; color: var(--gold-2);
  text-shadow: 0 6px 30px rgba(201,162,75,.5); opacity: 0; animation: titleIn .7s ease .45s forwards; }
.cine-stars { font-size: 38px; letter-spacing: 8px; color: var(--gold); margin-top: 12px;
  text-shadow: 0 4px 18px rgba(201,162,75,.6); opacity: 0; animation: fadeUp .6s ease .8s forwards; }
.cine-sub { font-size: 16px; font-weight: 700; color: var(--cream); margin-top: 12px;
  opacity: 0; animation: fadeUp .6s ease 1s forwards; }
.cine-skip { position: absolute; bottom: 26px; left: 0; right: 0; text-align: center; z-index: 4;
  font-size: 12px; color: var(--muted); opacity: 0; animation: blinkSkip 1.6s ease 1.6s infinite; }
@keyframes kenburns { from { transform: scale(1.06) translate(0,0); } to { transform: scale(1.2) translate(-2%, -3%); } }
@keyframes barsIn { from { height: 0; } to { height: 11%; } }
@keyframes floatUp { 0% { opacity: 0; bottom: -10px; } 15% { opacity: .9; } 100% { opacity: 0; bottom: 105%; } }
@keyframes fadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
@keyframes titleIn { from { opacity: 0; transform: translateY(16px); letter-spacing: 12px; } to { opacity: 1; transform: none; letter-spacing: 4px; } }
@keyframes badgeIn { from { opacity: 0; transform: scale(.5) rotate(-8deg); } to { opacity: 1; transform: scale(1) rotate(0); } }
@keyframes blinkSkip { 0%,100% { opacity: .35; } 50% { opacity: .8; } }

/* --- Mini-Games: Schleusen-Timing & Hafen-Suche --- */
.mg-btn{display:block;width:100%;margin-top:14px;padding:13px;border-radius:12px;border:1px solid rgba(201,162,75,.55);background:linear-gradient(180deg,#C9A24B,#A9842F);color:#10243f;font-weight:800;font-size:15px;letter-spacing:.04em;cursor:pointer}
.mg-btn:active{transform:translateY(1px)}
.lock-track{position:relative;height:24px;margin-top:16px;border-radius:12px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid rgba(255,255,255,.14)}
.lock-zone{position:absolute;top:0;bottom:0;left:40%;width:24%;background:linear-gradient(180deg,rgba(91,185,139,.9),rgba(54,128,94,.9));box-shadow:0 0 14px rgba(91,185,139,.6)}
.lock-marker{position:absolute;top:-3px;left:0;width:4px;height:30px;background:#F5F0E1;border-radius:2px;box-shadow:0 0 8px rgba(255,255,255,.85)}
.lock-flash{text-align:center;margin-top:8px;font-weight:800;min-height:20px;letter-spacing:.05em}
.search-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:16px}
.search-cell{aspect-ratio:1/1;border-radius:13px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:26px;color:rgba(245,240,225,.45);cursor:pointer;transition:transform .1s ease,background .2s}
.search-cell:active{transform:scale(.93)}
.search-cell.found{background:rgba(91,185,139,.26);border-color:rgba(91,185,139,.75);color:#fff}
.search-cell.empty{background:rgba(201,70,47,.14);opacity:.55}

/* --- AAA Boot-Loader (verhindert Schwarzbild, zeigt echten Ladefortschritt) --- */
#boot-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:radial-gradient(120% 90% at 50% 18%,#10294a 0%,#0B1E3B 55%,#081627 100%);transition:opacity .42s ease}
#boot-loader.done{opacity:0;pointer-events:none}
#boot-loader .bl-brand{display:flex;align-items:center;gap:12px;margin-bottom:4px}
#boot-loader .bl-anchor{font-size:30px;filter:drop-shadow(0 4px 10px rgba(201,162,75,.5))}
#boot-loader .bl-word{font-weight:800;letter-spacing:.14em;font-size:22px;color:#F5F0E1;line-height:1;display:flex;flex-direction:column}
#boot-loader .bl-word small{font-weight:600;letter-spacing:.42em;font-size:10px;color:var(--gold-2);margin-top:5px}
#boot-loader .bl-track{width:min(230px,58vw);height:6px;border-radius:99px;background:rgba(255,255,255,.1);overflow:hidden;margin-top:2px}
#boot-loader .bl-fill{display:block;height:100%;width:0;border-radius:99px;background:linear-gradient(90deg,#C9A24B,#E7CE8B);transition:width .25s ease;box-shadow:0 0 12px rgba(201,162,75,.6)}
#boot-loader .bl-pct{font-size:12px;font-weight:700;color:var(--gold-2);letter-spacing:.08em}
#boot-loader .bl-hint{font-size:11px;color:rgba(245,240,225,.55);letter-spacing:.05em}

/* ===== MARVEL-ACTION-INTRO (Boot als Held) ===== */
.intro-stage.mv{position:absolute;inset:0;overflow:hidden;background:#04080f}
.mv-boat{position:absolute;inset:-8%;background-size:cover;background-position:center 42%;transform:scale(1.18);animation:mvKen 13s ease-out forwards;will-change:transform;z-index:0}
.mv-boat.fallback{background:radial-gradient(120% 100% at 50% 35%,#15406e,#081627)}
@keyframes mvKen{to{transform:scale(1.0)}}
.mv-rays{position:absolute;inset:-30%;z-index:1;mix-blend-mode:screen;opacity:.6;pointer-events:none;
  background:repeating-conic-gradient(from 92deg at 50% 14%,rgba(150,200,255,.07) 0deg,rgba(150,200,255,0) 5deg,rgba(150,200,255,0) 13deg);
  animation:mvRays 18s linear infinite}
@keyframes mvRays{0%{transform:rotate(-4deg)}50%{opacity:.85}100%{transform:rotate(4deg)}}
.mv-fog{position:absolute;inset:-22%;z-index:1;filter:blur(10px);mix-blend-mode:screen;pointer-events:none;
  background:radial-gradient(closest-side,rgba(185,210,235,.12),rgba(185,210,235,0) 70%)}
.mv-fog.f1{opacity:.5;animation:mvFog1 26s linear infinite}
.mv-fog.f2{opacity:.34;animation:mvFog2 34s linear infinite}
@keyframes mvFog1{0%{transform:translate(-16%,0)}100%{transform:translate(16%,-5%)}}
@keyframes mvFog2{0%{transform:translate(18%,2%)}100%{transform:translate(-18%,-3%)}}
.mv-grade{position:absolute;inset:0;z-index:2;pointer-events:none;background:
  radial-gradient(120% 90% at 50% 28%,rgba(8,18,30,0) 20%,rgba(6,14,26,.82) 100%),
  linear-gradient(180deg,rgba(6,14,26,.5),rgba(4,8,15,.12) 36%,rgba(3,7,14,.96))}
.mv-beacon{position:absolute;left:50%;top:30%;width:46%;height:20%;transform:translate(-50%,-50%);z-index:2;
  background:radial-gradient(closest-side,rgba(70,150,255,.6),rgba(70,150,255,0) 70%);
  mix-blend-mode:screen;filter:blur(3px);animation:mvBeacon 1.5s ease-in-out infinite}
@keyframes mvBeacon{0%,100%{opacity:.22;transform:translate(-50%,-50%) scale(.9)}50%{opacity:.95;transform:translate(-50%,-50%) scale(1.12)}}
.mv-bluewash{position:absolute;inset:0;z-index:2;mix-blend-mode:screen;pointer-events:none;opacity:0;
  background:radial-gradient(120% 80% at 50% 24%,rgba(60,140,255,.4),rgba(60,140,255,0) 60%);animation:mvWash 3.1s linear infinite}
@keyframes mvWash{0%,9%,18%,100%{opacity:0}3%{opacity:.65}13%{opacity:.4}}
.mv-water{position:absolute;left:0;right:0;bottom:0;height:36%;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,20,38,0),rgba(6,16,32,.55))}
.mv-scan{position:absolute;left:0;right:0;height:2px;top:0;z-index:3;pointer-events:none;opacity:.45;
  background:linear-gradient(90deg,transparent,rgba(150,200,255,.55),transparent);animation:mvScan 6s linear infinite}
@keyframes mvScan{0%{top:-2%}100%{top:102%}}
.mv-titles{position:absolute;left:0;right:0;top:14%;text-align:center;z-index:6;padding:0 16px}
.mv-kicker{font-size:11px;letter-spacing:.5em;color:var(--gold-2);text-transform:uppercase;opacity:0;transform:translateY(8px);transition:opacity .6s ease,transform .6s ease}
.mv-kicker.in{opacity:.9;transform:none}
.mv-title{font-size:clamp(34px,11vw,52px);font-weight:800;letter-spacing:.05em;line-height:1;margin-top:10px;opacity:0;transform:scale(1.6);filter:blur(12px);transition:opacity .5s ease,transform .65s cubic-bezier(.16,.8,.3,1),filter .6s ease;text-shadow:0 10px 46px rgba(60,120,220,.45)}
.mv-title.in{opacity:1;transform:scale(1);filter:blur(0)}
.mv-shine{background:linear-gradient(90deg,#E7CE8B 0%,#FBF1D2 28%,#C9A24B 58%,#E7CE8B 100%);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:220% 100%;background-position:120% 0}
.mv-shine.go{animation:mvShine 1.15s ease forwards}
@keyframes mvShine{to{background-position:-20% 0}}
.mv-rule{width:0;height:3px;margin:12px auto 0;border-radius:2px;background:linear-gradient(90deg,rgba(201,162,75,0),#E7CE8B,rgba(201,162,75,0));transition:width .85s ease}
.mv-rule.in{width:min(220px,60vw)}
.mv-sub{margin-top:10px;font-size:14px;font-weight:700;letter-spacing:.42em;color:var(--gold-2);opacity:0;transform:translateY(8px);transition:opacity .6s ease,transform .6s ease}
.mv-sub.in{opacity:1;transform:none}
.mv-tag{margin-top:14px;font-size:11px;letter-spacing:.3em;color:rgba(245,240,225,.72);opacity:0;transition:opacity .9s ease}
.mv-tag.in{opacity:1}
.mv-disp{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.mv-disp.in{opacity:1;transform:none}
.intro-stage.mv .intro-go{animation:none;opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}
.intro-stage.mv .intro-go.in{opacity:1;transform:none}

/* ===== LIVING WORLD · Status-Strip + Lena-Nachrichten ===== */
.world-strip{position:relative;z-index:1;margin:0 0 12px}
.ws-strip{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;cursor:pointer;
  background:rgba(8,20,38,.5);border:1px solid rgba(201,162,75,.2);border-radius:14px;padding:8px 10px;backdrop-filter:blur(6px)}
.ws-chip{font-size:11px;font-weight:600;color:#cfe0f2;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:99px;padding:4px 9px;white-space:nowrap}
.ws-chip.gold{color:#10243f;background:linear-gradient(180deg,#E7CE8B,#C9A24B);border-color:#E7CE8B}
.ws-more{font-size:11px;font-weight:700;color:var(--gold-2);letter-spacing:.04em;margin-left:auto}
#overlay-news .nw-panel{max-width:520px;width:92%;max-height:86vh;overflow:auto;text-align:left}
.nw-top{display:flex;gap:12px;align-items:center;margin-bottom:6px}
.nw-port{width:54px;height:54px;border-radius:14px;background-size:cover;background-position:center;border:2px solid rgba(201,162,75,.5);flex:0 0 auto}
.nw-name{color:#7CE0A3;font-weight:800;letter-spacing:.06em;font-size:13px}
.nw-greet{color:var(--cream);font-weight:700;font-size:17px;margin-top:2px}
.nw-sec{margin-top:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:11px 12px}
.nw-h{font-weight:800;color:var(--gold-2);font-size:13px;letter-spacing:.03em;margin-bottom:7px}
.nw-text{font-size:13px;color:#d7e2f0;line-height:1.5}
.nw-chips{display:flex;flex-wrap:wrap;gap:6px}
.nw-list{margin:0;padding-left:18px;font-size:13px;color:#d7e2f0;line-height:1.6}
.nw-list li{margin:2px 0}
.nw-note{margin-top:8px;font-size:11px;color:rgba(245,240,225,.55);font-style:italic}
.nw-bar{height:8px;border-radius:99px;background:rgba(255,255,255,.1);overflow:hidden;margin-bottom:8px}
.nw-bar-fill{display:block;height:100%;background:linear-gradient(90deg,#C9462F,#E7CE8B);border-radius:99px}
.nw-op{font-size:13px;color:#d7e2f0}
#overlay-news #nw-go{margin-top:16px;width:100%}
/* News-Overlay: klarer Hintergrund */
#overlay-news{background:rgba(3,8,16,.72);backdrop-filter:blur(5px)}
#overlay-news .nw-panel{background:linear-gradient(180deg,#0d2138,#091627);border:1px solid rgba(201,162,75,.25);box-shadow:0 30px 80px rgba(0,0,0,.6)}

/* ===== LUCY · Bord-KI HUD (lebendig) ===== */
.lucy-hud{position:absolute;left:12px;bottom:14px;z-index:3;display:flex;align-items:flex-end;gap:10px;max-width:74%;cursor:pointer}
.lucy-av{position:relative;width:54px;height:54px;border-radius:14px;background-size:cover;background-position:center;flex:0 0 auto;
  border:1.5px solid rgba(124,224,163,.55);box-shadow:0 0 16px rgba(124,224,163,.35);overflow:hidden}
.lucy-av .lucy-scan{position:absolute;left:0;right:0;height:30%;background:linear-gradient(180deg,rgba(124,224,163,.35),transparent);animation:lucyScan 2.4s linear infinite}
.lucy-av .lucy-ring{position:absolute;inset:0;border-radius:14px;box-shadow:inset 0 0 12px rgba(124,224,163,.4);animation:lucyPulse 2.8s ease-in-out infinite}
@keyframes lucyScan{0%{top:-30%}100%{top:100%}}
@keyframes lucyPulse{0%,100%{opacity:.45}50%{opacity:.9}}
.lucy-bubble{background:rgba(8,20,38,.66);border:1px solid rgba(124,224,163,.28);border-radius:12px;padding:8px 11px;backdrop-filter:blur(6px)}
.lucy-name{font-size:10px;font-weight:800;letter-spacing:.08em;color:#7CE0A3;margin-bottom:3px}
.lucy-text{font-size:12px;color:#dbe7f2;line-height:1.35;min-height:16px}

/* Lucy In-Game Live-Ansage */
.lucy-callout{position:absolute;left:50%;top:150px;transform:translate(-50%,-8px);z-index:5;max-width:78%;
  background:rgba(8,20,38,.78);border:1px solid rgba(124,224,163,.45);border-radius:12px;padding:8px 14px;
  color:#dbe7f2;font-size:13px;font-weight:600;text-align:center;opacity:0;pointer-events:none;
  box-shadow:0 8px 24px rgba(0,0,0,.4);transition:opacity .25s ease,transform .25s ease;backdrop-filter:blur(6px)}
.lucy-callout::before{content:'● LENA-KI · LUCY  ';color:#7CE0A3;font-weight:800;font-size:10px;letter-spacing:.05em}
.lucy-callout.show{opacity:1;transform:translate(-50%,0)}

/* Karten-DNA-Leiste (Kanal · Revier · Koordinaten) */
.hud-chart{position:absolute;top:92px;left:0;right:0;display:flex;gap:7px;justify-content:center;flex-wrap:wrap;z-index:3;pointer-events:none}
.hud-chart span{font-size:10px;font-weight:700;letter-spacing:.04em;color:#9cc8ff;background:rgba(6,16,30,.6);border:1px solid rgba(124,180,255,.28);border-radius:99px;padding:3px 9px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
/* Lucy-HUD an den oberen Hero-Bereich (nicht über Menübuttons) */
#screen-start .lucy-hud{bottom:auto;top:62px;left:10px;max-width:60%}
#screen-start .lucy-hud .lucy-av{width:44px;height:44px}

/* Living-World Briefing: Location-Banner */
.nw-banner{height:120px;border-radius:12px;background-size:cover;background-position:center;margin-bottom:12px;animation:kenburns 14s ease-out forwards;
  box-shadow:inset 0 -40px 60px -20px rgba(9,22,39,.9);border:1px solid rgba(201,162,75,.2)}
/* Weiche Screen-Übergänge (Polish) */
.screen.active{animation:screenFade .32s ease both}
@keyframes screenFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ============ CGI ILLUSION PASS (Final) ============ */
/* Tiefe & Atmosphäre auf Cinematics: drift-Nebel (Parallax), God-Rays, Vignette, Film-Grain, Focus-Pull */
.cine-bg { animation: kenburns 5.2s ease-out forwards, cineFocus 1.1s ease-out forwards; }
@keyframes cineFocus { from { filter: blur(7px) saturate(.7); } to { filter: blur(0) saturate(1.05); } }
.cine-haze { position:absolute; inset:-12%; z-index:1; pointer-events:none;
  background: radial-gradient(60% 50% at 30% 35%, rgba(150,190,230,.10), transparent 60%),
              radial-gradient(70% 60% at 75% 70%, rgba(255,210,140,.08), transparent 65%);
  mix-blend-mode: screen; opacity:.0; animation: hazeIn 1.4s ease forwards, hazeDrift 22s ease-in-out infinite alternate; }
@keyframes hazeIn { to { opacity:.9; } }
@keyframes hazeDrift { from { transform: translate(0,0) scale(1.05);} to { transform: translate(-3%,-2%) scale(1.14);} }
.cine-godray { position:absolute; inset:0; z-index:1; pointer-events:none; mix-blend-mode:screen; opacity:.5;
  background: conic-gradient(from 210deg at 78% 18%, rgba(255,225,150,.16), transparent 16%, transparent 84%, rgba(255,225,150,.12));
  animation: rayBreath 9s ease-in-out infinite alternate; }
@keyframes rayBreath { from { opacity:.28; } to { opacity:.6; } }
.cine-vignette { position:absolute; inset:0; z-index:3; pointer-events:none;
  background: radial-gradient(120% 90% at 50% 42%, transparent 52%, rgba(4,10,18,.55) 100%);
  box-shadow: inset 0 0 140px 30px rgba(4,10,18,.45); }
.cine-grain { position:absolute; inset:0; z-index:4; pointer-events:none; opacity:.06; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px; animation: grainShift .5s steps(3) infinite; }
@keyframes grainShift { 0%{background-position:0 0;} 33%{background-position:-90px 40px;} 66%{background-position:60px -70px;} 100%{background-position:0 0;} }
/* Dialog-Hintergründe bekommen ebenfalls Vignette-Tiefe */
.dlg-bg::after { content:''; position:absolute; inset:0; background: radial-gradient(120% 100% at 50% 40%, transparent 55%, rgba(4,10,18,.5) 100%); }
/* Gameplay-Frame: filmische Vignette + dezenter Tiefen-Falloff (kein Canvas-Eingriff) */
#screen-game::after { content:''; position:absolute; inset:0; z-index:6; pointer-events:none;
  background: radial-gradient(130% 100% at 50% 38%, transparent 58%, rgba(5,12,22,.40) 100%); }
/* Lucy Bord-KI: sichtbare Reaktion beim Sprechen + dezenter Idle-Puls */
.lucy-av .lucy-ring { animation: lucyIdle 3.4s ease-in-out infinite; }
@keyframes lucyIdle { 0%,100%{ box-shadow:0 0 0 0 rgba(124,224,163,.0);} 50%{ box-shadow:0 0 10px 2px rgba(124,224,163,.25);} }
.lucy-av.speaking { animation: lucySpeak .5s ease; }
.lucy-av.speaking .lucy-scan { animation: lucyScan .5s ease 2; }
@keyframes lucySpeak { 0%{ transform:scale(1);} 35%{ transform:scale(1.07); filter:brightness(1.18);} 100%{ transform:scale(1);} }
@keyframes lucyScan { from{ opacity:.0; transform:translateY(-60%);} 50%{opacity:.8;} to{ opacity:0; transform:translateY(60%);} }

/* ===== GAMEPLAY REBOOT: kompaktes In-Game-HUD (mehr Spielflaeche, mobil-first) ===== */
#screen-game .hud-captain{transform:scale(.82);transform-origin:top left;opacity:.9}
#screen-game .hud-mission{padding:5px 9px}
#screen-game .hud-mission .ml{display:none}
#screen-game .hud-mission .mt{font-size:12px}
#screen-game .hud-right .hud-bar-wrap{padding:3px 8px}
#screen-game .hud-bar{width:54px}
#screen-game .hud-bar-label{font-size:9px}
#screen-game #lucy-callout{max-width:62%;font-size:12px;padding:7px 11px}
#screen-game .actions-bar{bottom:108px;gap:6px}
#screen-game .actions-bar .act{padding:7px 9px;font-size:17px}
#screen-game .actions-bar .act small{font-size:8.5px}
@media (max-width:560px){
  #screen-game .hud-right .hud-bar-wrap{padding:2px 6px}
  #screen-game .hud-bar{width:42px}
  #screen-game .actions-bar{bottom:104px}
  #screen-game .actions-bar .act small{display:none}
  #screen-game .hud-captain{display:none}      /* auf sehr schmal: Kapitaenschild aus, Funk reicht */
}

/* v45: Fahrwasser-Status im HUD */
.hud-fw{ margin-top:4px; font:700 11px/1.2 system-ui,sans-serif; color:#6fe0a3; letter-spacing:.2px; opacity:.92; text-shadow:0 1px 2px rgba(0,0,0,.5); }
@media (max-width:560px){ .hud-fw{ font-size:10px; } #hud-mission-obj{ display:none; } }

/* ===== v48 Modernisierte Einsatz-Minispiele (Teal/Gold) ===== */
.mg2{max-width:360px}
.mg-feedback{min-height:18px;margin-top:10px;font:700 12.5px/1.3 system-ui,sans-serif;opacity:0;transition:opacity .2s;letter-spacing:.2px}
.mg-feedback.show{opacity:1}
.mg-feedback.good{color:#6fe0a3}
.mg-feedback.bad{color:#ff7a66}
.mg-btn.ghost{background:linear-gradient(180deg,#16364f,#0e2438);color:#cfe6ff;border-color:rgba(120,200,235,.4)}
.mg-btn.alarm{background:linear-gradient(180deg,#C9462F,#8f2f1e);color:#fff;border-color:rgba(255,120,90,.5)}
/* Radar/Sonar */
.radar2{position:relative;width:280px;height:280px;margin:6px auto;border-radius:50%;background:radial-gradient(circle at 50% 50%,rgba(20,60,80,.85),rgba(8,22,38,.95));border:2px solid rgba(91,185,139,.4);box-shadow:inset 0 0 40px rgba(91,185,139,.18)}
.rd-sweep{position:absolute;top:50%;left:50%;width:50%;height:50%;transform-origin:0 0;background:conic-gradient(from 0deg,rgba(111,224,163,.35),rgba(111,224,163,0) 38%);border-radius:0 100% 0 0}
.rd-read{position:absolute;left:50%;top:8px;transform:translateX(-50%);font:700 11px ui-monospace,monospace;color:#9CE3BE;letter-spacing:1px}
.rd-blip{position:absolute;width:26px;height:26px;border-radius:50%;cursor:pointer;z-index:3;background:radial-gradient(circle,#F4D98A,#C9A24B);box-shadow:0 0 12px rgba(231,206,139,.8);animation:rdpulse 1s infinite}
.rd-blip.decoy{background:radial-gradient(circle,#9AA6B3,#566270);box-shadow:0 0 8px rgba(120,130,140,.5);animation:none}
.rd-blip.hit{background:radial-gradient(circle,#9CE3BE,#5BB98B);transform:scale(1.4);opacity:0;transition:all .17s}
.rd-blip.miss{background:radial-gradient(circle,#F2B5A8,#C9462F);transform:scale(.6);opacity:0;transition:all .17s}
.rd-blip.fade{opacity:0;transition:opacity .2s}
@keyframes rdpulse{0%,100%{box-shadow:0 0 8px rgba(231,206,139,.6)}50%{box-shadow:0 0 16px rgba(231,206,139,1)}}
/* Funk */
.funk-call{background:rgba(10,26,42,.7);border:1px solid rgba(120,200,235,.3);border-radius:12px;padding:12px;margin-bottom:6px}
.funk-rz{font:700 12px ui-monospace,monospace;color:#9CE3BE;letter-spacing:.5px;margin-bottom:4px}
.funk-say{color:#F5F0E1;font-size:14px}
.funk-opt{font-size:13.5px;text-align:left}
/* Schleuse */
.schl{padding-top:6px}
.schl-lights{display:flex;gap:10px;justify-content:center;margin-bottom:12px}
.sl{width:26px;height:26px;border-radius:50%;background:#22323f;border:1px solid rgba(255,255,255,.15);opacity:.4}
.sl.r.on{background:radial-gradient(circle,#ff6a52,#C9462F);opacity:1;box-shadow:0 0 12px #C9462F}
.sl.y.on{background:radial-gradient(circle,#ffd56a,#D8A24B);opacity:1;box-shadow:0 0 12px #D8A24B}
.sl.g.on{background:radial-gradient(circle,#9CE3BE,#5BB98B);opacity:1;box-shadow:0 0 12px #5BB98B}
.schl-meter{position:relative;height:26px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;margin:8px 0}
.schl-green{position:absolute;left:34%;width:32%;top:0;bottom:0;background:rgba(91,185,139,.35);border-left:2px solid #5BB98B;border-right:2px solid #5BB98B}
.schl-needle{position:absolute;top:-3px;width:6px;height:32px;border-radius:3px;background:#E7CE8B;left:50%;transition:left .05s linear}
.schl-needle.ok{background:#6fe0a3}.schl-needle.bad{background:#ff7a66}
.schl-lbl{font:700 12px ui-monospace,monospace;color:#cfe6ff;margin:6px 0}
/* Hafenkontrolle */
.hk-card{background:rgba(10,26,42,.7);border:1px solid rgba(201,162,75,.35);border-radius:12px;padding:12px;margin-bottom:6px;text-align:left}
.hk-name{font-weight:800;color:#E7CE8B;margin-bottom:6px}
.hk-clues{list-style:none;padding:0;margin:0;color:#dfe8f2;font-size:13px}
.hk-clues li{padding:2px 0}
/* Rettung */
.ret{padding-top:4px}
.ret-radar{position:relative;width:220px;height:220px;margin:4px auto;border-radius:50%;background:radial-gradient(circle,rgba(20,60,80,.8),rgba(8,22,38,.95));border:2px solid rgba(91,185,139,.4)}
.ret-arrow{position:absolute;left:50%;top:50%;transform-origin:50% 50%;transform:translate(-50%,-50%);font-size:46px;color:#9AA6B3;transition:color .2s}
.ret-read{position:absolute;left:50%;bottom:10px;transform:translateX(-50%);font:700 11px ui-monospace,monospace;color:#9CE3BE}
.ret-actions{display:flex;gap:10px}.ret-actions .mg-btn{flex:1}
.ret-bar{position:relative;height:30px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;margin:14px 0 6px}
.ret-zone{position:absolute;left:70%;width:18%;top:0;bottom:0;background:rgba(91,185,139,.35);border-left:2px solid #5BB98B;border-right:2px solid #5BB98B}
.ret-mark{position:absolute;top:-2px;width:8px;height:34px;border-radius:4px;background:#E7CE8B;left:0}
.ret-mark.ok{background:#6fe0a3}
.ret-lbl{font:700 12px ui-monospace,monospace;color:#cfe6ff;margin:4px 0}
@media (max-width:560px){.mg2{max-width:94vw}.radar2{width:74vw;height:74vw;max-width:280px;max-height:280px}.ret-radar{width:62vw;height:62vw;max-width:220px;max-height:220px}}

/* ===== v51 RC2.0 Retention: Niederlage-Motivation ===== */
.lose-motiv{margin:10px 0 4px}
.lose-prog{height:8px;border-radius:99px;background:rgba(255,255,255,.12);overflow:hidden;margin:0 auto 10px;max-width:240px}
.lose-prog span{display:block;height:100%;background:linear-gradient(90deg,#5BB98B,#9CE3BE);border-radius:99px}
.comeback{margin-top:8px;font:700 13px system-ui,sans-serif;color:#E7CE8B;background:rgba(201,162,75,.12);border:1px solid rgba(201,162,75,.35);border-radius:10px;padding:8px 10px}

/* RC2.0 Menue-Hero-Video (unter dem Inhalt, ueber dem Standbild) */
.start-hero-vid{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s ease;pointer-events:none}
.start-hero-vid.on{opacity:.5}

/* ===== RC3.0 Wasserlage-Cockpit-Instrument (Teal/Gold Bord-Display) ===== */
.wl-cockpit{ position:relative; z-index:2; max-width:420px; margin:10px auto 4px; padding:12px 14px;
  border-radius:16px; border:1px solid rgba(201,162,75,.34);
  background:linear-gradient(180deg,rgba(12,30,52,.82),rgba(8,20,36,.9)); backdrop-filter:blur(6px);
  box-shadow:inset 0 0 24px rgba(91,185,160,.10), 0 6px 20px rgba(0,0,0,.35); }
.wl-head{ display:flex; align-items:center; justify-content:space-between; }
.wl-title{ font:800 12px/1 ui-monospace,monospace; letter-spacing:1px; color:#9CE3BE; }
.wl-dot{ width:12px; height:12px; border-radius:50%; box-shadow:0 0 8px currentColor; }
.wl-dot.green{ background:#5BB98B; color:#5BB98B; } .wl-dot.amber{ background:#D8A24B; color:#D8A24B; } .wl-dot.red{ background:#C9462F; color:#C9462F; animation:wlPulse 1.2s infinite; }
@keyframes wlPulse{50%{opacity:.4}}
.wl-amp{ margin:8px 0 6px; font:800 13px/1.2 system-ui,sans-serif; letter-spacing:.5px; }
.wl-amp.green{ color:#6fe0a3; } .wl-amp.amber{ color:#E7CE8B; } .wl-amp.red{ color:#ff7a66; }
.wl-rows{ display:flex; flex-direction:column; gap:3px; margin-bottom:6px; }
.wl-row{ display:flex; justify-content:space-between; font-size:12.5px; color:#cfe0f0; }
.wl-row span{ color:#9DB0C4; } .wl-row b{ color:#F5F0E1; }
.wl-hint{ font-size:11.5px; color:#9DB0C4; margin-bottom:9px; }
.wl-btn{ display:block; width:100%; padding:9px; border-radius:11px; border:1px solid rgba(201,162,75,.5);
  background:linear-gradient(180deg,#C9A24B,#A9842F); color:#10243f; font-weight:800; font-size:13px; cursor:pointer; }
.wl-btn:active{ transform:translateY(1px); }
@media (max-width:560px){ .wl-cockpit{ max-width:94vw; padding:10px 12px; } }

/* RC3.0 Rueckkehr-Chip Wasserlage->Game */
.wl-back{display:block;text-align:center;margin:0 auto 8px;max-width:420px;padding:7px 10px;border-radius:10px;text-decoration:none;
  font:700 12px system-ui,sans-serif;color:#9CE3BE;border:1px solid rgba(91,185,160,.4);background:rgba(12,30,52,.7)}

/* ===== RC3.0 Revier-Radar (holografisches Nav-Instrument) ===== */
.navmap{ position:absolute; top:64px; right:8px; z-index:30; width:188px; padding:8px;
  border-radius:14px; border:1px solid rgba(91,185,160,.34);
  background:linear-gradient(180deg,rgba(10,28,48,.78),rgba(8,20,36,.86)); backdrop-filter:blur(5px);
  box-shadow:inset 0 0 22px rgba(91,185,160,.12), 0 6px 18px rgba(0,0,0,.4); }
.nav-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:5px; }
.nav-ttl{ font:800 9.5px/1 ui-monospace,monospace; letter-spacing:1px; color:#9CE3BE; }
.nav-tog{ width:20px; height:20px; border-radius:6px; border:1px solid rgba(201,162,75,.4); background:rgba(255,255,255,.06); color:#E7CE8B; font-size:10px; cursor:pointer; padding:0; }
#navmap-cv{ display:block; width:100%; height:auto; border-radius:8px; }
.nav-info{ display:flex; flex-wrap:wrap; gap:4px 8px; align-items:center; margin-top:6px; font:600 10.5px/1.2 ui-monospace,monospace; color:#cfe0f0; }
.nav-info b{ color:#E7CE8B; width:100%; font-size:11px; }
.nav-info span{ color:#9DB0C4; }
.nav-amp{ margin-left:auto; padding:1px 6px; border-radius:6px; font-weight:800; font-size:9.5px; }
.nav-amp.green{ color:#0c1f12; background:#5BB98B; } .nav-amp.amber{ color:#241a06; background:#D8A24B; } .nav-amp.red{ color:#2a0d08; background:#ff7a66; }
.nav-wl{ display:block; width:100%; margin-top:7px; padding:7px; border-radius:9px; border:1px solid rgba(201,162,75,.5);
  background:linear-gradient(180deg,#C9A24B,#A9842F); color:#10243f; font-weight:800; font-size:11px; cursor:pointer; }
.navmap.collapsed #navmap-cv, .navmap.collapsed .nav-info, .navmap.collapsed .nav-wl{ display:none; }
.navmap.collapsed{ width:auto; padding:5px 8px; background:rgba(10,28,48,.6); }
.navmap.collapsed .nav-head{ margin:0; }
.navmap.collapsed .nav-ttl::after{ content:' ▸'; color:#E7CE8B; }
@media (max-width:560px){ .navmap{ top:58px; right:6px; width:128px; padding:6px; } .navmap.collapsed{ width:auto; padding:5px 8px; background:rgba(10,28,48,.6); }
.navmap.collapsed .nav-head{ margin:0; }
.navmap.collapsed .nav-ttl::after{ content:' ▸'; color:#E7CE8B; } #navmap-cv{ } }

/* ===== RC4 P3 Cockpit-Instrumenten-Cluster (Armaturenbrett) ===== */
.wl-inst{ display:grid; grid-template-columns:1fr 1fr; gap:8px; margin:8px 0; }
.wl-i{ background:rgba(8,22,40,.6); border:1px solid rgba(91,185,160,.18); border-radius:11px; padding:8px 9px; min-height:64px; }
.wl-i-lbl{ font:800 9px/1 ui-monospace,monospace; letter-spacing:1.2px; color:#7F94A8; margin-bottom:4px; }
.wl-i-val{ font:800 13px/1.1 system-ui,sans-serif; color:#F5F0E1; }
.wl-i-sub{ font-size:10.5px; color:#9DB0C4; margin-top:2px; }
.wl-wind{ position:relative; }
.wl-dial{ position:absolute; top:8px; right:9px; width:30px; height:30px; border-radius:50%; border:1.5px solid rgba(120,210,235,.45); background:radial-gradient(circle,rgba(20,60,80,.7),rgba(8,22,38,.9)); }
.wl-needle{ position:absolute; left:50%; top:50%; width:2px; height:13px; background:linear-gradient(#E7CE8B,#C9462F); transform-origin:50% 100%; transform:translate(-50%,-100%); border-radius:2px; transition:transform .6s ease; }
.wl-stro .wl-bar{ height:8px; border-radius:99px; background:rgba(255,255,255,.1); overflow:hidden; margin:4px 0; }
.wl-stro .wl-bar span{ display:block; height:100%; background:linear-gradient(90deg,#5BB98B,#E7CE8B,#C9462F); border-radius:99px; }
.wl-amp{ font:800 11px/1.2 system-ui,sans-serif; }
.wl-amp.green{ color:#6fe0a3; } .wl-amp.amber{ color:#E7CE8B; } .wl-amp.red{ color:#ff7a66; }
.wl-sch{ font:800 12px/1.2 system-ui,sans-serif; }
.wl-sch.green{ color:#6fe0a3; } .wl-sch.amber{ color:#E7CE8B; } .wl-sch.red{ color:#ff7a66; }
.wl-foot{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:4px; }
.wl-foot .wl-hint{ font-size:10.5px; color:#9DB0C4; flex:1; }
.wl-link{ flex:0 0 auto; font:700 11px system-ui,sans-serif; color:#9CE3BE; text-decoration:none; border:1px solid rgba(91,185,160,.4); padding:5px 9px; border-radius:9px; background:rgba(12,30,52,.6); }

/* Echtes Wave-Bite-Badge als Hero-Logo (ersetzt Anker-Box, groesser & praesenter) */
.hero-mark.hero-badge{ width:142px; height:142px; border-radius:32px; background:none; box-shadow:none; margin-bottom:18px; }
.hero-mark.hero-badge img{ width:100%; height:100%; object-fit:contain; display:block; filter: drop-shadow(0 16px 42px rgba(201,162,75,.55)) drop-shadow(0 4px 14px rgba(0,0,0,.5)); }
@media (max-width:560px){ .hero-mark.hero-badge{ width:124px; height:124px; } }

/* ===== RS5: Skipper / Namens-Onboarding (Funkname) ===== */
#overlay-skipper .skp-card{position:relative;max-width:380px;margin:auto;padding:26px 22px 18px;border-radius:22px;text-align:center;
  background:linear-gradient(160deg, rgba(18,42,72,.97), rgba(8,20,36,.98));border:1px solid rgba(201,162,75,.42);
  box-shadow:0 30px 70px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.06);color:#eaf1f8;animation:skpIn .5s cubic-bezier(.2,.9,.3,1.15) both}
@keyframes skpIn{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:none}}
.skp-radio{font-size:10px;letter-spacing:.14em;font-weight:800;color:#7fd0b0;display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:14px;text-transform:uppercase}
.skp-radio span{width:4px;height:4px;border-radius:50%;background:#7fd0b0;display:inline-block;animation:skpPulse 1.2s infinite}
.skp-radio span:nth-child(2){animation-delay:.2s}.skp-radio span:nth-child(3){animation-delay:.4s}
@keyframes skpPulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.6)}}
.skp-port{width:76px;height:76px;border-radius:50%;margin:0 auto 10px;background-size:cover;background-position:center;border:2px solid rgba(201,162,75,.6);box-shadow:0 8px 24px rgba(0,0,0,.5)}
.skp-port-fb{display:grid;place-items:center;font-size:34px;background:linear-gradient(135deg,#c9a24b,#e7ce8b);color:#0b1e3b}
.skp-from{font-size:10.5px;letter-spacing:.1em;font-weight:800;color:var(--gold-2);text-transform:uppercase;margin-bottom:4px}
.skp-h{margin:2px 0 8px;font-size:20px;line-height:1.2}
.skp-x{color:var(--muted);font-size:13.5px;line-height:1.5;margin:0 auto 14px;max-width:300px}
.skp-input{width:100%;box-sizing:border-box;padding:13px 14px;border-radius:12px;font-size:16px;text-align:center;font-weight:600;
  background:rgba(255,255,255,.06);border:1.5px solid rgba(201,162,75,.45);color:#fff;outline:none;transition:border-color .2s,box-shadow .2s}
.skp-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.22)}
.skp-input::placeholder{color:rgba(255,255,255,.4);font-weight:500}
.skp-shake{animation:skpShake .45s}
@keyframes skpShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
.skp-actions{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.skp-note{margin-top:13px;font-size:10.5px;color:rgba(255,255,255,.45)}
.skp-check{width:62px;height:62px;border-radius:50%;margin:2px auto 10px;display:grid;place-items:center;font-size:32px;font-weight:800;color:#06241a;
  background:linear-gradient(135deg,#7fe0a3,#46b27a);box-shadow:0 10px 30px rgba(70,178,122,.5);animation:skpPop .5s cubic-bezier(.2,.9,.3,1.4) both}
@keyframes skpPop{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
@media (max-width:560px){#overlay-skipper .skp-card{max-width:92vw;padding:22px 16px 16px}}
@media (prefers-reduced-motion: reduce){.skp-card,.skp-radio span,.skp-check{animation:none}}

/* ===== RS5: Pixar-/Wave-Bite-Film vollständig sichtbar (Root-Cause-Fix: contain statt cover) ===== */
/* Video ist 16:9 (1376x768); im Hochformat-Container beschnitt object-fit:cover links/rechts + introZoom. */
.intro-stage.film{display:flex;align-items:center;justify-content:center;background:#03070e}
.intro-stage.film .intro-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:1;animation:none}
.intro-stage.film .intro-grade{background:linear-gradient(180deg,rgba(4,8,15,.20),rgba(4,8,15,0) 24%,rgba(4,8,15,0) 76%,rgba(4,8,15,.42))}
.intro-stage.film .cine-bar{display:none}

/* ===== RS5: PWA-Install-Button + iOS-Anleitung ===== */
.btn-install{ background:linear-gradient(135deg,#0a4d80,#0b6cab); color:#fff; border:1px solid rgba(120,180,255,.5);
  font-weight:800; box-shadow:0 8px 22px -10px rgba(11,108,171,.8), inset 0 1px 0 rgba(255,255,255,.25); }
.btn-install:hover{ transform:translateY(-1px); }
#overlay-install .inst-card{ position:relative; max-width:380px; margin:auto; padding:24px 22px 20px; border-radius:22px; text-align:center;
  background:linear-gradient(160deg, rgba(18,42,72,.97), rgba(8,20,36,.98)); border:1px solid rgba(201,162,75,.4);
  box-shadow:0 30px 70px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.06); color:#eaf1f8; animation:skpIn .5s cubic-bezier(.2,.9,.3,1.15) both; }
.inst-badge{ width:84px; height:84px; margin:0 auto 12px; border-radius:20px; overflow:hidden; box-shadow:0 12px 30px rgba(0,0,0,.5); }
.inst-badge img{ width:100%; height:100%; object-fit:cover; display:block; }
.inst-h{ margin:2px 0 8px; font-size:20px; }
.inst-x{ color:var(--muted); font-size:13.5px; line-height:1.5; margin:0 auto 16px; max-width:310px; }
.inst-step{ display:flex; align-items:center; gap:11px; text-align:left; background:rgba(255,255,255,.04);
  border:1px solid var(--glass-line); border-radius:13px; padding:11px 13px; margin:0 0 9px; font-size:13.5px; color:#dfe9f4; }
.inst-n{ flex:0 0 auto; width:26px; height:26px; border-radius:50%; display:grid; place-items:center; font-weight:800; font-size:13px;
  color:#06121f; background:linear-gradient(135deg,var(--gold),var(--gold-2)); }
.inst-share{ font-size:16px; }
.inst-note{ font-size:11px; color:rgba(255,255,255,.5); margin:12px 0 14px; line-height:1.45; }
@media (max-width:560px){ #overlay-install .inst-card{ max-width:92vw; } }

/* ===== GA4 Consent-Banner (Wave-Bite-Look) ===== */
.ga-consent{ position:absolute; left:8px; right:8px; bottom:calc(8px + env(safe-area-inset-bottom)); z-index:50;
  background:linear-gradient(160deg, rgba(18,42,72,.98), rgba(8,20,36,.99)); border:1px solid rgba(201,162,75,.45);
  border-radius:16px; padding:13px 14px; box-shadow:0 18px 44px rgba(0,0,0,.55);
  display:flex; flex-direction:column; gap:10px; transform:translateY(140%); opacity:0; transition:transform .4s cubic-bezier(.2,.9,.3,1.1), opacity .4s; }
.ga-consent.in{ transform:none; opacity:1; }
.ga-c-txt{ font-size:12px; line-height:1.5; color:#dfe9f4; }
.ga-c-btns{ display:flex; gap:9px; }
.ga-c-btns .btn{ flex:1; padding:11px; font-size:14px; }
@media (min-width:520px){ .ga-consent{ left:auto; right:14px; max-width:360px; } }
