/* ==========================================================
   ftc-game.css — Find the Colour Frontend Styles
   Mirrors Feedheardle CSS tokens and layout exactly.
   Adds Pokémon TCG Pocket-style card design on top.
   ========================================================== */

@font-face {
    font-family: 'AvantGarde-Bold';
    src: url('/feedheardle/feeder-parts/itc-avant-garde-std-bold.ttf') format('truetype');
    font-weight: 900;
    font-display: swap;
}

/* ── DESIGN TOKENS (mirrors Feedheardle) ────────────────── */
:root {
    --ftc-accent:   #6db6a6;
    --ftc-gold:     #ffcc00;
    --ftc-text:     #fff;
    --ftc-sub:      #bbb;
    --ftc-card:     rgba(0,0,0,0.65);
    --ftc-success:  #12E200;
    --ftc-bronze:        #cd7f32;
    --ftc-bronze-glow:   #e8a45a;
    --ftc-silver:        #c0c0c0;
    --ftc-silver-glow:   #e8e8e8;
    --ftc-gold-r:        #ffd700;
    --ftc-gold-glow:     #ffe84d;
    --ftc-platinum:      #e5e4e2;
    --ftc-platinum-glow: #ffffff;
    --ftc-icon:          #b388ff;
    --ftc-icon-glow:     #ea80fc;
}

/* ── BASE (mirrors Feedheardle body) ────────────────────── */
html { margin-top: 32px !important; }

#ftc-body {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    color: var(--ftc-text);
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
    min-height: 100vh;
    position: relative;
    background: #000;
}

#ftc-body::before {
    content: "";
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    background-color: #1a1a1a;
    background-image: url('/feedheardle/feeder-parts/feeder_comfortinsound_live-scaled.jpg');
    background-size: cover;
    background-position: center;
    filter: brightness(0.45);
    z-index: -1;
}

/* ── TITLE (mirrors Feedheardle) ────────────────────────── */
.ftc-title-container {
    display: flex; flex-direction: column; align-items: center;
    margin-bottom: 16px; width: 100%; margin-top: 40px;
}


.ftc-title-container h1 {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-weight: 900;
    font-size: clamp(2.2rem, 12vw, 5.5rem);
    margin: 0; text-transform: uppercase;
    text-shadow: 3px 3px 0 #000;
    letter-spacing: -0.02em; line-height: 0.9;
}

.ftc-subtitle {
    font-family: 'AvantGarde-Bold', sans-serif !important;
    font-style: italic !important;
    font-size: 1.1rem !important;
    color: var(--ftc-accent) !important;
    width: 100%;
    text-align: right;
    transform: skewX(-15deg);
    font-weight: 900 !important;
    margin-top: -4px;
    padding-right: 2px;
    letter-spacing: 2px;
    text-transform: uppercase;
}

/* ── NAV TABS ───────────────────────────────────────────── */
.ftc-nav-tabs {
    display: flex; gap: 6px; margin: 14px 0 0;
    flex-wrap: wrap; justify-content: center;
}

.ftc-nav-tab {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.65rem; letter-spacing: 1.5px; text-transform: uppercase;
    padding: 7px 14px; border: 1px solid rgba(255,255,255,0.15);
    background: rgba(0,0,0,0.45); color: #888;
    cursor: pointer; border-radius: 8px; transition: 0.2s; font-weight: 900;
}
.ftc-nav-tab:hover  { border-color: var(--ftc-accent); color: var(--ftc-accent); }
.ftc-nav-tab.active { background: rgba(109,182,166,0.15); border-color: var(--ftc-accent); color: var(--ftc-accent); }

/* Locked tabs — shown to logged-out users for auth-required sections */
.ftc-nav-tab--locked {
    opacity: 0.4;
    cursor: not-allowed !important;
    position: relative;
}
.ftc-nav-tab--locked:hover {
    border-color: rgba(255,255,255,0.15) !important;
    color: #888 !important;
    opacity: 0.55;
}
/* "🔒 Log in to access" tooltip */
.ftc-nav-tab--locked::after {
    content: '🔒 Log in to access';
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,0.85);
    color: #ccc;
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.55rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    white-space: nowrap;
    padding: 5px 10px;
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.1);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.15s ease;
    z-index: 100;
}
.ftc-nav-tab--locked:hover::after {
    opacity: 1;
}

/* ── RARITY FILTER ──────────────────────────────────────── */
.ftc-filter-bar {
    display: flex; gap: 6px; margin: 10px 0 0;
    flex-wrap: wrap; justify-content: center;
}

.ftc-rarity-btn {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.6rem; letter-spacing: 1px; text-transform: uppercase;
    padding: 5px 11px; border: 1px solid rgba(255,255,255,0.1);
    background: rgba(0,0,0,0.45); color: #666;
    cursor: pointer; border-radius: 6px; transition: 0.2s; font-weight: 900;
}
.ftc-rarity-btn.active.f-all      { border-color:var(--ftc-accent);    color:var(--ftc-accent);    background:rgba(109,182,166,0.1); }
.ftc-rarity-btn.active[data-rarity="bronze"]   { border-color:var(--ftc-bronze);  color:var(--ftc-bronze);  background:rgba(205,127,50,0.1); }
.ftc-rarity-btn.active[data-rarity="silver"]   { border-color:var(--ftc-silver);  color:var(--ftc-silver);  background:rgba(192,192,192,0.1); }
.ftc-rarity-btn.active[data-rarity="gold"]     { border-color:var(--ftc-gold-r);  color:var(--ftc-gold-r);  background:rgba(255,215,0,0.1); }
.ftc-rarity-btn.active[data-rarity="platinum"] { border-color:var(--ftc-platinum);color:var(--ftc-platinum);background:rgba(229,228,226,0.1); }
.ftc-rarity-btn.active[data-rarity="icon"]     { border-color:var(--ftc-icon);    color:var(--ftc-icon);    background:rgba(179,136,255,0.1); }

/* ── MAIN PANEL CARD (glassmorphism — mirrors Feedheardle) ── */
.ftc-panel-card {
    margin-top: 20px; width: 100%; max-width: 960px;
    background: var(--ftc-card); padding: 28px 24px;
    border-radius: 28px; border: 1px solid rgba(255,255,255,0.12);
    backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px);
    box-sizing: border-box;
}

.ftc-panel { display: none; }
.ftc-panel.active { display: block; }

.ftc-panel-heading {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.7rem; color: var(--ftc-accent);
    letter-spacing: 2px; text-transform: uppercase;
    margin-bottom: 16px; padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.08); font-weight: 900;
}

/* ── LOADING ─────────────────────────────────────────────── */
.ftc-loading {
    text-align: center; padding: 40px;
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.75rem; letter-spacing: 2px;
    text-transform: uppercase; color: #555;
    animation: ftc-flicker 0.8s ease-in-out infinite alternate;
}
@keyframes ftc-flicker { 0%{opacity:0.4} 100%{opacity:1} }

/* ════════════════════════════════════════════════════════════
   POKÉMON TCG POCKET-STYLE CARDS
   ════════════════════════════════════════════════════════════ */
.ftc-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(165px, 1fr));
    gap: 18px;
}

