/* css/medalhas.css */
:root { --gold: #ffd700; --silver: #c0c0c0; --bronze: #cd7f32; }

/* Overlay de Carregamento Desfocado e Padronizado */
#loadingOverlay {
    position: fixed; inset: 0; background: rgba(0, 0, 0, 0.7); backdrop-filter: blur(5px);
    z-index: 9999; display: none; flex-direction: column; align-items: center; justify-content: center;
}
.big-loader { font-family: 'Orbitron', sans-serif; color: var(--neon-blue); font-size: 1rem; letter-spacing: 2px; text-align: center; animation: pulse 1.5s infinite; }
@keyframes pulse { 0%, 100% {opacity: 0.5;} 50% {opacity: 1;} }

.container { padding: 100px 2% 40px 2%; max-width: 1800px; width: 100%; box-sizing: border-box; margin: 0 auto; text-align: center; }
h1 { font-size: 1.6rem; margin-bottom: 5px; color: var(--neon-blue); text-transform: uppercase; font-family: 'Orbitron', sans-serif; text-shadow: 0 0 10px rgba(0,242,255,0.3); }
.subtitle { font-family: 'Orbitron', sans-serif; font-size: 0.75rem; color: rgba(255,255,255,0.6); letter-spacing: 2px; margin-bottom: 40px; text-transform: uppercase; }

/* =========================================
   0. PÓDIO DA PONTUAÇÃO TOTAL
   ========================================= */
.podium-wrapper {
    background: var(--card-bg); border: 1px solid rgba(0, 242, 255, 0.2); border-radius: 12px;
    padding: 30px 20px; margin-bottom: 50px; box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    display: flex; flex-direction: column; align-items: center; max-width: 800px; margin-left: auto; margin-right: auto;
}
.podium-title { font-family: 'Orbitron', sans-serif; font-size: 1.3rem; color: var(--neon-blue); margin-bottom: 40px; text-transform: uppercase; letter-spacing: 1px; display: flex; align-items: center; gap: 10px; }

.podium-display { display: flex; align-items: flex-end; justify-content: center; gap: 10px; width: 100%; height: 180px; margin-bottom: 20px; }

.podium-step { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 30%; max-width: 140px; border-radius: 8px 8px 0 0; position: relative; transition: 0.3s; }
.podium-step:hover { filter: brightness(1.2); transform: translateY(-3px); }

.step-1 { height: 160px; background: linear-gradient(to top, rgba(255,215,0,0.05), rgba(255,215,0,0.2)); border-top: 3px solid var(--gold); border-left: 1px solid rgba(255,215,0,0.2); border-right: 1px solid rgba(255,215,0,0.2); box-shadow: 0 -10px 30px rgba(255,215,0,0.15); z-index: 3; }
.step-2 { height: 120px; background: linear-gradient(to top, rgba(192,192,192,0.05), rgba(192,192,192,0.2)); border-top: 3px solid var(--silver); border-left: 1px solid rgba(192,192,192,0.2); border-right: 1px solid rgba(192,192,192,0.2); box-shadow: 0 -10px 20px rgba(192,192,192,0.1); z-index: 2; }
.step-3 { height: 90px;  background: linear-gradient(to top, rgba(205,127,50,0.05), rgba(205,127,50,0.2)); border-top: 3px solid var(--bronze); border-left: 1px solid rgba(205,127,50,0.2); border-right: 1px solid rgba(205,127,50,0.2); box-shadow: 0 -10px 20px rgba(205,127,50,0.1); z-index: 1; }

.podium-medal { position: absolute; top: -35px; width: 60px; height: 60px; object-fit: contain; filter: drop-shadow(0 10px 10px rgba(0,0,0,0.8)); }
.step-1 .podium-medal { width: 80px; height: 80px; top: -45px; filter: drop-shadow(0 0 15px rgba(255,215,0,0.5)); }

