/* Tulip Empire v2 — minimal S1 styling */
:root {
    /* ===== Palette: Delfter Blau + Vermeer Elfenbein auf Schiefer ===== */
    --bg: #0d1620;
    --panel: #16212e;
    --panel-2: #1f2d3d;
    --panel-3: #2a3a4d;           /* hover/active */
    --ink: #e8e6de;                /* warmes Elfenbein */
    --ink-dim: #8fa0b4;            /* kühler Sekundär-Text */
    --ink-faint: #5a6b7f;
    --accent: #6aa8d9;             /* Delfter Blau — Primary */
    --accent-2: #4a7ab0;           /* dunklere Variante */
    --accent-ink: #0d1620;         /* Text auf Accent-Button */
    --brand: #6aa8d9;              /* alias, explizit für Brand-Rollen */
    --danger: #d9645a;
    --ok: #7dbe8a;
    --warn: #e3a94e;
    --info: #8abdd4;
    --border: rgba(170,190,210,.10);
    --border-strong: rgba(170,190,210,.22);
    --radius: 8px;
    --radius-sm: 4px;
    --radius-lg: 12px;
    /* Spacing scale */
    --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px;
    --sp-6: 24px; --sp-8: 32px; --sp-12: 48px;
}
/* Headings use neutral text by default — Brand-Farbe ist nicht für jede Überschrift */
h1, h2, h3, .auth-card h1 { color: var(--ink); }
h3 { color: var(--ink-dim); font-weight: 600; }
.topbar strong, .topbar .purse-big { color: var(--ink); }
.purse-big { font-weight: 700; }
.stat-card .stat-value { color: var(--ink); }
/* Recovery-reveal + specific brand moments may still use accent — kept locally */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
body {
    font-family: -apple-system, system-ui, "Segoe UI", Roboto, sans-serif;
    background: var(--bg);
    color: var(--ink);
    line-height: 1.5;
}
h1, h2, h3 { margin: .4em 0; }
h1 { font-size: 1.8rem; letter-spacing: .04em; }
h2 { font-size: 1.3rem; }
h3 { font-size: 1rem; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-dim); }
code { background: rgba(0,0,0,.3); padding: 0 .3em; border-radius: 3px; font-size: .9em; }
hr { border: 0; border-top: 1px solid rgba(255,255,255,.08); margin: 1em 0; }

/* Modal root */
.modal-root {
    position: fixed; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(10,5,2,.85);
    z-index: 1000;
    padding: 1rem;
}

/* Auth card */
.auth-card {
    background: var(--panel);
    border: 1px solid var(--accent-2);
    border-radius: var(--radius);
    padding: 1.5rem;
    width: 100%;
    max-width: 380px;
    display: flex; flex-direction: column; gap: .6rem;
    box-shadow: 0 10px 40px rgba(0,0,0,.6);
}
.auth-card h1 { text-align: center; margin: 0 0 .2em; }
.auth-card h2 { text-align: center; margin: 0 0 .8em; color: var(--ink); font-size: 1rem; font-weight: normal; }
.auth-card input, .auth-card button {
    font: inherit;
    padding: .6em .8em;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,.15);
    background: var(--panel-2);
    color: var(--ink);
}
.auth-card input:focus { outline: 2px solid var(--accent); }
.auth-primary {
    background: var(--accent) !important;
    color: var(--accent-ink) !important;
    font-weight: bold; cursor: pointer;
    border: none !important;
}
.auth-primary:disabled { opacity: .5; cursor: wait; }
.auth-secondary {
    background: transparent !important;
    color: var(--ink-dim) !important;
    border: none !important; cursor: pointer;
    font-size: .9em;
}
.auth-error {
    background: rgba(196,90,69,.15);
    color: var(--danger);
    padding: .5em .7em; border-radius: 6px;
    font-size: .9em;
}
.auth-status { text-align: center; color: var(--ink-dim); font-size: .8em; margin-top: .5em; }

/* Lobby */
.view { padding: 1rem; max-width: 900px; margin: 0 auto; }
.lobby-header { display: flex; justify-content: space-between; align-items: center; gap: 1em; margin-bottom: 1.5em; }
.lobby-actions { background: var(--panel); padding: 1.2em; border-radius: var(--radius); }
.lobby-actions input[type=text], .lobby-actions input[type=number] {
    background: var(--panel-2); color: var(--ink);
    border: 1px solid rgba(255,255,255,.15); border-radius: 4px;
    padding: .4em .6em; font: inherit; margin: .2em .3em .2em 0;
}
.lobby-actions label { display: inline-block; margin-right: 1em; color: var(--ink-dim); }
.lobby-actions button {
    background: var(--accent); color: var(--accent-ink); border: none;
    padding: .5em 1em; border-radius: 4px; cursor: pointer; font-weight: bold;
    margin: .2em 0;
}
.lobby-actions button:hover { background: var(--accent-2); color: var(--ink); }
#room-list { list-style: none; padding: 0; }
#room-list li {
    padding: .5em .7em; background: var(--panel-2); border-radius: 4px;
    margin: .3em 0; display: flex; align-items: center; gap: .8em;
}
#room-list .join-btn { margin-left: auto; }

/* Game */
.game-header { display: flex; justify-content: space-between; align-items: center; gap: 1em; margin-bottom: 1em; }
.game-header button { background: var(--danger); color: #fff; border: none; padding: .4em .8em; border-radius: 4px; cursor: pointer; }
.game-players ul { list-style: none; padding: 0; display: flex; gap: 1em; flex-wrap: wrap; }
.game-players li { background: var(--panel-2); padding: .3em .7em; border-radius: 4px; }
.game-stub { background: var(--panel); padding: 1em; border-radius: var(--radius); margin: 1em 0; color: var(--ink-dim); }
.game-chat { background: var(--panel); padding: 1em; border-radius: var(--radius); }
#chat-log { list-style: none; padding: 0; max-height: 240px; overflow-y: auto; margin: 0 0 .5em; }
#chat-log li { padding: .2em 0; border-bottom: 1px solid rgba(255,255,255,.05); font-size: .92em; }
#chat-form { display: flex; gap: .5em; }
#chat-form input { flex: 1; padding: .4em .6em; background: var(--panel-2); color: var(--ink); border: 1px solid rgba(255,255,255,.15); border-radius: 4px; }
#chat-form button { background: var(--accent); color: var(--accent-ink); border: none; padding: .4em 1em; border-radius: 4px; cursor: pointer; font-weight: bold; }

/* Game: market + travel */
.game-purse { text-align: right; }
.game-purse strong { font-size: 1.3rem; color: var(--accent); display: block; }
.game-purse small { color: var(--ink-dim); }
.game-market, .game-travel, .game-players, .game-chat { background: var(--panel); padding: 1em; border-radius: var(--radius); margin-bottom: 1em; }
.game-market table { width: 100%; border-collapse: collapse; }
.game-market th, .game-market td { text-align: left; padding: .4em .5em; border-bottom: 1px solid rgba(255,255,255,.05); }
.game-market th { color: var(--ink-dim); font-weight: normal; font-size: .85em; text-transform: uppercase; }
.game-market input[type=number] { background: var(--panel-2); color: var(--ink); border: 1px solid rgba(255,255,255,.15); border-radius: 3px; padding: .2em .4em; font: inherit; }
.game-market button { padding: .3em .7em; margin-left: .2em; background: var(--accent); color: var(--accent-ink); border: none; border-radius: 3px; cursor: pointer; font-weight: bold; }
.game-market button:disabled { opacity: .35; cursor: not-allowed; }
.game-market button.sell-btn { background: var(--ok); color: #fff; }
.travel-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: .4em; }
.travel-btn { background: var(--panel-2); color: var(--ink); border: 1px solid rgba(255,255,255,.15); padding: .5em .7em; border-radius: 4px; cursor: pointer; text-align: left; }
.travel-btn:hover:not([disabled]) { border-color: var(--accent); color: var(--accent); }
.travel-btn[disabled] { opacity: .4; cursor: default; }

/* Bank / Plantation / Fleet */
.game-bank, .game-plantations, .game-fleet { background: var(--panel); padding: 1em; border-radius: var(--radius); margin-bottom: 1em; }
.bank-row { display: flex; align-items: center; gap: .6em; padding: .4em 0; flex-wrap: wrap; }
.bank-row button { background: var(--accent); color: var(--accent-ink); border: none; padding: .4em .9em; border-radius: 4px; cursor: pointer; font-weight: bold; }
.bank-row button:disabled { opacity: .35; cursor: not-allowed; }
.bank-row input { background: var(--panel-2); color: var(--ink); border: 1px solid rgba(255,255,255,.15); border-radius: 4px; padding: .3em .5em; }

.plant-grid, .fleet-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: .6em; }
.plant-card, .ship-card { background: var(--panel-2); padding: .7em; border-radius: 4px; display: flex; flex-direction: column; gap: .3em; }
.plant-card.growing { border-left: 3px solid var(--warn); }
.plant-card.ready { border-left: 3px solid var(--ok); }
.plant-card button, .ship-card button { background: var(--accent); color: var(--accent-ink); border: none; padding: .3em .7em; border-radius: 3px; cursor: pointer; margin-top: .3em; }
.plant-card small, .ship-card small { color: var(--ink-dim); font-size: .85em; }
.ship-card.traveling { border-left: 3px solid var(--ok); }
.ship-card.arrived { border-left: 3px solid var(--accent); }
.ship-card.away { opacity: .5; }
.ship-dest, select#ship-kind { background: var(--panel); color: var(--ink); border: 1px solid rgba(255,255,255,.15); padding: .2em; margin-top: .3em; width: 100%; }
.ship-cargo-pick { display: flex; flex-wrap: wrap; gap: .3em; margin-top: .3em; font-size: .85em; }
.ship-cargo-pick label { background: var(--panel); padding: .1em .4em; border-radius: 3px; }
.ship-cargo-pick input { background: var(--panel-2); color: var(--ink); border: 1px solid rgba(255,255,255,.15); border-radius: 2px; padding: .1em .2em; }
.fleet-buy { display: flex; gap: .5em; margin-bottom: .6em; }

.toast-ok { border-left-color: var(--ok); }

/* Toast */
#toast-root {
    position: fixed; bottom: 1rem; right: 1rem;
    display: flex; flex-direction: column; gap: .5em; z-index: 2000;
}
.toast {
    background: var(--panel);
    border-left: 4px solid var(--danger);
    padding: .6em 1em;
    border-radius: 4px;
    box-shadow: 0 4px 16px rgba(0,0,0,.4);
    color: var(--ink);
    animation: toast-in .2s ease;
}
@keyframes toast-in { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }

/* Meta-Tabs (S8/S9) */
.game-meta { margin-top: 1.5rem; border-top: 2px solid var(--panel); padding-top: 1rem; }
.meta-tabs { display: flex; gap: .4em; flex-wrap: wrap; margin-bottom: 1em; }
.meta-tab {
    background: var(--panel); color: var(--ink); border: 1px solid var(--border-strong);
    padding: .4em .8em; border-radius: 6px; cursor: pointer; font-family: inherit;
}
.meta-tab:hover { background: var(--panel-3); }
#leaderboard-panel, #recap-panel, #cosmetics-panel,
#achievements-panel, #referral-panel, #profile-panel {
    background: rgba(0,0,0,0.15); padding: .8em; border-radius: 6px; margin-bottom: .8em;
}
#leaderboard-panel table { width: 100%; border-collapse: collapse; }
#leaderboard-panel th, #leaderboard-panel td { padding: .3em .6em; text-align: left; border-bottom: 1px solid var(--border); }
.recap-card { display: inline-block; margin: .4em; text-align: center; }
.recap-card img { border: 2px solid var(--accent); border-radius: 6px; display: block; }
.recap-card button { margin-top: .3em; }
.cosm { padding: .4em; border-bottom: 1px solid var(--border); }
.cosm.locked { opacity: .4; }
.ach-row { padding: .3em; border-bottom: 1px solid var(--border); }
.ref-code { display: flex; gap: .5em; align-items: center; flex-wrap: wrap; margin-top: .5em; }
.ref-code code { background: var(--panel-2); padding: .3em .8em; border-radius: 4px; font-size: 1.2em; color: var(--accent); }
.prof-row { display: flex; gap: 1em; align-items: center; margin-bottom: 1em; }
.prof-edit, .prof-audio { display: flex; gap: 1em; flex-wrap: wrap; align-items: center; margin-top: .5em; }

/* ========================================================== */
/* S11: Design-System (responsive, cards, progress, feedback)   */
/* ========================================================== */

/* ---- Base polish ---- */
body { padding-bottom: 5rem; } /* space for mobile bottom-nav */
button { font-family: inherit; }
input, select, button { min-height: 36px; }
@media (max-width: 600px) {
    input, select, button { min-height: 44px; font-size: 16px; } /* iOS no-zoom */
    h1 { font-size: 1.4rem; }
    h2 { font-size: 1.1rem; }
    .view { padding: .6rem; }
}

