Link do botão
Ícone do botão Button Label
Ícone de carregamento
Um erro ocorreu enquanto processava o modelo.
The following has evaluated to null or missing:
==> assetVocabularyService.fetchGroupVocabulary(groupId, vocabularyName)  [in template "20099#20135#10700480" at line 1505, column 31]

----
Tip: If the failing expression is known to legally refer to something that's sometimes null or missing, either specify a default value like myOptionalVar!myDefault, or use <#if myOptionalVar??>when-present<#else>when-missing</#if>. (These only cover the last step of the expression; to cover the whole expression, use parenthesis: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
----

----
FTL stack trace ("~" means nesting-related):
	- Failed at: #assign tagsVocabulary = assetVocabul...  [in template "20099#20135#10700480" in function "getCategoriesNamesAndIds" at line 1505, column 5]
----
1<#-- Conteúdo Web -> Templates: Site de Crise - Include de templates--> 
2<#-- include "${templatesPath}/1975602" --> 
3 
4<#-- Conteúdo Web -> Templates: Site de Crise - Funções gerais--> 
5<#include "${templatesPath}/1975398" /> 
6 
7<#-- Conteúdo Web -> Templates: Busca pelas imagens do tipo de noticia --> 
8<#include "${templatesPath}/18598756" /> 
9	 
10<#assign POST_TYPES_CATEGORIES = getPostTypeImages()!default([]) /> 
11 
12<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Extrair dados de Notícias --> 
13<#--include "${templatesPath}/7762031" --> 
14 
15<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Título --> 
16<#-- include "${templatesPath}/7761976" --> 
17 
18<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Redes sociais e data de publicação --> 
19<#--include "${templatesPath}/7762069" --> 
20 
21<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Áudios do conteúdo da notícia --> 
22<#-- include "${templatesPath}/7761972" --> 
23<#function getNodesByLabel fieldList parentNode label> 
24    <#assign result = []/> 
25    <#attempt> 
26        <#assign groupId =  getIdFromFieldName(fieldList, label) /> 
27        <#assign xSeletorCaminho = saxReaderUtil.createXPath("dynamic-element[@name='${groupId}' ]") /> 
28        <#assign result = xSeletorCaminho.selectNodes(parentNode) /> 
29        <#return result /> 
30        <#recover> 
31            <#return result /> 
32    </#attempt> 
33</#function> 
34 
35<#function findVocabulary vocabularyName vocabularies> 
36    <#assign vocabularyNameLowerCase = vocabularyName?lower_case> 
37    <#list vocabularies as vocabulary> 
38        <#if vocabulary.name?lower_case == vocabularyNameLowerCase> 
39            <#return vocabulary> 
40        </#if> 
41    </#list> 
42    <#return {}> 
43</#function> 
44 
45<#-- ############# Conteúdo Web -> Templates: Site de Crise - Include de templates #################################### --> 
46<#function getSiteUrl> 
47    <#assign portalUtil = staticUtil["com.liferay.portal.kernel.util.PortalUtil"]> 
48    <#if layout?? && layout?has_content> 
49        <#return portalUtil.getLayoutFriendlyURL(layout, themeDisplay)?replace(layout.getFriendlyURL(), "")> 
50    </#if> 
51    <#return portalUtil.getLayoutFriendlyURL(layout, themeDisplay)> 
52</#function> 
53 
54<#function getSiteName> 
55    <#return layout.getGroup().getDescriptiveName(locale)> 
56</#function> 
57 
58<#function mountUrlToPage targetPage> 
59    <#assign baseUrl = getSiteUrl()> 
60    <#assign trimmedUrl = baseUrl?replace("/w/", "/")> 
61    <#assign trimmedUrl = trimmedUrl?substring(0, trimmedUrl?last_index_of("/"))> 
62    <#return trimmedUrl + "/" + targetPage> 
63</#function> 
64<#-- ################################################################################################################## --> 
65 
66 
67<#assign 
68    journalArticleLocalService  = serviceLocator.findService("com.liferay.journal.service.JournalArticleLocalService") 
69    assetVocabularyService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetVocabularyLocalService") 
70    assetCategoryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetCategoryLocalService") 
71    vocabularies = assetVocabularyService.getGroupVocabularies(groupId) 
72    tagsLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetTagLocalService") 
73    tagVocabulary = findVocabulary("Tag", vocabularies) 
74    flagVocabulary = findVocabulary("Flag", vocabularies) 
75    tagCategoryTitles = extractVocabularyTitles(tagVocabulary) 
76    flagCategoryTitles = extractVocabularyTitles(flagVocabulary) 
77    assetEntryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetEntryLocalService") 
78    fileEntryService = staticUtil["com.liferay.document.library.kernel.service.DLFileEntryLocalServiceUtil"] 
79    layoutLocalService = serviceLocator.findService("com.liferay.portal.kernel.service.LayoutLocalService") 
80    PortalUtil = staticUtil["com.liferay.portal.kernel.util.PortalUtil"] 
81    AssetEntryQueryService = objectUtil("com.liferay.asset.kernel.service.AssetEntryLocalServiceUtil").getService() 
82    AssetEntryQuery = objectUtil('com.liferay.asset.kernel.service.persistence.AssetEntryQuery') 
83/> 
84 
85<#-- Nome das midias adaptativas de imagem para desktop e mobile --> 
86<#assign adaptativeMediaDesktopResolutionName = "Preview-1000x0" /> 
87<#assign adaptativeMediaMobileResolutionName = "Thumbnail-300x300" /> 
88 
89<#assign typeOfNewsVocabulary = findVocabulary("Tipo de Notícia", vocabularies)/> 
90<#assign ourEnergyVocabulary = findVocabulary("Nossa Energia", vocabularies)/> 
91 
92<#assign newsJournalArticle = ""> 
93<#assign assetEntry = getAssetEntryFromRequest(assetEntryLocalService)> 
94<#if assetEntry?? && assetEntry?has_content> 
95    <#assign newsJournalArticle = journalArticleLocalService.fetchLatestArticle(assetEntry.classPK)/> 
96</#if> 
97 
98<#function getSingleNode name root> 
99    <#attempt> 
100        <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@name='${name}']/dynamic-content[@language-id='${locale}']") /> 
101        <#return xPathSelector.selectSingleNode( root ) /> 
102        <#recover> 
103            <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@name='${name}']") /> 
104            <#return xPathSelector.selectSingleNode( root ) /> 
105    </#attempt> 
106</#function> 
107 
108<#-- Função para obter a primeira categoria associonada a um Vocabulário o qual está associado a um Jornal Article --> 
109<#function getFirstCategoryOfVocabulary journalArticle vocabulary > 
110    <#attempt> 
111        <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) /> 
112        <#list categories as category> 
113            <#if vocabulary.getVocabularyId() == category.getVocabularyId()> 
114                <#return category.getName()> 
115            </#if> 
116        </#list> 
117        <#return ""> 
118 
119        <#recover> 
120            <#return "" /> 
121    </#attempt> 
122</#function> 
123 
124<#function getFirstCategoryObjectOfVocabulary journalArticle vocabulary > 
125    <#attempt> 
126        <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) /> 
127        <#list categories as category> 
128            <#if vocabulary.getVocabularyId() == category.getVocabularyId()> 
129                <#return category> 
130            </#if> 
131        </#list> 
132        <#return ""> 
133 
134        <#recover> 
135            <#return "" /> 
136    </#attempt> 
137</#function> 
138 
139<#-- Função para obter todas os ids das categorias associonadas a um Vocabulário o qual está associado a um Jornal Article --> 
140<#function getAllCategoryIdOfVocabulary journalArticle vocabulary > 
141    <#attempt> 
142        <#assign categoriesIds = [] /> 
143        <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) /> 
144        <#list categories as category> 
145            <#if vocabulary.getVocabularyId() == category.getVocabularyId()> 
146               <#assign categoriesIds = categoriesIds + [category.getCategoryId()] /> 
147            </#if> 
148        </#list> 
149        <#return categoriesIds> 
150 
151        <#recover> 
152            <#return [] /> 
153    </#attempt> 
154</#function> 
155 
156<#if newsJournalArticle?? && newsJournalArticle?has_content> 
157 
158    <div class="breadcrumb-breakpoint breakpoint"> 
159        <div class="breadcrumb-col col-2-11 md-col-1-8 sm-col-1-4">  
160            <#assign homeURL = "/" /> 
161 
162            <#if currentURL?contains('webserver')> 
163               <#assign homeURL = "/web/nossa-energia" />  
164            </#if> 
165 
166            <a href="${homeURL}" class="breadcrumb-page text previous-page paragraph-micro-regular" tabindex="0">  
167                <span class="breadcrumb-text-truncate" original-text="Home">Home</span>  
168                <div class="icon"></div> 
169            </a> 
170             
171            <#assign currentUrl = getSiteUrl()> 
172 
173            <#assign lastIndex = currentUrl?last_index_of("/")> 
174            <#assign urlWithoutLastSegment = currentUrl?substring(0, lastIndex+1)> 
175            <#assign urlWithoutW = urlWithoutLastSegment?replace("/w/", "/")> 
176 
177            <#assign breadcrumbOurEnergyCategory = getFirstCategoryObjectOfVocabulary(assetEntry, ourEnergyVocabulary) /> 
178            <#assign categoryURL = urlWithoutW/> 
179            <a href="${categoryURL}" class="breadcrumb-page text previous-page paragraph-micro-regular" tabindex="0">  
180                <span class="breadcrumb-text-truncate" original-text="${breadcrumbOurEnergyCategory.getTitle(locale)}">${breadcrumbOurEnergyCategory.getTitle(locale)}</span>  
181                <div class="icon"></div> 
182            </a> 
183 
184            <span original-text="${newsJournalArticle.getTitle(locale)}" class="breadcrumb-page text active-page active paragraph-micro-bold">${newsJournalArticle.getTitle(locale)}</span> 
185        </div> 
186    </div> 
187 
188    <#-- add to head --> 
189    <@liferay_util["html-top"]> 
190      <script type="application/ld+json"> 
191
192        "@context": "https://schema.org", 
193        "@type": "BreadcrumbList", 
194        "itemListElement": [ 
195
196            "@type": "ListItem", 
197            "position": 1, 
198            "name": "Home", 
199            "item": "${themeDisplay.getPortalURL() + homeURL}" 
200          }, 
201
202            "@type": "ListItem", 
203            "position": 2, 
204            "name": "${breadcrumbOurEnergyCategory.getTitle(locale)}", 
205            "item": "${themeDisplay.getPortalURL() + categoryURL}" 
206          }, 
207
208            "@type": "ListItem", 
209            "position": 3, 
210            "name": "${newsJournalArticle.getTitle(locale)}", 
211            "item": "${themeDisplay.getPortalURL() + portalUtil.getLayoutFriendlyURL(layout, themeDisplay)}" 
212
213
214
215      </script> 
216    </@> 
217 
218    <div class="ptb-news__read-news"> 
219        <div class="ptb-news__read-news-post "> 
220            <div class="ptb-news__read-content"> 
221 
222                <#assign 
223                ddmStructure = newsJournalArticle.getDDMStructure() 
224                fieldList = getFieldListByStructure(ddmStructure) 
225                xmlArticle = newsJournalArticle.getDocument().getRootElement() 
226
227 
228                <#assign 
229                <#-- Título principal da notícia --> 
230                mainHeadlineOfTheNews = newsJournalArticle.getTitle(locale, true) 
231                <#-- Título de destaque da notícia --> 
232                featuredNewsHeadline = extractFeaturedNewsHeadline(fieldList, xmlArticle) 
233                <#-- Sumário da notícia --> 
234                newsSummary = extractNewsSummary(fieldList, xmlArticle) 
235                <#-- Data de publicação da notícia --> 
236                lastPublishDate = extractPublishDate(newsJournalArticle) 
237                <#-- Data de criação da notícia --> 
238                createDate = newsJournalArticle.getCreateDate() 
239
240 
241                <#-- Flag da notícia ----------------------------------------------------------------------------------> 
242                <#assign flag = getFirstCategoryTitle(newsJournalArticle, flagCategoryTitles, assetCategoryLocalService)> 
243 
244                <#-- Url amigável da notícia para visualização em DisplayPage -----------------------------------------> 
245                <#assign newsJournalArticleFriendlyUrl = themeDisplay.getPortalURL() + themeDisplay.getPathFriendlyURLPublic() + layout.getGroup().friendlyURL + "/w/" + newsJournalArticle.getUrlTitle()> 
246 
247                <#-- Conteúdo da notícia ------------------------------------------------------------------------------> 
248                <#assign newsContent = getFieldValue(fieldList, xmlArticle, "Corpo da notícia")> 
249 
250                <#-- Início Vídeo do youtube no corpo da notícia  --> 
251                <#--  structuredContentId refente ao webcontent da display page  --> 
252                <#assign structuredContentId =  newsJournalArticle.getResourcePrimKey()/> 
253 
254                <#assign ytVideoId = ""/> 
255                <#assign ytVideoIdentificador = ""/> 
256                <#assign ytVideoTitle = ""/> 
257                <#assign ytVideoDescription = ""/> 
258                <#assign ytVideoUploadDate = ""/> 
259                <#assign ytVideoDuration = ""/> 
260 
261                <#assign videoSchemaMarkupList = []/> 
262 
263                <#--  Obtém os dados do webcontent via rest api  --> 
264                <#assign newsStructuredContent = restClient.get("/headless-delivery/v1.0/structured-contents/${structuredContentId}")/> 
265                <#if newsStructuredContent?has_content && newsStructuredContent.contentFields??> 
266                  <#if newsStructuredContent.contentFields?size gt 0> 
267                    <#list newsStructuredContent.contentFields as field> 
268                      <#if field.label == "Gestão de vídeos do youtube"> 
269                        <#if field.nestedContentFields?size gt 0> 
270                          <#list field.nestedContentFields as ytVideoField> 
271                            <#if ytVideoField.label == "ID do vídeo do Youtube"> 
272                              <#assign ytVideoId = ytVideoField.contentFieldValue.data/> 
273                            </#if> 
274                            <#if ytVideoField.label == "Identificador do vídeo no corpo da notícia"> 
275                              <#assign ytVideoIdentificador = ytVideoField.contentFieldValue.data/> 
276                            </#if> 
277                            <#assign ytIframe = ' 
278                              <div class="yt-video-container" onclick="loadVideo(this, \'${ytVideoId}\')"> 
279                                <img class="yt-thumb-img" alt="Thumbnail do vídeo do youtube" src="https://img.youtube.com/vi/${ytVideoId}/hqdefault.jpg"/> 
280                                <div class="thumb-play-button"> 
281                                  <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"> 
282                                    <path d="M0 16C0 7.16344 7.16344 0 16 0C24.8366 0 32 7.16344 32 16C32 24.8366 24.8366 32 16 32C7.16344 32 0 24.8366 0 16Z" fill="white" fill-opacity="0.8"/> 
283                                    <path d="M22.2563 15.5744L13.2625 10.0744C13.1868 10.0277 13.1 10.0021 13.0111 10.0001C12.9221 9.99816 12.8343 10.02 12.7566 10.0633C12.6789 10.1066 12.6141 10.1698 12.569 10.2465C12.5239 10.3232 12.5001 10.4105 12.5 10.4994V21.4994C12.5001 21.5884 12.5239 21.6757 12.569 21.7524C12.6141 21.8291 12.6789 21.8923 12.7566 21.9356C12.8343 21.9789 12.9221 22.0007 13.0111 21.9988C13.1 21.9968 13.1868 21.9712 13.2625 21.9244L22.2563 16.4244C22.3301 16.3808 22.3913 16.3186 22.4338 16.2441C22.4763 16.1696 22.4987 16.0852 22.4987 15.9994C22.4987 15.9137 22.4763 15.8293 22.4338 15.7548C22.3913 15.6803 22.3301 15.6181 22.2563 15.5744Z" fill="#008542"/> 
284                                  </svg> 
285                                </div> 
286                              </div> 
287                            '/> 
288                            <#assign newsContent = newsContent?replace("<p>#[${ytVideoIdentificador}]</p>", ytIframe) /> 
289 
290                            <#if ytVideoField.label == "Título do vídeo"> 
291                              <#assign ytVideoTitle = ytVideoField.contentFieldValue.data/> 
292                            </#if> 
293                            <#if ytVideoField.label == "Descrição do vídeo"> 
294                              <#assign ytVideoDescription = ytVideoField.contentFieldValue.data/> 
295                            </#if> 
296                            <#if ytVideoField.label == "Data de publicação/upload do vídeo"> 
297                              <#assign ytVideoUploadDate = ytVideoField.contentFieldValue.data/> 
298                            </#if> 
299                            <#if ytVideoField.label == "Duração"> 
300                              <#assign ytVideoDuration = ytVideoField.contentFieldValue.data/> 
301                            </#if> 
302                          </#list> 
303                          <#assign videoSchemaMarkupList += [{ 
304                            "id": ytVideoId, 
305                            "name": ytVideoTitle, 
306                            "description": ytVideoDescription, 
307                            "uploadDate": (ytVideoUploadDate!)?has_content?then(ytVideoUploadDate?datetime("yyyy-MM-dd HH:mm")?string("yyyy-MM-dd'T'HH:mm:ssXXX"), ""), 
308                            "thumbnailUrl": "https://img.youtube.com/vi/${ytVideoId}/hqdefault.jpg", 
309                            "contentUrl": "https://www.youtube.com/watch?v=${ytVideoId}", 
310                            "embedUrl": "https://www.youtube.com/embed/${ytVideoId}", 
311                            "duration": ytVideoDuration 
312                          }] /> 
313                        </#if> 
314                      </#if> 
315                    </#list> 
316                  </#if> 
317                </#if> 
318 
319                <script> 
320                  function loadVideo(container, ytVideoId) { 
321                    const iframe = document.createElement("iframe"); 
322                    iframe.src = "https://www.youtube.com/embed/" + ytVideoId + "?rel=0&modestbranding=1&showinfo=0&autoplay=1"; 
323                    iframe.frameBorder = "0"; 
324                    iframe.allow = "autoplay; encrypted-media"; 
325                    iframe.style = "position:absolute; top:0; left:0; width:100%; height:100%;"; 
326 
327                    container.innerHTML = ""; // Remove imagem e botão 
328                    container.appendChild(iframe); // Insere o iframe 
329
330                </script>  
331                <style> 
332                  .yt-video-container { 
333                    position: relative; 
334                    padding-top: 56.25%; 
335                    overflow: hidden; 
336                    cursor: pointer; 
337                    border-radius: var(--border-radius-lg, 16px); 
338                    margin: var(--space-md, 24px) 0; 
339
340 
341                  .yt-video-container img { 
342                    position: absolute; 
343                    top: 0px; 
344                    left: 0px; 
345                    object-fit: cover; 
346                    max-width: none !important; 
347                    max-height: none !important; 
348
349 
350                  .yt-video-container .thumb-play-button { 
351                    position: absolute; 
352                    top: 50%; 
353                    left: 50%; 
354                    transform: translate(-50%, -50%); 
355                    border-radius: 50%; 
356
357                </style> 
358                <#-- Fim Vídeo do youtube no corpo da notícia  --> 
359 
360                <#assign WEB_STORIES_FIELD_SET_FIELD_REF = "Fieldset91054335" /> 
361                <#assign WEB_STORIES_IDENTIFICATION_FIELD_LABEL = "Identificador do Carousel" /> 
362                <#assign WEB_STORIES_TITLE_FIELD_LABEL = "Título do carrossel" /> 
363 
364                <#assign webStoriesCarouselsIds = [] /> 
365                <#assign webStoriesCarouselsTitles = [] /> 
366                <#assign webStoriesCarouselsIdsFieldSetList = getNodes(WEB_STORIES_FIELD_SET_FIELD_REF, xmlArticle) /> 
367 
368                <#list webStoriesCarouselsIdsFieldSetList as webStoriesFieldSet> 
369                    <#assign webStoriesCarouselsIds = webStoriesCarouselsIds + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_IDENTIFICATION_FIELD_LABEL) ] /> 
370                    <#assign webStoriesCarouselsTitles = webStoriesCarouselsTitles + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_TITLE_FIELD_LABEL) ] /> 
371                </#list> 
372 
373                <#assign wsCarouselContent = ' 
374                <div id="[CAROUSEL_ID]" class="ws-carousel"> 
375                    <div class="ws-carousel-header"> 
376                        <h1 class="h2"> 
377                            [CAROUSEL_TITLE] 
378                        </h1> 
379                        <div class="nav-buttons"> 
380                            <svg class="nav-arrow left-arrow inactive" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg"> 
381                                <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#bababa"/> 
382                                <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#bababa" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
383                            </svg> 
384                            <svg class="nav-arrow right-arrow active" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg"> 
385                                <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#008542"/> 
386                                <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
387                            </svg> 
388                        </div> 
389                    </div> 
390                    <div class="ws-carousel-body"> 
391                        <div class="ws-container"> 
392                        </div> 
393                    </div>     
394                </div>' /> 
395 
396                <#list webStoriesCarouselsIds as item > 
397                    <#assign carouselDiv = wsCarouselContent?replace("[CAROUSEL_ID]", item)?replace("[CAROUSEL_TITLE]", webStoriesCarouselsTitles[item?index]) /> 
398                    <#assign newsContent = newsContent?replace("<p>#[${item}]</p>", carouselDiv) /> 
399                </#list> 
400 
401 
402                <#assign WEB_STORIES_FIELD_SET_FIELD_REF = "Fieldset91054335" /> 
403                <#assign WEB_STORIES_IDENTIFICATION_FIELD_LABEL = "Identificador do Carousel" /> 
404                <#assign WEB_STORIES_TITLE_FIELD_LABEL = "Título do carrossel" /> 
405 
406                <#assign webStoriesCarouselsIds = [] /> 
407                <#assign webStoriesCarouselsTitles = [] /> 
408                <#assign webStoriesCarouselsIdsFieldSetList = getNodes(WEB_STORIES_FIELD_SET_FIELD_REF, xmlArticle) /> 
409 
410                <#list webStoriesCarouselsIdsFieldSetList as webStoriesFieldSet> 
411                    <#assign webStoriesCarouselsIds = webStoriesCarouselsIds + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_IDENTIFICATION_FIELD_LABEL) ] /> 
412                    <#assign webStoriesCarouselsTitles = webStoriesCarouselsTitles + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_TITLE_FIELD_LABEL) ] /> 
413                </#list> 
414 
415                <#assign wsCarouselContent = ' 
416                <div id="[CAROUSEL_ID]" class="ws-carousel"> 
417                    <div class="ws-carousel-header"> 
418                        <h1 class="h2"> 
419                            [CAROUSEL_TITLE] 
420                        </h1> 
421                        <div class="nav-buttons"> 
422                            <svg class="nav-arrow left-arrow inactive" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg"> 
423                                <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#bababa"/> 
424                                <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#bababa" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
425                            </svg> 
426                            <svg class="nav-arrow right-arrow active" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg"> 
427                                <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#008542"/> 
428                                <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
429                            </svg> 
430                        </div> 
431                    </div> 
432                    <div class="ws-carousel-body"> 
433                        <div class="ws-container"> 
434                        </div> 
435                    </div>     
436                </div>' /> 
437 
438                <#list webStoriesCarouselsIds as item > 
439                    <#assign carouselDiv = wsCarouselContent?replace("[CAROUSEL_ID]", item)?replace("[CAROUSEL_TITLE]", webStoriesCarouselsTitles[item?index]) /> 
440                    <#assign newsContent = newsContent?replace("<p>#[${item}]</p>", carouselDiv) /> 
441                </#list> 
442 
443 
444                <#-- Seção do áudio para o conteúdo da notícia --------------------------------------------------------> 
445                <#assign audios = [] 
446                audioIdentifierFieldSetList = getNodes("Fieldset65862311", xmlArticle) 
447
448                <#list audioIdentifierFieldSetList as audioIdentifierFieldSet> 
449                    <#assign 
450                    <#-- Grupo com as informações de url e legenda do áudio --> 
451                    audioInfoFieldSet = getGroupNode("Fieldset24035689",audioIdentifierFieldSet)> 
452                    <#assign 
453                    externalAudioUrl = getFieldValue(fieldList, audioInfoFieldSet, "URL externa do áudio") 
454                    internalAudioUrl = getFileFromXML("DocumentLibrary24170668", audioInfoFieldSet, fileEntryService) 
455                    audioLegend = getFieldValue(fieldList, audioInfoFieldSet, "Legenda do áudio")> 
456 
457                    <#if externalAudioUrl?has_content || internalAudioUrl.url?has_content > 
458                        <#assign audios += [{ 
459                        "id": getFieldValue(fieldList, audioIdentifierFieldSet, "Identificador de Áudio"), 
460                        "externalUrl" : externalAudioUrl, 
461                        "internalUrl" : internalAudioUrl, 
462                        "legend" : audioLegend 
463                        }]> 
464                    </#if> 
465                </#list> 
466 
467 
468                <#-- Seção de vídeo para o conteúdo da notícia --------------------------------------------------------> 
469                <#assign videos = [] 
470                videoIdentifierFieldSetList = getNodes("Fieldset24460782", xmlArticle) 
471
472                <#list videoIdentifierFieldSetList as videoIdentifierFieldSet> 
473                    <#assign 
474                    <#-- Grupo com as informações de url e legenda do áudio --> 
475                    videoInfoFieldSet = getGroupNode("Fieldset51040010",videoIdentifierFieldSet) 
476 
477                    videos += [{ 
478                    "id": getFieldValue(fieldList,videoIdentifierFieldSet, "Identificador de Vídeo"), 
479                    "youtubeID" : getFieldValue(fieldList, videoInfoFieldSet, "ID do vídeo do YouTube"), 
480                    "internalUrl" : getFileFromXML("DocumentLibrary15265409", videoInfoFieldSet, fileEntryService), 
481                    "legend" : getFieldValue(fieldList, videoInfoFieldSet, "Legenda do vídeo") 
482                    }] 
483
484                </#list> 
485 
486 
487                <#-- Seção de links para o conteúdo da notícia --------------------------------------------------------> 
488                <#assign 
489                links = [] 
490                linksFieldSetList = getNodes("Fieldset37770113", xmlArticle) 
491
492                <#list linksFieldSetList as linksFieldSet> 
493                    <#assign linkFieldSetList = getNodes("Fieldset10524367", linksFieldSet)> 
494 
495                    <#list linkFieldSetList as linkFieldSet> 
496                        <#assign 
497                        linkId = getFieldValue(fieldList, linkFieldSet, "Identificador do link") 
498 
499                        <#-- Grupo com as informações de url e legenda do áudio --> 
500                        linkInfoFieldSeet = getGroupNode("Fieldset86037074", linkFieldSet) 
501 
502                        iconType = getFieldValue(fieldList, linkInfoFieldSeet, "Ícone do link") 
503                        links += [{ 
504                        "id": linkId, 
505                        "externalLink" : getFieldValue(fieldList, linkInfoFieldSeet, "Link externo"), 
506                        "pageLink" : getPageLayoutLinkFromXML("LinkToLayout77941175", linkInfoFieldSeet, layoutLocalService), 
507                        "file" : getFileFromXML("DocumentLibrary34820760", linkInfoFieldSeet, fileEntryService), 
508                        "title" : getFieldValue(fieldList, linkInfoFieldSeet, "Título do link"), 
509                        "iconType" : iconType 
510                        }] 
511
512                    </#list> 
513                </#list> 
514 
515 
516                 
517                <#assign galleryItems = []/> 
518                
519                <#assign mediaGroupList = getNodes(getIdFromFieldName(fieldList, "Galeria de multimídia"), xmlArticle) /> 
520                 
521                <#list mediaGroupList as mediaGroup >       
522                    <#assign nodes = getNodes(getIdFromFieldName(fieldList, "Imagem da Galeria") , mediaGroup) /> 
523                    <#list nodes as node>                   
524                        <#assign image = getMediaInfo(fieldList, node, "Imagem", fileEntryService) /> 
525                        <#if image?? && image?has_content && image.url?has_content> 
526                            <#assign galleryItems += [{"image": image}] /> 
527                        </#if>   
528                    </#list> 
529                </#list> 
530                 
531				<#-- Seção de Quotes para o conteúdo da notícia --------------------------------------------------------> 
532				<#-- Seção de Quotes para o conteúdo da notícia --------------------------------------------------------> 
533                <#assign quotes = [] /> 
534                <#assign quotesRootFieldSetList = getNodes(getIdFromFieldName(fieldList, "Quotes da notícia"), xmlArticle) /> 
535                <#list quotesRootFieldSetList as quotesFieldSetList> 
536                     <#assign quoteFieldSetList = getNodes(getIdFromFieldName(fieldList, "Quote"), quotesFieldSetList) /> 
537						         <#list quoteFieldSetList as quoteFieldSet> 
538                                        <#assign imageJsonString  = getSingleNodeString("Image94530628", quoteFieldSet)   />                                                                       
539                                        <#assign imageJson = {"url": "", "alt": "", "fileEntryId" : "", "title" : ""} /> 
540                                        <#attempt> 
541                                            <#if imageJsonString ?? && imageJsonString?has_content>  
542                                                <#assign imageJson = jsonFactoryUtil.createJSONObject(imageJsonString) /> 
543                                            </#if> 
544 
545                                            <#if !imageJson.url?? || !imageJson.url?has_content> 
546                                                <#assign imageJson = {"url": "", "alt": "", "fileEntryId" : "", "title" : ""} /> 
547                                            </#if> 
548                                        <#recover>                                             
549                                        </#attempt> 
550 
551                                         <#if !imageJson.url?? || !imageJson.url?has_content> 
552                                                <#assign imageJson = {"url": "", "alt": "", "fileEntryId" : "", "title" : ""} /> 
553                                            </#if> 
554                                 					       
555                                    <#assign quotes += [{ 
556                                    "id": getFieldValue(fieldList, quoteFieldSet, "Identificador do Quote"), 
557                                    "content" : getFieldValue(fieldList, quoteFieldSet, "Texto do Quote"), 
558                                    "author" : getFieldValue(fieldList, quoteFieldSet, "Nome do autor"), 
559                                    "image" : {"url": imageJson.url, "alt": imageJson.alt, "fileEntryId" : imageJson.fileEntryId, "title" : imageJson.title}  
560                                    }] /> 
561						          </#list>                    
562                </#list> 
563 
564                <#assign newsInfo = { 
565                "mainHeadlineOfTheNews": mainHeadlineOfTheNews, 
566                "featuredNewsHeadline" : featuredNewsHeadline, 
567                "displayDate" : formatDate(createDate), 
568                "createDate": createDate, 
569                "newsSummary" : newsSummary, 
570                "newsMedia":  extractNewsMedia(fieldList, xmlArticle, fileEntryService), 
571                "lastPublishDate": lastPublishDate, 
572                "flag": flag, 
573                "url": newsJournalArticleFriendlyUrl, 
574                "newsContent": newsContent, 
575                "audios": audios, 
576                "videos": videos, 
577                "galleryItems": galleryItems, 
578                "links": links, 
579								"quotes": quotes 
580                }/> 
581 
582                <#-- Renderizar o título principal da notícia --> 
583                <#-- Conteúdo-> Conteúdo Web -> Templates: Site de Crise - Notícia - Título --> 
584                <@renderHeadLine newsInfo/> 
585 
586                <#-- Renderizar o resumo da notícia --> 
587                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Resumo --> 
588                <@renderReview newsInfo/> 
589 
590                <#-- Renderizar a data de publicação/edição da notícia e redes sociais --> 
591                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Redes sociais e data de publicação --> 
592                <@renderPublishAndSocialMediasInfos newsJournalArticle newsInfo/> 
593 
594                <#-- Renderizar as tags da notícia --> 
595                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Render Tags --> 
596                <#assign categoriesAsssetEntryResponse = restClient.get("/headless-delivery/v1.0/structured-contents/${assetEntry.getClassPK()}?nestedFields=embeddedTaxonomyCategory&fields=taxonomyCategoryBriefs") /> 
597               
598                <#if categoriesAsssetEntryResponse?? && categoriesAsssetEntryResponse?has_content && categoriesAsssetEntryResponse.taxonomyCategoryBriefs??> 
599                    <#assign tagCategoryList = getCategoriesNamesAndIds("Tags", categoriesAsssetEntryResponse.taxonomyCategoryBriefs) /> 
600                    <#assign removeStartParameterWhenTagIsClicked = true /> 
601                    <#assign includeRequestParams = false /> 
602                    <#assign NEWS_PAGE_NAME= "categorias"/> 
603                </#if> 
604                 
605 
606                <#-- Renderizar a imagem de destaque da notícia --> 
607                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Imagem de destaque --> 
608                <#assign typeOfNews = getFirstCategoryOfVocabulary(assetEntry, typeOfNewsVocabulary) /> 
609                 
610                <#if !typeOfNews?? || !typeOfNews?has_content || typeOfNews != "Infográfico" >                
611                    <@renderNewsFeaturedMedia newsInfo /> 
612                </#if> 
613 
614                <#-- Renderizar o conteúdo da notícia --> 
615                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Conteúdo da notícia --> 
616                <@renderNewsContent newsInfo/> 
617 
618                <#-- Renderizar o conteúdo da notícia-->  
619                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Conteúdo da notícia --> 
620 
621                <#-- Renderizar o conteúdo da notícia-->  
622                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Conteúdo da notícia --> 
623 
624                <#-- Renderiza botoes de compartilhamento na versao mobile --> 
625                <div class="render-share-news-container publish_and_social_medias_infos_desk mobile"> 
626                    <@renderShareAndCopyNews/> 
627                </div> 
628 
629                <#-- Renderizar links da notícia --> 
630                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Links do conteúdo da notícia --> 
631                <@renderLinks newsInfo /> 
632 
633                <@renderCite /> 
634 
635                <#-- Renderizar áudios da notícia --> 
636                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Áudios do conteúdo da notícia --> 
637 
638                <#-- Renderizar galeria de imagens notícia --> 
639                <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Render galeria --> 
640                <@renderGallery newsInfo /> 
641									 
642                <#-- Renderizar quotes da notícia --> 
643                <@renderQuotes newsInfo /> 
644            </div> 
645        </div> 
646    </div> 
647<#else > 
648    <div class="ptb-news__read-news paragraph-sm-regular">      
649        <p> <#if locale == "pt_BR"> Nenhuma notícia <#else> There are no news </#if></p> 
650    </div> 
651 
652    <style> 
653        .ptb-news__read-news p { 
654            color: #515867; 
655
656 
657        body.high-contrast-active .ptb-news__read-news p { 
658            color: var(--color-neutral-100); 
659
660    </style> 
661</#if> 
662 
663<style> 
664    .breadcrumb-breakpoint { 
665        padding-top: var(--space-xxl); 
666        padding-bottom: var(--space-xl); 
667
668 
669    body.high-contrast-active .breadcrumb-breakpoint { 
670        background: var(--background-surface-level-01, #010101); 
671
672 
673    .breadcrumb-breakpoint .breadcrumb-col { 
674        display: flex; 
675        width: max-content; 
676        gap: var(--space-xxs); 
677        height: fit-content; 
678        overflow-x: hidden; 
679
680 
681    .breadcrumb-breakpoint #liferay-breadcrumb { 
682        display: none; 
683
684 
685    .breadcrumb-breakpoint .breadcrumb-page { 
686        display: flex; 
687        gap: var(--space-micro); 
688        height: var(--size-md); 
689        size: var(--size-md); 
690        border: 1px solid rgba(0, 0, 0, 0); 
691        box-sizing: border-box; 
692        border-radius: var(--border-radius-sm); 
693
694 
695    .breadcrumb-breakpoint a.breadcrumb-page.text span, 
696    .breadcrumb-breakpoint span.breadcrumb-page.text { 
697        white-space: nowrap; 
698
699 
700    .breadcrumb-breakpoint .breadcrumb-page a:focus { 
701        outline: none; 
702
703 
704    .breadcrumb-breakpoint .breadcrumb-page.active-page { 
705        color: var(--color-text-primary-default); 
706        background-color: var(--color-background-default-level-02); 
707        border-radius: var(--border-radius-sm); 
708
709 
710    body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.active-page { 
711        background: var(--background-surface-level-02, #373737); 
712        color: var(--text-primary-default, #FFF); 
713
714 
715    .breadcrumb-breakpoint .breadcrumb-page.previous-page { 
716        transition: 300ms ease-in-out; 
717
718 
719    .breadcrumb-breakpoint .breadcrumb-page.previous-page.text { 
720        text-decoration: var(--text-decoration-none); 
721        color: var(--color-text-primary-default); 
722        text-transform: capitalize; 
723        padding-left: var(--space-xxs); 
724        padding-right: var(--space-xxs); 
725
726 
727    body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.previous-page.text { 
728        color: var(--text-primary-default, #FFF); 
729
730 
731    .breadcrumb-breakpoint .breadcrumb-page.active-page.text { 
732        color: var(--color-text-primary-default); 
733        text-decoration: var(--text-decoration-none); 
734        background-color: var(--color-background-default-level-02); 
735        text-transform: capitalize; 
736        padding-left: var(--space-xxs); 
737        padding-right: var(--space-xxs); 
738
739 
740    body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.previous-page.text { 
741        color: var(--text-primary-default, #FFF); 
742
743 
744    .breadcrumb-breakpoint .breadcrumb-page.previous-page:not(.three-dots):hover { 
745        background-color: var(--color-background-default-level-01); 
746        border-color: var(--border-color-dark); 
747        border-radius: var(--border-radius-sm); 
748        border: 1px solid; 
749        transition: all 300ms ease-in-out; 
750
751 
752    body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.previous-page:not(.three-dots):hover { 
753        background-color: transparent; 
754
755 
756    .breadcrumb-breakpoint .breadcrumb-page:focus-visible { 
757        margin: var(--space-micro); 
758        border-radius: var(--space-micro); 
759        outline: none; 
760        border: 1px solid var(--color-primary-medium); 
761        box-sizing: border-box; 
762        transition: 300ms ease-in-out; 
763
764 
765    body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page:focus-visible { 
766        border: 1px solid rgba(228, 247, 232, 1); 
767
768 
769    .breadcrumb-breakpoint .breadcrumb-page .icon { 
770        width: var(--size-xxs); 
771        height: var(--size-xxs); 
772        border-color: var(--border-color-darkest); 
773        background-image: url('data:image/svg+xml,%3Csvg width="12" height="12" viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M4.5 2.25L8.25 6L4.5 9.75" stroke="%23525252" stroke-linecap="round" stroke-linejoin="round"%3E%3C/path%3E%3C/svg%3E'); 
774        background-size: cover; 
775        margin-top: auto; 
776        margin-bottom: auto; 
777
778 
779    body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page .icon { 
780        background-image: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12" fill="none"><path d="M4.5 2.25L8.25 6L4.5 9.75" stroke="white" stroke-linecap="round" stroke-linejoin="round"/></svg>'); 
781
782 
783    .ptb-news__read-news { 
784        overflow: hidden; 
785
786 
787    body.high-contrast-active .ptb-news__read-news { 
788        background: var(--background-surface-level-01, #010101); 
789
790</style> 
791 
792 
793<#-- ############# Site de Crise - Notícia - Redes sociais e data de publicação ####################################### --> 
794<#-- 
795Add elements from the sidebar to define your template. Type "${" to use the 
796autocomplete feature. 
797--> 
798 
799<#function normalizeRichText richText> 
800  <#return richText 
801    ?replace('&[a-z]+;', ' ', 'r') <#--  Remove entidades HTML  --> 
802    ?replace('<[^>]+>', '', 'r')   <#--  Remove tags HTML  --> 
803    ?replace('[\n\r]+', ' ', 'r')  <#--  Normaliza quebras de linha  --> 
804    ?replace('[“”‘’]', '"', 'r')   <#--  Escapa espas curvas  --> 
805    ?replace('\\\\', '\\\\', 'r')  <#--  Escapa barras invertidas  --> 
806    ?trim                          <#--  Remove espaços no ínicio/fim  --> 
807    ?json_string                   <#--  Escapa o rstante da string para um JSON válido  --> 
808
809</#function> 
810 
811<#macro addSchemaMarkup newsInfo> 
812  <#assign image = ""/> 
813  <#assign datePublished = newsInfo.createDate?string('yyyy-MM-ddHH:mm:ss-03:00')/> 
814  <#assign datePublishedISOFormat = datePublished?substring(0, 10) + "T" + datePublished?substring(10)/> 
815  <#assign dateModified = newsInfo.lastPublishDate?string('yyyy-MM-ddHH:mm:ss-03:00')/> 
816  <#assign dateModifiedISOFormat = dateModified?substring(0, 10) + "T" + dateModified?substring(10)/> 
817 
818  <#if newsInfo.newsMedia.imageSrc?? && newsInfo.newsMedia.imageSrc?has_content> 
819    <#assign image = "${themeDisplay.getPortalURL()}/o/adaptive-media/image/${newsInfo.newsMedia.fileEntryId}/Thumbnail-300x300/image"/> 
820  <#else> 
821    <#if newsInfo.newsMedia.videoYotubeID?? && newsInfo.newsMedia.videoYotubeID?has_content> 
822      <#assign image = "https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/hqdefault.jpg"/> 
823    </#if> 
824  </#if> 
825 
826  <#--  Busca informações do cadastro Organization do institucional  do ambiente de produção--> 
827  <#--  35467409 é o id da estrutura de webcontent "Dados Estruturados - Organização"  --> 
828  <#assign organizationName = "" /> 
829  <#assign logoImgSrc = "" /> 
830 
831  <#assign structuredContents = restClient.get("/headless-delivery/v1.0/content-structures/35467409/structured-contents")/> 
832  <#if structuredContents?has_content && structuredContents.items?has_content> 
833    <#assign structuredContentData  = structuredContents.items[0]/> 
834    <#if structuredContentData?has_content && structuredContentData.contentFields?has_content> 
835      <#list structuredContentData.contentFields as item> 
836        <#if item.label == "Nome legal da organização"> 
837          <#assign organizationName = item.contentFieldValue.data!""> 
838        </#if> 
839        <#if item.label == "Logotipo" && item.contentFieldValue?has_content && item.contentFieldValue.image??> 
840          <#assign logoImgSrc = themeDisplay.getURLPortal() + item.contentFieldValue.image.contentUrl!""> 
841        </#if> 
842      </#list> 
843    </#if> 
844  </#if> 
845 
846  <#-- add to head --> 
847  <@liferay_util["html-top"]> 
848    <script type="application/ld+json"> 
849
850        "@context": "https://schema.org", 
851        "@type": "BlogPosting", 
852        "headline": "${normalizeRichText(newsInfo.mainHeadlineOfTheNews)}", 
853        "alternativeHeadline": "${normalizeRichText(newsInfo.featuredNewsHeadline)}", 
854        "image": "${image}", 
855        "author": { 
856          "@type": "Person", 
857          "name": "Petrobras", 
858          "url": "${themeDisplay.getPortalURL()}/autor" 
859        }, 
860        "publisher": { 
861          "@type": "Organization", 
862          "name": "${organizationName}", 
863          "logo": { 
864            "@type": "ImageObject", 
865            "url": "${logoImgSrc}" 
866
867        }, 
868        "datePublished": "${datePublishedISOFormat}", 
869        "dateModified": "${dateModifiedISOFormat}", 
870        "mainEntityOfPage": "${newsInfo.url}", 
871        "description": "${normalizeRichText(newsInfo.newsSummary)}", 
872        "keywords": [<#list tagCategoryList as tag>"${tag[0]}"<#sep>, </#list>], 
873        "articleBody": "${normalizeRichText(newsInfo.newsContent)}" 
874
875    </script> 
876 
877      <#list videoSchemaMarkupList as videoInfo> 
878        <#if videoInfo.id?has_content> 
879          <script type="application/ld+json"> 
880
881              "@context": "https://schema.org", 
882              "@type": "VideoObject", 
883              "name": "${normalizeRichText(videoInfo.name)}", 
884              "description": "${normalizeRichText(videoInfo.description)}", 
885              "uploadDate": "${videoInfo.uploadDate}", 
886              "thumbnailUrl": "${videoInfo.thumbnailUrl}", 
887              "contentUrl": "${videoInfo.contentUrl}", 
888              "embedUrl": "${videoInfo.embedUrl}", 
889              "duration": "${videoInfo.duration}", 
890              "publisher": { 
891                "@type": "Organization", 
892                "name": "Petrobras", 
893                "logo": { 
894                  "@type": "ImageObject", 
895                  "url": "${logoImgSrc}" 
896
897
898
899          </script> 
900        </#if> 
901      </#list> 
902    </@> 
903</#macro> 
904 
905<@addSchemaMarkup newsInfo/> 
906 
907<#macro renderHeadLine newsInfo> 
908     
909    <div class="main-headline-container breakpoint"> 
910        <div class="main-headline-container-col col-2-11 md-col-1-8 sm-col-1-4"> 
911            <h1 class="main-headline display-sm">${newsInfo.featuredNewsHeadline}</h1> 
912            <div class="bar"></div> 
913        </div> 
914    </div> 
915 
916    <style> 
917        .ptb-news__read-news .main-headline-container .main-headline-container-col { 
918            display: flex; 
919            flex-direction: column; 
920            gap: var(--space-sm); 
921            padding-bottom: var(--space-lg); 
922
923 
924        .ptb-news__read-news .main-headline-container .main-headline-container-col * { 
925            margin: 0; 
926            padding: 0; 
927
928 
929        .ptb-news__read-news .main-headline-container .main-headline { 
930            font-family: var(--font-family-base); 
931            color: var(--color-neutral-800); 
932
933 
934        body.high-contrast-active .ptb-news__read-news .main-headline-container .main-headline { 
935            color: var(--text-primary-default, var(--color-neutral-100)); 
936
937 
938        .ptb-news__read-news .main-headline-container .bar { 
939            width: 32px; 
940            height: var(--size-micro); 
941            background: var(--color-secondary-medium); 
942
943 
944        body.high-contrast-active .ptb-news__read-news .main-headline-container .bar{ 
945            background: var(--text-secondary-accent, #FFEEB3); 
946
947 
948        @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
949            .ptb-news__read-news .main-headline-container .main-headline-container-col { 
950                gap: var(--space-xs, 12px); 
951
952
953    </style> 
954</#macro> 
955<#-- ################################################################################################################## --> 
956 
957<#-- ############# Site de Crise - Notícia - Redes sociais e data de publicação ####################################### --> 
958<#macro renderReview newsInfo> 
959    <#assign summaryCssRoot = "summary-container" /> 
960 
961    <div class="${summaryCssRoot}-breakpoint breakpoint"> 
962        <div class="${summaryCssRoot} col-2-11 md-col-1-8 sm-col-1-4"> 
963            <p class="summary paragraph-lg-regular"> 
964                ${newsInfo.newsSummary} 
965            </p> 
966        </div> 
967        
968    </div> 
969 
970    <style> 
971        .${summaryCssRoot} .summary { 
972            padding-bottom: var(--space-lg); 
973
974 
975        .${summaryCssRoot} .summary, 
976        .${summaryCssRoot} .summary * { 
977            color: var(--color-neutral-800, #373737); 
978            font-family: var(--font-family-base); 
979            font-style: var(--font-style-italic); 
980            margin: var(--space-none); 
981
982 
983        body.high-contrast-active .summary, 
984        body.high-contrast-active .summary * { 
985            color: var(--text-secondary-default, #F8F8F8); 
986
987    </style> 
988</#macro> 
989<#-- ################################################################################################################## --> 
990 
991<#-- ############# Site de Crise - Notícia - Redes sociais e data de publicação ####################################### --> 
992<#macro renderPublishAndSocialMediasInfos journalArticle newsInfo> 
993 
994    <div class="publish_and_social_medias_infos_desk-breakpoint breakpoint"> 
995        <div class="publish_and_social_medias_infos_desk col-2-11 md-col-1-8 sm-col-1-4"> 
996            <div class="publish_and_update_date"> 
997                <#assign lastPublishDate = journalArticle.getModifiedDate()> 
998                <#assign createDate = journalArticle.getCreateDate()> 
999                <#if journalArticle.getLastPublishDate()??> 
1000                    <#assign lastPublishDate = journalArticle.getLastPublishDate()> 
1001                </#if> 
1002 
1003                <#if locale == "pt_BR"> 
1004                    <p class="updated">Atualizado em ${formatDate(lastPublishDate)}</p> 
1005                    <p class="published">Postado em ${formatDate(createDate)}</p> 
1006                <#else > 
1007                    <p class="updated">Updated on ${formatDate(lastPublishDate)}</p> 
1008                    <p class="published">Posted on ${formatDate(createDate)}</p> 
1009                </#if> 
1010            </div> 
1011            <div class="render-share-news-container desktop"> 
1012                <@renderShareAndCopyNews/> 
1013            </div> 
1014        </div> 
1015    </div> 
1016 
1017    <style> 
1018			.ptb-news__read-news .hidden { 
1019			     display: none; 
1020
1021        /*Data de publicação e redes sociais */ 
1022 
1023        /* Desktop */ 
1024        .ptb-news__read-news .publish_and_social_medias_infos_desk { 
1025            position: relative; 
1026            display: grid; 
1027            grid-template-columns: auto 1fr auto; 
1028
1029 
1030        .ptb-news__read-news .render-share-news-container.mobile { 
1031            display: none; 
1032
1033 
1034        .ptb-news__read-news .publish_and_social_medias_infos_desk * { 
1035            padding: var(--space-none, 0); 
1036            margin: var(--space-none, 0); 
1037            font-family: var(--font-family-base); 
1038            font-style: var(--font-style-normal, normal); 
1039            font-weight: var(--font-weight-regular, 400); 
1040            font-size: var(--font-size-xxs, 16px); 
1041            line-height: var(--line-height-xl, 160%); 
1042            color: var(--color-neutral-800, #373737); 
1043
1044 
1045        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk * { 
1046            color: var(--text-secondary-default, #F8F8F8); 
1047
1048 
1049        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk a svg path, 
1050        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .mobile-share svg path { 
1051            stroke: var(--color-neutral-500, #D7D7D7); 
1052            fill: rgba(255, 255, 255, 0.32); 
1053
1054 
1055        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk a svg circle, 
1056        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .mobile-share svg circle { 
1057            fill: rgba(255, 255, 255, 0.32); 
1058
1059 
1060        .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date { 
1061            display: flex; 
1062            align-items: center; 
1063            gap: var(--space-sm, 16px); 
1064
1065 
1066        .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .updated { 
1067            font-weight: var(--font-weight-bold, 700); 
1068            font-size: var(--font-size-xxxs, 14px); 
1069
1070 
1071        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .updated { 
1072            color: var(--text-primary-default, var(--color-neutral-100)); 
1073
1074 
1075        .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .published { 
1076            font-weight: var(--font-weight-normal, 400); 
1077            font-size: var(--font-size-xxxs, 14px); 
1078
1079 
1080        .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container { 
1081            display: flex; 
1082            width: 100%; 
1083            justify-content: flex-end; 
1084            align-items: center; 
1085            gap: var(--space-sm, 16px); 
1086
1087   
1088        .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .social-media-share { 
1089            position: relative; 
1090
1091	 
1092        .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .social-media-share span { 
1093            position: absolute; 
1094            width: 100%; 
1095            height: 100%; 
1096            opacity: 0; 
1097            overflow: hidden; 
1098            pointer-events: none; 
1099
1100 
1101        .ptb-news__read-news .social-media-share { 
1102	          width: 36px; 
1103	          height: 36px; 
1104	          border-radius: 50%; 
1105	          display: flex; 
1106	          align-items: center; 
1107	          justify-content: center; 
1108	          background-color: transparent; 
1109	          transition: background-color 0.3s ease; 
1110
1111 
1112        /* Hover dos ícones de redes sociais no modo alto contraste */ 
1113		body.high-contrast-active .ptb-news__read-news .social-media-share:hover { 
1114	        background-color: #000000 !important; 
1115
1116 
1117        /* Corrige stroke e fill dos ícones ao passar o mouse (hover) */ 
1118        body.high-contrast-active .ptb-news__read-news .social-media-share:hover svg path, 
1119        body.high-contrast-active .ptb-news__read-news .social-media-share:hover svg circle, 
1120        body.high-contrast-active .ptb-news__read-news .social-media-share:hover svg rect, 
1121        body.high-contrast-active .ptb-news__read-news .social-media-share:hover svg g 
1122
1123	        stroke: #000000 !important; 
1124	        fill: #ffffff !important; 
1125
1126 
1127        /* Ícone branco */ 
1128        .ptb-news__read-news .social-media-share:hover svg * { 
1129	        fill: #008542 !important; 
1130	        stroke: #ffffff !important; 
1131
1132 
1133        .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .mobile-share { 
1134            display: none; 
1135
1136 
1137        .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container { 
1138            background: var(--color-neutral-100); 
1139            border: var(--border-width-hairline, 1px) solid #CCCCCC; 
1140            border-radius: 32px; 
1141            display: flex; 
1142            align-items: center; 
1143            gap: var(--space-sm, 16px); 
1144            padding: 6px var(--space-xxs, 8px); 
1145            height: 36px; 
1146            margin: 0; 
1147            cursor: pointer; 
1148
1149 
1150        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container { 
1151            background: rgba(255, 255, 255, 0.32); 
1152            border: var(--border-width-hairline, 1px) solid rgba(255, 255, 255, 0.32); 
1153
1154 
1155        .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container svg { 
1156            width: 18px; 
1157
1158 
1159        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk  svg path { 
1160            stroke: var(--color-neutral-500, #D7D7D7); 
1161
1162 
1163        .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text { 
1164            font-family: var(--font-family-base); 
1165            font-style: normal; 
1166            margin: 0; 
1167            height: 100%; 
1168            display: flex; 
1169            align-items: center; 
1170            color: var(--color-primary-medium, #008542); 
1171            font-size: var(--font-size-micro, 12px); 
1172            font-weight: var(--font-weight-bold, 700); 
1173            line-height: var(--line-height-lg, 144%); 
1174            pointer-events: none; 
1175
1176 
1177        /* Hover padrão */ 
1178        .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container:hover { 
1179           background-color: #008542; 
1180           border-color: #008542; 
1181
1182 
1183        /* Texto branco no hover */ 
1184         .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container:hover .text { 
1185            color: #ffffff; 
1186
1187 
1188         /* Ícone branco (SVG path) no hover */ 
1189         .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container:hover svg path { 
1190             stroke: #ffffff !important; 
1191
1192 
1193         /* Hover no modo high-contrast */ 
1194         body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container:hover { 
1195           background-color: #ffffff; 
1196           border-color: #ffffff; 
1197
1198 
1199         body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container:hover .text { 
1200            color: #000000; 
1201
1202 
1203         body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container:hover svg path { 
1204            stroke: #000000 !important; 
1205
1206	 
1207	             
1208        .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text .copy-text-title-news { 
1209            position: absolute; 
1210            width: 100%; 
1211            height: 100%; 
1212            opacity: 0; 
1213            overflow: hidden; 
1214
1215 
1216        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text { 
1217            color: var(--text-primary-accent, #E4F7E8); 
1218
1219 
1220        .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message { 
1221            display: none; 
1222            position: absolute; 
1223            bottom: -43px; 
1224            right: -15px; 
1225            padding: var(--space-xxxs, 4px) 15px; 
1226            margin: var(--space-micro, 2px) 10px; 
1227            width: 110px; 
1228            font-family: var(--font-family-base); 
1229            font-size: var(--font-size-micro, 12px); 
1230 
1231            color: #008542; 
1232            background: var(--color-neutral-100); 
1233            border-radius: var(--border-radius-md, 8px); 
1234 
1235            filter: drop-shadow(0px 4px 16px rgba(0, 0, 0, 0.16)); 
1236 
1237            cursor: pointer; 
1238
1239 
1240        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message { 
1241            background: rgba(255, 255, 255, 0.32); 
1242            color: var(--text-primary-accent, #E4F7E8); 
1243
1244 
1245        .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message-active { 
1246            display: block; 
1247
1248 
1249        /* Mobile */ 
1250 
1251        .ptb-news__read-news .publish_and_social_medias_infos_mobile { 
1252            display: flex; 
1253            flex-direction: column; 
1254            gap: 19px; 
1255
1256 
1257        .ptb-news__read-news .publish_and_social_medias_infos_mobile { 
1258            display: none; 
1259
1260 
1261        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text { 
1262            display: flex; 
1263            justify-content: space-between; 
1264            align-items: center; 
1265            margin-bottom: var(--space-lg, 32px); 
1266
1267 
1268        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date * { 
1269            padding: 0; 
1270            margin: 0; 
1271            font-family: var(--font-family-base); 
1272            font-style: var(--font-style-normal, normal); 
1273            font-size: var(--font-size-micro, 12px); 
1274            line-height: 136%; 
1275            color: var(--color-neutral-800, #373737); 
1276
1277 
1278        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date * { 
1279            color: var(--text-primary-accent, #E4F7E8); 
1280
1281 
1282        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date { 
1283            display: flex; 
1284            flex-direction: column; 
1285            gap: 0; 
1286
1287 
1288        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date .updated { 
1289            font-weight: var(--font-weight-bold, 700); 
1290
1291 
1292        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date .published { 
1293            font-weight: var(--font-weight-regular, 400); 
1294
1295 
1296        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container { 
1297            background: var(--color-neutral-100); 
1298            border: var(--border-width-hairline, 1px) solid #CCCCCC; 
1299            border-radius: 32px; 
1300            display: flex; 
1301            align-items: center; 
1302            gap: var(--space-sm, 16px); 
1303            padding: 6px var(--space-xxs, 8px); 
1304            width: 112px; 
1305            height: 36px; 
1306
1307 
1308        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container { 
1309            background: rgba(255, 255, 255, 0.32); 
1310            color: var(--text-primary-accent, #E4F7E8); 
1311
1312 
1313        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container p.text { 
1314            margin: 0; 
1315
1316 
1317        .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container .text { 
1318            font-family: var(--font-family-base); 
1319            font-style: var(--font-style-normal, normal); 
1320            font-weight: var(--font-weight-regular, 400); 
1321            font-size: 13px; 
1322            line-height: 14px; 
1323            color: #008542; 
1324
1325 
1326        body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container .text { 
1327            background: rgba(255, 255, 255, 0.32); 
1328            color: var(--text-primary-accent, #E4F7E8); 
1329
1330 
1331        @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
1332 
1333            .ptb-news__read-news .publish_and_social_medias_infos_desk .render-share-news-container.desktop { 
1334                display: none; 
1335
1336 
1337            .ptb-news__read-news .render-share-news-container.mobile { 
1338                display: block; 
1339                margin: var(--space-xl) var(--space-lg) 0 var(--space-lg); 
1340
1341 
1342            .ptb-news__read-news .publish_and_social_medias_infos_desk * { 
1343                font-size: var(--font-size-micro, 12px); 
1344
1345             
1346            .ptb-news__read-news .publish_and_social_medias_infos_desk { 
1347                display: grid; 
1348                grid-template-columns: 100%; 
1349                grid-template-rows: 1fr 100%; 
1350
1351 
1352            .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date { 
1353                grid-column-start: 1; 
1354                grid-column-end: 1; 
1355                grid-row-start: 1; 
1356                grid-row-end: 1; 
1357                gap: var(--space-xxs, 8px); 
1358
1359 
1360            .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date * { 
1361                padding: 0; 
1362                margin: 0; 
1363                font-family: var(--font-family-base); 
1364                font-style: var(--font-style-normal); 
1365                color: var(--color-neutral-800, #373737); 
1366                font-weight: var(--font-weight-bold); 
1367                font-size: var(--font-size-xxxs, 14px); 
1368                line-height: var(--line-height-md, 132%); 
1369
1370 
1371            body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date * { 
1372                color: var(--text-primary-accent, #E4F7E8); 
1373
1374 
1375            .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .published { 
1376                font-weight: var(--font-weight-regular, 400); 
1377
1378 
1379            .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container { 
1380                grid-column-start: 1; 
1381                grid-column-end: 2; 
1382                grid-row-start: 2; 
1383                grid-row-end: 2; 
1384                justify-content: center; 
1385                gap: var(--space-xs, 12px); 
1386                height: 36px; 
1387
1388 
1389            .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container { 
1390                grid-column-start: 1; 
1391                grid-column-end: 2; 
1392                grid-row-start: 2; 
1393                grid-row-end: 2; 
1394                max-width: 112px; 
1395                place-self: end; 
1396
1397 
1398            .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text { 
1399                display: none; 
1400
1401 
1402            .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message { 
1403                bottom: 0; 
1404                right: -9px; 
1405
1406 
1407            .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .mobile-share { 
1408                display: initial; 
1409
1410
1411 
1412        @media screen and (min-width: ${MIN_TABLET_WIDTH}px) and (max-width: ${MAX_TABLET_WIDTH}px) { 
1413            .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container { 
1414                padding-right: 0; 
1415
1416
1417 
1418 
1419    </style> 
1420 
1421    <script> 
1422        AUI().ready(function () { 
1423 
1424            function copyOnClick(text) { 
1425 
1426                const strWithoutHtmlTags = text.replace(/(<([^>]+)>)/gi, ""); 
1427                const strWithoutMarcationBrackets = strWithoutHtmlTags.replace(/ *#\[[^\]]*]/g, ""); 
1428                const strWithoutNextPrevious = strWithoutMarcationBrackets.replace(/Previous    Next/g, ""); 
1429                const strWithoutBlankEnters = strWithoutNextPrevious.replace(/^\s*$(?:\r\n?|\n)/gm, ""); 
1430                const strWithoutBlankLines = strWithoutBlankEnters.replace(/&nbsp;/g, ''); 
1431                const tempInput = document.createElement("textarea"); 
1432                tempInput.value = strWithoutBlankLines; 
1433 
1434                document.body.appendChild(tempInput); 
1435                tempInput.select(); 
1436                document.execCommand("copy"); 
1437 
1438                if (tempInput.value.length > 0) { 
1439                    copyMessages.forEach(copyMessage => copyMessage.classList.add('copy-message-active')); 
1440 
1441                    timerToMessage() 
1442
1443 
1444                document.body.removeChild(tempInput); 
1445
1446 
1447            const copyTextContainers = document.querySelectorAll(".publish_and_social_medias_infos_desk .copy-text-container"); 
1448            copyTextContainers.forEach(copyTextContainer => { 
1449                copyTextContainer.addEventListener("click", (event) => { 
1450                    event.preventDefault(); 
1451                    const titleText = document.querySelector(".main-headline-container .main-headline").innerHTML; 
1452                    const publishSocialMediaText = document.querySelector(".publish_and_social_medias_infos_desk .publish_and_update_date").innerHTML; 
1453                    const tagsText = document.querySelector(".tags").innerHTML; 
1454                    const newsContentText = document.querySelector(".news-content").innerHTML; 
1455                    const text = titleText + publishSocialMediaText + tagsText + newsContentText; 
1456                    copyOnClick(text) 
1457                }); 
1458            }); 
1459 
1460            const mobileShare = async () => { 
1461                try { 
1462                    const shareData = { 
1463                        title: '${newsInfo.mainHeadlineOfTheNews}', 
1464                        text: '', 
1465                        url: '${newsInfo.url}' 
1466                    }; 
1467                    await navigator.share(shareData); 
1468                } catch (err) { 
1469 
1470
1471            }; 
1472 
1473            const mobileShareButtons = document.querySelectorAll(".publish_and_social_medias_infos_desk .mobile-share"); 
1474            mobileShareButtons.forEach(mobileShareButton => { 
1475                mobileShareButton.addEventListener("click", (event) => { 
1476                    event.preventDefault(); 
1477                    mobileShare(); 
1478                }); 
1479            }); 
1480 
1481            const copyMessages = document.querySelectorAll('.copy-message'); 
1482            const timerToMessage = () => { 
1483                setTimeout(() => { 
1484                    removeMessage(); 
1485                }, 2500); 
1486 
1487
1488 
1489            const removeMessage = () => { 
1490                copyMessages.forEach(copyMessage => copyMessage.classList.remove('copy-message-active')); 
1491
1492 
1493        }); 
1494    </script> 
1495 
1496</#macro> 
1497 
1498<#-- ################################################################################################################## --> 
1499 
1500<#-- ############# Site de Crise - Notícia - Render Tags ############################################################## --> 
1501 
1502<#function getCategoriesNamesAndIds vocabularyName categoriesList> 
1503    <#assign tagCategoryList = [] /> 
1504 
1505    <#assign tagsVocabulary = assetVocabularyService.fetchGroupVocabulary(groupId, vocabularyName) /> 
1506    <#list categoriesList as cat> 
1507        <#if tagsVocabulary.getVocabularyId() == cat.embeddedTaxonomyCategory.taxonomyVocabularyId > 
1508            <#assign tagCategoryList += [[cat.taxonomyCategoryName, cat.taxonomyCategoryId]] /> 
1509        </#if> 
1510    </#list> 
1511    <#return tagCategoryList> 
1512</#function> 
1513 
1514<#assign 
1515flagVocabulary = findVocabulary("Flag", vocabularies) 
1516assetCategoryPropService = serviceLocator.findService("com.liferay.asset.category.property.service.AssetCategoryPropertyLocalService") 
1517/> 
1518 
1519<#macro renderNewsTags categoryList targetPageWhenClickTag removeStartParameterWhenTagIsClicked updateTagParamsWhenClicked> 
1520    <#assign tagPrefix = "tags-" + randomNumber(groupId?number)> 
1521    <div class="${tagPrefix}-breakpoint breakpoint"> 
1522        <div class="${tagPrefix} col-2-11 md-col-1-8 sm-col-1-4"> 
1523 
1524            <div class="tags"> 
1525                <#list categoryList as cat> 
1526                    <#assign tagLink = mountUrlToPage("") /> 
1527                    <#assign urlWithoutTrailingSlash = tagLink?substring(0, tagLink?length - 1)> 
1528                    <#assign lastSlashIndex = urlWithoutTrailingSlash?last_index_of("/")> 
1529                    <#assign newUrl = urlWithoutTrailingSlash?substring(0, lastSlashIndex + 1)> 
1530                    <#assign tagLink = newUrl + "categorias?category=" + cat[1] /> 
1531                    <a href="${tagLink}" 
1532                        class="category" cetegoryid="${cat[1]}"># ${cat[0]}</a> 
1533                </#list> 
1534            </div> 
1535        </div>    
1536    </div> 
1537 
1538    <style> 
1539        .${tagPrefix} { 
1540            display: flex; 
1541            flex-direction: column; 
1542            padding: 0; 
1543            gap: var(--space-sm); 
1544
1545 
1546        .${tagPrefix} * { 
1547            margin: 0; 
1548            padding: 0; 
1549
1550 
1551        .${tagPrefix} .tags { 
1552            display: flex; 
1553            flex-wrap: wrap; 
1554            gap: var(--space-xxs, 8px); 
1555            padding: var(--space-lg) 0 0; 
1556
1557 
1558        .${tagPrefix} .tags .category { 
1559            padding: var(--space-xxxs) var(--space-xxs); 
1560            background: var(--color-neutral-100); 
1561            border: var(--border-width-hairline, 1px) solid var(--color-neutral-500); 
1562            border-radius: var(--border-radius-xl); 
1563 
1564            font-family: var(--font-family-base); 
1565            font-style: var(--font-style-normal); 
1566            font-weight: var(--font-weight-regular); 
1567            font-size: var(--font-size-xxxs); 
1568            line-height: var(--line-height-xl); 
1569            color: var(--color-neutral-800, #373737); 
1570            cursor: pointer; 
1571
1572 
1573        body.high-contrast-active .${tagPrefix} .tags .category { 
1574            background: rgba(255, 255, 255, 0.32); 
1575            border: 1px solid rgba(255, 255, 255, 0.32); 
1576            color: var(--text-secondary-default, #F8F8F8); 
1577
1578 
1579        @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
1580            .${tagPrefix} .tags { 
1581                display: flex; 
1582                flex-wrap: wrap; 
1583                gap: 8px; 
1584                padding: var(--space-sm) 0 var(--space-lg); 
1585
1586 
1587            .${tagPrefix} { 
1588                margin-top: var(--space-sm); 
1589
1590
1591    </style> 
1592 
1593    <script> 
1594        AUI().ready(function () { 
1595 
1596            const urlParams = new URLSearchParams(window.location.search); 
1597            const categories = urlParams.getAll("category").sort(); 
1598 
1599            const root = document.querySelector(".${tagPrefix}"); 
1600            const tags = root.querySelectorAll(".category"); 
1601            tags.forEach((tag, index) => { 
1602 
1603                const categoryId = tag.getAttribute("cetegoryid"); 
1604                if (categories.indexOf(categoryId) != -1) { 
1605                    tag.classList.add("active"); 
1606
1607 
1608                <#if updateTagParamsWhenClicked> 
1609                tag.addEventListener("click", (e) => { 
1610                    e.preventDefault(); 
1611                    const clickedTag = e.target; 
1612                    const urlParams = new URLSearchParams(window.location.search); 
1613                    urlParams.delete("tag"); 
1614                    urlParams.delete("category"); 
1615 
1616                    const categoryId = clickedTag.getAttribute("cetegoryid"); 
1617                    urlParams.append("category", categoryId); 
1618 
1619                    <#if removeStartParameterWhenTagIsClicked> 
1620                    urlParams.delete("start"); 
1621                    </#if> 
1622 
1623                    const href = "${themeDisplay.getPortalURL() + mountUrlToPage(targetPageWhenClickTag)}?" + urlParams.toString(); 
1624                    window.location.href = href; 
1625                }); 
1626                </#if> 
1627            }); 
1628        }); 
1629    </script> 
1630 
1631</#macro> 
1632 
1633<#-- ################################################################################################################## --> 
1634 
1635<#-- ############# Site de Crise - Notícia - Imagem de destaque ####################################################### --> 
1636<#macro renderNewsFeaturedMedia newsInfo> 
1637    <#if (newsInfo.newsMedia.imageSrc?? && newsInfo.newsMedia.imageSrc?has_content) || (newsInfo.newsMedia.videoYotubeID?? && newsInfo.newsMedia.videoYotubeID?has_content) || (newsInfo.newsMedia.internalVideo?? && newsInfo.newsMedia.internalVideo.url?has_content)> 
1638        <div class="news-featured-media"> 
1639             
1640            <div class="media-breakpoint breakpoint"> 
1641                <div class="media-col col-2-11 md-col-1-8 sm-col-1-4"> 
1642                    <#if newsInfo.newsMedia.imageSrc?? && newsInfo.newsMedia.imageSrc?has_content> 
1643                        <#-- Midias adaptativas de imagem para desktop e mobile --> 
1644                        <#assign fileDataRequest = restClient.get("/headless-delivery/v1.0/documents/${newsInfo.newsMedia.fileEntryId}") /> 
1645                        <#assign urlAdaptativeMediaMobile = newsInfo.newsMedia.imageSrc/> 
1646                        <#assign urlAdaptativeMediaDesktop = newsInfo.newsMedia.imageSrc/> 
1647                         
1648                        <#if fileDataRequest?? && fileDataRequest.adaptedImages?? > 
1649                            <#assign dataAdaptativeMedia = fileDataRequest.adaptedImages /> 
1650                            <#list dataAdaptativeMedia as data> 
1651                                <#if data.resolutionName == adaptativeMediaDesktopResolutionName> 
1652                                    <#assign urlAdaptativeMediaDesktop = data.contentUrl/> 
1653                                </#if> 
1654                                <#if data.resolutionName == adaptativeMediaMobileResolutionName> 
1655                                    <#assign urlAdaptativeMediaMobile = data.contentUrl/> 
1656                                </#if>      
1657                            </#list> 
1658                        </#if> 
1659 
1660                        <picture> 
1661                            <source media="(max-width:767px)" srcset="${urlAdaptativeMediaMobile}"> 
1662                            <img src="${urlAdaptativeMediaDesktop}" loading="lazy" alt="${newsInfo.newsMedia.imageAlt}"/> 
1663                        </picture> 
1664												<@liferay_util["html-top"]> 
1665                            <meta name="title" content="${newsInfo.mainHeadlineOfTheNews}"> 
1666                            <meta name="description" content="${newsInfo.newsSummary}"> 
1667 
1668                            <meta property="og:url" content="${currentURL}"> 
1669                            <meta property="og:type" content="website"> 
1670                            <meta property="og:title" content="${newsInfo.mainHeadlineOfTheNews}"> 
1671				            				<meta property="og:description" content="${newsInfo.newsSummary}" /> 
1672                            <meta property="og:image" content="${themeDisplay.getPortalURL()}/o/adaptive-media/image/${newsInfo.newsMedia.fileEntryId}/Thumbnail-300x300/image"> 
1673                            <meta property="og:image:alt" content="${newsInfo.newsMedia.imageAlt}"> 
1674 
1675                            <meta name="twitter:card" content="summary_large_image"> 
1676                            <meta name="twitter:url" content="${currentURL}" /> 
1677                            <meta name="twitter:title" content="${newsInfo.mainHeadlineOfTheNews}"> 
1678                            <meta name="twitter:description" content="${newsInfo.newsSummary}" /> 
1679                            <meta name="twitter:image" content= "${themeDisplay.getPortalURL()}/o/adaptive-media/image/${newsInfo.newsMedia.fileEntryId}/Thumbnail-300x300/image" > 
1680							 							<meta name="twitter:image:alt" content="${newsInfo.newsMedia.imageAlt}"> 
1681                        </@> 
1682                    <#else> 
1683                        <#if newsInfo.newsMedia.videoYotubeID?? && newsInfo.newsMedia.videoYotubeID?has_content> 
1684                            <iframe loading="lazy" data-video-id="${newsInfo.newsMedia.videoYotubeID}" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe> 
1685                            <@liferay_util["html-top"]>       
1686                            		<meta name="title" content="${newsInfo.mainHeadlineOfTheNews}"> 
1687                            		<meta name="description" content="${newsInfo.newsSummary}"> 
1688							 
1689							    							<meta property="og:url" content="${currentURL}"> 
1690                                <meta property="og:type" content="website"> 
1691                                <meta property="og:title" content="${newsInfo.mainHeadlineOfTheNews}"> 
1692				                				<meta property="og:description" content="${newsInfo.newsSummary}" /> 
1693                                <meta property="og:image" content="https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/hqdefault.jpg"> 
1694															  <meta property="og:image:alt" content="Youtube Video Thumbnail"> 
1695 
1696                                <meta name="twitter:card" content="summary_large_image"> 
1697                                <meta name="twitter:url" content="${currentURL}" /> 
1698                                <meta name="twitter:title" content="${newsInfo.mainHeadlineOfTheNews}"> 
1699                                <meta name="twitter:description" content="${newsInfo.newsSummary}" /> 
1700                                <meta name="twitter:image" content= "https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/hqdefault.jpg" > 
1701															  <meta name="twitter:image:alt" content="Youtube Video Thumbnail"> 
1702                            </@> 
1703														<#else> 
1704                            <video loading="lazy"> 
1705                                <source src="${newsInfo.newsMedia.internalVideo.url}"> 
1706                                Your browser does not support the video tag. 
1707                            </video> 
1708                        </#if> 
1709 
1710                         <div class="banner-video-icons"> 
1711                            <#if newsInfo.newsMedia.videoYotubeID?? && newsInfo.newsMedia.videoYotubeID?has_content> 
1712                                <picture> 
1713                                    <source media="(max-width:767px)" srcset="https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/mqdefault.jpg"> 
1714                                    <img class="banner-video-thumb-iframe" loading="lazy" src="https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/hqdefault.jpg" alt="YouTube Thumbnail"/> 
1715                                </picture> 
1716                            </#if> 
1717                            <svg class="banner-video-icon-play" width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"> 
1718                                <path d="M0 16C0 7.16344 7.16344 0 16 0C24.8366 0 32 7.16344 32 16C32 24.8366 24.8366 32 16 32C7.16344 32 0 24.8366 0 16Z" fill="white" fill-opacity="0.8"/> 
1719                                <path d="M22.2563 15.5744L13.2625 10.0744C13.1868 10.0277 13.1 10.0021 13.0111 10.0001C12.9221 9.99816 12.8343 10.02 12.7566 10.0633C12.6789 10.1066 12.6141 10.1698 12.569 10.2465C12.5239 10.3232 12.5001 10.4105 12.5 10.4994V21.4994C12.5001 21.5884 12.5239 21.6757 12.569 21.7524C12.6141 21.8291 12.6789 21.8923 12.7566 21.9356C12.8343 21.9789 12.9221 22.0007 13.0111 21.9988C13.1 21.9968 13.1868 21.9712 13.2625 21.9244L22.2563 16.4244C22.3301 16.3808 22.3913 16.3186 22.4338 16.2441C22.4763 16.1696 22.4987 16.0852 22.4987 15.9994C22.4987 15.9137 22.4763 15.8293 22.4338 15.7548C22.3913 15.6803 22.3301 15.6181 22.2563 15.5744Z" fill="#008542"/> 
1720                            </svg> 
1721                        </div> 
1722                    </#if> 
1723                </div> 
1724            </div> 
1725             
1726            <div class="credit-legend breakpoint"> 
1727							 
1728                    <div class="credit-legend-container col-2-11 md-col-1-8 sm-col-1-4"> 
1729											<#if newsInfo.newsMedia.legend != ""> 
1730															<div class="legend paragraph-micro-regular"> 
1731																	<p>${newsInfo.newsMedia.legend}</p> 
1732															</div> 
1733											</#if> 
1734											<#if newsInfo.newsMedia.credits != ""> 
1735															<p class="credits paragraph-micro-regular"> 
1736																	${newsInfo.newsMedia.credits} 
1737															</p>     
1738											</#if> 
1739 
1740                    </div> 
1741            </div> 
1742        </div> 
1743    </#if> 
1744    <style> 
1745        .ptb-news__read-news .news-featured-media { 
1746            padding: var(--space-xl) 0 var(--space-xl) 0; 
1747
1748 
1749        .ptb-news__read-news .news-featured-media .media-col { 
1750            position: relative; 
1751
1752 
1753        .ptb-news__read-news .news-featured-media img, 
1754        .ptb-news__read-news .news-featured-media video, 
1755        .ptb-news__read-news .news-featured-media iframe { 
1756            width: 100%; 
1757            max-height: 567px; 
1758            aspect-ratio: 16/9; 
1759            object-fit: cover; 
1760            border-radius: var(--border-radius-lg, 16px); 
1761
1762 
1763        .ptb-news__read-news .news-featured-media .banner-video-icons { 
1764            width: 100%; 
1765            height: 100%; 
1766            position: absolute; 
1767            top: 50%; 
1768            left: 50%; 
1769            transform: translate(-50%,-50%); 
1770            cursor: pointer; 
1771
1772 
1773        .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-thumb-iframe { 
1774            position: absolute; 
1775            width: 100%; 
1776            height: 100%; 
1777            object-fit: cover; 
1778
1779 
1780        .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-icon-play { 
1781            position: absolute; 
1782            top: 50%; 
1783            left: 50%; 
1784            transform: translate(-50%,-50%); 
1785
1786 
1787        body.high-contrast-active .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-icon-play path:nth-child(1) { 
1788            fill: black;   
1789
1790 
1791        body.high-contrast-active .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-icon-play path:nth-child(2) { 
1792            fill: white;   
1793
1794 
1795        .ptb-news__read-news .news-featured-media *:not(.breakpoint) { 
1796          margin: 0; 
1797
1798        .ptb-news__read-news .news-featured-media * { 
1799            padding: 0; 
1800            font-family: var(--font-family-base); 
1801            line-height: var(--line-height-xl); 
1802
1803 
1804        .ptb-news__read-news .news-featured-media .credits { 
1805            text-align: right; 
1806            color: var(--collor-neutral-dark-to-bright-200, #525252); 
1807            margin-bottom: var(--space-xxxs, 4px); 
1808            font-style: var(--font-style-italic, italic); 
1809            margin-top: var(--space-xxs, 8px); 
1810            margin-bottom: 0; 
1811
1812 
1813        body.high-contrast-active .ptb-news__read-news .news-featured-media .credits { 
1814            color: var(--text-secondary-default, #F8F8F8); 
1815
1816 
1817        .ptb-news__read-news .news-featured-media .legend { 
1818            margin-top: var(--space-xxs, 8px); 
1819            display: flex; 
1820            justify-content: space-between; 
1821
1822 
1823        .ptb-news__read-news .news-featured-media .legend, 
1824        .ptb-news__read-news .news-featured-media .legend * { 
1825            font-style: var(--font-style-italic, italic); 
1826            color: var(--collor-neutral-dark-to-bright-200, #525252); 
1827
1828			 
1829				.ptb-news__read-news .credit-legend .credit-legend-container { 
1830						display: flex; 
1831						justify-content: space-between; 
1832						flex-wrap: wrap; 
1833						gap: 8px; 
1834				}	 
1835 
1836        body.high-contrast-active .ptb-news__read-news .news-featured-media .legend, 
1837        body.high-contrast-active .ptb-news__read-news .news-featured-media .legend * { 
1838            color: var(--text-secondary-default, #F8F8F8); 
1839
1840 
1841        @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
1842            .ptb-news__read-news .news-featured-media .credits { 
1843                text-align: left; 
1844
1845
1846    </style> 
1847 
1848    <script> 
1849        /* Manipulation video*/ 
1850        let videoIsPlaying = false; 
1851 
1852        const modalForClick = document.querySelector(".ptb-news__read-news .news-featured-media .banner-video-icons"); 
1853        const video = document.querySelector(".ptb-news__read-news .news-featured-media .media-col > :first-child"); 
1854        
1855        const playIcon = modalForClick && modalForClick.querySelector(".banner-video-icon-play"); 
1856        modalForClick && modalForClick.addEventListener("click", ()=>{ 
1857            if(video.tagName === "VIDEO") { 
1858                if(videoIsPlaying) { 
1859                    video.pause(); 
1860                    playIcon.style.display = ""; 
1861                    videoIsPlaying = false; 
1862                }  
1863                else { 
1864                    video.play(); 
1865                    playIcon.style.display = "none"; 
1866                    videoIsPlaying = true; 
1867
1868            }   
1869            else if(video.tagName === "IFRAME") { 
1870                const thumbYoutube = modalForClick.querySelector(".banner-video-thumb-iframe"); 
1871                if(videoIsPlaying) { 
1872                    video.contentWindow.postMessage('{"event":"command","func":"pauseVideo"}', '*'); 
1873                    playIcon.style.display = ""; 
1874                    videoIsPlaying = false; 
1875                }  
1876                else { 
1877									if (!video.getAttribute('src')) { 
1878                          const videoId = video.getAttribute('data-video-id'); 
1879                          const youtubeIframeUrl = 'https://www.youtube-nocookie.com/embed/' + videoId + '?si=PDNu4EIwtCuSHC1S&amp;controls=0&enablejsapi=1&rel=0'; 
1880                          video.setAttribute('src', youtubeIframeUrl); 
1881                          video.setAttribute('allow', 'accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share'); 
1882 
1883                          video.onload = () => video.contentWindow.postMessage('{"event":"command","func":"playVideo"}', '*'); 
1884
1885                    thumbYoutube && (thumbYoutube.style.display = "none"); 
1886                    video.contentWindow.postMessage('{"event":"command","func":"playVideo"}', '*'); 
1887                    playIcon.style.display = "none"; 
1888                    videoIsPlaying = true; 
1889
1890            }       
1891        }); 
1892    </script> 
1893<#--/#if --> 
1894</#macro> 
1895<#-- ################################################################################################################## --> 
1896 
1897<#-- ############# Site de Crise - Notícia - Conteúdo da notícia ###################################################### --> 
1898 
1899<#macro renderNewsContent newsInfo> 
1900 
1901    <#assign targetStr = "<div class='paragraph_separator'><span class='dot'></span><span class='dot'></span><span class='dot'></span><span class='dot'></span></div>"> 
1902    <#assign content = newsInfo.newsContent?replace("<p></p>", targetStr, 'r')> 
1903    <#assign content = content?replace("<p> </p>", targetStr, 'r')> 
1904    <#assign content = content?replace("<p></p>", targetStr, 'r')> 
1905    <#assign content = content?replace("<p>&nbsp;</p>", targetStr, 'r')> 
1906  
1907     
1908    <div class="news-content breakpoint"> 
1909      <div class="col-1-12 md-col-1-8 sm-col-1-4"> 
1910        ${content} 
1911      </div> 
1912        <div class="audio-template audio-pause audio-unmuted" style="display:none"> 
1913            <div class="audio-button-play">  
1914                <svg class="audio-play-icon" width="100%" height="100%" viewBox="0 0 91 90" fill="#008542" xmlns="http://www.w3.org/2000/svg"><circle cx="45.2903" cy="45" r="44.5" stroke="#008542"></circle> <path d="M58.9759 43.2545C60.3409 44.0179 60.3409 45.9821 58.9759 46.7455L38.7505 58.0578C37.4173 58.8034 35.7742 57.8397 35.7742 56.3122L35.7742 33.6878C35.7742 32.1603 37.4173 31.1966 38.7505 31.9422L58.9759 43.2545Z" fill="white"></path> 
1915                </svg> 
1916 
1917                <svg class="audio-pause-icon" width="100%" height="100%" viewBox="0 0 91 90" fill="#008542" xmlns="http://www.w3.org/2000/svg"><circle cx="45.2903" cy="45" r="44.5" stroke="#008542"></circle> <path d="M42.3736 30.4167H33.6236V59.5834H42.3736V30.4167Z" fill="white"></path> <path d="M48.2069 59.5834H56.9569V30.4167H48.2069V59.5834Z" fill="white"></path> 
1918                </svg> 
1919            </div> 
1920            <div class="audio-sondwave">  
1921                <svg class="audio-sondwave-desktop" width="100%" height="100%" viewBox="0 0 590 30" fill="none" xmlns="http://www.w3.org/2000/svg"> 
1922                    <g clip-path="url(#clip0_2625_8152)"> 
1923                    <line x1="0.75" y1="0.75" x2="0.749999" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1924                    <line x1="5.91016" y1="7.75" x2="5.91016" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1925                    <line x1="11.0723" y1="5.75" x2="11.0723" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1926                    <line x1="16.2344" y1="11.75" x2="16.2344" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1927                    <line x1="21.3945" y1="9.75" x2="21.3945" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1928                    <line x1="26.5566" y1="9.75" x2="26.5566" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1929                    <line x1="30.6855" y1="1.75" x2="30.6855" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1930                    <line x1="35.8477" y1="12.75" x2="35.8477" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1931                    <line x1="41.0078" y1="13.75" x2="41.0078" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1932                    <line x1="46.1699" y1="10.75" x2="46.1699" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1933                    <line x1="51.3301" y1="8.75" x2="51.3301" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1934                    <line x1="56.4922" y1="0.75" x2="56.4922" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1935                    <line x1="61.6523" y1="7.75" x2="61.6523" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1936                    <line x1="66.8145" y1="5.75" x2="66.8145" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1937                    <line x1="71.9766" y1="11.75" x2="71.9766" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1938                    <line x1="77.1367" y1="9.75" x2="77.1367" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1939                    <line x1="82.2988" y1="9.75" x2="82.2988" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1940                    <line x1="86.4277" y1="1.75" x2="86.4277" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1941                    <line x1="91.5879" y1="12.75" x2="91.5879" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1942                    <line x1="96.75" y1="13.75" x2="96.75" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1943                    <line x1="101.91" y1="10.75" x2="101.91" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1944                    <line x1="107.072" y1="8.75" x2="107.072" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1945                    <line x1="112.234" y1="0.75" x2="112.234" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1946                    <line x1="117.395" y1="7.75" x2="117.395" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1947                    <line x1="122.557" y1="5.75" x2="122.557" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1948                    <line x1="127.717" y1="11.75" x2="127.717" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1949                    <line x1="132.879" y1="9.75" x2="132.879" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1950                    <line x1="138.041" y1="9.75" x2="138.041" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1951                    <line x1="142.17" y1="1.75" x2="142.17" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1952                    <line x1="147.33" y1="12.75" x2="147.33" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1953                    <line x1="151.75" y1="0.75" x2="151.75" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1954                    <line x1="156.91" y1="7.75" x2="156.91" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1955                    <line x1="162.072" y1="5.75" x2="162.072" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1956                    <line x1="167.234" y1="11.75" x2="167.234" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1957                    <line x1="172.395" y1="9.75" x2="172.395" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1958                    <line x1="177.557" y1="9.75" x2="177.557" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1959                    <line x1="181.686" y1="1.75" x2="181.686" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1960                    <line x1="186.848" y1="12.75" x2="186.848" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1961                    <line x1="192.008" y1="13.75" x2="192.008" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1962                    <line x1="197.17" y1="10.75" x2="197.17" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1963                    <line x1="202.33" y1="8.75" x2="202.33" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1964                    <line x1="207.492" y1="0.75" x2="207.492" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1965                    <line x1="212.652" y1="7.75" x2="212.652" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1966                    <line x1="217.814" y1="5.75" x2="217.814" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1967                    <line x1="222.977" y1="11.75" x2="222.977" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1968                    <line x1="228.137" y1="9.75" x2="228.137" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1969                    <line x1="233.299" y1="9.75" x2="233.299" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1970                    <line x1="237.428" y1="1.75" x2="237.428" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1971                    <line x1="242.588" y1="12.75" x2="242.588" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1972                    <line x1="247.75" y1="13.75" x2="247.75" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1973                    <line x1="252.91" y1="10.75" x2="252.91" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1974                    <line x1="258.072" y1="8.75" x2="258.072" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1975                    <line x1="263.234" y1="0.75" x2="263.234" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1976                    <line x1="268.395" y1="7.75" x2="268.395" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1977                    <line x1="273.557" y1="5.75" x2="273.557" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1978                    <line x1="278.717" y1="11.75" x2="278.717" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1979                    <line x1="283.879" y1="9.75" x2="283.879" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1980                    <line x1="289.041" y1="9.75" x2="289.041" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1981                    <line x1="293.17" y1="1.75" x2="293.17" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1982                    <line x1="298.33" y1="12.75" x2="298.33" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1983                    <line x1="302.75" y1="10.75" x2="302.75" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1984                    <line x1="307.912" y1="8.75" x2="307.912" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1985                    <line x1="313.072" y1="0.75" x2="313.072" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1986                    <line x1="318.234" y1="7.75" x2="318.234" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1987                    <line x1="323.395" y1="5.75" x2="323.395" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1988                    <line x1="328.557" y1="11.75" x2="328.557" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1989                    <line x1="333.719" y1="9.75" x2="333.719" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1990                    <line x1="338.879" y1="9.75" x2="338.879" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1991                    <line x1="343.008" y1="1.75" x2="343.008" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1992                    <line x1="348.17" y1="12.75" x2="348.17" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1993                    <line x1="353.33" y1="13.75" x2="353.33" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1994                    <line x1="358.492" y1="10.75" x2="358.492" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1995                    <line x1="363.652" y1="8.75" x2="363.652" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1996                    <line x1="368.814" y1="0.75" x2="368.814" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1997                    <line x1="373.977" y1="7.75" x2="373.977" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1998                    <line x1="379.137" y1="5.75" x2="379.137" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
1999                    <line x1="384.299" y1="11.75" x2="384.299" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2000                    <line x1="389.459" y1="9.75" x2="389.459" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2001                    <line x1="394.621" y1="9.75" x2="394.621" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2002                    <line x1="398.75" y1="1.75" x2="398.75" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2003                    <line x1="403.912" y1="12.75" x2="403.912" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2004                    <line x1="408.33" y1="10.75" x2="408.33" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2005                    <line x1="413.492" y1="8.75" x2="413.492" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2006                    <line x1="418.654" y1="0.75" x2="418.654" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2007                    <line x1="423.814" y1="7.75" x2="423.814" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2008                    <line x1="428.977" y1="5.75" x2="428.977" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2009                    <line x1="434.137" y1="11.75" x2="434.137" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2010                    <line x1="439.299" y1="9.75" x2="439.299" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2011                    <line x1="444.461" y1="9.75" x2="444.461" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2012                    <line x1="448.59" y1="1.75" x2="448.59" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2013                    <line x1="453.75" y1="12.75" x2="453.75" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2014                    <line x1="458.912" y1="13.75" x2="458.912" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2015                    <line x1="464.072" y1="10.75" x2="464.072" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2016                    <line x1="469.234" y1="8.75" x2="469.234" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2017                    <line x1="474.395" y1="0.75" x2="474.395" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2018                    <line x1="479.557" y1="7.75" x2="479.557" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2019                    <line x1="484.719" y1="5.75" x2="484.719" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2020                    <line x1="489.879" y1="11.75" x2="489.879" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2021                    <line x1="495.041" y1="9.75" x2="495.041" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2022                    <line x1="500.201" y1="9.75" x2="500.201" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2023                    <line x1="504.33" y1="1.75" x2="504.33" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2024                    <line x1="509.492" y1="12.75" x2="509.492" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2025                    <line x1="513.912" y1="10.75" x2="513.912" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2026                    <line x1="519.072" y1="8.75" x2="519.072" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2027                    <line x1="524.234" y1="0.75" x2="524.234" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2028                    <line x1="529.395" y1="7.75" x2="529.395" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2029                    <line x1="534.557" y1="5.75" x2="534.557" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2030                    <line x1="539.719" y1="11.75" x2="539.719" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2031                    <line x1="544.879" y1="9.75" x2="544.879" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2032                    <line x1="550.041" y1="9.75" x2="550.041" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2033                    <line x1="554.17" y1="1.75" x2="554.17" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2034                    <line x1="559.332" y1="12.75" x2="559.332" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2035                    <line x1="564.492" y1="13.75" x2="564.492" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2036                    <line x1="569.654" y1="10.75" x2="569.654" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2037                    <line x1="574.814" y1="8.75" x2="574.814" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2038                    <line x1="579.977" y1="0.75" x2="579.977" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2039                    <line x1="585.137" y1="7.75" x2="585.137" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2040                    <line x1="590.299" y1="5.75" x2="590.299" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2041                    </g> 
2042                    <defs> 
2043                    <clipPath id="clip0_2625_8152"> 
2044                    <rect width="590" height="30" fill="white"/> 
2045                    </clipPath> 
2046                    </defs> 
2047                </svg> 
2048                <svg class="audio-sondwave-mobile" width="100%" height="100%" viewBox="0 0 102 30" fill="none" xmlns="http://www.w3.org/2000/svg"> 
2049                    <g clip-path="url(#clip0_2625_8922)"> 
2050                    <line x1="0.75" y1="0.75" x2="0.749999" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2051                    <line x1="5.91016" y1="7.75" x2="5.91016" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2052                    <line x1="11.0723" y1="5.75" x2="11.0723" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2053                    <line x1="16.2344" y1="11.75" x2="16.2344" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2054                    <line x1="21.3945" y1="9.75" x2="21.3945" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2055                    <line x1="26.5566" y1="9.75" x2="26.5566" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2056                    <line x1="30.6855" y1="1.75" x2="30.6855" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2057                    <line x1="35.8477" y1="12.75" x2="35.8477" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2058                    <line x1="41.0078" y1="13.75" x2="41.0078" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2059                    <line x1="46.1699" y1="10.75" x2="46.1699" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2060                    <line x1="51.3301" y1="8.75" x2="51.3301" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2061                    <line x1="56.4922" y1="0.75" x2="56.4922" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2062                    <line x1="61.6523" y1="7.75" x2="61.6523" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2063                    <line x1="66.8145" y1="5.75" x2="66.8145" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2064                    <line x1="71.9766" y1="11.75" x2="71.9766" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2065                    <line x1="77.1367" y1="9.75" x2="77.1367" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2066                    <line x1="82.2988" y1="9.75" x2="82.2988" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2067                    <line x1="86.4277" y1="1.75" x2="86.4277" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2068                    <line x1="91.5879" y1="12.75" x2="91.5879" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2069                    <line x1="96.75" y1="13.75" x2="96.75" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2070                    <line x1="101.91" y1="10.75" x2="101.91" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/> 
2071                    </g> 
2072                    <defs> 
2073                    <clipPath id="clip0_2625_8922"> 
2074                    <rect width="102" height="30" fill="white"/> 
2075                    </clipPath> 
2076                    </defs> 
2077                </svg> 
2078            </div> 
2079            <div class="audio-time paragraph-micro-bold">  </div> 
2080            <div class="audio-button-mute"> 
2081                <svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32" fill="none"> 
2082                    <path d="M27.3625 9.6375C28.1993 10.4723 28.8632 11.464 29.3161 12.5558C29.7691 13.6476 30.0023 14.818 30.0023 16C30.0023 17.182 29.7691 18.3524 29.3161 19.4442C28.8632 20.536 28.1993 21.5277 27.3625 22.3625M10 21H4C3.73478 21 3.48043 20.8946 3.29289 20.7071C3.10536 20.5196 3 20.2652 3 20V12C3 11.7348 3.10536 11.4804 3.29289 11.2929C3.48043 11.1054 3.73478 11 4 11H10M10 21L19 28V4L10 11M10 21V11M23.825 13.175C24.1969 13.5455 24.492 13.9857 24.6933 14.4705C24.8947 14.9553 24.9983 15.4751 24.9983 16C24.9983 16.5249 24.8947 17.0447 24.6933 17.5295C24.492 18.0143 24.1969 18.4545 23.825 18.825" stroke="#525252" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
2083                </svg> 
2084            </div> 
2085        </div> 
2086    </div> 
2087     
2088			  <#if categoriesAsssetEntryResponse?? && categoriesAsssetEntryResponse?has_content && categoriesAsssetEntryResponse.taxonomyCategoryBriefs??> 
2089            <@renderNewsTags tagCategoryList NEWS_PAGE_NAME removeStartParameterWhenTagIsClicked includeRequestParams /> 
2090        </#if> 
2091    <style> 
2092 
2093        .ptb-news__read-news .news-content p { 
2094            margin-bottom: var(--space-md, 24px); 
2095
2096 
2097        .ptb-news__read-news .news-content strong { 
2098            font-weight: var(--font-weight-bold); 
2099
2100 
2101        .ptb-news__read-news .news-content em { 
2102            font-style: var(--font-style-italic); 
2103
2104 
2105        .ptb-news__read-news .news-content a:not(.stories-container *) { 
2106            font-family: var(--font-family-base); 
2107            font-style: var(--font-style-normal, normal); 
2108            font-weight: var(--font-weight-bold, 700); 
2109            font-size: var(--font-size-xs, 18px); 
2110            line-height: var(--line-height-xl, 160%); 
2111 
2112            color: #008542; 
2113
2114 
2115        body.high-contrast-active .ptb-news__read-news .news-content a { 
2116            color: #E4F7E8; 
2117
2118 
2119        .ptb-news__read-news .news-content ul { 
2120            padding-left: 27px; 
2121            margin-top: -16px; 
2122
2123 
2124        .ptb-news__read-news .news-content ul li::marker { 
2125            content: "■" !important; 
2126            color: var(--color-secondary-medium) !important; 
2127            font-size: var(--size-xxs); 
2128
2129 
2130        .ptb-news__read-news .news-content ul li { 
2131            color: var(--color-text-primary-default); 
2132            padding: 8px 0; 
2133 
2134            /*paragraph-sm-regular*/ 
2135            font-size: var(--font-size-xxs); 
2136            line-height: var(--line-height-xl); 
2137            font-weight: var(--font-weight-regular); 
2138            font-style: var(--font-style-normal); 
2139            text-decoration: var(--text-decoration-none); 
2140 
2141            margin-left: calc(-1* var(--space-sm)); 
2142            padding-left: var(--space-sm); 
2143
2144 
2145        .ptb-news__read-news .news-content ul li * { 
2146            color: var(--color-text-primary-default); 
2147            padding: 8px 0; 
2148 
2149            /*paragraph-sm-regular*/ 
2150            font-size: var(--font-size-xxs); 
2151            line-height: var(--line-height-xl); 
2152            font-weight: var(--font-weight-regular); 
2153            font-style: var(--font-style-normal); 
2154            text-decoration: var(--text-decoration-none); 
2155        }      
2156 
2157        @media screen and (min-width: 1024px) { 
2158          .ptb-news__read-news .news-content > * { 
2159            grid-column-start: 3; 
2160            grid-column-end: 11; 
2161
2162 
2163          <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Infográfico" > 
2164            .ptb-news__read-news .news-content > *:has(img) { 
2165                grid-column-start: 2; 
2166                grid-column-end: 12; 
2167
2168
2169 
2170          </#if> 
2171
2172 
2173        .ptb-news__read-news .news-content figure { 
2174            margin-bottom: var(--space-sm, 16px); 
2175
2176 
2177        .ptb-news__read-news .news-content figure figcaption { 
2178            display: flex; 
2179            justify-content: space-between; 
2180            align-items: flex-start; 
2181            align-self: stretch; 
2182            margin-top: var(--space-xxs, 8px); 
2183            text-align: justify; 
2184
2185 
2186        .ptb-news__read-news .news-content figure figcaption, 
2187        .ptb-news__read-news .news-content figure figcaption * { 
2188            color: var(--color-neutral-700, #525252); 
2189            font-family: var(--font-family-base); 
2190            font-size: var(--font-size-xxxs, 14px); 
2191            font-style: var(--font-style-italic, italic); 
2192            font-weight: var(--font-weight-regular, 400); 
2193            line-height: var(--line-height-xl, 160%); 
2194
2195 
2196        body.high-contrast-active .ptb-news__read-news .news-content figure figcaption, 
2197        body.high-contrast-active .ptb-news__read-news .news-content figure figcaption * { 
2198            color: var(--text-secondary-default, #F8F8F8); 
2199
2200         
2201        .ptb-news__read-news .news-content figure figcaption br { 
2202            display: none; 
2203
2204 
2205        .ptb-news__read-news .news-content .embed-responsive { 
2206            width: 100% !important; 
2207            border-radius: var(--border-radius-md, 16px); 
2208            margin-bottom: var(--space-md, 16px); 
2209            aspect-ratio: 16/9; 
2210
2211			 
2212		.ptb-news__read-news .news-content img.first-news-image { 
2213            max-width: 1008px; 
2214			max-height: 567px!important; 
2215            height: 567px !important; 
2216			object-fit: cover 
2217
2218 
2219        .ptb-news__read-news .news-content img { 
2220            width: 100%; 
2221			height: auto; 
2222			max-width: 800px ; 
2223			max-height: 450px; 
2224            display: block !important; 
2225            margin-left: auto !important; 
2226            margin-right: auto !important; 
2227            border-radius: var(--border-radius-md, 16px); 
2228
2229			 
2230        <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Artigo" > 
2231            .ptb-news__read-news .news-content img  { 
2232                aspect-ratio: 16/9; 
2233
2234        </#if> 
2235 
2236        .ptb-news__read-news .news-content .paragraph_separator { 
2237            display: flex; 
2238            width: 100%; 
2239            height: fit-content; 
2240            justify-content: center; 
2241            gap: 6px; 
2242
2243 
2244        .ptb-news__read-news .news-content .paragraph_separator .dot { 
2245            height: var(--size-micro, 4px); 
2246            width: var(--size-micro, 4px); 
2247            background-color: #959595; 
2248            border-radius: 100%; 
2249            display: inline-block; 
2250
2251 
2252        .ptb-news__read-news .news-content *:not(.stories-container *) { 
2253            font-family: var(--font-family-base); 
2254            font-style: var(--font-style-normal, normal); 
2255            font-weight: var(--font-weight-regular, 400); 
2256            font-size: var(--font-size-xs, 18px); 
2257            line-height: var(--line-height-xl, 160%); 
2258            color: var(--color-neutral-800, #373737); 
2259
2260 
2261        body.high-contrast-active .ptb-news__read-news .news-content * { 
2262            color: var(--text-primary-default, var(--color-neutral-100)); 
2263
2264 
2265        .ptb-news__read-news .news-content h1, 
2266        .ptb-news__read-news .news-content h1 *, 
2267        .ptb-news__read-news .news-content h2, 
2268        .ptb-news__read-news .news-content h2 *, 
2269        .ptb-news__read-news .news-content h3, 
2270        .ptb-news__read-news .news-content h3 *, 
2271        .ptb-news__read-news .news-content h4, 
2272        .ptb-news__read-news .news-content h4 *, 
2273        .ptb-news__read-news .news-content h5, 
2274        .ptb-news__read-news .news-content h5 *, 
2275        .ptb-news__read-news .news-content h6, 
2276        .ptb-news__read-news .news-content h6 * { 
2277            color: var(--color-neutral-800, #373737) !important; 
2278
2279 
2280        body.high-contrast-active .ptb-news__read-news .news-content h1, 
2281        body.high-contrast-active .ptb-news__read-news .news-content h1 *, 
2282        body.high-contrast-active .ptb-news__read-news .news-content h2, 
2283        body.high-contrast-active .ptb-news__read-news .news-content h2 *, 
2284        body.high-contrast-active .ptb-news__read-news .news-content h3, 
2285        body.high-contrast-active .ptb-news__read-news .news-content h3 *, 
2286        body.high-contrast-active .ptb-news__read-news .news-content h4, 
2287        body.high-contrast-active .ptb-news__read-news .news-content h4 *, 
2288        body.high-contrast-active .ptb-news__read-news .news-content h5, 
2289        body.high-contrast-active .ptb-news__read-news .news-content h5 *, 
2290        body.high-contrast-active .ptb-news__read-news .news-content h6, 
2291        body.high-contrast-active .ptb-news__read-news .news-content h6 * { 
2292            color: var(--text-primary-default, var(--color-neutral-100)) !important; 
2293
2294 
2295        .ptb-news__read-news .news-content h1:last-child, 
2296        .ptb-news__read-news .news-content h2:last-child, 
2297        .ptb-news__read-news .news-content h3:last-child, 
2298        .ptb-news__read-news .news-content h4:last-child, 
2299        .ptb-news__read-news .news-content h5:last-child, 
2300        .ptb-news__read-news .news-content h5:last-child, 
2301        .ptb-news__read-news .news-content h6:last-child, 
2302        .ptb-news__read-news .news-content p:last-child { 
2303            padding-bottom: 0 !important; 
2304
2305 
2306        .ptb-news__read-news .news-content h1, 
2307        .ptb-news__read-news .news-content h1 * { 
2308            font-size: var(--font-size-xxl) !important; 
2309            line-height: var(--line-height-sm) !important; 
2310            font-weight: var(--font-weight-bold) !important; 
2311            font-style: var(--font-style-normal) !important; 
2312            text-decoration: var(--text-decoration-none) !important; 
2313
2314 
2315        .ptb-news__read-news .news-content h2, 
2316        .ptb-news__read-news .news-content h2 * { 
2317             
2318            font-size: var(--font-size-xl) !important; 
2319            line-height: var(--line-height-sm) !important; 
2320            font-weight: var(--font-weight-bold) !important; 
2321            font-style: var(--font-style-normal) !important; 
2322            text-decoration: var(--text-decoration-none) !important; 
2323 
2324
2325 
2326        .ptb-news__read-news .news-content h2 { 
2327            margin-top: 48px !important; 
2328           margin-bottom: var(--space-xl, 40px) !important; 
2329 
2330
2331 
2332        .ptb-news__read-news .news-content h3, 
2333        .ptb-news__read-news .news-content h3 * { 
2334            font-size: var(--font-size-lg) !important; 
2335            line-height: var(--line-height-sm) !important; 
2336            font-weight: var(--font-weight-bold) !important; 
2337            font-style: var(--font-style-normal) !important; 
2338            text-decoration: var(--text-decoration-none) !important; 
2339
2340 
2341        .ptb-news__read-news .news-content h3 { 
2342            margin-bottom: var(--space-sm, 16px) !important; 
2343            margin-top: 48px !important; 
2344
2345 
2346        .ptb-news__read-news .news-content h4, 
2347        .ptb-news__read-news .news-content h4 * { 
2348            font-size: var(--font-size-md) !important; 
2349            line-height: var(--line-height-md) !important; 
2350            font-weight: var(--font-weight-bold) !important; 
2351            font-style: var(--font-style-normal) !important; 
2352            text-decoration: var(--text-decoration-none) !important; 
2353
2354 
2355        .ptb-news__read-news .news-content h4 { 
2356            margin-top: 48px !important; 
2357            margin-bottom: var(--space-sm, 16px) !important; 
2358
2359 
2360        .ptb-news__read-news .news-content h5, 
2361        .ptb-news__read-news .news-content h5 * { 
2362            font-size: var(--font-size-sm) !important; 
2363            line-height: var(--line-height-md) !important; 
2364            font-weight: var(--font-weight-bold) !important; 
2365            font-style: var(--font-style-normal) !important; 
2366            text-decoration: var(--text-decoration-none) !important; 
2367
2368 
2369        .ptb-news__read-news .news-content h5 { 
2370            margin-top: 48px !important; 
2371            margin-bottom: var(--space-sm, 16px) !important; 
2372
2373 
2374        .ptb-news__read-news .news-content table { 
2375            border-collapse: collapse; 
2376            border: none; 
2377            width: 100% !important; 
2378            margin: var(--space-md, 24px) 0; 
2379
2380 
2381        .ptb-news__read-news .news-content table * { 
2382            font-size: var(--font-size-xxs, 16px); 
2383            font-style: var(--font-style-normal, normal); 
2384            font-weight: var(--font-weight-regular, 400); 
2385            line-height: var(--line-height-xl, 160%); 
2386            color: var(--color-neutral-800, #373737); 
2387            border: 0; 
2388
2389 
2390        body.high-contrast-active .ptb-news__read-news .news-content table * { 
2391            color: var(--text-primary-default, var(--color-neutral-100)); 
2392
2393 
2394        .ptb-news__read-news .news-content table tbody > :first-child, 
2395        .ptb-news__read-news .news-content table tbody > :first-child * { 
2396            font-weight: var(--font-weight-bold, 700); 
2397            flex: 1 0 0; 
2398            background: var(--background-Surface-level-02, #F8F8F8); 
2399
2400 
2401        body.high-contrast-active .ptb-news__read-news .news-content table tbody > :first-child, 
2402        body.high-contrast-active .ptb-news__read-news .news-content table tbody > :first-child * { 
2403            background: #373737; 
2404
2405         
2406        .ptb-news__read-news .news-content table tbody { 
2407            display: flex; 
2408            flex-direction: column; 
2409
2410 
2411        .ptb-news__read-news .news-content table tbody * { 
2412            display: flex; 
2413            height: 100%; 
2414            align-items: center; 
2415            flex: 1 0 0; 
2416
2417	             
2418        .ptb-news__read-news .news-content table tbody tr * {          
2419            padding: 23px var(--space-lg, 32px); 
2420        }	 
2421             
2422 
2423        .ptb-news__read-news .news-content table tbody tr { 
2424            border-radius: var(--border-radius-md); 
2425            border: var(--border-width-hairline, 1px) solid #EEEEEE; 
2426
2427 
2428        body.high-contrast-active .ptb-news__read-news .news-content table tbody tr { 
2429            border: var(--border-width-hairline, 1px) solid #525252; 
2430
2431 
2432        .ptb-news__read-news .news-content table tbody tr:not(:last-child) { 
2433            border-bottom-left-radius: 0; 
2434            border-bottom-right-radius: 0; 
2435
2436 
2437        .ptb-news__read-news .news-content table tbody tr:not(:first-child) { 
2438            border-top-left-radius: 0; 
2439            border-top-right-radius: 0; 
2440            border-top: none; 
2441
2442 
2443        .ptb-news__read-news .news-content table tbody tr td:not(:last-child) { 
2444            border-right: var(--border-width-hairline, 1px) solid #EEEEEE; 
2445
2446 
2447        body.high-contrast-active .ptb-news__read-news .news-content table tbody tr td:not(:last-child) { 
2448            border-right: var(--border-width-hairline, 1px) solid #525252; 
2449
2450 
2451        .ptb-news__read-news .news-content table tbody tr:first-child td { 
2452            border-top: var(--border-width-hairline, 1px) solid #EEEEEE; 
2453            border-bottom: var(--border-width-hairline, 1px) solid #EEEEEE; 
2454
2455 
2456        body.high-contrast-active .ptb-news__read-news .news-content table tbody tr:first-child td { 
2457            border-top: var(--border-width-hairline, 1px) solid #525252; 
2458            border-bottom: var(--border-width-hairline, 1px) solid #525252; 
2459
2460 
2461        .ptb-news__read-news .news-content table tbody tr td:first-child { 
2462            padding-left: 0; 
2463
2464 
2465        .ptb-news__read-news .news-content table tbody tr td:last-child{ 
2466            padding-right: 0; 
2467
2468 
2469        .ptb-news__read-news .news-content audio { 
2470            display: none; 
2471
2472 
2473        .ptb-news__read-news .news-content .audio-template { 
2474            display: flex; 
2475            padding: var(--space-sm, 16px); 
2476            align-items: center; 
2477            gap: var(--space-md, 24px); 
2478            align-self: stretch; 
2479            border-radius: var(--border-radius-lg, 16px); 
2480            border: var(--border-width-hairline, 1px) solid var(--border-color-mid); 
2481            background: var(--background-card-default, #FFF); 
2482            max-height: var(--size-giant, 72px); 
2483            margin: 48px 0; 
2484
2485 
2486        body.high-contrast-active .ptb-news__read-news .news-content .audio-template { 
2487            background: var(--background-card-default, #010101); 
2488            border: var(--border-width-hairline, 1px) solid #525252; 
2489
2490 
2491        .ptb-news__read-news .news-content .audio-template .audio-button-play { 
2492            display: flex; 
2493            width: var(--size-xl, 40px); 
2494            height: var(--size-xl, 40px); 
2495            justify-content: center; 
2496            align-items: center; 
2497            flex-grow: 0; 
2498            flex-shrink: 0; 
2499            cursor: pointer; 
2500
2501 
2502        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-play-icon, 
2503        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-pause-icon { 
2504            fill: #FFFFFF; 
2505
2506 
2507        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-play-icon path, 
2508        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-pause-icon path { 
2509            fill: #010101; 
2510
2511 
2512        .ptb-news__read-news .news-content .audio-template.audio-pause .audio-button-play .audio-play-icon { 
2513            display: block; 
2514
2515 
2516        .ptb-news__read-news .news-content .audio-template.audio-pause .audio-button-play .audio-pause-icon { 
2517            display: none; 
2518
2519 
2520        .ptb-news__read-news .news-content .audio-template.audio-play .audio-button-play .audio-play-icon { 
2521            display: none; 
2522
2523 
2524        .ptb-news__read-news .news-content .audio-template.audio-play .audio-button-play .audio-pause-icon { 
2525            display: block; 
2526
2527 
2528        .ptb-news__read-news .news-content .audio-template .audio-sondwave { 
2529            display: flex; 
2530            flex-direction: column; 
2531            align-items: flex-start; 
2532            gap: var(--space-xxs, 8px); 
2533            flex: 1 0 0; 
2534            height: 100%; 
2535            flex-grow: 1; 
2536            flex-shrink: 1; 
2537
2538 
2539        .ptb-news__read-news .news-content .audio-template .audio-sondwave line { 
2540            stroke: #008542; 
2541
2542 
2543        .ptb-news__read-news .news-content .audio-template .audio-sondwave line.line-active { 
2544            stroke: #90EE90; 
2545
2546 
2547        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-sondwave line { 
2548            stroke: #E4F7E8; 
2549
2550 
2551        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-sondwave line.line-active { 
2552            stroke: #666666; 
2553
2554 
2555        .ptb-news__read-news .news-content .audio-template .audio-sondwave .audio-sondwave-mobile { 
2556            display: none; 
2557
2558 
2559        .ptb-news__read-news .news-content .audio-template .audio-time { 
2560            display: flex; 
2561            flex-direction: column; 
2562            align-items: flex-start; 
2563            gap: var(--space-xxs, 8px); 
2564            flex: 1 0 0; 
2565            color: var(--text-primary-accent, #008542); 
2566            text-align: center; 
2567            font-family: var(--font-family-base); 
2568            line-height: 124% !important;  
2569            flex-grow: 0; 
2570            flex-shrink: 0; 
2571
2572 
2573        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-time {     
2574            color: var(--text-primary-accent, #E4F7E8); 
2575
2576 
2577        .ptb-news__read-news .news-content .audio-template .audio-button-mute { 
2578            width: var(--size-lg, 32px); 
2579            height: var(--size-lg, 32px); 
2580            flex-grow: 0; 
2581            flex-shrink: 0; 
2582            cursor: pointer; 
2583
2584 
2585        body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-mute svg path { 
2586            stroke: white; 
2587            fill: none; 
2588
2589 
2590        .ptb-news__read-news .news-content .audio-template.audio-muted .audio-button-mute { 
2591            opacity: 0.6; 
2592
2593 
2594        @media screen and (max-width: 1280px) { 
2595            .ptb-news__read-news .news-content img.first-news-image { 
2596                height: auto!important; 
2597			    object-fit: cover 
2598
2599					 
2600		    .ptb-news__read-news .news-content img { 
2601                width: 100%; 
2602				height: auto; 
2603				max-width: 100% ; 
2604				max-height: auto; 
2605                object-fit: cover; 
2606
2607
2608         
2609        @media screen and (max-width: 1023px) and (min-width: ${MAX_MOBILE_WIDTH}px) { 
2610            .ptb-news__read-news .news-content > * { 
2611                grid-column-start: 1; 
2612                grid-column-end: 9; 
2613            }        
2614
2615         
2616 
2617        @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
2618 
2619            .ptb-news__read-news .news-content * { 
2620                font-size: var(--font-size-xxs, 16px); 
2621
2622 
2623             
2624            .ptb-news__read-news .news-content > * { 
2625                grid-column-start: 1; 
2626                grid-column-end: 5; 
2627
2628             
2629 
2630            .ptb-news__read-news .news-content h1, 
2631            .ptb-news__read-news .news-content h1 * { 
2632                font-size: var(--font-size-xl) !important; 
2633                line-height: var(--line-height-sm) !important; 
2634                font-weight: var(--font-weight-bold) !important; 
2635                font-style: var(--font-style-normal) !important; 
2636                text-decoration: var(--text-decoration-none) !important; 
2637 
2638
2639 
2640            .ptb-news__read-news .news-content h2, 
2641            .ptb-news__read-news .news-content h2 * { 
2642                font-size: var(--font-size-lg) !important; 
2643                line-height: var(--line-height-sm) !important; 
2644                font-weight: var(--font-weight-bold) !important; 
2645                font-style: var(--font-style-normal) !important; 
2646                text-decoration: var(--text-decoration-none) !important; 
2647
2648 
2649            .ptb-news__read-news .news-content h2 { 
2650                margin-bottom: var(--space-md, 24px) !important; 
2651
2652 
2653            .ptb-news__read-news .news-content h3, 
2654            .ptb-news__read-news .news-content h3 * { 
2655                font-size: var(--font-size-md) !important; 
2656                line-height: var(--line-height-sm) !important; 
2657                font-weight: var(--font-weight-bold) !important; 
2658                font-style: var(--font-style-normal) !important; 
2659                text-decoration: var(--text-decoration-none) !important; 
2660
2661 
2662            .ptb-news__read-news .news-content h3 { 
2663                margin-top: var(--space-xxs, 8px) !important; 
2664
2665 
2666            .ptb-news__read-news .news-content h4,  
2667            .ptb-news__read-news .news-content h4 * { 
2668                font-size: var(--font-size-sm) !important; 
2669                line-height: var(--line-height-md) !important; 
2670                font-weight: var(--font-weight-bold) !important; 
2671                font-style: var(--font-style-normal) !important; 
2672                text-decoration: var(--text-decoration-none) !important; 
2673
2674 
2675            .ptb-news__read-news .news-content h5, 
2676            .ptb-news__read-news .news-content h5 * { 
2677                font-size: var(--font-size-xs) !important; 
2678                line-height: var(--line-height-md) !important; 
2679                font-weight: var(--font-weight-bold) !important; 
2680                font-style: var(--font-style-normal) !important; 
2681                text-decoration: var(--text-decoration-none) !important; 
2682
2683 
2684            .ptb-news__read-news .news-content figure figcaption { 
2685                flex-direction: column; 
2686                gap: var(--space-xxs, 8px); 
2687
2688 
2689            .ptb-news__read-news .news-content figure figcaption, 
2690            .ptb-news__read-news .news-content figure figcaption * { 
2691                font-size: var(--font-size-micro, 12px); 
2692
2693 
2694            .ptb-news__read-news .news-content table { 
2695                margin-top: var(--space-xxs, 8px); 
2696                margin-bottom: var(--space-lg, 32px); 
2697
2698 
2699            .ptb-news__read-news .news-content table * { 
2700                font-size: var(--font-size-micro, 12px); 
2701                line-height: 19.2%; 
2702
2703 
2704            .ptb-news__read-news .news-content table tbody * { 
2705                height: 43px; 
2706                padding: var(--space-xs, 12px); 
2707
2708 
2709            .ptb-news__read-news .news-content .audio-template { 
2710                margin-top: var(--space-xxs, 8px); 
2711                margin-bottom: var(--space-lg, 32px); 
2712            }            
2713
2714 
2715        @media screen and (max-width: 500px) { 
2716             .ptb-news__read-news .news-content .audio-template .audio-sondwave .audio-sondwave-desktop { 
2717                display: none; 
2718
2719 
2720            .ptb-news__read-news .news-content .audio-template .audio-sondwave .audio-sondwave-mobile { 
2721                display: block; 
2722
2723
2724    </style> 
2725 
2726    <style> 
2727.ws-carousel p { 
2728    margin: var(--space-none, 0) !important; 
2729
2730 
2731.ws-carousel { 
2732    display: flex; 
2733    flex-direction: column; 
2734    gap: var(--space-lg, 32px); 
2735    margin: var(--space-big, 72px) auto; 
2736
2737 
2738.ws-carousel .ws-carousel-header { 
2739    display: flex; 
2740    justify-content: space-between; 
2741
2742 
2743.ws-carousel .ws-carousel-header .h2, 
2744.ws-carousel .ws-carousel-header h2 { 
2745    color: var(--color-neutral-800, #373737) !important; 
2746    font-family: var(--font-family-base), "Petrobras Sans" !important; 
2747    line-height: 100% !important; 
2748    margin: var(--space-none, 0) ! important; 
2749
2750 
2751.ws-carousel .ws-carousel-header .nav-buttons { 
2752    display: flex; 
2753    justify-content: space-between; 
2754    gap: var(--space-xxs, 8px); 
2755
2756 
2757.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.left-arrow { 
2758    transform: scaleX(-1); 
2759
2760 
2761.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow { 
2762    cursor: pointer; 
2763
2764 
2765.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.inactive { 
2766    cursor: not-allowed; 
2767
2768 
2769 
2770.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow path { 
2771    transition: stroke 0.3s ease; 
2772
2773 
2774.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.inactive path { 
2775    stroke: #bababa; 
2776
2777 
2778.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.active path { 
2779    stroke: #008542; 
2780
2781 
2782 
2783.ws-carousel .ws-carousel-body { 
2784    overflow-x: scroll; 
2785    -ms-overflow-style: none; 
2786    -scrollbar-width: none; 
2787
2788 
2789.ws-carousel .ws-carousel-body::-webkit-scrollbar { 
2790    display: none; 
2791
2792 
2793.ws-carousel .ws-carousel-body .ws-container { 
2794    display: flex; 
2795    gap: var(--space-lg, 32px); 
2796
2797 
2798.ws-carousel .ws-carousel-body .ws-container .ws-item { 
2799    min-width: 300px; 
2800    max-width: 300px; 
2801    min-height: 400px; 
2802    max-height: 400px; 
2803    position: relative; 
2804    overflow: hidden; 
2805    border-radius: var(--border-radius-lg); 
2806    box-shadow: 0px 12px 60px -10px rgba(145, 147, 149, 0.12); 
2807
2808 
2809.ws-carousel .ws-carousel-body .ws-container .ws-item:hover { 
2810    cursor: pointer; 
2811
2812 
2813.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-image { 
2814    position: absolute; 
2815    top: 50%; 
2816    left: 50%; 
2817    transform: translate(-50%, -50%); 
2818    height: 100%; 
2819
2820 
2821.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-overlay { 
2822    position: absolute; 
2823    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%); 
2824    width: 100%; 
2825    height: 100%; 
2826
2827 
2828.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-label { 
2829    position: absolute; 
2830    margin: var(--space-md, 24px) 0 0 var(--space-md, 24px); 
2831    border-radius: var(--border-radius-pill, 100%); 
2832    background: linear-gradient(0deg, var(--Background-Surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 0%, var(--Background-Surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 100%), var(--Default-sup-green-water, #006B65); 
2833    box-shadow: 0px 2px 6px 0px rgba(0, 178, 169, 0.10); 
2834    padding: var(--space-micro, 2px) var(--space-xs, 12px); 
2835 
2836    color: var(--Default-sup-green-water, #006B65); 
2837    font-family: var(--font-family-base), "Petrobras Sans"; 
2838    font-size: var(--font-size-xxxs, 12px); 
2839    font-style: normal; 
2840    font-weight: var(--font-weight-regular, 400); 
2841    line-height: var(--line-height-sm, 120%); 
2842    color: #006B65; 
2843
2844 
2845.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-content { 
2846    position: relative; 
2847    z-index: 1; 
2848    height: 100%; 
2849 
2850    display: flex; 
2851    padding: var(--space-lg, 32px) var(--space-md, 24px) var(--space-md, 24px) var(--space-md, 24px); 
2852    flex-direction: column; 
2853    justify-content: flex-end; 
2854    align-items: flex-start; 
2855    gap: var(--space-md, 24px); 
2856
2857 
2858.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-content .h5 { 
2859    overflow: hidden; 
2860    color: #FFF !important; 
2861    text-overflow: ellipsis; 
2862    margin: 0 !important; 
2863    font-family: var(--font-family-base), "Petrobras Sans" !important; 
2864
2865 
2866@media (max-width: 768px) { 
2867 
2868    .ws-carousel .ws-carousel-header .nav-buttons { 
2869        gap: var(--space-micro, 12px); 
2870
2871 
2872    .ws-carousel .ws-carousel-header .nav-buttons .nav-arrow { 
2873        width: 44px; 
2874        height: 44px; 
2875
2876 
2877    .ws-carousel .ws-carousel-header { 
2878        flex-direction: column; 
2879        align-items: flex-start; 
2880        gap: var(--space-lg, 32px); 
2881
2882 
2883    .ws-carousel .ws-carousel-header .h2 { 
2884        font-size: var(--font-size-lg, 24px) !important; 
2885
2886 
2887    .ws-carousel .ws-carousel-body .ws-container { 
2888        gap: var(--space-lg, 32px); 
2889
2890 
2891    .ws-carousel .ws-carousel-body .ws-container .ws-item { 
2892        min-width: 225px; 
2893        max-width: 225px; 
2894        background: linear-gradient(180deg, rgba(0, 0, 0, 0.00) 0%, rgba(0, 0, 0, 0.80) 100%), url(<path-to-image>) lightgray 50% / cover no-repeat; 
2895        box-shadow: 0px 12px 60px -10px rgba(145, 147, 149, 0.12); 
2896
2897
2898    </style> 
2899 
2900<#--  Exibição de um único story com naveação direto no conteúdo  --> 
2901<style> 
2902  .stories-container * { 
2903    margin: 0; 
2904    padding: 0; 
2905    box-sizing: border-box; 
2906
2907 
2908  .stories-container { 
2909    position: relative; 
2910    /* 
2911      Largura das duas setas com position absolute: 64px 
2912      Largura das somas margens das setas: 48px 
2913 
2914    */ 
2915    width: calc(100vw - 64px - 48px); 
2916    max-width: 400px; 
2917    height: auto; 
2918    aspect-ratio: 59/105; 
2919    border-radius: 8px; 
2920
2921 
2922  .header-container { 
2923    position: absolute; 
2924    top: 0; 
2925    left: 0; 
2926    right: 0; 
2927    z-index: 3; 
2928    padding: 16px 16px 0 16px; 
2929    display: flex; 
2930    flex-direction: column; 
2931    gap: 24px; 
2932
2933 
2934  .story-header { 
2935    display: flex; 
2936    flex-direction: column; 
2937    gap: 8px; 
2938
2939 
2940  .progress-bars { 
2941    display: flex; 
2942    gap: 5px; 
2943    width: 100%; 
2944
2945 
2946  .progress-bar { 
2947    height: 3px; 
2948    background-color: rgba(255, 255, 255, 0.3); 
2949    flex-grow: 1; 
2950    border-radius: 3px; 
2951    overflow: hidden; 
2952
2953 
2954  .story-progress { 
2955    height: 100%; 
2956    background-color: white; 
2957    width: 0%; 
2958    transition: width 0.2s linear; 
2959
2960 
2961  .story-progress.completed { 
2962    width: 100% !important; 
2963
2964 
2965  .story-progress.active { 
2966    animation: progress 8s linear forwards; 
2967
2968 
2969  @keyframes progress { 
2970    from { 
2971      width: 0%; 
2972
2973 
2974    to { 
2975      width: 100%; 
2976
2977
2978 
2979  .story-slide { 
2980    position: absolute; 
2981    width: 100%; 
2982    height: 100%; 
2983    display: none; 
2984    flex-direction: column; 
2985    justify-content: center; 
2986    align-items: center; 
2987    color: white; 
2988    overflow: hidden; 
2989    border-radius: 8px; 
2990
2991 
2992  .story-slide::before { 
2993    position: absolute; 
2994    z-index: 2; 
2995    content: ''; 
2996    width: 100%; 
2997    height: 100%; 
2998    background: linear-gradient(180deg, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%); 
2999
3000 
3001  .story-slide.active { 
3002    display: flex; 
3003
3004 
3005  .story-image { 
3006    width: 100%; 
3007    height: 100% !important; 
3008    object-fit: cover; 
3009    position: absolute; 
3010    top: 0; 
3011    left: 0; 
3012    z-index: 1; 
3013    aspect-ratio: auto !important; 
3014
3015 
3016  .story-content { 
3017    position: relative; 
3018    z-index: 2; 
3019    color: white; 
3020    width: 100%; 
3021    display: flex; 
3022    flex-direction: column; 
3023    justify-content: flex-end; 
3024    height: 100%; 
3025    padding: 16px 24px 64px 24px; 
3026
3027 
3028  .story-content .content-wrapper { 
3029    display: flex; 
3030    flex-direction: column; 
3031    align-items: flex-start; 
3032    gap: 24px; 
3033    align-self: stretch; 
3034    padding: 0 16px; 
3035
3036 
3037  .story-content .content-wrapper.no-padding { 
3038    padding: 0; 
3039
3040 
3041  .story-title { 
3042    display: flex; 
3043    padding: 8px; 
3044    flex-direction: column; 
3045    align-items: flex-start; 
3046    align-self: stretch; 
3047    backdrop-filter: blur(3px); 
3048
3049 
3050  .story-title.button { 
3051    display: none; 
3052
3053 
3054  .story-title.dark-theme, 
3055  .story-description.dark-theme { 
3056    background: rgba(13, 19, 16, 0.80); 
3057    color: #FFF; 
3058
3059 
3060  .story-description.dark-theme p { 
3061    color: #FFF !important; 
3062
3063 
3064  .story-title.light-theme, 
3065  .story-description.light-theme { 
3066    background: rgba(255, 255, 255, 0.90); 
3067    color: #373737; 
3068
3069 
3070  .story-title.green-theme, 
3071  .story-description.green-theme { 
3072    background: rgba(0, 133, 66, 0.80); 
3073    color: #FFF; 
3074
3075 
3076  .story-title .title-text { 
3077    align-self: stretch; 
3078    font-size: 24px; 
3079    font-style: normal; 
3080    font-weight: 700; 
3081    line-height: 100%; 
3082
3083 
3084  .story-title .mischievous { 
3085    color: #FDC82F; 
3086    font-size: 24px; 
3087    font-style: normal; 
3088    font-weight: 700; 
3089    line-height: 100%; 
3090    width: 24px; 
3091
3092 
3093  .description-and-link { 
3094    width: 100%; 
3095    display: flex; 
3096    flex-direction: column; 
3097    gap: 8px; 
3098
3099 
3100  .story-description { 
3101    padding: 8px; 
3102    width: 100%; 
3103
3104 
3105  .story-description p { 
3106    font-size: 16px; 
3107    font-weight: 400; 
3108    line-height: 120%; 
3109    margin-bottom: 0; 
3110
3111 
3112  .story-description.button { 
3113    padding: 0; 
3114    display: flex; 
3115    justify-content: center; 
3116
3117 
3118  .story-description.button p a { 
3119    text-decoration: underline; 
3120    font-weight: bold; 
3121
3122 
3123  .story-description.button p a { 
3124    background: #FFF; 
3125    width: fit-content; 
3126    height: 48px; 
3127    display: flex; 
3128    justify-content: center; 
3129    align-items: center; 
3130    gap: 16px; 
3131    text-decoration: none; 
3132    color: #008542; 
3133    border-radius: 100px; 
3134    padding: 0 24px; 
3135    box-shadow: 0px 4px 16px 0px #00000029; 
3136    font-family: 'Petrobras Sans'; 
3137    font-weight: 700; 
3138    font-size: 16px; 
3139    line-height: 144%; 
3140    letter-spacing: 0%; 
3141
3142 
3143  .story-description.button p a::after { 
3144    content: ''; 
3145    display: inline-block; 
3146    flex-shrink: 0; 
3147    width: 20px; 
3148    height: 20px; 
3149    vertical-align: middle; 
3150    background-image: url(""); 
3151    background-size: contain; 
3152    background-repeat: no-repeat; 
3153    background-position: center; 
3154
3155 
3156  .story-description a { 
3157    position: relative; 
3158    z-index: 3; 
3159    color: #FFF; 
3160    text-decoration: underline; 
3161
3162 
3163  .nav-area-container { 
3164    position: absolute; 
3165    top: 0; 
3166    left: 0; 
3167    right: 0; 
3168    bottom: 0; 
3169    display: flex; 
3170    justify-content: space-between; 
3171    align-items: center; 
3172    z-index: 1; 
3173    /* pointer-events: none; */ 
3174
3175 
3176  .nav-area { 
3177    height: 100%; 
3178    width: 50%; 
3179    display: flex; 
3180    align-items: center; 
3181
3182 
3183  .nav-area .arrow, 
3184  .nav-area .restart-icon { 
3185    position: absolute; 
3186
3187 
3188  .nav-area .arrow:hover, 
3189  .nav-area.next .restart-icon { 
3190    cursor: pointer; 
3191
3192 
3193  .nav-area.prev .arrow { 
3194    left: calc(-32px - 24px); 
3195
3196 
3197  .nav-area.next .arrow, 
3198  .nav-area.next .restart-icon { 
3199    right: calc(-32px - 24px); 
3200
3201 
3202  .nav-area .arrow.disabled { 
3203    opacity: 0.4; 
3204
3205 
3206  .nav-area .arrow.disabled:hover { 
3207    cursor: not-allowed; 
3208
3209 
3210  .nav-area .hidden { 
3211    display: none; 
3212
3213 
3214  .action-buttons { 
3215    display: flex; 
3216    gap: 24px; 
3217    justify-content: flex-end; 
3218
3219 
3220  .action-btn { 
3221    background: transparent; 
3222    border-radius: 50%; 
3223    border: none; 
3224    display: flex; 
3225    align-items: center; 
3226    justify-content: center; 
3227    cursor: pointer; 
3228    font-size: 14px; 
3229
3230 
3231  .action-btn.pause::before { 
3232    content: ''; 
3233    display: inline-block; 
3234    width: 15px; 
3235    height: 18px; 
3236    vertical-align: middle; 
3237    background-image: url(""); 
3238    background-size: contain; 
3239    background-repeat: no-repeat; 
3240    background-position: center; 
3241
3242 
3243  .action-btn.play::before { 
3244    content: ''; 
3245    display: inline-block; 
3246    width: 18px; 
3247    height: 18px; 
3248    vertical-align: middle; 
3249    background-image: url(""); 
3250    background-size: contain; 
3251    background-repeat: no-repeat; 
3252    background-position: center; 
3253
3254 
3255  .action-btn.share::before { 
3256    content: ''; 
3257    display: inline-block; 
3258    width: 18px; 
3259    height: 18px; 
3260    vertical-align: middle; 
3261    background-image: url(""); 
3262    background-size: contain; 
3263    background-repeat: no-repeat; 
3264    background-position: center; 
3265
3266 
3267  @media (max-width: 768px) { 
3268    .ws-carousel { 
3269      margin: var(--space-lg, 32px) 0; 
3270
3271 
3272    .stories-container { 
3273      /* 
3274        Largura das duas setas com position absolute: 64px 
3275        Largura das somas margens das setas mobile: 16px 
3276        Soma das margens laterais: 48px 
3277      */ 
3278      width: calc(100vw - 64px - 16px - 48px); 
3279
3280 
3281    .header-container { 
3282      padding: 6px; 
3283
3284 
3285    .story-progress { 
3286      height: 2px; 
3287
3288 
3289    .header-container, 
3290    .action-buttons { 
3291      gap: 12px; 
3292
3293 
3294    .action-btn.play::before, 
3295    .action-btn.pause::before, 
3296    .action-btn.share::before { 
3297      width: 10px; 
3298      height: 10px; 
3299
3300 
3301    .nav-area.prev .arrow { 
3302      left: calc(-32px - 8px); 
3303
3304 
3305    .nav-area.next .arrow, 
3306    .nav-area.next .restart-icon { 
3307      right: calc(-32px - 8px); 
3308
3309 
3310    .story-content { 
3311      padding: 16px 16px 32px 16px; 
3312
3313 
3314    .story-content .content-wrapper { 
3315      padding: 0; 
3316
3317 
3318    .story-title .title-text { 
3319      font-size: 16px; 
3320
3321 
3322    .story-description p, 
3323    .story-description p a { 
3324      font-size: 14px !important; 
3325
3326
3327</style> 
3328 
3329    <script> 
3330			 
3331/* Alteração tamanho primeira imagem */ 
3332document.addEventListener("DOMContentLoaded", function () { 
3333  const firstImg = document.querySelector(".ptb-news__read-news .news-content img:not(.yt-thumb-img)"); 
3334  if (firstImg) { 
3335    firstImg.classList.add("first-news-image"); 
3336
3337}); 
3338				 
3339/* CONSTANTS */ 
3340const PUBLISHER_LOGO_INDEX = 0; 
3341const POSTER_PORTRAIT_INDEX = 1; 
3342const PUBLISHER_INDEX = 2; 
3343const COVER_INDEX = 3; 
3344const STORIES_INDEX = 4; 
3345 
3346const COVER_HAS_COVER_INDEX = 0; 
3347const COVER_TITLE_INDEX = 1; 
3348const COVER_TEXT_INDEX = 2; 
3349const COVER_IMAGE_INDEX = 3; 
3350 
3351const STORY_TITLE_INDEX = 0; 
3352const STORY_TEXT_INDEX = 1; 
3353const STORY_COLOR_THEME_INDEX = 2; 
3354const STORY_IMAGE_INDEX = 3; 
3355 
3356const DETAILS_SVG = `<svg width="91" height="21" viewBox="0 0 91 21" fill="none" xmlns="http://www.w3.org/2000/svg"> <path d="M12.5 3.625H7.5C7.15482 3.625 6.875 3.90482 6.875 4.25V16.75C6.875 17.0952 7.15482 17.375 7.5 17.375H12.5C12.8452 17.375 13.125 17.0952 13.125 16.75V4.25C13.125 3.90482 12.8452 3.625 12.5 3.625Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/> <path d="M17.5 14.25V6.75C17.5 6.40482 17.2202 6.125 16.875 6.125H13.75C13.4048 6.125 13.125 6.40482 13.125 6.75V14.25C13.125 14.5952 13.4048 14.875 13.75 14.875H16.875C17.2202 14.875 17.5 14.5952 17.5 14.25Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/> <path d="M6.875 14.25L6.875 6.75C6.875 6.40482 6.59518 6.125 6.25 6.125H3.125C2.77982 6.125 2.5 6.40482 2.5 6.75L2.5 14.25C2.5 14.5952 2.77982 14.875 3.125 14.875H6.25C6.59518 14.875 6.875 14.5952 6.875 14.25Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/> <path d="M30.376 15.5L28.36 6.74H29.56L31.06 14.132L32.704 7.196H33.784L35.428 14.132L36.928 6.74H38.08L36.064 15.5H34.828L33.208 8.672L31.588 15.5H30.376ZM39.6543 12.836C39.6783 13.252 39.7343 13.588 39.8223 13.844C39.9183 14.092 40.0503 14.284 40.2183 14.42C40.3863 14.548 40.5863 14.636 40.8183 14.684C41.0583 14.724 41.3303 14.744 41.6343 14.744C41.9143 14.744 42.1743 14.732 42.4143 14.708C42.6543 14.684 42.8863 14.656 43.1103 14.624V15.344C42.8703 15.44 42.5943 15.512 42.2823 15.56C41.9783 15.616 41.6623 15.644 41.3343 15.644C40.3343 15.644 39.6183 15.388 39.1863 14.876C38.7623 14.356 38.5503 13.584 38.5503 12.56C38.5503 11.456 38.7663 10.652 39.1983 10.148C39.6383 9.636 40.2703 9.38 41.0943 9.38C41.5183 9.38 41.8783 9.448 42.1743 9.584C42.4703 9.712 42.7103 9.908 42.8943 10.172C43.0783 10.428 43.2103 10.744 43.2903 11.12C43.3703 11.496 43.4103 11.928 43.4103 12.416V12.836H39.6543ZM42.3543 12.056C42.3543 11.424 42.2583 10.968 42.0663 10.688C41.8823 10.4 41.5543 10.256 41.0823 10.256C40.5703 10.256 40.2103 10.412 40.0023 10.724C39.7943 11.028 39.6743 11.472 39.6423 12.056H42.3543ZM44.9427 15.5V6.74H46.0467V10.1C46.2147 9.916 46.4347 9.752 46.7067 9.608C46.9867 9.456 47.3667 9.38 47.8467 9.38C48.6467 9.38 49.2387 9.652 49.6227 10.196C50.0067 10.74 50.1987 11.496 50.1987 12.464C50.1987 13.512 49.9827 14.304 49.5507 14.84C49.1267 15.376 48.5067 15.644 47.6907 15.644C47.2347 15.644 46.8707 15.572 46.5987 15.428C46.3347 15.284 46.1107 15.096 45.9267 14.864L45.8427 15.5H44.9427ZM46.0227 12.944C46.0227 13.28 46.0627 13.56 46.1427 13.784C46.2227 14.008 46.3307 14.192 46.4667 14.336C46.6107 14.472 46.7747 14.572 46.9587 14.636C47.1507 14.692 47.3547 14.72 47.5707 14.72C48.0587 14.72 48.4267 14.556 48.6747 14.228C48.9307 13.9 49.0587 13.332 49.0587 12.524C49.0587 12.092 49.0227 11.736 48.9507 11.456C48.8867 11.168 48.7907 10.94 48.6627 10.772C48.5347 10.604 48.3747 10.484 48.1827 10.412C47.9987 10.34 47.7907 10.304 47.5587 10.304C47.3347 10.304 47.1267 10.332 46.9347 10.388C46.7507 10.444 46.5907 10.54 46.4547 10.676C46.3187 10.804 46.2107 10.98 46.1307 11.204C46.0587 11.42 46.0227 11.692 46.0227 12.02V12.944ZM54.1271 14.36C54.4711 14.424 54.8431 14.48 55.2431 14.528C55.6431 14.576 56.0231 14.6 56.3831 14.6C56.6791 14.6 56.9431 14.584 57.1751 14.552C57.4071 14.512 57.6031 14.436 57.7631 14.324C57.9231 14.212 58.0431 14.056 58.1231 13.856C58.2111 13.648 58.2551 13.38 58.2551 13.052C58.2551 12.796 58.2271 12.588 58.1711 12.428C58.1151 12.26 58.0191 12.124 57.8831 12.02C57.7551 11.916 57.5831 11.832 57.3671 11.768C57.1511 11.696 56.8871 11.624 56.5751 11.552L56.2151 11.468C55.8951 11.396 55.5991 11.308 55.3271 11.204C55.0631 11.092 54.8351 10.948 54.6431 10.772C54.4511 10.588 54.2991 10.364 54.1871 10.1C54.0831 9.836 54.0311 9.508 54.0311 9.116C54.0311 8.292 54.2711 7.668 54.7511 7.244C55.2391 6.82 55.9551 6.608 56.8991 6.608C57.3391 6.608 57.7471 6.648 58.1231 6.728C58.5071 6.808 58.8431 6.904 59.1311 7.016V7.82C58.8351 7.78 58.4951 7.736 58.1111 7.688C57.7351 7.64 57.3671 7.616 57.0071 7.616C56.7351 7.616 56.4871 7.632 56.2631 7.664C56.0391 7.696 55.8431 7.764 55.6751 7.868C55.5151 7.964 55.3911 8.104 55.3031 8.288C55.2151 8.472 55.1711 8.712 55.1711 9.008C55.1711 9.264 55.2031 9.476 55.2671 9.644C55.3391 9.804 55.4431 9.936 55.5791 10.04C55.7231 10.144 55.8951 10.232 56.0951 10.304C56.3031 10.368 56.5471 10.428 56.8271 10.484L57.2111 10.568C57.5791 10.648 57.8991 10.748 58.1711 10.868C58.4511 10.98 58.6831 11.128 58.8671 11.312C59.0511 11.496 59.1871 11.724 59.2751 11.996C59.3711 12.268 59.4191 12.6 59.4191 12.992C59.4191 13.464 59.3511 13.868 59.2151 14.204C59.0871 14.54 58.8991 14.816 58.6511 15.032C58.4031 15.24 58.0991 15.392 57.7391 15.488C57.3791 15.584 56.9711 15.632 56.5151 15.632C56.0031 15.632 55.5471 15.584 55.1471 15.488C54.7471 15.384 54.4071 15.276 54.1271 15.164V14.36ZM62.3096 13.52C62.3096 14.016 62.4056 14.348 62.5976 14.516C62.7896 14.676 63.0776 14.756 63.4616 14.756C63.7496 14.756 64.0096 14.744 64.2416 14.72V15.44C64.0736 15.488 63.8896 15.528 63.6896 15.56C63.4896 15.6 63.2776 15.62 63.0536 15.62C62.4056 15.62 61.9336 15.46 61.6376 15.14C61.3496 14.82 61.2056 14.296 61.2056 13.568V10.376H60.1376V9.74L61.2056 9.536V7.7H62.3096V9.524H64.1336V10.376H62.3096V13.52ZM66.6991 14.24C66.8351 14.416 66.9951 14.54 67.1791 14.612C67.3711 14.684 67.5951 14.72 67.8511 14.72C68.0991 14.72 68.3151 14.684 68.4991 14.612C68.6911 14.54 68.8471 14.42 68.9671 14.252C69.0951 14.076 69.1911 13.848 69.2551 13.568C69.3191 13.288 69.3511 12.936 69.3511 12.512C69.3511 12.096 69.3191 11.748 69.2551 11.468C69.1911 11.18 69.0911 10.952 68.9551 10.784C68.8271 10.608 68.6671 10.484 68.4751 10.412C68.2831 10.34 68.0631 10.304 67.8151 10.304C67.5671 10.304 67.3471 10.34 67.1551 10.412C66.9711 10.484 66.8151 10.604 66.6871 10.772C66.5671 10.94 66.4751 11.168 66.4111 11.456C66.3471 11.736 66.3151 12.084 66.3151 12.5C66.3151 12.924 66.3471 13.276 66.4111 13.556C66.4751 13.836 66.5711 14.064 66.6991 14.24ZM67.8271 15.644C66.9311 15.644 66.2671 15.384 65.8351 14.864C65.4031 14.344 65.1871 13.564 65.1871 12.524C65.1871 11.476 65.4031 10.692 65.8351 10.172C66.2751 9.644 66.9471 9.38 67.8511 9.38C68.7471 9.38 69.4111 9.64 69.8431 10.16C70.2751 10.68 70.4911 11.46 70.4911 12.5C70.4911 13.548 70.2711 14.336 69.8311 14.864C69.3991 15.384 68.7311 15.644 67.8271 15.644ZM72.0247 15.5V9.524H72.9127L73.0327 10.28C73.4407 9.712 74.0447 9.428 74.8447 9.428C74.9727 9.428 75.1047 9.44 75.2407 9.464V10.376C75.1767 10.368 75.1167 10.364 75.0607 10.364C75.0047 10.364 74.9487 10.364 74.8927 10.364C74.3007 10.364 73.8567 10.504 73.5607 10.784C73.2727 11.064 73.1287 11.516 73.1287 12.14V15.5H72.0247ZM76.431 15.5V9.524H77.535V15.5H76.431ZM76.995 8.3C76.763 8.3 76.591 8.24 76.479 8.12C76.367 8 76.311 7.832 76.311 7.616C76.311 7.144 76.539 6.908 76.995 6.908C77.227 6.908 77.395 6.968 77.499 7.088C77.611 7.208 77.667 7.376 77.667 7.592C77.667 8.064 77.443 8.3 76.995 8.3ZM80.1778 12.836C80.2018 13.252 80.2578 13.588 80.3458 13.844C80.4418 14.092 80.5738 14.284 80.7418 14.42C80.9098 14.548 81.1098 14.636 81.3418 14.684C81.5818 14.724 81.8538 14.744 82.1578 14.744C82.4378 14.744 82.6978 14.732 82.9378 14.708C83.1778 14.684 83.4098 14.656 83.6338 14.624V15.344C83.3938 15.44 83.1178 15.512 82.8058 15.56C82.5018 15.616 82.1858 15.644 81.8578 15.644C80.8578 15.644 80.1418 15.388 79.7098 14.876C79.2858 14.356 79.0738 13.584 79.0738 12.56C79.0738 11.456 79.2898 10.652 79.7218 10.148C80.1618 9.636 80.7938 9.38 81.6178 9.38C82.0418 9.38 82.4018 9.448 82.6978 9.584C82.9938 9.712 83.2338 9.908 83.4178 10.172C83.6018 10.428 83.7338 10.744 83.8138 11.12C83.8938 11.496 83.9338 11.928 83.9338 12.416V12.836H80.1778ZM82.8778 12.056C82.8778 11.424 82.7818 10.968 82.5898 10.688C82.4058 10.4 82.0778 10.256 81.6058 10.256C81.0938 10.256 80.7338 10.412 80.5258 10.724C80.3178 11.028 80.1978 11.472 80.1658 12.056H82.8778ZM85.2741 14.612C85.5141 14.644 85.7901 14.672 86.1021 14.696C86.4221 14.72 86.7341 14.732 87.0381 14.732C87.2781 14.732 87.4861 14.724 87.6621 14.708C87.8461 14.684 87.9941 14.64 88.1061 14.576C88.2181 14.504 88.3021 14.408 88.3581 14.288C88.4141 14.168 88.4421 14.012 88.4421 13.82C88.4421 13.66 88.4221 13.532 88.3821 13.436C88.3421 13.332 88.2741 13.248 88.1781 13.184C88.0901 13.12 87.9661 13.072 87.8061 13.04C87.6541 13 87.4621 12.964 87.2301 12.932L86.8341 12.872C86.6181 12.84 86.4101 12.792 86.2101 12.728C86.0101 12.656 85.8341 12.56 85.6821 12.44C85.5381 12.312 85.4181 12.148 85.3221 11.948C85.2341 11.74 85.1901 11.48 85.1901 11.168C85.1901 10.848 85.2421 10.576 85.3461 10.352C85.4501 10.128 85.5981 9.944 85.7901 9.8C85.9821 9.656 86.2101 9.552 86.4741 9.488C86.7461 9.424 87.0461 9.392 87.3741 9.392C87.7341 9.392 88.0621 9.42 88.3581 9.476C88.6621 9.524 88.9501 9.592 89.2221 9.68V10.388C88.9901 10.364 88.7301 10.34 88.4421 10.316C88.1621 10.292 87.8701 10.28 87.5661 10.28C87.3581 10.28 87.1701 10.288 87.0021 10.304C86.8341 10.32 86.6901 10.36 86.5701 10.424C86.4501 10.48 86.3541 10.564 86.2821 10.676C86.2181 10.78 86.1861 10.928 86.1861 11.12C86.1861 11.272 86.2061 11.396 86.2461 11.492C86.2941 11.58 86.3621 11.656 86.4501 11.72C86.5461 11.776 86.6661 11.82 86.8101 11.852C86.9541 11.884 87.1301 11.916 87.3381 11.948L87.6621 11.996C87.9421 12.036 88.1941 12.092 88.4181 12.164C88.6421 12.236 88.8301 12.34 88.9821 12.476C89.1421 12.604 89.2621 12.772 89.3421 12.98C89.4301 13.188 89.4741 13.452 89.4741 13.772C89.4741 14.436 89.2861 14.912 88.9101 15.2C88.5341 15.488 88.0141 15.632 87.3501 15.632C87.1501 15.632 86.9501 15.62 86.7501 15.596C86.5501 15.58 86.3581 15.556 86.1741 15.524C85.9901 15.492 85.8181 15.46 85.6581 15.428C85.5061 15.388 85.3781 15.352 85.2741 15.32V14.612Z" fill="white"/> </svg`; 
3357 
3358/* Função para criar formatar object*/ 
3359const createStoryObject = (objectContent) => { 
3360  const hasCover = Boolean( 
3361    objectContent.contentFields[COVER_INDEX].nestedContentFields[ 
3362      COVER_HAS_COVER_INDEX 
3363    ].contentFieldValue.data 
3364  ); 
3365  return { 
3366    category: objectContent.taxonomyCategoryBriefs[0].taxonomyCategoryName, 
3367    publisherLogoSrc: 
3368      objectContent.contentFields[PUBLISHER_LOGO_INDEX].contentFieldValue.data, 
3369    posterPortraitSrc: 
3370      objectContent.contentFields[POSTER_PORTRAIT_INDEX].contentFieldValue.data, 
3371    publisher: 
3372      objectContent.contentFields[PUBLISHER_INDEX].contentFieldValue.data, 
3373    friendlyUrlPath: objectContent.friendlyUrlPath, 
3374    cover: { 
3375      image: Boolean( 
3376        objectContent.contentFields[COVER_INDEX].nestedContentFields[ 
3377          COVER_HAS_COVER_INDEX 
3378        ].contentFieldValue.data 
3379      ), 
3380      title: 
3381        objectContent.contentFields[COVER_INDEX].nestedContentFields[ 
3382          COVER_TITLE_INDEX 
3383        ].contentFieldValue.data, 
3384      description: 
3385        objectContent.contentFields[COVER_INDEX].nestedContentFields[ 
3386          COVER_TEXT_INDEX 
3387        ].contentFieldValue.data, 
3388      imageUrl: 
3389        objectContent.contentFields[COVER_INDEX].nestedContentFields[ 
3390          COVER_IMAGE_INDEX 
3391        ].contentFieldValue.image?.contentUrl || null, 
3392      imageAlt: 
3393        objectContent.contentFields[COVER_INDEX].nestedContentFields[ 
3394          COVER_IMAGE_INDEX 
3395        ].contentFieldValue.image?.description || null, 
3396    }, 
3397    stories: objectContent.contentFields 
3398      .slice(STORIES_INDEX) 
3399      .map((contentField) => { 
3400        return { 
3401          title: 
3402            contentField.nestedContentFields[STORY_TITLE_INDEX] 
3403              ?.contentFieldValue?.data ?? null, 
3404          description: 
3405            contentField.nestedContentFields[STORY_TEXT_INDEX]?.contentFieldValue 
3406              .data ?? null, 
3407          colorTheme: 
3408            contentField.nestedContentFields[STORY_COLOR_THEME_INDEX] 
3409              ?.contentFieldValue?.value ?? null, 
3410          imageUrl: 
3411            contentField.nestedContentFields[STORY_IMAGE_INDEX] 
3412              ?.contentFieldValue?.image?.contentUrl ?? null, 
3413          imageAlt: 
3414            contentField.nestedContentFields[STORY_IMAGE_INDEX] 
3415              ?.contentFieldValue?.image?.description ?? null, 
3416        }; 
3417      }), 
3418  }; 
3419}; 
3420 
3421/* Renderiza os cards */ 
3422const storyCardFrom = (storyData) => { 
3423  const storyCard = document.createElement("div"); 
3424  storyCard.classList.add("ws-item"); 
3425 
3426  let displayPageUrl; 
3427  if (`${themeDisplay.getURLPortal()}`.includes('webserver')) { 
3428    displayPageUrl = `${themeDisplay.getURLPortal()}/web/nossa-energia/w/` + storyData.friendlyUrlPath; 
3429  } else { 
3430    displayPageUrl = `${themeDisplay.getURLPortal()}/w/` + storyData.friendlyUrlPath; 
3431
3432 
3433  storyCard.addEventListener("click", (e) => { 
3434    window.location.href = displayPageUrl; 
3435  }); 
3436 
3437  const image = document.createElement("img"); 
3438  image.classList.add("ws-image"); 
3439  image.src = storyData.cover.imageUrl 
3440    ? storyData.cover.imageUrl 
3441    : storyData.stories[0].imageUrl; 
3442  image.alt = storyData.cover.imageAlt 
3443    ? storyData.cover.imageAlt 
3444    : storyData.stories[0].imageAlt; 
3445 
3446  storyCard.appendChild(image); 
3447 
3448  const overlay = document.createElement("div"); 
3449  overlay.classList.add("ws-overlay"); 
3450  storyCard.appendChild(overlay); 
3451 
3452  const label = document.createElement("span"); 
3453  label.classList.add("ws-label"); 
3454  label.dataset.category = storyData.category; 
3455  label.classList.add((storyData.category || "Categoria").toLowerCase().replace(" ", '-')); 
3456  label.textContent = storyData.category || "Categoria"; 
3457  storyCard.appendChild(label); 
3458 
3459  const content = document.createElement("div"); 
3460  content.classList.add("ws-content"); 
3461 
3462  const title = document.createElement("h5"); 
3463  title.classList.add("h5") 
3464  title.textContent = storyData.cover.title || "Título do Card"; 
3465  content.appendChild(title); 
3466 
3467  const details = document.createElement("div"); 
3468  details.classList.add("ws-details"); 
3469 
3470  details.innerHTML = DETAILS_SVG || `<svg>...</svg>`; 
3471  content.appendChild(details); 
3472 
3473  storyCard.appendChild(content); 
3474 
3475  return storyCard; 
3476}; 
3477 
3478/* Renderiza cores */ 
3479 
3480const getCategoriesColorsStyles = async () => { 
3481    // 
3482    const urlToFetchToGetWebStoriesCategoriesColor = `/o/headless-admin-taxonomy/v1.0/taxonomy-vocabularies/31841266/taxonomy-categories?fields=name%2CtaxonomyCategoryProperties`; 
3483 
3484  return fetch(urlToFetchToGetWebStoriesCategoriesColor, { 
3485    method: "GET", 
3486    headers: { 
3487      accept: "application/json", 
3488      "x-csrf-token": Liferay.authToken, 
3489    }, 
3490  }) 
3491    .then((response) => { 
3492      if (response.status === 200) { 
3493        return response.json(); 
3494      } else { 
3495        throw new Error("Erro interno. Por favor tente mais tarde."); 
3496
3497    }) 
3498    .then((data) => { 
3499      const styleTag = document.createElement('style'); 
3500      styleTag.id= 'webstories-carousel-labels'; 
3501 
3502      let styleContent = ``; 
3503       
3504      data.items.forEach(item => { 
3505        let textColor = item.taxonomyCategoryProperties.find(taxonomtProp => taxonomtProp.key === "Cor do Texto")?.value; 
3506        let textHighContrastColor = item.taxonomyCategoryProperties.find(taxonomtProp => taxonomtProp.key === "Cor do Texto em Alto Contraste")?.value; 
3507 
3508        if (textColor != undefined) { 
3509            styleContent = styleContent + ` 
3510            .ws-carousel .ws-carousel-body .ws-container .ws-item .ws-label[data-category="` + item.name + `"] { 
3511                color: #` + textColor + `; 
3512
3513
3514
3515 
3516        if (textHighContrastColor != undefined) { 
3517            styleContent = styleContent + ` 
3518            body.high-contrast .ws-carousel .ws-carousel-body .ws-container .ws-item .ws-label[data-category="` + item.name + `"] { 
3519                color: #` + textHighContrastColor + `; 
3520
3521
3522
3523      }); 
3524 
3525      styleTag.textContent = styleContent; 
3526 
3527      document.head.appendChild(styleTag); 
3528    }); 
3529}; 
3530 
3531getCategoriesColorsStyles(); 
3532 
3533/* Renderiza os itens */ 
3534const renderItems = (carouselId, webStoriesObjects) => { 
3535  const carouselElement = document.querySelector(`#` + carouselId); 
3536  const carouselContainer = carouselElement.querySelector(`.ws-container`); 
3537  const carouselBody = carouselElement.querySelector(".ws-carousel-body"); 
3538  const navButtons = carouselElement.querySelector(".nav-buttons"); 
3539  const leftArrow = navButtons.querySelector(".left-arrow"); 
3540  const rightArrow = navButtons.querySelector(".right-arrow"); 
3541 
3542  // Adiciona Cards 
3543  webStoriesObjects.forEach((storyObject, index) => { 
3544    const storyCard = storyCardFrom(storyObject); 
3545    storyCard.dataset.index = index; 
3546    carouselContainer.appendChild(storyCard); 
3547  }); 
3548 
3549  // Altera o Layout 
3550  function updateLayout() { 
3551    if (webStoriesObjects.length < 3) { 
3552      if (window.matchMedia("(min-width: 769px)").matches) { 
3553        carouselContainer.style.justifyContent = "center"; 
3554        navButtons.style.display = "none"; 
3555      } else { 
3556        carouselContainer.style.justifyContent = "flex-start"; 
3557        navButtons.style.display = "flex"; 
3558
3559    } else { 
3560      carouselContainer.style.justifyContent = ""; 
3561      carouselContainer.style.gap = window.matchMedia("(max-width: 768px)") 
3562        .matches 
3563        ? "32px" 
3564        : "16px"; 
3565      navButtons.style.display = ""; 
3566
3567
3568  updateLayout(); 
3569  window.addEventListener("resize", updateLayout); 
3570 
3571  // Configura Scroll das setas 
3572  leftArrow.addEventListener("click", () => { 
3573    const items = carouselBody.querySelectorAll(".ws-item"); 
3574    const gap = window.matchMedia("(max-width: 768px)").matches ? 32 : 16; 
3575    const pageSize = items[0].offsetWidth + gap; 
3576    const currentScroll = carouselBody.scrollLeft; 
3577    const currentPageReal = carouselBody.scrollLeft / pageSize; 
3578    const currentPage = parseInt(currentPageReal); 
3579    const rest = currentPage - currentPageReal; 
3580    const nextPage = rest !== 0 ? currentPage : currentPage - 1; 
3581    carouselBody.scrollLeft = nextPage * pageSize; 
3582  }); 
3583 
3584  rightArrow.addEventListener("click", () => { 
3585    const gap = window.matchMedia("(max-width: 768px)").matches ? 32 : 16; 
3586    const items = carouselBody.querySelectorAll(".ws-item"); 
3587    carouselBody.scrollLeft += items[0].offsetWidth + gap; 
3588  }); 
3589 
3590  const updateArrows = () => { 
3591    const scrollLeft = carouselBody.scrollLeft; 
3592    const maxScrollLeft = carouselBody.scrollWidth - carouselBody.clientWidth; 
3593 
3594    // Regra 1: A seta esquerda fica cinza se scrollLeft for 0 
3595    if (scrollLeft === 0) { 
3596      leftArrow.classList.remove("active"); 
3597      leftArrow.classList.add("inactive"); 
3598    } else { 
3599      leftArrow.classList.remove("inactive"); 
3600      leftArrow.classList.add("active"); 
3601
3602 
3603    // Regra 2: A seta direita fica cinza se o scroll for máximo 
3604    if (scrollLeft >= maxScrollLeft) { 
3605      rightArrow.classList.remove("active"); 
3606      rightArrow.classList.add("inactive"); 
3607    } else { 
3608      rightArrow.classList.remove("inactive"); 
3609      rightArrow.classList.add("active"); 
3610
3611  }; 
3612 
3613  carouselBody.addEventListener("scroll", updateArrows); 
3614}; 
3615 
3616/* Fetch Things */ 
3617async function getWebStoriesDataSectionFromNews(webContentId) { 
3618  const ID_INDEX = 0; 
3619  const WEB_STORIES_STRUCTURED_CONTENT_INDEX_START_AT = 2; 
3620  const urlToFetchToGetWebStoriesGroup = 
3621    `/o/headless-delivery/v1.0/structured-contents/` + 
3622    webContentId + 
3623    `?fields=contentFields`; 
3624 
3625  return fetch(urlToFetchToGetWebStoriesGroup, { 
3626    method: "GET", 
3627    headers: { 
3628      accept: "application/json", 
3629      "x-csrf-token": Liferay.authToken, 
3630    }, 
3631  }) 
3632    .then((response) => { 
3633      if (response.status === 200) { 
3634        return response.json(); 
3635      } else { 
3636        throw new Error("Erro interno. Por favor tente mais tarde."); 
3637
3638    }) 
3639    .then((data) => { 
3640      const webStoriesGroups = Array.from(data.contentFields).filter( 
3641        (contentField) => contentField.label === "Web Stories" 
3642      ); 
3643 
3644      const webStoriesDataMapped = webStoriesGroups.map((webStoryGroup) => { 
3645        const webStoryGroupId = 
3646          webStoryGroup.nestedContentFields[ID_INDEX].contentFieldValue.data; 
3647        const webStoriesStrucutredContentNodes = 
3648          webStoryGroup.nestedContentFields.slice( 
3649            WEB_STORIES_STRUCTURED_CONTENT_INDEX_START_AT 
3650          ); 
3651        const webStoriesIds = Array.from(webStoriesStrucutredContentNodes).map( 
3652          (webStoryNode) => { 
3653            const webStoryId = 
3654              webStoryNode.contentFieldValue.structuredContentLink.id; 
3655            return { 
3656              webStoryId: webStoryId, 
3657            }; 
3658
3659        ); 
3660        return { 
3661          webStoryGroupId: webStoryGroupId, 
3662          webStoriesIds: webStoriesIds, 
3663        }; 
3664      }); 
3665 
3666      return webStoriesDataMapped; 
3667    }) 
3668    .then((webStoriesDataMapped) => { 
3669      // Mapeia os dados recebidos 
3670      return Promise.all( 
3671        webStoriesDataMapped.map(async (group) => { 
3672          const updatedWebStoriesIds = await Promise.all( 
3673            group.webStoriesIds.map(async (story) => { 
3674              // Faz o fetch para obter os dados do webStoryId 
3675              const response = await fetch( 
3676                `/o/headless-delivery/v1.0/structured-contents/` + 
3677                  story.webStoryId, 
3678
3679                  method: "GET", 
3680                  headers: { 
3681                    accept: "application/json", 
3682                    "x-csrf-token": Liferay.authToken, 
3683                  }, 
3684
3685              ); 
3686              if (!response.ok) { 
3687                throw new Error( 
3688                  `Erro ao buscar dados para webStoryId` + story.webStoryId 
3689                ); 
3690
3691              const webStoryData = await response.json(); 
3692              return { webStoryData: webStoryData }; 
3693            }) 
3694          ); 
3695 
3696          // Retorna o objeto transformado 
3697          return { 
3698            webStoryGroupId: group.webStoryGroupId, 
3699            webStoriesData: updatedWebStoriesIds, 
3700          }; 
3701        }) 
3702      ); 
3703    }) 
3704    .then((webStoriesDataFetched) => { 
3705      return webStoriesDataFetched.map((data) => { 
3706        return { 
3707          webStoryGroupId: data.webStoryGroupId, 
3708          webStoryObjects: data.webStoriesData.map((data) => 
3709            createStoryObject(data.webStoryData) 
3710          ), 
3711        }; 
3712      }); 
3713    }) 
3714    .catch((error) => { 
3715      console.error("Erro ao buscar coleção: ", error); 
3716    }); 
3717
3718 
3719async function getWebStoriesData(webStoriesIds) { 
3720  // Mapeia os IDs para criar um array de promessas 
3721  const fetchPromises = webStoriesIds.map((webStoryId) => { 
3722    //const urlToFetch = `/o/headless-delivery/v1.0/structured-contents/` + webStoryId + `?fields=contentFields`; 
3723    const urlToFetch = 
3724      `/o/headless-delivery/v1.0/structured-contents/` + 
3725      webStoryId + 
3726      `?fields=contentFields%2CtaxonomyCategoryBriefs`; 
3727    return fetch(urlToFetch, { 
3728      method: "GET", 
3729      headers: { 
3730        accept: "application/json", 
3731        "x-csrf-token": Liferay.authToken, 
3732      }, 
3733    }).then((response) => { 
3734      if (!response.ok) { 
3735        throw new Error(`Erro ao buscar ID`); 
3736
3737      return response.json(); // Transforma a resposta em JSON 
3738    }); 
3739  }); 
3740 
3741  // Aguarda todas as promessas e preserva a ordem 
3742  try { 
3743    const results = await Promise.all(fetchPromises); 
3744    return results; // Retorna os resultados em ordem 
3745  } catch (error) { 
3746    console.error("Erro ao buscar Web Stories:", error); 
3747    throw error; // Relança o erro para tratamento posterior 
3748
3749
3750 
3751<#noparse> 
3752const scriptForStoryInNews = (storyData, containerId) => { 
3753 
3754  storyData.stories = storyData.stories.filter(story => story.imageUrl !== null) 
3755  
3756  const storiesContainer = document.getElementById(`stories-container-${containerId}`); 
3757  const prevArrow = storiesContainer.querySelector('.nav-area.prev svg.arrow'); 
3758  const nextArrow = storiesContainer.querySelector('.nav-area.next svg.arrow'); 
3759  const restartIcon = storiesContainer.querySelector('.nav-area.next svg.restart-icon'); 
3760  const progressBars = storiesContainer.querySelector('.progress-bars'); 
3761  const pauseBtn = storiesContainer.querySelector('.pause-btn'); 
3762  const shareBtn = storiesContainer.querySelector('.share-btn'); 
3763 
3764  let currentStoryIndex = 0; 
3765  let progressTimeout; 
3766  let touchStartX = 0; 
3767  let touchEndX = 0; 
3768  let isPaused = false; 
3769  let viewedStories = new Set(); 
3770  let progressStartTime = 0; 
3771  let remainingTime = 8000; 
3772 
3773  // Cria slides dos stories 
3774  function createStorySlides() { 
3775    // Cria barras de progresso 
3776    storyData.stories.forEach((story, index) => { 
3777      const progressContainer = document.createElement('div'); 
3778      progressContainer.className = 'progress-bar'; 
3779      progressContainer.dataset.index = index; 
3780 
3781      const progress = document.createElement('div'); 
3782      progress.className = 'story-progress'; 
3783      progressContainer.appendChild(progress); 
3784 
3785      progressBars.appendChild(progressContainer); 
3786    }); 
3787 
3788    // Cria slides 
3789    storyData.stories.forEach((story, index) => { 
3790      const slide = document.createElement('div'); 
3791      slide.className = `story-slide ${index === 0 ? 'active' : ''}`; 
3792      slide.dataset.index = index; 
3793 
3794      let imageHtml = ''; 
3795      if (story.imageUrl) { 
3796        imageHtml = `<img src="${story.imageUrl}" alt="${story.imageAlt || ''}" class="story-image" loading="lazy">`; 
3797
3798 
3799      slide.innerHTML = ` 
3800        ${imageHtml} 
3801        <div class="story-content"> 
3802          <div class="content-wrapper"> 
3803          ${story.title && ( 
3804            `<div class="story-title ${story.colorTheme}"> 
3805              <p class="title-text">${story.title}</p> 
3806              <div class="mischievous">—</div> 
3807            </div>` 
3808          )} 
3809            ${story.description && `<div class="story-description description-text ${story.colorTheme}">${story.description}</div>`} 
3810          </div> 
3811        </div> 
3812      `; 
3813      storiesContainer.insertBefore(slide, storiesContainer.querySelector('.nav-area-container')); 
3814    }); 
3815 
3816    updateArrows(); 
3817    updateProgressBars(); 
3818    startProgressBar(); 
3819
3820 
3821  // Atualiza o estado das setas de navegação 
3822  function updateArrows() { 
3823    // Seta anterior 
3824    if (currentStoryIndex === 0) { 
3825      prevArrow.classList.add('disabled'); 
3826    } else { 
3827      prevArrow.classList.remove('disabled'); 
3828
3829 
3830    // Próxima seta 
3831    if (currentStoryIndex === storyData.stories.length - 1) { 
3832      nextArrow.classList.add('hidden'); 
3833      restartIcon.classList.remove('hidden'); 
3834    } else { 
3835      nextArrow.classList.remove('hidden'); 
3836      restartIcon.classList.add('hidden'); 
3837
3838
3839 
3840  // Atualiza as barras de progresso conforme navegação 
3841  function updateProgressBars() { 
3842    const allProgressBars = storiesContainer.querySelectorAll('.progress-bar .story-progress'); 
3843 
3844    allProgressBars.forEach((bar, index) => { 
3845      bar.classList.remove('completed', 'active'); 
3846      bar.style.width = '0%'; 
3847      bar.style.animation = 'none'; 
3848 
3849      if (index < currentStoryIndex) { 
3850        // Stories já vistos - barra completa 
3851        bar.classList.add('completed'); 
3852        bar.style.width = '100%'; 
3853      } else if (index === currentStoryIndex) { 
3854        // Story atual - barra em progresso 
3855        bar.classList.add('active'); 
3856      } else { 
3857        // Stories não vistos - barra vazia 
3858        bar.style.width = '0%'; 
3859
3860    }); 
3861
3862 
3863  function nextStory() { 
3864    if (currentStoryIndex < storyData.stories.length - 1) { 
3865      viewedStories.add(currentStoryIndex); 
3866      goToStory(currentStoryIndex + 1); 
3867
3868
3869 
3870  function prevStory() { 
3871    if (currentStoryIndex > 0) { 
3872      viewedStories.delete(currentStoryIndex); 
3873      goToStory(currentStoryIndex - 1); 
3874
3875
3876 
3877  function goToStory(index) { 
3878    // Pausa a animação atual 
3879    clearTimeout(progressTimeout); 
3880 
3881    storiesContainer.querySelector('.story-slide.active').classList.remove('active'); 
3882    currentStoryIndex = index; 
3883    storiesContainer.querySelector(`.story-slide[data-index="${index}"]`).classList.add('active'); 
3884 
3885    updateArrows(); 
3886    updateProgressBars(); 
3887 
3888    isPaused = false; 
3889    pauseBtn.classList.replace('play', 'pause'); 
3890    startProgressBar(); 
3891
3892 
3893  function startProgressBar() { 
3894    const currentProgressBar = storiesContainer.querySelector(`.progress-bar[data-index="${currentStoryIndex}"] .story-progress`); 
3895 
3896    // Resetar e iniciar animação 
3897    currentProgressBar.style.animation = 'none'; 
3898    currentProgressBar.offsetHeight; // Trigger reflow 
3899    currentProgressBar.style.animation = 'progress 8s linear forwards'; 
3900 
3901    progressStartTime = Date.now(); 
3902 
3903    progressTimeout = setTimeout(() => { 
3904      nextStory(); 
3905    }, remainingTime); 
3906
3907 
3908  // Pausar/continuar story 
3909  function togglePause() { 
3910    isPaused = !isPaused; 
3911 
3912    const currentProgressBar = storiesContainer.querySelector(`.progress-bar[data-index="${currentStoryIndex}"] .story-progress`); 
3913 
3914    if (isPaused) { 
3915      // Pausar 
3916      currentProgressBar.style.animationPlayState = 'paused'; 
3917      clearTimeout(progressTimeout); 
3918 
3919      // Calcular tempo restante 
3920      const elapsed = Date.now() - progressStartTime; 
3921      remainingTime = Math.max(0, 8000 - elapsed); 
3922 
3923      pauseBtn.classList.remove('pause'); 
3924      pauseBtn.classList.add('play'); 
3925    } else { 
3926      // Retomar 
3927      currentProgressBar.style.animationPlayState = 'running'; 
3928      pauseBtn.classList.remove('play'); 
3929      pauseBtn.classList.add('pause'); 
3930 
3931      // Reiniciar com tempo restante 
3932      progressStartTime = Date.now(); 
3933      progressTimeout = setTimeout(() => { 
3934        nextStory(); 
3935      }, remainingTime); 
3936
3937
3938 
3939  function shareStory() { 
3940    const currentStory = storyData.stories[currentStoryIndex]; 
3941    const baseUrl = window.location.origin; 
3942    let displayPageUrl; 
3943    if (baseUrl.includes('webserver')) { 
3944      displayPageUrl = `${baseUrl}/web/nossa-energia/w/${storyData.friendlyUrlPath}`; 
3945    } else { 
3946      displayPageUrl = `${baseUrl}/w/${storyData.friendlyUrlPath}`; 
3947
3948     
3949    const shareData = { 
3950      title: currentStory.title || 'Story', 
3951      text: currentStory.description ? currentStory.description.replace(/<[^>]*>/g, '') : '', 
3952      url: displayPageUrl 
3953    }; 
3954 
3955    if (navigator.share) { 
3956      navigator.share(shareData) 
3957        .then(() => console.log('Compartilhado com sucesso')) 
3958        .catch((error) => console.log('Erro ao compartilhar:', error)); 
3959    } else { 
3960      // Fallback para navegadores que não suportam a API de compartilhamento 
3961      alert('Compartilhar: ' + shareData.title + '\n' + shareData.text + '\n' + shareData.url); 
3962
3963
3964 
3965  // Event Listeners 
3966  prevArrow.addEventListener('click', (e) => { 
3967    e.stopPropagation(); 
3968    prevStory(); 
3969  }); 
3970 
3971  nextArrow.addEventListener('click', (e) => { 
3972    e.stopPropagation(); 
3973    nextStory(); 
3974  }); 
3975 
3976  restartIcon.addEventListener('click', (e) => { 
3977    e.stopPropagation(); 
3978    goToStory(0); 
3979  }); 
3980 
3981  pauseBtn.addEventListener('click', e => { 
3982    e.stopPropagation(); 
3983    togglePause(); 
3984  }); 
3985   
3986  shareBtn.addEventListener('click', e => { 
3987    e.stopPropagation(); 
3988    shareStory(); 
3989  }); 
3990 
3991  // Navegação por clique na tela 
3992  storiesContainer.addEventListener('click', (e) => { 
3993    const containerWidth = storiesContainer.offsetWidth; 
3994    const clickX = e.clientX - storiesContainer.getBoundingClientRect().left; 
3995 
3996    // Se clicou na metade esquerda 
3997    if (clickX < containerWidth / 2) { 
3998      prevStory(); 
3999
4000    // Se clicou na metade direita 
4001    else if (clickX > containerWidth / 2) { 
4002      nextStory(); 
4003
4004  }); 
4005 
4006  // Inicializar 
4007  createStorySlides(); 
4008
4009</#noparse> 
4010 
4011async function fetchAndLogWebStories() { 
4012  const webStoriesCarouselDataList = await getWebStoriesDataSectionFromNews( 
4013    "${newsJournalArticle.getResourcePrimKey()}" 
4014  ); 
4015 
4016  webStoriesCarouselDataList.forEach((webStoriesCarouselData) => { 
4017    const onlyOneWebstory = webStoriesCarouselData.webStoryObjects.length === 1; 
4018 
4019    if (onlyOneWebstory) { 
4020      // renderiza um único story com navegação dentro da notícia 
4021      const carouselElement = document.querySelector(`#` + webStoriesCarouselData.webStoryGroupId); 
4022      carouselElement.style.alignItems = 'center'; 
4023      <#noparse> 
4024      carouselElement.innerHTML = 
4025      ` <div class="stories-container" id="stories-container-${webStoriesCarouselData.webStoryGroupId}"> 
4026          <div class="header-container"> 
4027            <div class="story-header"> 
4028              <div class="progress-bars"></div> 
4029            </div> 
4030            <div class="action-buttons"> 
4031              <button class="action-btn pause pause-btn"></button> 
4032              <button class="action-btn share share-btn"></button> 
4033            </div> 
4034          </div> 
4035 
4036          <!-- Os stories serão inseridas aqui via JavaScript --> 
4037 
4038          <div class="nav-area-container"> 
4039            <div class="nav-area prev"> 
4040              <svg class="arrow disabled" width="32" height="32" viewBox="0 0 34 33" fill="none" 
4041                xmlns="http://www.w3.org/2000/svg"> 
4042                <g> 
4043                  <path 
4044                    d="M1 16.5C1 7.66344 8.16344 0.5 17 0.5C25.8366 0.5 33 7.66344 33 16.5C33 25.3366 25.8366 32.5 17 32.5C8.16344 32.5 1 25.3366 1 16.5Z" 
4045                    stroke="#959595" /> 
4046                  <path d="M19 21.5L14 16.5L19 11.5" stroke="#525252" stroke-width="1.5" stroke-linecap="round" 
4047                    stroke-linejoin="round" /> 
4048                </g> 
4049              </svg> 
4050            </div> 
4051            <div class="nav-area next"> 
4052              <svg class="arrow" width="32" height="32" viewBox="0 0 34 33" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4053                <path 
4054                  d="M1 16.5C1 7.66344 8.16344 0.5 17 0.5C25.8366 0.5 33 7.66344 33 16.5C33 25.3366 25.8366 32.5 17 32.5C8.16344 32.5 1 25.3366 1 16.5Z" 
4055                  stroke="#008542" /> 
4056                <path d="M15 11.5L20 16.5L15 21.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round" 
4057                  stroke-linejoin="round" /> 
4058              </svg> 
4059              <svg class="restart-icon hidden" width="32" height="32" viewBox="0 0 34 33" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4060                <path 
4061                  d="M1 16.5C1 7.66344 8.16344 0.5 17 0.5C25.8366 0.5 33 7.66344 33 16.5C33 25.3366 25.8366 32.5 17 32.5C8.16344 32.5 1 25.3366 1 16.5Z" 
4062                  stroke="#008542" /> 
4063                <path 
4064                  d="M13.9875 14.7313H10.9875M10.9875 14.7313V11.7313M10.9875 14.7313L13.1125 12.6125C13.8816 11.8429 14.8616 11.3186 15.9286 11.106C16.9956 10.8934 18.1017 11.0021 19.1069 11.4182C20.1122 11.8344 20.9714 12.5393 21.576 13.4439C22.1805 14.3485 22.5032 15.412 22.5032 16.5C22.5032 17.588 22.1805 18.6515 21.576 19.5561C20.9714 20.4607 20.1122 21.1656 19.1069 21.5818C18.1017 21.9979 16.9956 22.1066 15.9286 21.894C14.8616 21.6814 13.8816 21.1571 13.1125 20.3875" 
4065                  stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" /> 
4066              </svg> 
4067            </div> 
4068          </div> 
4069        </div> 
4070      `; 
4071      </#noparse> 
4072      const singleWebstoryData = webStoriesCarouselData.webStoryObjects[0]; 
4073      scriptForStoryInNews(singleWebstoryData, webStoriesCarouselData.webStoryGroupId); 
4074    } else { 
4075      // Carrossel 
4076      renderItems( 
4077        webStoriesCarouselData.webStoryGroupId, 
4078        webStoriesCarouselData.webStoryObjects 
4079      ); 
4080
4081  }); 
4082
4083 
4084fetchAndLogWebStories(); 
4085 
4086</script> 
4087 
4088    <script> 
4089        <#assign configureLinkTab = "configureLinkTab_" + randomNumber(5)> 
4090 
4091        function ${configureLinkTab}() { 
4092            const root = document.querySelector(".ptb-news__read-news"); 
4093            const newsContentElement = root.querySelector(".news-content div:first-child"); 
4094            const pList = newsContentElement.querySelectorAll("p"); 
4095            pList.forEach((pElement) => { 
4096                const cont = pElement.innerHTML.trim(); 
4097                if (cont == "" || cont == "&nbsp;") { 
4098                    newsContentElement?.removeChild(pElement); 
4099
4100            }); 
4101
4102 
4103        ${configureLinkTab}(); 
4104 
4105        <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Infográfico" > 
4106 
4107            function resizeMediaInfographic() { 
4108                if (window.innerWidth > 1024) { 
4109                    const contents = document.querySelectorAll(".ptb-news__read-news .news-content p"); 
4110                    contents.forEach((content) => {        
4111                        content.querySelector("img") && (content.style.gridColumn = "2 / 12"); 
4112                    }); 
4113
4114                else { 
4115                    const contents = document.querySelectorAll(".ptb-news__read-news .news-content p"); 
4116                    contents.forEach((content) => {        
4117                        content.querySelector("img") && (content.style.gridColumn = ""); 
4118                    }); 
4119 
4120                }           
4121
4122            resizeMediaInfographic(); 
4123        </#if> 
4124 
4125         
4126 
4127        document.addEventListener("DOMContentLoaded", () => { 
4128            const headers = document.querySelectorAll(".ptb-news__read-news .news-content h1, .ptb-news__read-news .news-content h2, .ptb-news__read-news .news-content h3, .ptb-news__read-news .news-content h4"); 
4129 
4130            headers.forEach((header) => { 
4131                 
4132                const currentLevel = parseInt(header.tagName.charAt(1)); 
4133 
4134                if (currentLevel >= 1 && currentLevel <= 5) { 
4135                     
4136                    const newLevel = currentLevel + 1; 
4137                    const newTagName = "h" + newLevel; 
4138 
4139                    // Criar a nova tag e transferir o conteúdo 
4140                    const newHeader = document.createElement(newTagName); 
4141                    newHeader.innerHTML = header.innerHTML; 
4142 
4143                    // Substituir a tag antiga pela nova 
4144                    header.parentNode.replaceChild(newHeader, header); 
4145
4146            }); 
4147             
4148            <#assign typeOfNews = getFirstCategoryOfVocabulary(assetEntry, typeOfNewsVocabulary) /> 
4149                 
4150            <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Infográfico" > 
4151                resizeMediaInfographic(); 
4152                window.addEventListener("resize", resizeMediaInfographic); 
4153            </#if>           
4154        }); 
4155 
4156        AUI().ready(()=>{ 
4157            const audiosContainer = document.querySelectorAll(".ptb-news__read-news .news-content .audio-content"); 
4158            const audioTemplate = document.querySelector(".ptb-news__read-news .news-content .audio-template"); 
4159 
4160            audiosContainer.forEach((audioContainer)=>{ 
4161                 
4162                const audio = audioContainer.querySelector("audio"); 
4163                const audioInterface = audioTemplate.cloneNode(true); 
4164 
4165                const sondwave = audioInterface.querySelector(".audio-sondwave"); 
4166                const linesDesktop = audioInterface.querySelectorAll(".audio-sondwave .audio-sondwave-desktop line"); 
4167                const linesMobile = audioInterface.querySelectorAll(".audio-sondwave .audio-sondwave-mobile line"); 
4168                 
4169                const playPauseButtonAudioInterface = audioInterface.querySelector(".audio-button-play"); 
4170 
4171                playPauseButtonAudioInterface.addEventListener("click", ()=>{ 
4172                    if(audioInterface.classList.contains("audio-play")) { 
4173                        audioInterface.classList.replace("audio-play", "audio-pause"); 
4174                        audio.pause(); 
4175
4176                    else { 
4177 
4178                        audiosContainer.forEach((audioContainer)=>{ 
4179                            const otherAudio = audioContainer.querySelector("audio"); 
4180                            const otherAudioInterface = audioContainer.querySelector(".audio-button-play"); 
4181                            !otherAudio.paused && otherAudioInterface.click(); 
4182                        }); 
4183 
4184                        audioInterface.classList.replace("audio-pause", "audio-play"); 
4185                        audio.play(); 
4186
4187                }); 
4188 
4189                const audioMuteButton = audioInterface.querySelector(".audio-button-mute"); 
4190 
4191                audioMuteButton.addEventListener("click", ()=>{ 
4192                    if(audioInterface.classList.contains("audio-unmuted")) { 
4193                        audioInterface.classList.replace("audio-unmuted", "audio-muted"); 
4194                        audio.muted = true; 
4195
4196                    else { 
4197                        audioInterface.classList.replace("audio-muted", "audio-unmuted"); 
4198                        audio.muted = false; 
4199
4200                }); 
4201 
4202                const audioTime = audioInterface.querySelector(".audio-time"); 
4203                audioTime.textContent = Math.floor(audio.duration / 60) + ":" + Math.floor(audio.duration % 60); 
4204 
4205 
4206                audio.addEventListener("timeupdate", ()=>{ 
4207                    let minutes = Math.floor((audio.duration - audio.currentTime) / 60);  
4208                    let seconds = Math.floor((audio.duration - audio.currentTime) % 60); 
4209 
4210                    minutes = minutes < 10? "0" + minutes : minutes; 
4211                    seconds = seconds < 10? "0" + seconds : seconds; 
4212                     
4213                    audioTime.textContent = minutes + ":" + seconds; 
4214 
4215                    const progress = (audio.currentTime / audio.duration) * 100; 
4216 
4217                    linesDesktop.forEach(function(line, index) { 
4218                        const lineProgress = (index / linesDesktop.length) * 100; 
4219                        if (progress >= lineProgress) { 
4220                            !line.classList.contains("line-active") && line.classList.add("line-active"); 
4221                        } else { 
4222                            line.classList.contains("line-active") && line.classList.remove("line-active"); 
4223
4224                    }); 
4225 
4226                    linesMobile.forEach(function(line, index) { 
4227                        const lineProgress = (index / linesMobile.length) * 100; 
4228                        if (progress >= lineProgress) { 
4229                            !line.classList.contains("line-active") && line.classList.add("line-active"); 
4230                        } else { 
4231                            line.classList.contains("line-active") && line.classList.remove("line-active"); 
4232
4233                    });                    
4234                }); 
4235 
4236                
4237                sondwave.addEventListener("click", (event)=>{                     
4238                    const distanceLeft = (event.clientX - sondwave.getBoundingClientRect().left)/sondwave.offsetWidth; 
4239                    audio.currentTime = audio.duration * distanceLeft; 
4240                }); 
4241                
4242                audioInterface.style.display = ""; 
4243                audioContainer.appendChild(audioInterface); 
4244            }); 
4245 
4246        }); 
4247    </script> 
4248</#macro> 
4249 
4250<#macro renderShareAndCopyNews> 
4251    <#--        <div class="share_news_container">--> 
4252        <div class="social-media-container"> 
4253 
4254            <#assign emailMsg = "Veja o conteúdo do post no link "> 
4255            <#if locale == "en_US"> 
4256                <#assign emailMsg = "See the content of the post in the link "> 
4257            </#if> 
4258            <a class="social-media-share" href="mailto:?subject=${newsInfo.mainHeadlineOfTheNews}&amp;body=${emailMsg}${newsInfo.url}" 
4259                target="_blank"> 
4260                <svg class="email" width="37" height="36" viewBox="0 0 37 36" fill="none" 
4261                        xmlns="http://www.w3.org/2000/svg"> 
4262                    <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/> 
4263                    <path d="M24.9231 12H11.0769C10.9239 12 10.7772 12.0579 10.669 12.1611C10.5608 12.2642 10.5 12.4041 10.5 12.55V21.9C10.5 22.1917 10.6216 22.4715 10.838 22.6778C11.0543 22.8841 11.3478 23 11.6538 23H24.3462C24.6522 23 24.9457 22.8841 25.162 22.6778C25.3784 22.4715 25.5 22.1917 25.5 21.9V12.55C25.5 12.4041 25.4392 12.2642 25.331 12.1611C25.2228 12.0579 25.0761 12 24.9231 12ZM24.3462 21.9H11.6538V13.8012L17.6106 19.0056C17.7169 19.0984 17.8559 19.1498 18 19.1498C18.1441 19.1498 18.2831 19.0984 18.3894 19.0056L24.3462 13.8012V21.9Z" 
4264                            fill="#008542"/> 
4265                </svg> 
4266                <span >send e-mail</span> 
4267            </a> 
4268 
4269            <a class="social-media-share"  href="https://www.facebook.com/sharer/sharer.php?u=${newsInfo.url}" target="_blank"> 
4270                <svg class="facebook" width="37" height="36" viewBox="0 0 37 36" fill="none" 
4271                        xmlns="http://www.w3.org/2000/svg"> 
4272                    <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/> 
4273                    <path d="M17.5417 24H20.0341V18.1855H21.9697L22.2879 15.875H20.0341V14.2754C20.0341 13.9199 20.0871 13.6406 20.2462 13.4629C20.4053 13.2598 20.75 13.1582 21.2273 13.1582H22.5V11.1016C22.0227 11.0508 21.3864 11 20.6439 11C19.6894 11 18.947 11.2793 18.3902 11.8125C17.8068 12.3457 17.5417 13.082 17.5417 14.0469V15.875H15.5V18.1855H17.5417V24Z" 
4274                            fill="#008542"/> 
4275                </svg> 
4276                    <span >Facebook</span> 
4277            </a> 
4278 
4279            <#assign mobileShareButtonId = "mobile-share-" + randomNumber(5)> 
4280            <div class="mobile-share" id="${mobileShareButtonId}"> 
4281                <svg width="37" height="36" viewBox="0 0 37 36" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4282                    <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/> 
4283                    <path d="M13.8923 20.5914C15.2136 20.5914 16.2847 19.5151 16.2847 18.1875C16.2847 16.8599 15.2136 15.7837 13.8923 15.7837C12.5711 15.7837 11.5 16.8599 11.5 18.1875C11.5 19.5151 12.5711 20.5914 13.8923 20.5914Z" 
4284                            fill="#008542" stroke="#008542" stroke-linecap="round" stroke-linejoin="round"/> 
4285                    <path d="M22.2654 26.0001C23.5866 26.0001 24.6577 24.9238 24.6577 23.5962C24.6577 22.2686 23.5866 21.1924 22.2654 21.1924C20.9441 21.1924 19.873 22.2686 19.873 23.5962C19.873 24.9238 20.9441 26.0001 22.2654 26.0001Z" 
4286                            fill="#008542" stroke="#008542" stroke-linecap="round" stroke-linejoin="round"/> 
4287                    <path d="M22.2654 15.1827C23.5866 15.1827 24.6577 14.1064 24.6577 12.7788C24.6577 11.4512 23.5866 10.375 22.2654 10.375C20.9441 10.375 19.873 11.4512 19.873 12.7788C19.873 14.1064 20.9441 15.1827 22.2654 15.1827Z" 
4288                            fill="#008542" stroke="#008542" stroke-linecap="round" stroke-linejoin="round"/> 
4289                    <path d="M20.2546 14.0784L15.9036 16.8879" stroke="#008542" stroke-linecap="round" 
4290                            stroke-linejoin="round"/> 
4291                    <path d="M15.9036 19.4871L20.2546 22.2966" stroke="#008542" stroke-linecap="round" 
4292                            stroke-linejoin="round"/> 
4293                </svg> 
4294            </div> 
4295 
4296            <a class="social-media-share"  href="https://twitter.com/intent/tweet?url=${newsInfo.url}" target="_blank" data-size="large"> 
4297                <svg class="twitter" width="37" height="36" viewBox="0 0 37 36" fill="none" 
4298                        xmlns="http://www.w3.org/2000/svg"> 
4299                    <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/> 
4300                    <path d="M22.7542 12H24.7809L20.3542 17.0933 25.5809 24H21.4742L18.2741 19.8133 14.5941 24H12.5674L17.3141 18.56 12.3008 12H16.5141L19.4208 15.84 22.7542 12ZM22.0342 22.7733H23.1542L15.9008 13.1467H14.6741L22.0342 22.7733Z" fill="#008542"/> 
4301                </svg> 
4302                        <span >twitter</span> 
4303            </a> 
4304 
4305            <a class="social-media-share"  href="https://api.whatsapp.com/send?text=${newsInfo.url}" data-action="share/whatsapp/share" 
4306                target="_blank"> 
4307                <svg class="whatsapp" width="37" height="36" viewBox="0 0 37 36" fill="none" 
4308                        xmlns="http://www.w3.org/2000/svg"> 
4309                    <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/> 
4310                    <path d="M12.5482 21.3241C11.6166 19.7525 11.2908 17.8949 11.6318 16.1C11.9729 14.3052 12.9573 12.6965 14.4003 11.5761C15.8434 10.4556 17.6457 9.90042 19.4691 10.0147C21.2925 10.129 23.0114 10.9049 24.3033 12.1967C25.5951 13.4886 26.371 15.2075 26.4853 17.0309C26.5996 18.8543 26.0444 20.6566 24.9239 22.0997C23.8035 23.5427 22.1948 24.5271 20.4 24.8682C18.6051 25.2092 16.7475 24.8834 15.1759 23.9518L12.5795 24.687C12.4731 24.7181 12.3603 24.72 12.2529 24.6925C12.1455 24.6651 12.0475 24.6092 11.9692 24.5308C11.8908 24.4525 11.8349 24.3545 11.8075 24.2471C11.78 24.1397 11.7819 24.0269 11.813 23.9205L12.5482 21.3241Z" 
4311                            fill="#008542"/> 
4312                    <path d="M20.6917 21C20.0094 21.0017 19.3335 20.8686 18.7029 20.6083C18.0722 20.348 17.4992 19.9656 17.0168 19.4832C16.5344 19.0008 16.152 18.4278 15.8917 17.7971C15.6314 17.1665 15.4983 16.4906 15.5 15.8083C15.5017 15.3281 15.6937 14.8682 16.0338 14.5293C16.374 14.1903 16.8346 14 17.3148 14C17.394 13.9994 17.472 14.0201 17.5404 14.06C17.6089 14.1 17.6653 14.1576 17.7037 14.2269L18.462 15.5491C18.5071 15.6295 18.5303 15.7203 18.5291 15.8124C18.528 15.9046 18.5026 15.9948 18.4556 16.0741L17.8463 17.0917C18.1584 17.7859 18.7141 18.3416 19.4083 18.6537L20.4259 18.0444C20.5052 17.9974 20.5954 17.972 20.6876 17.9709C20.7797 17.9697 20.8705 17.9929 20.9509 18.038L22.2731 18.7963C22.3424 18.8347 22.4 18.8911 22.44 18.9596C22.4799 19.028 22.5006 19.106 22.5 19.1852C22.4983 19.6649 22.3074 20.1245 21.9689 20.4643C21.6303 20.8041 21.1713 20.9966 20.6917 21Z" 
4313                            fill="white"/> 
4314                </svg> 
4315                <span >Share to WhatsApp </span> 
4316            </a> 
4317 
4318            <div class="copy-text-container"> 
4319                <svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4320                    <path d="M10.5 10.5H13.5V2.5H5.5V5.5" stroke="#008542" stroke-linecap="round" 
4321                            stroke-linejoin="round"/> 
4322                    <path d="M10.5 5.5H2.5V13.5H10.5V5.5Z" stroke="#008542" stroke-linecap="round" 
4323                            stroke-linejoin="round"/> 
4324                </svg> 
4325 
4326                <#if locale == "pt_BR"> 
4327                    <p class="text">Copiar texto <span class="copy-text-title-news"> ${newsInfo.mainHeadlineOfTheNews} </span> </p> 
4328                <#else > 
4329                    <p class="text">Copy text <span class="copy-text-title-news"> ${newsInfo.mainHeadlineOfTheNews} </span> </p> 
4330                </#if> 
4331            </div> 
4332 
4333        </div> 
4334 
4335        <#if locale == "pt_BR"> 
4336            <span class="copy-message">Texto copiado!</span> 
4337        <#else > 
4338            <span class="copy-message">Text copied!</span> 
4339        </#if> 
4340    <#--        </div>--> 
4341</#macro> 
4342 
4343<#-- ################################################################################################################## --> 
4344 
4345<#-- ############# Site de Crise - Notícia - Links do conteúdo da notícia ############################################# --> 
4346<#macro renderLinks newsInfo> 
4347    <#if newsInfo.links?size != 0> 
4348    <#--videos "escondidos" que serão unidos a .ptb-news__read-content --> 
4349 
4350        <div class="ptb-news__links-container d-none "> 
4351            <div id="ptb-news__links-identifiers"> 
4352                <#assign separator = ""> 
4353                <#list newsInfo.links as link> 
4354                    ${link.id}; 
4355                    <#assign separator = ";"> 
4356                </#list> 
4357            </div> 
4358            <#list newsInfo.links as link> 
4359                <#assign link_index = link?index> 
4360                <#assign linkUrl = "#"> 
4361                <#assign target = "_blank"> 
4362                <#assign linkClass = ""> 
4363 
4364                <div id="ptb-news__link-container-${link_index}"> 
4365                    <#if link.externalLink?has_content> 
4366                        <#assign linkUrl = link.externalLink> 
4367                        <#assign target = "_blank"> 
4368                        <#assign linkClass = "external-link"> 
4369                    <#elseif link.pageLink?has_content> 
4370                        <#assign linkUrl = link.pageLink> 
4371                        <#assign target = "_self"> 
4372                        <#assign linkClass = "internal-page-link"> 
4373                    <#elseif link.file.mimeType?has_content> 
4374                        <#assign linkUrl = link.file.url> 
4375                        <#assign target = "_blank"> 
4376                        <#assign linkClass = "file-link"> 
4377                    </#if> 
4378 
4379                    <#-- PDF icon --> 
4380                    <#if link.iconType == "Opção78730408" > 
4381                        <svg width="24" height="24" viewBox="0 0 24 24" fill="none" 
4382                             xmlns="http://www.w3.org/2000/svg"> 
4383                            <path d="M3.752 15.974H4.664C4.912 15.974 5.124 15.954 5.3 15.914C5.476 15.874 5.62 15.806 5.732 15.71C5.852 15.606 5.94 15.466 5.996 15.29C6.052 15.114 6.08 14.894 6.08 14.63C6.08 14.11 5.968 13.758 5.744 13.574C5.528 13.39 5.168 13.298 4.664 13.298H3.752V15.974ZM2 20.654V11.894H4.784C5.856 11.894 6.632 12.122 7.112 12.578C7.6 13.026 7.844 13.698 7.844 14.594C7.844 15.474 7.604 16.158 7.124 16.646C6.652 17.134 5.872 17.378 4.784 17.378H3.752V20.654H2Z" 
4384                                  fill="#008542"/> 
4385                            <path d="M10.8402 19.142H11.9442C12.2962 19.142 12.6042 19.102 12.8682 19.022C13.1322 18.942 13.3482 18.798 13.5162 18.59C13.6922 18.374 13.8242 18.082 13.9122 17.714C14.0002 17.338 14.0442 16.854 14.0442 16.262C14.0442 15.678 14.0002 15.202 13.9122 14.834C13.8322 14.458 13.7042 14.166 13.5282 13.958C13.3602 13.75 13.1442 13.606 12.8802 13.526C12.6242 13.446 12.3202 13.406 11.9682 13.406H10.8402V19.142ZM9.16016 20.654V11.894H12.1002C12.7642 11.894 13.3322 11.982 13.8042 12.158C14.2762 12.326 14.6602 12.59 14.9562 12.95C15.2602 13.302 15.4802 13.75 15.6162 14.294C15.7602 14.83 15.8322 15.47 15.8322 16.214C15.8322 17.726 15.5362 18.846 14.9442 19.574C14.3522 20.294 13.3882 20.654 12.0522 20.654H9.16016Z" 
4386                                  fill="#008542"/> 
4387                            <path d="M17.2695 20.654V11.894H22.2735V13.358H18.9735V15.59H21.9015V17.054H18.9735V20.654H17.2695Z" 
4388                                  fill="#008542"/> 
4389                            <path d="M6.08984 8.24516V1.60376C6.08984 1.44364 6.15211 1.29007 6.26294 1.17684C6.37377 1.06361 6.52408 1 6.68082 1H13.7725M13.7725 1L17.9094 5.22634M13.7725 1L13.7725 5.22634H17.9094M17.9094 5.22634V8.24516" 
4390                                  stroke="#008542" stroke-width="1.5" stroke-linecap="round" 
4391                                  stroke-linejoin="round"/> 
4392                        </svg> 
4393 
4394                    <#-- JPG icon --> 
4395                    <#elseif link.iconType == "Opção89889679" > 
4396                        <svg width="24" height="24" viewBox="0 0 24 24" fill="none" 
4397                             xmlns="http://www.w3.org/2000/svg"> 
4398                            <path d="M2 19.1657C2.248 19.1977 2.504 19.2257 2.768 19.2497C3.032 19.2657 3.284 19.2737 3.524 19.2737C3.844 19.2737 4.112 19.2497 4.328 19.2017C4.544 19.1537 4.72 19.0657 4.856 18.9377C4.992 18.8017 5.088 18.6257 5.144 18.4097C5.208 18.1857 5.24 17.8977 5.24 17.5457V11.8937H6.992V17.5457C6.992 18.6817 6.756 19.5057 6.284 20.0177C5.82 20.5297 5.128 20.7857 4.208 20.7857C3.984 20.7857 3.764 20.7737 3.548 20.7497C3.34 20.7257 3.14 20.6937 2.948 20.6537C2.756 20.6137 2.58 20.5697 2.42 20.5217C2.26 20.4737 2.12 20.4257 2 20.3777V19.1657Z" 
4399                                  fill="#008542"/> 
4400                            <path d="M10.4203 15.9737H11.3323C11.5803 15.9737 11.7923 15.9537 11.9683 15.9137C12.1443 15.8737 12.2883 15.8057 12.4003 15.7097C12.5203 15.6057 12.6083 15.4657 12.6643 15.2897C12.7203 15.1137 12.7483 14.8937 12.7483 14.6297C12.7483 14.1097 12.6363 13.7577 12.4123 13.5737C12.1963 13.3897 11.8363 13.2977 11.3323 13.2977H10.4203V15.9737ZM8.66834 20.6537V11.8937H11.4523C12.5243 11.8937 13.3003 12.1217 13.7803 12.5777C14.2683 13.0257 14.5123 13.6977 14.5123 14.5937C14.5123 15.4737 14.2723 16.1577 13.7923 16.6457C13.3203 17.1337 12.5403 17.3777 11.4523 17.3777H10.4203V20.6537H8.66834Z" 
4401                                  fill="#008542"/> 
4402                            <path d="M22.0085 20.2697C21.6405 20.4057 21.2085 20.5257 20.7125 20.6297C20.2245 20.7337 19.7165 20.7857 19.1885 20.7857C18.5005 20.7857 17.9245 20.6897 17.4605 20.4977C17.0045 20.2977 16.6365 20.0097 16.3565 19.6337C16.0845 19.2577 15.8885 18.7977 15.7685 18.2537C15.6485 17.7017 15.5885 17.0777 15.5885 16.3817C15.5885 15.6217 15.6565 14.9537 15.7925 14.3777C15.9285 13.8017 16.1445 13.3217 16.4405 12.9377C16.7365 12.5457 17.1205 12.2537 17.5925 12.0617C18.0645 11.8617 18.6405 11.7617 19.3205 11.7617C19.7845 11.7617 20.2125 11.8017 20.6045 11.8817C21.0045 11.9617 21.3605 12.0577 21.6725 12.1697V13.3937C21.5525 13.3857 21.4125 13.3737 21.2525 13.3577C21.0925 13.3337 20.9205 13.3137 20.7365 13.2977C20.5605 13.2817 20.3765 13.2697 20.1845 13.2617C20.0005 13.2457 19.8205 13.2377 19.6445 13.2377C19.2205 13.2377 18.8605 13.2857 18.5645 13.3817C18.2765 13.4697 18.0405 13.6297 17.8565 13.8617C17.6805 14.0857 17.5485 14.3937 17.4605 14.7857C17.3805 15.1777 17.3405 15.6737 17.3405 16.2737C17.3405 16.8417 17.3765 17.3217 17.4485 17.7137C17.5285 18.0977 17.6485 18.4097 17.8085 18.6497C17.9685 18.8897 18.1765 19.0617 18.4325 19.1657C18.6965 19.2697 19.0125 19.3217 19.3805 19.3217C19.6765 19.3217 20.0245 19.2857 20.4245 19.2137V17.1977H19.1045V15.8897H22.0085V20.2697Z" 
4403                                  fill="#008542"/> 
4404                            <path d="M6.08984 8.24516V1.60376C6.08984 1.44364 6.15211 1.29007 6.26294 1.17684C6.37377 1.06361 6.52408 1 6.68082 1H13.7725M13.7725 1L17.9094 5.22634M13.7725 1L13.7725 5.22634H17.9094M17.9094 5.22634V8.24516" 
4405                                  stroke="#008542" stroke-width="1.5" stroke-linecap="round" 
4406                                  stroke-linejoin="round"/> 
4407                        </svg> 
4408                    <#-- DOC icon --> 
4409                    <#elseif link.iconType == "Opção15480314" > 
4410                        <svg width="24" height="24" viewBox="0 0 24 24" fill="none" 
4411                             xmlns="http://www.w3.org/2000/svg"> 
4412                            <path d="M2.68 19.1417H3.784C4.136 19.1417 4.444 19.1017 4.708 19.0217C4.972 18.9417 5.188 18.7977 5.356 18.5897C5.532 18.3737 5.664 18.0817 5.752 17.7137C5.84 17.3377 5.884 16.8537 5.884 16.2617C5.884 15.6777 5.84 15.2017 5.752 14.8337C5.672 14.4577 5.544 14.1657 5.368 13.9577C5.2 13.7497 4.984 13.6057 4.72 13.5257C4.464 13.4457 4.16 13.4057 3.808 13.4057H2.68V19.1417ZM1 20.6537V11.8937H3.94C4.604 11.8937 5.172 11.9817 5.644 12.1577C6.116 12.3257 6.5 12.5897 6.796 12.9497C7.1 13.3017 7.32 13.7497 7.456 14.2937C7.6 14.8297 7.672 15.4697 7.672 16.2137C7.672 17.7257 7.376 18.8457 6.784 19.5737C6.192 20.2937 5.228 20.6537 3.892 20.6537H1Z" 
4413                                  fill="#008542"/> 
4414                            <path d="M10.7894 20.4977C10.3334 20.3057 9.96138 20.0217 9.67338 19.6457C9.39338 19.2697 9.18937 18.8057 9.06137 18.2537C8.93337 17.6937 8.86938 17.0457 8.86938 16.3097C8.86938 15.5657 8.93337 14.9097 9.06137 14.3417C9.19737 13.7737 9.40938 13.2977 9.69738 12.9137C9.99338 12.5297 10.3694 12.2417 10.8254 12.0497C11.2894 11.8577 11.8494 11.7617 12.5054 11.7617C13.1694 11.7617 13.7294 11.8577 14.1854 12.0497C14.6414 12.2417 15.0094 12.5257 15.2894 12.9017C15.5774 13.2777 15.7854 13.7457 15.9134 14.3057C16.0414 14.8577 16.1054 15.5017 16.1054 16.2377C16.1054 16.9817 16.0374 17.6377 15.9014 18.2057C15.7734 18.7737 15.5614 19.2497 15.2654 19.6337C14.9774 20.0177 14.6014 20.3057 14.1374 20.4977C13.6814 20.6897 13.1254 20.7857 12.4694 20.7857C11.8054 20.7857 11.2454 20.6897 10.7894 20.4977ZM11.0894 18.6737C11.2414 18.9057 11.4334 19.0737 11.6654 19.1777C11.8974 19.2737 12.1694 19.3217 12.4814 19.3217C12.7934 19.3217 13.0654 19.2737 13.2974 19.1777C13.5294 19.0737 13.7214 18.9057 13.8734 18.6737C14.0254 18.4337 14.1374 18.1217 14.2094 17.7377C14.2814 17.3457 14.3174 16.8577 14.3174 16.2737C14.3174 15.6897 14.2814 15.2057 14.2094 14.8217C14.1374 14.4297 14.0254 14.1177 13.8734 13.8857C13.7294 13.6457 13.5414 13.4777 13.3094 13.3817C13.0774 13.2777 12.8054 13.2257 12.4934 13.2257C12.1814 13.2257 11.9094 13.2777 11.6774 13.3817C11.4454 13.4777 11.2534 13.6457 11.1014 13.8857C10.9494 14.1177 10.8374 14.4297 10.7654 14.8217C10.6934 15.2057 10.6574 15.6897 10.6574 16.2737C10.6574 16.8577 10.6934 17.3457 10.7654 17.7377C10.8374 18.1217 10.9454 18.4337 11.0894 18.6737Z" 
4415                                  fill="#008542"/> 
4416                            <path d="M23.1389 20.3897C22.8349 20.5017 22.4989 20.5937 22.1309 20.6657C21.7709 20.7457 21.3629 20.7857 20.9069 20.7857C20.2189 20.7857 19.6429 20.6897 19.1789 20.4977C18.7229 20.3057 18.3549 20.0257 18.0749 19.6577C17.7949 19.2817 17.5949 18.8177 17.4749 18.2657C17.3629 17.7137 17.3069 17.0777 17.3069 16.3577C17.3069 15.5977 17.3709 14.9297 17.4989 14.3537C17.6269 13.7777 17.8309 13.2977 18.1109 12.9137C18.3909 12.5297 18.7589 12.2417 19.2149 12.0497C19.6709 11.8577 20.2229 11.7617 20.8709 11.7617C21.3029 11.7617 21.6989 11.8017 22.0589 11.8817C22.4269 11.9537 22.7629 12.0457 23.0669 12.1577V13.3817C22.8029 13.3497 22.4949 13.3177 22.1429 13.2857C21.7989 13.2537 21.4829 13.2377 21.1949 13.2377C20.8029 13.2377 20.4709 13.2857 20.1989 13.3817C19.9349 13.4697 19.7189 13.6297 19.5509 13.8617C19.3829 14.0857 19.2629 14.3937 19.1909 14.7857C19.1189 15.1697 19.0829 15.6617 19.0829 16.2617C19.0829 16.8617 19.1189 17.3617 19.1909 17.7617C19.2709 18.1537 19.3949 18.4657 19.5629 18.6977C19.7389 18.9217 19.9669 19.0817 20.2469 19.1777C20.5269 19.2657 20.8709 19.3097 21.2789 19.3097C21.5989 19.3097 21.9309 19.2937 22.2749 19.2617C22.6189 19.2217 22.9069 19.1897 23.1389 19.1657V20.3897Z" 
4417                                  fill="#008542"/> 
4418                            <path d="M6.08984 8.24516V1.60376C6.08984 1.44364 6.15211 1.29007 6.26294 1.17684C6.37377 1.06361 6.52408 1 6.68082 1H13.7725M13.7725 1L17.9094 5.22634M13.7725 1L13.7725 5.22634H17.9094M17.9094 5.22634V8.24516" 
4419                                  stroke="#008542" stroke-width="1.5" stroke-linecap="round" 
4420                                  stroke-linejoin="round"/> 
4421                        </svg> 
4422                    <#-- External link icon --> 
4423                    <#elseif link.iconType == "Opção43823553" > 
4424                        <svg width="24" height="24" viewBox="0 0 32 32" fill="none" 
4425                             xmlns="http://www.w3.org/2000/svg"> 
4426                            <path opacity="0.98" 
4427                                  d="M25.5 15.5001V26.5001C25.5 26.7653 25.3946 27.0197 25.2071 27.2072C25.0196 27.3947 24.7652 27.5001 24.5 27.5001L5.5 27.5001C5.23479 27.5001 4.98043 27.3947 4.79289 27.2072C4.60536 27.0197 4.5 26.7653 4.5 26.5001L4.5 7.50009C4.5 7.23488 4.60536 6.98052 4.79289 6.79299C4.98043 6.60545 5.23478 6.50009 5.5 6.50009L17 6.50009M20.4742 4.7124H27.8988M27.8988 4.7124V12.137M27.8988 4.7124L14.5 18.0001" 
4428                                  stroke="#008542" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/> 
4429                        </svg> 
4430                    <#-- Internal page link icon --> 
4431                    <#elseif link.iconType == "Opção64212757" > 
4432                    <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="#008542" viewBox="0 0 256 256"> 
4433                        <path d="M137.54,186.36a8,8,0,0,1,0,11.31l-9.94,10A56,56,0,0,1,48.38,128.4L72.5,104.28A56,56,0,0,1,149.31,102a8,8,0,1,1-10.64,12,40,40,0,0,0-54.85,1.63L59.7,139.72a40,40,0,0,0,56.58,56.58l9.94-9.94A8,8,0,0,1,137.54,186.36Zm70.08-138a56.08,56.08,0,0,0-79.22,0l-9.94,9.95a8,8,0,0,0,11.32,11.31l9.94-9.94a40,40,0,0,1,56.58,56.58L172.18,140.4A40,40,0,0,1,117.33,142,8,8,0,1,0,106.69,154a56,56,0,0,0,76.81-2.26l24.12-24.12A56.08,56.08,0,0,0,207.62,48.38Z"> 
4434                        </path> 
4435                    </svg> 
4436                    <#-- Download link icon --> 
4437                    <#elseif link.iconType == "Opção20766606" > 
4438                        <svg width="24" height="24" viewBox="0 0 32 32" fill="none" 
4439                             xmlns="http://www.w3.org/2000/svg"> 
4440                            <path d="M10.75 13.75L16 19M16 19L21.25 13.75M16 19V5M27 19V26C27 26.2652 26.8946 26.5196 26.7071 26.7071C26.5196 26.8946 26.2652 27 26 27H6C5.73478 27 5.48043 26.8946 5.29289 26.7071C5.10536 26.5196 5 26.2652 5 26V19" 
4441                                  stroke="#008542" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/> 
4442                        </svg> 
4443                    </#if> 
4444<#if link.title?? && link.title?has_content> 
4445                    <a href="${linkUrl}" class="link ${linkClass}" target="${target}">${link.title}</a> 
4446	</#if> 
4447                </div> 
4448            </#list> 
4449        </div> 
4450 
4451        <script> 
4452            var newsContent_code = document.querySelector(".news-content").innerHTML; 
4453 
4454            var linksIdentifiers = document.querySelector("#ptb-news__links-identifiers").innerHTML.trim().split(";"); 
4455            linksIdentifiers.forEach((linkIdentifier, index) => { 
4456                const linkIdentifierContent = document.querySelector("#ptb-news__link-container-" + index); 
4457                if (linkIdentifierContent) { 
4458                    const tag = "#[" + linkIdentifier.trim() + "]"; 
4459                    const splitContent = newsContent_code.split(tag); 
4460                    newsContent_code = splitContent.join(linkIdentifierContent.innerHTML); 
4461                    //linkIdentifierContent.parentNode.removeChild(linkIdentifierContent); 
4462
4463            }); 
4464 
4465 
4466            var ptb_news__read_content = document.querySelector(".news-content"); 
4467            ptb_news__read_content.innerHTML = newsContent_code; 
4468             
4469            const links_ptb_news = document.querySelectorAll(".news-content a"); 
4470            links_ptb_news.forEach((link) => { 
4471                link.classList.add("link-ptb-news"); 
4472            }); 
4473 
4474        </script> 
4475 
4476        <style> 
4477            .ptb-news__read-news .ptb-news__link a { 
4478                font-family: var(--font-family-base); 
4479                font-style: var(--font-style-normal, normal); 
4480                font-weight: var(--font-weight-bold, 700); 
4481                font-size: var(--font-size-xxs, 16px); 
4482                line-height: var(--line-height-xl, 160%); 
4483                text-decoration-line: var(--text-decoration-underline, underline); 
4484                color: #008542; 
4485
4486 
4487            body.high-contrast-active .ptb-news__read-news .ptb-news__link a { 
4488                color: #E4F7E8; 
4489            }           
4490 
4491            .ptb-news__read-news .news-content .link { 
4492                font-family: var(--font-family-base); 
4493                font-style: var(--font-style-normal, normal); 
4494                font-weight: var(--font-weight-bold, 700); 
4495                font-size: var(--font-size-xs, 18px); 
4496                line-height: var(--line-height-xl, 160%); 
4497 
4498                text-decoration-line: var(--text-decoration-underline, underline); 
4499                color: #008542; 
4500
4501 
4502            body.high-contrast-active .ptb-news__read-news .news-content .link { 
4503                color: #E4F7E8; 
4504
4505 
4506            body.high-contrast-active .ptb-news__read-news .news-content svg path { 
4507                stroke: var(--color-neutral-500, #D7D7D7); 
4508                fill: rgba(255, 255, 255, 0.32); 
4509
4510 
4511            .ptb-news__read-news .news-content .ptb-link__wrapper { 
4512                display: flex; 
4513                flex-direction: column; 
4514                gap: 0; 
4515                margin-top: -24px; 
4516
4517 
4518            .ptb-news__read-news .news-content .ptb-link__wrapper svg { 
4519                margin-right: var(--space-sm, 16px); 
4520
4521 
4522            .ptb-news__read-news .news-content .ptb-link__wrapper .first { 
4523                gap: 0 !important; 
4524
4525 
4526            @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
4527                .ptb-news__read-news .news-content .link { 
4528                    font-size: var(--font-size-xxs, 16px); 
4529
4530
4531        </style> 
4532    </#if> 
4533</#macro> 
4534 
4535<#-- ################################################################################################################## --> 
4536 
4537<#-- ################################################################################################################## --> 
4538 
4539<#-- ############# Site de Crise - Notícia - Links do conteúdo da notícia ############################################# --> 
4540<#macro renderCite> 
4541    <div class="ptb-news__cite-container"> 
4542        <div class="ptb-news__cite-container-breakpoint breakpoint"> 
4543            <div class="ptb-news__cite-container-col col-1-12 md-col-1-8 sm-col-1-4"> 
4544                <div class="ptb-news__cite-title"> 
4545                    <#if locale?lower_case == "pt_br"> 
4546                        Notas 
4547                    <#else> 
4548                        Notes 
4549                    </#if> 
4550                </div> 
4551 
4552                <div class="ptb-news__cites-elements"> 
4553                </div> 
4554            </div> 
4555        </div> 
4556    </div> 
4557 
4558    <script> 
4559        function positionCitesText(parentNodeCitesText) { 
4560             
4561            parentNodeCitesText.forEach((parentNodeCiteText)=>{ 
4562                if(window.innerWidth > 1024) { 
4563                    parentNodeCiteText.style.display=""; 
4564                    parentNodeCiteText.style.gridColumnStart = "11"; 
4565                    parentNodeCiteText.style.gridColumnEnd = "13"; 
4566                }  
4567                else { 
4568                    parentNodeCiteText.style.display="none"; 
4569                    parentNodeCiteText.style.gridColumnStart = ""; 
4570                    parentNodeCiteText.style.gridColumnEnd = "";                  
4571
4572            }); 
4573
4574 
4575        function addCitesTextMobile(citesText) { 
4576            const citesContainer = document.querySelector(".ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cites-elements"); 
4577 
4578            if(citesContainer.children.length === 0) { 
4579                citesContainer && citesText.forEach((citeText)=>{                         
4580                    citesContainer.appendChild(citeText.cloneNode(true)); 
4581                }); 
4582            }         
4583
4584 
4585        const citesText = document.querySelectorAll(".news-content cite"); 
4586         
4587        if (citesText.length > 0) { 
4588            const parentNodeCitesText = [...citesText].map((citeText)=>citeText.parentNode); 
4589            positionCitesText(parentNodeCitesText); 
4590            addCitesTextMobile(citesText);     
4591
4592        else { 
4593            const citesContainer = document.querySelector(".ptb-news__cite-container"); 
4594            citesContainer && (citesContainer.style.display="none"); 
4595
4596         
4597        document.addEventListener('DOMContentLoaded', ()=>{ 
4598             
4599            const citesText = document.querySelectorAll(".news-content cite"); 
4600             
4601            if (citesText.length > 0) { 
4602                const parentNodeCitesText = [...citesText].map((citeText)=>citeText.parentNode);            
4603 
4604                positionCitesText(parentNodeCitesText); 
4605                addCitesTextMobile(citesText); 
4606 
4607                window.addEventListener('resize', ()=>{positionCitesText(parentNodeCitesText)}); 
4608
4609            else { 
4610                const citesContainer = document.querySelector(".ptb-news__cite-container"); 
4611                citesContainer && (citesContainer.style.display="none"); 
4612
4613        }); 
4614 
4615    </script> 
4616 
4617    <style> 
4618     
4619        .ptb-news__read-news-post cite { 
4620            color: var(--color-neutral-800, #373737); 
4621            font-family: var(--font-family-base); 
4622            font-size: var(--font-size-xxxs, 14px) !important; 
4623            font-style: var(--font-style-normal, normal); 
4624            font-weight: var(--font-weight-regular, 400); 
4625            line-height: var(--line-height-xl, 160%); 
4626
4627 
4628        .ptb-news__read-news-post cite  a{ 
4629            font-size: var(--font-size-xxxs, 14px) !important; 
4630
4631 
4632        body.high-contrast-active .ptb-news__read-news-post cite { 
4633        color: var(--text-primary-default, var(--color-neutral-100)); 
4634        }  
4635 
4636        .ptb-news__read-news-post .news-content cite, 
4637        .ptb-news__read-news-post .ptb-news__cite-container cite { 
4638            display: block; 
4639            padding-left: var(--space-md); 
4640            border-left: var(--border-width-hairline, 1px) solid var(--color-neutral-500, #D7D7D7); 
4641
4642 
4643        @media screen and (min-width: 1025px) { 
4644            .ptb-news__read-news-post .ptb-news__cite-container { 
4645                display: none;                
4646            }         
4647
4648 
4649        @media screen and (max-width: 1025px) { 
4650            .ptb-news__read-news .ptb-news__cite-container .link { 
4651                text-decoration-line: var(--text-decoration-underline, underline); 
4652                color: #008542; 
4653
4654 
4655            body.high-contrast-active .ptb-news__read-news .ptb-news__cite-container .link { 
4656                color: #E4F7E8; 
4657
4658 
4659            body.high-contrast-active .ptb-news__read-news .ptb-news__cite-container svg path { 
4660                stroke: var(--color-neutral-500, #D7D7D7); 
4661                fill: rgba(255, 255, 255, 0.32); 
4662
4663             
4664            .ptb-news__read-news-post .ptb-news__cite-container { 
4665                display: grid; 
4666                background: var(--background-surface-level-03, #EEE); 
4667
4668 
4669            body.high-contrast-active .ptb-news__read-news-post .ptb-news__cite-container { 
4670                background: var(--background-surface-level-03, #525252); 
4671
4672 
4673            .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col { 
4674                padding: var(--space-xxl) 0; 
4675                display: flex; 
4676                flex-direction: column; 
4677                gap: var(--space-lg, 32px); 
4678
4679 
4680            .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cites-elements { 
4681                display: flex; 
4682                flex-direction: column; 
4683                gap: var(--space-lg, 32px);  
4684            }       
4685 
4686            .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cite-title { 
4687                color: var(--color-neutral-800, #373737); 
4688                font-size: var(--font-size-sm, 20px); 
4689                font-style: var(--font-style-normal, normal); 
4690                font-weight: var(--font-weight-bold, 700); 
4691                line-height: var(--line-height-xl, 160%); 
4692
4693 
4694            body.high-contrast-active .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cite-title { 
4695                color: var(--text-primary-default, var(--color-neutral-100)); 
4696
4697        }         
4698    </style> 
4699     
4700</#macro> 
4701 
4702<#-- ################################################################################################################## --> 
4703 
4704 
4705<#-- ############# Site de Crise - Notícia - Galeria de imagens ####################################################### --> 
4706<#macro renderGallery newsInfo> 
4707    <#if newsInfo.galleryItems?size == 0> 
4708        <#return /> 
4709    </#if> 
4710 
4711    <div class="gallery-breakpoint breakpoint"> 
4712        <div class="gallery col-3-11 md-col-1-8 sm-col-1-4"> 
4713 
4714            <div class="title-container"> 
4715                <svg class="icon" viewBox="0 0 26 23" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4716                    <path d="M23 22H3C2.46957 22 1.96086 21.7893 1.58579 21.4142C1.21071 21.0391 1 20.5304 1 20V6C1 5.46957 1.21071 4.96086 1.58579 4.58579C1.96086 4.21071 2.46957 4 3 4H7L9 1H17L19 4H23C23.5304 4 24.0391 4.21071 24.4142 4.58579C24.7893 4.96086 25 5.46957 25 6V20C25 20.5304 24.7893 21.0391 24.4142 21.4142C24.0391 21.7893 23.5304 22 23 22Z" 
4717                            stroke="#525252" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/> 
4718                    <path d="M13 17C15.4853 17 17.5 14.9853 17.5 12.5C17.5 10.0147 15.4853 8 13 8C10.5147 8 8.5 10.0147 8.5 12.5C8.5 14.9853 10.5147 17 13 17Z" 
4719                            stroke="#525252" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/> 
4720                </svg> 
4721                <p class="title"> 
4722                    <#if locale == "pt_BR"> Galeria de Imagens <#else > Image gallery </#if> 
4723                </p> 
4724            </div> 
4725 
4726            <div class="image-container"> 
4727				<#assign index = 0 /> 
4728				<#assign index = 0 /> 
4729                <#list newsInfo.galleryItems as gItem> 
4730                    <div class="modal-image-fragment" index="${index}"> 
4731                        <div class="modal-image-container" index="${index}"> 
4732                            <span class="click-image" ></span> 
4733 
4734                            <div class="image-player-container"> 
4735                                <span class="close-image"> 
4736                                    <svg width="44" height="44" viewBox="0 0 44 44" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4737                                        <path d="M22 -9.61651e-07C34.1503 -4.30546e-07 44 9.84974 44 22C44 34.1503 34.1503 44 22 44C9.84973 44 -1.49276e-06 34.1503 -9.61651e-07 22C-4.30546e-07 9.84973 9.84974 -1.49276e-06 22 -9.61651e-07Z" fill="white"/> 
4738                                        <path d="M26.5 26.5L17.5 17.5M17.5 26.5L26.5 17.5" stroke="#008542" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/> 
4739                                    </svg> 
4740                                </span> 
4741                                <div class="image-player-session"> 
4742                                    <#-- Midias adaptativas de imagem para desktop e mobile --> 
4743                                    <#assign fileDataRequest = restClient.get("/headless-delivery/v1.0/documents/${gItem.image.fileEntryId}") /> 
4744                                    <#assign urlAdaptativeMediaMobile = gItem.image.url/> 
4745                                    <#assign urlAdaptativeMediaDesktop = gItem.image.url/> 
4746                                     
4747                                    <#if fileDataRequest?? && fileDataRequest.adaptedImages?? > 
4748                                        <#assign dataAdaptativeMedia = fileDataRequest.adaptedImages /> 
4749                                        <#list dataAdaptativeMedia as data> 
4750                                            <#if data.resolutionName == adaptativeMediaDesktopResolutionName> 
4751                                                <#assign urlAdaptativeMediaDesktop = data.contentUrl/> 
4752                                            </#if> 
4753                                            <#if data.resolutionName == adaptativeMediaMobileResolutionName> 
4754                                                <#assign urlAdaptativeMediaMobile = data.contentUrl/> 
4755                                            </#if>      
4756                                        </#list> 
4757                                    </#if> 
4758																																				 
4759                                    <picture> 
4760                                        <source media="(max-width:767px)" srcset="${urlAdaptativeMediaMobile}"  > 
4761                                        <img width="274px" height="152px" loading="lazy" src="${urlAdaptativeMediaDesktop}" alt="${gItem.image.alt}"/> 
4762                                    </picture>		   
4763                                </div> 
4764                            </div> 
4765                        </div> 
4766                    </div> 
4767                    <#assign index = index + 1 /> 
4768                    <#assign index = index + 1 /> 
4769                </#list> 
4770                <div class="control-arrow left-arrow"> 
4771                    <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4772                        <path d="M20 26L10 16L20 6" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
4773                    </svg> 
4774                </div> 
4775                <div class="control-arrow right-arrow"> 
4776                    <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4777                        <path d="M12 6L22 16L12 26" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
4778                    </svg> 
4779                </div> 
4780                <div class="image-bullets"> 
4781                    <#list 0..(newsInfo.galleryItems?size-1) as index> 
4782                        <div index="${index}" class="bullet"></div> 
4783                    </#list> 
4784                </div> 
4785            </div> 
4786                <div class="control-arrow left-arrow"> 
4787                    <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4788                        <path d="M20 26L10 16L20 6" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
4789                    </svg> 
4790                </div> 
4791                <div class="control-arrow right-arrow"> 
4792                    <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"> 
4793                        <path d="M12 6L22 16L12 26" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
4794                    </svg> 
4795                </div> 
4796                <div class="image-bullets"> 
4797                    <#list 0..(newsInfo.galleryItems?size-1) as index> 
4798                        <div index="${index}" class="bullet"></div> 
4799                    </#list> 
4800                </div> 
4801            </div> 
4802        </div> 
4803    </div> 
4804 
4805    <style> 
4806 
4807        .ptb-news__read-news .gallery { 
4808            padding-top: 42px; 
4809
4810 
4811        .ptb-news__read-news .gallery * { 
4812            margin: 0; 
4813            padding: 0; 
4814
4815 
4816        .ptb-news__read-news .gallery { 
4817            display: flex; 
4818            gap: var(--space-xl, 40px); 
4819            flex-direction: column; 
4820
4821			 
4822        .ptb-news__read-news .gallery .control-arrow { 
4823            position: fixed; 
4824            height: 100%; 
4825            align-items: center; 
4826            display: flex; 
4827            justify-content: center; 
4828            display: none; 
4829            z-index: 9999; 
4830
4831 
4832        .ptb-news__read-news .gallery .control-arrow svg { 
4833          cursor: pointer; 
4834
4835 
4836        .ptb-news__read-news .gallery .left-arrow { 
4837            top: 0; 
4838            left: 5vw; 
4839
4840 
4841        .ptb-news__read-news .gallery .right-arrow { 
4842            top: 0; 
4843            right: 5vw; 
4844
4845 
4846        .ptb-news__read-news .gallery .lefg-arrow svg { 
4847          margin-left: 16px !important; 
4848
4849 
4850        .ptb-news__read-news .gallery .right-arrow svg { 
4851          margin-right: 16px !important; 
4852
4853 
4854        .ptb-news__read-news .gallery .image-bullets { 
4855          display: none; 
4856          gap: var(--space-sm, 16px); 
4857          position: fixed; 
4858          left: 0; 
4859          bottom: calc(10vh + 24px); 
4860          width: 100vw; 
4861          z-index: 9999; 
4862          justify-content: center; 
4863
4864 
4865        .ptb-news__read-news .gallery .image-bullets .bullet { 
4866          width: var(--size-xs, 16px); 
4867          height: var(--size-xs, 16px); 
4868          border-radius: 50%; 
4869          border: 1px solid var(--color-neutral-100, #FFFFFF); 
4870          z-index: 9999; 
4871          cursor: pointer; 
4872
4873 
4874        .ptb-news__read-news .gallery .image-bullets .bullet.current-item { 
4875          background: var(--color-neutral-100, #FFFFFF); 
4876
4877			 
4878        .ptb-news__read-news .gallery .control-arrow { 
4879            position: fixed; 
4880            height: 100%; 
4881            align-items: center; 
4882            display: flex; 
4883            justify-content: center; 
4884            display: none; 
4885            z-index: 9999; 
4886
4887 
4888        .ptb-news__read-news .gallery .left-arrow { 
4889            top: 0; 
4890            left: 5vw; 
4891
4892 
4893        .ptb-news__read-news .gallery .right-arrow { 
4894            top: 0; 
4895            right: 5vw; 
4896
4897 
4898        .ptb-news__read-news .gallery .lefg-arrow svg { 
4899          margin-left: 16px !important; 
4900
4901 
4902        .ptb-news__read-news .gallery .right-arrow svg { 
4903          margin-right: 16px !important; 
4904
4905 
4906        .ptb-news__read-news .gallery .image-bullets { 
4907          display: none; 
4908          gap: var(--space-sm, 16px); 
4909          position: fixed; 
4910          left: 0; 
4911          bottom: calc(10vh + 24px); 
4912          width: 100vw; 
4913          z-index: 9999; 
4914          justify-content: center; 
4915
4916 
4917        .ptb-news__read-news .gallery .image-bullets .bullet { 
4918          width: var(--size-xs, 16px); 
4919          height: var(--size-xs, 16px); 
4920          border-radius: 50%; 
4921          border: 1px solid var(--color-neutral-100, #FFFFFF); 
4922          z-index: 9999; 
4923
4924 
4925        .ptb-news__read-news .gallery .image-bullets .bullet.current-item { 
4926          background: var(--color-neutral-100, #FFFFFF); 
4927
4928 
4929        .ptb-news__read-news .gallery .title-container { 
4930            display: flex; 
4931            align-items: center; 
4932            gap: var(--space-sm, 16px); 
4933
4934 
4935        .ptb-news__read-news .gallery .title-container svg { 
4936            width: var(--size-md, 24px); 
4937            height: 21px; 
4938
4939 
4940        .ptb-news__read-news .gallery .title-container .title { 
4941            color: var(--color-neutral-800, #373737); 
4942            font-family: var(--font-family-base); 
4943            font-size: var(--font-size-lg); 
4944            font-style: var(--font-style-normal); 
4945            font-weight: var(--font-weight-bold); 
4946            line-height: var(--line-height-md); 
4947
4948 
4949        body.high-contrast-active .ptb-news__read-news .gallery .title-container .title { 
4950            color: var(--color-neutral-100); 
4951
4952 
4953        .ptb-news__read-news .gallery .image-container { 
4954            display: flex; 
4955            gap: var(--space-sm, 16px); 
4956            flex-wrap: wrap; 
4957
4958 
4959         .ptb-news__read-news .gallery .image-container .modal-image-fragment { 
4960            width: inherit; 
4961            height: inherit; 
4962            max-height: calc(100vw/2); 
4963            padding: 0; 
4964            margin: 0; 
4965            overflow: hidden; 
4966
4967 
4968        .ptb-news__read-news .gallery .image-container .modal-image-fragment * { 
4969            box-sizing: border-box; 
4970            margin: 0; 
4971            padding: 0; 
4972
4973 
4974        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container { 
4975            width: 100%; 
4976            height: inherit; 
4977            display: flex; 
4978            justify-content: center; 
4979            align-items: center; 
4980            position: relative; 
4981
4982 
4983        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container.image-playing {     
4984            position: fixed; 
4985            top: 0; 
4986            left: 0; 
4987            width: 100vw !important; 
4988            height: 100vh !important; 
4989            z-index: 9999 !important; 
4990            background-color: rgba(0, 0, 0, 0.75); 
4991            max-height: 100vh; 
4992
4993 
4994        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .click-image { 
4995            height: 100%; 
4996            width: 100%; 
4997            position: absolute; 
4998            z-index: 3; 
4999            cursor: pointer; 
5000
5001 
5002        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container { 
5003            width: 100%; 
5004            height: 100%; 
5005
5006 
5007        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing { 
5008            position: relative; 
5009            width: 90vw !important; 
5010            height: 80vh !important; 
5011            z-index: 9999 !important; 
5012            background-color: rgba(0, 0, 0, 0.75); 
5013            border-radius: var(--border-radius-card); 
5014
5015 
5016        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image { 
5017            display: none; 
5018            position: absolute; 
5019            top: 0; 
5020	        right: 0; 
5021            transform: translate(100%, -100%); 
5022            z-index: 99999; 
5023
5024 
5025        body.high-contrast-active .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image path:nth-child(1) { 
5026           fill: var(--background-Surface-level-01, #010101); 
5027
5028 
5029        body.high-contrast-active .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image path:nth-child(2) { 
5030           stroke: #E4F7E8; 
5031
5032 
5033        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image.image-active { 
5034            display: block; 
5035
5036 
5037        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .image-player-session { 
5038            width: 100%; 
5039            height: 100%; 
5040
5041 
5042        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing .image-player-session { 
5043            width: 90vw !important; 
5044            height: 80vh !important; 
5045            z-index: 9999 !important; 
5046            background-color: rgba(0, 0, 0, 0.75); 
5047            border-radius: var(--border-radius-card); 
5048            overflow: hidden; 
5049
5050 
5051        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .image-player-session img { 
5052            object-fit: cover; 
5053
5054 
5055        .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing .image-player-session img { 
5056            width: 100%; 
5057            height: 100%; 
5058            margin-left: 0 !important; 
5059            max-height: 100vh; 
5060
5061 
5062        .ptb-news__read-news .gallery .image-container img { 
5063            width: 274px; 
5064            height: 152px; 
5065            border-radius: var(--border-radius-md, 8px); 
5066
5067 
5068        @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
5069 
5070            .ptb-news__read-news .gallery { 
5071                padding-top: var(--space-xl, 40px); 
5072
5073 
5074            .ptb-news__read-news .gallery .image-container { 
5075                gap: var(--space-xxs, 8px); 
5076
5077 
5078            .ptb-news__read-news .gallery .image-container img { 
5079                width: 296px; 
5080                height: 180px; 
5081
5082 
5083            .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container.image-playing .image-player-container.image-playing { 
5084                transform: rotate(90deg); 
5085                transform-origin: center; 
5086                width: 80vh !important; 
5087                height: 90vw !important; 
5088
5089 
5090            .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container.image-playing .image-player-container.image-playing img{ 
5091                cursor: pointer; 
5092
5093 
5094            .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing .image-player-session { 
5095                width: 80vh !important; 
5096                height: 90vw !important; 
5097
5098 
5099            .ptb-news__read-news .gallery .lefg-arrow svg { 
5100                margin-left: 4px !important; 
5101
5102 
5103            .ptb-news__read-news .gallery .right-arrow svg { 
5104                margin-right: 4px !important; 
5105
5106 
5107            .ptb-news__read-news .gallery .image-bullets { 
5108              gap: 14px; 
5109
5110 
5111            .ptb-news__read-news .gallery .image-bullets .bullet { 
5112              width: var(--size-xxs, 12px); 
5113              height: var(--size-xxs, 12px); 
5114
5115 
5116            .ptb-news__read-news .gallery .lefg-arrow svg { 
5117                margin-left: 4px !important; 
5118
5119 
5120            .ptb-news__read-news .gallery .right-arrow svg { 
5121                margin-right: 4px !important; 
5122
5123 
5124            .ptb-news__read-news .gallery .image-bullets { 
5125              gap: 14px; 
5126
5127 
5128            .ptb-news__read-news .gallery .image-bullets .bullet { 
5129              width: var(--size-xxs, 12px); 
5130              height: var(--size-xxs, 12px); 
5131
5132
5133 
5134    </style> 
5135 
5136    <script> 
5137     
5138     
5139        const allModalImagesFragment = document.querySelectorAll(".ptb-news__read-news .gallery .modal-image-fragment"); 
5140        const totalItems = allModalImagesFragment.length; 
5141        const bulletsContainer = document.querySelector(".ptb-news__read-news .gallery .image-bullets"); 
5142        const bullets = bulletsContainer.querySelectorAll(".bullet"); 
5143        let currentItem = 0; 
5144        const nextImage = document.querySelector(".ptb-news__read-news .gallery .right-arrow"); 
5145        const previousImage = document.querySelector(".ptb-news__read-news .gallery .left-arrow"); 
5146 
5147        const stopImage = (getImageClick, imagePlayerContainer, imageContainer, closeImage) => { 
5148            getImageClick.classList.remove('image-playing'); 
5149            imagePlayerContainer.classList.remove('image-playing'); 
5150            imageContainer.classList.remove('image-playing'); 
5151 
5152            const currentBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + currentItem +  '"]') 
5153            currentBullet && currentBullet.classList.remove('current-item'); 
5154             
5155            closeImage.classList.remove('image-active'); 
5156             
5157            document.querySelector("body").style.overflow = 'initial'; 
5158            [nextImage, previousImage].forEach(item => { 
5159                item.style.display = "none"; 
5160            }); 
5161            bulletsContainer.style.display = "none"; 
5162
5163 
5164        const playImage = (index, getImageClick, imagePlayerContainer, imageContainer, closeImage) => { 
5165            getImageClick.classList.add('image-playing'); 
5166            imagePlayerContainer.classList.add('image-playing'); 
5167            imageContainer.classList.add('image-playing'); 
5168            closeImage.classList.add('image-active'); 
5169 
5170             
5171            document.querySelector("body").style.overflow = 'hidden'; 
5172            [nextImage, previousImage].forEach(item => { 
5173                item.style.display = "flex"; 
5174            }); 
5175            bulletsContainer.style.display = "flex"; 
5176            bullets[index].classList.add('current-item'); 
5177
5178 
5179        const changeImage = (next) => { 
5180          if(next == currentItem || next < 0 || next >= totalItems) return; 
5181 
5182          const getImageClick = allModalImagesFragment[currentItem].querySelector('.click-image'); 
5183          const imageContainer = allModalImagesFragment[currentItem].querySelector('.modal-image-container'); 
5184          const imagePlayerContainer = allModalImagesFragment[currentItem].querySelector('.image-player-container'); 
5185          const image = imagePlayerContainer.querySelector('img'); 
5186          const closeImage = imagePlayerContainer.querySelector('.close-image'); 
5187 
5188          const currentBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + currentItem +  '"]') 
5189          currentBullet.classList.remove('current-item'); 
5190 
5191          stopImage(getImageClick, imagePlayerContainer, imageContainer, closeImage);  
5192          allModalImagesFragment[next].querySelector('.click-image')?.click(); 
5193           
5194          const nextBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + next +  '"]') 
5195          nextBullet.classList.add('current-item'); 
5196          currentItem = next; 
5197
5198 
5199        nextImage.addEventListener('click', () => { 
5200          changeImage(currentItem + 1); 
5201        }); 
5202 
5203        previousImage.addEventListener('click', () => { 
5204          changeImage(currentItem - 1); 
5205        }); 
5206 
5207        bullets.forEach((bullet, bulletIndex) => { 
5208          bullet.addEventListener('click', (_) => changeImage(bulletIndex)) ; 
5209        }); 
5210 
5211        allModalImagesFragment.forEach((modalImageFragment, index)=>{ 
5212        const totalItems = allModalImagesFragment.length; 
5213        const bulletsContainer = document.querySelector(".ptb-news__read-news .gallery .image-bullets"); 
5214        const bullets = bulletsContainer.querySelectorAll(".bullet"); 
5215        let currentItem = 0; 
5216        const nextImage = document.querySelector(".ptb-news__read-news .gallery .right-arrow"); 
5217        const previousImage = document.querySelector(".ptb-news__read-news .gallery .left-arrow"); 
5218      }); 
5219 
5220        allModalImagesFragment.forEach((modalImageFragment, index)=>{ 
5221            const getImageClick = modalImageFragment.querySelector('.click-image'); 
5222            const imageContainer = modalImageFragment.querySelector('.modal-image-container'); 
5223            const imagePlayerContainer = modalImageFragment.querySelector('.image-player-container'); 
5224 
5225            const image = imagePlayerContainer.querySelector('img'); 
5226            const closeImage = imagePlayerContainer.querySelector('.close-image'); 
5227            const body = document.body; 
5228 
5229            const toTopButton = document.querySelector(".fragment_88038 .petro-button"); 
5230 
5231            getImageClick.addEventListener('click', () => { 
5232                if (document.body.classList.contains('has-edit-mode-menu')) { 
5233                    return; 
5234
5235                currentItem = index; 
5236                if (imagePlayerContainer.classList.contains('image-playing')) { 
5237                    toTopButton && (toTopButton.style.zIndex = ""); 
5238                    stopImage(getImageClick, imagePlayerContainer, imageContainer, closeImage); 
5239                } else { 
5240                    playImage(index, getImageClick, imagePlayerContainer, imageContainer, closeImage); 
5241                    toTopButton && (toTopButton.style.zIndex = "1"); 
5242
5243            }) 
5244 
5245            closeImage.addEventListener('click', () => { 
5246                if (imagePlayerContainer.classList.contains('image-playing')) { 
5247                    toTopButton && (toTopButton.style.zIndex = ""); 
5248                    stopImage(getImageClick, imagePlayerContainer, imageContainer, closeImage); 
5249                    const bulletToClose = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + index +  '"]') 
5250                    bulletToClose?.classList.remove('current-item'); 
5251                }  
5252            }) 
5253        });             
5254    </script> 
5255 
5256</#macro> 
5257 
5258 
5259<#-- ################################################################################################################## --> 
5260	 
5261	 
5262	 
5263	 
5264	 
5265	 
5266	 
5267	 
5268	 
5269	 
5270	 
5271	 
5272	 
5273	<#-- ############# Site de Crise - Notícia - Galeria de imagens ####################################################### --> 
5274<#macro renderQuotes newsInfo> 
5275    <#if newsInfo.quotes?size != 0> 
5276    <#--quotes "escondidas" que serão unidas a .ptb-news__read-content --> 
5277 
5278        <div class="ptb-news__quotes-container d-none "> 
5279            <div id="ptb-news__quotes-identifiers"> 
5280                <#assign separator = ""> 
5281                <#list newsInfo.quotes as quote> 
5282                    ${quote.id}; 
5283                    <#assign separator = ";"> 
5284                </#list> 
5285            </div> 
5286            <#list newsInfo.quotes as quote> 
5287                <#assign quotes_index = quote?index> 
5288                <div id="ptb-news__quotes-container-${quote_index}"> 
5289                    <#assign noAuthorWrapper = !((quote.image.url?? && quote.image.url?has_content) || (quote.author?has_content)) /> 
5290                    <div class="quote <#if noAuthorWrapper>no-author-wrapper</#if>"> 
5291                        <div class="text-wrapper"> 
5292                            <blockquote class="text">${quote.content}</blockquote > 
5293                        </div> 
5294                        <#if !noAuthorWrapper>   
5295                            <div class="author-wrapper"> 
5296                                <#if quote.image.url?? && quote.image.url?has_content> 
5297                                    <#assign imageUrl = "/o/adaptive-media/image/" + quote.image.fileEntryId +"/Thumbnail-300x300/image"/> 
5298                                    <img src="${imageUrl}" loading="lazy" alt="${quote.image.alt}">		 
5299                                </#if> 
5300                                <#if quote.author?? && quote?has_content>                             
5301                                    <p class="author">${quote.author}</p> 
5302                                </#if> 
5303                            </div> 
5304                        </#if> 
5305                    </div> 
5306                </div> 
5307            </#list> 
5308        </div> 
5309 
5310        <script> 
5311            var newsContent_code = document.querySelector(".news-content").innerHTML; 
5312 
5313            var quotesIdentifiers = document.querySelector("#ptb-news__quotes-identifiers").innerHTML.trim().split(";"); 
5314            quotesIdentifiers.forEach((quoteIdentifier, index) => { 
5315                const quoteIdentifierContent = document.querySelector("#ptb-news__quotes-container-" + index); 
5316                if (quoteIdentifierContent) { 
5317                    const tag = "#[" + quoteIdentifier.trim() + "]"; 
5318                    const splitContent = newsContent_code.split(tag); 
5319                    newsContent_code = splitContent.join(quoteIdentifierContent.innerHTML); 
5320                    //linkIdentifierContent.parentNode.removeChild(linkIdentifierContent); 
5321
5322            }); 
5323 
5324 
5325            var ptb_news__read_content = document.querySelector(".news-content"); 
5326            ptb_news__read_content.innerHTML = newsContent_code; 
5327 
5328        </script> 
5329 
5330        <style> 
5331            
5332            .ptb-news__read-news .quote { 
5333                display: flex; 
5334                flex-direction: column; 
5335                gap: var(--space-md, 24px); 
5336
5337 
5338            .ptb-news__read-news .quote.no-author-wrapper{ 
5339                gap: 0; 
5340
5341 
5342            .ptb-news__read-news .quote .text-wrapper { 
5343                padding-left: var(--space-xl, 40px); 
5344
5345 
5346            .ptb-news__read-news .quote .text-wrapper .text { 
5347                font-style: var(--font-style-italic) !important; 
5348                padding-left: var(--space-md, 24px); 
5349                margin-bottom: 0; 
5350                border-left: 1px solid var(--border-color-mid, #d7d7d7); 
5351							  font-size: var(--font-size-xxs, 16px); 
5352
5353 
5354            .ptb-news__read-news .quote .author-wrapper {  
5355                display: flex; 
5356                flex-direction: row; 
5357                gap: var(--space-md, 24px); 
5358
5359 
5360            .ptb-news__read-news .news-content .quote .author-wrapper img { 
5361                height: var(--size-xxxl, 56px); 
5362                width: var(--size-xxxl, 56px); 
5363                border-radius: 100px; 
5364                border: var(--size-nano, 2px) solid var(--border-color-mid) !important; 
5365
5366 
5367            .ptb-news__read-news .news-content .quote .author-wrapper p { 
5368                margin: 0; 
5369                align-self: center; 
5370                font-size: var(--font-size-xs, 18px); 
5371                font-style: var(--font-style-normal, normal); 
5372                font-weight: var(--font-weight-bold, 700); 
5373                line-height: var(--line-height-xs, 100%); 
5374
5375 
5376            @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
5377                .ptb-news__read-news .quote .text-wrapper { 
5378                    padding-left: 0; 
5379
5380							 
5381							  .ptb-news__read-news .quote .text-wrapper .text { 
5382							      font-size: var(--font-size-xxxs, 14px); 
5383
5384 
5385                .ptb-news__read-news .news-content .quote .author-wrapper p { 
5386                    font-size: var(--font-size-xxs, 16px); 
5387
5388
5389        </style> 
5390    </#if> 
5391</#macro> 
5392 
5393 
5394					 
5395					 
5396<#-- ################################################################################################################## --> 
5397	 
5398	 
5399	 
5400	 
5401	 
5402	 
5403 
5404 
5405<#-- ############# Site de Crise - Notícia - Extrair dados de Notícias ################################################ --> 
5406<#-- 
5407Add elements from the sidebar to define your template. Type "${" to use the 
5408autocomplete feature. 
5409--> 
5410<#function extractFeaturedNewsHeadline fieldList xmlArticle> 
5411    <#return getFieldValue(fieldList, xmlArticle, "Título de destaque da notícia")> 
5412</#function> 
5413 
5414<#function extractNewsSummary fieldList xmlArticle> 
5415    <#return getFieldValue(fieldList, xmlArticle, "Resumo da notícia")> 
5416</#function> 
5417 
5418<#function extractPublishDate journalArticle> 
5419    <#assign lastPublishDate = journalArticle.getModifiedDate()> 
5420    <#if journalArticle.getLastPublishDate()??> 
5421        <#assign lastPublishDate = journalArticle.getLastPublishDate()> 
5422    <#else> 
5423        <#assign lastPublishDate = journalArticle.getModifiedDate()> 
5424    </#if> 
5425    <#return lastPublishDate /> 
5426</#function> 
5427 
5428<#-- Seção da imagem de destaque ----------------------------------------------------------------------> 
5429<#function extractNewsMedia fieldList xmlArticle  fileEntryService> 
5430    <#-- Tentando pegar Imagem --> 
5431    <#assign mediasGroup = getNodes(getIdFromFieldName(fieldList, "Mídia de destaque da notícia"), xmlArticle) /> 
5432    <#assign media = {} /> 
5433    <#list mediasGroup as mediaGroup > 
5434        <#assign media = getMediaInfo(fieldList, mediaGroup, "Imagem Destaque", fileEntryService) />  
5435        <#assign media = {"imageSrc": media.url, "imageAlt": media.alt, "fileEntryId" : media.fileEntryId} /> 
5436 
5437        <#-- Se não tiver imagem, tentar pegar vídeo --> 
5438        <#if !media.imageSrc?has_content>               
5439            <#assign youtubeID = getFieldValue(fieldList, mediaGroup, "ID do vídeo do YouTube do vídeo de destaque") /> 
5440            <#if youtubeID?? && youtubeID?has_content>  
5441                <#assign media = {"videoYotubeID": youtubeID} /> 
5442            <#else> 
5443                <#-- Tentar pegar vídeo Interno --> 
5444                <#assign internalVideo = getMediaInfo(fieldList, mediaGroup, "Fazer upload de um vídeo de destaque", fileEntryService) /> 
5445                <#if internalVideo?? && internalVideo?has_content> 
5446                    <#assign media = {"internalVideo": internalVideo} /> 
5447                </#if> 
5448            </#if>          
5449        </#if> 
5450 
5451        <#assign referenceMediasGroup = getNodes(getIdFromFieldName(fieldList, "Referências"), mediaGroup) /> 
5452        <#list referenceMediasGroup as referenciaMediaGroup > 
5453            <#assign credits = getFieldValue(fieldList, referenceMediasGroup, "Crédito da mídia de destaque da notícia") /> 
5454            <#assign legend = getFieldValue(fieldList, referenceMediasGroup, "Legenda da mídia de destaque da notícia") /> 
5455        </#list> 
5456 
5457        <#assign media = media + {"credits": credits, "legend": legend} /> 
5458         
5459    </#list> 
5460 
5461    <#return media> 
5462</#function> 
5463 
5464 
5465<#--------------------- Renderização de Lista de Cards -----------------------------------------------> 
5466 
5467<#-- Root Css -> Para poder instanciar dois elementos e não dar confusão no JS --> 
5468<#assign rootCss = "card-news-list-container_" + randomNumber(4586) /> 
5469 
5470<#attempt> 
5471    <#assign ourEnergyStyles = [] /> 
5472    <#list ourEnergyVocabulary.getCategories() as ourEnergyCategory > 
5473        <#assign shadowColorCategory = "" /> 
5474        <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor da Sombra")??)> 
5475            <#assign categoryShadowColorByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor da Sombra") /> 
5476            <#assign shadowColorCategory = categoryShadowColorByService.value /> 
5477        </#if> 
5478 
5479        <#assign backgroundColorCategory = "" /> 
5480        <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor de Fundo")??)> 
5481            <#assign categoryBackgroundColorByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor de Fundo") /> 
5482            <#assign backgroundColorCategory = categoryBackgroundColorByService.value /> 
5483        </#if> 
5484 
5485        <#assign textColorCategory = "" /> 
5486        <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto")??)> 
5487            <#assign categoryTextColorByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto") /> 
5488            <#assign textColorCategory = categoryTextColorByService.value /> 
5489        </#if> 
5490 
5491        <#assign textColorHighContrastCategory = "" /> 
5492        <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto em Alto Contraste")??)> 
5493            <#assign categoryTextColorHighContrastByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto em Alto Contraste") /> 
5494            <#assign textColorHighContrastCategory = categoryTextColorHighContrastByService.value /> 
5495        </#if> 
5496 
5497        <#assign ourEnergyStyles += [{"titleLocale": ourEnergyCategory.getTitle(locale),"shadowColor": shadowColorCategory, "backgroundColor": backgroundColorCategory, "textColor": textColorCategory, "textColorHighContrast": textColorHighContrastCategory}] /> 
5498    </#list> 
5499 
5500    <#recover> 
5501        <#assign ourEnergyStyles = [] /> 
5502     
5503</#attempt> 
5504 
5505<#-- Função para obter a primeira categoria associonada a um Vocabulário o qual está associado a um Jornal Article --> 
5506<#function getFirstCategoryTitleLocaleOfVocabulary journalArticle vocabulary > 
5507    <#attempt> 
5508        <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) /> 
5509         
5510        <#list categories as category> 
5511            <#if vocabulary.getVocabularyId() == category.getVocabularyId()> 
5512                <#return category.getTitle(locale)> 
5513            </#if> 
5514        </#list> 
5515 
5516        <#return ""> 
5517 
5518        <#recover> 
5519            <#return "" /> 
5520 
5521    </#attempt> 
5522</#function> 
5523 
5524<#-- Função para obter os dados de um card no Web Content (Journal Article) --> 
5525<#function getDataForCard entry > 
5526    <#attempt> 
5527        <#assign journalArticle = journalArticleLocalService.getLatestArticle(entry.getClassPK()) /> 
5528        <#assign ddmStructure = journalArticle.getDDMStructure() /> 
5529        <#assign fieldList = getFieldListByStructure(ddmStructure) /> 
5530        <#assign xmlArticle = journalArticle.getDocument().getRootElement() /> 
5531 
5532        <#-- Tentando pegar Imagem --> 
5533        <#assign mediasGroup = getNodes(getIdFromFieldName(fieldList, "Mídia de destaque da notícia"), xmlArticle) /> 
5534        <#assign media = "" /> 
5535        <#list mediasGroup as mediaGroup > 
5536            <#assign media = getMediaInfo(fieldList, mediaGroup, "Imagem Destaque", fileEntryService) /> 
5537 
5538            <#assign fileDataRequest = restClient.get("/headless-delivery/v1.0/documents/${media.fileEntryId}") /> 
5539 
5540            <#assign urlAdaptativeMediaDesktop = ""/> 
5541            <#assign urlAdaptativeMediaMobile = ""/> 
5542            <#if media.url?? && media.url?has_content && fileDataRequest?? && fileDataRequest.adaptedImages?? > 
5543                <#assign dataAdaptativeMedia = fileDataRequest.adaptedImages /> 
5544                <#list dataAdaptativeMedia as data> 
5545                    <#if data.resolutionName == adaptativeMediaDesktopResolutionName> 
5546                        <#assign urlAdaptativeMediaDesktop = data.contentUrl/> 
5547                    </#if> 
5548                    <#if data.resolutionName == adaptativeMediaMobileResolutionName> 
5549                        <#assign urlAdaptativeMediaMobile = data.contentUrl/> 
5550                    </#if>      
5551                </#list> 
5552            </#if> 
5553            <#assign media = {"imageSrc": media.url, "imageAlt": media.alt, "imageFileEntryId": media.fileEntryId, "urlAdaptativeMedia": {"mobile": urlAdaptativeMediaMobile, "desktop": urlAdaptativeMediaDesktop}} />  
5554             
5555            <#-- Se não tiver imagem, tentar pegar vídeo --> 
5556            <#if !media.imageSrc?? || !media.imageSrc?has_content>               
5557                <#assign youtubeID = getFieldValue(fieldList, mediaGroup, "ID do vídeo do YouTube do vídeo de destaque") /> 
5558                <#if youtubeID?? && youtubeID?has_content>  
5559                    <#assign media = {"videoYotubeID": youtubeID} /> 
5560                <#else> 
5561                    <#-- Tentar pegar vídeo Interno --> 
5562                    <#assign internalVideo = getMediaInfo(fieldList, mediaGroup, "Fazer upload de um vídeo de destaque", fileEntryService) /> 
5563                    <#if internalVideo?? && internalVideo?has_content> 
5564                        <#assign media = {"internalVideo": internalVideo} /> 
5565                    </#if> 
5566                </#if>          
5567            </#if> 
5568        </#list> 
5569 
5570        <#assign title = getFieldValue(fieldList, xmlArticle, "Título de destaque da notícia") /> 
5571 
5572        <#assign timeRead = getFieldValue(fieldList, xmlArticle, "Tempo de Leitura") /> 
5573 
5574        <#assign ourEnergyCategory = getFirstCategoryTitleLocaleOfVocabulary(entry, ourEnergyVocabulary) /> 
5575 
5576        <#assign typeOfNews = getFirstCategoryTitleLocaleOfVocabulary(entry, typeOfNewsVocabulary) /> 
5577 
5578        <#if themeDisplay.getPortalURL()?contains("webserver")> 
5579					<#assign urlNews = themeDisplay.getPortalURL() + themeDisplay.getPathFriendlyURLPublic() + layout.getGroup().friendlyURL + "/w/" + journalArticle.getUrlTitle()> 
5580				<#else> 
5581						<#assign urlNews = themeDisplay.getPortalURL() + "/w/" + journalArticle.getUrlTitle()> 
5582				</#if> 
5583         
5584        <#assign cardData = {"media": media, "title": title, "timeRead": timeRead, "ourEnergyCategory": ourEnergyCategory, "typeOfNews": typeOfNews, "urlNews": urlNews} /> 
5585         
5586        <#return cardData> 
5587 
5588        <#recover> 
5589            <#return {} /> 
5590    </#attempt> 
5591 
5592    <#-- cardData ->    image: url, alt 
5593                        title 
5594                        timeRead 
5595                        ourEnergyCategory 
5596                        typeOfNews 
5597                        urlNews 
5598    --> 
5599</#function> 
5600 
5601 
5602<#-- Macro para renderizar os arrows--> 
5603<#macro renderArrows> 
5604    <div class="card-news-list-arrows-breakpoint"> 
5605        <div class="card-news-list-arrows"> 
5606            <div class="card-news-arrow-left arrow-disable">  
5607                <svg width="34" height="34" viewBox="0 0 34 34" fill="none" xmlns="http://www.w3.org/2000/svg"> 
5608                    <path d="M1 17C1 8.16344 8.16344 1 17 1C25.8366 1 33 8.16344 33 17C33 25.8366 25.8366 33 17 33C8.16344 33 1 25.8366 1 17Z" stroke="#959595"/> 
5609                    <path d="M22.5 17H11.5M11.5 17L16 12.5M11.5 17L16 21.5" stroke="#525252" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
5610                </svg> 
5611            </div> 
5612            <div class="card-news-arrow-right">  
5613                <svg width="34" height="34" viewBox="0 0 34 34" fill="none" xmlns="http://www.w3.org/2000/svg"> 
5614                    <path d="M1 17C1 8.16344 8.16344 1 17 1C25.8366 1 33 8.16344 33 17C33 25.8366 25.8366 33 17 33C8.16344 33 1 25.8366 1 17Z" stroke="#008542"/> 
5615                    <path d="M11.5 17H22.5M22.5 17L18 12.5M22.5 17L18 21.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/> 
5616                </svg> 
5617 
5618            </div> 
5619        </div> 
5620    </div> 
5621 
5622    <style> 
5623 
5624        .${rootCss} .card-news-list-arrows-breakpoint { 
5625            position: relative; 
5626            z-index: 1; 
5627					width: 100%; 
5628
5629 
5630        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows { 
5631            display: flex; 
5632            align-items: flex-start; 
5633            justify-self: flex-end; 
5634            gap: var(--space-xxs, 8px); 
5635
5636         
5637        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left, 
5638        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right { 
5639            cursor: pointer; 
5640
5641 
5642        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(1), 
5643        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(1) { 
5644            fill: rgb(0, 133, 66); 
5645
5646 
5647        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(1), 
5648        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(1) { 
5649            fill: white; 
5650
5651 
5652        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(2), 
5653        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(2) { 
5654            stroke: #fff; 
5655
5656 
5657        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(2), 
5658        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(2) { 
5659            stroke: #010101; 
5660
5661 
5662        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable, 
5663        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable { 
5664            opacity: 0.4; 
5665            cursor: auto; 
5666
5667 
5668        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left path, 
5669        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right path { 
5670            stroke: rgb(0, 133, 66); 
5671            transition: all 300ms ease-in-out; 
5672
5673 
5674        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left path, 
5675        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right path { 
5676            stroke: rgba(228, 247, 232, 1); 
5677
5678 
5679        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(1), 
5680        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(1) { 
5681            stroke: rgb(149, 149, 149); 
5682
5683 
5684        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(1), 
5685        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(1) { 
5686            stroke: rgba(215, 215, 215, 1); 
5687
5688 
5689        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(2), 
5690        .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(2) { 
5691            stroke: rgb(82, 82, 82); 
5692
5693 
5694        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(2), 
5695        body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(2) { 
5696            stroke: rgba(149, 149, 149, 1); 
5697
5698 
5699        @media screen and (min-width: 1440px) { 
5700            .${rootCss} .card-news-list-arrows-breakpoint { 
5701                width: 100%; 
5702
5703
5704 
5705        @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) { 
5706 
5707            .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows { 
5708                justify-self: flex-start; 
5709                margin-top: var(--space-lg); 
5710
5711
5712 
5713    </style> 
5714 
5715</#macro> 
5716 
5717 
5718<#-- Macro para renderizar um Card --> 
5719<#macro renderCard cardData> 
5720    <#-- cardData ->    image: url, alt 
5721                        title 
5722                        timeRead 
5723                        ourEnergyCategory 
5724                        typeOfNews 
5725                        urlNews 
5726    --> 
5727 
5728    <div class="card-news-container"> 
5729        <a class="news-page-see-more-link card-news-link" href="${cardData.urlNews}">  Link da Notícia ${cardData.title}  </a> 
5730        <div class="card-news-thumb"> 
5731            <#assign noImage = "" /> 
5732            <#if cardData.media.imageSrc?? && cardData.media.imageSrc?has_content> 
5733                <#assign imageSrcDesktop = cardData.media.imageSrc /> 
5734                <#assign imageSrcMobile = cardData.media.imageSrc /> 
5735                <#if cardData.media.urlAdaptativeMedia?? && cardData.media.urlAdaptativeMedia?has_content> 
5736                    <#assign imageSrcDesktop = cardData.media.urlAdaptativeMedia.desktop /> 
5737                    <#assign imageSrcMobile = cardData.media.urlAdaptativeMedia.mobile /> 
5738                </#if> 
5739                <picture> 
5740                    <source media="(max-width:767px)" srcset="${imageSrcMobile}"> 
5741                    <img class="card-news-image" loading="lazy" src="${imageSrcDesktop}" alt="${cardData.media.imageAlt}"/> 
5742                </picture>		 
5743            <#else> 
5744                <#if cardData.media.videoYotubeID?? && cardData.media.videoYotubeID?has_content> 
5745                <picture> 
5746                    <source media="(max-width:767px)" srcset="https://img.youtube.com/vi/${cardData.media.videoYotubeID}/mqdefault.jpg"> 
5747                    <img class="card-news-image" loading="lazy" src="https://img.youtube.com/vi/${cardData.media.videoYotubeID}/maxresdefault.jpg" alt="YouTube Thumbnail"/> 
5748                </picture>  
5749                <#else> 
5750                    <#if (cardData.media.internalVideo?? && cardData.media.internalVideo.url?has_content) > 
5751                        <video class="card-news-image" loading="lazy"> 
5752                            <source src="${cardData.media.internalVideo.url}"> 
5753                            Your browser does not support the video tag. 
5754                        </video> 
5755                    <#else> 
5756                        <#assign noImage = "no-image" /> 
5757                    </#if> 
5758                </#if> 
5759                <svg class="thumb-play-icon" width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg"> 
5760                    <path d="M0 16C0 7.16344 7.16344 0 16 0C24.8366 0 32 7.16344 32 16C32 24.8366 24.8366 32 16 32C7.16344 32 0 24.8366 0 16Z" fill="white" fill-opacity="0.8"/> 
5761                    <path d="M22.2563 15.5744L13.2625 10.0744C13.1868 10.0277 13.1 10.0021 13.0111 10.0001C12.9221 9.99816 12.8343 10.02 12.7566 10.0633C12.6789 10.1066 12.6141 10.1698 12.569 10.2465C12.5239 10.3232 12.5001 10.4105 12.5 10.4994V21.4994C12.5001 21.5884 12.5239 21.6757 12.569 21.7524C12.6141 21.8291 12.6789 21.8923 12.7566 21.9356C12.8343 21.9789 12.9221 22.0007 13.0111 21.9988C13.1 21.9968 13.1868 21.9712 13.2625 21.9244L22.2563 16.4244C22.3301 16.3808 22.3913 16.3186 22.4338 16.2441C22.4763 16.1696 22.4987 16.0852 22.4987 15.9994C22.4987 15.9137 22.4763 15.8293 22.4338 15.7548C22.3913 15.6803 22.3301 15.6181 22.2563 15.5744Z" fill="#008542"/> 
5762                </svg>        
5763            </#if>         
5764        </div> 
5765         
5766        <div class="card-news-category-container ${noImage}">  
5767            <div data-category="${cardData.ourEnergyCategory}" class="card-news-category paragraph-micro-regular"> ${cardData.ourEnergyCategory} </div> 
5768        </div>  
5769 
5770        <div class="card-news-text-content ${noImage}">  
5771            <div class="card-news-title h5"> ${cardData.title} </div> 
5772 
5773             <div class="card-news-info">  
5774                <div class="card-news-type">  
5775                    <#if getPostTypeImageUrl(POST_TYPES_CATEGORIES, (cardData.typeOfNews)!default(""))?? > 
5776												<#assign postTypeIconUrl = getPostTypeImageUrl(POST_TYPES_CATEGORIES, (cardData.typeOfNews)!default("")) /> 
5777												<img src="${postTypeIconUrl}" loading="lazy" alt="post type icon" /> 
5778                        <div class="card-news-type-text paragraph-micro-regular">${cardData.typeOfNews}</div> 
5779												<#else/> 
5780                            <svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"> 
5781                                <path d="M6.25 7.5H13.75M6.25 10H13.75M6.25 12.5H13.75M3.125 3.75H16.875C17.2202 3.75 17.5 4.02982 17.5 4.375V15.625C17.5 15.9702 17.2202 16.25 16.875 16.25H3.125C2.77982 16.25 2.5 15.9702 2.5 15.625V4.375C2.5 4.02982 2.77982 3.75 3.125 3.75Z" stroke="#959595" stroke-linecap="round" stroke-linejoin="round"/> 
5782                            </svg>										 
5783                            <div class="card-news-type-text paragraph-micro-regular">Artigo</div> 
5784										</#if> 
5785                </div> 
5786 
5787								<#if cardData.timeRead?? && cardData.timeRead?has_content> 
5788									<div class="card-news-time-read">  
5789											<svg class="card-news-icon-time-read" width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"> 
5790													<path d="M10.5 5.625C10.5 5.34886 10.2761 5.125 10 5.125C9.72386 5.125 9.5 5.34886 9.5 5.625H10.5ZM10 10H9.5C9.5 10.2761 9.72386 10.5 10 10.5V10ZM14.375 10.5C14.6511 10.5 14.875 10.2761 14.875 10C14.875 9.72386 14.6511 9.5 14.375 9.5V10.5ZM17 10C17 13.866 13.866 17 10 17V18C14.4183 18 18 14.4183 18 10H17ZM10 17C6.13401 17 3 13.866 3 10H2C2 14.4183 5.58172 18 10 18V17ZM3 10C3 6.13401 6.13401 3 10 3V2C5.58172 2 2 5.58172 2 10H3ZM10 3C13.866 3 17 6.13401 17 10H18C18 5.58172 14.4183 2 10 2V3ZM9.5 5.625V10H10.5V5.625H9.5ZM10 10.5H14.375V9.5H10V10.5Z" fill="#959595"/> 
5791											</svg> 
5792 
5793											<div class="card-news-time-read-text paragraph-micro-regular">${cardData.timeRead} min</div> 
5794									</div> 
5795								</#if> 
5796            </div> 
5797        </div> 
5798    </div> 
5799</#macro> 
5800 
5801<style> 
5802    .${rootCss} .card-news-container { 
5803        width: 300px; 
5804        height: 370px; 
5805        display: flex; 
5806        flex-direction: column; 
5807        flex-shrink: 0; 
5808        align-items: flex-start; 
5809        border-radius: var(--border-radius-lg); 
5810        border: var(--border-width-hairline) solid var(--border-card-default, #EEE); 
5811        background: var(--background-surface-level-01, #FFF); 
5812        box-shadow: 0px 12px 60px -10px rgba(145, 147, 149, 0.12); 
5813        overflow: hidden; 
5814        scroll-snap-align: start; 
5815        cursor: pointer; 
5816        transition: border 300ms ease-in-out; 
5817        text-decoration: none; 
5818        position: relative; 
5819
5820 
5821    body.high-contrast-active .${rootCss} .card-news-container {      
5822        border: var(--border-width-hairline) solid var(--border-card-default, #525252); 
5823        background: var(--background-surface-level-01, #010101); 
5824
5825 
5826    .${rootCss} .card-news-container:hover { 
5827        border: var(--border-width-hairline) solid rgb(0, 133, 66); 
5828
5829 
5830    body.high-contrast-active .${rootCss} .card-news-container:hover { 
5831        border: var(--border-width-hairline) solid var(--border-card-default, #E4F7E8); 
5832
5833 
5834    .${rootCss} .card-news-container .card-news-link { 
5835        position: absolute; 
5836        top: 0; 
5837        width: 100%; 
5838        height: 100%; 
5839        z-index: 1; 
5840        opacity: 0; 
5841
5842 
5843    .${rootCss} .card-news-container .card-news-thumb { 
5844        position: relative; 
5845
5846 
5847    .${rootCss} .card-news-container .card-news-image { 
5848        width: 298px; 
5849        height: 168px; 
5850        object-fit: cover; 
5851
5852 
5853 
5854    .${rootCss} .card-news-container .card-news-thumb .thumb-play-icon { 
5855        position: absolute; 
5856        left: 50%; 
5857        top: 50%; 
5858        transform: translate(-50%, -50%); 
5859
5860 
5861    body.high-contrast-active .${rootCss} .card-news-container .card-news-thumb .thumb-play-icon path:nth-child(1) { 
5862        fill: black;   
5863
5864 
5865    body.high-contrast-active .${rootCss} .card-news-container .card-news-thumb .thumb-play-icon path:nth-child(2) { 
5866        fill: white;   
5867
5868 
5869    .${rootCss} .card-news-container .card-news-category-container { 
5870        position: relative; 
5871
5872 
5873    .${rootCss} .card-news-container .card-news-category-container .card-news-category { 
5874        display: flex; 
5875        justify-content: center; 
5876        align-items: center;  
5877        padding: var(--space-micro) var(--space-xs); 
5878        position: absolute; 
5879        z-index: 2; 
5880        left: var(--space-md); 
5881        top: -13px; 
5882        border-radius: var(--border-radius-pill); 
5883        background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 0%, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 100%), var(--default-sup-green-water, #006B65); 
5884        box-shadow: 0px 2px 6px 0px rgba(0, 178, 169, 0.10); 
5885        line-height: var(--line-height-lg, 144%); 
5886        color: var(--default-sup-green-water, #006B65); 
5887			  white-space: nowrap; 
5888
5889 
5890    body.high-contrast-active .${rootCss} .card-news-container .card-news-category-container .card-news-category { 
5891        background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, #373737) 0%, var(--background-surface-opacity-light-level-07, #373737) 100%), var(--default-sup-green-water, #99E0DD); 
5892        color: var(--default-sup-green-water, #99E0DD);  
5893
5894 
5895    .${rootCss} .card-news-container .card-news-category-container.no-image .card-news-category { 
5896        position: relative; 
5897        top: 0; 
5898        left: 0; 
5899        margin-left: var(--space-md); 
5900        margin-top: var(--space-md); 
5901
5902 
5903    .${rootCss} .card-news-container .card-news-text-content { 
5904        display: flex; 
5905        padding: var(--space-lg, 32px) var(--space-md, 24px) var(--space-md, 24px) var(--space-md, 24px); 
5906        flex-direction: column; 
5907        justify-content: space-between; 
5908        align-items: flex-start; 
5909        flex: 1 0 0; 
5910        align-self: stretch; 
5911
5912 
5913    .${rootCss} .card-news-container .card-news-text-content.no-image { 
5914        padding-top: var(--space-sm); 
5915
5916 
5917    .${rootCss} .card-news-container .card-news-text-content .card-news-title { 
5918        display: -webkit-box; 
5919        -webkit-box-orient: vertical; 
5920        -webkit-line-clamp: 4; 
5921        align-self: stretch; 
5922        overflow: hidden; 
5923        color: var(--text-primary-default, #373737); 
5924        text-overflow: ellipsis; 
5925        margin: 0; 
5926
5927 
5928    body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-title { 
5929        color: var(--text-primary-default, #FFF); 
5930
5931 
5932    .${rootCss} .card-news-container .card-news-text-content .card-news-info { 
5933        display: flex; 
5934        align-items: center; 
5935        align-content: center; 
5936        gap: var(--space-sm, 16px); 
5937        align-self: stretch; 
5938        flex-wrap: wrap; 
5939
5940 
5941    .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type, 
5942    .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read { 
5943        display: flex; 
5944        align-items: center; 
5945        gap: var(--space-xxs, 8px); 
5946
5947 
5948    body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type path { 
5949        stroke: #D7D7D7; 
5950
5951 
5952    .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type .card-news-type-text, 
5953    .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-time-read-text { 
5954        color: var(--text-tertiary-default, #959595); 
5955        line-height: var(--line-height-lg, 144%); 
5956
5957 
5958    body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type .card-news-type-text, 
5959    body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-time-read-text { 
5960        color: var(--text-tertiary-default, #EEE); 
5961
5962 
5963    .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-icon-time-read { 
5964        transform: translateY(-0.5px); 
5965
5966 
5967    body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-icon-time-read path { 
5968        fill: #D7D7D7; 
5969
5970</style> 
5971 
5972<#assign maxNumberOfCards = 9/> 
5973<#assign className = "com.liferay.journal.model.JournalArticle" /> 
5974<#assign classNameId = PortalUtil.getClassNameId(className) /> 
5975${AssetEntryQuery.setClassNameIds([classNameId]) } 
5976${AssetEntryQuery.setEnd(maxNumberOfCards)} 
5977 
5978<#assign entries = []/> 
5979<#assign ourEnergyCategoriesIds = getAllCategoryIdOfVocabulary(assetEntry, ourEnergyVocabulary) /> 
5980<#list ourEnergyCategoriesIds as ourEnergyCategoryId> 
5981    ${AssetEntryQuery.setAllCategoryIds([ourEnergyCategoryId])} 
5982    <#assign ents = AssetEntryQueryService.getEntries(AssetEntryQuery) /> 
5983    <#assign entries = entries + ents /> 
5984</#list> 
5985 
5986 
5987<#-- Renderizar Lista de cards --> 
5988<#if entries?has_content> 
5989    <div class="${rootCss}"> 
5990        <div class="list-of-news-title breakpoint"> 
5991            <div class="list-of-news-title-col col-1-12 md-col-1-8 sm-col-1-4"> 
5992                <div class="list-title fragment_85017"> 
5993                    <div class="petro-title"> 
5994                        <h2 id="title" class="display-sm" style="color: var(--color-neutral-800)"> 
5995                            <#if locale?lower_case == "pt_br"> Leia também <#else> Read also </#if> 
5996                        </h2> 
5997                        <div class="yellow-bar-container">   
5998                            <div class="yellow-bar bar-display-sm" style="background-color: var(--color-secondary-medium)"></div> 
5999                               <@renderArrows /> 
6000                        </div> 
6001                    </div> 
6002                </div> 
6003            </div>  
6004        </div> 
6005         
6006        <div class="card-news-list-breakpoint breakpoint"> 
6007            <div class="card-news-list col-1-12 md-col-1-8 sm-col-1-4">  
6008                <#if entries?size gt maxNumberOfCards> 
6009                    <#assign entries = entries[0..maxNumberOfCards] /> 
6010                </#if> 
6011                <#list entries as entry> 
6012                    <#if assetEntry.getClassPK() != entry.getClassPK() > 
6013                        <#assign cardData = getDataForCard(entry) /> 
6014                        <@renderCard cardData/> 
6015                    </#if> 
6016                </#list> 
6017            </div> 
6018        </div>   
6019    </div> 
6020</#if> 
6021 
6022 
6023<style> 
6024    .portlet { 
6025        margin: 0; 
6026
6027     
6028    .${rootCss} { 
6029        padding: var(--space-giant, 80px) 0; 
6030        background: var(--background-surface-level-01, #FFF); 
6031        width: 100%; 
6032        position: relative; 
6033        font-family: var(--font-family-base, "Petrobras Sans"); 
6034        display: flex; 
6035        flex-direction: column; 
6036        gap: var(--space-lg); 
6037
6038 
6039    body.high-contrast-active .${rootCss} { 
6040        background: var(--background-surface-level-01, #010101); 
6041
6042 
6043    .${rootCss} .list-of-news-title { 
6044        position: relative; 
6045        z-index: 1; 
6046
6047 
6048    .${rootCss} body.high-contrast-active .fragment_614685 .petro-title .yellow-bar { 
6049        background-color: #FFEEB3 !important; 
6050
6051 
6052    .${rootCss} .petro-title > div:has(> .yellow-bar, > .card-news-list-arrows-breakpoint) { 
6053        display: flex;     
6054
6055 
6056    .${rootCss} .card-news-list { 
6057        display: flex; 
6058        gap: var(--space-lg); 
6059        overflow: auto; 
6060        position: relative; 
6061        z-index: 1; 
6062        scroll-snap-type: x mandatory; 
6063        scrollbar-width: none; 
6064
6065 
6066    .${rootCss} .card-news-list::-webkit-scrollbar { 
6067        display: none; 
6068
6069 
6070    @media screen and (min-width: 1441px) { 
6071        .${rootCss} .card-news-list-breakpoint { 
6072            width: 100%;            
6073
6074 
6075        .${rootCss} .list-of-news-title { 
6076            width: 100%; 
6077
6078
6079 
6080    @media screen and (max-width: 1024px) { 
6081        .${rootCss} .fragment_614685 { 
6082            padding: var(--space-xxl, 56px) 0; 
6083
6084
6085    
6086    @media screen and (max-width: 768px) { 
6087				.${rootCss} .petro-title > div:has(> .yellow-bar, > .card-news-list-arrows-breakpoint) { 
6088						flex-direction: column; 
6089
6090
6091 
6092 
6093</style> 
6094 
6095<#list ourEnergyStyles as ourEnergyStyle> 
6096    <style> 
6097        .${rootCss} [data-category="${ourEnergyStyle.titleLocale}"] { 
6098            background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 0%, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 100%), #${ourEnergyStyle.backgroundColor} !important; 
6099            box-shadow: 0px 2px 6px 0px #${ourEnergyStyle.shadowColor} !important; 
6100            color: #${ourEnergyStyle.textColor} !important; 
6101
6102 
6103        body.high-contrast-active .${rootCss} [data-category="${ourEnergyStyle.titleLocale}"] { 
6104             background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, rgba(55, 55, 55, 1)) 0%, var(--background-surface-opacity-light-level-07, rgba(55, 55, 55, 1)) 100%), #${ourEnergyStyle.backgroundColor} !important; 
6105            color: #${ourEnergyStyle.textColorHighContrast} !important; 
6106
6107 
6108    </style> 
6109</#list> 
6110 
6111<script> 
6112 
6113    function disableEnableArrow(arrow, scrollBar, maxDistance, direction) 
6114
6115        if(direction === "left") { 
6116            if (scrollBar.scrollLeft > 0) { 
6117                arrow.classList.contains("arrow-disable") && arrow.classList.remove("arrow-disable"); 
6118
6119            else { 
6120                !arrow.classList.contains("arrow-disable") && arrow.classList.add("arrow-disable"); 
6121
6122        }  
6123        else if(direction === "right") { 
6124            if (Math.ceil(scrollBar.scrollLeft + scrollBar.clientWidth) < maxDistance) { 
6125                arrow.classList.contains("arrow-disable") && arrow.classList.remove("arrow-disable"); 
6126
6127            else { 
6128                !arrow.classList.contains("arrow-disable") && arrow.classList.add("arrow-disable"); 
6129
6130
6131
6132 
6133    function scrollCarousel() 
6134
6135        const root = document.querySelector(".${rootCss}"); 
6136        if(root) { 
6137            const scrollBar = root.querySelector(".${rootCss} .card-news-list"); 
6138            const gap = 32;// var(--space-lg); 
6139            const stepLength = scrollBar.querySelector(".card-news-container").offsetWidth + gap; 
6140            const arrowLeftBtn = root.querySelector(".card-news-arrow-left") 
6141            const arrowRightBtn = root.querySelector(".card-news-arrow-right") 
6142 
6143            let maxDistance = scrollBar.scrollWidth; 
6144 
6145            arrowLeftBtn.addEventListener('click', () => { 
6146                if (scrollBar.scrollLeft > 0) { 
6147                    scrollBar.scroll({ 
6148                        left: scrollBar.scrollLeft - stepLength, 
6149                        behavior: "smooth", 
6150                    });	 
6151
6152            }); 
6153 
6154            arrowRightBtn.addEventListener('click', () => { 
6155                if (scrollBar.scrollLeft < maxDistance) { 
6156                    scrollBar.scroll({ 
6157                        left: scrollBar.scrollLeft + stepLength, 
6158                        behavior: "smooth", 
6159                    }); 
6160
6161            }); 
6162             
6163            scrollBar.addEventListener("scroll", ()=>{ 
6164                disableEnableArrow(arrowLeftBtn, scrollBar, maxDistance, "left"); 
6165                disableEnableArrow(arrowRightBtn, scrollBar, maxDistance, "right"); 
6166            }); 
6167 
6168            disableEnableArrow(arrowLeftBtn, scrollBar, maxDistance, "left"); 
6169            disableEnableArrow(arrowRightBtn, scrollBar, maxDistance, "right"); 
6170 
6171        }        
6172
6173 
6174    document.addEventListener('DOMContentLoaded', scrollCarousel); 
6175 
6176</script> 
6177	 
6178<style> 
6179 
6180 
6181.ptb-news__read-news .news-content .embed-responsive-youtube::before { 
6182    padding-top: 0; 
6183
6184	 
6185.ptb-news__read-news .news-content .embed-responsive-liferay::before { 
6186    padding-top: calc(9/16 *100% - 64px); 
6187
6188 
6189.ptb-news__read-news .news-content .thumnail-play-button { 
6190
6191 
6192.ptb-news__read-news .news-content .thumnail-play-button { 
6193    position: relative; 
6194    z-index: 100; 
6195    height: 64px; 
6196    width: 64px; 
6197    background-repeat: no-repeat; 
6198    top: calc(50%); 
6199    left: calc(50% - 32px); 
6200
6201	 
6202	 
6203.ptb-news__read-news .news-content .thumnail-play-button-youtube { 
6204    position: absolute; 
6205    z-index: 100; 
6206    height: 64px; 
6207    width: 64px; 
6208    background-repeat: no-repeat; 
6209	top: calc(50% - 135px); 
6210    left: calc(50% - 32px); 
6211
6212 
6213.ptb-news__read-news .news-content .thumnail-play-button-liferay { 
6214    position: relative; 
6215    z-index: 100; 
6216    height: 64px; 
6217    width: 64px; 
6218    top: calc(-50% + 32px); 
6219    left: calc(50% - 32px); 
6220    background-repeat: no-repeat; 
6221
6222 
6223	 
6224	.ptb-news__read-news .news-content .embed-responsive-youtube img { 
6225	width: 100%; 
6226		height: 100%; 
6227
6228	 
6229</style> 
6230 
6231	<script> 
6232	<#assign createYoutubeThumbnails = "createYoutubeThumbnails_"+ randomNumber(5952) />  
6233	 
6234	function ${createYoutubeThumbnails}(){ 
6235 
6236        const newsContent = document.querySelector(".news-content"); 
6237 
6238        const getYoutubeId = (youtubeUrl) => { 
6239 
6240            const url = new URL(youtubeUrl); 
6241            const splittedPathName = url.pathname.split("/"); 
6242 
6243            if (splittedPathName.length <= 0){ 
6244                return ""; 
6245
6246 
6247            return splittedPathName[splittedPathName.length-1]; 
6248        }; 
6249		 
6250		    window.addEventListener("resize", (event) => { 
6251				const iframeList = newsContent.querySelectorAll('iframe'); 
6252           iframeList.forEach((iframe) => { 
6253                const src = iframe.src; 
6254                if (!src){ 
6255                    return; 
6256
6257 
6258                const isYoutube = src.toLowerCase().includes("youtube"); 
6259                if (!isYoutube){ 
6260                    return; 
6261
6262						  
6263						    const iframeParent = iframe.parentNode; 
6264						  
6265						    const thumbnail = iframeParent.querySelector("img"); 
6266                if (thumbnail){ 
6267					         // thumbnail.style="width:" + iframe.width + "px; height: " + iframe.height + "px"; 
6268
6269				   }); 
6270				 
6271				}); 
6272         
6273        const iframeList = newsContent.querySelectorAll('iframe'); 
6274        iframeList.forEach((iframe) => { 
6275                const src = iframe.src; 
6276                if (!src){ 
6277                    return; 
6278
6279 
6280                const isYoutube = src.toLowerCase().includes("youtube"); 
6281                if (!isYoutube){ 
6282                    return; 
6283
6284 
6285                const iframeParent = iframe.parentNode; 
6286 
6287                const thumbnail = document.createElement("img"); 
6288                thumbnail.src = 'https://img.youtube.com/vi/' + getYoutubeId(src) +'/hqdefault.jpg'; 
6289                thumbnail.alt = "Youtube"; 
6290                thumbnail.loading = "lazy"; 
6291					      //thumbnail.style="width:" + iframe.width + "px; height: " + iframe.height + "px"; 
6292 
6293                const playButton = document.createElement("div"); 
6294                playButton.style = 'background-image: url("data:image/svg+xml,%3Csvg width=\'64\' height=\'64\' viewBox=\'0 0 64 64\' fill=\'none\' xmlns=\'http://www.w3.org/2000/svg\'%3E%3Cg clip-path=\'url(%23clip0_4118_27800)\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3Cpath d=\'M39.22 32.52C39.591 32.2726 39.591 31.7274 39.22 31.48L28.9717 24.6478C28.5563 24.3709 28 24.6686 28 25.1678V38.8322C28 39.3314 28.5563 39.6291 28.9717 39.3522L39.22 32.52Z\' fill=\'%23008542\' stroke=\'%23008542\' stroke-width=\'2\' stroke-linecap=\'round\' stroke-linejoin=\'round\'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id=\'clip0_4118_27800\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A")'; 
6295                playButton.classList.add("thumnail-play-button-youtube"); 
6296                const children = iframeParent.children; 
6297 
6298                if (children.length > 0) { 
6299                    iframeParent.insertBefore(thumbnail, children.firstChild); 
6300                    iframeParent.insertBefore(playButton, thumbnail); 
6301                    iframe.classList.add("hide"); 
6302                    iframeParent.classList.add("embed-responsive-youtube"); 
6303
6304 
6305                playButton.addEventListener("click", () => { 
6306                    thumbnail.click(); 
6307                }); 
6308 
6309                thumbnail.addEventListener("click", () => { 
6310                    thumbnail.classList.add("hide"); 
6311                    playButton.classList.add("hide"); 
6312                    iframe.classList.remove("hide"); 
6313                    iframeParent.classList.remove("embed-responsive-youtube"); 
6314                    const url = new URL(src); 
6315                    const searchParams = url.searchParams; 
6316                    searchParams.set("rel", "0"); 
6317                    //searchParams.set("modestbranding", "0"); 
6318                    //searchParams.set("mute", "0"); 
6319                    //searchParams.set("color", "white"); 
6320                    searchParams.set("controls", "1"); 
6321                    //searchParams.set("playsinline", "1"); 
6322                    //searchParams.set("enablejsapi", "1"); 
6323                    searchParams.set("autoplay", "1"); 
6324                    //searchParams.set("logo", "0"); 
6325                    iframeParent.setAttribute("data-embed-id", url.toString()); 
6326                    iframe.setAttribute("src", url.toString()); 
6327                }); 
6328        }); 
6329  
6330
6331		 
6332	${createYoutubeThumbnails}(); 
6333		 
6334    <#assign createLRThumbnails = "createLRThumbnails"+ randomNumber(5952) />  
6335	 
6336	function ${createLRThumbnails}(){ 
6337 
6338        const newsContent = document.querySelector(".news-content"); 
6339        const iframeList = newsContent.querySelectorAll("iframe[data-video-liferay]"); 
6340 
6341        iframeList.forEach(iframe => {                       
6342 
6343            const playButton = document.createElement("div"); 
6344            playButton.style = 'background-image: url("data:image/svg+xml,%3Csvg width=\'64\' height=\'64\' viewBox=\'0 0 64 64\' fill=\'none\' xmlns=\'http://www.w3.org/2000/svg\'%3E%3Cg clip-path=\'url(%23clip0_4118_27800)\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3Cpath d=\'M39.22 32.52C39.591 32.2726 39.591 31.7274 39.22 31.48L28.9717 24.6478C28.5563 24.3709 28 24.6686 28 25.1678V38.8322C28 39.3314 28.5563 39.6291 28.9717 39.3522L39.22 32.52Z\' fill=\'%23008542\' stroke=\'%23008542\' stroke-width=\'2\' stroke-linecap=\'round\' stroke-linejoin=\'round\'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id=\'clip0_4118_27800\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A")'; 
6345            playButton.classList.add("thumnail-play-button-liferay"); 
6346            const children = iframe.parentNode.children; 
6347            if (children.length > 0) {                
6348                iframe.parentNode.insertBefore(playButton, children.firstChild);                 
6349
6350 
6351            iframe.addEventListener("load", () => { 
6352                if (iframe.contentDocument){ 
6353                    const video = iframe.contentDocument.body.querySelector("video"); 
6354                    video.removeAttribute("controls"); 
6355
6356            }); 
6357					 
6358					iframe.parentNode.classList.add("embed-responsive-liferay"); 
6359             
6360 
6361            playButton.addEventListener("click", () => { 
6362                playButton.classList.add("hide"); 
6363                playButton.classList.remove("thumnail-play-button-liferay");     
6364							iframe.parentNode.classList.remove("embed-responsive-liferay"); 
6365                if (iframe.contentDocument){ 
6366                    const video = iframe.contentDocument.body.querySelector("video"); 
6367                    video.setAttribute("controls", ""); 
6368                    video.play(); 
6369
6370            }); 
6371        }); 
6372
6373 
6374    ${createLRThumbnails}(); 
6375	 
6376    document.querySelectorAll(".news-content img").forEach(img => img.loading = "lazy"); 
6377 
6378  </script> 




Canais

Acessibilidade

Faça uma busca:

Sugestões de busca

Link de exemplo
Ícone do botão /documents/d/nossa-energia/chevronright-svg?download=true Exibir mais resultados
Ícone de carregamento

Mais pesquisados

Preço dos combustíveis

Pré-Sal

Time Petrobras

Escolha um Canal:

Portal da Transparência
Transparência
Portal da Transparência
Investidor Petrobras
Investidor Petrobras
Investidor Petrobras
Site Petrobras
Site Petrobras
Site Petrobras

Acessibilidade

Alto-Contraste

Desligado

Ligado

Texto Grande

Desligado

Ligado

Idioma:

Selecione um idioma: