/* Download Center Extension - Prosilver Standard Styles */
:root {
    --dc-primary: #105289;
    /* Azul padrÃ£o Prosilver */
    --dc-primary-hover: #004473;
    --dc-success: #228b22;
    --dc-danger: #bc2a4d;
    --dc-warning: #daa520;
    --dc-border: #cadceb;
    /* Borda padrÃ£o Prosilver */
    --dc-light: #eef5f9;
    /* Fundo claro Prosilver */
    --dc-dark: #333333;
    --dc-text: #3f3f3f;
    --dc-text-muted: #536482;
}

/* Container & Sections */
.dc-container,
.download-view-container {
    background: #ffffff;
    border: 1px solid var(--dc-border);
    border-radius: 7px;
    padding: 15px;
    margin-bottom: 20px;
}

.dc-header-title {
    font-size: 1.8em;
    font-weight: bold;
    color: var(--dc-primary);
    margin-bottom: 15px;
    padding-bottom: 5px;
    border-bottom: 1px solid var(--dc-border);
}



.dc-tabs {
    display: flex;
    gap: 5px;
    margin-bottom: 15px;
}

.tab-item {
    padding: 5px 12px;
    background: var(--dc-light);
    border: 1px solid var(--dc-border);
    border-radius: 4px;
    text-decoration: none !important;
    color: var(--dc-primary);
    font-size: 0.9em;
}

.tab-item.active {
    background: var(--dc-primary);
    color: #ffffff !important;
    border-color: var(--dc-primary);
}

/* Search Row */
.dc-search-row {
    margin-bottom: 15px;
}

.search-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.search-icon {
    position: absolute;
    left: 10px;
    color: var(--dc-text-muted);
}

.dc-search-input {
    width: 100%;
    padding: 8px 35px;
    border: 1px solid var(--dc-border);
    background: #ffffff;
    border-radius: 4px;
}

.btn-toggle-filters {
    position: absolute;
    right: 10px;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--dc-text-muted);
}

/* Filters */
.dc-filter-form {
    display: none;
    background: var(--dc-light);
    border: 1px solid var(--dc-border);
    padding: 15px;
    border-radius: 7px;
    margin-bottom: 20px;
}

.dc-alphabet {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    margin-bottom: 15px;
}

.letra-btn {
    padding: 4px 8px;
    background: #ffffff;
    border: 1px solid var(--dc-border);
    border-radius: 3px;
    text-decoration: none !important;
    color: var(--dc-primary);
    font-size: 0.85em;
}

.letra-btn.active {
    background: var(--dc-primary);
    color: #ffffff !important;
}

/* Acervo List */
#acervo-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.acervo-row {
    display: flex;
    gap: 15px;
    background: #ffffff;
    border: 1px solid var(--dc-border);
    padding: 10px;
    border-radius: 7px;
}

.acervo-row:hover {
    background-color: #f6f6f6;
}

.acervo-row .dc-poster {
    width: 150px;
    flex-shrink: 0;
    position: relative;
}

.status-overlay {
    position: absolute;
    top: 5px;
    left: 5px;
    z-index: 10;
    padding: 8px 16px;
    border-radius: 6px;
    font-size: 1.1em;
    font-weight: 900;
    text-transform: uppercase;
    color: #fff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

/* Status DinÃƒÂ¢micos baseados no nome do ACP */
.status-overlay {
    background: #95a5a6;
}

/* Cor padrÃƒÂ£o cinza */
.status-overlay.status-aberto,
.status-overlay.status-ativo,
.status-overlay.status-completo {
    background: #2ecc71;
}

.status-overlay.status-em-andamento,
.status-overlay.status-novo {
    background: #3498db;
}

.status-overlay.status-atendido,
.status-overlay.status-finalizado {
    background: #f1c40f;
    color: #000;
}

.status-overlay.status-erro,
.status-overlay.status-incorreto,
.status-overlay.status-cancelado {
    background: #e74c3c;
}

.acervo-row .dc-poster img {
    width: 100%;
    border-radius: 4px;
    border: 1px solid var(--dc-border);
}

.acervo-titulo {
    font-size: 1.1em;
    font-weight: bold;
    margin: 0 0 5px 0;
}

.acervo-titulo a {
    color: var(--dc-primary);
    text-decoration: none;
}

.acervo-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 10px;
}

.tag-item {
    font-size: 0.75em;
    padding: 3px 8px;
    background: #f1f5f9;
    color: #475569;
    border-radius: 4px;
    font-weight: 600;
    border: 1px solid #e2e8f0;
    display: flex;
    align-items: center;
    gap: 4px;
}

.tag-item i {
    font-size: 1.1em;
}