/* ---- Sticky Top-Bar ---- */
.topbar {
    position: sticky; top: 0; z-index: 100;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: .8rem;
    padding: .6rem 1rem;
    background: linear-gradient(to bottom, var(--panel) 0%, rgba(46,26,15,.97) 100%);
    border-bottom: 1px solid var(--accent-2);
    box-shadow: 0 2px 10px rgba(0,0,0,.4);
    backdrop-filter: blur(6px);
}
.topbar-left, .topbar-center, .topbar-right { display: flex; align-items: center; gap: .6rem; }
.topbar-right { justify-content: flex-end; }
.topbar-center { justify-content: center; flex-wrap: wrap; }
.topbar strong { color: var(--accent); }
.topbar small { color: var(--ink-dim); font-size: .8em; }
.topbar .purse-big {
    font-size: 1.3rem; font-weight: 700; color: var(--accent);
    transition: color .3s;
}
.topbar .purse-big.flash-up { color: var(--ok); }
.topbar .purse-big.flash-down { color: var(--danger); }
@media (max-width: 600px) {
    .topbar { grid-template-columns: auto 1fr auto; padding: .4rem .6rem; gap: .4rem; }
    .topbar small { display: none; }
    .topbar .purse-big { font-size: 1rem; }
}

/* ---- Circular day-progress ring ---- */
.day-ring { --pct: 0; width: 40px; height: 40px; position: relative; flex-shrink: 0; }
.day-ring svg { width: 40px; height: 40px; transform: rotate(-90deg); }
.day-ring circle { fill: none; stroke-width: 4; }
.day-ring .bg { stroke: var(--panel-2); }
.day-ring .fg { stroke: var(--accent); stroke-linecap: round; transition: stroke-dashoffset .5s; }
.day-ring-label {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    font-size: .7rem; color: var(--ink);
}

/* ---- Top-Tabs ---- */
.tabbar {
    display: flex; gap: 0; position: sticky; top: 60px; z-index: 99;
    background: var(--bg); border-bottom: 1px solid var(--panel-2);
    overflow-x: auto; scrollbar-width: none;
}
.tabbar::-webkit-scrollbar { display: none; }
.tabbar-btn {
    flex: 1; min-width: max-content;
    background: transparent; color: var(--ink-dim);
    border: none; border-bottom: 2px solid transparent;
    padding: .7em 1em; cursor: pointer; font-size: .95rem;
    transition: color .15s, border-color .15s;
}
.tabbar-btn:hover { color: var(--ink); }
.tabbar-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
@media (max-width: 600px) {
    .tabbar { top: auto; position: fixed; bottom: 0; left: 0; right: 0; top: auto;
        background: var(--panel); border-top: 1px solid var(--accent-2); border-bottom: none;
        box-shadow: 0 -2px 10px rgba(0,0,0,.5);
    }
    .tabbar-btn { font-size: .8rem; padding: .5em .3em; }
    .tabbar-btn .tab-icon { display: block; font-size: 1.3rem; }
    .tabbar-btn .tab-label { display: block; font-size: .65rem; }
}
@media (min-width: 601px) {
    .tab-icon { margin-right: .3em; }
}

/* Tab content container */
.tab-content { display: none; }
.tab-content.active { display: block; animation: fade-in .2s ease; }
@keyframes fade-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* ---- Card system ---- */
.card {
    background: var(--panel-2);
    padding: .8rem;
    border-radius: var(--radius);
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
    transition: transform .15s, box-shadow .15s;
    display: flex; flex-direction: column; gap: .4rem;
    position: relative;
    overflow: hidden;
}
.card--interactive:hover { transform: translateY(-2px); box-shadow: 0 4px 14px rgba(0,0,0,.5); }
/* State-accent strip on top */
.card--state-ready::before,
.card--state-growing::before,
.card--state-traveling::before,
.card--state-alert::before,
.card--state-arrived::before {
    content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px;
}
.card--state-ready::before    { background: var(--ok); }
.card--state-growing::before  { background: var(--warn); }
.card--state-traveling::before{ background: var(--ok); }
.card--state-arrived::before  { background: var(--accent); }
.card--state-alert::before    { background: var(--danger); }
.card--ready-pulse { animation: ready-pulse 2s ease-in-out infinite; }
@keyframes ready-pulse {
    0%, 100% { box-shadow: 0 2px 8px rgba(0,0,0,.3); }
    50% { box-shadow: 0 2px 18px rgba(106,168,217,.35); }
}

