/* ===================================================================
   The Crew - shared visuals (cards, tasks, tokens)
   Imported via host.css and player.css (both already pull common.css).
   ================================================================ */

:root {
    --crew-blue:   #4dabff;
    --crew-blue-dark: #1a4566;
    --crew-yellow: #f6d23c;
    --crew-yellow-dark: #8a6b00;
    --crew-pink:   #ff5b8a;
    --crew-pink-dark: #872c4a;
    --crew-green:  #38d9a9;
    --crew-green-dark: #146b54;
    --crew-rocket: #d4213d;
    --crew-rocket-dark: #5a0814;
}

/* -------------------- Crew card visual -------------------- */
.crew-card {
    --bg-1: #fafafa;
    --bg-2: #e2e0d6;
    --ink: var(--c-ink);
    --accent: var(--c-ink-3);
    width: 60px; height: 88px;
    border-radius: 8px;
    background: linear-gradient(160deg, var(--bg-1), var(--bg-2));
    color: var(--ink);
    box-shadow: var(--shadow-card);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    overflow: hidden;
    border: 1px solid rgba(0,0,0,.18);
    transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
    user-select: none;
}
.crew-card::after {
    content: '';
    position: absolute; inset: 4px;
    border: 1.5px solid var(--accent);
    border-radius: 5px;
    opacity: .22;
    pointer-events: none;
}
.crew-card__center {
    font-size: 1.8rem;
    line-height: 1;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,.18));
}
.crew-card__value {
    position: absolute;
    font-family: var(--f-display);
    font-size: 1.1rem;
    line-height: 1;
    color: var(--accent);
    letter-spacing: 0;
}
.crew-card__value--tl { top: 5px; left: 7px; }
.crew-card__value--br { bottom: 5px; right: 7px; transform: rotate(180deg); }