.tag-rating {
    font-size: 0.8em;
    font-weight: bold;
    color: #daa520;
    background: #fffbe6;
    border: 1px solid #ffe58f;
    padding: 3px 8px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Age Ratings */
.age-l {
    background: #2ecc71;
    color: #fff;
    border-color: #27ae60;
}

.age-10 {
    background: #3498db;
    color: #fff;
    border-color: #2980b9;
}

.age-12 {
    background: #f1c40f;
    color: #fff;
    border-color: #f39c12;
}

.age-14 {
    background: #e67e22;
    color: #fff;
    border-color: #d35400;
}

.age-16 {
    background: #e74c3c;
    color: #fff;
    border-color: #c0392b;
}

.age-18 {
    background: #000;
    color: #fff;
    border-color: #000;
}

.acervo-resumo {
    font-size: 0.9em;
    color: #555;
    line-height: 1.4;
    margin-bottom: 10px;
}

.acervo-meta {
    display: flex;
    gap: 15px;
    font-size: 0.85em;
    color: var(--dc-text-muted);
}

.acervo-meta span {
    display: flex;
    align-items: center;
    gap: 5px;
}

/* View Page Components */
.download-media-header {
    display: flex;
    gap: 20px;
}

.dc-block-title {
    font-size: 1.3em;
    margin-bottom: 20px;
    color: #105289;
    font-weight: bold;
}

.media-info-box {
    flex: 1;
    min-width: 0;
    /* Permite que o conteÃƒÂºdo interno quebre ou scrolle sem estourar o flex */
}

.media-overview {
    word-wrap: break-word;
    overflow-wrap: break-word;
    margin-bottom: 20px;
    line-height: 1.6;
    color: #3f3f3f;
    font-size: 1.05em;
}

.download-media-header .dc-poster {
    width: 350px !important;
    min-width: 350px !important;
    flex-shrink: 0;
}

.download-media-header .dc-poster img {
    width: 100%;
    border-radius: 8px;
    border: 1px solid var(--dc-border);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

.dc-age-badge {
    position: absolute;
    bottom: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    line-height: 32px;
    text-align: center;
    border-radius: 4px;
    font-weight: bold;
    color: #fff;
    font-size: 14px;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.age-l {
    background-color: #00a651;
}

.age-10 {
    background-color: #00adef;
}

.age-12 {
    background-color: #f7ec13;
    color: #000;
    text-shadow: none;
}

.age-14 {
    background-color: #f26522;
}

.age-16 {
    background-color: #ed1c24;
}

.age-18 {
    background-color: #000000;
}

.dc-poster-actions .button {
    font-size: 0.85em;
    padding: 8px 10px;
    border-radius: 6px;
    transition: all 0.3s ease;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 700;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.dc-btn-action {
    flex: 1;
}

.dc-btn-trailer {
    background: linear-gradient(135deg, #e52d27 0%, #b31217 100%);
    color: #fff !important;
}

.dc-btn-imdb {
    background: linear-gradient(135deg, #f5c518 0%, #f1a10d 100%);
    color: #000 !important;
    text-shadow: none;
}

.dc-btn-tmdb {
    background: linear-gradient(135deg, #01b4e4 0%, #0d253f 100%);
    color: #fff !important;
}

.dc-poster-actions .button:hover {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
    opacity: 0.9;
    transform: none !important;
}

.dc-btn-trailer:hover {
    background: linear-gradient(135deg, #e52d27 0%, #b31217 100%) !important;
    color: #fff !important;
    background-color: #b31217 !important;
}

.dc-btn-imdb:hover {
    background: linear-gradient(135deg, #f5c518 0%, #f1a10d 100%) !important;
    color: #000 !important;
    background-color: #f1a10d !important;
}

.dc-btn-tmdb:hover {
    background: linear-gradient(135deg, #01b4e4 0%, #0d253f 100%) !important;
    color: #fff !important;
    background-color: #0d253f !important;
}

.dc-btn-imdb i,
.dc-btn-tmdb i,
.dc-btn-trailer i {
    font-size: 1.5em;
    vertical-align: middle;
}

/* Cast Section */
.dc-cast-section {
    margin-top: 20px;
    border-top: 1px solid var(--dc-border);
    padding-top: 15px;
}

.dc-cast-list {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 15px !important;
    overflow-x: auto !important;
    padding-bottom: 10px;
    scrollbar-width: thin;
    scrollbar-color: var(--dc-border) transparent;
    width: 100%;
}

.dc-cast-list::-webkit-scrollbar {
    height: 6px;
}

.dc-cast-list::-webkit-scrollbar-thumb {
    background: var(--dc-border);
    border-radius: 10px;
}

.dc-cast-card {
    flex: 0 0 120px !important;
    text-align: center !important;
    display: block !important;
    text-decoration: none !important;
}

.dc-cast-photo {
    overflow: hidden !important;
    border-radius: 50% !important;
    width: 100px !important;
    height: 100px !important;
    margin: 0 auto !important;
    border: 2px solid var(--dc-border) !important;
    transition: all 0.3s ease !important;
}

.dc-cast-photo img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.3s ease !important;
    display: block !important;
}

.dc-cast-card:hover .dc-cast-photo {
    border-color: var(--dc-primary) !important;
    box-shadow: 0 4px 10px rgba(16, 82, 137, 0.3) !important;
}

.dc-cast-card:hover .dc-cast-photo img {
    transform: scale(1.15) !important;
}

.dc-cast-info .dc-cast-name {
    display: block;
    font-weight: bold;
    font-size: 0.85em;
    margin-top: 5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--dc-text) !important;
}

.dc-cast-info .dc-cast-char {
    display: block;
    font-size: 0.75em;
    color: var(--dc-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.download-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.download-block {
    background: #ffffff;
    border: 1px solid var(--dc-border);
    padding: 15px;
    border-radius: 7px;
}

.server-link-btn {
    display: block;
    padding: 10px;
    background: var(--dc-primary);
    color: #ffffff !important;
    text-align: center;
    border-radius: 4px;
    text-decoration: none !important;
    font-weight: bold;
    margin-bottom: 5px;
}

.server-link-btn:hover {
    background: var(--dc-primary-hover);
}

.dc-empty-msg {
    text-align: center;
    padding: 40px;
    background: var(--dc-light);
    border: 1px dashed var(--dc-border);
}

/* Dark Mode (Basic compatibility) */
.dark-mode {
    background-color: #121212;
    color: #cccccc;
}

/* Technical Panel Styles */
.dc-tech-panel {
    background: #fdfdfd;
    border: 1px solid #cadceb;
    border-radius: 8px;
    padding: 20px;
    margin: 20px 0;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.03);
}

.dc-tech-legend {
    font-size: 1.2em;
    font-weight: bold;
    color: #105289;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 2px solid #105289;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dc-btn-mediainfo {
    background: #27ae60;
    color: #fff !important;
    border: none;
    padding: 6px 15px;
    border-radius: 4px;
    font-size: 0.8em;
    cursor: pointer;
    transition: background 0.2s;
}

.dc-btn-mediainfo:hover {
    background: #219150;
}

.dc-tech-section {
    margin-bottom: 25px;
}

.dc-section-title {
    font-weight: bold;
    color: var(--dc-primary);
    margin-bottom: 12px;
    font-size: 0.95em;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid var(--dc-border);
    padding-bottom: 5px;
}

.dc-pill-tech {
    display: inline-flex;
    align-items: center;
    background: transparent;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 5px 12px;
    gap: 10px;
    font-size: 13px;
    transition: all 0.2s ease;
    cursor: help;
    position: relative;
}

.dc-pill-tech:hover {
    box-shadow: 0 4px 8px rgba(0,0,0,0.08);
    border-color: #3498db;
}

.dc-pill-more {
    background: var(--dc-primary) !important;
    color: #fff !important;
    border-color: var(--dc-primary) !important;
    font-weight: bold;
    cursor: default !important;
    padding: 5px 10px !important;
    min-width: 35px;
    justify-content: center;
}

.dc-pill-more:hover {
    background: var(--dc-primary-hover) !important;
    box-shadow: none !important;
}

/* Tooltip Elegante */
.dc-pill-tech[data-info]::after {
    content: attr(data-info);
    position: absolute;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background: #1e293b;
    color: #fff;
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 11px;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    box-shadow: 0 10px 15px -3px rgba(0,0,0,0.3);
    z-index: 100;
    pointer-events: none;
    font-weight: 500;
}

.dc-pill-tech[data-info]::before {
    content: '';
    position: absolute;
    bottom: 110%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    border: 6px solid transparent;
    border-top-color: #1e293b;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    z-index: 100;
}

.dc-pill-tech:hover[data-info]::after,
.dc-pill-tech:hover[data-info]::before {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

.dc-pill-lang {
    color: #1e293b !important;
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    line-height: 1;
    white-space: nowrap;
}

.pill-audio {
    border-left: 4px solid #2ecc71 !important;
}

.pill-subtitle {
    border-left: 4px solid #3498db !important;
}

.pill-audio .dc-pill-lang,
.pill-subtitle .dc-pill-lang {
    background: transparent;
}

.pill-details {
    color: #64748b;
    font-size: 12px;
}

.pill-details strong {
    color: #1e293b;
}

/* Flag Icons Integration */
.dc-pill-tech .fi {
    display: inline-block;
    border-radius: 2px;
    box-shadow: 0 0 2px rgba(0,0,0,0.2);
    width: 1.33333333em;
    line-height: 1em;
    vertical-align: middle;
}

/* Tech Info Panel Modernization */
.dc-tech-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 15px;
}

.dc-tech-card {
    background: #fff;
    border: 1px solid var(--dc-border);
    border-radius: 12px;
    padding: 18px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.02);
    height: 100%;
}

.dc-tech-card:hover {
    border-color: #3498db66;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.dc-tech-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.dc-tech-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid #f1f5f9;
    font-size: 0.92em;
}

.dc-tech-item:last-child {
    border-bottom: none;
}

.dc-tech-label {
    color: #64748b;
    display: flex;
    align-items: center;
    gap: 10px;
}

.dc-tech-label i {
    width: 20px;
    text-align: center;
    color: #3498db;
    font-size: 1.1em;
}

.dc-tech-value {
    color: #1e293b;
    font-weight: 600;
    text-align: right;
}

.dc-badge-tech {
    display: inline-block;
    padding: 2px 8px;
    background: #e0f2fe;
    color: #0369a1;
    border-radius: 4px;
    font-size: 0.85em;
    font-weight: 700;
    text-transform: uppercase;
}

.dc-badge-soft {
    display: inline-block;
    padding: 2px 8px;
    background: #f8fafc;
    color: #64748b;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    font-size: 0.8em;
    font-weight: 600;
}

/* Technical Info Enhancements */
.dc-tech-item-vertical {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 10px;
}

/* Post Form Modernization */
.dc-post-card {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 20px;
    margin-bottom: 20px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.dc-post-section-title {
    font-weight: 700;
    font-size: 1.1em;
    color: #1e293b;
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 1px solid #f1f5f9;
    padding-bottom: 10px;
}

.dc-post-section-title i {
    color: #3498db;
}

.dc-input-group {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
}

.dc-input-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.dc-input-item label {
    font-weight: 600;
    font-size: 0.9em;
    color: #64748b;
}

.dc-btn-mediainfo-modern {
    background: #105289;
    color: #ffffff !important;
    padding: 8px 16px;
    border-radius: 8px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.dc-btn-mediainfo-modern:hover {
    background: #004473;
    transform: translateY(-1px);
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.dc-tech-label-full {
    width: 100%;
    border-bottom: 1px dashed #f1f5f9;
    padding-bottom: 5px;
    margin-bottom: 2px;
}

.dc-tech-badges-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: flex-start;
    width: 100%;
}

.dc-text-danger {
    color: #e74c3c !important;
}

.dc-sub-label-group {
    font-size: 0.8em;
    font-weight: 700;
    color: #94a3b8;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.dc-sub-section-divider {
    border-top: 1px dashed #f1f5f9;
    padding-top: 15px;
}

.dc-footer-team-info {
    margin-top: 15px;
    padding-top: 10px;
    border-top: 1px dashed #e2e8f0;
    font-size: 0.85em;
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.dc-team-item {
    color: #64748b;
    display: flex;
    align-items: center;
    gap: 8px;
}

.dc-team-item i {
    width: 15px;
    color: #3498db;
}

.dc-text-normal {
    font-weight: normal !important;
}

/* Utility Classes */
.dc-flex-column { display: flex; flex-direction: column; }
.dc-flex-wrap { display: flex; flex-wrap: wrap; }
.dc-gap-8 { gap: 8px; }
.dc-gap-20 { gap: 20px; }
.dc-text-success { color: #22c55e !important; }
.dc-text-info { color: #3498db !important; }
.dc-text-muted { color: #64748b !important; }

.dc-badge-codec {
    background: #f1f5f9 !important;
    color: #475569 !important;
}

/* Tooltip Z-Index Fix */
.dc-pill-tech[data-info]::after,
.dc-pill-tech[data-info]::before {
    z-index: 999;
}

/* Team Colors */
.dc-team-colab { color: #00BF00 !important; font-weight: 700; }
.dc-team-rip { color: #FFBF00 !important; font-weight: 700; }
.dc-team-rmz { color: #008000 !important; font-weight: 700; }
.dc-team-leg { color: #004000 !important; font-weight: 700; }

.dc-flex-item {
    flex: 1;
    min-width: 150px;
}

.dc-flex-item label {
    display: block;
    font-size: 0.85em;
    color: #536482;
    margin-bottom: 4px;
}

.dc-row-item {
    display: flex;
    gap: 10px;
    margin-bottom: 8px;
    align-items: center;
}

.dc-btn-add {
    background: #105289;
    color: #fff !important;
    border: none;
    padding: 5px 12px;
    border-radius: 4px;
    font-size: 0.85em;
    cursor: pointer;
}

.dc-btn-del {
    background: #e74c3c;
    color: #fff !important;
    border: none;
    width: 32px;
    height: 32px;
    border-radius: 4px;
    cursor: pointer;
}

.dc-screenshots-area {
    width: 100%;
    min-height: 100px;
    border: 1px solid #cadceb;
    border-radius: 4px;
    padding: 10px;
    font-family: monospace;
    font-size: 0.9em;
    resize: vertical;
}

.dc-btn-add:hover {
    opacity: 0.9;
}

.dc-btn-del:hover {
    background: #c0392b;
}

/* Action Bar Styles */
.dc-actions-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: stretch;
    padding: 5px 0;
}

.dc-action-group {
    flex: 1;
    min-width: 120px;
    display: flex;
    flex-direction: column;
    padding: 0 15px;
    border-right: 1px solid var(--dc-border);
}

.dc-action-group:last-child {
    border-right: none;
}

/* Centraliza o Label em TODOS os grupos */
.dc-action-label {
    display: block !important;
    font-size: 0.75em;
    text-transform: uppercase;
    color: var(--dc-text-muted);
    font-weight: bold;
    margin-bottom: 12px;
    letter-spacing: 0.5px;
    text-align: center !important; 
    width: 100% !important;
}

/* Detalhes e Status: Centralizam o CONTEÚDO */
.dc-action-group {
    align-items: center !important; /* CENTRALIZA TUDO POR PADRÃO (Títulos inclusos) */
    text-align: center !important;
}

.dc-specs-column,
.dc-status-wrapper {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 6px;
    width: 100%;
}

/* Grupo Ações: Título centralizado (pelo pai) mas BOTÕES à esquerda */
.dc-action-group-main {
    flex: 2;
}

.dc-main-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: flex-start !important; /* BOTÕES NA ESQUERDA */
    width: 100%;
}

.dc-btn-icon-only {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    width: auto;
    padding: 0 10px;
    height: 42px;
    background: #fff;
    border: 1px solid #cbd5e1;
    border-radius: 4px; /* QUADRADOS com canto suave */
    color: #475569 !important;
    text-decoration: none !important;
    font-size: 1.45em;
    font-weight: 700;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    box-sizing: border-box;
    position: relative;
}

/* Removendo a regra de pílula específica pois agora todos seguem o mesmo padrão */
.dc-btn-icon-only.dc-like-btn {
    border-radius: 4px;
}

.dc-btn-icon-only i {
    margin: 0 !important;
    display: inline-block;
}

.dc-btn-icon-only:hover {
    background: #f8fafc;
    border-color: var(--dc-primary);
    color: var(--dc-primary) !important;
    transform: translateY(-3px) scale(1.1);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.dc-btn-download-big {
    background: linear-gradient(135deg, #105289 0%, #004473 100%);
    color: #fff !important;
    border: none;
    padding: 0 25px;
    border-radius: 4px;
    font-weight: bold;
    font-size: 1.1em;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    box-shadow: 0 4px 6px rgba(16, 82, 137, 0.2);
    transition: all 0.3s ease;
    height: 42px;
}

.dc-btn-download-big i {
    font-size: 1.45em; /* Ícone grande igual aos outros */
}

.dc-btn-download-big:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(16, 82, 137, 0.3);
    filter: brightness(1.1);
}

/* Tooltip System */
[data-tooltip] {
    position: relative;
}

[data-tooltip]::before {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    padding: 6px 12px;
    background: rgba(30, 41, 59, 0.95);
    color: #fff;
    font-size: 0.8em;
    font-weight: 500;
    border-radius: 6px;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    z-index: 100;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

[data-tooltip]::after {
    content: '';
    position: absolute;
    bottom: 110%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    border-width: 6px;
    border-style: solid;
    border-color: rgba(30, 41, 59, 0.95) transparent transparent transparent;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s ease;
    z-index: 100;
}

[data-tooltip]:hover::before,
[data-tooltip]:hover::after {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

/* Liked Button State */
.dc-btn-icon-only.dc-like-btn.dc-btn-liked {
    background-color: #f0fdf4 !important;
    border-color: #22c55e !important;
    color: #16a34a !important;
}

.dc-btn-icon-only.dc-like-btn.dc-btn-liked i {
    color: #16a34a !important;
}

.dc-btn-icon-only .dc-action-count {
    margin-left: 6px;
    font-size: 1.1em;
    font-weight: 700;
}

/* Tip Button Hover */
.dc-btn-tip:hover {
    color: #e67e22 !important;
    border-color: #f39c12 !important;
    background-color: #fffaf0 !important;
}

/* Favorite Button State */
.dc-btn-icon-only.dc-favorite-btn.active {
    border-color: #e91e63 !important;
    color: #e91e63 !important;
    background-color: #fff1f2 !important;
}

.dc-btn-icon-only.dc-favorite-btn.active i {
    color: #e91e63 !important;
}

/* Report Button Hover */
.dc-report-offline-btn:hover {
    color: #ef4444 !important;
    border-color: #ef4444 !important;
    background-color: #fef2f2 !important;
}



.DOWNLOAD-specs-column {
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: center;
}

.dc-status-badge {
    display: inline-block !important;
    padding: 7px 18px !important;
    border-radius: 6px !important;
    font-size: 1.1em !important;
    font-weight: 900 !important;
    text-align: center !important;
    white-space: nowrap !important;
    text-transform: uppercase !important;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.2) !important;
    border-width: 2px !important;
    border-style: solid !important;
}

.badge-big {
    display: inline-block;
    padding: 8px 16px;
    border-radius: 6px;
    font-size: 1.1em;
    font-weight: 900;
    text-align: center;
    box-sizing: border-box;
    white-space: nowrap;
    text-transform: uppercase;
}

.badge-type-big {
    background: #3498db;
    color: #fff;
}

.badge-res-big {
    background: #9b59b6;
    color: #fff;
}

.badge-audio-big {
    background: #2ecc71;
    color: #fff;
}





.download-voters-row {
    margin-top: 15px;
    padding-top: 10px;
    border-top: 1px dashed var(--dc-border);
    font-size: 0.85em;
    color: var(--dc-text-muted);
}

/* Dropdown de ConfiguraÃƒÂ§ÃƒÂµes */
.dc-dropdown {
    position: relative;
    display: inline-block;
}

.dc-btn-config {
    background-color: #444;
    color: #fff !important;
    border: none;
    padding: 8px 15px;
    border-radius: 5px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9em;
    font-weight: 600;
    transition: background 0.2s;
}

.dc-btn-config:hover {
    background-color: #555;
}

.dc-dropdown-content {
    display: none;
    position: absolute;
    right: 0;
    background-color: #1a1a1a;
    min-width: 200px;
    box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.5);
    z-index: 1000;
    border-radius: 4px;
    border: 1px solid #333;
    margin-top: 5px;
    overflow: hidden;
    text-align: left;
}

.dc-dropdown-content.show {
    display: block;
}

.dc-dropdown-content a {
    color: #ccc !important;
    padding: 10px 15px;
    text-decoration: none !important;
    display: block;
    font-size: 13px;
    border-bottom: 1px solid #222;
    transition: background 0.2s, color 0.2s;
}

.dc-dropdown-content a:last-child {
    border-bottom: none;
}

.dc-dropdown-content a:hover {
    background-color: #333;
    color: #fff !important;
}

.dc-dropdown-content a i {
    margin-right: 8px;
    width: 16px;
    text-align: center;
}

/* MCP Report Badges */
.report-badge {
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 0.75em;
    font-weight: bold;
    text-transform: uppercase;
    display: inline-block;
    margin-left: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.report-badge-comment {
    background-color: #3498db;
    color: #fff;
}

.report-badge-download {
    background-color: #e67e22;
    color: #fff;
}

/* Banners de Alerta (PendÃƒÂªncia e DenÃƒÂºncia) */
.dc-banner {
    margin-bottom: 20px;
    padding: 15px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 15px;
    border: 1px solid;
}

.dc-banner i {
    font-size: 2em;
}

.dc-banner .banner-content {
    flex-grow: 1;
}

.dc-banner .banner-title {
    font-size: 1.1em;
    display: block;
    margin-bottom: 4px;
    font-weight: bold;
}

.dc-banner .banner-explain {
    font-size: 0.9em;
}

.dc-banner-pending {
    background-color: #fef5e7;
    border-color: #f39c12;
    color: #d35400;
}

.dc-banner-report {
    background-color: #fceae9;
    border-color: #e74c3c;
    color: #c0392b;
}

.dc-banner .banner-action {
    margin-left: auto;
}

.dc-banner .btn-banner {
    color: white !important;
    border: none;
    padding: 8px 15px;
    border-radius: 5px;
    font-weight: bold;
    text-decoration: none !important;
    display: inline-block;
}

.dc-banner-pending .btn-banner {
    background-color: #2ecc71;
}

.dc-banner-report .btn-banner {
    background-color: #e74c3c;
}

.dc-banner-offline {
    background-color: #ebf5ff;
    border-color: #3b82f6;
    color: #1e3a8a;
}

.dc-banner-offline.dc-offline-attention {
    background-color: #fffbeb;
    border-color: #f1c40f;
    color: #92400e;
}

.dc-banner-offline.dc-offline-critical {
    background-color: #fdf2f2;
    border-color: #e74c3c;
    color: #9b1c1c;
}

.dc-banner-offline .btn-banner {
    background-color: #105289;
}

.dc-banner-offline.dc-offline-attention .btn-banner {
    background-color: #f39c12;
}

.dc-banner-offline.dc-offline-critical .btn-banner {
    background-color: #e74c3c;
}


/* --- Dark Mode Support --- */
.dark-mode .dc-container,
.dark-mode .download-view-container,
.dark .dc-container,
.dark .download-view-container,
.night .dc-container,
.night .download-view-container,
.dark-mode .panel,
.dark .panel,
.night .panel {
    background: #1e1e1e !important;
    border-color: #333 !important;
    color: #e2e8f0 !important;
}

.dark-mode .acervo-row,
.dark .acervo-row,
.night .acervo-row {
    background: #262626 !important;
    border-color: #383838 !important;
}

.dark-mode .acervo-row:hover,
.dark .acervo-row:hover,
.night .acervo-row:hover {
    background-color: #2d2d2d !important;
}

.dark-mode .tag-item,
.dark .tag-item,
.night .tag-item {
    background: #334155 !important;
    color: #f1f5f9 !important;
    border-color: #475569 !important;
}

.dark-mode .tag-item i,
.dark .tag-item i,
.night .tag-item i {
    color: #94a3b8 !important;
}

.dark-mode .tag-rating,
.dark .tag-rating,
.night .tag-rating {
    background: #2d2d1a !important;
    border-color: #4d4d00 !important;
}

.dark-mode .acervo-titulo a,
.dark .acervo-titulo a,
.night .acervo-titulo a {
    color: #60a5fa !important;
}

.dark-mode .acervo-resumo,
.dark .acervo-resumo,
.night .acervo-resumo {
    color: #94a3b8 !important;
}

.dark-mode .acervo-meta span,
.dark .acervo-meta span,
.night .acervo-meta span {
    color: #64748b !important;
}

.dark-mode .media-overview,
.dark .media-overview,
.night .media-overview {
    color: #cbd5e1 !important;
}

.dark-mode .author-meta,
.dark .author-meta,
.night .author-meta {
    color: #64748b !important;
}

.dark-mode .dc-tech-panel,
.dark .dc-tech-panel,
.night .dc-tech-panel {
    background: #262626 !important;
    border-color: #383838 !important;
}

.dark-mode .dc-tech-legend,
.dark .dc-tech-legend,
.night .dc-tech-legend {
    color: #60a5fa !important;
    border-color: #60a5fa !important;
}

.dark-mode .dc-btn-action-big,
.dark .dc-btn-action-big,
.night .dc-btn-action-big {
    background: #2d3748 !important;
    border-color: #4a5568 !important;
    color: #edf2f7 !important;
}

.dark-mode .dc-btn-action-big:hover,
.dark .dc-btn-action-big:hover,
.night .dc-btn-action-big:hover {
    background: #4a5568 !important;
    border-color: #60a5fa !important;
}

.dark-mode .btn-download-big,
.dark .btn-download-big,
.night .btn-download-big {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4) !important;
}



.dark-mode .dc-action-label,
.dark .dc-action-label,
.night .dc-action-label {
    color: #718096 !important;
}

.dark-mode .dc-action-group,
.dark .dc-action-group,
.night .dc-action-group {
    border-color: #2d3748 !important;
}

.dark-mode .dc-search-input,
.dark .dc-search-input,
.night .dc-search-input {
    background: #2d3748 !important;
    border-color: #4a5568 !important;
    color: #fff !important;
}

.dark-mode .dc-filter-form,
.dark .dc-filter-form,
.night .dc-filter-form {
    background: #262626 !important;
    border-color: #383838 !important;
}

.dark-mode .letra-btn,
.dark .letra-btn,
.night .letra-btn {
    background: #2d3748 !important;
    border-color: #4a5568 !important;
    color: #cbd5e1 !important;
}

.dark-mode .letra-btn.active,
.dark .letra-btn.active,
.night .letra-btn.active {
    background: #3182ce !important;
    color: #fff !important;
}

/* Trailer, IMDB e TMDB Buttons in Dark Mode */
.dc-btn-imdb, .dc-btn-tmdb {
    height: 32px !important;
    padding: 0 12px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 0.9rem !important;
    font-weight: 700 !important;
    border-radius: 6px !important;
}

.dc-btn-trailer {
    height: 44px !important; /* Bem mais alto */
    line-height: 44px !important; /* Garante centralização vertical do texto */
    padding: 0 30px !important; /* Bem mais largo */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    font-size: 0.9rem !important; /* Volta ao tamanho original */
    font-weight: 800 !important;
    border-radius: 8px !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap !important;
}

.dc-btn-tmdb img {
    height: 18px !important;
    width: auto !important;
    display: block;
}

.dc-btn-imdb i {
    font-size: 1.4rem !important;
    color: #000 !important; /* Preto para contraste no fundo amarelo */
}

.dark-mode .dc-btn-imdb,
.dark .dc-btn-imdb,
.night .dc-btn-imdb,
.dark-mode .dc-btn-trailer,
.dark .dc-btn-trailer,
.night .dc-btn-trailer,
.dark-mode .dc-btn-tmdb,
.dark .dc-btn-tmdb,
.night .dc-btn-tmdb {
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.6) !important;
}

/* Status Badges in Dark Mode */
.dark-mode .status-overlay,
.dark .status-overlay,
.night .status-overlay {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.6) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.dark-mode .badge,
.dark .badge,
.night .badge {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.4) !important;
}

.dark-mode .tech-pill,
.dark .tech-pill,
.night .tech-pill {
    background: #334155 !important;
    color: #f1f5f9 !important;
    border-color: #475569 !important;
}

.dark-mode .dc-section-title,
.dark .dc-section-title,
.night .dc-section-title {
    color: #60a5fa !important;
    border-color: #333 !important;
}

.dark-mode .download-technical-info h3,
.dark .download-technical-info h3,
.night .download-technical-info h3,
.dark-mode .dc-block-title,
.dark .dc-block-title,
.night .dc-block-title {
    color: #60a5fa !important;
}

/* System-level Dark Mode Support */
@media (prefers-color-scheme: dark) {

    .dc-container,
    .download-view-container,
    .panel {
        background: #1e1e1e !important;
        border-color: #333 !important;
        color: #e2e8f0 !important;
    }

    .acervo-row {
        background: #262626 !important;
        border-color: #383838 !important;
    }

    .tag-item {
        background: #334155 !important;
        color: #f1f5f9 !important;
        border-color: #475569 !important;
    }

    .dc-btn-action-big {
        background: #2d3748 !important;
        border-color: #4a5568 !important;
        color: #edf2f7 !important;
    }

    .dc-tech-panel {
        background: #262626 !important;
        border-color: #383838 !important;
    }
}

/* Age Rating Tooltips on existing classes */
.tag-item[class*="age-"] {
    position: relative;
    cursor: help;
    transition: transform 0.2s;
    display: inline-block;
    padding: 0 10px;
    border-radius: 4px;
    font-weight: bold;
    color: white !important;
    min-width: 40px; 
    text-align: center;
    height: 32px;
    line-height: 32px; 
    text-transform: uppercase;
    font-size: 14px;
    margin-right: 5px;
}

.tag-item[class*="age-"]:hover {
    transform: scale(1.05);
}

/* Tooltip Base */
.tag-item[class*="age-"]::before {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 125%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background-color: #333;
    color: #fff !important;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
    z-index: 1000;
    line-height: 1.4;
    font-weight: bold;
    pointer-events: none;
}

/* Tooltip Arrow */
.tag-item[class*="age-"]::after {
    content: "";
    position: absolute;
    bottom: 105%;
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    border-width: 6px;
    border-style: solid;
    border-color: #333 transparent transparent transparent;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    z-index: 1000;
    pointer-events: none;
}

.tag-item[class*="age-"]:hover::before,
.tag-item[class*="age-"]:hover::after {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

/* Specific Tooltip Colors matching Age Ratings */
.age-livre, .age-l { background-color: #008000 !important; color: #fff !important; } 
.age-10 { background-color: #2980b9 !important; color: #fff !important; } 
.age-12 { background-color: #f39c12 !important; color: #fff !important; } 
.age-14 { background-color: #d35400 !important; color: #fff !important; } 
.age-16 { background-color: #c0392b !important; color: #fff !important; } 
.age-18 { background-color: #000000 !important; color: #fff !important; } 

.age-livre:hover::before, .age-l:hover::before { background-color: #008000; }
.age-livre:hover::after, .age-l:hover::after { border-color: #008000 transparent transparent transparent; }

.age-10:hover::before { background-color: #2980b9; }
.age-10:hover::after { border-color: #2980b9 transparent transparent transparent; }

.age-12:hover::before { background-color: #f39c12; color: #fff !important; }
.age-12:hover::after { border-color: #f39c12 transparent transparent transparent; }

.age-14:hover::before { background-color: #d35400; }
.age-14:hover::after { border-color: #d35400 transparent transparent transparent; }

.age-16:hover::before { background-color: #c0392b; }
.age-16:hover::after { border-color: #c0392b transparent transparent transparent; }

.age-18:hover::before { background-color: #000000; }
.age-18:hover::after { border-color: #000000 transparent transparent transparent; }

/* SweetAlert2 MediaHub Search Styles */
.mh-swal-select {
    width: 700px !important;
    max-width: 100% !important;
    margin: 20px auto !important;
    box-sizing: border-box !important;
    border-radius: 8px !important;
    border: 1px solid #cadceb !important;
    font-size: 14px !important;
    padding: 10px !important;
    display: block !important;
}

.mh-swal-confirm {
    background-color: #105289 !important;
    border-radius: 8px !important;
    padding: 10px 24px !important;
    font-weight: bold !important;
}

.mh-swal-cancel {
    border-radius: 8px !important;
    padding: 10px 24px !important;
}

/* Post Form Layout Styles */
.dc-title-row {
    clear: both !important;
    margin-bottom: 20px !important;
}

.dc-flex-row {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 10px !important;
    align-items: center !important;
    width: auto !important;
    float: none !important;
}

.dc-input-flex {
    flex: 1 1 auto !important;
    width: 0 !important; /* ForÃƒÂ§a o flex a controlar a largura */
    min-width: 200px !important;
    box-sizing: border-box !important;
}

.dc-btn-group {
    display: flex !important;
    gap: 5px !important;
    flex-shrink: 0 !important;
}

.dc-btn-import {
    background-color: #27ae60 !important;
    color: #ffffff !important;
    border: 1px solid #219150 !important;
    border-radius: 4px !important;
    padding: 0 15px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    white-space: nowrap !important;
    font-weight: bold !important;
    text-transform: uppercase !important;
    font-size: 11px !important;
    cursor: pointer !important;
    text-decoration: none !important;
}

.dc-btn-import:hover {
    background-color: #2ecc71 !important;
    color: #ffffff !important;
}

.dc-btn-import i {
    color: #ffffff !important;
    font-size: 14px !important;
}

.dc-btn-search {
    margin: 0 !important;
    padding: 0 12px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.dc-input-full {
    width: 100% !important;
    border-radius: 8px !important;
    box-sizing: border-box !important;
}

/* Statistics Page Styles */
.dc-global-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 20px;
    margin-bottom: 30px;
    margin-top: 10px;
}

.dc-stat-mini-card {
    background: #f1f5f9;
    border-radius: 12px;
    padding: 15px;
    display: flex;
    align-items: center;
    gap: 15px;
    border: 1px solid #e2e8f0;
}

.dc-mini-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.2rem;
}

.dc-mini-value {
    display: block;
    font-size: 1.4rem;
    font-weight: 800;
    color: #1e293b;
    line-height: 1;
}

.dc-mini-label {
    font-size: 0.85rem;
    color: #64748b;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dc-stats-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
    margin-bottom: 30px;
}

@media (max-width: 1100px) {
    .dc-stats-row {
        grid-template-columns: repeat(auto-fit, minmax(450px, 1fr));
    }
}

@media (max-width: 768px) {
    .dc-stats-row {
        grid-template-columns: 1fr;
    }
}

.dc-stats-section {
    background: #fff;
    border-radius: 20px;
    padding: 25px;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.04);
}

.dc-section-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #1e293b;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.dc-section-title i {
    color: #3b82f6;
}

.dc-stats-list {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.dc-stats-item {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 12px;
    border-radius: 12px;
    transition: background 0.2s;
    background: #f8fafc;
}

.dc-stats-item:hover {
    background: #f1f5f9;
}

.dc-item-rank {
    font-size: 1.1rem;
    font-weight: 800;
    color: #94a3b8;
    min-width: 25px;
    text-align: center;
}

.dc-item-poster {
    width: 45px;
    height: 65px;
    background-size: cover;
    background-position: center;
    border-radius: 6px;
    flex-shrink: 0;
}

.dc-item-content {
    flex-grow: 1;
}

.dc-item-name {
    display: block;
    font-weight: 700;
    color: #334155;
    font-size: 1rem;
    margin-bottom: 4px;
    text-decoration: none !important;
}

.dc-item-meta {
    font-size: 0.8rem;
    color: #64748b;
    display: flex;
    gap: 12px;
}

.dc-item-meta i {
    margin-right: 4px;
}

.dc-item-score {
    font-weight: 800;
    color: #1e293b;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 1.1rem;
}

.dc-item-score i {
    color: #ec4899;
}

.dc-item-score i.fa-bookmark {
    color: #10b981;
}

.dc-item-score.score-purple i {
    color: #8b5cf6;
}

.contributor-item {
    padding: 15px;
}

.dc-contributor-name b, .dc-contributor-name span {
    font-size: 1rem;
}

.dc-profile-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #3b82f6;
    border: 1px solid #e2e8f0;
    transition: all 0.2s;
}

.dc-profile-btn:hover {
    background: #3b82f6;
    color: #fff;
    border-color: #3b82f6;
}

.bg-blue { background: linear-gradient(135deg, #3b82f6, #2563eb); }
.bg-purple { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }
.bg-pink { background: linear-gradient(135deg, #ec4899, #db2777); }

/* Report Badges in Banner */
.report-badges {
    display: inline-flex;
    gap: 5px;
    margin-left: 10px;
    vertical-align: middle;
}
.report-badges .badge {
    display: inline-block;
    padding: 3px 7px;
    border-radius: 4px;
    font-size: 0.75em;
    font-weight: 800;
    color: #fff;
    line-height: 1;
    text-shadow: 0 1px 1px rgba(0,0,0,0.2);
}
.report-badges .badge-internal {
    background-color: #e74c3c;
}
.report-badges .badge-offline {
    background-color: #f39c12;
}

/* --- Custom SweetAlert2 / DCModal Styles --- */
.swal-modal-popup {
    border-radius: 16px !important;
    font-family: 'Inter', sans-serif !important;
    padding: 30px !important;
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25) !important;
}

.swal-modal-title {
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    color: #1e293b !important;
    padding-top: 10px !important;
}

.swal-modal-content {
    color: #475569 !important;
    font-size: 1.05rem !important;
    line-height: 1.6 !important;
}

.swal-modal-progress {
    background: var(--dc-primary) !important;
    height: 6px !important;
    z-index: 9999 !important;
}

.swal-loading .swal-modal-popup {
    padding: 50px !important;
}

/* Fix for icons appearing in list modals */
.swal2-icon-hide {
    display: none !important;
}

/* --- Comments Section (Namespaced) --- */
.dc-comments-section {
    margin-top: 30px;
}

.dc-comments-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.dc-comment-row {
    display: flex;
    gap: 15px;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px solid var(--dc-border);
}

.dc-comment-avatar {
    flex-shrink: 0;
}

.dc-comment-avatar img {
    width: 45px;
    height: 45px;
    border-radius: 4px;
    object-fit: cover;
}

.dc-comment-body {
    flex: 1;
    min-width: 0;
}

.dc-comment-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    font-size: 0.85em;
    color: var(--dc-text-muted);
}

.dc-comment-author {
    font-weight: bold;
    color: var(--dc-primary);
}

.dc-comment-actions {
    display: flex;
    gap: 4px;
}

.dc-comment-content {
    color: #333;
    line-height: 1.6;
    padding-top: 5px;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.dc-no-comments {
    font-style: italic;
    color: var(--dc-text-muted);
    text-align: center;
    padding: 20px;
}

/* Comment Form (Namespaced) */
.dc-comment-form-container {
    margin-top: 20px;
    padding: 20px;
    background: #f8fafc;
    border-radius: 12px;
    border: 1px solid var(--dc-border);
}

.dc-comment-form-container h4 {
    margin-bottom: 15px;
    color: var(--dc-primary);
    display: flex;
    align-items: center;
    gap: 8px;
}

.dc-bbcode-toolbar {
    margin-bottom: 10px;
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
}

.dc-comment-textarea {
    width: 100% !important;
    border-radius: 8px !important;
    border: 1px solid #cadceb !important;
    padding: 12px !important;
    box-sizing: border-box !important;
    font-family: inherit !important;
    font-size: 14px !important;
    resize: vertical !important;
    min-height: 100px !important;
}

.dc-comment-textarea:focus {
    border-color: var(--dc-primary) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(16, 82, 137, 0.1) !important;
}

.dark .dc-comment-form-container {
    background: #262626 !important;
}

.dark .dc-comment-content {
    color: #e2e8f0 !important;
}

/* --- Media Header (Namespaced) --- */
.dc-media-header {
    display: flex;
    gap: 25px;
    background: transparent;
    border: none;
    padding: 0;
}

.dc-poster {
    width: 350px;
    min-width: 350px;
    flex-shrink: 0;
}

.dc-poster-img-wrapper {
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.dc-poster-img-wrapper img {
    width: 100%;
    display: block;
}

.dc-poster-actions {
    margin-top: 15px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.dc-poster-badges {
    display: flex;
    gap: 8px;
}

.dc-media-info {
    flex: 1;
    min-width: 0;
}

.dc-media-top-actions {
    float: right;
    display: flex;
    gap: 8px;
}

.dc-media-title {
    font-size: 2em !important;
    font-weight: 800 !important;
    margin: 0 0 15px 0 !important;
    color: var(--dc-primary) !important;
    border: none !important;
    padding: 0 !important;
}

.dc-media-tags {
    margin-bottom: 15px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.dc-author-meta {
    font-size: 0.9em;
    color: var(--dc-text-muted);
    margin-bottom: 20px;
}

.dc-media-overview {
    color: #444;
    font-size: 1.1em;
    line-height: 1.6;
    margin-bottom: 25px;
}

.dc-cast-section {
    margin-top: 20px;
}

.dc-cast-title {
    font-size: 1.1em !important;
    font-weight: 700 !important;
    color: #1e293b !important;
    margin-bottom: 15px !important;
    border-bottom: 1px solid #e2e8f0 !important;
    padding-bottom: 8px !important;
}

.dc-cast-list {
    display: flex;
    gap: 15px;
    overflow-x: auto;
    padding-bottom: 15px;
}

.dc-cast-card {
    flex: 0 0 100px;
    text-align: center;
}

.dc-cast-card a {
    text-decoration: none !important;
}

.dc-cast-photo {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    overflow: hidden;
    margin-bottom: 8px;
    border: 2px solid #fff;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
}

.dc-cast-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dc-cast-name {
    display: block;
    font-weight: bold;
    font-size: 0.9em;
    color: #1e293b;
    line-height: 1.2;
}

.dc-cast-char {
    display: block;
    font-size: 0.8em;
    color: #64748b;
    line-height: 1.2;
    margin-top: 2px;
}

.dark .dc-media-overview { color: #cbd5e1; }
.dark .dc-cast-title { color: #60a5fa !important; border-color: #333 !important; }
.dark .dc-cast-name { color: #f1f5f9; }

.dc-view-actions-panel {
    text-align: left !important;
    padding: 10px !important;
}

.dc-view-actions-panel .inner {
    text-align: left !important;
    padding: 0 !important;
}

/* --- Action Bar (Namespaced) --- */
.dc-actions-bar {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 20px !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    padding: 10px 0 !important;
    width: 100% !important;
    text-align: left !important;
}

.dc-action-group {
    flex: 1 !important;
    min-width: 180px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    text-align: left !important;
    border-right: 1px solid var(--dc-border) !important;
    padding: 0 15px !important;
}

.dc-action-group:last-child {
    border-right: none;
}

.dc-action-label {
    display: block !important;
    font-size: 0.75em !important;
    text-transform: uppercase !important;
    color: var(--dc-text-muted) !important;
    font-weight: bold !important;
    margin-bottom: 10px !important;
    letter-spacing: 0.5px !important;
    text-align: left !important;
    width: 100% !important;
}

.dc-main-actions {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    justify-content: flex-start !important;
}

.dc-btn-action-big {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 20px;
    background: #fff;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    color: #475569 !important;
    text-decoration: none !important;
    font-size: 1rem;
    font-weight: 700;
    transition: all 0.2s ease;
    cursor: pointer;
    height: 44px;
    box-sizing: border-box;
}

.dc-btn-action-big:hover {
    background: #f1f5f9;
    border-color: var(--dc-primary);
    color: var(--dc-primary) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
}

/* Estado: Já Agradeceu/Liked (Desativado) */
.dc-btn-liked {
    background-color: #f8f9fa !important;
    border-color: #dee2e6 !important;
    color: #94a3b8 !important;
    cursor: default !important;
    pointer-events: none !important;
    opacity: 0.7 !important;
    box-shadow: none !important;
    transform: none !important;
}

.dc-btn-liked i {
    color: #2e8b57 !important; /* Mantém o ícone verde para indicar sucesso */
}

.dc-btn-download-big {
    background: linear-gradient(135deg, #105289 0%, #004473 100%);
    color: #fff !important;
    border: none;
    padding: 0 25px;
    border-radius: 8px;
    font-weight: 800;
    font-size: 1.1em;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    box-shadow: 0 4px 10px rgba(16, 82, 137, 0.3);
    transition: all 0.3s ease;
    height: 44px;
    text-transform: uppercase;
}

.dc-btn-download-big:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(16, 82, 137, 0.4);
    filter: brightness(1.1);
}

.dc-specs-column {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: flex-start;
}

.dc-badge-big {
    display: inline-block;
    padding: 6px 14px;
    border-radius: 6px;
    font-size: 0.95em;
    font-weight: 800;
    text-align: center;
    text-transform: uppercase;
    min-width: 100px;
    color: #fff;
}

.dc-badge-type-big { background: #3498db; }
.dc-badge-res-big { background: #9b59b6; }
.dc-badge-audio-big { background: #2ecc71; }

.dc-status-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
}

.dc-status-badge {
    display: inline-block;
    padding: 8px 20px;
    border-radius: 6px;
    font-size: 1em;
    font-weight: 900;
    text-transform: uppercase;
    box-shadow: 0 3px 6px rgba(0,0,0,0.15);
    border: 2px solid transparent;
}

.dc-status-pending { background-color: #f39c12; border-color: #f39c12; color: #fff; }
.dc-status-offline { background-color: #e74c3c; border-color: #e74c3c; color: #fff; }

.dc-view-likers-container {
    margin-top: 15px;
    padding-top: 10px;
    border-top: 1px dashed var(--dc-border);
    font-size: 0.9em;
    color: #536482;
}

.dc-likers-list {
    display: inline;
}

.dc-liker-item {
    white-space: nowrap;
    margin-right: 5px;
}

.dc-liker-item i {
    color: #2e8b57;
}

.dc-view-likers-link {
    color: var(--dc-primary);
    font-weight: 800;
    text-decoration: none !important;
}

.dc-view-likers-link:hover {
    text-decoration: underline !important;
}

.dark .dc-btn-action-big { background: #2d3748 !important; border-color: #4a5568 !important; color: #edf2f7 !important; }
.dark .dc-btn-action-big:hover { background: #4a5568 !important; }

/* --- Index Page (Namespaced) --- */
.dc-container {
    max-width: 1200px;
    margin: 20px auto;
    padding: 20px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
}

.dc-header-title {
    font-size: 24px;
    font-weight: 800;
    color: var(--dc-primary);
    margin-bottom: 20px;
}

.dc-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 25px;
    border-bottom: 2px solid #f1f5f9;
    padding-bottom: 10px;
    overflow-x: auto;
}

.dc-tab-item {
    padding: 8px 16px;
    border-radius: 8px;
    color: #64748b;
    text-decoration: none !important;
    font-weight: 600;
    transition: all 0.2s;
    white-space: nowrap;
}

.dc-tab-item:hover, .dc-tab-item.active {
    background: var(--dc-primary);
    color: #fff !important;
}

.dc-search-row {
    margin-bottom: 20px;
}

.dc-search-input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.dc-search-icon {
    position: absolute;
    left: 15px;
    color: #94a3b8;
}

.dc-search-input {
    width: 100%;
    padding: 12px 50px 12px 45px !important;
    border-radius: 12px !important;
    border: 2px solid #e2e8f0 !important;
    font-size: 16px !important;
    transition: all 0.2s;
}

.dc-search-input:focus {
    border-color: var(--dc-primary) !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(16, 82, 137, 0.1) !important;
}

.dc-btn-toggle-filters {
    position: absolute;
    right: 15px;
    background: none;
    border: none;
    color: #64748b;
    cursor: pointer;
    font-size: 18px;
}

.dc-btn-toggle-filters.active {
    color: var(--dc-primary);
}

.dc-filter-form {
    background: #f8fafc;
    padding: 20px;
    border-radius: 12px;
    margin-bottom: 25px;
    border: 1px solid #e2e8f0;
    display: none;
}

.dc-alphabet {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-bottom: 20px;
}

.dc-letra-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    color: #64748b;
    font-weight: bold;
    text-decoration: none !important;
    transition: all 0.2s;
}

.dc-letra-btn:hover, .dc-letra-btn.active {
    background: var(--dc-primary);
    color: #fff !important;
    border-color: var(--dc-primary);
}

.dc-filters-flex-row {
    display: flex;
    gap: 30px;
    flex-wrap: wrap;
}

.dc-filter-bloco {
    flex: 1;
    min-width: 300px;
}

.dc-bloco-titulo {
    font-weight: 800;
    color: #1e293b;
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: 1px solid #e2e8f0;
    padding-bottom: 8px;
}

.dc-f-group {
    margin-bottom: 12px;
}

.dc-f-group label {
    display: block;
    font-size: 0.85em;
    font-weight: bold;
    color: #64748b;
    margin-bottom: 5px;
}

.dc-f-select {
    width: 100%;
    padding: 8px 12px !important;
    border-radius: 8px !important;
    border: 1px solid #e2e8f0 !important;
    background: #fff !important;
}

.dc-f-range {
    display: flex;
    gap: 10px;
}

.dc-btn-apply-inline {
    background: var(--dc-primary);
    color: #fff !important;
    border: none;
    padding: 10px 20px;
    border-radius: 8px;
    font-weight: bold;
    cursor: pointer;
    width: 100%;
}

.dc-botoes-acao {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid #e2e8f0;
}

.dc-btn-clear {
    color: #64748b;
    text-decoration: none !important;
    font-weight: 600;
}

.dc-btn-f {
    background: var(--dc-primary);
    color: #fff !important;
    border: none;
    padding: 10px 25px;
    border-radius: 8px;
    font-weight: 800;
    cursor: pointer;
}

.dc-pagination-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 20px 0;
}

.dc-acervo-row {
    display: flex;
    gap: 20px;
    padding: 15px;
    border-radius: 12px;
    background: #fff;
    border: 1px solid #f1f5f9;
    margin-bottom: 15px;
    transition: all 0.2s;
}

.dc-acervo-row:hover {
    border-color: var(--dc-primary);
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.dc-index-poster {
    width: 150px;
    height: 220px;
    flex-shrink: 0;
    position: relative;
    border-radius: 8px;
    overflow: hidden;
}

.dc-index-poster img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dc-status-overlay {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.7em;
    font-weight: 900;
    color: #fff;
    z-index: 10;
}

.dc-acervo-info {
    flex: 1;
    min-width: 0;
}

.dc-acervo-titulo {
    font-size: 1.25em !important;
    font-weight: 800 !important;
    margin: 0 0 10px 0 !important;
    color: #1e293b !important;
    border: none !important;
    padding: 0 !important;
}

.dc-acervo-titulo a {
    color: inherit;
    text-decoration: none !important;
}

.dc-acervo-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}

.dc-acervo-resumo {
    font-size: 0.95em;
    color: #475569;
    line-height: 1.5;
    margin-bottom: 15px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.dc-acervo-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
    font-size: 0.85em;
    color: #94a3b8;
}

.dc-offline-since {
    color: #e74c3c;
    font-weight: bold;
}

.dc-empty-msg {
    text-align: center;
    padding: 50px;
    color: #64748b;
}

.dc-empty-msg i {
    font-size: 48px;
    margin-bottom: 20px;
    display: block;
}

.dark .dc-container { background: #1a1a1a; border-color: #333; }
.dark .dc-header-title { color: #60a5fa; }
.dark .dc-tab-item { color: #94a3b8; }
.dark .dc-filter-form { background: #262626; border-color: #333; }
.dark .dc-bloco-titulo { color: #f1f5f9; border-color: #333; }
.dark .dc-letra-btn { background: #262626; border-color: #333; color: #94a3b8; }
.dark .dc-acervo-row { background: #262626; border-color: #333; }
.dark .dc-acervo-titulo { color: #f1f5f9 !important; }
.dark .dc-acervo-resumo { color: #94a3b8; }


.dc-report-offline-btn {
    border: 2px solid #e74c3c !important;
    color: #e74c3c !important;
}

.dc-report-offline-btn:hover {
    background-color: #fceae9 !important;
    border-color: #c0392b !important;
    color: #c0392b !important;
}