/* ---- Button system ---- */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .4em;
    font: inherit; cursor: pointer;
    border-radius: 6px; border: 1px solid transparent;
    padding: .5em 1em;
    transition: background .15s, transform .1s, box-shadow .15s;
    min-height: 36px; line-height: 1;
}
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: .45; cursor: not-allowed; transform: none; }
.btn--primary { background: var(--accent); color: var(--accent-ink); font-weight: 700; border-color: var(--accent-2); }
.btn--primary:hover:not(:disabled) { background: var(--accent-2); }
.btn--secondary { background: var(--panel-2); color: var(--ink); border: 1px solid var(--accent); font-weight: 600; }
.btn--secondary:hover:not(:disabled) { background: color-mix(in srgb, var(--accent) 22%, var(--panel-2)); color: var(--ink); }
.btn--secondary:disabled { color: var(--ink-faint); border-color: rgba(255,255,255,.08); opacity: .5; }
.btn--danger { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn--danger:hover:not(:disabled) { background: color-mix(in srgb, var(--danger) 80%, #fff); }
.btn--ghost { background: var(--panel-3); color: var(--ink); border: 1px solid var(--border); }
.btn--ghost:hover:not(:disabled) { background: var(--panel-2); color: var(--accent); border-color: var(--accent); }
.btn--ghost:disabled { color: var(--ink-faint); opacity: .5; }
.btn--sm { padding: .3em .7em; font-size: .85rem; min-height: 30px; }
@media (max-width: 600px) { .btn { min-height: 44px; padding: .6em 1em; } }

/* ---- Loading state ---- */
.btn--loading { pointer-events: none; position: relative; color: transparent !important; }
.btn--loading::after {
    content: ''; position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    border: 2px solid currentColor; border-top-color: transparent;
    border-radius: 50%; width: 16px; height: 16px;
    margin: auto;
    animation: spin .6s linear infinite;
    color: var(--accent-ink);
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ---- Linear progress bar ---- */
.progress {
    width: 100%; height: 6px;
    background: rgba(0,0,0,.4);
    border-radius: 3px; overflow: hidden;
    position: relative;
}
.progress__fill {
    height: 100%; background: var(--accent);
    transition: width .6s ease, background .3s;
    border-radius: 3px;
}
.progress--urgent .progress__fill { background: var(--danger); animation: pulse-urgent .5s ease-in-out infinite; }
.progress--warn .progress__fill { background: var(--warn); }
.progress--ok .progress__fill { background: var(--ok); }
@keyframes pulse-urgent { 0%, 100% { opacity: 1; } 50% { opacity: .6; } }

/* ---- Chip (status tag) ---- */
.chip {
    display: inline-flex; align-items: center; gap: .3em;
    font-size: .75rem; font-weight: 600;
    padding: .15em .6em; border-radius: 12px;
    background: rgba(0,0,0,.3); color: var(--ink-dim);
    text-transform: uppercase; letter-spacing: .04em;
}
.chip--ok    { background: rgba(111,179,106,.2); color: var(--ok); }
.chip--warn  { background: rgba(232,160,52,.2); color: var(--warn); }
.chip--danger{ background: rgba(196,90,69,.2); color: var(--danger); }
.chip--info  { background: rgba(106,168,217,.15); color: var(--accent); }

/* ---- Stat card (metric display) ---- */
.stat-card {
    background: var(--panel); padding: .7em .9em; border-radius: var(--radius);
    display: flex; flex-direction: column; gap: .2em;
}
.stat-card .stat-value { font-size: 1.4rem; font-weight: 700; color: var(--accent); }
.stat-card .stat-label { font-size: .75rem; color: var(--ink-dim); text-transform: uppercase; letter-spacing: .05em; }

/* ---- Skeleton loader ---- */
.skeleton {
    background: linear-gradient(90deg, var(--panel-2) 0%, var(--panel-3) 50%, var(--panel-2) 100%);
    background-size: 200% 100%;
    animation: shimmer 1.4s infinite;
    border-radius: 4px;
    height: 1.2em; margin: .3em 0;
}
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ---- Grids ---- */
.grid-auto { display: grid; gap: .6rem; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
@media (max-width: 600px) { .grid-auto { grid-template-columns: 1fr; gap: .5rem; } }

/* ---- Day-tick fade ---- */
.game-root.day-transition { animation: day-fade .4s ease; }
@keyframes day-fade { 0% { opacity: 1; } 30% { opacity: .3; } 100% { opacity: 1; } }

/* ---- Toast improvements ---- */
.toast { position: relative; padding-right: 2em; }
.toast::after {
    content: ''; position: absolute; left: 0; right: 0; bottom: 0;
    height: 2px; background: var(--accent);
    animation: toast-strip 3.2s linear forwards;
}
.toast .toast-close {
    position: absolute; right: .4em; top: .3em;
    background: transparent; border: none; color: var(--ink-dim);
    cursor: pointer; font-size: 1em; padding: 0 .3em;
}
.toast .toast-close:hover { color: var(--ink); }
@keyframes toast-strip { from { width: 100%; } to { width: 0; } }

/* ---- Market cards (mobile) override table ---- */
@media (max-width: 600px) {
    .game-market table, .game-market thead { display: none; }
    .game-market tbody, .game-market tr, .game-market td { display: block; width: 100%; }
    .game-market tr { background: var(--panel-2); padding: .6em; border-radius: 6px; margin-bottom: .5em; border-bottom: none; }
    .game-market td { padding: .15em 0; border: none; }
    .game-market td:first-child { font-weight: 700; font-size: 1.05rem; }
}

/* ---- Tutorial redesign ---- */
.tut-overlay {
    position: fixed; right: 1rem; bottom: 1rem; z-index: 1500;
    background: var(--panel); border: 1px solid var(--accent-2);
    border-radius: 10px; padding: 1em 1.1em;
    max-width: 320px;
    box-shadow: 0 8px 30px rgba(0,0,0,.55);
    animation: tut-slide .3s ease;
}
@keyframes tut-slide { from { transform: translateY(30px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.tut-title { color: var(--accent); font-weight: 700; margin-bottom: .4em; }
.tut-body  { color: var(--ink); font-size: .9em; margin-bottom: .6em; }
.tut-pips  { display: flex; gap: .3em; margin: .5em 0; }
.tut-pip   {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--panel-2);
    transition: background .2s, transform .2s;
}
.tut-pip.active { background: var(--accent); transform: scale(1.3); }
.tut-pip.done   { background: var(--ink-dim); }
.tut-footer { display: flex; justify-content: space-between; align-items: center; gap: .4em; margin-top: .5em; }
.tut-close  { background: transparent; border: none; color: var(--ink-dim); cursor: pointer; font-size: 1.2em; }
.tut-close:hover { color: var(--ink); }
.tut-arrow {
    position: fixed; z-index: 1400; font-size: 2rem;
    color: var(--accent); pointer-events: none;
    animation: tut-bounce 1s ease-in-out infinite;
    text-shadow: 0 0 8px rgba(106,168,217,.6);
}
@keyframes tut-bounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
@media (max-width: 600px) {
    .tut-overlay { left: .5rem; right: .5rem; bottom: 5rem; max-width: none; }
}

/* ---- Plant / ship card progress slot ---- */
.plant-card .progress, .ship-card .progress { margin-top: .4em; }

/* ---- Tutorial overlay (inline fallback removed, now styled) ---- */
/* FX-Layer uses inline styles in 08-visuals.js */

/* ---- S11b: Accordions ---- */
.acc {
    background: var(--panel);
    border: 1px solid rgba(106,168,217,.15);
    border-radius: 8px;
    margin-bottom: .6rem;
    overflow: hidden;
}
.acc[open] { border-color: rgba(106,168,217,.3); }
.acc-sum {
    padding: .7rem .9rem;
    cursor: pointer;
    list-style: none;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: .5rem;
    user-select: none;
    background: var(--panel-2);
}
.acc-sum::-webkit-details-marker { display: none; }
.acc-sum::before {
    content: '▸';
    display: inline-block;
    transition: transform .2s;
    color: var(--accent);
}
.acc[open] > .acc-sum::before { transform: rotate(90deg); }
.acc-count {
    margin-left: auto;
    background: rgba(106,168,217,.15);
    color: var(--accent);
    padding: 1px 8px;
    border-radius: 10px;
    font-size: .8em;
    font-weight: 500;
}
.acc-body { padding: .8rem 1rem; }
.acc-body > section:first-child { margin-top: 0; }
.acc-body > section > h3:first-child { margin-top: 0; }

/* ---- S11b: World map (Travel + Live) ---- */
.world-map-wrap, .live-map-wrap {
    width: 100%;
    background: var(--panel-2);
    border-radius: 8px;
    border: 1px solid var(--border-strong);
    overflow: hidden;
}
.world-map {
    width: 100%;
    height: auto;
    max-height: 62vh;
    display: block;
}
.wm-node { cursor: pointer; }
.wm-node:hover circle:first-of-type { fill: var(--accent); transform-origin: center; }
.wm-node.wm-here { cursor: default; }
.wm-node:focus { outline: none; }
.wm-node:focus circle:first-of-type { stroke: #fff; stroke-width: 3; }
.world-map-hint {
    display: block;
    padding: .5rem .8rem;
    color: var(--ink-dim);
    border-top: 1px solid rgba(106,168,217,.15);
}
.lm-legend {
    padding: .5rem .8rem;
    display: flex;
    flex-wrap: wrap;
    gap: .6rem .9rem;
    border-top: 1px solid rgba(106,168,217,.15);
    font-size: .85em;
}
.lm-legend-dot {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 50%;
    margin-right: 4px;
    vertical-align: middle;
}
.lm-ship text { animation: lm-ship-bob 2.5s ease-in-out infinite; }
@keyframes lm-ship-bob {
    0%,100% { transform: translateY(0); }
    50%     { transform: translateY(-3px); }
}

/* ---- S11b: NPC cards with portrait ---- */
.npc-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: .75rem;
}
.npc-card {
    display: flex;
    flex-direction: column;
    padding: 0;
    overflow: hidden;
}
.npc-portrait {
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.npc-portrait-face {
    font-size: 56px;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,.6));
    animation: npc-float 4s ease-in-out infinite;
}
@keyframes npc-float {
    0%,100% { transform: translateY(0); }
    50%     { transform: translateY(-4px); }
}
.npc-body { padding: .7rem .85rem; display: flex; flex-direction: column; gap: .4rem; }
.npc-name { font-size: 1.05em; }
.npc-role { color: var(--ink-dim); }
.npc-aff { display: flex; flex-direction: column; gap: .2rem; }
.npc-aff-bar { height: 5px; }
.npc-actions { display: flex; flex-wrap: wrap; gap: .3rem; margin-top: .3rem; align-items: center; }
.npc-gift-good { flex: 1; min-width: 0; }
.npc-dialog { margin-top: .7rem; }
.npc-line { margin: 0 0 .5rem 0; }
.npc-offer {
    display: flex; align-items: center; gap: .6rem; flex-wrap: wrap;
    padding: .5rem .7rem; background: rgba(106,168,217,.08); border-radius: 6px;
}

/* ---- S11b: Profile wappen ---- */
.prof-wappen {
    width: 64px; height: 64px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 32px;
    border: 2px solid rgba(106,168,217,.3);
    transition: background .2s;
}
.prof-row { display: flex; gap: .8rem; align-items: center; margin-bottom: .8rem; }
.prof-edit, .prof-audio { display: flex; gap: .8rem; flex-wrap: wrap; align-items: center; margin-bottom: .6rem; }

/* ---- Progress fill variants ---- */
.progress__fill--ok { background: var(--ok); }
.progress__fill--warn { background: var(--warn); }
.progress__fill--danger { background: var(--danger); }

@media (max-width: 600px) {
    .world-map, .live-map-wrap .world-map { max-height: 40vh; }
    .npc-grid { grid-template-columns: 1fr; }
    .acc-body { padding: .6rem .7rem; }
}

/* ---- Travel banner ---- */
.travel-banner {
    margin: .4rem 0 .8rem;
    padding: .6rem .9rem;
    background: linear-gradient(90deg, rgba(106,168,217,.12), rgba(106,168,217,.04));
    border: 1px solid rgba(106,168,217,.35);
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
    animation: travelBannerIn .3s ease-out;
}
@keyframes travelBannerIn {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.travel-banner__line {
    display: flex; justify-content: space-between; align-items: baseline;
    gap: .8rem; margin-bottom: .4rem;
}
.travel-banner__route { font-size: 1rem; }
.travel-banner__eta   { font-family: monospace; font-weight: 700; color: var(--accent); }
.travel-banner__actions { display: flex; align-items: center; gap: .6rem; margin-top: .4rem; flex-wrap: wrap; }
.travel-banner__hint { color: var(--ink-dim); }
.progress.progress--travel { height: 8px; background: rgba(255,255,255,.06); border-radius: 4px; overflow: hidden; }
.progress.progress--travel .progress__fill {
    height: 100%; background: linear-gradient(90deg, var(--accent), var(--warn));
    transition: width 1s linear;
}

/* ---- City scene (silhouette + clickable buildings) ---- */
.city-scene {
    position: relative;
    margin: 0 0 1rem;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid rgba(106,168,217,.3);
    box-shadow: 0 4px 16px rgba(0,0,0,.4);
    min-height: 180px;
}
.city-scene__sil {
    display: block;
    width: 100%;
    height: auto;
}
.city-scene__overlay {
    position: absolute; inset: 0;
    display: block;
}
.city-scene__title {
    position: absolute; top: .5rem; left: .8rem;
    color: #fff;
    text-shadow: 0 2px 4px rgba(0,0,0,.8);
}
.city-scene__title h2 { margin: 0; font-size: 1.3rem; }
.city-scene__title small { opacity: .85; }
.city-building {
    position: absolute;
    transform: translate(-50%, -50%);
    background: rgba(13,22,32,.82);
    border: 1px solid rgba(106,168,217,.5);
    color: var(--ink);
    padding: .35rem .55rem .4rem;
    border-radius: 6px;
    cursor: pointer;
    display: flex; flex-direction: column; align-items: center; gap: 1px;
    font-size: .7rem;
    transition: transform .15s ease-out, background .15s, border-color .15s;
    box-shadow: 0 2px 6px rgba(0,0,0,.4);
    white-space: nowrap;
}
.city-building:hover {
    background: var(--panel-3);
    border-color: var(--accent);
    transform: translate(-50%, -54%) scale(1.05);
}
.city-building__icon { font-size: 1.4rem; line-height: 1; }
.city-building__label { font-weight: 600; letter-spacing: .3px; }
@media (max-width: 600px) {
    .city-building { padding: .2rem .35rem; font-size: .6rem; }
    .city-building__icon { font-size: 1.1rem; }
}

/* Highlight flash when jumping to an accordion */
.acc--highlight {
    animation: accHighlight 1.4s ease-out;
}
@keyframes accHighlight {
    0%   { box-shadow: 0 0 0 0 rgba(106,168,217,.9); }
    40%  { box-shadow: 0 0 0 6px rgba(106,168,217,.5); }
    100% { box-shadow: 0 0 0 0 rgba(106,168,217,0); }
}

.empty-state p { color: var(--ink-dim); font-style: italic; }

/* ---- Plantation 2D field grid (Vermeer-style) ---- */
.field-hint { color: var(--ink-dim); display: block; margin-bottom: .6rem; }
.field-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    padding: 4px;
    background: linear-gradient(180deg, var(--panel-2), var(--panel));
    border: 1px solid var(--border-strong);
    border-radius: 4px;
    margin: .5rem 0;
}
.field-tile {
    aspect-ratio: 1;
    display: flex; align-items: center; justify-content: center;
    background: var(--panel-3);
    border-radius: 2px;
    font-size: 1.1rem;
    user-select: none;
    box-shadow: inset 0 0 4px rgba(0,0,0,.4);
}
.field-tile--idle    { background: var(--panel-3); }
.field-tile--growing { background: rgba(125,190,138,.22); animation: fieldSway 3s ease-in-out infinite; }
.field-tile--ready   { background: rgba(227,169,78,.30); box-shadow: inset 0 0 8px rgba(227,169,78,.45); }
.field-tile--locked  { background: var(--panel); opacity: .4; }
.field-tile--upgrade {
    background: rgba(106,168,217,.15);
    border: 1px dashed var(--accent);
    color: var(--accent);
    cursor: pointer;
    transition: background .15s;
}
.field-tile--upgrade:hover { background: rgba(106,168,217,.35); }
@keyframes fieldSway {
    0%,100% { transform: translateY(0); }
    50%     { transform: translateY(-1px); }
}
.plant-card--buy { cursor: pointer; }
.plant-card--buy:hover { border-color: var(--accent); }
.plant-actions { display: flex; gap: .4rem; flex-wrap: wrap; margin-top: .3rem; }

/* ---- Live-map ship progress (small bar under ship icon) ---- */
.lm-ship-progress-bg { fill: rgba(0,0,0,.4); }
.lm-ship-progress-fg { fill: var(--accent); }

/* ---- World map click ripple + locked state ---- */
.wm-node { cursor: pointer; }
.wm-node.wm-locked:not(.wm-here) { opacity: .35; cursor: not-allowed; filter: grayscale(.5); }
.wm-node.wm-click circle:first-of-type {
    animation: wmRipple .65s ease-out;
    transform-box: fill-box;
    transform-origin: center;
}
@keyframes wmRipple {
    0%   { transform: scale(1);   filter: drop-shadow(0 0 0 rgba(106,168,217,.9)); }
    50%  { transform: scale(1.6); filter: drop-shadow(0 0 8px rgba(106,168,217,.9)); }
    100% { transform: scale(1);   filter: drop-shadow(0 0 0 rgba(106,168,217,0)); }
}

/* ===== Kassenbuch / Ledger ===== */
.ledger-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: .5rem;
    margin-bottom: .75rem;
}
.ledger-scroll {
    max-height: 420px;
    overflow-y: auto;
    border: 1px solid var(--panel-2);
    border-radius: 6px;
}
.ledger-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
}
.ledger-table thead {
    position: sticky;
    top: 0;
    background: var(--panel-2);
    z-index: 1;
}
.ledger-table th, .ledger-table td {
    padding: .35em .6em;
    text-align: left;
    border-bottom: 1px solid var(--panel-2);
}
.ledger-table .ledger-amount,
.ledger-table .ledger-balance { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.ledger-table tr.ledger-in  .ledger-amount { color: var(--ok, #4ade80); font-weight: 600; }
.ledger-table tr.ledger-out .ledger-amount { color: var(--danger, #f87171); font-weight: 600; }
.ledger-in  { color: var(--ok, #4ade80) !important; }
.ledger-out { color: var(--danger, #f87171) !important; }

/* Less prominent Leave button inside profile */
.profile-actions {
    margin-top: .75rem;
    padding-top: .75rem;
    border-top: 1px dashed var(--panel-2);
    display: flex;
    justify-content: flex-end;
}
.profile-actions .btn--ghost {
    opacity: .7;
    background: transparent;
    color: var(--ink-dim);
    border: 1px solid var(--panel-2);
}
.profile-actions .btn--ghost:hover { opacity: 1; color: var(--danger); border-color: var(--danger); }

/* Password recovery */
.auth-hint { font-size: .85rem; color: var(--ink-dim); margin: 0 0 .6em; text-align: center; line-height: 1.35; }
.auth-success {
    background: rgba(76, 175, 80, .15);
    color: var(--ok, #6c6);
    border: 1px solid rgba(76, 175, 80, .35);
    padding: .55em .7em;
    border-radius: 6px;
    font-size: .85rem;
    margin-bottom: .5em;
}
.auth-actions { display: flex; flex-wrap: wrap; gap: .4em; justify-content: center; margin-top: .2em; }
.auth-actions .btn { flex: 1 1 45%; font-size: .82rem; padding: .4em .5em; }
.recovery-reveal { max-width: 440px; }
.recovery-reveal h2 { color: var(--accent); font-size: 1.15rem; font-weight: 600; }
.recovery-code {
    font-family: 'SFMono-Regular', Menlo, Consolas, monospace;
    font-size: 1.35rem;
    letter-spacing: .08em;
    background: var(--panel-2);
    color: var(--accent);
    padding: .8em 1em;
    text-align: center;
    border-radius: 8px;
    margin: .6em 0;
    user-select: all;
    border: 1px dashed var(--accent);
    word-break: break-all;
}

/* ============================================================ */
/* S13 Delft — New IA components                                */
/* ============================================================ */

/* Top-bar avatar button (opens ProfileModal) */
.topbar-avatar {
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--panel-3); color: var(--ink);
    border: 1px solid var(--border-strong);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.1rem; cursor: pointer; transition: background .15s, border-color .15s;
    padding: 0;
}
.topbar-avatar:hover { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* ActionBar — sticky strip under topbar */
.actionbar {
    position: sticky; top: 64px; z-index: 30;
    background: var(--panel);
    border-bottom: 1px solid var(--border);
    padding: var(--sp-2) var(--sp-3);
    display: flex; gap: var(--sp-2);
    overflow-x: auto; overflow-y: hidden;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}
.actionbar:empty { display: none; }
.actionbar__chip {
    flex: 0 0 auto;
    background: var(--panel-2); color: var(--ink);
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    padding: var(--sp-2) var(--sp-3);
    font: inherit; font-size: .85rem;
    cursor: pointer;
    display: inline-flex; gap: var(--sp-2); align-items: center;
    transition: background .15s, border-color .15s, transform .1s;
    white-space: nowrap;
}
.actionbar__chip:hover { background: var(--panel-3); border-color: var(--accent); }
.actionbar__chip:active { transform: translateY(1px); }
.actionbar__chip--urgent { border-color: var(--warn); color: var(--warn); }
.actionbar__chip--ready  { border-color: var(--ok); color: var(--ok); }
.actionbar__chip .chip-count {
    background: var(--accent); color: var(--accent-ink);
    border-radius: 999px; padding: 0 .5em; font-weight: 700; font-size: .75em;
}

/* ProfileModal — full-overlay, nav + content */
.profile-modal-root {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.6);
    z-index: 2000;
    display: flex; align-items: center; justify-content: center;
    padding: var(--sp-4);
}
.profile-modal-root[hidden] { display: none; }
.profile-modal__card {
    background: var(--panel);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-strong);
    width: 100%; max-width: 920px;
    height: min(88vh, 720px);
    display: grid; grid-template-columns: 200px 1fr;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,.6);
}
.profile-modal__nav {
    background: var(--panel-2);
    border-right: 1px solid var(--border);
    padding: var(--sp-3);
    display: flex; flex-direction: column; gap: var(--sp-1);
    overflow-y: auto;
}
.profile-modal__nav button {
    background: transparent; color: var(--ink-dim);
    border: none; border-radius: 6px;
    padding: .6em .8em; text-align: left; cursor: pointer;
    font: inherit; font-size: .9rem;
    transition: background .1s, color .1s;
}
.profile-modal__nav button:hover { background: var(--panel-3); color: var(--ink); }
.profile-modal__nav button.is-active {
    background: var(--accent); color: var(--accent-ink); font-weight: 600;
}
.profile-modal__body {
    padding: var(--sp-4); overflow-y: auto;
    position: relative;
}
.profile-modal__close {
    position: absolute; top: var(--sp-3); right: var(--sp-3);
    background: var(--panel-3); color: var(--ink);
    border: none; border-radius: 50%; width: 32px; height: 32px;
    cursor: pointer; font-size: 1.1rem;
}
.profile-modal__close:hover { background: var(--danger); color: #fff; }
@media (max-width: 720px) {
    .profile-modal-root { padding: 0; }
    .profile-modal__card { border-radius: 0; height: 100vh; max-width: 100%; grid-template-columns: 1fr; grid-template-rows: auto 1fr; }
    .profile-modal__nav { flex-direction: row; overflow-x: auto; border-right: none; border-bottom: 1px solid var(--border); padding: var(--sp-2); }
    .profile-modal__nav button { white-space: nowrap; }
}

/* QuestDrawer — right-side slide-in */
.quest-drawer {
    position: fixed; top: 0; right: 0; bottom: 0;
    width: 340px; max-width: 90vw;
    background: var(--panel);
    border-left: 1px solid var(--border-strong);
    box-shadow: -8px 0 30px rgba(0,0,0,.5);
    transform: translateX(100%);
    transition: transform .25s ease-out;
    z-index: 1500;
    display: flex; flex-direction: column;
}
.quest-drawer--open { transform: translateX(0); }
.quest-drawer__head {
    padding: var(--sp-3) var(--sp-4);
    border-bottom: 1px solid var(--border);
    display: flex; justify-content: space-between; align-items: center;
}
.quest-drawer__head h2 { margin: 0; font-size: 1.1rem; }
.quest-drawer__close {
    background: transparent; border: none; color: var(--ink-dim);
    font-size: 1.3rem; cursor: pointer;
}
.quest-drawer__close:hover { color: var(--ink); }
.quest-drawer__body {
    padding: var(--sp-3) var(--sp-4);
    overflow-y: auto; flex: 1;
}
.quest-drawer__empty { color: var(--ink-faint); font-style: italic; padding: var(--sp-4) 0; text-align: center; }
@media (max-width: 720px) {
    .quest-drawer { width: 100vw; max-width: 100vw; }
}

/* Quest drawer toggle button (floating, above bottom-nav on mobile) */
.quest-drawer-toggle {
    background: var(--panel-3); color: var(--ink);
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    padding: .4em .8em; cursor: pointer;
    font: inherit; font-size: .85rem;
    display: inline-flex; gap: .3em; align-items: center;
}
.quest-drawer-toggle:hover { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }

/* 5-Button BottomNav (mobile only) */
.bottom-nav {
    display: none;
    position: fixed; bottom: 0; left: 0; right: 0;
    background: var(--panel);
    border-top: 1px solid var(--border-strong);
    z-index: 40;
    padding-bottom: env(safe-area-inset-bottom, 0);
}
.bottom-nav__inner {
    display: grid; grid-template-columns: repeat(5, 1fr);
}
.bottom-nav button {
    background: transparent; color: var(--ink-dim);
    border: none; padding: .55em .2em .5em;
    cursor: pointer;
    display: flex; flex-direction: column; align-items: center; gap: 2px;
    font: inherit; font-size: .65rem;
    border-top: 2px solid transparent;
}
.bottom-nav button .bn-icon { font-size: 1.3rem; line-height: 1; }
.bottom-nav button.is-active {
    color: var(--accent);
    border-top-color: var(--accent);
    background: var(--panel-2);
}
@media (max-width: 720px) {
    .bottom-nav { display: block; }
    body { padding-bottom: 64px; }
}

/* Card state strips */
.card--state-ready    { box-shadow: inset 0 3px 0 0 var(--ok); }
.card--state-warn     { box-shadow: inset 0 3px 0 0 var(--warn); }
.card--state-neutral  { box-shadow: inset 0 3px 0 0 var(--border-strong); }
.card--state-danger   { box-shadow: inset 0 3px 0 0 var(--danger); }

/* Hide the legacy meta-tabs DOM — replaced by ProfileModal */
.meta-tabs.is-replaced, .game-meta.is-replaced { display: none !important; }

/* ---- S13b: Generic Content-Drawer (für Markt/Bank/Plantagen/… ) ---- */
.content-drawer {
    position: fixed; top: 0; right: 0; bottom: 0;
    width: 520px; max-width: 95vw;
    background: var(--panel);
    border-left: 1px solid var(--border-strong);
    box-shadow: -8px 0 30px rgba(0,0,0,.5);
    transform: translateX(100%);
    transition: transform .25s ease-out;
    z-index: 1400;
    display: flex; flex-direction: column;
}
.content-drawer--open { transform: translateX(0); }
.content-drawer__head {
    padding: var(--sp-3) var(--sp-4);
    border-bottom: 1px solid var(--border);
    display: flex; justify-content: space-between; align-items: center;
    background: var(--panel-2);
}
.content-drawer__head h2 { margin: 0; font-size: 1.15rem; color: var(--ink); }
.content-drawer__close {
    background: transparent; border: none; color: var(--ink-dim);
    font-size: 1.4rem; cursor: pointer; padding: 0 .4em;
}
.content-drawer__close:hover { color: var(--ink); }
.content-drawer__body {
    padding: var(--sp-3) var(--sp-4);
    overflow-y: auto; flex: 1;
}
@media (max-width: 720px) {
    .content-drawer { width: 100vw; max-width: 100vw; }
}

/* Drawer-Backdrop */
.drawer-backdrop {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.45);
    z-index: 1300;
}
.drawer-backdrop[hidden] { display: none; }

/* Hub-Grid: große Buttons in Wirtschaft-Tab */
.hub-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: var(--sp-3);
    margin: var(--sp-4) 0;
}
.hub-btn {
    background: var(--panel-2);
    border: 1px solid var(--border-strong);
    color: var(--ink);
    padding: var(--sp-4) var(--sp-3);
    border-radius: var(--radius-lg);
    cursor: pointer;
    display: flex; flex-direction: column; align-items: center; gap: .4em;
    font: inherit;
    transition: background .15s, border-color .15s, transform .1s;
    position: relative;
}
.hub-btn:hover { background: var(--panel-3); border-color: var(--accent); transform: translateY(-2px); }
.hub-btn:active { transform: translateY(0); }
.hub-btn__icon { font-size: 2rem; line-height: 1; }
.hub-btn__label { font-weight: 600; font-size: .95rem; }
.hub-btn__hint  { font-size: .72rem; color: var(--ink-dim); }
.hub-btn .chip-count {
    position: absolute; top: 8px; right: 8px;
    background: var(--accent); color: var(--accent-ink);
    border-radius: 999px; padding: 0 .5em; font-weight: 700; font-size: .7em;
}
.hub-btn--alert { border-color: var(--warn); }
.hub-btn--alert .chip-count { background: var(--warn); }
.hub-btn--ready { border-color: var(--ok); }
.hub-btn--ready .chip-count { background: var(--ok); color: var(--accent-ink); }
.hub-btn[disabled] { opacity: .4; cursor: not-allowed; }

/* Notification bar */
.notif-bar { display: flex; flex-direction: column; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); }
.notif-bar[hidden] { display: none; }
.notif-item {
    display: flex; gap: var(--sp-2); align-items: center;
    background: var(--panel-2); border: 1px solid var(--border);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius-sm);
    padding: var(--sp-2) var(--sp-3);
    font-size: .9rem;
    animation: notif-slide-in .25s ease-out;
}
.notif--info { border-left-color: var(--info, var(--accent)); }
.notif--ok { border-left-color: var(--ok); }
.notif--warn { border-left-color: var(--warn); }
.notif--danger { border-left-color: var(--danger); }
.notif-icon { font-size: 1.1rem; flex-shrink: 0; }
.notif-text { flex: 1; color: var(--ink); }
.notif-dismiss {
    background: transparent; border: none; color: var(--ink-dim);
    font-size: 1.1rem; cursor: pointer; padding: 0 .3em;
    line-height: 1;
}
.notif-dismiss:hover { color: var(--ink); }
@keyframes notif-slide-in {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Compact Market Grid */
.market-summary {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: var(--sp-2) var(--sp-3);
    border-bottom: 1px solid var(--border);
    margin-bottom: var(--sp-2);
}
.market-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 6px;
    padding: 0 6px 8px;
}
.mk-card {
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 6px 8px;
    display: flex; flex-direction: column; gap: 4px;
    font-size: .85rem;
}
.mk-card--owned { border-left: 3px solid var(--accent); }
.mk-row1 { display: flex; align-items: center; gap: .4em; }
.mk-row2 { display: flex; justify-content: space-between; align-items: center; gap: .3em; min-height: 20px; }
.mk-name { font-weight: 600; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mk-price { font-size: 1rem; font-weight: 700; color: var(--accent); white-space: nowrap; }
.mk-trend { font-size: .68rem; font-weight: 600; padding: 0 .35em; border-radius: 999px; background: var(--panel-3); color: var(--ink-dim); }
.mk-trend--up   { background: color-mix(in srgb, var(--ok) 25%, transparent); color: var(--ok); }
.mk-trend--down { background: color-mix(in srgb, var(--danger) 25%, transparent); color: var(--danger); }
.mk-spark { opacity: .8; flex-shrink: 0; }
.mk-meta-line { color: var(--ink-dim); font-size: .72rem; }
.mk-best { display: block; color: var(--ink-dim); font-size: .7rem; line-height: 1.3; }
.mk-actions {
    display: grid;
    grid-template-areas:
        "qty   buy   sell"
        "max   all   all";
    grid-template-columns: 3.6em 1fr 1fr;
    gap: 4px;
    margin-top: 4px;
    align-items: center;
}
.mk-actions .mk-qty     { grid-area: qty; }
.mk-actions .buy-btn    { grid-area: buy; }
.mk-actions .sell-btn   { grid-area: sell; }
.mk-actions .market-max { grid-area: max; }
.mk-actions .market-all { grid-area: all; }
.mk-actions .btn {
    padding: 4px 6px;
    font-size: .75rem;
    min-height: 28px;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mk-qty {
    width: 100%;
    padding: 4px 6px;
    font-size: .85rem;
    min-width: 0;
    box-sizing: border-box;
}
@media (max-width: 600px) {
    .market-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 4px; padding: 0 4px 6px; }
    .mk-card { padding: 5px 6px; gap: 3px; }
    .mk-actions .btn { min-height: 32px; padding: 4px 4px; }
    .mk-qty { padding: 4px; }
}
.chip--tight { padding: 0 .4em; font-size: .7rem; }
@media (max-width: 520px) {
    .market-grid { grid-template-columns: 1fr; }
}

/* Stocks & Art shared classes */
.pl-ok  { color: var(--ok); }
.pl-bad { color: var(--danger); }

.stocks-summary, .art-summary {
    display: flex; flex-wrap: wrap; gap: var(--sp-3);
    background: var(--panel-2); border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: var(--sp-2) var(--sp-3); margin-bottom: var(--sp-2);
}
.stocks-summary > div, .art-summary > div {
    display: flex; flex-direction: column; gap: 2px;
}
.stocks-summary small, .art-summary small { color: var(--ink-dim); font-size: .7rem; text-transform: uppercase; letter-spacing: .05em; }
.stocks-summary strong, .art-summary strong { font-size: 1rem; }

.stocks-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--sp-2);
}
.stk-card {
    background: var(--panel-2); border: 1px solid var(--border);
    border-radius: var(--radius-sm); padding: var(--sp-2);
    display: flex; flex-direction: column; gap: .3em;
    font-size: .9rem;
}
.stk-card--owned { border-left: 3px solid var(--accent); }
.stk-own { display: flex; flex-direction: column; gap: 2px; min-height: 2.4em; }
.stk-short-line { color: var(--warn); }
.stk-actions { display: grid; grid-template-columns: 3em 1fr 1fr 1fr 1fr; gap: .25em; align-items: center; margin-top: .3em; }
.stk-actions .btn { padding: .3em .4em; font-size: .78rem; }

/* Art cards */
.art-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--sp-2);
}
.art-card { padding: var(--sp-2); display: flex; flex-direction: column; gap: .3em; }
.art-card--displayed { border-left: 3px solid var(--ok); }
.art-card__head { display: flex; justify-content: space-between; align-items: center; gap: .4em; }
.art-card__artist { color: var(--ink-dim); font-style: italic; }
.art-card__values { display: flex; flex-direction: column; gap: 2px; padding: .3em 0; border-top: 1px dashed var(--border); border-bottom: 1px dashed var(--border); }
.art-card__actions { display: flex; gap: .3em; flex-wrap: wrap; }

@media (max-width: 520px) {
    .stocks-grid, .art-grid { grid-template-columns: 1fr; }
    .stk-actions { grid-template-columns: 3em 1fr 1fr; }
    .stk-actions .stk-short, .stk-actions .stk-cover { grid-column: span 1; }
}

/* Bank panel */
.bank-panel { display: flex; flex-direction: column; gap: var(--sp-3); padding: var(--sp-2); }
.bank-block {
    background: var(--panel-2); border: 1px solid var(--border);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius-sm);
    padding: var(--sp-3);
    display: flex; flex-direction: column; gap: var(--sp-1);
}
.bank-block--warn  { border-left-color: var(--warn); }
.bank-block--alert { border-left-color: var(--danger); }
.bank-block__head { display: flex; justify-content: space-between; align-items: center; gap: .5em; flex-wrap: wrap; }
.bank-stat { font-size: 1.4rem; font-weight: 700; color: var(--accent); }
.bank-stat small { font-size: .7rem; font-weight: 400; color: var(--ink-dim); margin-left: .3em; }
.bank-hint { color: var(--ink-dim); line-height: 1.4; }
.bank-actions { display: flex; gap: .4em; flex-wrap: wrap; align-items: center; margin-top: var(--sp-1); }
.bank-actions input { flex: 1 1 8em; min-width: 8em; padding: .4em; }

/* City overlay (anchored to map node) */
.world-map-wrap { position: relative; }
.city-overlay {
    position: absolute;
    width: 280px; max-height: 80%;
    overflow-y: auto;
    background: var(--panel);
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    box-shadow: 0 8px 24px rgba(0,0,0,.55);
    padding: var(--sp-2) var(--sp-3);
    z-index: 50;
    color: var(--ink);
    font-size: .85rem;
    animation: co-pop .15s ease-out;
}
.city-overlay[hidden] { display: none; }
@keyframes co-pop { from { opacity: 0; transform: scale(.95); } to { opacity: 1; transform: scale(1); } }
.co-head { display: flex; justify-content: space-between; align-items: flex-start; gap: .5em; margin-bottom: var(--sp-1); }
.co-head strong { font-size: 1.05rem; color: var(--accent); display: block; }
.co-head small { color: var(--ink-dim); font-size: .72rem; }
.co-close {
    background: transparent; border: none; color: var(--ink-dim);
    font-size: 1.3rem; cursor: pointer; line-height: 1; padding: 0 .2em;
}
.co-close:hover { color: var(--ink); }
.co-meta { display: flex; flex-wrap: wrap; gap: .3em; margin-bottom: var(--sp-2); align-items: center; }
.co-row { margin-top: var(--sp-2); }
.co-row strong { display: block; font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-dim); margin-bottom: .3em; }
.co-tabs, .co-npcs { display: flex; flex-wrap: wrap; gap: .25em; }
.co-goods { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.co-goods li { display: flex; justify-content: space-between; align-items: center; padding: .15em .3em; border-radius: 3px; }
.co-goods li:nth-child(odd) { background: var(--panel-2); }
.co-foot { margin-top: var(--sp-3); }
.co-action { width: 100%; }
@media (max-width: 600px) {
    .city-overlay {
        position: fixed;
        left: 8px !important; right: 8px; top: 50% !important;
        width: auto; transform: translateY(-50%);
        max-height: 70vh;
    }
}

/* Inventory overview */
.inventar-panel { display: flex; flex-direction: column; gap: var(--sp-3); padding: var(--sp-2); }
.inv-summary {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--sp-2);
    background: var(--panel-2); border: 1px solid var(--border);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius-sm); padding: var(--sp-3);
}
.inv-summary > div { display: flex; flex-direction: column; gap: 2px; }
.inv-summary small { color: var(--ink-dim); font-size: .68rem; text-transform: uppercase; letter-spacing: .05em; }
.inv-summary strong { font-size: 1.05rem; }
.inv-section h4 { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-dim); margin: 0 0 .5em 0; }
.inv-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.inv-table th, .inv-table td { padding: .4em .5em; text-align: left; border-bottom: 1px solid var(--border); }
.inv-table th { font-size: .7rem; text-transform: uppercase; color: var(--ink-dim); letter-spacing: .05em; }
.inv-table .inv-num { text-align: right; white-space: nowrap; }
.inv-table .inv-extra { font-size: .75rem; }
.inv-row--owned { background: color-mix(in srgb, var(--accent) 8%, transparent); }
.inv-row td { vertical-align: middle; }
.inv-good { font-weight: 600; }
.inv-ships { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .3em; }
.inv-ships li { padding: .3em .5em; background: var(--panel-2); border-radius: var(--radius-sm); border-left: 2px solid var(--accent); }
.inv-ships li small { display: block; color: var(--ink-dim); font-size: .75rem; margin-top: 2px; }
.inv-art-summary { display: flex; flex-wrap: wrap; gap: var(--sp-3); }
.inv-art-summary > span { display: flex; flex-direction: column; gap: 2px; }
.inv-art-summary small { color: var(--ink-dim); font-size: .68rem; text-transform: uppercase; }
@media (max-width: 600px) {
    .inv-table th:nth-child(5), .inv-table td:nth-child(5),
    .inv-table th:nth-child(6), .inv-table td:nth-child(6) { display: none; }
}

/* Map tokens (Delft Blue maritime) */
.world-map {
    --ocean: #0a1828;
    --ocean-light: #173249;
    --land: url(#landGrad);
    --land-edge: #5a7d66;
    --route: #6aa8d9;
    --port: #d9824a;
    --lat: rgba(170, 200, 230, 0.12);
    --lat-ink: rgba(170, 200, 230, 0.5);
    width: 100%; height: auto; display: block;
    border-radius: var(--radius-sm);
    background: var(--ocean);
}
.wm-node { cursor: pointer; }
.wm-node__hit { pointer-events: all; }
.wm-node__dot { transition: r .15s, fill .15s; }
.wm-node:hover .wm-node__dot { r: 9; fill: var(--accent); }
.wm-node:hover .wm-node__label { fill: #fff; }
.wm-node__label {
    fill: #f0e6d6;
    paint-order: stroke;
    stroke: rgba(0,0,0,0.85);
    stroke-width: 2.5px;
    stroke-linejoin: round;
    transition: fill .15s;
}
.wm-node__cost {
    fill: var(--accent);
    paint-order: stroke;
    stroke: rgba(0,0,0,0.7);
    stroke-width: 2px;
    stroke-linejoin: round;
}
.wm-here .wm-node__dot { fill: var(--accent); }
.wm-here .wm-node__label { fill: #fff; }
.wm-locked { opacity: .35; cursor: not-allowed; }
.wm-click .wm-node__dot { animation: wm-pulse .7s ease-out; }
@keyframes wm-pulse { 0%{r:9;} 50%{r:14;} 100%{r:7;} }
.world-map-wrap { background: var(--panel-2); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: var(--sp-1); }
.world-map-hint { display: block; margin-top: var(--sp-1); padding: 0 var(--sp-2); color: var(--ink-dim); }

/* Plantation new layout */
.pf-section { margin-bottom: var(--sp-3); }
.pf-section h4 { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-dim); margin: 0 0 .5em; }
.plant-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--sp-2); }
.plant-card--owned { border-left: 3px solid var(--ok); }
.plant-card--buy { border-left: 3px solid var(--accent); }
.pf-head { display: flex; justify-content: space-between; align-items: center; gap: .4em; margin-bottom: .3em; }
.pf-meta { color: var(--ink-dim); margin-bottom: .4em; }
.pf-fields { display: flex; flex-wrap: wrap; gap: .3em; margin-bottom: .5em; }
.pf-field {
    flex: 1 1 60px; min-width: 50px;
    background: var(--panel-3);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: .3em .35em;
    display: flex; flex-direction: column; gap: .2em; align-items: center;
}
.pf-field--ready { background: color-mix(in srgb, var(--ok) 20%, var(--panel-3)); border-color: var(--ok); animation: pf-ready-pulse 2s infinite; }
@keyframes pf-ready-pulse { 0%,100%{box-shadow:0 0 0 0 rgba(110,200,140,0)} 50%{box-shadow:0 0 0 4px rgba(110,200,140,.25)} }
.pf-field__icon { font-size: 1.1rem; line-height: 1; }
.pf-field__bar { width: 100%; height: 4px; background: var(--panel); border-radius: 2px; overflow: hidden; }
.pf-field__fill { height: 100%; background: var(--accent); transition: width .3s; }
.pf-bucket { display: flex; gap: .4em; align-items: center; margin-bottom: .4em; flex-wrap: wrap; }
.pf-actions { display: flex; gap: .3em; }
.pf-elsewhere { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .3em; }
.pf-elsewhere li { padding: .4em .6em; background: var(--panel-2); border-radius: var(--radius-sm); border-left: 2px solid var(--accent); }
.pf-elsewhere li small { display: block; color: var(--ink-dim); margin-top: 2px; }

/* Fleet new layout */
.fleet-buy { display: flex; gap: .4em; margin-bottom: var(--sp-2); flex-wrap: wrap; align-items: center; }
.fleet-buy select { flex: 1 1 220px; padding: .4em; }
.fleet-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--sp-2); }
.ship-head { display: flex; justify-content: space-between; align-items: center; gap: .3em; margin-bottom: .3em; flex-wrap: wrap; }
.ship-card--docked { border-left: 3px solid var(--accent); }
.ship-card--moving { border-left: 3px solid var(--info, var(--accent)); }
.ship-dispatch-row { display: flex; flex-direction: column; gap: .3em; margin: .4em 0; }
.ship-dispatch-pick { width: 100%; padding: .4em; font-size: .85rem; }
.ship-auto-toggle { display: flex; align-items: center; gap: .4em; font-size: .85rem; color: var(--ink-dim); }