.crew-card[data-suit="blue"]   { --accent: var(--crew-blue-dark);   --bg-1: #d6ecff; --bg-2: #a8d5ff; }
.crew-card[data-suit="yellow"] { --accent: var(--crew-yellow-dark); --bg-1: #fdf4c0; --bg-2: #f3dc6c; }
.crew-card[data-suit="pink"]   { --accent: var(--crew-pink-dark);   --bg-1: #ffd9e6; --bg-2: #ffa3bf; }
.crew-card[data-suit="green"]  { --accent: var(--crew-green-dark);  --bg-1: #d2f5e6; --bg-2: #88e3bc; }
.crew-card[data-suit="rocket"] {
    --accent: var(--c-bone);
    background: linear-gradient(160deg, #5d1428, #2c0612);
    color: var(--c-bone);
    border: 1px solid rgba(212,33,61,.6);
    box-shadow: var(--shadow-card), 0 0 18px rgba(212,33,61,.2);
}
.crew-card[data-suit="rocket"] .crew-card__value { color: var(--c-bone); }
.crew-card[data-suit="rocket"]::after { border-color: rgba(212,33,61,.7); opacity: .8; }

.crew-card.crew-card--sm { width: 44px; height: 64px; }
.crew-card.crew-card--sm .crew-card__center { font-size: 1.4rem; }
.crew-card.crew-card--sm .crew-card__value { font-size: .85rem; }

.crew-card.crew-card--lg { width: 90px; height: 132px; }
.crew-card.crew-card--lg .crew-card__center { font-size: 2.6rem; }
.crew-card.crew-card--lg .crew-card__value { font-size: 1.5rem; }

.crew-card.crew-card--faded { opacity: .35; filter: grayscale(.4); }

.crew-card.crew-card--playable {
    cursor: pointer;
    box-shadow: var(--shadow-card), 0 0 0 2px var(--c-amber) inset;
}
.crew-card.crew-card--playable:hover { transform: translateY(-4px); }
.crew-card.crew-card--playable:active { transform: translateY(-1px); }

.crew-card.is-comm-selected {
    box-shadow: var(--shadow-card-h), 0 0 18px var(--c-violet), 0 0 0 2px var(--c-violet) inset;
    transform: translateY(-4px);
}

.crew-card.crew-card--enter { animation: crewCardEnter .35s cubic-bezier(.2,1.3,.4,1) both; }
@keyframes crewCardEnter {
    0% { transform: translateY(-12px) scale(.85) rotate(-3deg); opacity: 0; }
    100% { transform: translateY(0) scale(1) rotate(0); opacity: 1; }
}

/* -------------------- Task card visual -------------------- */
.crew-task {
    position: relative;
    display: inline-block;
    padding: 6px 6px 18px;
}
.crew-task .crew-card { box-shadow: 0 6px 18px rgba(0,0,0,.4); }
.crew-task.is-completed .crew-card { opacity: .35; filter: saturate(.4); }
.crew-task.is-completed::after {
    content: '✓ DONE';
    position: absolute;
    top: 8px; right: 8px;
    background: rgba(56,217,169,.95);
    color: var(--c-ink);
    font-family: var(--f-display);
    font-size: .7rem;
    padding: .15rem .45rem;
    border-radius: 4px;
    letter-spacing: .12em;
}
.crew-task.is-failed .crew-card { opacity: .35; filter: hue-rotate(-30deg) saturate(2); }
.crew-task.is-failed::after {
    content: '✗ FAIL';
    position: absolute;
    top: 8px; right: 8px;
    background: var(--c-crimson);
    color: var(--c-bone);
    font-family: var(--f-display);
    font-size: .7rem;
    padding: .15rem .45rem;
    border-radius: 4px;
    letter-spacing: .12em;
}
.crew-task.is-claimable {
    cursor: pointer;
    transition: transform .12s ease;
}
.crew-task.is-claimable:hover { transform: translateY(-3px); }
.crew-task.is-claimable .crew-card { box-shadow: var(--shadow-card-h), 0 0 0 2px var(--c-amber) inset; }

.crew-task-token {
    position: absolute;
    top: -8px; left: -8px;
    width: 32px; height: 32px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--f-display);
    font-size: 1.1rem;
    line-height: 1;
    color: var(--c-ink);
    background: var(--c-bone);
    border: 2px solid var(--c-ink);
    box-shadow: 0 4px 8px rgba(0,0,0,.3);
}
.crew-task-token--numbered { background: var(--c-amber); }
.crew-task-token--first    { background: var(--c-teal); }
.crew-task-token--last     { background: var(--c-violet); color: var(--c-bone); }
.crew-task-owner {
    position: absolute;
    bottom: 2px; left: 6px; right: 6px;
    text-align: center;
    font-size: .68rem;
    color: var(--c-bone-dim);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-family: var(--f-display);
    letter-spacing: .1em;
}

/* -------------------- Game-type picker in lobby -------------------- */
.lobby-game-picker {
    display: flex; flex-direction: column; gap: .3rem;
    margin-bottom: .6rem;
    padding-bottom: .55rem;
    border-bottom: 1px solid rgba(255,255,255,.06);
}
.lobby-game-picker__label {
    font-family: var(--f-display);
    letter-spacing: .15em;
    color: var(--c-bone-dim);
    font-size: .78rem;
}
.lobby-game-picker__options {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
    gap: .4rem;
}
.game-pick {
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: var(--r-md);
    padding: .5rem .6rem;
    text-align: left;
    color: var(--c-bone-dim);
    display: flex; flex-direction: column; gap: .1rem;
    transition: all .14s ease;
    cursor: pointer;
}
.game-pick:hover { background: rgba(255,255,255,.06); color: var(--c-bone); }
.game-pick.is-active {
    background: rgba(212,33,61,.15);
    border-color: rgba(212,33,61,.6);
    color: var(--c-bone);
    box-shadow: 0 0 24px rgba(212,33,61,.15);
}
.game-pick__icon { font-size: 1.15rem; line-height: 1; }
.game-pick__name {
    font-family: var(--f-display);
    font-size: .95rem;
    letter-spacing: .04em;
}
.game-pick__sub { font-size: .62rem; color: var(--c-bone-dim); letter-spacing: .05em; }
