/* ── Coup — game stylesheet ─────────────────────────────────────────────────
   Prefix: cp-
   Accent: #f0a500 (gold)
   Character gradients: Duke=purple, Assassin=red, Captain=blue,
                        Ambassador=green, Contessa=pink
   ────────────────────────────────────────────────────────────────────────── */

:root {
    --cp-gold:          #f0a500;
    --cp-gold-dark:     #c8880a;
    --cp-gold-glow:     rgba(240, 165, 0, 0.22);
    --cp-duke:          linear-gradient(155deg, #5b2c8b, #9b59b6);
    --cp-assassin:      linear-gradient(155deg, #7b241c, #c0392b);
    --cp-captain:       linear-gradient(155deg, #154360, #2980b9);
    --cp-ambassador:    linear-gradient(155deg, #145a32, #27ae60);
    --cp-contessa:      linear-gradient(155deg, #6c1f51, #c0166a);
    --cp-card-back-bg:  linear-gradient(145deg, #1c1240, #2d1f5e);
}

/* ── Container ── */
.cp-container {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.2rem 1rem 2rem;
    gap: 1rem;
    max-width: 780px;
    margin: 0 auto;
    width: 100%;
}

/* ── Room code ── */
.cp-room-code {
    text-align: center;
    font-size: 0.8rem;
    color: var(--muted, #9d8fb5);
    letter-spacing: 0.05em;
}
.cp-room-code .code {
    font-family: 'Cabin Sketch', cursive;
    font-size: 2rem;
    color: var(--cp-gold);
    letter-spacing: 3px;
    display: block;
    text-shadow: 0 0 20px var(--cp-gold-glow);
}

/* ── Phase title ── */
.cp-phase-title {
    font-family: 'Cabin Sketch', cursive;
    font-size: 1.5rem;
    color: var(--cp-gold);
    text-align: center;
    margin: 0;
}

/* ── Player board row (opponents) ── */
.cp-board {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    justify-content: center;
    width: 100%;
}

.cp-player-tile {
    background: rgba(26, 16, 53, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 0.6rem 0.85rem;
    min-width: 110px;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    position: relative;
    transition: border-color 0.2s;
}
.cp-player-tile.active-turn {
    border-color: rgba(240, 165, 0, 0.55);
    box-shadow: 0 0 14px rgba(240, 165, 0, 0.12);
}
.cp-player-tile.eliminated {
    opacity: 0.42;
    filter: grayscale(0.5);
}
.cp-player-tile.cp-target-highlight {
    border-color: rgba(240, 165, 0, 0.75);
    cursor: pointer;
    transform: translateY(-2px);
    box-shadow: 0 0 0 2px rgba(240, 165, 0, 0.3);
}
.cp-player-tile.cp-targeted {
    border-color: rgba(255, 71, 87, 0.75);
    box-shadow: 0 0 0 2px rgba(255, 71, 87, 0.3);
}

.cp-tile-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.3rem;
}
.cp-tile-name {
    font-weight: 700;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.cp-tile-you-tag {
    font-size: 0.6rem;
    background: rgba(240, 165, 0, 0.18);
    color: var(--cp-gold);
    border-radius: 4px;
    padding: 0.04rem 0.35rem;
}
.cp-tile-coins {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--cp-gold);
    white-space: nowrap;
}
.cp-tile-coins.danger { color: #ff4757; }
.cp-tile-must-coup {
    font-size: 0.62rem;
    color: #ff4757;
    font-weight: 700;
    text-align: center;
}

.cp-tile-cards {
    display: flex;
    gap: 0.3rem;
}

/* ── Role cards ── */
.cp-card {
    width: 40px;
    height: 56px;
    border-radius: 6px;
    border: 2px solid rgba(255, 255, 255, 0.12);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
    user-select: none;
}
.cp-card-md {
    width: 70px;
    height: 98px;
    border-radius: 8px;
}
.cp-card-lg {
    width: 100px;
    height: 140px;
    border-radius: 10px;
    cursor: default;
}
.cp-card-xlg {
    width: 120px;
    height: 168px;
    border-radius: 12px;
}

/* Card back */
.cp-card-back {
    background: var(--cp-card-back-bg);
    color: rgba(255, 255, 255, 0.18);
    font-size: 1.1rem;
    font-weight: 900;
}
.cp-card-back::before {
    content: '';
    position: absolute;
    inset: 4px;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 4px;
}

/* Character colors */
.cp-card-duke       { background: var(--cp-duke);       border-color: rgba(155, 89, 182, 0.5); }
.cp-card-assassin   { background: var(--cp-assassin);   border-color: rgba(192, 57,  43, 0.5); }
.cp-card-captain    { background: var(--cp-captain);    border-color: rgba( 41,128, 185, 0.5); }
.cp-card-ambassador { background: var(--cp-ambassador); border-color: rgba( 39,174,  96, 0.5); }
.cp-card-contessa   { background: var(--cp-contessa);   border-color: rgba(192, 22, 106, 0.5); }

/* Revealed (face-up, dead) */
.cp-card.revealed {
    filter: grayscale(0.8) brightness(0.45);
}
.cp-dead-x {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    color: rgba(255, 70, 70, 0.8);
    font-weight: 900;
    z-index: 2;
}
.cp-card-lg .cp-dead-x,
.cp-card-xlg .cp-dead-x { font-size: 2.5rem; }

/* Card text */
.cp-card-emoji {
    font-size: 1rem;
    position: relative;
    z-index: 1;
    line-height: 1;
}
.cp-card-md  .cp-card-emoji  { font-size: 1.5rem; }
.cp-card-lg  .cp-card-emoji  { font-size: 2.2rem; }
.cp-card-xlg .cp-card-emoji  { font-size: 2.8rem; }

.cp-card-name, .cp-card-lbl {
    font-size: 0.52rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: relative;
    z-index: 1;
    text-align: center;
    line-height: 1;
}
.cp-card-md  .cp-card-name { font-size: 0.65rem; }
.cp-card-lg  .cp-card-name { font-family: 'Cabin Sketch', cursive; font-size: 0.9rem; letter-spacing: 0; margin-top: 0.2rem; }
.cp-card-xlg .cp-card-name { font-family: 'Cabin Sketch', cursive; font-size: 1rem;  letter-spacing: 0; margin-top: 0.25rem; }

.cp-card-hint {
    font-size: 0.5rem;
    opacity: 0.72;
    text-align: center;
    position: relative;
    z-index: 1;
    padding: 0 4px;
    line-height: 1.3;
}
.cp-card-lg  .cp-card-hint { font-size: 0.6rem; margin-top: 0.1rem; }
.cp-card-xlg .cp-card-hint { font-size: 0.65rem; margin-top: 0.15rem; }

/* Clickable card (lose influence) */
.cp-card-clickable {
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
}
.cp-card-clickable:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 24px rgba(255, 71, 87, 0.25);
    border-color: rgba(255, 71, 87, 0.65);
}

/* Exchange selection */
.cp-card-selectable {
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
}
.cp-card-selectable:hover {
    transform: translateY(-3px);
}
.cp-card-selectable.selected {
    border-color: var(--cp-gold) !important;
    box-shadow: 0 0 0 2px var(--cp-gold-glow), 0 8px 20px rgba(240, 165, 0, 0.2);
}

/* ── Self area ── */
.cp-self {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.6rem;
    padding: 0.8rem;
    background: rgba(240, 165, 0, 0.04);
    border: 1px solid rgba(240, 165, 0, 0.15);
    border-radius: 14px;
}
.cp-self-label {
    font-size: 0.7rem;
    color: var(--cp-gold);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.cp-self-cards {
    display: flex;
    gap: 1rem;
    justify-content: center;
}
.cp-self-coins {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--cp-gold);
}

/* ── Event log ── */
.cp-event-log {
    width: 100%;
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    padding: 0.6rem 0.9rem;
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    max-height: 150px;
    overflow-y: auto;
}
.cp-log-entry {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.5);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    padding-bottom: 0.12rem;
}
.cp-log-entry:last-child {
    color: rgba(255, 255, 255, 0.85);
    border-bottom: none;
    font-weight: 600;
}

/* ── Current action banner ── */
.cp-current-action {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.7rem 1rem;
    border-radius: 12px;
    border-left: 4px solid;
    animation: cp-action-in 0.3s ease;
}

.cp-current-action-icon {
    font-size: 1.6rem;
    flex-shrink: 0;
}

.cp-current-action-info {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.cp-current-action-name {
    font-family: 'Cabin Sketch', cursive;
    font-size: 1.25rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cp-current-action-by {
    font-size: 0.82rem;
    opacity: 0.7;
}

.cp-current-action-arrow {
    margin: 0 0.15rem;
    opacity: 0.5;
}

/* Action color variants */
.cp-act-generic {
    border-color: var(--cp-gold);
    background: rgba(240, 165, 0, 0.08);
    color: var(--cp-gold);
}
.cp-act-generic .cp-current-action-name { color: var(--cp-gold); }

.cp-act-duke {
    border-color: #9b59b6;
    background: rgba(155, 89, 182, 0.1);
}
.cp-act-duke .cp-current-action-name { color: #c39bdb; }

.cp-act-captain {
    border-color: #2980b9;
    background: rgba(41, 128, 185, 0.1);
}
.cp-act-captain .cp-current-action-name { color: #5dade2; }

.cp-act-ambassador {
    border-color: #27ae60;
    background: rgba(39, 174, 96, 0.1);
}
.cp-act-ambassador .cp-current-action-name { color: #58d68d; }

.cp-act-assassin {
    border-color: #c0392b;
    background: rgba(192, 57, 43, 0.1);
}
.cp-act-assassin .cp-current-action-name { color: #e74c3c; }

.cp-act-coup {
    border-color: #ff4757;
    background: rgba(255, 71, 87, 0.12);
}
.cp-act-coup .cp-current-action-name { color: #ff6b81; }

@keyframes cp-action-in {
    from { opacity: 0; transform: translateX(-8px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* ── Action grid ── */
.cp-action-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 0.5rem;
    width: 100%;
}

.cp-action-btn {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 10px;
    padding: 0.65rem 0.85rem;
    color: var(--text, #f0e6ff);
    cursor: pointer;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    transition: background 0.15s, border-color 0.15s, transform 0.15s;
}
.cp-action-btn:hover:not(:disabled) {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.22);
    transform: translateY(-1px);
}
.cp-action-btn:disabled {
    opacity: 0.32;
    cursor: not-allowed;
    transform: none;
}

.cp-action-btn.char-action {
    border-color: rgba(240, 165, 0, 0.18);
}
.cp-action-btn.char-action:hover:not(:disabled) {
    border-color: rgba(240, 165, 0, 0.45);
}
.cp-action-btn.coup-action {
    border-color: rgba(255, 71, 87, 0.25);
    grid-column: 1 / -1;
}
.cp-action-btn.coup-action:hover:not(:disabled) {
    border-color: rgba(255, 71, 87, 0.55);
}

.cp-action-name {
    font-weight: 700;
    font-size: 1rem;
    display: flex;
    align-items: center;
    gap: 0.35rem;
}
.cp-action-desc {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
}
.cp-action-cost {
    font-size: 0.78rem;
    color: #ff6b6b;
    font-weight: 600;
}

/* ── Target selection bar ── */
.cp-target-bar {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    padding: 0.65rem 1rem;
    background: rgba(240, 165, 0, 0.07);
    border: 1px solid rgba(240, 165, 0, 0.28);
    border-radius: 10px;
    flex-wrap: wrap;
}
.cp-target-text {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--cp-gold);
}
.cp-target-cancel {
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 8px;
    padding: 0.4rem 0.8rem;
    color: rgba(255, 255, 255, 0.55);
    cursor: pointer;
    font-size: 0.82rem;
    transition: background 0.15s;
}
.cp-target-cancel:hover { background: rgba(255,255,255,0.07); }

/* ── Reaction panel ── */
.cp-reaction-panel {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    padding: 0.9rem 1rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
}
.cp-reaction-prompt {
    font-weight: 700;
    font-size: 0.9rem;
    margin: 0;
}
.cp-reaction-btns {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.cp-rbtn {
    flex: 1;
    min-width: 130px;
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    padding: 0.7rem 1rem;
    border-radius: 10px;
    border: 1px solid;
    cursor: pointer;
    text-align: left;
    background: none;
    transition: opacity 0.15s, transform 0.15s;
}
.cp-rbtn:hover { opacity: 0.88; transform: translateY(-1px); }
.cp-rbtn-icon  { font-size: 1.1rem; }
.cp-rbtn-label { font-weight: 700; font-size: 0.88rem; }
.cp-rbtn-desc  { font-size: 0.7rem; opacity: 0.6; }

.cp-rbtn-allow     { border-color: rgba(39, 174,  96, 0.5); color: #2ed573; background: rgba(39,174,96,0.07); }
.cp-rbtn-challenge { border-color: rgba(192, 57,  43, 0.5); color: #ff4757; background: rgba(192,57,43,0.07); }
.cp-rbtn-block     { border-color: rgba(41,  128, 185, 0.5); color: #4fc3f7; background: rgba(41,128,185,0.07); }

.cp-block-role-select {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-top: 0.3rem;
}
.cp-block-role-btn {
    padding: 0.25rem 0.6rem;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.05);
    color: var(--text, #f0e6ff);
    font-size: 0.75rem;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
}
.cp-block-role-btn:hover { background: rgba(255,255,255,0.12); }
.cp-block-role-btn.selected {
    border-color: var(--cp-gold);
    background: rgba(240,165,0,0.15);
    color: var(--cp-gold);
}

.cp-reaction-note {
    font-size: 0.7rem;
    color: rgba(255,255,255,0.38);
    margin: 0;
    font-style: italic;
}

/* Reaction status for others */
.cp-react-status {
    font-size: 0.68rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    justify-content: center;
}
.cp-react-allowed   { color: #2ed573; font-weight: 700; }
.cp-react-challenged { color: #ff4757; font-weight: 700; }
.cp-react-blocked   { color: #4fc3f7; font-weight: 700; }
.cp-react-waiting   { color: rgba(255,255,255,0.4); }

.cp-blink-dot {
    width: 5px; height: 5px;
    border-radius: 50%;
    background: #ffe66d;
    animation: cp-blink 0.9s infinite;
    flex-shrink: 0;
}
@keyframes cp-blink { 0%,100%{opacity:1;} 50%{opacity:0.15;} }

/* ── Waiting messages ── */
.cp-waiting-msg {
    text-align: center;
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.88rem;
    padding: 1rem;
}

/* ── Eliminated banner ── */
.cp-eliminated-banner {
    width: 100%;
    padding: 0.6rem 1rem;
    background: rgba(255, 71, 87, 0.1);
    border: 1px solid rgba(255, 71, 87, 0.3);
    border-radius: 10px;
    text-align: center;
    font-size: 0.85rem;
    color: #ff6b6b;
    font-weight: 600;
}

/* ── Lose influence view ── */
.cp-lose-title {
    font-family: 'Cabin Sketch', cursive;
    font-size: 1.7rem;
    color: #ff4757;
    text-align: center;
    margin: 0;
}
.cp-lose-sub {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.45);
    text-align: center;
    margin: 0;
}
.cp-lose-cards {
    display: flex;
    gap: 1.5rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* ── Exchange view ── */
.cp-exchange-title {
    font-family: 'Cabin Sketch', cursive;
    font-size: 1.6rem;
    color: var(--cp-gold);
    text-align: center;
    margin: 0;
}
.cp-exchange-sub {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.45);
    text-align: center;
    margin: 0;
}
.cp-exchange-cards {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}
.cp-exchange-section-label {
    font-size: 0.7rem;
    color: rgba(255,255,255,0.4);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 0.4rem;
}
.cp-exchange-section {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.cp-exchange-select-count {
    font-size: 0.82rem;
    color: var(--cp-gold);
    font-weight: 600;
    text-align: center;
}

/* ── Game over ── */
.cp-gameover {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.4rem;
}
.cp-winner-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.25rem;
}
.cp-winner-crown { font-size: 3rem; }
.cp-winner-name {
    font-family: 'Cabin Sketch', cursive;
    font-size: 2.6rem;
    color: var(--cp-gold);
    text-shadow: 0 0 30px var(--cp-gold-glow);
    text-align: center;
}
.cp-winner-sub {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.45);
}

/* Leaderboard */
.cp-leaderboard {
    width: 100%;
    border-collapse: collapse;
    background: var(--surface, #2a1a4a);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border, #3d2b5f);
}
.cp-leaderboard th {
    font-family: 'Cabin Sketch', cursive;
    font-size: 0.9rem;
    color: var(--cp-gold);
    padding: 0.6rem 0.9rem;
    text-align: left;
    background: rgba(240, 165, 0, 0.07);
    border-bottom: 1px solid var(--border, #3d2b5f);
}
.cp-leaderboard td {
    padding: 0.55rem 0.9rem;
    font-size: 0.85rem;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    vertical-align: middle;
}
.cp-leaderboard tr:last-child td { border-bottom: none; }
.cp-leaderboard tr.winner-row { background: rgba(240,165,0,0.07); }
.cp-leaderboard tr.elim-row   { opacity: 0.55; }

.cp-score-badge {
    display: inline-block;
    padding: 0.18rem 0.55rem;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 700;
}
.cp-score-badge.s2 { background: rgba(240,165,0,0.2);  color: var(--cp-gold); }
.cp-score-badge.s1 { background: rgba(39,174,96,0.18); color: #2ed573; }
.cp-score-badge.s0 { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.4); }

.cp-leaderboard-cards {
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
}

/* ── Buttons ── */
.cp-btn-primary {
    background: linear-gradient(135deg, var(--cp-gold), var(--cp-gold-dark));
    border: none;
    border-radius: 12px;
    padding: 0.75rem 2rem;
    font-size: 1rem;
    font-weight: 700;
    color: #0f0820;
    cursor: pointer;
    transition: opacity 0.15s, transform 0.15s;
}
.cp-btn-primary:hover:not(:disabled) {
    opacity: 0.9;
    transform: translateY(-2px);
}
.cp-btn-primary:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.cp-btn-secondary {
    background: transparent;
    border: 1px solid var(--border, #3d2b5f);
    border-radius: 12px;
    padding: 0.65rem 1.6rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, transform 0.15s;
}
.cp-btn-secondary:hover {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.22);
    transform: translateY(-1px);
}

.cp-btn-danger {
    background: linear-gradient(135deg, #c0392b, #7b241c);
    border: none;
    border-radius: 12px;
    padding: 0.65rem 1.4rem;
    font-size: 0.92rem;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    transition: opacity 0.15s, transform 0.15s;
}
.cp-btn-danger:hover { opacity: 0.9; transform: translateY(-1px); }

.cp-btn-row {
    display: flex;
    gap: 0.8rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* ── Lobby ── */
.cp-player-list {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}
.cp-lobby-player {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 0.9rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 10px;
}
.cp-lobby-player-name {
    flex: 1;
    font-weight: 600;
    font-size: 0.9rem;
}
.cp-host-badge {
    font-size: 0.65rem;
    background: rgba(240,165,0,0.18);
    color: var(--cp-gold);
    border-radius: 4px;
    padding: 0.06rem 0.35rem;
}
.cp-you-badge {
    font-size: 0.65rem;
    background: rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.55);
    border-radius: 4px;
    padding: 0.06rem 0.35rem;
}
.cp-kick-btn {
    background: none;
    border: 1px solid rgba(255, 71, 87, 0.3);
    border-radius: 6px;
    color: rgba(255, 71, 87, 0.7);
    padding: 0.22rem 0.5rem;
    font-size: 0.72rem;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
}
.cp-kick-btn:hover {
    background: rgba(255, 71, 87, 0.1);
    border-color: rgba(255, 71, 87, 0.6);
}

/* ── Coins danger animation ── */
@keyframes cp-danger-pulse { 0%,100%{opacity:1;} 50%{opacity:0.5;} }
.cp-danger-coins { animation: cp-danger-pulse 1.3s infinite; }

/* ── Section separators / helpers ── */
.cp-section {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.6rem;
}

.cp-info-box {
    width: 100%;
    padding: 0.6rem 0.9rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 10px;
    font-size: 0.83rem;
    color: rgba(255,255,255,0.6);
    text-align: center;
}
.cp-info-box.gold {
    border-color: rgba(240,165,0,0.28);
    color: var(--cp-gold);
    background: rgba(240,165,0,0.06);
    font-weight: 600;
}