/* Buildings */
.building-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: var(--sp-2); }
.building-card { display: flex; flex-direction: column; gap: .35em; }
.building-card--owned { border-left: 3px solid var(--ok); }
.bld-head { display: flex; justify-content: space-between; align-items: center; gap: .3em; }
.bld-desc { color: var(--ink-dim); }
.bld-effect { color: var(--accent); font-weight: 500; }

/* Allow city overlay to extend slightly past the map area when needed */
.world-map-wrap { overflow: visible !important; }
.city-overlay { max-height: 80vh; }

/* ---- Pferderennen ---- */
.game-race { display: flex; flex-direction: column; gap: var(--sp-2); padding: var(--sp-2); }
.race-head { display: flex; justify-content: space-between; align-items: center; gap: .4em; }

.race-track {
    position: relative;
    background: linear-gradient(180deg, #2a3a4a 0%, #1a2530 100%);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: var(--sp-2);
    height: 180px;
    overflow: hidden;
}
.race-lane {
    position: relative;
    height: 36px;
    margin: 4px 0;
    display: flex; align-items: center;
    border-bottom: 1px dashed rgba(170,200,230,0.15);
}
.race-lane-bg {
    position: absolute; inset: 0;
    background: repeating-linear-gradient(90deg, transparent 0 38px, rgba(255,255,255,0.05) 38px 40px);
}
.race-runner {
    position: absolute;
    left: 0;
    font-size: 1.6rem;
    transition: left .3s linear;
    z-index: 2;
}
.race-track--running .race-runner {
    animation: race-run var(--dur, 10s) cubic-bezier(.35,.1,.65,.9) forwards;
}
@keyframes race-run {
    0%   { left: 0; }
    100% { left: calc(100% - 36px); }
}
.race-lane-name {
    position: absolute;
    right: 8px; top: 50%; transform: translateY(-50%);
    color: var(--ink-dim);
    font-size: .75rem;
    background: rgba(0,0,0,.4);
    padding: 1px 6px;
    border-radius: 4px;
    z-index: 1;
}
.race-track-finish {
    position: absolute;
    top: 0; right: 4px; bottom: 0;
    width: 24px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    background: repeating-linear-gradient(0deg, #fff 0 8px, #000 8px 16px);
    background-clip: padding-box;
    opacity: .35;
}

.race-horses-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--sp-2);
}
.race-horse-card {
    display: flex; flex-direction: column; align-items: flex-start; gap: 3px;
    background: var(--panel-2);
    border: 2px solid var(--border);
    border-radius: var(--radius-sm);
    padding: var(--sp-2);
    cursor: pointer;
    transition: border-color .15s, transform .1s;
}
.race-horse-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.race-horse-card input { margin-right: .3em; }
.race-horse-card:has(input:checked) {
    border-color: var(--accent);
    background: color-mix(in srgb, var(--accent) 12%, var(--panel-2));
}
.race-horse-card--mine { border-color: var(--accent) !important; background: color-mix(in srgb, var(--accent) 18%, var(--panel-2)) !important; }
.race-horse-card--locked { opacity: .55; cursor: not-allowed; }
.race-horse-emoji { font-size: 1.6rem; }