/* Card wrapper — perspective for 3D flip */
.ftc-card-wrap {
    perspective: 1000px;
    cursor: pointer;
    opacity: 0;
    transform: translateY(16px);
    animation: ftcReveal 0.35s ease forwards;
}
@keyframes ftcReveal { to { opacity:1; transform:translateY(0); } }

/* The card — 2.5:3.5 Pokémon TCG standard ratio */
.ftc-card {
    width: 100%;
    aspect-ratio: 2.5 / 3.5;
    position: relative;
    transform-style: preserve-3d;
    transition: transform 0.55s cubic-bezier(0.4,0,0.2,1);
    border-radius: 16px;
    /* Tilt on hover — subtle */
    transform-origin: center center;
}
.ftc-card-wrap:hover .ftc-card {
    transform: rotateY(12deg) rotateX(-3deg) scale(1.04);
    /* Note: pack reveal uses rotateY(180deg) — JS overrides this */
}
.ftc-card-wrap.flip-mode:hover .ftc-card { transform: none; }
.ftc-card-wrap.flipped .ftc-card { transform: rotateY(180deg) !important; }

.ftc-card-front, .ftc-card-back {
    position: absolute; inset: 0; border-radius: 16px;
    backface-visibility: hidden; overflow: hidden;
}
.ftc-card-back-face {
    position: absolute; inset: 0; border-radius: 16px;
    backface-visibility: hidden; overflow: hidden;
    transform: rotateY(180deg);
    display: flex; flex-direction: column; align-items: center;
    justify-content: center; padding: 12px; text-align: center; gap: 5px;
    background: #0a0a12;
    border: 2px solid rgba(109,182,166,0.3);
}

/* ── STANDARD CARD FRONT LAYOUT (Pokémon TCG style) ─────── */
.ftc-card-front {
    display: flex;
    flex-direction: column;
}

/* Header strip — rarity record icon + name */
.ftc-card-header {
    padding: 8px 10px 5px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
}

.ftc-card-name {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.72rem; font-weight: 900;
    letter-spacing: 0.5px; line-height: 1.15;
    text-transform: uppercase; flex: 1; margin-right: 5px;
}

.ftc-record-icon { flex-shrink: 0; width: 28px; height: 28px; }
.ftc-record-icon svg { width: 100%; height: 100%; }

/* ARTWORK — fills the majority of the card */
.ftc-card-artwork {
    flex: 1;
    margin: 0 6px;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
}

.ftc-card-artwork img {
    width: 100%; height: 100%; object-fit: cover;
    border-radius: 10px;
}

.ftc-card-artwork .ftc-art-placeholder {
    font-size: 3rem;
    display: flex; align-items: center; justify-content: center;
    width: 100%; height: 100%;
}

/* TEXT BOX at bottom — Pokémon style */
.ftc-card-textbox {
    margin: 5px 6px 6px;
    border-radius: 8px;
    padding: 6px 8px;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
}

.ftc-card-type-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 3px;
}

.ftc-type-chip {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.5rem; letter-spacing: 1px;
    text-transform: uppercase; padding: 2px 5px;
    border-radius: 3px; font-weight: 900;
}

.ftc-card-number {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.48rem; color: #555; letter-spacing: 0.5px;
}

.ftc-card-flavour {
    font-size: 0.55rem;
    line-height: 1.4;
    font-style: italic;
    margin-top: 2px;
}

/* ── FULL ART CARD (Icon tier) ───────────────────────────── */
/* Artwork bleeds to edges, text overlaid at bottom */
.ftc-card-wrap.full-art .ftc-card-front { display: block; }

.ftc-card-wrap.full-art .ftc-card-artwork {
    position: absolute;
    inset: 0; margin: 0; border-radius: 16px;
    z-index: 0;
}

.ftc-card-wrap.full-art .ftc-card-artwork img {
    border-radius: 16px;
}

.ftc-card-wrap.full-art .ftc-card-header {
    position: absolute; top: 0; left: 0; right: 0;
    z-index: 3;
    background: linear-gradient(to bottom, rgba(0,0,0,0.7) 0%, transparent 100%);
    border-radius: 16px 16px 0 0;
}

.ftc-card-wrap.full-art .ftc-card-textbox {
    position: absolute; bottom: 0; left: 0; right: 0;
    margin: 0; border-radius: 0 0 16px 16px;
    z-index: 3;
}

