/* =====================================================================
 * GAMEDETAIL — paleta alinhada a /perfil/meus-dados
 * Tokens:
 *   --gd-bg-card        #212129     fundo dos cards
 *   --gd-bg-sub         #181c24     sub-cards / inputs
 *   --gd-bg-deeper      #1f2531     ainda mais escuro (form)
 *   --gd-border         rgba(77,171,247,.08)
 *   --gd-border-strong  rgba(77,171,247,.18)
 *   --gd-text           #ffffff
 *   --gd-text-soft      #c7c7c7
 *   --gd-text-mute      #8b94a3
 *   --gd-accent         #01d5fa     CTA primário
 *   --gd-accent-ink     #313144     texto sobre cyan
 *   --gd-success        #00d189
 *   --gd-warn           #ffb648
 *   --gd-danger         #ef4444
 * Prefixo .gd-* — isolado do CSS legado
 * ===================================================================== */
:root {
    --gd-bg-card: #212129;
    --gd-bg-sub: #181c24;
    --gd-bg-deeper: #1f2531;
    --gd-border: rgba(77, 171, 247, .08);
    --gd-border-strong: rgba(77, 171, 247, .18);
    --gd-text: #ffffff;
    --gd-text-soft: #c7c7c7;
    --gd-text-mute: #8b94a3;
    --gd-accent: #01d5fa;
    --gd-accent-ink: #313144;
    --gd-success: #00d189;
    --gd-warn: #ffb648;
    --gd-danger: #ef4444;
    --gd-shadow: 0 20px 40px rgba(12, 15, 24, .35);
}

.gd-page { padding: 24px 16px 80px; color: var(--gd-text); }
@media (min-width: 992px) {
    .gd-page { padding: 32px 24px 48px; }
}

.gd-alert { margin-bottom: 16px; }

/* ----- Breadcrumb ----- */
.gd-breadcrumb { margin-bottom: 16px; }
.gd-breadcrumb .breadcrumb { background: transparent; padding: 0; margin: 0; font-size: .875rem; }
.gd-breadcrumb a { color: var(--gd-text-mute); text-decoration: none; }
.gd-breadcrumb a:hover { color: var(--gd-accent); }
.gd-breadcrumb .breadcrumb-item.active { color: var(--gd-text-soft); }
.gd-breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: #4a5161; }

/* ----- Grid ----- */
.gd-grid { gap: 0; }
.gd-left  { display: flex; flex-direction: column; gap: 20px; }
.gd-right { display: flex; flex-direction: column; }

/* =====================================================================
 * HERO
 * ===================================================================== */
.gd-hero {
    display: grid;
    grid-template-columns: minmax(220px, 320px) 1fr;
    gap: 24px;
    background: var(--gd-bg-card);
    border: 1px solid var(--gd-border);
    border-radius: 10px;
    padding: 24px;
    box-shadow: var(--gd-shadow);
    position: relative;
    /* sem overflow:hidden — dropdown de compartilhar precisa escapar do card */
}
@media (max-width: 767.98px) {
    .gd-hero { grid-template-columns: 1fr; text-align: center; padding: 18px; }
}

/* Dropdown de compartilhar — força sair por cima de qualquer container */
.gd-share-wrap { position: relative; }
.gd-share-menu { z-index: 1080; min-width: 220px; }

.gd-hero-cover {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    aspect-ratio: 3/4;
    box-shadow: 0 12px 28px rgba(0, 0, 0, .35);
}
.gd-hero-cover.is-unavailable .gd-cover-img { filter: grayscale(.7) opacity(.6); }
.gd-cover-img { width: 100%; height: 100%; object-fit: cover; display: block; }

.gd-unavailable-tag {
    position: absolute; bottom: 12px; left: 12px; right: 12px;
    background: rgba(239, 68, 68, .9); color: #fff;
    padding: 8px 12px; border-radius: 6px;
    font-size: .75rem; font-weight: 600; text-align: center;
    backdrop-filter: blur(4px);
}

.gd-hero-info { display: flex; flex-direction: column; gap: 14px; min-width: 0; }
@media (max-width: 767.98px) { .gd-hero-info { align-items: center; } }