.race-bet-row {
    display: flex; gap: .5em; align-items: center; flex-wrap: wrap;
    background: var(--panel-2); padding: var(--sp-2);
    border-radius: var(--radius-sm); border: 1px solid var(--border);
}
.race-bet-row label { display: flex; align-items: center; gap: .3em; }
.race-bet-row input[type=number] { width: 6em; padding: .35em; }
.race-mybet {
    background: var(--panel-2); padding: var(--sp-2);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius-sm);
}
.race-mybet small { display: block; color: var(--ink-dim); margin-top: .3em; }
.race-hint { color: var(--ink-dim); }

.race-result-head {
    display: flex; justify-content: space-between; align-items: center;
    padding: var(--sp-3);
    background: var(--panel-2);
    border-left: 4px solid var(--info, var(--accent));
    border-radius: var(--radius-sm);
    font-size: 1.1rem;
}
.race-result--win  { border-left-color: var(--ok); background: color-mix(in srgb, var(--ok) 12%, var(--panel-2)); animation: race-win-flash .8s ease-out 2; }
.race-result--lose { border-left-color: var(--danger); background: color-mix(in srgb, var(--danger) 8%, var(--panel-2)); }
@keyframes race-win-flash { 0%,100%{box-shadow:none} 50%{box-shadow:0 0 0 6px rgba(110,200,140,.35)} }
.race-podium { padding-left: 1.4em; margin: var(--sp-2) 0; }
.race-podium li { padding: 2px 0; }
.race-podium--winner { font-weight: bold; color: var(--ok); }