.step-cia { font-family: 'Orbitron', sans-serif; font-size: 1rem; font-weight: bold; margin-top: 10px; text-shadow: 0 2px 5px rgba(0,0,0,0.9); text-align: center; }
.step-pts { font-family: 'Orbitron', sans-serif; font-size: 0.8rem; color: #fff; font-weight: bold; margin-top: 3px; text-shadow: 0 2px 5px rgba(0,0,0,0.9); }

/* Novo 4º Lugar Vertical Harmonizado */
.podium-4th { display: flex; flex-direction: column; align-items: center; justify-content: center; background: rgba(0,0,0,0.4); padding: 15px 30px; border-radius: 8px; border: 1px dashed rgba(255,255,255,0.2); margin-top: 15px; min-width: 140px; box-shadow: 0 5px 15px rgba(0,0,0,0.3); }
.podium-4th .rank-label { margin-bottom: 8px; color: #aaa; background: rgba(255,255,255,0.05); }
.podium-4th .cia-nome { color: #ddd; font-size: 0.95rem; font-family: 'Orbitron', sans-serif; font-weight: bold;}
.podium-4th .cia-pts { font-size: 0.75rem; margin-top: 2px; font-family: 'Orbitron', sans-serif;}

/* =========================================
   1. INTERFACE DESKTOP E CLASSES COMPARTILHADAS
   ========================================= */
.desktop-view { display: block; }
.table-wrapper { width: 100%; overflow-x: auto; padding-bottom: 25px; padding-top: 10px; }
.table-wrapper::-webkit-scrollbar { height: 8px; }
.table-wrapper::-webkit-scrollbar-thumb { background: var(--neon-blue); border-radius: 10px; }
.tabela-grid { min-width: 1000px; display: flex; flex-direction: column; gap: 10px; text-align: left; }
.tabela-header { display: grid; background: rgba(0, 242, 255, 0.1); border-bottom: 2px solid var(--neon-blue); padding: 12px 15px; font-family: 'Orbitron', sans-serif; color: var(--neon-blue); font-size: 0.85rem; letter-spacing: 1px; text-transform: uppercase; border-radius: 8px 8px 0 0; gap: 12px; }
.tabela-header div { display: flex; align-items: center; justify-content: center; text-align: center; }
.tabela-header .col-mod { justify-content: flex-start; padding-left: 10px; }
.tabela-row { display: grid; background: var(--card-bg); border: 1px solid rgba(255, 255, 255, 0.05); border-radius: 8px; padding: 10px 15px; gap: 12px; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); }
.tabela-row:hover { border-color: rgba(0, 242, 255, 0.5); transform: translateY(-4px); box-shadow: 0 8px 20px rgba(0,242,255,0.15); z-index: 2; position: relative; }
.col-mod { display: flex; align-items: center; gap: 15px; border-right: 1px solid rgba(255,255,255,0.1); padding-right: 10px; }
.mod-icon { width: 45px; height: 45px; object-fit: contain; filter: drop-shadow(0 0 3px rgba(0,242,255,0.3)); flex-shrink: 0; }
.mod-nome { font-family: 'Orbitron', sans-serif; font-size: 0.95rem; color: #fff; font-weight: bold; letter-spacing: 1px; }

/* Harmonização das fontes para todo o documento */
.pos-cell { display: flex; align-items: center; justify-content: space-between; background: rgba(0,0,0,0.3); padding: 8px 15px; border-radius: 6px; gap: 10px; }
.pos-data { display: flex; flex-direction: column; gap: 3px; }
.cia-nome { font-family: 'Orbitron', sans-serif; font-size: 1rem; font-weight: bold; text-shadow: 0 0 5px rgba(255,255,255,0.2); }
.cia-pts { font-family: 'Orbitron', monospace; font-size: 0.75rem; color: #aaa; }
.mini-medal-desk { width: 35px; height: 35px; object-fit: contain; filter: drop-shadow(0 0 5px rgba(0,0,0,0.5)); flex-shrink: 0; }
.vazio { justify-content: center; color: #333; font-family: 'Orbitron', sans-serif; font-size: 0.8rem; }

/* =========================================
   2. INTERFACE MOBILE (ACORDEÃO)
   ========================================= */
.mobile-view { display: none; }
.accordion-list { flex-direction: column; gap: 12px; text-align: left; max-width: 800px; margin: 0 auto; }
.accordion-header { display: flex; align-items: center; justify-content: space-between; background: var(--card-bg); border: 1px solid rgba(0, 242, 255, 0.2); border-radius: 8px; padding: 12px 20px; cursor: pointer; transition: all 0.3s ease; }
.accordion-header:active { background: rgba(0, 242, 255, 0.1); border-color: var(--neon-blue); }
.accordion-header.active { background: rgba(0, 242, 255, 0.1); border-color: var(--neon-blue); border-radius: 8px 8px 0 0; }
.mod-info-mob { display: flex; align-items: center; gap: 15px; }
.toggle-icon { color: var(--neon-blue); transition: transform 0.3s ease; font-size: 28px; }
.accordion-header.active .toggle-icon { transform: rotate(180deg); }
.accordion-content { display: none; background: rgba(13, 17, 23, 0.8); border: 1px solid rgba(0, 242, 255, 0.2); border-top: none; border-radius: 0 0 8px 8px; padding: 20px; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 15px; }

.result-card { background: rgba(0, 0, 0, 0.4); border: 1px solid rgba(255, 255, 255, 0.05); border-radius: 8px; padding: 15px; display: flex; flex-direction: column; align-items: center; text-align: center; }
.rank-label { font-family: 'Orbitron', sans-serif; font-size: 0.7rem; color: #fff; background: rgba(255,255,255,0.1); padding: 4px 10px; border-radius: 10px; margin-bottom: 15px; letter-spacing: 1px; }
.mini-medal-mob { width: 45px; height: 45px; object-fit: contain; margin-bottom: 10px; filter: drop-shadow(0 0 8px rgba(0,0,0,0.8)); }

@media (max-width: 900px) {
    .desktop-view { display: none !important; }
    .mobile-view { display: flex; }
}
@media (max-width: 500px) {
    .accordion-content { grid-template-columns: 1fr; }
    .step-cia { font-size: 0.8rem; }
    .step-1 .step-cia { font-size: 1rem; }
    .step-pts { font-size: 0.8rem; }
    .podium-medal { width: 40px; height: 40px; top: -25px;}
    .step-1 .podium-medal { width: 60px; height: 60px; top: -35px;}
}