.gd-hero-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.gd-tag {
    display: inline-flex; align-items: center;
    padding: 4px 10px; border-radius: 999px;
    font-size: .7rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: .03em;
}
.gd-tag-platform { background: rgba(1, 213, 250, .12); color: var(--gd-accent); border: 1px solid rgba(1, 213, 250, .25); }
.gd-tag-cat      { background: rgba(255, 255, 255, .04); color: var(--gd-text-soft); border: 1px solid var(--gd-border-strong); }

.gd-title {
    font-size: clamp(1.5rem, 4vw, 2.2rem);
    font-weight: 800;
    margin: 0;
    color: var(--gd-text);
    line-height: 1.18;
    word-break: break-word;
}

.gd-meta-row {
    display: flex; flex-wrap: wrap; gap: 14px; align-items: center;
    color: var(--gd-text-soft); font-size: .9rem;
}
.gd-meta-item, .gd-rating { display: inline-flex; align-items: center; gap: 6px; }
.gd-meta-item i { color: var(--gd-text-mute); }
.gd-rating i { color: var(--gd-warn); }
.gd-rating strong { font-size: 1.05rem; color: var(--gd-warn); }

.gd-availability { padding: 4px 10px; border-radius: 6px; font-size: .8rem; }
.gd-availability-disponivel   { background: rgba(0, 209, 137, .14); color: var(--gd-success); }
.gd-availability-indisponivel { background: rgba(239, 68, 68, .14); color: #f87171; }

.gd-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 4px; }

/* Info técnica embutida no hero (ao lado da capa, abaixo do compartilhar) */
.gd-hero-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    margin-top: 6px;
}
.gd-hero-info-grid .gd-info-item {
    padding: 6px 9px;
    gap: 1px;
    border-radius: 6px;
}
.gd-hero-info-grid .gd-info-label {
    font-size: .62rem;
    letter-spacing: .04em;
    line-height: 1.2;
}
.gd-hero-info-grid .gd-info-label i { margin-right: 4px; font-size: .7rem; }
.gd-hero-info-grid .gd-info-value {
    font-size: .78rem;
    line-height: 1.25;
}
@media (max-width: 575.98px) {
    .gd-hero-info-grid { grid-template-columns: 1fr; }
}
.gd-fav-btn, .gd-share-btn {
    border-radius: 999px;
    font-size: .85rem;
    padding: 8px 18px;
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--gd-bg-sub);
    border: 1px solid var(--gd-border);
    color: var(--gd-text-soft);
}
.gd-fav-btn:hover, .gd-share-btn:hover { color: var(--gd-text); border-color: var(--gd-border-strong); }
.gd-fav-btn.is-fav { background: rgba(1, 213, 250, .12); color: var(--gd-accent); border-color: rgba(1, 213, 250, .35); }
.gd-share-menu { background: var(--gd-bg-card); border: 1px solid var(--gd-border-strong); }
.gd-share-menu .dropdown-item { color: var(--gd-text-soft); padding: 8px 14px; display: flex; align-items: center; gap: 10px; }
.gd-share-menu .dropdown-item:hover { background: rgba(1, 213, 250, .12); color: var(--gd-text); }
.gd-share-menu .dropdown-divider { border-color: var(--gd-border); }

/* =====================================================================
 * SECTION genérica
 * ===================================================================== */
.gd-section {
    background: var(--gd-bg-card);
    border: 1px solid var(--gd-border);
    border-radius: 10px;
    padding: 22px 22px;
    box-shadow: var(--gd-shadow);
}
.gd-section-title {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 16px;
    color: var(--gd-text-soft);
    display: flex; align-items: center; gap: 10px;
}
.gd-section-title i { color: var(--gd-accent); }

/* ----- Trailer (altura fixa, responsiva) ----- */
.gd-video-wrap {
    border-radius: 10px;
    overflow: hidden;
    background: #000;
    height: 420px;
}
.gd-video-wrap iframe { width: 100%; height: 100%; display: block; }
@media (max-width: 991.98px) { .gd-video-wrap { height: 340px; } }
@media (max-width: 575.98px) { .gd-video-wrap { height: 220px; } }