/* Ship details (collapsible upgrades/repair/sell block) */
.ship-details { margin-top: var(--sp-2); border-top: 1px dashed var(--border); padding-top: var(--sp-2); }
.ship-details summary { cursor: pointer; color: var(--ink-dim); font-size: .85rem; padding: 4px 0; user-select: none; }
.ship-details summary:hover { color: var(--accent); }
.ship-details-body { display: flex; flex-direction: column; gap: var(--sp-2); margin-top: var(--sp-2); }
.ship-condition { display: flex; flex-direction: column; gap: 4px; }
.ship-condition .progress { height: 6px; }
.ship-upgrades { display: flex; flex-direction: column; gap: 6px; }
.ship-upg-row {
    display: flex; justify-content: space-between; align-items: center;
    gap: 8px; flex-wrap: wrap;
    background: var(--panel-2); padding: 6px 8px;
    border-radius: 4px;
    font-size: .82rem;
}
.ship-upg-row strong { color: var(--ink); }
.ship-upg-row small { color: var(--ink-dim); }
.ship-upg-row .btn { white-space: nowrap; }

/* Market: chart button (clickable sparkline) */
.mk-chart-btn {
    background: transparent;
    border: 1px solid transparent;
    border-radius: 4px;
    padding: 2px 4px;
    cursor: pointer;
    line-height: 0;
}
.mk-chart-btn:hover { background: var(--panel-3); border-color: var(--accent); }

/* Price chart modal */
.chart-modal {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    display: flex; align-items: center; justify-content: center;
    z-index: 200;
    padding: var(--sp-3);
    animation: chart-fade .15s ease-out;
}
@keyframes chart-fade { from{opacity:0} to{opacity:1} }
.chart-modal__card {
    background: var(--panel);
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    box-shadow: 0 12px 32px rgba(0,0,0,.6);
    width: 100%; max-width: 560px;
    max-height: 90vh; overflow: auto;
}
.chart-modal__head {
    display: flex; justify-content: space-between; align-items: center;
    padding: var(--sp-2) var(--sp-3);
    border-bottom: 1px solid var(--border);
}
.chart-modal__head strong { color: var(--accent); font-size: 1.05rem; }
.chart-modal__close {
    background: transparent; border: none; color: var(--ink-dim);
    font-size: 1.4rem; cursor: pointer; line-height: 1; padding: 0 .3em;
}
.chart-modal__close:hover { color: var(--ink); }
.chart-modal__body { padding: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-2); }
.chart-stat { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.chart-stat > span { display: flex; flex-direction: column; gap: 2px; }
.chart-stat small { color: var(--ink-dim); font-size: .68rem; text-transform: uppercase; letter-spacing: .05em; }
.chart-stat strong { font-size: 1rem; }

/* Profit/loss color helpers (used in inventory + chart) */
.pl-ok  { color: var(--ok); }
.pl-bad { color: var(--danger); }

/* Rank chip in topbar */
.rank-chip {
    display: inline-flex; align-items: center; gap: .35em;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 25%, var(--panel-2)), var(--panel-2));
    border: 1px solid var(--accent);
    border-radius: 999px;
    padding: .25em .7em;
    color: var(--ink);
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    transition: transform .1s, box-shadow .15s;
}
.rank-chip:hover { transform: translateY(-1px); box-shadow: 0 2px 8px rgba(0,0,0,.4); }
.rank-chip span { font-weight: 600; }

/* Rank panel in profile modal */
.rank-panel { display: flex; flex-direction: column; gap: var(--sp-3); }
.rank-head { display: flex; align-items: center; gap: var(--sp-3); }
.rank-icon { font-size: 3rem; line-height: 1; }
.rank-head h2 { margin: 0; color: var(--accent); }
.rank-head small { color: var(--ink-dim); }
.rank-bonuses { display: flex; gap: .5em; flex-wrap: wrap; }
.rank-progress { display: flex; flex-direction: column; gap: .4em; }
.rank-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.rank-list li {
    display: grid; grid-template-columns: 36px 1fr auto; gap: 8px;
    align-items: center;
    padding: .5em .8em;
    background: var(--panel-2);
    border-radius: var(--radius-sm);
    border-left: 3px solid transparent;
    opacity: .55;
}
.rank-list--reached { opacity: 1; border-left-color: var(--ink-dim); }
.rank-list--current { border-left-color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, var(--panel-2)); opacity: 1; box-shadow: 0 0 0 1px var(--accent); }
.rank-list__icon { font-size: 1.4rem; text-align: center; }
.rank-list__name { font-weight: 600; }
.rank-list small { color: var(--ink-dim); font-size: .72rem; }

/* Drawer: suppress slide-in animation when re-mounting after a state update */
.content-drawer.content-drawer--no-anim,
.content-drawer.content-drawer--no-anim * { transition: none !important; animation: none !important; }

/* Day-remaining label */
.day-remaining { color: var(--ink-dim); font-variant-numeric: tabular-nums; }
.day-remaining--urgent { color: var(--danger); font-weight: 600; }

/* Wealth chip in topbar */
.wealth-chip {
    display: inline-flex; align-items: center; gap: .3em;
    background: var(--panel-2);
    border: 1px solid var(--accent-2);
    border-radius: 999px;
    padding: .25em .7em;
    color: var(--ink);
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    margin-left: .5em;
    font-variant-numeric: tabular-nums;
}
.wealth-chip:hover { background: var(--panel-3); border-color: var(--accent); }

/* Finance drawer (Vermögen + Kassenbuch tabs) */
.fin-tabs { display: flex; flex-direction: column; gap: var(--sp-2); }
.fin-tabbar { display: flex; gap: 4px; padding: 4px; background: var(--panel-2); border-radius: var(--radius-sm); }
.fin-tabbar button {
    flex: 1; padding: 6px 10px;
    background: transparent; border: 1px solid transparent;
    color: var(--ink-dim); font-weight: 600; cursor: pointer;
    border-radius: 4px;
}
.fin-tabbar button.is-active { background: var(--panel); color: var(--accent); border-color: var(--accent); }

/* Wealth panel */
.wealth-panel { display: flex; flex-direction: column; gap: var(--sp-2); padding: var(--sp-2); }
.wealth-head {
    display: flex; justify-content: space-between; align-items: baseline;
    background: var(--panel-2); padding: var(--sp-3);
    border-radius: var(--radius-sm); border-left: 3px solid var(--accent);
}
.wealth-head small { display: block; color: var(--ink-dim); font-size: .7rem; text-transform: uppercase; letter-spacing: .05em; }
.wealth-total { font-size: 1.7rem; font-weight: 700; color: var(--accent); font-variant-numeric: tabular-nums; }
.wealth-stack {
    display: flex; height: 14px; overflow: hidden; border-radius: 4px;
    background: var(--panel-3);
}
.wealth-stack__seg { display: block; height: 100%; transition: width .3s; }
.wealth-stack__seg:hover { filter: brightness(1.2); }
.wealth-legend { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.wealth-legend li {
    display: grid;
    grid-template-columns: 14px 1fr auto auto;
    gap: 8px; align-items: center;
    padding: 4px 8px; background: var(--panel-2); border-radius: 4px;
    font-size: .85rem;
}
.wealth-legend--debt { background: color-mix(in srgb, var(--danger) 12%, var(--panel-2)); }
.wealth-legend__sw { width: 12px; height: 12px; border-radius: 3px; }
.wealth-legend__lbl { color: var(--ink); }
.wealth-legend small { color: var(--ink-dim); }
.wealth-section summary {
    cursor: pointer; padding: 8px; background: var(--panel-2); border-radius: 4px;
    color: var(--ink-dim); font-weight: 600; user-select: none;
}
.wealth-section[open] summary { color: var(--accent); }
.wealth-table { width: 100%; border-collapse: collapse; margin-top: 6px; font-size: .82rem; }
.wealth-table th, .wealth-table td { padding: 4px 8px; text-align: left; border-bottom: 1px solid var(--border); }
.wealth-table th { color: var(--ink-dim); font-weight: 500; font-size: .7rem; text-transform: uppercase; }
.wealth-table .num { text-align: right; font-variant-numeric: tabular-nums; }

/* Ledger row expand */
.ledger-row { cursor: pointer; }
.ledger-row:hover { background: color-mix(in srgb, var(--accent) 8%, transparent); }
.ledger-row--open { background: color-mix(in srgb, var(--accent) 14%, transparent); }
.ledger-detail-row td { background: var(--panel-3); padding: 8px 12px; border-bottom: 1px solid var(--border); }
.ledger-expand { display: flex; flex-direction: column; gap: 4px; font-size: .82rem; }
.ledger-expand small { color: var(--ink-dim); }
.ledger-detail { color: var(--ink-dim); margin-left: .3em; }

/* Event chip in topbar — clickable */
.event-chip {
    cursor: pointer;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 35%, var(--panel-2)), var(--panel-2));
    border: 1px solid var(--accent);
    color: var(--ink);
    font-weight: 600;
    transition: transform .1s, box-shadow .15s;
    animation: event-pulse 2.5s infinite;
}
.event-chip:hover { transform: translateY(-1px); box-shadow: 0 0 0 2px var(--accent); animation: none; }
@keyframes event-pulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(106,168,217,0); } 50% { box-shadow: 0 0 0 4px rgba(106,168,217,0.25); } }

/* City scene polish — softer building buttons */
.city-scene__sil { display: block; width: 100%; height: 260px; }
@media (max-width: 600px) { .city-scene__sil { height: 220px; } }
.city-building {
    position: absolute; transform: translate(-50%,-50%);
    background: rgba(0,0,0,0.55);
    border: 1px solid rgba(255,255,255,0.18);
    backdrop-filter: blur(2px);
    padding: 4px 8px; border-radius: 6px;
    color: var(--ink); cursor: pointer;
    display: flex; flex-direction: column; align-items: center;
    transition: transform .12s, background .15s, border-color .15s, box-shadow .15s;
    font-size: .72rem;
}
.city-building:hover {
    transform: translate(-50%,-50%) scale(1.1);
    background: rgba(0,0,0,0.8);
    border-color: var(--accent);
    box-shadow: 0 4px 14px rgba(0,0,0,0.7);
}
.city-building__icon { font-size: 1.4rem; line-height: 1; }
.city-building__label { display: block; margin-top: 2px; }