/* ── RARITY-SPECIFIC CARD STYLES ────────────────────────── */
/* Bronze */
.ftc-card-wrap[data-rarity="bronze"] .ftc-card-front {
    background: linear-gradient(165deg, #1a1208, #2a1f0a, #1a1208);
    border: 2px solid var(--ftc-bronze);
    box-shadow: 0 4px 20px rgba(205,127,50,0.2);
}
.ftc-card-wrap[data-rarity="bronze"] .ftc-card-name   { color: var(--ftc-bronze-glow); }
.ftc-card-wrap[data-rarity="bronze"] .ftc-card-textbox{ background: rgba(26,18,8,0.85); border: 1px solid rgba(205,127,50,0.3); }
.ftc-card-wrap[data-rarity="bronze"] .ftc-type-chip   { background: rgba(205,127,50,0.2); color: var(--ftc-bronze); border: 1px solid rgba(205,127,50,0.4); }
.ftc-card-wrap[data-rarity="bronze"] .ftc-card-artwork{ background: linear-gradient(135deg, #2a1f0a, #3d2d0f); border: 1px solid rgba(205,127,50,0.25); }
.ftc-card-wrap[data-rarity="bronze"] .ftc-card-flavour{ color: #7a6040; }

/* Silver */
.ftc-card-wrap[data-rarity="silver"] .ftc-card-front {
    background: linear-gradient(165deg, #0f0f18, #1c1c2e, #0f0f18);
    border: 2px solid var(--ftc-silver);
    box-shadow: 0 4px 24px rgba(192,192,192,0.18);
}
.ftc-card-wrap[data-rarity="silver"] .ftc-card-name   { color: var(--ftc-silver-glow); }
.ftc-card-wrap[data-rarity="silver"] .ftc-card-textbox{ background: rgba(15,15,24,0.88); border: 1px solid rgba(192,192,192,0.3); }
.ftc-card-wrap[data-rarity="silver"] .ftc-type-chip   { background: rgba(192,192,192,0.15); color: var(--ftc-silver); border: 1px solid rgba(192,192,192,0.4); }
.ftc-card-wrap[data-rarity="silver"] .ftc-card-artwork{ background: linear-gradient(135deg, #1c1c28, #2a2a3a); border: 1px solid rgba(192,192,192,0.2); }
.ftc-card-wrap[data-rarity="silver"] .ftc-card-flavour{ color: #7a7a8a; }

/* Gold */
.ftc-card-wrap[data-rarity="gold"] .ftc-card-front {
    background: linear-gradient(165deg, #1a1500, #2a2200, #1a1500);
    border: 2px solid var(--ftc-gold-r);
    box-shadow: 0 4px 28px rgba(255,215,0,0.22);
}
.ftc-card-wrap[data-rarity="gold"] .ftc-card-name   { color: var(--ftc-gold-glow); text-shadow: 0 0 8px rgba(255,215,0,0.4); }
.ftc-card-wrap[data-rarity="gold"] .ftc-card-textbox{ background: rgba(26,21,0,0.9); border: 1px solid rgba(255,215,0,0.3); }
.ftc-card-wrap[data-rarity="gold"] .ftc-type-chip   { background: rgba(255,215,0,0.15); color: var(--ftc-gold-r); border: 1px solid rgba(255,215,0,0.4); }
.ftc-card-wrap[data-rarity="gold"] .ftc-card-artwork{ background: linear-gradient(135deg, #2a2200, #3d3300); border: 1px solid rgba(255,215,0,0.25); }
.ftc-card-wrap[data-rarity="gold"] .ftc-card-flavour{ color: #8a7a30; }

/* Platinum */
.ftc-card-wrap[data-rarity="platinum"] .ftc-card-front {
    background: linear-gradient(165deg, #0d0d18, #1a1a30, #0d0d18);
    border: 2px solid var(--ftc-platinum);
    box-shadow: 0 4px 32px rgba(229,228,226,0.22);
}
.ftc-card-wrap[data-rarity="platinum"] .ftc-card-name   { color: #fff; text-shadow: 0 0 10px rgba(229,228,226,0.5); }
.ftc-card-wrap[data-rarity="platinum"] .ftc-card-textbox{ background: rgba(13,13,24,0.92); border: 1px solid rgba(229,228,226,0.3); }
.ftc-card-wrap[data-rarity="platinum"] .ftc-type-chip   { background: rgba(229,228,226,0.12); color: var(--ftc-platinum); border: 1px solid rgba(229,228,226,0.4); }
.ftc-card-wrap[data-rarity="platinum"] .ftc-card-artwork{ background: linear-gradient(135deg, #1a1a2e, #252545); border: 1px solid rgba(229,228,226,0.25); }
.ftc-card-wrap[data-rarity="platinum"] .ftc-card-flavour{ color: #888; }

/* Platinum + Icon holographic shimmer */
.ftc-card-wrap[data-rarity="platinum"] .ftc-card-front::after,
.ftc-card-wrap[data-rarity="icon"] .ftc-card-front::after {
    content: ''; position: absolute; inset: 0; border-radius: 16px;
    background: linear-gradient(105deg, transparent 25%, rgba(255,255,255,0.06) 50%, transparent 75%);
    background-size: 200% 200%;
    animation: ftcShimmer 4s ease-in-out infinite;
    pointer-events: none; z-index: 4;
}
@keyframes ftcShimmer {
    0%   { background-position: -100% 0; }
    100% { background-position: 300% 0; }
}

/* Icon */
.ftc-card-wrap[data-rarity="icon"] .ftc-card-front {
    background: linear-gradient(165deg, #0d0010, #1a0030, #0d0010);
    border: 2px solid var(--ftc-icon);
    box-shadow: 0 0 40px rgba(179,136,255,0.45), 0 0 80px rgba(234,128,252,0.15);
    animation: ftcIconPulse 3s ease-in-out infinite;
}
.ftc-card-wrap[data-rarity="icon"] .ftc-card-name   { color: #fff; text-shadow: 0 0 12px var(--ftc-icon); }
.ftc-card-wrap[data-rarity="icon"] .ftc-card-textbox{ background: rgba(13,0,16,0.92); border: 1px solid rgba(179,136,255,0.4); }
.ftc-card-wrap[data-rarity="icon"] .ftc-type-chip   { background: rgba(179,136,255,0.15); color: var(--ftc-icon); border: 1px solid rgba(179,136,255,0.45); }
.ftc-card-wrap[data-rarity="icon"] .ftc-card-artwork{ background: linear-gradient(135deg, #1a0028, #2d0045); border: 1px solid rgba(179,136,255,0.4); }
.ftc-card-wrap[data-rarity="icon"] .ftc-card-flavour{ color: #9a7ab0; }

@keyframes ftcIconPulse {
    0%,100% { box-shadow:0 0 40px rgba(179,136,255,0.4), 0 0 80px rgba(234,128,252,0.12); }
    50%     { box-shadow:0 0 60px rgba(179,136,255,0.65),0 0 120px rgba(234,128,252,0.25); }
}

/* Tribute badge */
.ftc-tribute-badge {
    position: absolute; top: 6px; right: 6px; z-index: 5;
    background: rgba(109,182,166,0.15); border: 1px solid var(--ftc-accent);
    border-radius: 3px; padding: 1px 5px;
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.45rem; letter-spacing: 1px;
    color: var(--ftc-accent); text-transform: uppercase;
}

/* ════════════════════════════════════════════════════════════
   CARD BACK (flip side — for pack reveals)
   ════════════════════════════════════════════════════════════ */
.ftc-card-back-title { font-family:'AvantGarde-Bold',sans-serif; font-size:0.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--ftc-accent); font-weight:900; }
.ftc-card-back-name  { font-family:'AvantGarde-Bold',sans-serif; font-size:0.85rem; font-weight:900; text-transform:uppercase; line-height:1.1; }
.ftc-card-back-meta  { font-size:0.55rem; color:#555; }
.ftc-card-back-quote { font-size:0.52rem; font-style:italic; color:#666; border-top:1px solid rgba(255,255,255,0.08); padding-top:5px; margin-top:3px; line-height:1.4; max-width:90%; }

/* ════════════════════════════════════════════════════════════
   PACK OPENING
   ════════════════════════════════════════════════════════════ */
.ftc-pack-area {
    display: flex; flex-direction: column; align-items: center;
    gap: 20px; padding: 10px 0;
}

/* ── Pack grid ── */
.ftc-pack-loading {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.65rem; letter-spacing: 2px; text-transform: uppercase;
    color: #555; padding: 24px 0; text-align: center;
}

.ftc-pack-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
    width: 100%; max-width: 700px;
}

.ftc-pack-tile {
    background: rgba(0,0,0,0.35);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 12px;
    padding: 14px 10px 12px;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s, transform 0.15s;
    user-select: none;
}
.ftc-pack-tile:hover {
    background: rgba(255,255,255,0.04);
    border-color: rgba(255,255,255,0.15);
    transform: translateY(-2px);
}
.ftc-pack-tile.pack-tile-selected {
    border-color: var(--ftc-accent) !important;
    background: rgba(109,182,166,0.08) !important;
}
.ftc-pack-tile.pack-tile-ready {
    border-color: rgba(18,226,0,0.25);
}
.ftc-pack-tile.pack-tile-locked {
    opacity: 0.6;
}

.ftc-pack-tile-icon { font-size: 1.5rem; margin-bottom: 6px; }

.ftc-pack-tile-name {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.6rem; font-weight: 900;
    letter-spacing: 1.5px; text-transform: uppercase;
    color: var(--ftc-accent); line-height: 1.3; margin-bottom: 8px;
}

.ftc-pack-tile-status {
    display: flex; align-items: center; justify-content: center; gap: 5px;
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.6rem; letter-spacing: 1px; text-transform: uppercase;
}

.ftc-tile-ready-dot {
    display: inline-block; width: 6px; height: 6px;
    background: #12E200; border-radius: 50%;
    box-shadow: 0 0 5px #12E200;
    animation: ftc-throb 1.5s infinite ease-in-out;
}
.ftc-tile-ready-label { color: #12E200 !important; }
.ftc-tile-countdown { color: var(--ftc-gold) !important; font-size: 0.65rem; }

/* ── Pack detail box ── */
.ftc-pack-detail { width: 100%; max-width: 420px; }
.ftc-pack-tile-ready-label-big {
    color: var(--ftc-success);
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.75rem; letter-spacing: 2px;
    text-transform: uppercase; margin-bottom: 12px;
}

.ftc-pack-status-box {
    background: rgba(0,0,0,0.4); border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px; padding: 24px 32px; text-align: center;
    max-width: 420px; width: 100%;
}

.ftc-pack-title {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 1.1rem; font-weight: 900; letter-spacing: 2px;
    text-transform: uppercase; color: var(--ftc-accent);
    margin-bottom: 8px;
}

.ftc-pack-desc {
    font-size: 0.75rem; color: #666; margin-bottom: 18px;
    line-height: 1.5;
}

.ftc-pack-countdown-big {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 2.5rem; font-weight: 900; letter-spacing: 3px;
    color: var(--ftc-gold); margin: 10px 0;
}

.ftc-pack-countdown-label {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.6rem; letter-spacing: 2px; text-transform: uppercase;
    color: #555; margin-bottom: 16px;
}

/* The pack reveal row */
.ftc-pack-reveal-row {
    display: flex; gap: 12px; justify-content: center;
    flex-wrap: wrap; margin-top: 8px;
}

/* Individual card slots in pack reveal — same dimensions as card grid */
.ftc-pack-card-slot {
    width: 165px;
    aspect-ratio: 2.5/3.5;
    perspective: 1000px;
    cursor: pointer;
}

.ftc-pack-card-slot .ftc-card-wrap {
    width: 100%; height: 100%; margin: 0;
    animation: none; opacity: 1; transform: none;
}

/* Face-down card back image */
.ftc-card-facedown {
    position: absolute; inset: 0; border-radius: 16px;
    background: linear-gradient(135deg, #0a0a15, #151520);
    border: 2px solid rgba(109,182,166,0.25);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
}

.ftc-card-facedown-logo {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.65rem; letter-spacing: 3px; text-transform: uppercase;
    color: rgba(109,182,166,0.4); text-align: center; line-height: 1.6;
}

.ftc-card-facedown::before {
    content: '';
    position: absolute; inset: 8px; border-radius: 10px;
    border: 1px solid rgba(109,182,166,0.12);
}

.ftc-tap-hint {
    position: absolute; bottom: 12px; left: 0; right: 0; text-align: center;
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.5rem; letter-spacing: 1.5px; text-transform: uppercase;
    color: rgba(109,182,166,0.5);
    animation: ftcPulse 1.5s ease-in-out infinite;
}
@keyframes ftcPulse { 0%,100%{opacity:0.4} 50%{opacity:1} }

/* New card badge */
.ftc-new-badge {
    position: absolute; top: -6px; right: -6px; z-index: 10;
    background: var(--ftc-success); color: #000;
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.45rem; font-weight: 900; letter-spacing: 1px;
    padding: 2px 6px; border-radius: 10px; text-transform: uppercase;
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.ftc-btn {
    font-family: 'AvantGarde-Bold', sans-serif;
    font-size: 0.7rem; font-weight: 900; letter-spacing: 1.5px;
    text-transform: uppercase; padding: 12px 22px;
    border-radius: 12px; border: 1px solid rgba(255,255,255,0.15);
    background: rgba(0,0,0,0.5); color: #888;
    cursor: pointer; transition: 0.2s;
}
.ftc-btn:hover  { border-color: var(--ftc-accent); color: var(--ftc-accent); }
.ftc-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.ftc-btn-primary {
    background: rgba(109,182,166,0.15);
    border-color: var(--ftc-accent); color: var(--ftc-accent);
}
.ftc-btn-primary:hover:not(:disabled) { background: rgba(109,182,166,0.25); }

.ftc-btn-open-pack {
    font-size: 0.9rem; padding: 16px 36px; border-radius: 14px;
    background: rgba(109,182,166,0.12); border: 2px solid var(--ftc-accent);
    color: var(--ftc-accent); position: relative; overflow: hidden;
}
.ftc-btn-open-pack::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(90deg, transparent, rgba(109,182,166,0.1), transparent);
    transform: translateX(-100%); transition: transform 0.4s;
}
.ftc-btn-open-pack:hover::before { transform: translateX(100%); }
.ftc-btn-open-pack.pack-ready { animation: ftcPackGlow 2s ease-in-out infinite; }
@keyframes ftcPackGlow {
    0%,100% { box-shadow:0 0 15px rgba(109,182,166,0.2); }
    50%     { box-shadow:0 0 30px rgba(109,182,166,0.5); }
}

/* ── COLLECTION ──────────────────────────────────────────── */
.ftc-progress-wrap { background:rgba(0,0,0,0.4); border:1px solid rgba(255,255,255,0.08); border-radius:14px; padding:16px 20px; margin-bottom:20px; }
.ftc-progress-label { font-family:'AvantGarde-Bold',sans-serif; font-size:0.65rem; letter-spacing:1.5px; text-transform:uppercase; color:#888; margin-bottom:8px; font-weight:900; }
.ftc-progress-bar { height:5px; background:rgba(255,255,255,0.08); border-radius:3px; overflow:hidden; }
.ftc-progress-fill { height:100%; background:linear-gradient(90deg,var(--ftc-accent),var(--ftc-icon)); border-radius:3px; transition:width 0.5s ease; }
.ftc-progress-count { font-family:'AvantGarde-Bold',sans-serif; font-size:1.4rem; color:var(--ftc-accent); margin-top:4px; font-weight:900; letter-spacing:1px; }
.ftc-collection-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(85px,1fr)); gap:8px; }

.ftc-col-slot { aspect-ratio:2.5/3.5; border-radius:10px; border:1px dashed rgba(255,255,255,0.1); display:flex; flex-direction:column; align-items:center; justify-content:center; background:rgba(0,0,0,0.3); cursor:pointer; transition:0.2s; gap:4px; position:relative; overflow:hidden; }
.ftc-col-slot:hover { border-color:var(--ftc-accent); }
.ftc-col-slot.owned-bronze   { border:1px solid var(--ftc-bronze);   background:rgba(205,127,50,0.06); }
.ftc-col-slot.owned-silver   { border:1px solid var(--ftc-silver);   background:rgba(192,192,192,0.06); }
.ftc-col-slot.owned-gold     { border:1px solid var(--ftc-gold-r);   background:rgba(255,215,0,0.06); }
.ftc-col-slot.owned-platinum { border:1px solid var(--ftc-platinum); background:rgba(229,228,226,0.06); }
.ftc-col-slot.owned-icon     { border:1px solid var(--ftc-icon);     background:rgba(179,136,255,0.06); animation:ftcIconPulse 3s ease-in-out infinite; }
.ftc-col-slot-img { width:100%; height:60%; object-fit:cover; }
.ftc-col-slot-emoji { font-size:1.4rem; }
.ftc-col-slot-name { font-family:'AvantGarde-Bold',sans-serif; font-size:0.44rem; letter-spacing:0.5px; text-align:center; padding:0 4px; line-height:1.2; font-weight:900; text-transform:uppercase; }

/* ── TRADE BOARD ─────────────────────────────────────────── */
.ftc-trade-post-form { background:rgba(0,0,0,0.3); border:1px solid rgba(255,255,255,0.08); border-radius:14px; padding:16px 18px; margin-bottom:16px; }
.ftc-trade-form-row { display:flex; align-items:flex-end; gap:12px; flex-wrap:wrap; }
.ftc-trade-form-group { display:flex; flex-direction:column; gap:5px; flex:1; min-width:140px; }
.ftc-trade-form-group label { font-family:'AvantGarde-Bold',sans-serif; font-size:0.6rem; letter-spacing:1.5px; text-transform:uppercase; color:#666; font-weight:900; }
.ftc-trade-arrow-label { font-size:1.4rem; color:var(--ftc-accent); padding-bottom:4px; flex-shrink:0; }
.ftc-select { background:#111; border:1px solid #333; color:#ccc; padding:10px 12px; border-radius:10px; font-family:'AvantGarde-Bold',sans-serif; font-size:0.65rem; font-weight:900; letter-spacing:0.5px; width:100%; }
.ftc-select:focus { border-color:var(--ftc-accent); outline:none; }

.ftc-trade-item { background:rgba(0,0,0,0.4); border:1px solid rgba(255,255,255,0.08); border-radius:12px; padding:14px 18px; margin-bottom:8px; display:flex; justify-content:space-between; align-items:center; gap:10px; flex-wrap:wrap; }
.ftc-trade-side { display:flex; flex-direction:column; gap:2px; }
.ftc-trade-side-label { font-family:'AvantGarde-Bold',sans-serif; font-size:0.55rem; letter-spacing:1.5px; text-transform:uppercase; color:#555; font-weight:900; }
.ftc-trade-card-name  { font-family:'AvantGarde-Bold',sans-serif; font-size:0.9rem; font-weight:900; text-transform:uppercase; }
.ftc-trade-meta  { font-size:0.6rem; color:#555; }
.ftc-trade-arrow { font-size:1.3rem; color:var(--ftc-accent); flex-shrink:0; }
.ftc-coming-soon { display:inline-block; background:rgba(179,136,255,0.1); border:1px solid var(--ftc-icon); color:var(--ftc-icon); padding:2px 8px; border-radius:5px; font-family:'AvantGarde-Bold',sans-serif; font-size:0.55rem; letter-spacing:1.5px; text-transform:uppercase; margin-left:8px; font-weight:900; }

/* ── VERSION LOG ─────────────────────────────────────────── */
.ftc-patch-version { margin-bottom:22px; }
.ftc-patch-ver-label { font-family:'AvantGarde-Bold',sans-serif; font-size:0.8rem; color:var(--ftc-gold); letter-spacing:1px; margin-bottom:8px; text-transform:uppercase; font-weight:900; }
.ftc-patch-ver-sub { color:#555; font-size:0.7rem; }
.ftc-patch-list { margin:0; padding-left:18px; }
.ftc-patch-list li { color:#aaa; font-size:0.75rem; line-height:1.8; border-bottom:1px solid rgba(255,255,255,0.04); padding-bottom:3px; }
.ftc-patch-list li:last-child { border-bottom:none; }

/* ── FOOTER ──────────────────────────────────────────────── */
.ftc-footer-card { margin-top:24px; padding:18px; background:var(--ftc-card); border-radius:24px; border:1px solid rgba(255,255,255,0.12); backdrop-filter:blur(15px); -webkit-backdrop-filter:blur(15px); max-width:960px; width:100%; display:flex; flex-direction:column; align-items:center; text-align:center; gap:6px; box-sizing:border-box; }

/* ── TOAST NOTIFICATIONS ─────────────────────────────────── */
.ftc-toast {
    position: fixed; bottom: 30px; left: 50%; transform: translateX(-50%);
    background: rgba(0,0,0,0.9); border: 1px solid var(--ftc-accent);
    color: var(--ftc-accent); padding: 10px 22px; border-radius: 10px;
    font-family: 'AvantGarde-Bold', sans-serif; font-size: 0.7rem;
    letter-spacing: 1.5px; text-transform: uppercase; font-weight: 900;
    z-index: 99999; opacity: 0;
    animation: ftcToast 3s ease forwards;
    backdrop-filter: blur(12px);
}
@keyframes ftcToast {
    0%   { opacity:0; transform:translateX(-50%) translateY(10px); }
    15%  { opacity:1; transform:translateX(-50%) translateY(0); }
    75%  { opacity:1; transform:translateX(-50%) translateY(0); }
    100% { opacity:0; transform:translateX(-50%) translateY(-5px); }
}

/* ── MOBILE HUD BAR ─────────────────────────────────────── */
/* Hidden on desktop — shown only via @media ≤480px below */
#ftc-mobile-hud,
#ftc-mobile-user-menu,
#ftc-mobile-col-panel { display: none !important; }

@media (max-width: 480px) {
    /* Hide WP admin bar entirely on mobile — replaced by bottom bar */
    #wpadminbar { display: none !important; }
    html { margin-top: 0 !important; }

    /* Extra bottom padding so content clears the 52px mobile bar */
    #ftc-body { padding: 0 14px 72px; box-sizing: border-box; }

    .ftc-title-container { margin-top: 16px !important; }
    .ftc-title-container h1 { font-size: clamp(2.2rem,13vw,3.2rem); }
    .ftc-subtitle { font-size: 0.85rem !important; }
    .ftc-panel-card { padding: 18px 14px; border-radius: 20px; }
    .ftc-card-grid { grid-template-columns: repeat(auto-fill, minmax(140px,1fr)); gap: 12px; }
    .ftc-pack-card-slot { width: 130px; }
    .ftc-pack-reveal-row { gap: 8px; }
    .ftc-collection-grid { grid-template-columns: repeat(auto-fill, minmax(70px,1fr)); gap:6px; }

    /* ── MOBILE HUD BAR ── */
    #ftc-mobile-hud {
        display: flex !important;
        position: fixed;
        bottom: 0; left: 0; right: 0;
        height: 52px;
        background: rgba(10,10,10,0.96);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        border-top: 1px solid rgba(255,255,255,0.08);
        z-index: 99998;
        align-items: center;
        padding: 0 16px;
        box-sizing: border-box;
        gap: 8px;
        font-family: 'AvantGarde-Bold', sans-serif;
        font-size: 11px;
        color: #eee;
    }
    .ftc-mhud-group  { display: flex; align-items: center; gap: 4px; white-space: nowrap; flex-shrink: 0; }
    .ftc-mhud-val    { color: #fff; font-size: 13px; font-weight: 900; }
    .ftc-mhud-sub    { color: #666; font-size: 10px; }
    .ftc-mhud-spacer { flex: 1; }
    .ftc-mhud-pack-ready { display: inline-flex; align-items: center; gap: 5px; color: #12E200; font-size: 10px; font-weight: 900; }
    .ftc-mhud-countdown  { color: var(--ftc-gold); font-size: 10px; font-weight: 900; }
    .ftc-mhud-btn {
        display: flex; align-items: center; justify-content: center;
        width: 40px; height: 40px;
        background: rgba(255,255,255,0.06);
        border: 1px solid rgba(255,255,255,0.1);
        border-radius: 10px;
        cursor: pointer; font-size: 18px;
        text-decoration: none; color: #eee;
        flex-shrink: 0; transition: background 0.15s;
    }
    .ftc-mhud-btn:hover, .ftc-mhud-btn:active { background: rgba(255,255,255,0.14); }
    .ftc-mhud-login { color: var(--ftc-gold) !important; border-color: rgba(255,204,0,0.35) !important; }

    /* ── MOBILE USER MENU ── */
    #ftc-mobile-user-menu {
        position: fixed; bottom: 60px; right: 12px;
        background: rgba(18,18,18,0.98);
        border: 1px solid rgba(255,255,255,0.12);
        border-radius: 14px; padding: 8px 0;
        z-index: 99999; min-width: 160px;
        box-shadow: 0 -8px 24px rgba(0,0,0,0.6);
        backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    }
    #ftc-mobile-user-menu.open { display: block !important; }
    .ftc-mum-name {
        font-family: 'AvantGarde-Bold', sans-serif;
        font-size: 0.65rem; color: var(--ftc-gold); letter-spacing: 1px;
        padding: 8px 16px 10px; border-bottom: 1px solid rgba(255,255,255,0.07);
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .ftc-mum-item {
        display: block; padding: 10px 16px;
        font-family: 'AvantGarde-Bold', sans-serif;
        font-size: 0.7rem; letter-spacing: 1px; color: #ccc; text-decoration: none;
        transition: background 0.15s, color 0.15s;
    }
    .ftc-mum-item:hover, .ftc-mum-item:active { background: rgba(255,255,255,0.07); color: #fff; }
    .ftc-mum-logout { color: #ff6b6b !important; }
    .ftc-mum-logout:hover { background: rgba(255,80,80,0.08) !important; }

    /* ── MOBILE COLLECTORS PANEL ── */
    #ftc-mobile-col-panel {
        position: fixed; bottom: 52px; left: 0; right: 0;
        max-height: 60vh;
        background: rgba(13,13,13,0.97);
        backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
        border-top: 1px solid rgba(255,255,255,0.1);
        border-radius: 20px 20px 0 0;
        z-index: 99997; overflow-y: auto;
        padding: 20px 20px 12px; box-sizing: border-box;
    }
    #ftc-mobile-col-panel.open { display: block !important; }
    .ftc-mob-panel-head {
        display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px;
    }
    .ftc-mob-panel-head > span {
        font-family: 'AvantGarde-Bold', sans-serif;
        font-size: 0.75rem; color: var(--ftc-accent); letter-spacing: 2px; text-transform: uppercase;
    }
    .ftc-mob-panel-head > button {
        background: transparent; border: 1px solid #333; color: #888;
        padding: 4px 10px; border-radius: 8px;
        font-size: 0.65rem; cursor: pointer;
        font-family: 'AvantGarde-Bold', sans-serif; letter-spacing: 1px;
    }
    .ftc-mob-col-list { list-style: none; margin: 0; padding: 0; }
    .ftc-mob-col-list li {
        display: flex; align-items: center; gap: 8px;
        padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,0.05); font-size: 11px;
    }
    .ftc-mob-col-medal { font-size: 14px; width: 20px; flex-shrink: 0; }
    .ftc-mob-col-name  { flex: 1; color: #ccc; font-family: 'AvantGarde-Bold', sans-serif; font-weight: 900; font-size: 10px; }
    .ftc-mob-col-you   { color: #fff !important; }
    .ftc-mob-col-stat  { color: #888; font-size: 10px; white-space: nowrap; }
    .ftc-mob-col-empty { color: #555; font-size: 10px; font-style: italic; padding: 8px 0; }
}



/* ══════════════════════════════════════════════════════════
   THEME OVERRIDES — suppress Feeder.ROCKS theme chrome
   on the Find the Colour page
   ══════════════════════════════════════════════════════════ */

/* Hide theme header (logo + nav) on the TCG page */
body:has(#ftc-body) .site-header,
body:has(#ftc-body) .site-branding,
body:has(#ftc-body) .main-navigation,
body:has(#ftc-body) header.site-header,
body:has(#ftc-body) #masthead,
body:has(#ftc-body) .entry-header,
body:has(#ftc-body) .page-header,
body:has(#ftc-body) h1.entry-title,
body:has(#ftc-body) h1.page-title,
body:has(#ftc-body) .site-footer,
body:has(#ftc-body) footer.site-footer,
body:has(#ftc-body) #colophon {
    display: none !important;
}

/* Remove theme page padding/margin so game fills the viewport */
body:has(#ftc-body) .site-content,
body:has(#ftc-body) .content-area,
body:has(#ftc-body) .entry-content,
body:has(#ftc-body) main.site-main,
body:has(#ftc-body) #primary,
body:has(#ftc-body) #content,
body:has(#ftc-body) .container,
body:has(#ftc-body) .page-content {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    background: transparent !important;
}

/* Force dark background on body itself */
body:has(#ftc-body) {
    background: #000 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── STRENGTHEN GLASSMORPHISM against theme interference ── */
#ftc-body .ftc-panel-card {
    background: rgba(0,0,0,0.65) !important;
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    border-radius: 28px !important;
}

#ftc-body .ftc-footer-card {
    background: rgba(0,0,0,0.65) !important;
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    border-radius: 24px !important;
}

/* Ensure concert background renders above theme background */
#ftc-body {
    position: relative !important;
    z-index: 1 !important;
    min-height: 100vh !important;
}

#ftc-body::before {
    content: "" !important;
    position: fixed !important;
    top: 0 !important; left: 0 !important;
    width: 100% !important; height: 100% !important;
    background-image: url('/feedheardle/feeder-parts/feeder_comfortinsound_live-scaled.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
    filter: brightness(0.45) !important;
    z-index: -1 !important;
}

/* ── FONT OVERRIDES — ensure AvantGarde wins over theme fonts ── */
#ftc-body h1,
#ftc-body .ftc-subtitle,
#ftc-body .ftc-nav-tab,
#ftc-body .ftc-rarity-btn,
#ftc-body .ftc-panel-heading,
#ftc-body .ftc-btn {
    font-family: 'AvantGarde-Bold', 'Helvetica Neue', Arial, sans-serif !important;
}

/* Make sure theme doesn't inject its own h1 styles into our title */
#ftc-body .ftc-title-container h1 {
    font-size: clamp(2.2rem, 12vw, 5.5rem) !important;
    color: #fff !important;
    text-shadow: 3px 3px 0 #000 !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: none !important;
}

/* Subtitle position fix — sits below h1 */
#ftc-body .ftc-title-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

#ftc-body .ftc-subtitle {
    margin-top: 4px !important;
    width: 100% !important;
    text-align: right !important;
}


/* ── TITLE LAYOUT FIX — one line, subtitle centred below ── */
#ftc-body .ftc-title-container h1 {
    white-space: nowrap !important;
    font-size: clamp(2.2rem, 10vw, 5.5rem) !important;
    text-align: center !important;
}

#ftc-body .ftc-title-box {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    width: 100% !important;
}

#ftc-body .ftc-subtitle {
    text-align: center !important;
    width: auto !important;
    transform: skewX(-15deg) !important;
    margin-top: 2px !important;
}

/* ── HUD BAR — centred, matching Feedheardle ── */
#wp-admin-bar-ftc-hud {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
}


/* ── FIND THE COLOUR SINGLE COVER GRADIENT TITLE ── */
#ftc-body .ftc-title-container h1 {
    background: linear-gradient(
        to bottom,
        #ffffff 0%,
        #d4d0e8 20%,
        #9b8fd4 40%,
        #6b5bb0 60%,
        #4a3d8f 80%,
        #2d2460 100%
    ) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    text-shadow: none !important;
    filter: drop-shadow(2px 2px 4px rgba(0,0,0,0.8)) !important;
}

/* ── HUD BAR CENTRE FIX (stronger specificity) ── */
#wpadminbar #wp-admin-bar-ftc-hud,
#wpadminbar li#wp-admin-bar-ftc-hud {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    float: none !important;
}

#wpadminbar #wp-admin-bar-ftc-hud > .ab-item {
    padding: 0 10px !important;
}



/* ── FIND THE COLOUR — STACKED REPEAT TITLE (single cover style) ── */

#ftc-body .ftc-title-container h1 {
    display: none !important;
}

#ftc-body .ftc-title-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    margin: 0;
    line-height: 0.88;
}

/* Each line is a coloured block of text — colour set directly, no gradient clip */
#ftc-body .ftc-title-stack .ftc-stack-line {
    font-family: 'AvantGarde-Bold', 'Helvetica Neue', Arial, sans-serif !important;
    font-weight: 900 !important;
    font-size: clamp(1.6rem, 8.5vw, 4.8rem) !important;
    text-transform: uppercase !important;
    letter-spacing: -0.01em !important;
    white-space: nowrap !important;
    line-height: 0.92 !important;
    display: block !important;
    -webkit-text-fill-color: unset !important;
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
}

/* Each line gets a solid colour progressing purple → blue top to bottom */
#ftc-body .ftc-stack-line:nth-child(1) { color: #7030a0 !important; }
#ftc-body .ftc-stack-line:nth-child(2) { color: #8b2d9e !important; }
#ftc-body .ftc-stack-line:nth-child(3) { color: #4040aa !important; }
#ftc-body .ftc-stack-line:nth-child(4) { color: #1a66cc !important; }
#ftc-body .ftc-stack-line:nth-child(5) { color: #2090e0 !important; }

/* Reflection: flip + fade using mask */
#ftc-body .ftc-stack-line.ftc-stack-fade {
    color: #2090e0 !important;
    transform: scaleY(-0.55) !important;
    transform-origin: top center !important;
    margin-top: -3px !important;
    -webkit-mask-image: linear-gradient(to bottom, rgba(255,255,255,0.4) 0%, transparent 100%) !important;
    mask-image: linear-gradient(to bottom, rgba(255,255,255,0.4) 0%, transparent 100%) !important;
}


/* ── TITLE SIZE FIX + REFLECTION ── */
#ftc-body .ftc-title-stack .ftc-stack-line {
    font-size: clamp(1.2rem, 6vw, 3.8rem) !important;
}

/* Reflection line — show it properly */
#ftc-body .ftc-stack-line.ftc-stack-fade {
    display: block !important;
    color: #2090e0 !important;
    transform: scaleY(-0.5) !important;
    transform-origin: top center !important;
    margin-top: -4px !important;
    opacity: 0.35 !important;
    -webkit-mask-image: linear-gradient(to bottom, rgba(255,255,255,1) 0%, transparent 80%) !important;
    mask-image: linear-gradient(to bottom, rgba(255,255,255,1) 0%, transparent 80%) !important;
}

/* ── HUD CENTRE FIX — stronger override ── */
#wpadminbar ul#wp-admin-bar-root-default > li#wp-admin-bar-ftc-hud {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    float: none !important;
}


/* ── TITLE FINAL FIX ── */

/* Push the whole game up to the top */
#ftc-body {
    padding-top: 10px !important;
    justify-content: flex-start !important;
}

#ftc-body .ftc-title-container {
    margin-top: 40px !important;
    margin-bottom: 10px !important;
}

/* Size — bigger, fills width nicely */
#ftc-body .ftc-title-stack .ftc-stack-line {
    font-size: clamp(2rem, 9.5vw, 5.2rem) !important;
    line-height: 0.94 !important;
}

/* Reflection — scoped tightly, fades from 40% opacity to 0 */
#ftc-body .ftc-title-stack .ftc-stack-line.ftc-stack-fade {
    font-size: clamp(2rem, 9.5vw, 5.2rem) !important;
    color: #2090e0 !important;
    transform: scaleY(-0.5) translateY(0) !important;
    transform-origin: top center !important;
    margin-top: -6px !important;
    opacity: 1 !important;
    -webkit-mask-image: linear-gradient(to bottom, rgba(255,255,255,0.38) 0%, rgba(255,255,255,0) 75%) !important;
    mask-image: linear-gradient(to bottom, rgba(255,255,255,0.38) 0%, rgba(255,255,255,0) 75%) !important;
}


/* ── CANVAS TITLE — hide the HTML stack, show canvas instead ── */
#ftc-body .ftc-title-stack {
    display: none !important;
}

#ftc-body #ftcTitleCanvas {
    display: block;
    width: 100%;
    max-width: 960px;
    height: auto;
    margin: 0 auto;
}


/* ── PUSH CONTENT TO TOP ── */
#ftc-body {
    padding-top: 6px !important;
    justify-content: flex-start !important;
    align-items: center !important;
}

#ftc-body .ftc-title-container {
    margin-top: 40px !important;
    margin-bottom: 8px !important;
    padding-top: 0 !important;
}



/* ── ADMIN BAR CLEANUP — icons only, remove clutter ── */

/* "Feeder.ROCKS" text — keep the WP logo icon, hide the site name */
#wpadminbar #wp-admin-bar-site-name > .ab-item {
    font-size: 0 !important;
    padding: 0 8px !important;
}
#wpadminbar #wp-admin-bar-site-name .ab-icon {
    font-size: 20px !important;
    margin-right: 0 !important;
}

/* Hide "Edit Site" entirely — it's Gutenberg site editor, not needed */
#wpadminbar #wp-admin-bar-site-editor { display: none !important; }

/* Hide comments icon/link */
#wpadminbar #wp-admin-bar-comments { display: none !important; }

/* Hide "+ New" */
#wpadminbar #wp-admin-bar-new-content { display: none !important; }

/* Hide "Edit Page" */
#wpadminbar #wp-admin-bar-edit { display: none !important; }


/* ── FORCE CONTENT TO TOP ── */
#ftc-body,
#ftc-body .ftc-game-wrap,
#ftc-body .ftc-container {
    justify-content: flex-start !important;
    align-items: center !important;
    min-height: unset !important;
}

#ftc-body {
    padding-top: 8px !important;
    display: flex !important;
    flex-direction: column !important;
}

#ftc-body .ftc-title-container,
#ftc-body #ftcTitleCanvas {
    padding-top: 0 !important;
}
#ftc-body .ftc-title-container {
    margin-top: 40px !important;
}



/* ── REMOVE BACKGROUND IMAGE ── */
#ftc-body::before {
    background-image: none !important;
    display: none !important;
}

/* ── FORCE CONTENT TO TOP ── */
#ftc-body {
    min-height: unset !important;
    height: auto !important;
    padding-top: 6px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
}

.ftc-game-wrap,
.ftc-container,
.ftc-main {
    justify-content: flex-start !important;
    align-items: center !important;
    min-height: unset !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
}



/* ── WHITE BACKGROUND ── */
#ftc-body {
    background: #ffffff !important;
}
#ftc-body::before {
    display: none !important;
}

/* ── HIDE STRAY THEME ELEMENTS ── */
/* "Feeder.ROCKS" site title top left */
body:has(#ftc-body) .site-title,
body:has(#ftc-body) .site-description,
body:has(#ftc-body) #site-title,
body:has(#ftc-body) .custom-logo-link,
body:has(#ftc-body) .site-branding { display: none !important; }

/* "Find the Colour" page title top right and inline */
body:has(#ftc-body) .entry-title,
body:has(#ftc-body) h1.page-title,
body:has(#ftc-body) .page-header,
body:has(#ftc-body) .wp-block-post-title,
body:has(#ftc-body) h1:not(#ftcTitleCanvas ~ *):not(.ftc-stack-line) { display: none !important; }


/* ── OUTER PAGE BACKGROUND — white to match plugin area ── */
html, body {
    background: #ffffff !important;
}

body:has(#ftc-body) {
    background: #ffffff !important;
}

/* ── HIDE STRAY THEME TEXT — stronger selectors ── */
body:has(#ftc-body) .site-branding,
body:has(#ftc-body) .site-title,
body:has(#ftc-body) .site-description,
body:has(#ftc-body) #masthead .site-branding *,
body:has(#ftc-body) .custom-logo-link { 
    display: none !important; 
    visibility: hidden !important;
}

/* "Find the Colour" top right — this is likely the page nav/menu item */
body:has(#ftc-body) .main-navigation,
body:has(#ftc-body) .nav-menu,
body:has(#ftc-body) #site-navigation,
body:has(#ftc-body) header nav { 
    display: none !important; 
}


/* ════════════════════════════════════════════════════════
   WHITE THEME OVERHAUL — complements the single artwork
   ════════════════════════════════════════════════════════ */

/* ── Tighter line spacing on canvas title ── */
/* (handled in JS — see ftc-game.js lineH) */

/* ── "Trading Card Game" subtitle ── */
#ftc-body .ftc-subtitle,
#ftc-body .ftc-subtitle * {
    font-family: 'AvantGarde-Bold', 'Helvetica Neue', Arial, sans-serif !important;
    font-style: normal !important;
    font-weight: 900 !important;
    font-size: 1.1rem !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: #111 !important;
    -webkit-text-fill-color: #111 !important;
    text-align: center !important;
    width: 100% !important;
    display: block !important;
    transform: none !important;
    margin-top: 6px !important;
    padding-right: 0 !important;
}

/* ── Nav tabs — clean black/grey on white ── */
#ftc-body .ftc-nav-tab {
    background: transparent !important;
    border: 1.5px solid #ccc !important;
    color: #555 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
#ftc-body .ftc-nav-tab:hover {
    border-color: #333 !important;
    color: #111 !important;
    background: rgba(0,0,0,0.05) !important;
}
#ftc-body .ftc-nav-tab.active {
    background: #111 !important;
    border-color: #111 !important;
    color: #fff !important;
}

/* ── Rarity filter buttons — clean on white ── */
#ftc-body .ftc-rarity-btn {
    background: transparent !important;
    border: 1.5px solid #ddd !important;
    color: #777 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
#ftc-body .ftc-rarity-btn:hover {
    border-color: #999 !important;
    color: #333 !important;
}
#ftc-body .ftc-rarity-btn.active.f-all {
    background: #111 !important; border-color: #111 !important; color: #fff !important;
}
#ftc-body .ftc-rarity-btn.active[data-rarity="bronze"]   { background: rgba(205,127,50,0.12)  !important; border-color: #cd7f32 !important; color: #a0631e !important; }
#ftc-body .ftc-rarity-btn.active[data-rarity="silver"]   { background: rgba(120,120,120,0.1)  !important; border-color: #888 !important;    color: #555 !important; }
#ftc-body .ftc-rarity-btn.active[data-rarity="gold"]     { background: rgba(200,160,0,0.1)    !important; border-color: #b8960a !important; color: #8a6f00 !important; }
#ftc-body .ftc-rarity-btn.active[data-rarity="platinum"] { background: rgba(80,80,120,0.08)   !important; border-color: #6060a0 !important; color: #4a4a80 !important; }
#ftc-body .ftc-rarity-btn.active[data-rarity="icon"]     { background: rgba(100,60,180,0.1)   !important; border-color: #6040b0 !important; color: #4a2a90 !important; }

/* ── Main panel card — clean white card ── */
#ftc-body .ftc-panel-card {
    background: #f8f8f8 !important;
    border: 1px solid #e0e0e0 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
}

/* ── Panel heading ── */
#ftc-body .ftc-panel-heading {
    color: #111 !important;
    border-bottom: 1px solid #e0e0e0 !important;
}

/* ── Footer card ── */
#ftc-body .ftc-footer-card {
    background: #f0f0f0 !important;
    border: 1px solid #ddd !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
#ftc-body .ftc-footer-card * { color: #555 !important; }
#ftc-body .ftc-footer-card a { color: #3060a0 !important; }

/* ── General text on white background ── */
#ftc-body .ftc-empty-state,
#ftc-body .ftc-no-cards { color: #999 !important; }


/* ── CONSTRAIN CANVAS WIDTH + TOP PADDING ── */
#ftc-body {
    padding: 12px 16px 0 !important;
}

#ftc-body #ftcTitleCanvas {
    max-width: 700px !important;
    width: 100% !important;
}

#ftc-body .ftc-title-container {
    width: 100% !important;
    max-width: 700px !important;
    margin-top: 40px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-bottom: 0 !important;
}

/* ══════════════════════════════════════════════════════════
   DEFINITIVE OVERRIDES — appended last, always wins
   Fixes accumulated conflicts from earlier rule layers.
   ══════════════════════════════════════════════════════════ */

/* Gap: match Feedheardle's visual spacing between admin bar
   and "Feeder.ROCKS presents". Feedheardle = body padding 20px
   + title-container margin-top 20px. FTC is a shortcode so we
   push via padding-top on #ftc-body directly. */
#ftc-body {
    padding-top: 40px !important;
}

/* Subtitle: 1.1rem — larger than nav tabs (0.65rem), smaller than title */
#ftc-body .ftc-subtitle,
#ftc-body .ftc-subtitle * {
    font-size: 1.1rem !important;
    color: #111 !important;
    -webkit-text-fill-color: #111 !important;
}

/* ── DEFINITIVE GAP RULE — must stay last in file ────────
   All earlier margin-top overrides are neutralised here.
   40px matches Feedheardle's body padding-top gap exactly. */
#ftc-body .ftc-title-container {
    margin-top: 40px !important;
    padding-top: 0 !important;
}