/* ----- Info técnica ----- */
.gd-info-grid { margin: 0; }
.gd-info-item {
    background: var(--gd-bg-sub);
    border: 1px solid var(--gd-border);
    border-radius: 8px;
    padding: 12px 14px;
    display: flex; flex-direction: column; gap: 4px;
    height: 100%;
}
.gd-info-label { font-size: .72rem; color: var(--gd-text-mute); text-transform: uppercase; letter-spacing: .05em; }
.gd-info-label i { margin-right: 6px; color: var(--gd-accent); }
.gd-info-value { color: var(--gd-text); font-weight: 600; word-break: break-word; }

/* ----- Descrição ----- */
.gd-description-text { color: var(--gd-text-soft); line-height: 1.7; font-size: 1rem; }

/* =====================================================================
 * REVIEWS
 * ===================================================================== */
.gd-reviews-summary {
    display: grid;
    grid-template-columns: minmax(140px, 200px) 1fr;
    gap: 22px;
    margin-bottom: 16px;
}
@media (max-width: 575.98px) { .gd-reviews-summary { grid-template-columns: 1fr; } }

.gd-reviews-score { text-align: center; padding: 16px; background: var(--gd-bg-sub); border: 1px solid var(--gd-border); border-radius: 10px; }
.gd-reviews-avg { font-size: 2.4rem; font-weight: 800; color: var(--gd-warn); line-height: 1; }
.gd-reviews-stars { display: inline-flex; gap: 2px; margin: 6px 0; }
.gd-star { color: #4b5365; font-size: 1rem; }
.gd-star.is-full { color: var(--gd-warn); }
.gd-star.is-half { color: var(--gd-warn); opacity: .5; }
.gd-reviews-count { font-size: .8rem; color: var(--gd-text-mute); }

.gd-reviews-bars { display: flex; flex-direction: column; gap: 6px; justify-content: center; }
.gd-review-bar { display: grid; grid-template-columns: 50px 1fr 36px; align-items: center; gap: 10px; font-size: .85rem; color: var(--gd-text-soft); }
.gd-review-bar-label { display: flex; align-items: center; gap: 4px; color: var(--gd-text-mute); }
.gd-review-bar-label i { color: var(--gd-warn); font-size: .7rem; }
.gd-review-bar-track { height: 8px; background: rgba(255, 255, 255, .05); border-radius: 4px; overflow: hidden; }
.gd-review-bar-fill { height: 100%; background: linear-gradient(90deg, #ffa620, var(--gd-warn)); border-radius: 4px; transition: width .3s; }
.gd-review-bar-count { text-align: right; color: var(--gd-text-mute); }

.gd-review-mine {
    border-top: 1px solid var(--gd-border);
    padding-top: 14px; margin-top: 8px;
    display: flex; flex-direction: column; gap: 8px; align-items: flex-start;
}
.gd-review-mine-label { color: var(--gd-text-soft); margin: 0; font-size: .9rem; }
.gd-rate-stars { display: inline-flex; gap: 4px; }
.gd-rate-star {
    background: transparent; border: 0; padding: 4px;
    cursor: pointer; color: #4b5365; font-size: 1.4rem;
    transition: transform .15s, color .15s;
}
.gd-rate-star:hover { transform: scale(1.15); }
.gd-rate-star.is-active, .gd-rate-star.is-hover { color: var(--gd-warn); }
.gd-rate-feedback { font-size: .8rem; color: var(--gd-text-mute); }

.gd-login-cta { color: var(--gd-text-soft); font-size: .9rem; margin: 0; }
.gd-login-cta a { color: var(--gd-accent); text-decoration: none; font-weight: 600; }
.gd-login-cta a:hover { text-decoration: underline; }

/* =====================================================================
 * COMENTÁRIOS
 * ===================================================================== */
.gd-comment-form { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.gd-comment-rate {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px;
    background: var(--gd-bg-sub);
    border: 1px solid var(--gd-border);
    border-radius: 8px;
    flex-wrap: wrap;
}
.gd-comment-rate-label { color: var(--gd-text-mute); font-size: .8rem; }
.gd-comment-rate-stars { display: inline-flex; gap: 2px; }
.gd-comment-rate-star {
    background: transparent; border: 0; padding: 2px;
    color: #4b5365; font-size: 1.05rem; cursor: pointer;
    transition: transform .12s, color .12s;
}
.gd-comment-rate-star:hover { transform: scale(1.15); }
.gd-comment-rate-star.is-active, .gd-comment-rate-star.is-hover { color: var(--gd-warn); }
.gd-comment-rate-clear {
    background: transparent; border: 0; color: var(--gd-text-mute); cursor: pointer;
    font-size: .85rem; padding: 4px 6px; border-radius: 4px;
}
.gd-comment-rate-clear:hover { color: var(--gd-danger); background: rgba(239, 68, 68, .08); }

.gd-comment-rating { display: inline-flex; align-items: center; gap: 3px; margin: 4px 0 6px; }
.gd-comment-rating .fa-star { color: #4b5365; font-size: .85rem; }
.gd-comment-rating .fa-star.is-active { color: var(--gd-warn); }
.gd-comment-rating-num { color: var(--gd-warn); font-size: .75rem; margin-left: 6px; font-weight: 600; }

.gd-comment-input {
    background: var(--gd-bg-deeper);
    border: 1px solid var(--gd-border);
    color: var(--gd-text);
    border-radius: 8px;
    resize: vertical;
}
.gd-comment-input:focus {
    background: var(--gd-bg-deeper);
    border-color: var(--gd-accent);
    box-shadow: 0 0 0 .2rem rgba(1, 213, 250, .15);
    color: var(--gd-text);
}
.gd-comment-input::placeholder { color: #4a5161; }
.gd-comment-actions { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.gd-comment-counter { font-size: .75rem; }

.gd-comments-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.gd-comments-empty {
    color: var(--gd-text-mute); padding: 16px; text-align: center; font-style: italic;
    background: var(--gd-bg-sub); border: 1px solid var(--gd-border); border-radius: 8px;
}
.gd-comment-item {
    background: var(--gd-bg-sub);
    border: 1px solid var(--gd-border);
    border-radius: 8px;
    padding: 14px 16px;
}
.gd-comment-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; gap: 12px; }
.gd-comment-author { color: var(--gd-accent); font-weight: 600; font-size: .9rem; display: inline-flex; align-items: center; gap: 6px; }
.gd-comment-date { color: var(--gd-text-mute); font-size: .75rem; }
.gd-comment-body { color: var(--gd-text); font-size: .95rem; line-height: 1.55; word-break: break-word; }
.gd-comment-foot {
    margin-top: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.gd-comment-like, .gd-comment-reply-toggle, .gd-comment-delete {
    background: transparent;
    border: 1px solid var(--gd-border);
    border-radius: 999px;
    color: var(--gd-text-mute);
    font-size: .78rem;
    padding: 4px 12px;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 6px;
    transition: background .12s, color .12s, border-color .12s;
}
.gd-comment-like:hover, .gd-comment-reply-toggle:hover { color: var(--gd-text); border-color: var(--gd-border-strong); }
.gd-comment-like:disabled { opacity: .55; cursor: default; }
.gd-comment-like.is-liked { background: rgba(239, 68, 68, .14); color: #ff8b8b; border-color: rgba(239, 68, 68, .35); }
.gd-comment-like.is-liked .fa-heart { color: var(--gd-danger); }
.gd-comment-like-count { font-weight: 600; }
.gd-comment-delete { color: var(--gd-danger); border-color: rgba(239, 68, 68, .25); }
.gd-comment-delete:hover { background: rgba(239, 68, 68, .12); border-color: rgba(239, 68, 68, .45); }

.gd-reply-form {
    margin-top: 10px;
    background: rgba(0, 0, 0, .12);
    border: 1px solid var(--gd-border);
    border-radius: 8px;
    padding: 10px 12px;
    display: flex; flex-direction: column; gap: 8px;
}
.gd-reply-input {
    background: var(--gd-bg-deeper);
    border: 1px solid var(--gd-border);
    color: var(--gd-text);
    border-radius: 6px;
    resize: vertical;
    padding: 8px 10px;
    font-size: .9rem;
}
.gd-reply-input:focus {
    outline: none;
    border-color: var(--gd-accent);
    box-shadow: 0 0 0 .15rem rgba(1, 213, 250, .15);
}
.gd-reply-actions { display: flex; justify-content: flex-end; gap: 8px; }
.gd-reply-cancel, .gd-reply-submit {
    border: 0; border-radius: 6px;
    font-size: .8rem; padding: 6px 14px; cursor: pointer; font-weight: 600;
}
.gd-reply-cancel { background: transparent; color: var(--gd-text-mute); }
.gd-reply-cancel:hover { color: var(--gd-text); }
.gd-reply-submit { background: var(--gd-accent); color: var(--gd-accent-ink); }
.gd-reply-submit:hover { filter: brightness(1.08); }
.gd-reply-submit:disabled { opacity: .6; cursor: default; }

.gd-comment-replies {
    list-style: none; padding-left: 14px; margin-top: 12px;
    border-left: 2px solid var(--gd-border-strong);
    display: flex; flex-direction: column; gap: 8px;
}
.gd-comment-item.is-reply { padding: 10px 14px; }

/* Header com sort */
.gd-comments-header {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 12px; margin-bottom: 16px;
}
.gd-comments-total { color: var(--gd-text-mute); font-weight: 500; }
.gd-comments-sort { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.gd-comments-sort-btn {
    background: var(--gd-bg-sub); border: 1px solid var(--gd-border);
    border-radius: 999px; padding: 5px 12px;
    font-size: .78rem; font-weight: 600;
    color: var(--gd-text-mute); cursor: pointer;
    display: inline-flex; align-items: center; gap: 6px;
    transition: background .12s, color .12s, border-color .12s;
}
.gd-comments-sort-btn:hover { color: var(--gd-text-soft); }
.gd-comments-sort-btn.is-active {
    background: rgba(1, 213, 250, .14);
    border-color: rgba(1, 213, 250, .4);
    color: var(--gd-accent);
}

/* Carregar mais */
.gd-comments-more { display: flex; justify-content: center; margin-top: 14px; }
.gd-comments-more-btn {
    background: var(--gd-bg-sub); border: 1px solid var(--gd-border);
    border-radius: 999px; color: var(--gd-text-soft);
    font-weight: 600; font-size: .85rem;
    padding: 8px 18px; cursor: pointer;
    display: inline-flex; align-items: center; gap: 8px;
}
.gd-comments-more-btn:hover { color: var(--gd-text); border-color: var(--gd-border-strong); background: rgba(255, 255, 255, .03); }
.gd-comments-more-btn:disabled { opacity: .55; cursor: default; }
.gd-comments-loading { text-align: center; color: var(--gd-text-mute); margin-top: 10px; font-size: .85rem; }

/* Info técnica — mais compacta no mobile (2 cols com col-6) */
@media (max-width: 575.98px) {
    .gd-info-item { padding: 10px 12px; }
    .gd-info-label { font-size: .65rem; }
    .gd-info-value { font-size: .85rem; }
}

/* =====================================================================
 * COLUNA DIREITA — JOGUE AGORA
 * ===================================================================== */
.gd-action-card { top: 96px; }
.gd-play-now {
    background: var(--gd-bg-card);
    border: 1px solid var(--gd-border-strong);
    border-radius: 10px;
    padding: 22px;
    box-shadow: var(--gd-shadow);
    position: relative;
    overflow: hidden;
}
.gd-play-now::before {
    content: '';
    position: absolute; top: -50%; right: -20%;
    width: 240px; height: 240px;
    background: radial-gradient(circle, rgba(1, 213, 250, .10), transparent 70%);
    pointer-events: none;
}
.gd-play-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; gap: 12px; }
.gd-play-title { font-size: 1.1rem; font-weight: 800; margin: 0; display: inline-flex; align-items: center; gap: 8px; color: var(--gd-text); }
.gd-play-title i { color: var(--gd-accent); }
.gd-play-badge { font-size: .7rem; padding: 4px 10px; border-radius: 999px; font-weight: 600; }
.gd-play-badge--ok   { background: rgba(0, 209, 137, .14); color: var(--gd-success); }
.gd-play-badge--warn { background: rgba(255, 182, 72, .14); color: var(--gd-warn); }
.gd-play-badge--info { background: rgba(1, 213, 250, .14); color: var(--gd-accent); }

.gd-play-lead { color: var(--gd-text-soft); font-size: .92rem; line-height: 1.55; margin-bottom: 14px; }

/* Botão primário do play-now (sobrescreve btn-primary do bootstrap) */
.gd-play-now .btn-primary,
.gd-play-now .btn-warning {
    border: none;
}
.gd-play-now .btn-primary {
    background: var(--gd-accent);
    color: var(--gd-accent-ink);
}
.gd-play-now .btn-primary:hover { background: #18e6ff; color: var(--gd-accent-ink); }
.gd-play-now .btn-outline-primary {
    background: transparent;
    color: var(--gd-accent);
    border: 1px solid rgba(1, 213, 250, .45);
}
.gd-play-now .btn-outline-primary:hover { background: rgba(1, 213, 250, .12); color: var(--gd-accent); }
.gd-play-now .btn-outline-light {
    background: transparent; color: var(--gd-text-soft);
    border: 1px solid var(--gd-border-strong);
}
.gd-play-now .btn-outline-light:hover { background: rgba(255, 255, 255, .04); color: var(--gd-text); }
.gd-play-now .btn-warning { background: var(--gd-warn); color: #2a2010; }
.gd-play-now .btn-warning:hover { background: #ffc874; color: #2a2010; }

.gd-play-cta { padding: 12px 18px; font-weight: 700; border-radius: 8px; }
.gd-play-cta i { margin-right: 6px; }

.gd-play-helper { color: var(--gd-text-mute); font-size: .8rem; margin-top: 12px; line-height: 1.45; }
.gd-play-helper i { color: var(--gd-accent); margin-right: 4px; }

.gd-play-options { display: flex; flex-direction: column; gap: 12px; }
.gd-play-option {
    background: var(--gd-bg-sub);
    border: 1px solid var(--gd-border);
    border-radius: 8px;
    padding: 14px;
}
.gd-play-option--featured {
    border-color: rgba(1, 213, 250, .35);
    background:
        linear-gradient(180deg, rgba(1, 213, 250, .08) 0%, var(--gd-bg-sub) 100%);
    position: relative;
}
.gd-play-option--featured::before {
    content: 'Recomendado';
    position: absolute; top: -10px; left: 14px;
    background: var(--gd-accent); color: var(--gd-accent-ink);
    font-size: .65rem; font-weight: 800;
    padding: 3px 10px; border-radius: 999px;
    text-transform: uppercase; letter-spacing: .05em;
}
.gd-play-option-head { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; margin-bottom: 10px; }
.gd-play-option-head h3 { font-size: 1rem; font-weight: 700; margin: 0; color: var(--gd-text); }
.gd-play-price { color: var(--gd-accent); font-weight: 800; font-size: 1.1rem; }
.gd-play-price small { color: var(--gd-text-mute); font-weight: 400; font-size: .75rem; }
.gd-play-option p { color: var(--gd-text-soft); font-size: .85rem; margin: 0 0 10px; }
.gd-play-features { list-style: none; padding: 0; margin: 0 0 10px; display: flex; flex-direction: column; gap: 4px; font-size: .85rem; color: var(--gd-text-soft); }
.gd-play-features li i { color: var(--gd-success); margin-right: 6px; }

.gd-play-secondary-link { display: block; text-align: center; color: var(--gd-text-mute); font-size: .8rem; margin-top: 8px; text-decoration: none; }
.gd-play-secondary-link:hover { color: var(--gd-accent); }

.gd-play-helper-note {
    display: block;
    text-align: center;
    color: var(--gd-text-soft);
    font-size: .8rem;
    margin-top: 8px;
    line-height: 1.4;
}

.gd-play-trust { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--gd-border); display: flex; flex-direction: column; gap: 6px; font-size: .75rem; color: var(--gd-text-mute); }
.gd-play-trust-item i { color: var(--gd-accent); margin-right: 6px; width: 14px; }

/* =====================================================================
 * FAB MOBILE — fonte original do botão de ação
 *
 * O elemento .gd-mfab-wrap renderiza no DOM mas fica SEMPRE escondido.
 * No mobile (<=800px), JS move o botão pra dentro do dock #ac-itens_mob
 * e marca o próprio dock com a classe `.gd-dock-cta`. As regras abaixo
 * SÓ atuam quando essa classe está presente — então o layout original
 * do dock continua intacto em qualquer outra página.
 *
 * Cor do fundo do dock muda conforme a variante do botão:
 *   .gd-dock-cta            → cyan (primário)
 *   .gd-dock-cta--warn      → amarelo (fila/aviso)
 *
 * No desktop a coluna direita "Jogue agora" sticky cumpre o papel.
 * ===================================================================== */
.gd-mfab-wrap { display: none !important; }

@media screen and (max-width: 800px) {
    /* dá ar embaixo da página pra o dock não tampar conteúdo */
    body { padding-bottom: 5rem; }

    /* ----- Dock no estado "tem ação prominente" ----- */
    /* Pinta o fundo + sombra na cor do botão. Permite o Menu transbordar. */
    #ac-cc_header.gd-dock-cta {
        background: #01d5fa !important;
        box-shadow: 0 -8px 24px rgba(1, 213, 250, .45) !important;
        overflow: visible !important;
        transition: background .25s ease, box-shadow .25s ease;
    }
    #ac-cc_header.gd-dock-cta--warn {
        background: #ffb648 !important;
        box-shadow: 0 -8px 24px rgba(255, 182, 72, .45) !important;
    }

    /* container do dock — overflow visible pra Menu sair do limite */
    #ac-cc_header.gd-dock-cta #ac-itens_mob {
        overflow: visible !important;
        align-items: center;
    }

    /* Esconde os itens originais (Assinatura/Conta/Jogos) */
    #ac-cc_header.gd-dock-cta #ac-itens_mob > .ac-games_mob:not(.ac-menu_mob):not(.gd-dock-action) {
        display: none !important;
    }

    /* Botão de ação — ícone à esquerda + (subtítulo em cima / título em baixo) */
    #ac-cc_header.gd-dock-cta #ac-itens_mob > .gd-dock-action {
        flex: 1;
        display: inline-flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 12px !important;
        padding: 0 12px !important;
        height: 100% !important;
        color: #313144 !important;
        text-decoration: none;
        background: transparent !important;
        border: 0 !important;
        overflow: hidden;
        min-width: 0;
    }
    #ac-cc_header.gd-dock-cta--warn #ac-itens_mob > .gd-dock-action {
        color: #2a2010 !important;
    }
    #ac-cc_header.gd-dock-cta #ac-itens_mob > .gd-dock-action i {
        font-size: 26px !important;
        flex-shrink: 0;
        color: inherit !important;
    }
    .gd-dock-action-text {
        display: flex;
        flex-direction: column;
        line-height: 1.15;
        min-width: 0;
        overflow: hidden;
        text-align: left;
    }
    .gd-dock-action-text small {
        font-size: .7rem;
        font-weight: 500;
        opacity: .85;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .gd-dock-action-text strong {
        font-size: 1.05rem;
        font-weight: 700;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    /* Menu — bola circular ALINHADA dentro do bloco (sem estourar pra cima) */
    #ac-cc_header.gd-dock-cta #ac-itens_mob > .ac-menu_mob {
        width: 50px !important;
        height: 50px !important;
        padding: 0 !important;
        margin: 0 0 0 auto !important;          /* alinhada à direita, dentro do dock */
        border-radius: 50% !important;
        background: #1a1a23 !important;         /* preto escuro, contrastando com cyan/amarelo */
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-direction: row !important;
        flex-shrink: 0 !important;
        font-size: 0 !important;                /* esconde a label "Menu" */
        transform: none;                         /* sem protrusão — fica dentro do bloco */
        box-shadow: 0 4px 10px rgba(0, 0, 0, .25);
        cursor: pointer;
    }
    #ac-cc_header.gd-dock-cta #ac-itens_mob > .ac-menu_mob svg {
        width: 26px !important;
        height: 26px !important;
        margin: 0 !important;
        stroke: #ffffff !important;
        stroke-width: 2.5;
    }
    #ac-cc_header.gd-dock-cta--warn #ac-itens_mob > .ac-menu_mob svg {
        stroke: #ffffff !important;
    }
    .gd-dock-cta #ac-main_header{
        padding: 5px !important;
    }
    #ac-cc_header.gd-dock-cta {
        padding: 0px 0 0 10px !important;
    }
}