/* Inline help/info blocks (collapsible game-mechanics explanations) */
.info-block {
    background: color-mix(in srgb, var(--accent) 8%, var(--panel-2));
    border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--border));
    border-radius: var(--radius-sm);
    margin: var(--sp-2) 0;
    overflow: hidden;
}
.info-block summary {
    cursor: pointer;
    padding: 8px 12px;
    color: var(--accent);
    font-weight: 600;
    font-size: .88rem;
    user-select: none;
    list-style: none;
}
.info-block summary::marker { display: none; }
.info-block summary::-webkit-details-marker { display: none; }
.info-block summary::before {
    content: '▸ ';
    display: inline-block;
    transition: transform .15s;
}
.info-block[open] summary::before { transform: rotate(90deg); }
.info-block summary:hover { background: color-mix(in srgb, var(--accent) 14%, transparent); }
.info-block__body {
    padding: 0 12px 12px;
    border-top: 1px dashed color-mix(in srgb, var(--accent) 30%, var(--border));
    color: var(--ink);
    font-size: .85rem;
    line-height: 1.5;
}
.info-block__body ul { margin: 8px 0 0; padding-left: 1.2em; }
.info-block__body li { margin-bottom: 4px; }
.info-block__body strong { color: var(--ink); }
.info-block__body em { color: var(--ink-dim); font-style: italic; }

/* Plantation: elsewhere list with courier button on the right */
.pf-elsewhere li {
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.pf-elsewhere li > div { flex: 1; min-width: 0; }
.pf-bucket .plant-courier { font-size: .78rem; }

/* Faktor (Handelsagent) */
.game-factor { display: flex; flex-direction: column; gap: var(--sp-3); padding: var(--sp-2); }
.factor-tiers { display: flex; flex-direction: column; gap: var(--sp-2); }
.factor-tier {
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-left: 3px solid var(--ink-dim);
    border-radius: var(--radius-sm);
    padding: var(--sp-2) var(--sp-3);
    display: flex; flex-direction: column; gap: 4px;
    opacity: .7;
}
.factor-tier--active { opacity: 1; border-left-color: var(--ok); }
.factor-tier--current { border-left-color: var(--accent); background: color-mix(in srgb, var(--accent) 10%, var(--panel-2)); }
.factor-tier header { display: flex; justify-content: space-between; align-items: center; gap: 6px; }
.factor-tier__cost { color: var(--ink-dim); font-size: .85rem; }
.factor-tier__cost strong { color: var(--ink); }

/* Live-Auktions-Banner — prominent, oben fest */
.auct-banner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--sp-2);
    align-items: center;
    padding: var(--sp-2) var(--sp-3);
    margin: 0 var(--sp-2) var(--sp-2);
    border-radius: var(--radius-sm);
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, var(--panel-2)), var(--panel-2));
    border: 2px solid var(--accent);
    box-shadow: 0 4px 16px rgba(0,0,0,.4);
    color: var(--ink);
    animation: auct-pulse 2s infinite;
}
.auct-banner--gold {
    background: linear-gradient(135deg, #4a3a1e, #2a1f12);
    border-color: #d9a64a;
    box-shadow: 0 4px 16px rgba(217,166,74,.35);
}
.auct-banner--premium {
    background: linear-gradient(135deg, #4a1e2a, #2a1218);
    border-color: #d94a76;
    box-shadow: 0 4px 20px rgba(217,74,118,.45);
    animation: auct-pulse-premium 1.5s infinite;
}
@keyframes auct-pulse { 0%,100%{box-shadow:0 4px 16px rgba(0,0,0,.4)} 50%{box-shadow:0 4px 16px rgba(106,168,217,.45)} }
@keyframes auct-pulse-premium { 0%,100%{box-shadow:0 4px 18px rgba(217,74,118,.35)} 50%{box-shadow:0 4px 28px rgba(217,74,118,.7)} }
.auct-banner--ended { opacity: .5; animation: none; }

.auct-banner__left { display: flex; align-items: center; gap: 10px; min-width: 0; }
.auct-banner__icon { font-size: 1.8rem; line-height: 1; }
.auct-banner__left strong { display: block; font-size: 1.05rem; }
.auct-banner__left small { color: var(--ink-dim); font-style: italic; }
.auct-banner__center { min-width: 0; }
.auct-banner__bid { display: block; font-size: .9rem; }
.auct-banner__bid em { color: var(--ink-dim); font-style: italic; }
.auct-banner__right { display: flex; align-items: center; gap: 10px; }
.auct-banner__right strong { font-size: 1.3rem; font-variant-numeric: tabular-nums; color: var(--accent); }

@media (max-width: 600px) {
    .auct-banner { grid-template-columns: auto 1fr; grid-template-rows: auto auto; padding: 8px 10px; }
    .auct-banner__center { grid-column: 1 / -1; }
    .auct-banner__right strong { font-size: 1.1rem; }
}

/* Topbar room name */
.topbar-room { color: var(--ink-dim); font-style: italic; }

/* Profile: room block */
.prof-room {
    margin-top: var(--sp-2);
    padding: var(--sp-2) var(--sp-3);
    background: var(--panel-2);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius-sm);
    display: flex; flex-direction: column; gap: 4px;
}
.prof-room small { color: var(--ink-dim); }
.prof-room small strong { color: var(--ink); }
.prof-room-code {
    background: var(--panel-3);
    padding: 1px 6px;
    border-radius: 3px;
    font-family: ui-monospace, Menlo, monospace;
    color: var(--accent);
}

/* Achievements rows */
.ach-row {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 10px;
    background: var(--panel-2);
    border-radius: var(--radius-sm);
    margin-bottom: 4px;
    font-size: .9rem;
}
.ach-row--unlocked { border-left: 3px solid var(--ok); }
.ach-row--locked { border-left: 3px solid var(--border); opacity: .5; }
.ach-row small { margin-left: auto; color: var(--ink-dim); font-size: .75rem; }

/* Cosmetics intro */
.cosm-intro { margin-bottom: var(--sp-3); color: var(--ink-dim); }
.cosm-intro h3 { color: var(--ink); margin-bottom: .5em; }
.cosm-intro p { line-height: 1.5; margin: 4px 0; }

/* Steward (player-as-faktor) */
.steward-active {
    margin-top: var(--sp-2);
    padding: 8px 10px;
    background: color-mix(in srgb, var(--ok) 14%, var(--panel-2));
    border-left: 3px solid var(--ok);
    border-radius: var(--radius-sm);
    display: flex; flex-direction: column; gap: 4px;
}
.steward-active small { color: var(--ink-dim); }
.steward-post { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: var(--sp-2); }
.steward-post input { padding: 4px 6px; }
.steward-offers { margin-top: var(--sp-2); }
.steward-offers ul { list-style: none; padding: 0; margin: 6px 0 0; display: flex; flex-direction: column; gap: 4px; }
.steward-offers li { display: flex; justify-content: space-between; align-items: center; padding: 6px 8px; background: var(--panel-2); border-radius: 4px; gap: 8px; }

/* Steward delegation toggle in topbar */
.steward-chip {
    display: inline-flex; align-items: center; gap: .3em;
    background: var(--panel-2);
    border: 1px solid var(--ink-dim);
    border-radius: 999px;
    padding: .25em .7em;
    color: var(--ink);
    font-size: .8rem;
    cursor: pointer;
    margin-right: .4em;
}
.steward-chip:hover { background: var(--panel-3); border-color: var(--accent); }
.steward-chip--active {
    background: linear-gradient(135deg, color-mix(in srgb, var(--ok) 30%, var(--panel-2)), var(--panel-2));
    border-color: var(--ok); color: var(--ok); font-weight: 700;
}

/* Auction redesign */
.game-auction { padding: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-3); }
.auct-head { display: flex; align-items: center; gap: var(--sp-3); }
.auct-head-art { font-size: 3rem; line-height: 1; }
.auct-head h2 { margin: 0; color: var(--accent); }
.auct-head small { color: var(--ink-dim); }
.auct-stage {
    display: grid; grid-template-columns: 200px 1fr; gap: var(--sp-3);
    background: linear-gradient(180deg, #1f3247, #0f1d2c);
    border: 1px solid var(--accent-2); border-radius: var(--radius);
    padding: var(--sp-3);
}
.auct-stage__lot { display: flex; align-items: center; justify-content: center; }
.auct-stage__frame {
    width: 160px; height: 160px;
    background: linear-gradient(135deg, #5e3f1d, #2a1a0c);
    border: 6px solid #b88a4a;
    border-radius: 4px;
    display: flex; align-items: center; justify-content: center;
    font-size: 4rem;
    box-shadow: 0 8px 24px rgba(0,0,0,.6), inset 0 0 24px rgba(0,0,0,.4);
}
.auct-stage__info { display: flex; flex-direction: column; gap: var(--sp-2); }
.auct-current { display: flex; flex-direction: column; gap: 2px; }
.auct-current small { color: var(--ink-dim); font-size: .75rem; text-transform: uppercase; letter-spacing: .05em; }
.auct-current strong { font-size: 1.8rem; color: var(--accent); font-variant-numeric: tabular-nums; }
.auct-current em { color: var(--ink-dim); font-style: italic; }
.auct-time { text-align: center; }
.auct-time strong { font-size: 1.6rem; font-variant-numeric: tabular-nums; }
.auct-bid-row { display: flex; flex-direction: column; gap: var(--sp-2); }
.auct-quick-row { display: flex; gap: 4px; flex-wrap: wrap; }
.auct-custom { display: flex; gap: 6px; align-items: center; }
.auct-custom input { flex: 1; padding: 6px 8px; }

@media (max-width: 600px) {
    .auct-stage { grid-template-columns: 1fr; }
    .auct-stage__lot { padding: 8px; }
    .auct-stage__frame { width: 120px; height: 120px; font-size: 3rem; }
}

/* Sell preview line in market card */
.mk-erloes { display: block; padding: 4px 6px; background: color-mix(in srgb, var(--ok) 12%, transparent); border-left: 2px solid var(--ok); border-radius: 3px; color: var(--ink); font-size: .78rem; margin-top: 4px; }
.mk-erloes strong { color: var(--ok); }

/* Steward toggle chip in topbar */
.steward-chip {
    background: var(--panel-2);
    border: 1px solid var(--accent-2);
    border-radius: 999px;
    padding: 4px 10px;
    font-size: .8rem;
    color: var(--ink);
    cursor: pointer;
    margin-right: .35em;
    font-weight: 600;
    transition: background .15s, border-color .15s;
}
.steward-chip:hover { background: var(--panel-3); border-color: var(--accent); }
.steward-chip--active {
    background: linear-gradient(135deg, color-mix(in srgb, var(--ok) 35%, var(--panel-2)), var(--panel-2));
    border-color: var(--ok);
    color: var(--ok);
    animation: steward-pulse 2.5s infinite;
}
@keyframes steward-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(125,190,138,0); }
    50%      { box-shadow: 0 0 0 4px rgba(125,190,138,0.25); }
}

/* Auction banner: live bid flash */
.auct-banner--flash {
    animation: auct-bid-flash .7s ease-out;
}
@keyframes auct-bid-flash {
    0%   { box-shadow: 0 0 0 0 rgba(125,190,138,0); transform: scale(1); }
    20%  { box-shadow: 0 0 0 6px rgba(125,190,138,.55); transform: scale(1.015); }
    100% { box-shadow: 0 0 0 0 rgba(125,190,138,0); transform: scale(1); }
}

/* Tiny button variant for inline / corner actions */
.btn--xs {
    padding: 2px 6px !important;
    font-size: .72rem !important;
    min-height: 22px !important;
    line-height: 1.1;
}
.ship-card__actions {
    display: flex; gap: 4px; justify-content: flex-end;
    margin-top: 4px;
}

/* Stronger disabled-state contrast for action buttons */
.btn:disabled,
.btn[disabled] {
    background: var(--panel-3) !important;
    color: var(--ink-faint) !important;
    border-color: var(--border) !important;
    opacity: .45 !important;
    cursor: not-allowed !important;
    text-decoration: line-through;
    text-decoration-color: rgba(170,190,210,0.25);
    text-decoration-thickness: 1px;
}
.btn--secondary:disabled, .btn--secondary[disabled] {
    background: transparent !important;
}

/* Topbar polish: tighter, XP visible, rank chip compact */
.topbar { padding: 8px 12px !important; gap: 12px; align-items: center; }
.topbar-left { gap: 8px; align-items: center; }
.topbar-left strong { font-size: .95rem; }
.topbar-left small { font-size: .72rem; line-height: 1.25; }
.purse-big { font-size: 1.15rem !important; font-variant-numeric: tabular-nums; }
.wealth-chip { font-variant-numeric: tabular-nums; }
.rank-chip {
    max-width: 130px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 3px 8px !important;
    font-size: .74rem !important;
}
.rank-chip span { overflow: hidden; text-overflow: ellipsis; }
.topbar-right .stat-card { padding: 2px 6px !important; }
.topbar-right .stat-card .stat-value { font-size: .78rem !important; line-height: 1.1; }
.topbar-right .stat-card .progress {
    height: 4px !important;
    width: 50px !important;
    background: var(--panel-3);
    border: 1px solid var(--border);
}
.topbar-right .stat-card .progress__fill {
    background: var(--accent);
    min-width: 2px;
}

/* Trend chip: tighter typography */
.mk-trend { font-variant-numeric: tabular-nums; letter-spacing: -.02em; }

/* Players list with transfer actions */
.players-list { display: flex !important; flex-direction: column; gap: 4px; }
.players-list li {
    display: flex !important; justify-content: space-between; align-items: center;
    gap: 8px; padding: 6px 10px;
}
.player-actions { display: flex; gap: 4px; }

/* Topbar gulden flash on incoming transfer */
.purse-big.flash-up {
    color: var(--ok) !important;
    transition: color .3s;
    text-shadow: 0 0 8px rgba(125,190,138,0.6);
}

/* Transfer modal (gift / loan) */
.tx-modal {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.6);
    display: flex; align-items: center; justify-content: center;
    z-index: 200;
    padding: var(--sp-3);
    animation: chart-fade .12s ease-out;
}
.tx-modal__card {
    background: var(--panel);
    border: 1px solid var(--accent);
    border-radius: var(--radius-sm);
    box-shadow: 0 12px 32px rgba(0,0,0,.6);
    width: 100%; max-width: 420px;
    max-height: 90vh; overflow: auto;
}
.tx-modal__head {
    display: flex; justify-content: space-between; align-items: center;
    padding: var(--sp-2) var(--sp-3);
    border-bottom: 1px solid var(--border);
}
.tx-modal__head strong { color: var(--accent); }
.tx-modal__close {
    background: transparent; border: none; color: var(--ink-dim);
    font-size: 1.4rem; cursor: pointer; line-height: 1; padding: 0 .3em;
}
.tx-modal__close:hover { color: var(--ink); }
.tx-modal__body { padding: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-2); }
.tx-modal__body label { display: flex; flex-direction: column; gap: 4px; font-size: .85rem; color: var(--ink-dim); }
.tx-modal__body input[type=number],
.tx-modal__body input[type=text] {
    padding: 8px 10px; font-size: 1rem;
    background: var(--panel-2);
    color: var(--ink);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
}
.tx-modal__body input:focus { outline: 2px solid var(--accent); border-color: var(--accent); }
.tx-quick { display: flex; gap: 4px; flex-wrap: wrap; }
.tx-quick button {
    padding: 4px 10px; font-size: .8rem;
    background: var(--panel-2); color: var(--ink);
    border: 1px solid var(--border); border-radius: 4px; cursor: pointer;
}
.tx-quick button:hover { border-color: var(--accent); color: var(--accent); }
.tx-modal__foot {
    display: flex; justify-content: flex-end; gap: 8px;
    padding: var(--sp-2) var(--sp-3);
    border-top: 1px solid var(--border);
}

/* PvP defend buttons: wrap better, show readable names */
.pvp-defend { display: flex; flex-wrap: wrap; gap: 6px; margin-top: var(--sp-2); }
.pvp-defend-btn {
    padding: 6px 10px; font-size: .82rem;
    background: var(--panel-2);
    border: 1px solid var(--border);
    color: var(--ink);
    border-radius: 4px; cursor: pointer;
    text-align: left;
}
.pvp-defend-btn small { color: var(--ink-dim); margin-left: .3em; }
.pvp-defend-btn:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); }
.pvp-defend-btn--active {
    background: color-mix(in srgb, var(--ok) 18%, var(--panel-2));
    border-color: var(--ok); color: var(--ok);
    cursor: default;
}

/* Fleet: grouped same-route cards */
.ship-card--group {
    border-left: 3px solid var(--info, var(--accent));
    background: color-mix(in srgb, var(--accent) 8%, var(--panel-2));
}
.ship-card--group details summary {
    cursor: pointer; color: var(--ink-dim); padding: 4px 0;
    font-size: .82rem; user-select: none;
}
.ship-card--group details[open] summary { color: var(--accent); }
.fleet-group__expand {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 6px;
    margin-top: 6px;
}

/* Topbar: tighter on mobile */
@media (max-width: 720px) {
    .topbar {
        grid-template-columns: auto 1fr auto;
        gap: .4rem;
        padding: .5rem .6rem;
    }
    .topbar-left, .topbar-center, .topbar-right { gap: .4rem; }
    .topbar .purse-big { font-size: 1.05rem; }
    .topbar-room { display: none; }   /* hide room name on mobile, still in profile */
    .wealth-chip, .rank-chip, .steward-chip { font-size: .72rem; padding: 3px 8px; }
    .topbar-right .stat-card { padding: .2em .35em !important; }
    .topbar-right .stat-card .stat-value { font-size: .8rem; }
    .topbar-right .stat-card .progress { width: 40px !important; }
    .day-ring svg { width: 32px; height: 32px; }
    .day-remaining { font-size: .72rem; }
}
@media (max-width: 480px) {
    /* Stack center → second row on very narrow screens */
    .topbar { grid-template-columns: 1fr 1fr; }
    .topbar-center { grid-column: 1 / -1; justify-content: flex-start; padding-top: .3rem; border-top: 1px dashed var(--border); }
}

/* Site-wide footer (legal links) */
.site-footer {
    text-align: center; padding: 1.2em 1em; color: var(--ink-faint);
    font-size: .8rem; border-top: 1px solid var(--border);
    margin-top: 2em;
}
.site-footer a { color: var(--ink-dim); text-decoration: none; margin: 0 .3em; }
.site-footer a:hover { color: var(--accent); }

.auth-legal {
    margin-top: .5em; text-align: center;
    color: var(--ink-faint); font-size: .75em;
}
.auth-legal a { color: var(--ink-dim); text-decoration: none; }
.auth-legal a:hover { color: var(--accent); }

.auth-actions { display: flex; flex-wrap: wrap; gap: .35em; justify-content: center; margin-top: .5em; }
.auth-actions button { font-size: .8em; padding: .3em .6em; }

/* Plantation slot indicator */
.pf-slots { display: flex; align-items: center; gap: 4px; margin-top: 4px; }
.pf-owners { color: var(--ink-dim); font-size: .72rem; font-style: italic; }
.plant-card--full { opacity: .7; border-left-color: var(--danger); }
.plant-card--full button[disabled] { cursor: not-allowed; }

/* Live race enhancements */
.race-track-header {
    background: var(--panel-2);
    border-left: 3px solid var(--accent);
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    margin-bottom: 6px;
}
.race-track-header strong { color: var(--accent); display: block; }
.race-track-header small { color: var(--ink-dim); }

.race-track--live {
    box-shadow: 0 0 0 2px var(--accent), 0 0 30px rgba(106,168,217,0.4);
    animation: race-live-pulse 2s infinite;
}
@keyframes race-live-pulse {
    0%, 100% { box-shadow: 0 0 0 2px var(--accent), 0 0 20px rgba(106,168,217,0.3); }
    50%      { box-shadow: 0 0 0 2px var(--accent), 0 0 35px rgba(106,168,217,0.6); }
}
.race-track--live .race-runner {
    transition: left 1.4s cubic-bezier(.4, .1, .6, .9);
    animation: none !important;
}

.race-commentary {
    margin: 8px 0;
    padding: 8px 12px;
    background: var(--panel-2);
    border-left: 3px solid var(--warn);
    border-radius: var(--radius-sm);
    display: flex; flex-direction: column; gap: 4px;
}
.race-comment {
    font-size: .9rem;
    color: var(--ink);
    animation: race-comment-in .4s ease-out;
}
@keyframes race-comment-in {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.race-start-row {
    text-align: center;
    margin: var(--sp-2) 0;
    display: flex; flex-direction: column; gap: 4px;
}
.race-start-row .btn { align-self: center; }
.race-locked-msg {
    text-align: center; padding: 12px;
    background: var(--panel-2);
    border-radius: var(--radius-sm);
    color: var(--ink-dim);
}

/* Crowd favorite badge */
.race-horse-card--crowd {
    border-color: var(--warn) !important;
    box-shadow: 0 0 0 1px var(--warn);
}
.race-pool {
    display: block;
    margin-top: 4px;
    color: var(--warn);
    font-weight: 600;
    font-size: .75rem;
}

/* Race no-race state + countdown */
.race-no-race {
    background: var(--panel-2);
    border-radius: var(--radius-sm);
    padding: var(--sp-3);
    border-left: 3px solid var(--accent);
}
.race-bet-countdown {
    display: block; text-align: center;
    color: var(--warn);
    font-size: 1.5rem;
    font-variant-numeric: tabular-nums;
    animation: race-cd-pulse 1s infinite;
}
@keyframes race-cd-pulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.7; }
}

/* Floating live-race banner — overlay always visible during live phase */
.race-live-banner {
    position: fixed;
    top: 76px; right: 16px;
    width: min(420px, calc(100vw - 32px));
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 30%, var(--panel)), var(--panel));
    border: 2px solid var(--accent);
    border-radius: var(--radius-sm);
    box-shadow: 0 8px 32px rgba(0,0,0,.6), 0 0 24px rgba(106,168,217,.4);
    padding: 10px 12px;
    z-index: 250;
    color: var(--ink);
    font-size: .85rem;
    animation: rlb-in .3s ease-out;
}
@keyframes rlb-in { from { transform: translateX(20px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.race-live-banner__head {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 6px;
}
.race-live-banner__head strong { color: var(--accent); font-size: 1rem; }
.race-live-banner__close {
    background: transparent; border: none; color: var(--ink-dim);
    font-size: 1.2rem; cursor: pointer; line-height: 1;
}
.race-live-banner__lanes {
    display: flex; flex-direction: column; gap: 4px;
    margin-bottom: 6px;
}
.rlb-lane { display: flex; align-items: center; gap: 6px; }
.rlb-name {
    flex: 0 0 90px; font-size: .75rem;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    color: var(--ink);
}
.rlb-track {
    flex: 1; position: relative; height: 16px;
    background: rgba(0,0,0,.3); border-radius: 8px;
    overflow: visible;
}
.rlb-runner {
    position: absolute; left: 0; top: 50%;
    transform: translate(-50%, -50%);
    transition: left 1.4s cubic-bezier(.4, .1, .6, .9);
    font-size: 1rem;
    line-height: 1;
}
.race-live-banner__commentary {
    background: rgba(0,0,0,.3);
    padding: 4px 8px;
    border-radius: 4px;
    border-left: 2px solid var(--warn);
    font-size: .82rem; color: var(--ink);
    min-height: 1.2em;
    margin-bottom: 6px;
}
.race-live-banner__open {
    width: 100%;
}
@media (max-width: 540px) {
    .race-live-banner { top: 60px; right: 4px; left: 4px; width: auto; }
    .rlb-name { flex: 0 0 70px; font-size: .7rem; }
}

/* Empty-state polish with steps */
.empty-state--hint {
    text-align: center;
    padding: var(--sp-8) var(--sp-3);
    background: var(--panel-2);
    border-radius: var(--radius);
    border: 1px dashed var(--border-strong);
}
.empty-state--hint .empty-icon {
    font-size: 3rem;
    line-height: 1;
    margin-bottom: var(--sp-2);
    opacity: .8;
}
.empty-state--hint h3 {
    color: var(--ink);
    text-transform: none;
    letter-spacing: normal;
    font-size: 1.2rem;
}
.empty-state--hint p {
    color: var(--ink-dim);
    margin-bottom: var(--sp-3);
}
.empty-steps {
    list-style: none;
    padding: 0;
    max-width: 320px;
    margin: 0 auto;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}
.empty-steps li {
    padding: 8px 12px;
    background: var(--panel);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius-sm);
    color: var(--ink);
}

/* Tagesziele (Daily Goals) */
.daily-goals { margin-bottom: var(--sp-3); }
.daily-goals h3 { margin-bottom: 6px; }
.daily-bonus {
    display: block;
    color: var(--warn);
    background: color-mix(in srgb, var(--warn) 12%, transparent);
    padding: 6px 10px;
    border-radius: var(--radius-sm);
    margin-bottom: 8px;
}
.daily-goals__grid { display: flex; flex-direction: column; gap: 6px; }
.daily-goal {
    background: var(--panel-2);
    border: 1px solid var(--border);
    border-left: 3px solid var(--accent);
    border-radius: var(--radius-sm);
    padding: 8px 10px;
    display: flex; flex-direction: column; gap: 4px;
}
.daily-goal--ready {
    border-left-color: var(--ok);
    background: color-mix(in srgb, var(--ok) 14%, var(--panel-2));
    animation: daily-ready 1.5s infinite;
}
@keyframes daily-ready {
    0%, 100% { box-shadow: 0 0 0 0 rgba(125,190,138,0); }
    50%      { box-shadow: 0 0 0 4px rgba(125,190,138,0.25); }
}
.daily-goal--claimed {
    opacity: .55;
    border-left-color: var(--ink-faint);
}
.daily-goal__head { display: flex; justify-content: space-between; align-items: center; }
.daily-goal__head small { color: var(--ink-dim); font-variant-numeric: tabular-nums; }
.daily-goal__foot {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: 4px;
}
