CINXE.COM
Home | Ceres: Sustainability is the bottom line
<!-- /layout.antlers.html --> <!doctype html> <html lang="en" class="antialiased"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0, viewport-fit=cover"> <link rel="preload" as="style" href="https://www.ceres.org/build/assets/site-bc2278b4.css" /><link rel="modulepreload" href="https://www.ceres.org/build/assets/site-f5535cd5.js" /><link rel="stylesheet" href="https://www.ceres.org/build/assets/site-bc2278b4.css" data-navigate-track="reload" /><script type="module" src="https://www.ceres.org/build/assets/site-f5535cd5.js" data-navigate-track="reload"></script> <link rel="stylesheet" href="https://unpkg.com/tippy.js@6/dist/tippy.css" /> <!-- statamic-peak-seo::snippets/_seo.antlers.html --> <title> Home | Ceres: Sustainability is the bottom line </title> <link rel="alternate" hreflang="en-US" href="https://www.ceres.org"> <link rel="canonical" href="https://www.ceres.org"> <meta property="og:site_name" content="Ceres: Sustainability is the bottom line"> <meta property="og:type" content="website"> <meta property="og:locale" content="en_US"> <meta property="og:title" content="Home"> <meta property="og:image" content="https://assets.ceres.org/cache/containers/social_images/social-media-preview.png/2e2942f777ec2f94bcfb196fcd49af51.png"> <script>(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start': new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0],j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src='https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f);})(window,document,'script','dataLayer','GTM-K7574ND');function gtag(){dataLayer.push(arguments);}</script> <script> gtag('consent', 'default', { 'ad_storage': 'denied', 'analytics_storage': 'denied', 'wait_for_update': 500 }); dataLayer.push({ 'event': 'default_consent' }); </script> <!-- End: statamic-peak-seo::snippets/_seo.antlers.html --> <!-- /snippets/_browser_appearance.antlers.html --> <link rel="icon" href="https://assets.ceres.org/images/favicons/ceres_logo.svg" type="image/svg+xml"> <link rel="icon" href="/favicons/default/favicon.ico" type="image/x-icon"> <link rel="icon" href="https://assets.ceres.org/cache/containers/favicons/ceres_logo.png/745e90b115200c251a72efe551a21a93.png" sizes="16x16"> <link rel="icon" href="https://assets.ceres.org/cache/containers/favicons/ceres_logo.png/604ff9f514f749ad9c374c18a9fdfc07.png" sizes="32x32"> <link rel="manifest" href="https://www.ceres.org/site.webmanifest"> <!-- End: /snippets/_browser_appearance.antlers.html --> <script src="https://75fc01f3120645c39e3c70274c82795f.js.ubembed.com" async></script> <!-- Livewire Styles --><style >[wire\:loading][wire\:loading], [wire\:loading\.delay][wire\:loading\.delay], [wire\:loading\.inline-block][wire\:loading\.inline-block], [wire\:loading\.inline][wire\:loading\.inline], [wire\:loading\.block][wire\:loading\.block], [wire\:loading\.flex][wire\:loading\.flex], [wire\:loading\.table][wire\:loading\.table], [wire\:loading\.grid][wire\:loading\.grid], [wire\:loading\.inline-flex][wire\:loading\.inline-flex] {display: none;}[wire\:loading\.delay\.none][wire\:loading\.delay\.none], [wire\:loading\.delay\.shortest][wire\:loading\.delay\.shortest], [wire\:loading\.delay\.shorter][wire\:loading\.delay\.shorter], [wire\:loading\.delay\.short][wire\:loading\.delay\.short], [wire\:loading\.delay\.default][wire\:loading\.delay\.default], [wire\:loading\.delay\.long][wire\:loading\.delay\.long], [wire\:loading\.delay\.longer][wire\:loading\.delay\.longer], [wire\:loading\.delay\.longest][wire\:loading\.delay\.longest] {display: none;}[wire\:offline][wire\:offline] {display: none;}[wire\:dirty]:not(textarea):not(input):not(select) {display: none;}:root {--livewire-progress-bar-color: #2299dd;}[x-cloak] {display: none !important;}</style> <script>(function(w,d,s,n,a){if(!w[n]){var l='call,catch,on,once,set,then,track' .split(','),i,o=function(n){return'function'==typeof n?o.l.push([arguments])&&o :function(){return o.l.push([n,arguments])&&o}},t=d.getElementsByTagName(s)[0], j=d.createElement(s);j.async=!0;j.src='https://cdn.fundraiseup.com/widget/'+a+''; t.parentNode.insertBefore(j,t);o.s=Date.now();o.v=4;o.h=w.location.href;o.l=[]; for(i=0;i<7;i++)o[l[i]]=o(l[i]);w[n]=o} })(window,document,'script','FundraiseUp','ADRUXVPU');</script> </head> <body class="overflow-x-hidden"> <!-- statamic-peak-tools::snippets/_noscript.antlers.html --> <noscript> <style> nav.hidden, nav ul [x-cloak], nav ul li ul { display: block !important; } </style> <p class="relative z-50 py-3 px-4 bg-gray-100 border-b border-gray-200 text-center font-bold text-xs text-gray-600">This website requires Javascript for some parts to function properly. Your experience may vary.</p> </noscript> <!-- End: statamic-peak-tools::snippets/_noscript.antlers.html --> <!-- statamic-peak-tools::navigation/_skip_to_content.antlers.html --> <a class="fixed z-50 px-4 py-2 text-sm font-bold text-white -translate-y-24 opacity-0 top-4 left-8 bg-primary focus-visible:translate-y-0 focus-visible:opacity-100 outline-primary motion-safe:transition-transform" href="#content"> Skip to content </a> <!-- End: statamic-peak-tools::navigation/_skip_to_content.antlers.html --> <!-- statamic-peak-tools::components/_toolbar.antlers.html --> <!-- End: statamic-peak-tools::components/_toolbar.antlers.html --> <!-- statamic-peak-seo::components/_consent_banner.antlers.html --> <div x-data="consentBanner" x-show="!$store.consentBanner.getConsent()" x-transition class=" fixed z-[1000] inset-x-[1rem] bottom-[1rem] md:bottom-[2rem] max-h-[calc(100vh-2rem)] md:max-h-[calc(100vh-4rem)] md:w-[21rem] flex flex-col stack-2 p-6 bg-white border border-neutral/10 rounded shadow-lg overflow-auto overscroll-contain md:right-auto md:left-[2rem] " x-cloak > <h2 class="text-2xl font-bold">Cookies 🍪</h2> <p class="text-sm font-bold text-neutral"> This site uses cookies that need consent. </p> <div class="stack-space-4 py-6 flex flex-col gap-4"> <template x-for="type in $store.consentBanner.getConsentTypes()"> <label class="inline-flex"> <template x-if="type.disabled"> <input class="mr-2 w-4 h-4 rounded border-neutral !bg-cw-green-200 focus:border-cw-green-200 opacity-50" type="checkbox" :name="type.handle" checked disabled> </template> <template x-if="!type.disabled"> <input class="mr-2 w-4 h-4 rounded border-neutral checked:!bg-cw-green-200 focus:border-cw-green-200" type="checkbox" :name="type.handle" x-model="type.value"> </template> <span class="flex flex-col gap-0.5"> <span class="font-bold text-xs" x-html="type.title"></span> <span class="text-xs" x-html="type.explanation"></span> </span> </label> </template> </div> <div class="stack-space-4 flex flex-wrap gap-2"> <button @click="$store.consentBanner.acceptAll()" type="button" class="px-2 py-2 rounded text-xs font-bold bg-cw-green-200 text-white outline-primary"> Accept all </button> <button @click="$store.consentBanner.saveConsent()" type="button" class="px-2 py-2 rounded text-xs font-bold bg-neutral/10 text-neutral"> Accept selected </button> <button @click="$store.consentBanner.rejectAll()" type="button" class="px-2 py-2 rounded text-xs font-bold bg-neutral/10 text-neutral"> Reject all </button> </div> <script> let consentData = { "consent": false, "date": null, "consent_api": true, "custom_scripts": false, "types": [ { "value": true, "handle": "functionalCookies", "title": "Functional", "explanation": "First party cookies needed for the website to function. These can't be turned off.", "disabled": true }, { "value": false, "handle": "analyticsStorage", "title": "Analytics", "explanation": "Third party cookies used for analytics.", "consent_api": true, "consent_api_handle": "analytics_storage" }, { "value": false, "handle": "adStorage", "title": "Ads & tracking", "explanation": "Third party cookies used for advertisement.", "consent_api": true, "consent_api_handle": "ad_storage" }, { "value": false, "handle": "adUserData", "title": "Share Ad Data", "explanation": "Share advertising data with Google.", "consent_api": true, "consent_api_handle": "ad_user_data" }, { "value": false, "handle": "adPersonalization", "title": "Personalize Ads", "explanation": "Allow for personalized advertising.", "consent_api": true, "consent_api_handle": "ad_personalization" }, ] } </script> <script> document.addEventListener('alpine:init', () => { Alpine.store('consentBanner', { data: Alpine.$persist(consentData).as('consentBannerDefault'), acceptAll() { this.data.types.forEach((type) => type.value = true) this.saveConsent() }, getConsent() { return this.data.consent }, getConsentAPIValues() { return this.data.types.filter((type) => { return type['consent_api'] === true }).reduce((acc, type) => { acc[type.consent_api_handle] = type.value ? 'granted' : 'denied'; return acc; }, {}); }, getCustomScripts() { return this.data.types.filter((type) => type.hasOwnProperty('script_fragments') && type.value); }, getConsentDate() { return this.data.date }, getConsentTypes() { return this.data.types }, getConsentValue(handle) { return this.data.types.filter((type) => { return type['handle'] === handle })[0]['value'] }, invalidate() { this.data = consentData }, rejectAll() { this.data.types.forEach((type) => type.value = false) this.saveConsent() }, revokeConsent() { this.data.consent = false this.data.date = null }, saveConsent() { this.data.consent = true this.data.date = Math.floor(Date.now() / 1000) }, useConsentAPI() { return this.data.consent_api }, useCustomScripts() { return this.data.custom_scripts }, useEmbeds() { return this.data.embeds } }) Alpine.data('consentBanner', () => { return { data: Alpine.store('consentBanner').data, init() { if (Alpine.store('consentBanner').getConsentDate() < '') { Alpine.store('consentBanner').invalidate() } if (Alpine.store('consentBanner').useConsentAPI() && Alpine.store('consentBanner').getConsent()) { gtag('consent', 'update', Alpine.store('consentBanner').getConsentAPIValues()) } if (Alpine.store('consentBanner').useConsentAPI()) { this.$watch('data.consent', value => value && gtag('consent', 'update', Alpine.store('consentBanner').getConsentAPIValues())) } if (Alpine.store('consentBanner').useCustomScripts() && Alpine.store('consentBanner').getConsent()) { this.runCustomScripts() } if (Alpine.store('consentBanner').useCustomScripts()) { this.$watch('data.consent', value => value ? this.runCustomScripts() : this.removeCustomScripts()) } }, runCustomScripts() { Alpine.store('consentBanner') .getCustomScripts() .flatMap(script => script.script_fragments) .forEach(script => { const tag = document.createElement('script') script.type === 'script_tag' ? tag.src = script.source : tag.text = script.inline_script tag.defer = script.defer tag.async = script.async script.attributes.forEach(attribute => tag.setAttribute(attribute.key, attribute.value)) document.head.appendChild(tag) this.$el.addEventListener(`remove-custom-scripts-${script.category}`, () => tag.remove(), {once: true}) }) }, removeCustomScripts() { Alpine.store('consentBanner') .getCustomScripts() .forEach(script => this.$dispatch(`remove-custom-scripts-${script.handle}`)) } } }) }) </script> </div> <!-- End: statamic-peak-seo::components/_consent_banner.antlers.html --> <section> </section> <nav x-data="{ activeButton: null, activeSubMenu: null, activeSection: null, isMenuOpen: false, closeAllSubMenus: function() { this.activeButton = null; this.activeSubMenu = null; }, isSearchOpen: false, }" @keydown.escape.window="activeButton = null; activeSubMenu = null;" class="overflow-hidden" > <div class="bg-white relative border-b border-b-cw-green-50/40 z-[500]"> <div class="container flex flex-col lg:flex-row justify-between py-5"> <div class="flex xl:flex-row gap-10 justify-between w-full md:w-auto items-center"> <!-- /components/_logo.antlers.html --> <a aria-label="Logo Ceres" href="/" > <img src="/visuals/logo-dark.svg" class="select-none " width="" alt="Ceres"/> </a> <!-- End: /components/_logo.antlers.html --> <div class="flex flex-row items-center gap-5"> <button title="Search" aria-label="Search" class="inline-block lg:hidden" @click="isSearchOpen = !isSearchOpen;"> <svg width="20" height="20" class="cursor-pointer" aria-hidden="true" fill="none" stroke="black" viewBox="-1 -1 21 21"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="4" d="m19 19-4-4m0-7A7 7 0 1 1 1 8a7 7 0 0 1 14 0Z"/> </svg> </button> <button type="button" class="inline-flex items-center p-2 w-10 h-10 justify-center text-sm text-white rounded-lg lg:hidden focus:outline-none" aria-controls="mega-menu-full" aria-expanded="false" @click="isMenuOpen = !isMenuOpen; closeAllSubMenus()" @keydown.escape.window="isMenuOpen = false; closeAllSubMenus()" x-bind:aria-expanded="isMenuOpen.toString()" > <span class="sr-only">Open main menu</span> <svg class="w-5 h-5" aria-hidden="true" xmlns="http://www.w3.org/2000/svg" fill="#72c100" viewBox="0 0 17 14"> <path stroke="#9CDD36" stroke-linecap="round" stroke-linejoin="round" stroke-width="3" d="M1 1h15M1 7h15M1 13h15"/> </svg> </button> </div> </div> <div id="mega-menu-full" class="gap-5 items-center justify-between hidden w-full lg:flex lg:w-auto lg:order-1 flex-grow" :class="{ 'hidden': !isMenuOpen }"> <ul id="megaMenuItemList" @click.away=" if (!$event.target.closest('#megaMenuItemList, #megaMenuNavigation')) { activeButton = null; activeSubMenu = null; } " class="flex flex-col mt-4 py-2 font-medium lg:flex-row lg:space-x-8 lg:mt-0"> <li> <button id="mega-menu-button-1" class="flex items-center justify-between w-full py-1 hover:text-black text-black/80 transition-all duration-200 relative group outline-none text-lg font-medium" :class="{ '!text-cw-green-400': activeButton === 'mega-menu-button-1' }" @click="activeButton = activeButton === 'mega-menu-button-1' ? null : 'mega-menu-button-1'; activeSubMenu = activeSubMenu === 'mega-menu-1' ? null : 'mega-menu-1'; activeSection = null" > Our work <span class="absolute w-12 h-0.5 bg-white bottom-0 left-0 group-hover:opacity-100 transition-all duration-200 ease-in-out opacity-0" :class="{ 'opacity-100': activeButton === 'mega-menu-button-1' }"></span> </button> </li> <li> <button id="mega-menu-button-2" class="flex items-center justify-between w-full py-1 hover:text-black text-black/80 transition-all duration-200 relative group outline-none text-lg font-medium" :class="{ '!text-cw-green-400': activeButton === 'mega-menu-button-2' }" @click="activeButton = activeButton === 'mega-menu-button-2' ? null : 'mega-menu-button-2'; activeSubMenu = activeSubMenu === 'mega-menu-2' ? null : 'mega-menu-2'; activeSection = null" > Get involved <span class="absolute w-12 h-0.5 bg-white bottom-0 left-0 group-hover:opacity-100 transition-all duration-200 ease-in-out opacity-0" :class="{ 'opacity-100': activeButton === 'mega-menu-button-2' }"></span> </button> </li> <li> <button id="mega-menu-button-3" class="flex items-center justify-between w-full py-1 hover:text-black text-black/80 transition-all duration-200 relative group outline-none text-lg font-medium" :class="{ '!text-cw-green-400': activeButton === 'mega-menu-button-3' }" @click="activeButton = activeButton === 'mega-menu-button-3' ? null : 'mega-menu-button-3'; activeSubMenu = activeSubMenu === 'mega-menu-3' ? null : 'mega-menu-3'; activeSection = null" > Resources <span class="absolute w-12 h-0.5 bg-white bottom-0 left-0 group-hover:opacity-100 transition-all duration-200 ease-in-out opacity-0" :class="{ 'opacity-100': activeButton === 'mega-menu-button-3' }"></span> </button> </li> <li> <button id="mega-menu-button-4" class="flex items-center justify-between w-full py-1 hover:text-black text-black/80 transition-all duration-200 relative group outline-none text-lg font-medium" :class="{ '!text-cw-green-400': activeButton === 'mega-menu-button-4' }" @click="activeButton = activeButton === 'mega-menu-button-4' ? null : 'mega-menu-button-4'; activeSubMenu = activeSubMenu === 'mega-menu-4' ? null : 'mega-menu-4'; activeSection = null" > About Ceres <span class="absolute w-12 h-0.5 bg-white bottom-0 left-0 group-hover:opacity-100 transition-all duration-200 ease-in-out opacity-0" :class="{ 'opacity-100': activeButton === 'mega-menu-button-4' }"></span> </button> </li> </ul> <div class="flex flex-row items-center gap-6"> <button title="Search" aria-label="Search" class="hidden lg:inline-block" @click=" isSearchOpen = !isSearchOpen; $nextTick(() => { if (isSearchOpen) { requestAnimationFrame(() => { document.getElementById('navSearchField').focus(); }) } }); "> <svg width="20" height="20" class="stroke-black" class="cursor-pointer text-cw-green-400" aria-hidden="true" fill="none" viewBox="-3 -3 24 24"> <path stroke-linecap="round" stroke-linejoin="round" stroke-width="4" d="m19 19-4-4m0-7A7 7 0 1 1 1 8a7 7 0 0 1 14 0Z"/> </svg> </button> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start hidden xl:inline-block bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="#XLXBXUKE" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Donate </div> </a> <!-- End: /components/_button.antlers.html --> <script> <a href="#XLXBXUKE" style="display: none"></a> </script> </div> </div> </div> </div> <div class="w-full bg-white p-5" x-show="isSearchOpen" x-cloak> <div class="container"> <form action="/search" class="" x-data="{ query: '' }"> <label for="nav-search" class="mb-2 text-sm font-medium sr-only">Search</label> <div class="relative flex flex-row gap-2 items-center"> <input id="navSearchField" type="search" name="q" class="bg-transparent border-cw-green-800 w-full focus:border-cw-green-800 rounded-md py-3 px-6" placeholder="Search" autocomplete="off" x-model="query" > <div x-bind:class="{'opacity-50': query.trim() === ''}"> <button type="submit" class="py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start inline-block bg-cw-green-200 font-bold text-white text-lg" :disabled="query.trim() === ''" x-bind:class="{'cursor-not-allowed opacity-50': query.trim() === ''}" x-bind:aria-disabled="query.trim() === ''" > <div class="flex flex-row text-center items-center justify-center gap-2"> Search </div> </button> </div> </div> </form> </div> </div> <div class="absolute w-full z-[300]"> <div class="lg:container bg-white lg:bg-transparent [&_a]:before:hidden [&_a]:md:before:block [&_a]:relative [&_a]:before:opacity-0 [&_a]:before:transition-opacity hover:[&_a]:before:opacity-100 [&_a]:before:bg-cw-green-150/10 [&_a]:before:w-[calc(100%+1.5rem)] [&_a]:before:h-full [&_a]:before:absolute [&_a]:before:rounded-md [&_a]:before:-left-3"> <div id="megaMenuNavigation" class="container md:max-w-full md:px-0 pb-2 lg:pb-0 overflow-hidden"> <div id="mega-menu-1" class="bg-white hidden" :class="{ 'hidden': activeSubMenu !== 'mega-menu-1' }"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 relative gap-0 col-span-full "> <span class="hidden md:block absolute bg-gradient-to-b from-black/20 to-transparent top-0 w-full h-2 z-50"></span> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 col-span-full md:col-span-8 md:gap-x-4 lg:gap-x-8 xl:gap-x-16 pt-6 md:px-8 lg:py-10 "> <div class="col-span-full md:col-span-4"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'help-our-work-0' ? null : 'help-our-work-0'" class="mb-5 md:mb-0 col-span-full lg:col-span-3 pb-2 border-b-2 border-black text-sm cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed text-base">Issues we work on</p> <!-- End: /typography/_p.antlers.html --> </div> <div :class="activeSection === 'help-our-work-0' ? 'max-h-[1200px]' : 'max-h-0'" class="transition-all duration-500 ease-in-out col-span-3 overflow-hidden md:overflow-visible md:max-h-full"> <div class="flex flex-col gap-3 md:gap-2"> <a href="/climate" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="block py-1 md:py-3 group before:top-1 leading-tight"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Climate crisis</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Advancing climate solutions for a zero emissions future.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/nature" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="block py-1 md:py-3 group before:top-1 leading-tight"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Nature and biodiversity loss</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Restoring and preserving our natural ecosystems.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/water" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="block py-1 md:py-3 group before:top-1 leading-tight"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Water scarcity and pollution</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Protecting our precious global water resources.</p> <!-- End: /typography/_p.antlers.html --> </a> </div> </div> </div> </div> <div class="col-span-full md:col-span-8"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'know-our-work-0' ? null : 'know-our-work-0'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Sectors we work in</p> <!-- End: /typography/_p.antlers.html --> </div> <div :class="activeSection === 'know-our-work-0' ? 'max-h-[1200px]' : 'max-h-0'" class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 md:gap-y-2 gap-y-3 lg:gap-x-8 "> <a href="/banking" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Banking</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Financing the transition to a low-carbon economy.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/food" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Food and beverage</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Building a more just and sustainable food system.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/oil-and-gas" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Oil and gas</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Transitioning away from fossil fuels.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/transportation" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Transportation</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Cutting emissions and driving innovation.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/steel" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Steel</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Reducing climate impacts in the built environment.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/electric-power" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Electric power</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Transforming the electric utility landscape.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/accelerator/insurance" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Insurance</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Addressing risk and seizing new opportunities.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/sectors" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">More sectors</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">We work across nearly all sectors of the economy.</p> <!-- End: /typography/_p.antlers.html --> </a> </div> </div> </div> </div> </div> <div class=" gap-0 col-span-full md:col-span-4 relative pb-6 md:px-8 md:pt-6 lg:py-10 md:bg-cw-green-50 " > <div class="relative"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'latest-our-work-0' ? null : 'latest-our-work-0'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Latest resources</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out" :class="activeSection === 'latest-our-work-0' ? 'max-h-[1200px]' : 'max-h-0'"> <div class="flex flex-col gap-1 md:gap-5"> <a href="/resources/reports/ceres-10-point-plan-for-the-insurance-industry" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/istock-2075186172.jpg/19fd11180f4f3bfef44b97eb8984ea78/istock-2075186172.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Ceres 10-Point Plan for the Insurance Industry </h4> </div> </div> </div> </a> <a href="/resources/reports/benchmarking-air-emissions-of-the-100-largest-electric-power-producers-in-the-united-states" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_621084085.jpeg/3ffa4a6289808eca93d9fac90b0b0c2d/adobestock_621084085.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Benchmarking Air Emissions of the 100 Largest Electric Power Producers in the United States </h4> </div> </div> </div> </a> </div> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed mb-5 md:mb-0 pb-2 border-b-2 border-black">Quick finds</p> <!-- End: /typography/_p.antlers.html --> <div class="flex flex-row md:flex-col gap-5 md:gap-4 justify-between md:justify-start hover:[&_a]:text-cw-green-250"> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="https://www.ceres.org/support" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Support our work</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/resources/news" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">News and insights</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/events" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Events and webinars</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> </div> </div> </div> </div> <span class="bg-cw-green-200 hidden lg:block absolute left-0 right-0 bottom-0 py-2 text-white"></span> </div> </div> <div id="mega-menu-2" class="bg-white hidden" :class="{ 'hidden': activeSubMenu !== 'mega-menu-2' }"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 relative gap-0 col-span-full "> <span class="hidden md:block absolute bg-gradient-to-b from-black/20 to-transparent top-0 w-full h-2 z-50"></span> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 col-span-full md:col-span-8 md:gap-x-4 lg:gap-x-8 xl:gap-x-16 pt-6 md:px-8 lg:py-10 "> <div class="col-span-full md:col-span-4"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'help-get-involved-1' ? null : 'help-get-involved-1'" class="mb-5 md:mb-0 col-span-full lg:col-span-3 pb-2 border-b-2 border-black text-sm cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed text-base">Who we work with</p> <!-- End: /typography/_p.antlers.html --> </div> <div :class="activeSection === 'help-get-involved-1' ? 'max-h-[1200px]' : 'max-h-0'" class="transition-all duration-500 ease-in-out col-span-3 overflow-hidden md:overflow-visible md:max-h-full"> <div class="flex flex-col gap-3 md:gap-2"> <a href="/get-involved#investors" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="block py-1 md:py-3 group before:top-1 leading-tight"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Investors</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">We work with leading asset managers and owners, public pension funds, and more.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/get-involved#companies" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="block py-1 md:py-3 group before:top-1 leading-tight"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Companies</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">We work with leading companies, including many Fortune 500 companies.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/get-involved#small-to-mid-size-enterprises" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="block py-1 md:py-3 group before:top-1 leading-tight"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Small and midsize enterprises</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">We provide resources to support SMEs on their sustainability journey.</p> <!-- End: /typography/_p.antlers.html --> </a> </div> </div> </div> </div> <div class="col-span-full md:col-span-8"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'know-get-involved-1' ? null : 'know-get-involved-1'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Ways to get involved</p> <!-- End: /typography/_p.antlers.html --> </div> <div :class="activeSection === 'know-get-involved-1' ? 'max-h-[1200px]' : 'max-h-0'" class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 md:gap-y-2 gap-y-3 lg:gap-x-8 "> <a href="/networks" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Join a network</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Learn more about our powerful investor, company, and policy networks.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/get-involved/initiatives" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Join an initiative</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Explore initiatives, working groups, and advocacy opportunities.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/get-involved/sponsors" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Become a sponsor</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Maximize your impact with premium benefits across the year.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/events" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Attend an event</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Engage with leading business and sustainability experts virtually and in-person.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/support" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Ways to give</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Your donation can help ensure a just and sustainable future.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/subscribe" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-6 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Subscribe</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Sign up for the latest news and updates from Ceres.</p> <!-- End: /typography/_p.antlers.html --> </a> </div> </div> </div> </div> </div> <div class=" gap-0 col-span-full md:col-span-4 relative pb-6 md:px-8 md:pt-6 lg:py-10 md:bg-cw-green-50 " > <div class="relative"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'latest-get-involved-1' ? null : 'latest-get-involved-1'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Latest resources</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out" :class="activeSection === 'latest-get-involved-1' ? 'max-h-[1200px]' : 'max-h-0'"> <div class="flex flex-col gap-1 md:gap-5"> <a href="/resources/reports/ceres-10-point-plan-for-the-insurance-industry" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/istock-2075186172.jpg/19fd11180f4f3bfef44b97eb8984ea78/istock-2075186172.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Ceres 10-Point Plan for the Insurance Industry </h4> </div> </div> </div> </a> <a href="/resources/reports/benchmarking-air-emissions-of-the-100-largest-electric-power-producers-in-the-united-states" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_621084085.jpeg/3ffa4a6289808eca93d9fac90b0b0c2d/adobestock_621084085.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Benchmarking Air Emissions of the 100 Largest Electric Power Producers in the United States </h4> </div> </div> </div> </a> </div> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed mb-5 md:mb-0 pb-2 border-b-2 border-black">Quick finds</p> <!-- End: /typography/_p.antlers.html --> <div class="flex flex-row md:flex-col gap-5 md:gap-4 justify-between md:justify-start hover:[&_a]:text-cw-green-250"> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="https://www.ceres.org/support" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Support our work</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/resources/news" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">News and insights</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/events" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Events and webinars</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> </div> </div> </div> </div> <span class="bg-cw-green-200 hidden lg:block absolute left-0 right-0 bottom-0 py-2 text-white"></span> </div> </div> <div id="mega-menu-3" class="bg-white hidden" :class="{ 'hidden': activeSubMenu !== 'mega-menu-3' }"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 relative gap-0 col-span-full "> <span class="hidden md:block absolute bg-gradient-to-b from-black/20 to-transparent top-0 w-full h-2 z-50"></span> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 col-span-full md:col-span-8 md:gap-x-4 lg:gap-x-8 xl:gap-x-16 pt-6 md:px-8 lg:py-10 "> <div class="col-span-full "> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'know-resources-2' ? null : 'know-resources-2'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Select a resource</p> <!-- End: /typography/_p.antlers.html --> </div> <div :class="activeSection === 'know-resources-2' ? 'max-h-[1200px]' : 'max-h-0'" class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 md:gap-y-2 gap-y-3 lg:gap-x-8 "> <a href="/resources/reports" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Reports</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">View our cutting-edge research and analysis to learn about sustainability risks, opportunities, and solutions.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/resources/assessments" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Benchmarks and assessments</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">See the progress businesses are making toward their sustainability goals.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/events" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Events and webinars</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Hear from leading business and sustainability experts virtually and in-person.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/resources/news" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">News and insights</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Read our latest press releases and statements and expert commentary.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/resources/tools" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Tools</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Use our interactive tools to support your company or investment firm’s sustainability journey.</p> <!-- End: /typography/_p.antlers.html --> </a> </div> </div> </div> </div> <a href="/resources" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="w-fit min-w-24 h-fit py-2 before:top-0.5 hidden md:block"> <div class="flex flex-row items-center gap-3 pb-2 relative after:absolute after:h-0.5 after:w-24 after:bg-cw-green-800 after:bottom-0 mb-4 md:mb-0"> <!-- /typography/_h3.antlers.html --> <h3 class="text-base font-semibold text-nowrap">View all resources</h3> <!-- End: /typography/_h3.antlers.html --> <svg class="w-[10px] h-[10px] inline fill-black" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> </div> <div class=" gap-0 col-span-full md:col-span-4 relative pb-6 md:px-8 md:pt-6 lg:py-10 md:bg-cw-green-50 " > <div class="relative"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'latest-resources-2' ? null : 'latest-resources-2'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Latest resources</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out" :class="activeSection === 'latest-resources-2' ? 'max-h-[1200px]' : 'max-h-0'"> <div class="flex flex-col gap-1 md:gap-5"> <a href="/resources/reports/ceres-10-point-plan-for-the-insurance-industry" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/istock-2075186172.jpg/19fd11180f4f3bfef44b97eb8984ea78/istock-2075186172.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Ceres 10-Point Plan for the Insurance Industry </h4> </div> </div> </div> </a> <a href="/resources/reports/benchmarking-air-emissions-of-the-100-largest-electric-power-producers-in-the-united-states" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_621084085.jpeg/3ffa4a6289808eca93d9fac90b0b0c2d/adobestock_621084085.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Benchmarking Air Emissions of the 100 Largest Electric Power Producers in the United States </h4> </div> </div> </div> </a> </div> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed mb-5 md:mb-0 pb-2 border-b-2 border-black">Quick finds</p> <!-- End: /typography/_p.antlers.html --> <div class="flex flex-row md:flex-col gap-5 md:gap-4 justify-between md:justify-start hover:[&_a]:text-cw-green-250"> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="https://www.ceres.org/support" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Support our work</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/resources/news" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">News and insights</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/events" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Events and webinars</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> </div> </div> </div> </div> <span class="bg-cw-green-200 hidden lg:block absolute left-0 right-0 bottom-0 py-2 text-white"></span> </div> <a href="/resources" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="w-fit visible md:hidden"> <div class="flex flex-row items-center gap-3 pb-3 relative after:absolute after:h-0.5 after:w-24 after:bg-cw-green-800 after:bottom-0 mb-4 md:mb-0"> <!-- /typography/_h3.antlers.html --> <h3 class="text-base font-semibold">View all resources</h3> <!-- End: /typography/_h3.antlers.html --> <svg class="w-[10px] h-[10px] inline fill-black" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> </div> <div id="mega-menu-4" class="bg-white hidden" :class="{ 'hidden': activeSubMenu !== 'mega-menu-4' }"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 relative gap-0 col-span-full "> <span class="hidden md:block absolute bg-gradient-to-b from-black/20 to-transparent top-0 w-full h-2 z-50"></span> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 col-span-full md:col-span-8 md:gap-x-4 lg:gap-x-8 xl:gap-x-16 pt-6 md:px-8 lg:py-10 "> <div class="col-span-full "> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'know-about-ceres-3' ? null : 'know-about-ceres-3'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Learn more about us</p> <!-- End: /typography/_p.antlers.html --> </div> <div :class="activeSection === 'know-about-ceres-3' ? 'max-h-[1200px]' : 'max-h-0'" class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 md:gap-y-2 gap-y-3 lg:gap-x-8 "> <a href="/about" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Who we are</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Learn about our mission, our history, and our values.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/about/leadership" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Leadership</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Meet our board of directors, president’s council, and leadership staff.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/about/experts" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Experts</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Meet our leading experts with deep subject matter expertise and knowledge.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/networks" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Our members</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Learn more about the investors and companies we work with.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/careers" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Careers</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Join our growing team to help make our mission a reality.</p> <!-- End: /typography/_p.antlers.html --> </a> <a href="/about/annual-report" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="tracking-tight block col-span-full py-1 md:py-3 before:top-1 md:col-span-4 group"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold mb-2 text-base transition-colors group-hover:text-cw-green-200">Annual Report</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed leading-tight">Read about our impact and the progress we’ve made thanks to supporters.</p> <!-- End: /typography/_p.antlers.html --> </a> </div> </div> </div> </div> <a href="/about" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="w-fit min-w-24 h-fit py-2 before:top-0.5 hidden md:block"> <div class="flex flex-row items-center gap-3 pb-2 relative after:absolute after:h-0.5 after:w-24 after:bg-cw-green-800 after:bottom-0 mb-4 md:mb-0"> <!-- /typography/_h3.antlers.html --> <h3 class="text-base font-semibold text-nowrap">See all about Ceres</h3> <!-- End: /typography/_h3.antlers.html --> <svg class="w-[10px] h-[10px] inline fill-black" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> </div> <div class=" gap-0 col-span-full md:col-span-4 relative pb-6 md:px-8 md:pt-6 lg:py-10 md:bg-cw-green-50 " > <div class="relative"> <div class="flex flex-col gap-0 md:gap-5"> <div @click="activeSection = activeSection === 'latest-about-ceres-3' ? null : 'latest-about-ceres-3'" class="mb-5 md:mb-0 pb-2 border-b-2 border-black cursor-pointer md:cursor-default"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Latest resources</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="md:max-h-full overflow-hidden md:overflow-visible transition-all duration-500 ease-in-out" :class="activeSection === 'latest-about-ceres-3' ? 'max-h-[1200px]' : 'max-h-0'"> <div class="flex flex-col gap-1 md:gap-5"> <a href="/resources/reports/ceres-10-point-plan-for-the-insurance-industry" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/istock-2075186172.jpg/19fd11180f4f3bfef44b97eb8984ea78/istock-2075186172.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Ceres 10-Point Plan for the Insurance Industry </h4> </div> </div> </div> </a> <a href="/resources/reports/benchmarking-air-emissions-of-the-100-largest-electric-power-producers-in-the-united-states" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="py-3 before:top-0"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 mb-5 md:mb-0 "> <div class="col-span-5 relative h-24"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_621084085.jpeg/3ffa4a6289808eca93d9fac90b0b0c2d/adobestock_621084085.webp" alt="" class="w-full h-full object-cover rounded-lg absolute min-h-12"> </div> <div class="flex flex-col col-span-7 gap-2"> <div class="flex flex-col col-span-7 gap-1"> <p class="text-sm uppercase font-semibold text-black/50"> Report </p> <h4 class="leading-tight"> Benchmarking Air Emissions of the 100 Largest Electric Power Producers in the United States </h4> </div> </div> </div> </a> </div> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed mb-5 md:mb-0 pb-2 border-b-2 border-black">Quick finds</p> <!-- End: /typography/_p.antlers.html --> <div class="flex flex-row md:flex-col gap-5 md:gap-4 justify-between md:justify-start hover:[&_a]:text-cw-green-250"> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="https://www.ceres.org/support" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Support our work</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/resources/news" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">News and insights</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> <a class="cursor-pointer py-2 md:py-3 rounded-md w-fit relative before:top-0" href="/events" > <div class="flex flex-row gap-2 items-center relative"> <!-- /typography/_h3.antlers.html --> <h3 class="font-semibold text-base">Events and webinars</h3> <!-- End: /typography/_h3.antlers.html --> </div> </a> </div> </div> </div> </div> <span class="bg-cw-green-200 hidden lg:block absolute left-0 right-0 bottom-0 py-2 text-white"></span> </div> <a href="/about" @click="if ($event.target.href.includes('#')) isMenuOpen = false; closeAllSubMenus();" class="w-fit visible md:hidden"> <div class="flex flex-row items-center gap-3 pb-3 relative after:absolute after:h-0.5 after:w-24 after:bg-cw-green-800 after:bottom-0 mb-4 md:mb-0"> <!-- /typography/_h3.antlers.html --> <h3 class="text-base font-semibold">See all about Ceres</h3> <!-- End: /typography/_h3.antlers.html --> <svg class="w-[10px] h-[10px] inline fill-black" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> </div> </div> </div> </div> <span class="fixed w-full top-0 h-full bg-black/50 z-[80] opacity-0 transition-opacity pointer-events-none" :class="activeSubMenu ? 'opacity-100' : null"></span> </nav> <script> let currentOpenMenu; [...document.querySelectorAll("[data-collapse-toggle]")].forEach((button) => { button.addEventListener('click', (event) => { const targetId = event.currentTarget.getAttribute('data-collapse-toggle'); const targetElem = document.getElementById(targetId); // If there is a currently open menu and it's not the one being clicked, hide it if (currentOpenMenu && currentOpenMenu !== targetElem) { currentOpenMenu.classList.add('hidden'); } // If the clicked menu is already open, hide it. Otherwise, show it. if (targetElem === currentOpenMenu) { targetElem.classList.add('hidden'); currentOpenMenu = null; } else if (targetElem) { targetElem.classList.remove('hidden'); currentOpenMenu = targetElem; } }); }); </script> <!-- /default.antlers.html --> <main id="content"> <!-- /page_builder/_hero_banner.antlers.html --> <section class="bg-cw-green-800 text-white overflow-hidden"> <div x-data="{ translateX: 0 }" x-init="() => { function updateTranslate() { let containerWidth = $el.offsetWidth; let containerPaddingRight = parseInt(window.getComputedStyle($el).paddingRight, 10); let screenWidth = window.innerWidth; translateX = (screenWidth - containerWidth) / 2 + containerPaddingRight; } updateTranslate(); window.addEventListener('resize', updateTranslate); return () => window.removeEventListener('resize', updateTranslate); }" class="container relative z-50"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 relative "> <div class="flex flex-col lg:col-span-7 py-12 justify-center col-span-full gap-4 sm:gap-8 z-20"> <h1 class="text-5xl xl:text-[81px] font-bold leading-[107%] [&_p]:inline [&_p_>_span]:font-semibold"> <span class="text-color" style="color: #84cc16">Sustainability</span> is the bottom line </h1> <div class="flex flex-col gap-8"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed text-xl lg:text-2xl">Ceres is a nonprofit advocacy organization working to accelerate the transition to a cleaner, more just, and sustainable economy. With powerful networks of investors and companies, we are proving sustainability is the bottom line – changing markets and sectors from the inside out. </p> <!-- End: /typography/_p.antlers.html --> <!-- /components/_button.antlers.html --> <!-- End: /components/_button.antlers.html --> </div> </div> <div class="col-span-5 absolute min-h-[30dvh] lg:relative w-full h-full md:block"> <div class="absolute right-0 h-full"> <img src="https://assets.ceres.org/cache/containers/images/ceres_mark_positive_xl_2024px-1715624927.png/58ca992bbb6d3bf727e48cef48aaa870.webp" alt="Ceres logo" alt="Ceres logo" class="hidden lg:block w-full h-full object-cover opacity-20 lg:opacity-100" :style="{transform: 'translateX(' + translateX + 'px)'}"/> </div> </div> </div> </div> <!-- /page_builder/_information_cards.antlers.html --> <section class="relative z-20 sm:pt-0 bg-white text-black "> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 before:w-full before:h-40 before:bg-cw-green-800 before:absolute before:-z-10 before:left-0 before:-translate-y-[4.25rem] container py-16 "> <div class="p-4 md:p-6 rounded flex flex-col gap-3 shadow-cards text-black z-20 col-span-12 md:col-span-6 lg:col-span-4 bg-white text-black "> <div x-data="{ count: 0, // Initialize the count as 0 countText: '', // Initialize the text representation of the count start: 0, // This will be your starting number end: 200, // This will be your ending number duration: 3000, // This represents the duration of the count animation in milliseconds showDecimals: false // This boolean variable determines whether to show decimals or not }" x-intersect.full.once=" () => { count = start; // Assign the starting number to count // Check if both start and end are integers. If either one is not an integer, set showDecimals to true showDecimals = !(Number.isInteger(start) && Number.isInteger(end)); let startTimestamp = null; // This will be used to track the starting timestamp of the animation // Cubic easing function for a smooth count up const easeOutCubic = t => (--t) * t * t + 1; // This function will run for each frame of the animation let step = timestamp => { // Set the start timestamp for the first frame if(!startTimestamp) startTimestamp = timestamp; // Calculate the progress of the animation, capped at 1 const progress = Math.min((timestamp - startTimestamp) / duration, 1); // Update count based on the progress. The count will smoothly increase from start to end count = start + (end - start) * easeOutCubic(progress); // Update the text representation of the count countText = showDecimals ? count.toFixed(1) : Math.round(count); // Request the next frame of the animation if the progress hasn't reached 1 if(progress < 1) requestAnimationFrame(step); }; // Start the animation requestAnimationFrame(step); } "> <h3 class="text-5xl md:text-6xl text-cw-green-200 font-bold"> <span class="font-black"> <span x-text="countText.toLocaleString()"></span>+ </span> </h3> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">investors with $44T in AUM comprise our Investor Network. They are committed to responsible investment practices that ensure long-term value.</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="p-4 md:p-6 rounded flex flex-col gap-3 shadow-cards text-black z-20 col-span-12 md:col-span-6 lg:col-span-4 bg-white text-black "> <div x-data="{ count: 0, // Initialize the count as 0 countText: '', // Initialize the text representation of the count start: 0, // This will be your starting number end: 70, // This will be your ending number duration: 3000, // This represents the duration of the count animation in milliseconds showDecimals: false // This boolean variable determines whether to show decimals or not }" x-intersect.full.once=" () => { count = start; // Assign the starting number to count // Check if both start and end are integers. If either one is not an integer, set showDecimals to true showDecimals = !(Number.isInteger(start) && Number.isInteger(end)); let startTimestamp = null; // This will be used to track the starting timestamp of the animation // Cubic easing function for a smooth count up const easeOutCubic = t => (--t) * t * t + 1; // This function will run for each frame of the animation let step = timestamp => { // Set the start timestamp for the first frame if(!startTimestamp) startTimestamp = timestamp; // Calculate the progress of the animation, capped at 1 const progress = Math.min((timestamp - startTimestamp) / duration, 1); // Update count based on the progress. The count will smoothly increase from start to end count = start + (end - start) * easeOutCubic(progress); // Update the text representation of the count countText = showDecimals ? count.toFixed(1) : Math.round(count); // Request the next frame of the animation if the progress hasn't reached 1 if(progress < 1) requestAnimationFrame(step); }; // Start the animation requestAnimationFrame(step); } "> <h3 class="text-5xl md:text-6xl text-cw-green-200 font-bold"> <span class="font-black"> <span x-text="countText.toLocaleString()"></span>% </span> </h3> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">of our Company Network members are Fortune 500 firms advancing sustainable business practices that improve their bottom line and protect the planet.</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="p-4 md:p-6 rounded flex flex-col gap-3 shadow-cards text-black z-20 col-span-12 md:col-span-6 lg:col-span-4 bg-white text-black "> <div x-data="{ count: 0, // Initialize the count as 0 countText: '', // Initialize the text representation of the count start: 0, // This will be your starting number end: 80, // This will be your ending number duration: 3000, // This represents the duration of the count animation in milliseconds showDecimals: false // This boolean variable determines whether to show decimals or not }" x-intersect.full.once=" () => { count = start; // Assign the starting number to count // Check if both start and end are integers. If either one is not an integer, set showDecimals to true showDecimals = !(Number.isInteger(start) && Number.isInteger(end)); let startTimestamp = null; // This will be used to track the starting timestamp of the animation // Cubic easing function for a smooth count up const easeOutCubic = t => (--t) * t * t + 1; // This function will run for each frame of the animation let step = timestamp => { // Set the start timestamp for the first frame if(!startTimestamp) startTimestamp = timestamp; // Calculate the progress of the animation, capped at 1 const progress = Math.min((timestamp - startTimestamp) / duration, 1); // Update count based on the progress. The count will smoothly increase from start to end count = start + (end - start) * easeOutCubic(progress); // Update the text representation of the count countText = showDecimals ? count.toFixed(1) : Math.round(count); // Request the next frame of the animation if the progress hasn't reached 1 if(progress < 1) requestAnimationFrame(step); }; // Start the animation requestAnimationFrame(step); } "> <h3 class="text-5xl md:text-6xl text-cw-green-200 font-bold"> <span class="font-black"> <span x-text="countText.toLocaleString()"></span>+ </span> </h3> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">well-known brands make up our Policy Network. They advocate for innovative policies and regulations that support a more resilient and inclusive economy.</p> <!-- End: /typography/_p.antlers.html --> </div> </div> </section> <!-- End: /page_builder/_information_cards.antlers.html --> </section> <!-- End: /page_builder/_hero_banner.antlers.html --> <!-- class="absolute bottom-0 -translate-y-[90%] translate-x-1 xl:-translate-y-[130%]" --> <!-- /page_builder/_accordion_with_image.antlers.html --> <section class="bg-white text-black "> <div class="container py-16"> <div class="flex flex-col gap-8"> <div class="flex flex-col gap-2"> <!-- /typography/_h3.antlers.html --> <h3 class="font-bold text-4xl">Issues we work on</h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed md:max-w-4xl text-md">For more than 35 years, Ceres has been at the forefront of building business leadership and driving economic solutions to help solve the world’s greatest sustainability challenges.</p> <!-- End: /typography/_p.antlers.html --> </div> <div><section x-data="{ activeTab: 0 }" class="h-full"> <div class=" flex flex-col h-full"> <div class=" grid grid-cols-1 lg:grid-cols-2"> <div> <div :class="activeTab !== 0 && '!border-b-cw-green-100'" class="border-b-2 border-b-cw-green-800" > <button x-on:click.prevent="activeTab = 0" type="button" class="flex items-center text-left justify-between w-full p-5" data-accordion-target="#accordion-collapse-body-1" aria-expanded="true" aria-controls="accordion-collapse-body-1" > <!-- /typography/_h2.antlers.html --> <h2 class="text-2xl font-bold leading-tight">Climate crisis</h2> <!-- End: /typography/_h2.antlers.html --> <svg width="18" height="12" viewBox="0 0 18 12" fill="none" class="duration-500 ease-in-out" x-bind:style="activeTab === 0 && 'rotate: 180deg'" > <path d="M16 2L9 9L2 2" stroke="black" stroke-width="3" /> </svg> </button> <div x-show="activeTab === 0" x-cloak id="accordion-collapse-body-1" aria-labelledby="accordion-collapse-heading-1" class="p-5 flex flex-col gap-5" > <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">We work with investors, companies, and policymakers to advance climate solutions and achieve a just and sustainable future where people and the planet prosper.</p> <!-- End: /typography/_p.antlers.html --> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex rounded-full select-none whitespace-nowrap items-start self-start py-2 px-0 opacity-50 bg-none text-black stroke-black fill-black <!-- Adds extra space for mobile browsers to click on links if button requires it. --> relative before:w-full before:h-full before:py-6 before:absolute before:top-1/2 before:-translate-y-1/2 md:before:hidden " href="/climate" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Learn more <svg width="14" height="14" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> <div :class="activeTab !== 1 && '!border-b-cw-green-100'" class="border-b-2 border-b-cw-green-800" > <button x-on:click.prevent="activeTab = 1" type="button" class="flex items-center text-left justify-between w-full p-5" data-accordion-target="#accordion-collapse-body-1" aria-expanded="true" aria-controls="accordion-collapse-body-1" > <!-- /typography/_h2.antlers.html --> <h2 class="text-2xl font-bold leading-tight">Nature and biodiversity loss</h2> <!-- End: /typography/_h2.antlers.html --> <svg width="18" height="12" viewBox="0 0 18 12" fill="none" class="duration-500 ease-in-out" x-bind:style="activeTab === 1 && 'rotate: 180deg'" > <path d="M16 2L9 9L2 2" stroke="black" stroke-width="3" /> </svg> </button> <div x-show="activeTab === 1" x-cloak id="accordion-collapse-body-1" aria-labelledby="accordion-collapse-heading-1" class="p-5 flex flex-col gap-5" > <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">We work across sectors to protect and restore natural ecosystems, improve the management of agricultural lands, and build more sustainable and resilient supply chains—all in a way that advances justice and equity.</p> <!-- End: /typography/_p.antlers.html --> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex rounded-full select-none whitespace-nowrap items-start self-start py-2 px-0 opacity-50 bg-none text-black stroke-black fill-black <!-- Adds extra space for mobile browsers to click on links if button requires it. --> relative before:w-full before:h-full before:py-6 before:absolute before:top-1/2 before:-translate-y-1/2 md:before:hidden " href="/nature" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Learn more <svg width="14" height="14" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> <div :class="activeTab !== 2 && '!border-b-cw-green-100'" class="" > <button x-on:click.prevent="activeTab = 2" type="button" class="flex items-center text-left justify-between w-full p-5" data-accordion-target="#accordion-collapse-body-1" aria-expanded="true" aria-controls="accordion-collapse-body-1" > <!-- /typography/_h2.antlers.html --> <h2 class="text-2xl font-bold leading-tight">Water scarcity and pollution</h2> <!-- End: /typography/_h2.antlers.html --> <svg width="18" height="12" viewBox="0 0 18 12" fill="none" class="duration-500 ease-in-out" x-bind:style="activeTab === 2 && 'rotate: 180deg'" > <path d="M16 2L9 9L2 2" stroke="black" stroke-width="3" /> </svg> </button> <div x-show="activeTab === 2" x-cloak id="accordion-collapse-body-1" aria-labelledby="accordion-collapse-heading-1" class="p-5 flex flex-col gap-5" > <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">We work with investors and companies to turn smart water management into a business fundamental, advancing private-sector action to address the impacts of growing demand, wasteful use, and pollution.</p> <!-- End: /typography/_p.antlers.html --> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex rounded-full select-none whitespace-nowrap items-start self-start py-2 px-0 opacity-50 bg-none text-black stroke-black fill-black <!-- Adds extra space for mobile browsers to click on links if button requires it. --> relative before:w-full before:h-full before:py-6 before:absolute before:top-1/2 before:-translate-y-1/2 md:before:hidden " href="/water" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Learn more <svg width="14" height="14" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> </div> <div> <div class="h-full relative" x-show="activeTab === 0" x-cloak > <img src="https://assets.ceres.org/cache/containers/images/new-climate.jpeg/27ee6e24ebf624acd2fc4ba326c6dc7f.webp" alt="Melting arctic glaciers" class="object-cover w-full h-full absolute hidden lg:block" /> </div> <div class="h-full relative" x-show="activeTab === 1" x-cloak > <img src="https://assets.ceres.org/cache/containers/images/nature-loss-homepage.jpeg/e08c88ca1fc6f11f88f0c3c1f74532ac.webp" alt="fresh green Siamese Rosewood sapling growth in plant nursery,reforestation concept." class="object-cover w-full h-full absolute hidden lg:block" /> </div> <div class="h-full relative" x-show="activeTab === 2" x-cloak > <img src="https://assets.ceres.org/cache/containers/images/vwfi-water-banner.png/c588ec0d139bb9460a1c4ec915780ab2.webp" alt="Pipe dispersing water" class="object-cover w-full h-full absolute hidden lg:block" /> </div> </div> </div> </div> </section> </div> </div> </div> </section> <!-- End: /page_builder/_accordion_with_image.antlers.html --> <!-- /page_builder/_expert_list.antlers.html --> <section class="bg-white text-black "> <div class="container py-16"> <div id="issue-experts" class="flex flex-col gap-4 pb-4"> <!-- /typography/_h2.antlers.html --> <h2 class="font-bold text-4xl">Issue experts</h2> <!-- End: /typography/_h2.antlers.html --> <div class="flex flex-col justify-between md:flex-row gap-4"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed md:max-w-[70%]">Our leading experts ground their work in research and science to make the business case for sustainability and drive meaningful change across the economy.</p> <!-- End: /typography/_p.antlers.html --> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/about/experts" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> See all experts <svg width="14" height="14" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> <div class="flex gap-6 overflow-x-auto overflow-y-hidden themed-scrollbar px-4 [&>div]:my-6 [&>a]:my-6 md:[&>div]:w-64 md:[&>a]:w-64"> <a href="/people/bakal" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/bakal.jpg/b81ecb866d3ad905eb5176f350016095.webp" alt="Bakal head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Dan Bakal</h3> <p>Senior Program Director, Climate and Energy</p> </div> </div> </a> <a href="/people/bateson" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/bateson_updated.jpg/0fb4d2a94501b10287d92735d995b9c2.webp" alt="Bateson head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Blair Bateson</h3> <p>Director, Company Network, Financial Services</p> </div> </div> </a> <a href="/people/berridge" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/berridge.jpg/8835af2ddd4a55849ea397e7315e37df.webp" alt="Berridge head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Rob Berridge</h3> <p>Senior Director, Investor Network, Shareholder Engagement</p> </div> </div> </a> <a href="/people/boudett" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/boudett.png/2e5e38ab06829f7d5dd6eb7a777cd0da.webp" alt="Boudett head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Michael Boudett</h3> <p>General Counsel</p> </div> </div> </a> <a href="/people/ching" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/ching.jpg/c813c184f8048d7e00467cd4fe837a05.webp" alt="Ching head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Carolyn Ching</h3> <p>Director, Food and Forests, Research</p> </div> </div> </a> <a href="/people/clarke" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/clarke.png/e81ce6223a58291a9f95f85ec528e6fa.webp" alt="Clarke head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Steven Clarke</h3> <p>Program Director, Climate and Energy</p> </div> </div> </a> <a href="/people/coburn" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/coburn-1703031557.jpg/a0766b4445e0233c8755094120726bf1.webp" alt="Coburn head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Jim Coburn</h3> <p>Senior Manager, Ceres Accelerator, Disclosure and Regulation</p> </div> </div> </a> <a href="/people/collins" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/collins_updated.jpeg/147f084e9773b95a5a9a47cddc6848ab.webp" alt="Collins head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Siobhan Collins</h3> <p>Director, Company Network</p> </div> </div> </a> <a href="/people/draucker" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/draucker.jpg/61ce672104460d5d775f3916bc289584.webp" alt="Draucker Ph.D. head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Laura Draucker Ph.D.</h3> <p>Senior Director, Corporate Climate Action</p> </div> </div> </a> <a href="/people/ellsworth" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/ellsworth.jpg/f4d18fd2eaf1b5f76d7ca223e80a5e34.webp" alt="Ellsworth head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Peter Ellsworth</h3> <p>Senior Director, Investor Network, Private Equity and Paris Aligned Investing</p> </div> </div> </a> <a href="/people/friedman" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/freidman.jpg/f4e34de504cdaf288e7551220f76b6b2.webp" alt="Friedman head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Zach Friedman</h3> <p>Senior Director, Federal Policy</p> </div> </div> </a> <a href="/people/james" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/james.jpg/6a1816057c9c186a9efaa363490ffe16.webp" alt="James head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Kirsten James</h3> <p>Senior Program Director, Water</p> </div> </div> </a> <a href="/people/kelly" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/kelly.jpg/d65455d0889e9cd571ef50b0258a5ab8.webp" alt="Kelly head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Anne L. Kelly</h3> <p>Vice President, Government Relations</p> </div> </div> </a> <a href="/people/kodransky" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/kodransky.jpg/1d51fe80df4231df9724f2a78b6435d4.webp" alt="Kodransky head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Michael Kodransky</h3> <p>Senior Director, Climate and Energy, Transportation</p> </div> </div> </a> <a href="/people/logan" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/logan.jpg/b90f3944d81c29330282d1cef8c507fa.webp" alt="Logan head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Andrew Logan</h3> <p>Senior Director, Climate and Energy, Oil and Gas</p> </div> </div> </a> <a href="/people/mindy-lubber" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/lubber.jpg/01e1a67407948cd0b1b67d23d1705bc3.webp" alt="Lubber head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Mindy Lubber</h3> <p>CEO and President</p> </div> </div> </a> <a href="/people/mail" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/mail.jpg/6be73852f06fcdac7aad58d0637a5899.webp" alt="Mail head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Randi Mail</h3> <p>Director, Ceres Accelerator, Campaigns</p> </div> </div> </a> <a href="/people/mchale" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/mchale.png/39df3d94bf60496f08a453460a6a8440.webp" alt="McHale head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Cynthia McHale</h3> <p>Senior Director, Investor Network, Shareholder Engagement</p> </div> </div> </a> <a href="/people/ormond" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/ormond.jpg/d6f660df98803f8cbdeac1243f17f00b.webp" alt="Ormond head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Mary Ann Ormond</h3> <p>Senior Director, Company Network, Food and Beverage, Retail, Healthcare</p> </div> </div> </a> <a href="/people/perveen" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/perveen.jpg/f3bfd9767cb6671a08f0baa91079186a.webp" alt="Perveen, Ph.D. head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Shama Perveen, Ph.D.</h3> <p>Director, Water, Research</p> </div> </div> </a> <a href="/people/jake-rascoff" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/rascoff.png/dd0214812a82b3e364b39938186735ed.webp" alt="Rascoff head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Jake Rascoff</h3> <p>Director, Ceres Accelerator for Sustainable Capital Markets</p> </div> </div> </a> <a href="/people/richards" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/richards.jpg/1f38a6e42322c3909c8667eabca67418.webp" alt="Richards, Ph.D. head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Meryl Richards, Ph.D.</h3> <p>Program Director, Food and Forests</p> </div> </div> </a> <a href="/people/rothstein" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/rothstein.jpg/057978f9683554eb88f9bd4a59534e56.webp" alt="Rothstein head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Steven Rothstein</h3> <p>Managing Director, Ceres Accelerator</p> </div> </div> </a> <a href="/people/saccardi" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/saccardi.jpg/cad4ab3a1337ff56e0a4611c276636d1.webp" alt="Saccardi head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Dan Saccardi</h3> <p>Program Director, Company Network</p> </div> </div> </a> <a href="/people/seligman" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/seligman.jpg/cb01114c990fb3e891ac4364fb016b30.webp" alt="Seligman head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Dan Seligman</h3> <p>Director, Climate and Energy, Steel</p> </div> </div> </a> <a href="/people/spalding" class="flex flex-col items-center justify-center bg-white transition duration-300 shadow-cards flex-shrink-0 w-full rounded-md hover:shadow-cards-darker"> <div class="flex flex-col h-full flex-shrink-0 text-center gap-2 p-6 items-center"> <div class="rounded-full w-24 h-24 overflow-hidden"> <img src="https://assets.ceres.org/cache/containers/images/headshots/spalding.jpg/371e395f1bab7f5a567ae4a62bc49a1f.webp" alt="Spalding head shot" class="object-cover w-full h-full"/> </div> <div class="[&_p]:mb-0"> <h3 class="font-bold pb-4">Kirsten Spalding</h3> <p>Vice President, Investor Network</p> </div> </div> </a> </div> </div> </section> <!-- End: /page_builder/_expert_list.antlers.html --> <!-- /page_builder/_text_and_image_i.antlers.html --> <section class="bg-cw-green-100 text-black overflow-hidden"> <div class="container" x-data="{ translateX: 0, imagePosition: 'right' }" x-init="() => { function updateTranslate() { let containerWidth = $el.offsetWidth; let containerPaddingRight = parseInt(window.getComputedStyle($el).paddingRight, 10); let screenWidth = window.innerWidth; let calculatedTranslation = (screenWidth - containerWidth) / 2 + containerPaddingRight; // Flip the translation value based on image position translateX = imagePosition === 'left' ? -calculatedTranslation : calculatedTranslation; } updateTranslate(); window.addEventListener('resize', updateTranslate); return () => window.removeEventListener('resize', updateTranslate); }" > <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 "> <div class="col-span-6 row-span-full lg:block hidden col-start-7" :style="'transform: translateX(' + translateX + 'px)'" > <img src="https://assets.ceres.org/cache/containers/images/test-toc.png/0324c15e40f6f365163f473aa5e5411a.webp" alt="Ceres Theory of Change includes investor change, corporate change, and policy and regulatory change that leads to a cleaner, more just and sustainable economy." class="rounded w-full h-full object-cover"/> </div> <div class="flex flex-col gap-8 max-w-1/2 lg:col-span-7 col-span-12 row-span-full py-16 justify-center lg:col-start-1"> <div class="flex flex-col gap-2"> <!-- /typography/_h2.antlers.html --> <h2 class="text-[44px] font-medium leading-[137%]"><strong>Our theory of change</strong></h2> <!-- End: /typography/_h2.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Climate change, water scarcity and pollution, and nature and biodiversity loss are systemic threats that not only harm people and the planet, but also pose risks to investment portfolios, business operations, supply chains, and the long-term stability of markets and economies. While individuals, communities, and policymakers all have key roles to play, investors and companies who have the most influence and impact on our economy are a critical part of the solution. That’s where Ceres comes in.</p> <!-- End: /typography/_p.antlers.html --> </div> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/about" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Learn more </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> </div> </section> <!-- End: /page_builder/_text_and_image_i.antlers.html --> <style> @keyframes logoListScroll { from { transform: translateY(var(--logo-list-scroll-end)) } to { transform: translateY(var(--logo-list-scroll-start)) } } </style> <!-- /page_builder/_logo_soup_rotating.antlers.html --> <section class="bg-white text-black "> <section class="container py-16"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 md:gap-12 "> <div class="flex flex-col lg:col-span-6 col-span-12 items-center justify-center order-last lg:order-first"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-3 gap-8 overflow-hidden max-h-96 relative before:top-0 before:w-full before:h-8 before:absolute before:bg-gradient-to-b before:from-white before:to-transparent before:z-20 after:bottom-0 after:w-full after:h-8 after:absolute after:bg-gradient-to-t after:from-white after:to-transparent after:z-20 hover:pause "> <div class="col-span-1 flex flex-col gap-logo-list logoListScrollReverse" style="animation: logoListScroll 34s linear infinite ;" > <img src="https://assets.ceres.org/images/partner-logos/amazon.svg" alt="Amazon logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/aveda.png/20a2cadeb38a4984ba27fcf0ddcec0d5.webp" alt="Aveda logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/barclays.png/14279d6af315ff645e1e0f23012df6ae.webp" alt="Barclays logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/best-buy.jpeg/f8985b02b3ee9994ca9a3db7f0d4ce3d.webp" alt="Best Buy logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/cvs.png/c9a28b7020441b2ec35f6086e3476a2b.webp" alt="CVS logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/dell.jpg/ce7b25e53754c9bf4ba09703893f3bff.webp" alt="Dell Technologies logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/exelon-logo.png/8db49deabd085f4da77a381265379ec3.webp" alt="Exelon logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/ford_logo_flat.svg" alt="Ford logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/gm.jpeg/84e1dd5ba348e0a7cc811a56faa17bcf.webp" alt="General Motors logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/jll.png/2a44c1a0a94626d79970bddb07389757.webp" alt="JLL logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/lululemon.jpeg/e14d270328035b42b562285e12fc32c0.webp" alt="Lululemon logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/nationalgrid.png/7a8895d08a49e8917632a15eef95d9d9.webp" alt="National Grid logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pnc.png/f909512f9339b12ca004852494c88d73.webp" alt="PNC" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pepsico-logo.png/9d31b6a98b3e032fe728d6c294fa48d0.webp" alt="Pepsico logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/starbucks.png/1a1456f58d041c0569da0b0ff38d1870.webp" alt="Starbucks logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/target.png/5525abee40f78a043c833620de42ffa2.webp" alt="Target logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/wells-fargo.png/ce56cbdac8a3e57bf8269895b7abd12d.webp" alt="Wells Fargo logo" class="col-span-1 object-scale-down h-24 w-full" /> </div> <div class="col-span-1 flex flex-col gap-logo-list logoListScrollForward" style="animation: logoListScroll 34s linear infinite reverse;" > <img src="https://assets.ceres.org/images/partner-logos/amd-1722357328.svg" alt="AMD logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/bank-of-america.png/b2a127177e83b6ecec2c8ea14ce6790b.webp" alt="Bank of America logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/baxter.png/68756d3195113cc6a77498b2f411511a.webp" alt="Baxter logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/bloomberg.png/c1baeab6c22eee2b0b93f58ff39f0562.webp" alt="Bloomberg logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/citi-logo-new.png/69c47fa2ae92221516b0f923d6fde4c4.webp" alt="Citi logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/deloitte.png/026a00489cac8bbdd0b302cdd6e421f4.webp" alt="Deloitte logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/fannie-mae.png/1532f17d277a3aa85e1994f663bd753c.webp" alt="Fannie Mae logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/gap.png/bb61458322f58b172519fb91a0e90b5a.webp" alt="Gap" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/hp.png/8da8ae3c161bb4e35e5c58210e1911f1.webp" alt="HP logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/jp-morgan.png/db1d7714598b4704031b599a0309a0a6.webp" alt="JP Morgan Chase logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/moodys.png/2b61450d8e3059161ca64a5590502a4c.webp" alt="Moody's logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/nike-logo.png/dd627308dbfd79206e185a99396d265d.webp" alt="Nike logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pseg.png/9df45535837f383825ec280c7d121f97.webp" alt="PSEG logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/regions.png/9063cb01dd8676170f6bda3f91e33669.webp" alt="Regions logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/state-street.png/58d45cff6111be9afa47315db6ccae42.webp" alt="State Street logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/truist.png/eeeafc270df35e03899a64dc62cd45fe.webp" alt="Truist logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/gap.png/bb61458322f58b172519fb91a0e90b5a.webp" alt="Gap" class="col-span-1 object-scale-down h-24 w-full" /> </div> <div class="col-span-1 flex flex-col gap-logo-list logoListScrollReverse" style="animation: logoListScroll 34s linear infinite ;" > <img src="https://assets.ceres.org/cache/containers/images/partner-logos/akamai.png/b69742cda688db5b19081589ec910cd5.webp" alt="Akamai logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/apple_logo_black_lg.svg" alt="Apple logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/bmo_logo.svg" alt="Bank of Montreal (BMO)" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/ben-and-jerry.png/ab1b8b9e81d666f521e86f691900e37d.webp" alt="Ben and Jerry's logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/brown-forman.svg" alt="Brown-forman logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/coca-cola.png/5f6d67162fb6dae0346e2e5e34daf46a.webp" alt="The Coca-Cola Company logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/edison.png/2ff099d7e39dd5b7308412f09bcb5c66.webp" alt="Company Logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/fifth-third-bank.png/b40ae616b4e102fca4b9f361bb2c3712.webp" alt="Fifth Third Bank logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/general-mills.png/6a79d07da3ae800c6744efb3dce9c0b6.webp" alt="General Mills logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/hershey.png/e5ce276be8b0189bb48e9f3375fe8fd0.webp" alt="Hershey logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/levi-strauss.jpeg/66a79d79a6c5bca33e62811ae145f7db.webp" alt="Levi Strauss & Co logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/nrg.png/b603344ac69569002b3db93db9f85954.webp" alt="NRG logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pge.png/f499f05a11fb81386f27111ba2444bfc.webp" alt="PG&E Logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/paypal.png/d4886b07002d914dc5a0b888eb79dce9.webp" alt="PayPal logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/seventh-gen.jpeg/bb363d2635f38092091f588c815cee43.webp" alt="Seventh Generation logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/suncor.png/4bc6d2082220128692a375729cab59d2.webp" alt="Suncor logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/walt-disney-logo.png/28db436128035fe9f3deb5b981204606.webp" alt="Walt Disney logo" class="col-span-1 object-scale-down h-24 w-full" /> </div> <div class="col-span-1 flex flex-col gap-logo-list logoListScrollReverse" style="animation: logoListScroll 34s linear infinite ;" > <img src="https://assets.ceres.org/images/partner-logos/amazon.svg" alt="Amazon logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/aveda.png/20a2cadeb38a4984ba27fcf0ddcec0d5.webp" alt="Aveda logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/barclays.png/14279d6af315ff645e1e0f23012df6ae.webp" alt="Barclays logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/best-buy.jpeg/f8985b02b3ee9994ca9a3db7f0d4ce3d.webp" alt="Best Buy logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/cvs.png/c9a28b7020441b2ec35f6086e3476a2b.webp" alt="CVS logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/dell.jpg/ce7b25e53754c9bf4ba09703893f3bff.webp" alt="Dell Technologies logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/exelon-logo.png/8db49deabd085f4da77a381265379ec3.webp" alt="Exelon logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/ford_logo_flat.svg" alt="Ford logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/gm.jpeg/84e1dd5ba348e0a7cc811a56faa17bcf.webp" alt="General Motors logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/jll.png/2a44c1a0a94626d79970bddb07389757.webp" alt="JLL logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/lululemon.jpeg/e14d270328035b42b562285e12fc32c0.webp" alt="Lululemon logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/nationalgrid.png/7a8895d08a49e8917632a15eef95d9d9.webp" alt="National Grid logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pnc.png/f909512f9339b12ca004852494c88d73.webp" alt="PNC" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pepsico-logo.png/9d31b6a98b3e032fe728d6c294fa48d0.webp" alt="Pepsico logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/starbucks.png/1a1456f58d041c0569da0b0ff38d1870.webp" alt="Starbucks logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/target.png/5525abee40f78a043c833620de42ffa2.webp" alt="Target logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/wells-fargo.png/ce56cbdac8a3e57bf8269895b7abd12d.webp" alt="Wells Fargo logo" class="col-span-1 object-scale-down h-24 w-full" /> </div> <div class="col-span-1 flex flex-col gap-logo-list logoListScrollForward" style="animation: logoListScroll 34s linear infinite reverse;" > <img src="https://assets.ceres.org/images/partner-logos/amd-1722357328.svg" alt="AMD logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/bank-of-america.png/b2a127177e83b6ecec2c8ea14ce6790b.webp" alt="Bank of America logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/baxter.png/68756d3195113cc6a77498b2f411511a.webp" alt="Baxter logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/bloomberg.png/c1baeab6c22eee2b0b93f58ff39f0562.webp" alt="Bloomberg logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/citi-logo-new.png/69c47fa2ae92221516b0f923d6fde4c4.webp" alt="Citi logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/deloitte.png/026a00489cac8bbdd0b302cdd6e421f4.webp" alt="Deloitte logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/fannie-mae.png/1532f17d277a3aa85e1994f663bd753c.webp" alt="Fannie Mae logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/gap.png/bb61458322f58b172519fb91a0e90b5a.webp" alt="Gap" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/hp.png/8da8ae3c161bb4e35e5c58210e1911f1.webp" alt="HP logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/jp-morgan.png/db1d7714598b4704031b599a0309a0a6.webp" alt="JP Morgan Chase logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/moodys.png/2b61450d8e3059161ca64a5590502a4c.webp" alt="Moody's logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/nike-logo.png/dd627308dbfd79206e185a99396d265d.webp" alt="Nike logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pseg.png/9df45535837f383825ec280c7d121f97.webp" alt="PSEG logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/regions.png/9063cb01dd8676170f6bda3f91e33669.webp" alt="Regions logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/state-street.png/58d45cff6111be9afa47315db6ccae42.webp" alt="State Street logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/truist.png/eeeafc270df35e03899a64dc62cd45fe.webp" alt="Truist logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/gap.png/bb61458322f58b172519fb91a0e90b5a.webp" alt="Gap" class="col-span-1 object-scale-down h-24 w-full" /> </div> <div class="col-span-1 flex flex-col gap-logo-list logoListScrollReverse" style="animation: logoListScroll 34s linear infinite ;" > <img src="https://assets.ceres.org/cache/containers/images/partner-logos/akamai.png/b69742cda688db5b19081589ec910cd5.webp" alt="Akamai logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/apple_logo_black_lg.svg" alt="Apple logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/bmo_logo.svg" alt="Bank of Montreal (BMO)" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/ben-and-jerry.png/ab1b8b9e81d666f521e86f691900e37d.webp" alt="Ben and Jerry's logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/images/partner-logos/brown-forman.svg" alt="Brown-forman logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/coca-cola.png/5f6d67162fb6dae0346e2e5e34daf46a.webp" alt="The Coca-Cola Company logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/edison.png/2ff099d7e39dd5b7308412f09bcb5c66.webp" alt="Company Logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/fifth-third-bank.png/b40ae616b4e102fca4b9f361bb2c3712.webp" alt="Fifth Third Bank logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/general-mills.png/6a79d07da3ae800c6744efb3dce9c0b6.webp" alt="General Mills logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/hershey.png/e5ce276be8b0189bb48e9f3375fe8fd0.webp" alt="Hershey logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/levi-strauss.jpeg/66a79d79a6c5bca33e62811ae145f7db.webp" alt="Levi Strauss & Co logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/nrg.png/b603344ac69569002b3db93db9f85954.webp" alt="NRG logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/pge.png/f499f05a11fb81386f27111ba2444bfc.webp" alt="PG&E Logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/paypal.png/d4886b07002d914dc5a0b888eb79dce9.webp" alt="PayPal logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/seventh-gen.jpeg/bb363d2635f38092091f588c815cee43.webp" alt="Seventh Generation logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/suncor.png/4bc6d2082220128692a375729cab59d2.webp" alt="Suncor logo" class="col-span-1 object-scale-down h-24 w-full" /> <img src="https://assets.ceres.org/cache/containers/images/partner-logos/walt-disney-logo.png/28db436128035fe9f3deb5b981204606.webp" alt="Walt Disney logo" class="col-span-1 object-scale-down h-24 w-full" /> </div> </div> </div> <div class="flex flex-col col-span-12 lg:col-span-6 gap-8 pb-16 md:py-16 order-first lg:order-last"> <div class="flex flex-col gap-5"> <!-- /typography/_h3.antlers.html --> <h3 class="text-4xl font-medium leading-[140%] [&_span]:inline-block [text-wrap:balance]"><p><strong>Join a growing network of leading investors and companies</strong></p></h3> <!-- End: /typography/_h3.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed lg:max-w-[80%] max-w-full">Our powerful networks of investors and companies drive change and advocate for innovative policies and regulations that build a cleaner, more just, and more sustainable economy.</p> <!-- End: /typography/_p.antlers.html --> </div> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/networks" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> See all networks <svg width="14" height="14" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> </section> </section> <!-- End: /page_builder/_logo_soup_rotating.antlers.html --> <!-- /page_builder/_text_and_image_i.antlers.html --> <section class="bg-cw-green-100 text-black overflow-hidden"> <div class="container" x-data="{ translateX: 0, imagePosition: 'left' }" x-init="() => { function updateTranslate() { let containerWidth = $el.offsetWidth; let containerPaddingRight = parseInt(window.getComputedStyle($el).paddingRight, 10); let screenWidth = window.innerWidth; let calculatedTranslation = (screenWidth - containerWidth) / 2 + containerPaddingRight; // Flip the translation value based on image position translateX = imagePosition === 'left' ? -calculatedTranslation : calculatedTranslation; } updateTranslate(); window.addEventListener('resize', updateTranslate); return () => window.removeEventListener('resize', updateTranslate); }" > <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 "> <div class="col-span-6 row-span-full lg:block hidden col-start-1" :style="'transform: translateX(' + translateX + 'px)'" > <img src="https://assets.ceres.org/cache/containers/images/accelerator-banner-web-thumbnail.png/b0e9a2a4a9d77f1735d0b6a28d7bf9cb.webp" alt="Composite of data" class="rounded w-full h-full object-cover"/> </div> <div class="flex flex-col gap-8 max-w-1/2 lg:col-span-7 col-span-12 row-span-full py-16 justify-center lg:col-start-6"> <div class="flex flex-col gap-2"> <!-- /typography/_h2.antlers.html --> <h2 class="text-[44px] font-medium leading-[137%]"><strong>Ceres Accelerator for Sustainable Capital Markets</strong></h2> <!-- End: /typography/_h2.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Our center for excellence within Ceres aims to transform the practices and policies that govern capital markets by engaging federal and state regulators, financial institutions, investors, and corporate boards to act on climate change as a systemic financial risk.</p> <!-- End: /typography/_p.antlers.html --> </div> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/accelerator" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Learn more </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> </div> </section> <!-- End: /page_builder/_text_and_image_i.antlers.html --> <!-- /page_builder/_featured_resources.antlers.html --> <section class="bg-white text-black "> <div class="container py-16"> <div> <!-- /typography/_h2.antlers.html --> <h2 class="font-bold text-4xl">Explore our reports</h2> <!-- End: /typography/_h2.antlers.html --> <br /> <div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed text-md md:max-w-4xl">At Ceres, we equip investors and companies with science-based research and actionable steps to help them thrive in the transition to a cleaner, more just, and sustainable economy. Our latest reports champion best practices to mitigate sustainability risks and unlock new business opportunities.</p> <!-- End: /typography/_p.antlers.html --> </div> </div> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" my-8 grid grid-cols-1 lg:grid-cols-3 gap-8 mb-8 "> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden "> <a title="Ceres 10-Point Plan for the Insurance Industry" aria-label="Ceres 10-Point Plan for the Insurance Industry" href="/resources/reports/ceres-10-point-plan-for-the-insurance-industry"> <img src="https://assets.ceres.org/cache/containers/images/istock-2075186172.jpg/028665115926e69b26f3342226792757/istock-2075186172.webp" alt="" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Nov 20, 2024 </div> <div class="text-lg font-bold"> Ceres 10-Point Plan for the Insurance Industry </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden "> <a title="Benchmarking Air Emissions of the 100 Largest Electric Power Producers in the United States" aria-label="Benchmarking Air Emissions of the 100 Largest Electric Power Producers in the United States" href="/resources/reports/benchmarking-air-emissions-of-the-100-largest-electric-power-producers-in-the-united-states"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_621084085.jpeg/315f38e1a346699038729c9cbec2ef3a/adobestock_621084085.webp" alt="" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Nov 19, 2024 </div> <div class="text-lg font-bold"> Benchmarking Air Emissions of the 100 Largest Electric Power Producers in the United States </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden "> <a title="Guidance for Investor Engagements with Directors on Climate Risk Governance" aria-label="Guidance for Investor Engagements with Directors on Climate Risk Governance" href="/resources/reports/guidance-engaging-climate-risk-governance-and-voting-directors"> <img src="https://assets.ceres.org/cache/containers/images/resource-thumbnails-banners/guide-voting-thumbnail.png/2f01a5d3ca6cc87a9da41358ac8fc169.webp" alt="" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Oct 23, 2024 </div> <div class="text-lg font-bold"> Guidance for Investor Engagements with Directors on Climate Risk Governance </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden hidden "> <a title="Ahead or Behind? The State of Climate Finance in the Banking Sector" aria-label="Ahead or Behind? The State of Climate Finance in the Banking Sector" href="/resources/reports/ahead-or-behind"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_529773169-copy.jpg/6e11f40f7364dba3adb4b3511e5a4ffd/adobestock_529773169-copy.webp" alt="" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Oct 1, 2024 </div> <div class="text-lg font-bold"> Ahead or Behind? The State of Climate Finance in the Banking Sector </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden hidden "> <a title="Taking Stock: The State of Climate Action and Disclosure in the Food Sector" aria-label="Taking Stock: The State of Climate Action and Disclosure in the Food Sector" href="/resources/reports/taking-stock-the-state-of-climate-action-and-disclosure-in-the-food-sector"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_581599290-edit.jpg/a1ed004b096be74d60d67520d740058f/adobestock_581599290-edit.webp" alt="" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Sep 17, 2024 </div> <div class="text-lg font-bold"> Taking Stock: The State of Climate Action and Disclosure in the Food Sector </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden hidden "> <a title="Investor Climate Action Plans are Becoming a Norm" aria-label="Investor Climate Action Plans are Becoming a Norm" href="/resources/reports/investor-climate-action-plans-are-becoming-a-norm"> <img src="https://assets.ceres.org/cache/containers/images/adobestock_173426561.jpeg/0555fcffa4d27024be8184d00363e519/adobestock_173426561.webp" alt="A bird's eye view of a field of solar panels with a few green trees growing in between them." class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Aug 27, 2024 </div> <div class="text-lg font-bold"> Investor Climate Action Plans are Becoming a Norm </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden hidden "> <a title="Investing in the Future: Unlocking Value Through Avoided Emissions" aria-label="Investing in the Future: Unlocking Value Through Avoided Emissions" href="/resources/reports/investing-in-the-future-unlocking-value-through-avoided-emissions"> <img src="https://assets.ceres.org/cache/containers/images/banner-investing_in_the_future.png/632fdd00ee653035ff4f7e25d4412409/banner-investing_in_the_future.webp" alt="" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Aug 20, 2024 </div> <div class="text-lg font-bold"> Investing in the Future: Unlocking Value Through Avoided Emissions </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden hidden "> <a title="From Commitment to Implementation: An Analysis of Corporate Climate Actions from the 2021 Proxy Season" aria-label="From Commitment to Implementation: An Analysis of Corporate Climate Actions from the 2021 Proxy Season" href="/resources/reports/from-commitment-to-implementation-an-analysis-of-corporate-climate-actions-from-the-2021-proxy-season"> <img src="https://assets.ceres.org/cache/containers/images/analysis-cover.jpg/7dc71284b8fd82f1b1da9320cb25de33/analysis-cover.webp" alt="Wind mills" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Jul 24, 2024 </div> <div class="text-lg font-bold"> From Commitment to Implementation: An Analysis of Corporate Climate Actions from the 2021 Proxy Season </div> </div> </div> </div> </a> </div> <div class=" bg-white flex flex-col resource_card_grid_6 resource_cards_grid text-sm font-semibold shadow-cards hover:shadow-cards-darker transition duration-250 group rounded-t overflow-hidden hidden "> <a title="Navigating Climate Risks: Progress and Challenges in U.S. Insurance Sector Disclosures" aria-label="Navigating Climate Risks: Progress and Challenges in U.S. Insurance Sector Disclosures" href="/resources/reports/navigating-climate-risks-progress-and-challenges-in-us-insurance-sector-disclosures"> <img src="https://assets.ceres.org/cache/containers/images/insurance-report-banner.jpg/a416552e42971a5ee681142ad7c89a1f/insurance-report-banner.webp" alt="Wildfire" class="h-48 w-full object-cover block group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-16 h-full"> <div> <div class="my-4 text-gray-500"> Jun 18, 2024 </div> <div class="text-lg font-bold"> Navigating Climate Risks: Progress and Challenges in U.S. Insurance Sector Disclosures </div> </div> </div> </div> </a> </div> </div> <div class="see-more-button-container-6 flex items-center w-full "> <div class="bg-black opacity-30 h-0.5 w-1/2"></div> <!-- /components/_button.antlers.html --> <div class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start see-more-button-6 mx-1 hover:cursor-pointer text-black border border-black stroke-black fill-black <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> See more </div> </div> <!-- End: /components/_button.antlers.html --> <div class="bg-black opacity-30 h-0.5 w-1/2"></div> </div> <script> const see_more_button_container_6 = document.getElementsByClassName('see-more-button-container-6')[0] const see_more_button_6 = document.getElementsByClassName('see-more-button-6')[0] // These 2 variables are the props that passed from parent view, this syntax can get the props in Antlers const target_class_6 = 'resource_card_grid_6' const load_more_amount_6 = Number('3') // need to convert it to number because it is a string const target_elements_6 = document.getElementsByClassName(target_class_6) const total_number_of_target_elements_6 = Array.from(target_elements_6).length const redirect_url_6 = '/resources/reports' const getDisplayedItems_6 = () => { let number_of_displayed_items = 0 for(const element of target_elements_6) { if(!element.classList.contains('hidden')) { number_of_displayed_items++ } } return number_of_displayed_items } const loadMore_6 = () => { let displayed_items = getDisplayedItems_6() const redirect_user_to_url = () => { window.location.href = redirect_url_6; } if(displayed_items < total_number_of_target_elements_6 || displayed_items < 9) { for(let i = 0; i < displayed_items + load_more_amount_6; i++) { if(i < total_number_of_target_elements_6) { if(target_elements_6[i].classList.contains('hidden')) { target_elements_6[i].classList.remove('hidden') } } } displayed_items = getDisplayedItems_6() if(displayed_items >= total_number_of_target_elements_6 || displayed_items >= 9) { if(redirect_url_6 == '/') { see_more_button_container_6.classList.add('hidden') } else { see_more_button_6.removeEventListener('click', loadMore_6) see_more_button_6.addEventListener('click', redirect_user_to_url) } } } } const check_button_should_display_6 = () => { const number_of_cards = target_elements_6.length if(number_of_cards <= 3) { see_more_button_container_6.classList.add('hidden') } } see_more_button_6.addEventListener('click', loadMore_6) window.addEventListener('load', check_button_should_display_6) </script> </div> <div id="authFormModal" class="hidden fixed opacity-0 z-50 transition-opacity duration-500 w-full h-full bg-black/50 z-50 top-0 left-0 px-4"> <section class="overflow-y-auto overflow-x-hidden fixed top-0 right-0 left-0 z-50 h-screen flex items-center justify-center bg-black/30"> <div class=" lg:p-4 lg:w-1/2 container py-16"> <div class="relative bg-white rounded-lg shadow dark:bg-gray-700"> <button onclick="closeAuthModal()" type="button" class="absolute top-3 end-2.5 text-gray-400 bg-transparent rounded-lg text-sm w-8 h-8 ms-auto inline-flex justify-center items-center dark:hover:bg-gray-600 dark:hover:text-white"> <svg width="32" height="32" class="stroke-gray-400 hover:stroke-cw-green-200" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-x-circle"><circle cx="12" cy="12" r="10"/><path d="m15 9-6 6"/><path d="m9 9 6 6"/></svg> <span class="sr-only">Close form</span> </button> <div id="authFormContainer" class="p-6 lg:p-16"> <div class="p-4" id="authMessage"></div> <form id="loginForm"> <div class="flex flex-col max-w-lg mx-auto gap-8"> <div class="flex flex-col items-center gap-2"> <!-- /typography/_h2.antlers.html --> <h2 class="lg:text-2xl text-lg font-medium">Log in to download this report.</h2> <!-- End: /typography/_h2.antlers.html --> <span class="flex flex-row items-center gap-2"> <span class="lg:text-lg text-xs">Don't have an account?</span> <button type="button" id="showRegisterForm"> <span class="lg:text-lg text-xs underline">Sign up for free.</span> </button> </span> </div> <div class="flex flex-col"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 text-black [&_*]:text-center "> <input type="hidden" name="_token" value="STATAMIC_CSRF_TOKEN"> <input type="email" name="email" value="" required="1" placeholder="Email Address" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.email }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6" /> <input type="password" name="password" value="" required="1" placeholder="Password" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.password }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6" /> </div> </div> <div class="flex flex-col gap-4 items-center"> <a href="/forgot-password" class="text-sm underline">Forgot your password?</a> <button type="submit" disabled class="text-white bg-black/40 rounded-full w-fit px-10 py-4 text-md transition-bg duration-300 ease-in-out cursor-not-allowed" background="#FFFFFF" > Log in </button> </div> </div> </form> <form class="hidden" action="/register" method="post" id="registerForm"> <div class="flex flex-col max-w-lg mx-auto gap-8"> <div class="flex flex-col items-center gap-1"> <!-- /typography/_h2.antlers.html --> <h2 class="lg:text-2xl text-lg font-medium">Sign up to unlock our reports.</h2> <!-- End: /typography/_h2.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed lg:text-md text-base">Create your free account to unlock access to all of our reports.</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="flex flex-col"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 "> <input type="hidden" name="_token" value="STATAMIC_CSRF_TOKEN"> <input type="text" name="first_name" value="" required="1" placeholder="First Name" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.first_name }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="text" name="last_name" value="" required="1" placeholder="Last Name" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.last_name }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="email" name="email" value="" required="1" placeholder="Email Address" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.email }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6 text-black" /> <input type="text" name="organisation" value="" required="1" placeholder="Organization" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.organisation }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="text" name="zip_code" value="" required="1" placeholder="Zip Code" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.zip_code }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="password" name="password" value="" required="1" placeholder="Password - 8 character minimum" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.password }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6 text-black" /> <label class="col-span-12 flex items-center gap-2"> <input type="checkbox" name="subscribe" value="on" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6"> <span class="lg:text-lg text-xs">Subscribe to email updates from Ceres.</span> </label> </div> </div> <div class="flex flex-col gap-4 items-center"> <p class="lg:text-lg text-xs [text-wrap:balance] text-center max-w-sm [&_a]:cursor-pointer bg-white text-black [&_a]:font-medium"> By signing up, you agree to our <a class="underline" href="/privacy-policy">privacy policy</a> </p> <button type="submit" disabled class="text-white bg-black/40 rounded-full w-fit px-10 py-4 text-md transition-bg duration-300 ease-in-out cursor-not-allowed" background="#FFFFFF" > Create account </button> <span class="flex flex-row items-center gap-2"> <span class="lg:text-lg text-xs">Already have an account?</span> <button type="button" id="showLoginForm"> <span class="lg:text-lg text-xs underline">Log In</span> </button> </span> </div> </div> </form> </div> <script> document.addEventListener('DOMContentLoaded', () => { if (localStorage.getItem('NeedsVerifyEmail') === 'true') { let attempts = 0; let interval = setInterval(() => { attempts++; fetch('/fortify/api/verification-check', { credentials: 'include', headers: { 'Authorization': 'Bearer ' + localStorage.getItem('TOKEN') } } ).then((r) => { if (r.status !== 200) { clearInterval(interval); throw new Error(`Request rejected with status ${r.status}`); } else { return r.json(); } }) .then(data => { if (data.type === 'success') { localStorage.setItem('NeedsVerifyEmail', 'false'); localStorage.removeItem('TOKEN'); location.reload(); } }) .catch(err => console.error(err)); if (attempts >= 12) { clearInterval(interval); } }, 10000); } let elements = document.querySelectorAll('#authFormModal'); if (elements.length > 1) { for (let i = 0; i < elements.length - 1; i++) { elements[i].remove(); } }else{ const formsIds = ['loginForm', 'registerForm']; const authFormContainer = document.getElementById('authFormContainer'); const messageDiv = document.getElementById('authMessage'); formsIds.forEach(formId => { const form = document.getElementById(formId); if(form) { const submitButton = form.querySelector('button[type="submit"]'); submitButton.addEventListener('click', e => { e.preventDefault(); handleFormSubmit(messageDiv, formId); }); form.addEventListener('input', () => { const isValid = validateFields(form, submitButton); toggleButtonStyling(isValid, submitButton); }); form.addEventListener('keydown', e => { if (e.code === 'Enter' || e.key === 'Enter') { e.preventDefault(); } }) } }); const toggleFormDisplay = (showFormId, hideFormId) => { document.getElementById(showFormId).style.display = 'block'; document.getElementById(hideFormId).style.display = 'none'; } const showLoginFormButton = document.getElementById('showLoginForm'); if(showLoginFormButton) { showLoginFormButton.addEventListener('click', e => { e.preventDefault(); toggleFormDisplay('loginForm', 'registerForm'); }); } const showRegisterFormButton = document.getElementById('showRegisterForm'); if(showRegisterFormButton) { showRegisterFormButton.addEventListener('click', e => { e.preventDefault(); toggleFormDisplay('registerForm', 'loginForm'); }); } authFormContainer.addEventListener('click', event => { if (!event.target.closest('#authFormContainer')) { closeAuthModal(); } }); } }); function handleFormSubmit(messageDiv, formId) { const form = document.getElementById(formId); const submitButton = form.querySelector('button[type="submit"]'); if(formId === 'loginForm') { const _token = form.querySelector('[name="_token"]').value; const email = form.querySelector('[name="email"]').value; const password = form.querySelector('[name="password"]').value; submitButton.classList.remove('cursor-pointer') submitButton.classList.add('cursor-not-allowed'); submitButton.disabled = true; fetch('/fortify/api/auth/login', { method: 'POST', headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'X-CSRF-TOKEN': _token }, body: JSON.stringify({ email, password }) }) .then(response => { if (!response.ok) { throw new Error(response.status + ' ' + response.statusText); } return response.json(); }) .then(data => { if (data && data.message) { messageDiv.classList.remove('text-red-500'); messageDiv.classList.add('text-green-500'); messageDiv.innerText = data.message; location.reload(); } else { throw new Error('Invalid response format'); } }) .catch(error => { messageDiv.classList.remove('text-green-500'); messageDiv.classList.add('text-red-500'); messageDiv.innerText = 'The username or password is incorrect. For assistance, please contact us at info@ceres.org.'; setTimeout(() => { submitButton.classList.add('cursor-pointer'); submitButton.disabled = false }, 5000); }); } else { const _token = form.querySelector('[name="_token"]').value; const emailInput = form.querySelector('[name="email"]').value; const passwordInput = form.querySelector('[name="password"]').value; const firstNameInput = form.querySelector('[name="first_name"]').value; const lastNameInput = form.querySelector('[name="last_name"]').value; const organisationInput = form.querySelector('[name="organisation"]').value; const zipCodeInput = form.querySelector('[name="zip_code"]').value; const subscribeCheckbox = form.querySelector('[name="subscribe"]').checked ? 'on' : 'off'; submitButton.classList.remove('cursor-pointer'); submitButton.classList.add('cursor-not-allowed'); submitButton.disabled = true; const customErrorMessages = { "The email has already been taken.": "This email is already in use. Please try again with a different email." }; fetch('/register', { method: 'POST', headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'X-CSRF-TOKEN': _token }, body: JSON.stringify({ email: emailInput, password: passwordInput, first_name: firstNameInput, last_name: lastNameInput, organisation: organisationInput, zip_code: zipCodeInput, subscribe: subscribeCheckbox, }) }) .then(response => response.json().then(data => ({ status: response.status, body: data }))) // Parse JSON and include status .then(response => { if (response.status === 200) { if (response.body && response.body.message) { messageDiv.classList.remove('text-red-500'); messageDiv.classList.add('text-green-500'); messageDiv.innerText = response.body.message; localStorage.setItem('TOKEN', response.body.token); localStorage.setItem('NeedsVerifyEmail', 'true'); setTimeout(() => { location.reload(); }, 10000); } else { throw new Error('Invalid response format'); } } else if (response.status === 422) { // Validation errors messageDiv.classList.remove('text-green-500'); messageDiv.classList.add('text-red-500'); messageDiv.innerText = ''; // Clear any existing messages for (const [field, messages] of Object.entries(response.body.errors)) { messages.forEach(message => { const errorParagraph = document.createElement('p'); // Use custom message if available, otherwise use the original message errorParagraph.innerText = customErrorMessages[message] || message; messageDiv.appendChild(errorParagraph); }); } } else { throw new Error(response.status + ' ' + response.statusText); } }) .catch(error => { messageDiv.classList.remove('text-green-500'); messageDiv.classList.add('text-red-500'); messageDiv.innerText = 'An unexpected error occurred. Please try again.'; }) .finally(() => { submitButton.classList.add('cursor-pointer'); submitButton.classList.remove('cursor-not-allowed'); submitButton.disabled = false; }); } } function validateFields(form) { const inputs = [...form.querySelectorAll('input:not([type="hidden"])')]; const formValidity = inputs.reduce((valid, element) => { switch (element.type) { case 'email': return valid && /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(element.value); case 'password': return valid && element.value.length >= 8; case 'text': if (element.name === 'zip_code') { return valid && element.value.length >= 2 && element.value.length <= 20; } else if (element.name === 'first_name' || element.name === 'last_name') { return valid && element.value.trim() !== '' && /^[a-zA-Z\s]+$/.test(element.value) && element.value.length <= 40; } else if (element.name === 'organisation') { return valid && element.value.trim() !== '' && element.value.length <= 40; } else { return valid && element.value.trim() !== '' && element.value.trim() !== '' && element.value.length <= 40; } default: return valid; } }, true); const passwordInputs = inputs.filter(input => input.type === 'password'); const passwordsMatch = passwordInputs.length <= 1 || (passwordInputs[0].value === passwordInputs[1].value); return formValidity && passwordsMatch; } function toggleButtonStyling(isValid, submitButton) { if (isValid) { submitButton.disabled = false submitButton.classList.remove('cursor-not-allowed', 'bg-black/40'); submitButton.classList.add('cursor-pointer', 'bg-cw-green-200'); submitButton.disabled = false; } else { submitButton.disabled = true submitButton.classList.add('cursor-not-allowed', 'bg-black/40'); submitButton.classList.remove('cursor-pointer', 'bg-cw-green-200'); submitButton.disabled = true; } } function openAuthModal() { const authModal = document.getElementById('authFormModal'); authModal.classList.remove('hidden'); document.body.style.overflow = 'hidden' setTimeout(() => { authModal.classList.remove('opacity-0'); authModal.classList.add('opacity-100'); }, 30); } function closeAuthModal() { const authModal = document.getElementById('authFormModal'); authModal.classList.remove('opacity-100'); authModal.classList.add('opacity-0'); setTimeout(() => { authModal.classList.add('hidden'); document.body.style.overflow = 'auto'; }, 200); } </script> </div> </div> </section> </div> </section> <!-- End: /page_builder/_featured_resources.antlers.html --> <!-- /page_builder/_text_and_image_i.antlers.html --> <section class="bg-cw-green-100 text-black overflow-hidden"> <div class="container" x-data="{ translateX: 0, imagePosition: 'right' }" x-init="() => { function updateTranslate() { let containerWidth = $el.offsetWidth; let containerPaddingRight = parseInt(window.getComputedStyle($el).paddingRight, 10); let screenWidth = window.innerWidth; let calculatedTranslation = (screenWidth - containerWidth) / 2 + containerPaddingRight; // Flip the translation value based on image position translateX = imagePosition === 'left' ? -calculatedTranslation : calculatedTranslation; } updateTranslate(); window.addEventListener('resize', updateTranslate); return () => window.removeEventListener('resize', updateTranslate); }" > <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 "> <div class="col-span-6 row-span-full lg:block hidden col-start-7" :style="'transform: translateX(' + translateX + 'px)'" > <img src="https://assets.ceres.org/cache/containers/images/ctaps-preview.jpg/4e759ac650b9e8c0ec3644a4ed14a2d8.webp" alt="Solar panels" class="rounded w-full h-full object-cover"/> </div> <div class="flex flex-col gap-8 max-w-1/2 lg:col-span-7 col-span-12 row-span-full py-16 justify-center lg:col-start-1"> <div class="flex flex-col gap-2"> <!-- /typography/_h2.antlers.html --> <h2 class="text-[44px] font-medium leading-[137%]"><strong>Learn How to Create a Transition Plan </strong></h2> <!-- End: /typography/_h2.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Broad commitments and long-term goals for stabilizing the climate, protecting water, and conserving and restoring nature aren’t enough. The next step for investors and companies is to develop and publicly disclose a concrete plan for moving from commitment to impact.</p> <!-- End: /typography/_p.antlers.html --> </div> <!-- /components/_button.antlers.html --> <a class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/transition-plans" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Learn more <svg width="14" height="14" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </div> </a> <!-- End: /components/_button.antlers.html --> </div> </div> </div> </section> <!-- End: /page_builder/_text_and_image_i.antlers.html --> <!-- /page_builder/_quote_with_image_or_video.antlers.html --> <section class="container py-16"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 "> <div class="md:col-span-6 col-span-full row-span-full md:col-start-7 relative items-center py-8 hidden md:block"> <div class="w-full h-full relative"> <!-- Absolute image to stop container expanding to fit image and creating whitespace. --> <img src="https://assets.ceres.org/images/msl-speaking.png" class="w-full h-full object-cover md:absolute" alt="Ceres CEO Mindy Lubber speaking at an event"> </div> </div> <div class="order-first md:order-2 md:col-span-6 col-span-full md:col-start-1 flex flex-col px-8 md:px-12 xl:px-20 gap-4 py-16 relative shadow-cards-darker rounded-lg"> <blockquote class="sm:text-lg lg:text-2xl xl:text-3xl"> <div> <p>"If the world’s largest investors and companies act, we can stabilize the climate, protect water and natural resources, and build a stronger, more resilient economy."</p> </div> </blockquote> <div class="flex gap-8"> <div class="rounded-full border border-white overflow-hidden h-16 w-16 md:h-20 md:w-20 shrink-0"> <img src="https://assets.ceres.org/images/headshots/lubber.jpg" alt="Photo of Mindy Lubber" class="w-full h-full object-cover"> </div> <div class="flex flex-col justify-center *:mb-0"> <p class="font-bold"> Mindy Lubber </p> <p> CEO and President </p> </div> </div> </div> </div> </section> <!-- End: /page_builder/_quote_with_image_or_video.antlers.html --> <!-- /page_builder/_featured_resources.antlers.html --> <section class="bg-white text-black "> <div class="container py-16"> <div> <!-- /typography/_h2.antlers.html --> <h2 class="font-bold text-4xl">Discover upcoming events</h2> <!-- End: /typography/_h2.antlers.html --> <br /> <div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed text-md md:max-w-4xl">Join us virtually or in-person to hear directly from leading business and sustainability experts. To learn how to sponsor an event, contact us at <a href="/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="7707160503191205041f1e070437141205120459180510">[email protected]</a>.</p> <!-- End: /typography/_p.antlers.html --> </div> </div> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" my-8 grid grid-cols-1 lg:grid-cols-3 gap-8 mb-8 "> <div class="bg-white flex flex-col transition-all duration-250 hover:shadow-cards-darker rounded-t-lg group resource_card_grid_9 resource_cards_grid text-sm font-semibold shadow-cards overflow-hidden "> <a href="https://www.innovationforum.co.uk/conferences/scope-3" class="h-full flex flex-col"> <img src="https://assets.ceres.org/cache/containers/images/s3us---ceres.png/61e639d4e1e5f543f205b8adfb712f89/s3us---ceres.webp" alt="" class="h-48 w-full object-cover block rounded-t group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-8 h-full"> <div class="h-full"> <div class="my-4 text-gray-500"> <!-- /components/_date_time_format.antlers.html --> <span> <!-- Extracting components (year, month, day, time) from the start_date and start_time --> <!-- Extracting components (year, month, day, time) from the end_date and end_time --> <!-- Checking if there is no end_date --> <!-- Checking different date ranges and displaying accordingly --> <!-- Displaying event within the same month and year --> Dec 3 - Dec 4, 2024 </span> <!-- End: /components/_date_time_format.antlers.html --> </div> <div class="text-cw-green-250 font-semibold text-sm"> In-Person | Washington, DC </div> <div class="text-lg font-bold"> Scope 3 Innovation Forum USA (Innovation Forum) with Jake Rascoff </div> </div> <div class="gap-4 flex flex-col w-full"> <!-- /components/_button.antlers.html --> <div class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/events/the-scope-3-innovation-forum-usa-innovation-forum" rel="noopener noreferrer" target="_blank" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Register </div> </div> <!-- End: /components/_button.antlers.html --> </div> </div> </div> </a> </div> <div class="bg-white flex flex-col transition-all duration-250 hover:shadow-cards-darker rounded-t-lg group resource_card_grid_9 resource_cards_grid text-sm font-semibold shadow-cards overflow-hidden "> <a href="https://www.ceres.org/greenbiz25" class="h-full flex flex-col"> <img src="https://assets.ceres.org/cache/containers/images/%5Bevent-thumbnail%5D-greenbiz-25-800x400-%281%29.png/5901ec731cb1ed24465042ba731962d9/%5Bevent-thumbnail%5D-greenbiz-25-800x400-%281%29.webp" alt="" class="h-48 w-full object-cover block rounded-t group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-8 h-full"> <div class="h-full"> <div class="my-4 text-gray-500"> <!-- /components/_date_time_format.antlers.html --> <span> <!-- Extracting components (year, month, day, time) from the start_date and start_time --> <!-- Extracting components (year, month, day, time) from the end_date and end_time --> <!-- Checking if there is no end_date --> <!-- Checking different date ranges and displaying accordingly --> <!-- Displaying event within the same month and year --> Feb 10 - Feb 12, 2025 </span> <!-- End: /components/_date_time_format.antlers.html --> </div> <div class="text-cw-green-250 font-semibold text-sm"> In-Person | JW Marriott Desert Ridge, Phoenix, AZ </div> <div class="text-lg font-bold"> GreenBiz 25 (Trellis) </div> </div> <div class="gap-4 flex flex-col w-full"> <!-- /components/_button.antlers.html --> <div class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/events/greenbiz-25-trellis" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Register </div> </div> <!-- End: /components/_button.antlers.html --> </div> </div> </div> </a> </div> <div class="bg-white flex flex-col transition-all duration-250 hover:shadow-cards-darker rounded-t-lg group resource_card_grid_9 resource_cards_grid text-sm font-semibold shadow-cards overflow-hidden "> <a href="https://events.ceres.org/lead" class="h-full flex flex-col"> <img src="https://assets.ceres.org/cache/containers/images/%5Bthumbnail%5D-lead-2025.png/6019dc23082a6cd1a08d266ab32208f3/%5Bthumbnail%5D-lead-2025.webp" alt="LEAD on a Clean Economy" class="h-48 w-full object-cover block rounded-t group-hover:scale-105 group-focus:scale-105 origin-bottom transition"> <div class="flex-grow p-2 sm:p-4"> <div class="flex flex-col justify-between gap-8 h-full"> <div class="h-full"> <div class="my-4 text-gray-500"> <!-- /components/_date_time_format.antlers.html --> <span> <!-- Extracting components (year, month, day, time) from the start_date and start_time --> <!-- Extracting components (year, month, day, time) from the end_date and end_time --> <!-- Checking if there is no end_date --> <!-- Checking different date ranges and displaying accordingly --> <!-- Displaying event within the same month and year --> Mar 4 - Mar 6, 2025 </span> <!-- End: /components/_date_time_format.antlers.html --> </div> <div class="text-cw-green-250 font-semibold text-sm"> In-Person | Washington, D.C. </div> <div class="text-lg font-bold"> LEAD on a Clean Economy </div> </div> <div class="gap-4 flex flex-col w-full"> <!-- /components/_button.antlers.html --> <div class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start bg-cw-green-200 font-bold text-white text-lg [&_svg]:stroke-white [&_svg]:fill-white <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/events/lead-2025" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> Register </div> </div> <!-- End: /components/_button.antlers.html --> </div> </div> </div> </a> </div> </div> <div class="see-more-button-container-9 flex items-center w-full "> <div class="bg-black opacity-30 h-0.5 w-1/2"></div> <!-- /components/_button.antlers.html --> <div class=" cursor-pointer inline-flex py-3 px-8 rounded-full select-none whitespace-nowrap items-start self-start see-more-button-9 mx-1 hover:cursor-pointer text-black border border-black stroke-black fill-black <!-- Adds extra space for mobile browsers to click on links if button requires it. --> " href="/" > <div class="flex flex-row text-center items-center justify-center gap-2" wire:click=""> See more </div> </div> <!-- End: /components/_button.antlers.html --> <div class="bg-black opacity-30 h-0.5 w-1/2"></div> </div> <script data-cfasync="false" src="/cdn-cgi/scripts/5c5dd728/cloudflare-static/email-decode.min.js"></script><script> const see_more_button_container_9 = document.getElementsByClassName('see-more-button-container-9')[0] const see_more_button_9 = document.getElementsByClassName('see-more-button-9')[0] // These 2 variables are the props that passed from parent view, this syntax can get the props in Antlers const target_class_9 = 'resource_card_grid_9' const load_more_amount_9 = Number('3') // need to convert it to number because it is a string const target_elements_9 = document.getElementsByClassName(target_class_9) const total_number_of_target_elements_9 = Array.from(target_elements_9).length const redirect_url_9 = '/events' const getDisplayedItems_9 = () => { let number_of_displayed_items = 0 for(const element of target_elements_9) { if(!element.classList.contains('hidden')) { number_of_displayed_items++ } } return number_of_displayed_items } const loadMore_9 = () => { let displayed_items = getDisplayedItems_9() const redirect_user_to_url = () => { window.location.href = redirect_url_9; } if(displayed_items < total_number_of_target_elements_9 || displayed_items < 9) { for(let i = 0; i < displayed_items + load_more_amount_9; i++) { if(i < total_number_of_target_elements_9) { if(target_elements_9[i].classList.contains('hidden')) { target_elements_9[i].classList.remove('hidden') } } } displayed_items = getDisplayedItems_9() if(displayed_items >= total_number_of_target_elements_9 || displayed_items >= 9) { if(redirect_url_9 == '/') { see_more_button_container_9.classList.add('hidden') } else { see_more_button_9.removeEventListener('click', loadMore_9) see_more_button_9.addEventListener('click', redirect_user_to_url) } } } } const check_button_should_display_9 = () => { const number_of_cards = target_elements_9.length if(number_of_cards <= 3) { see_more_button_container_9.classList.add('hidden') } } see_more_button_9.addEventListener('click', loadMore_9) window.addEventListener('load', check_button_should_display_9) </script> </div> <div id="authFormModal" class="hidden fixed opacity-0 z-50 transition-opacity duration-500 w-full h-full bg-black/50 z-50 top-0 left-0 px-4"> <section class="overflow-y-auto overflow-x-hidden fixed top-0 right-0 left-0 z-50 h-screen flex items-center justify-center bg-black/30"> <div class=" lg:p-4 lg:w-1/2 container py-16"> <div class="relative bg-white rounded-lg shadow dark:bg-gray-700"> <button onclick="closeAuthModal()" type="button" class="absolute top-3 end-2.5 text-gray-400 bg-transparent rounded-lg text-sm w-8 h-8 ms-auto inline-flex justify-center items-center dark:hover:bg-gray-600 dark:hover:text-white"> <svg width="32" height="32" class="stroke-gray-400 hover:stroke-cw-green-200" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-x-circle"><circle cx="12" cy="12" r="10"/><path d="m15 9-6 6"/><path d="m9 9 6 6"/></svg> <span class="sr-only">Close form</span> </button> <div id="authFormContainer" class="p-6 lg:p-16"> <div class="p-4" id="authMessage"></div> <form id="loginForm"> <div class="flex flex-col max-w-lg mx-auto gap-8"> <div class="flex flex-col items-center gap-2"> <!-- /typography/_h2.antlers.html --> <h2 class="lg:text-2xl text-lg font-medium">Log in to download this report.</h2> <!-- End: /typography/_h2.antlers.html --> <span class="flex flex-row items-center gap-2"> <span class="lg:text-lg text-xs">Don't have an account?</span> <button type="button" id="showRegisterForm"> <span class="lg:text-lg text-xs underline">Sign up for free.</span> </button> </span> </div> <div class="flex flex-col"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 text-black [&_*]:text-center "> <input type="hidden" name="_token" value="STATAMIC_CSRF_TOKEN"> <input type="email" name="email" value="" required="1" placeholder="Email Address" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.email }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6" /> <input type="password" name="password" value="" required="1" placeholder="Password" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.password }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6" /> </div> </div> <div class="flex flex-col gap-4 items-center"> <a href="/forgot-password" class="text-sm underline">Forgot your password?</a> <button type="submit" disabled class="text-white bg-black/40 rounded-full w-fit px-10 py-4 text-md transition-bg duration-300 ease-in-out cursor-not-allowed" background="#FFFFFF" > Log in </button> </div> </div> </form> <form class="hidden" action="/register" method="post" id="registerForm"> <div class="flex flex-col max-w-lg mx-auto gap-8"> <div class="flex flex-col items-center gap-1"> <!-- /typography/_h2.antlers.html --> <h2 class="lg:text-2xl text-lg font-medium">Sign up to unlock our reports.</h2> <!-- End: /typography/_h2.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed lg:text-md text-base">Create your free account to unlock access to all of our reports.</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="flex flex-col"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 "> <input type="hidden" name="_token" value="STATAMIC_CSRF_TOKEN"> <input type="text" name="first_name" value="" required="1" placeholder="First Name" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.first_name }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="text" name="last_name" value="" required="1" placeholder="Last Name" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.last_name }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="email" name="email" value="" required="1" placeholder="Email Address" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.email }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6 text-black" /> <input type="text" name="organisation" value="" required="1" placeholder="Organization" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.organisation }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="text" name="zip_code" value="" required="1" placeholder="Zip Code" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.zip_code }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6 text-black" /> <input type="password" name="password" value="" required="1" placeholder="Password - 8 character minimum" minlength="" maxlength="" autocomplete="off" x-model="" x-on:input="" :class="{ '!border-cw-green-150/90': valid.password }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-full lg:col-span-6 text-black" /> <label class="col-span-12 flex items-center gap-2"> <input type="checkbox" name="subscribe" value="on" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6"> <span class="lg:text-lg text-xs">Subscribe to email updates from Ceres.</span> </label> </div> </div> <div class="flex flex-col gap-4 items-center"> <p class="lg:text-lg text-xs [text-wrap:balance] text-center max-w-sm [&_a]:cursor-pointer bg-white text-black [&_a]:font-medium"> By signing up, you agree to our <a class="underline" href="/privacy-policy">privacy policy</a> </p> <button type="submit" disabled class="text-white bg-black/40 rounded-full w-fit px-10 py-4 text-md transition-bg duration-300 ease-in-out cursor-not-allowed" background="#FFFFFF" > Create account </button> <span class="flex flex-row items-center gap-2"> <span class="lg:text-lg text-xs">Already have an account?</span> <button type="button" id="showLoginForm"> <span class="lg:text-lg text-xs underline">Log In</span> </button> </span> </div> </div> </form> </div> <script> document.addEventListener('DOMContentLoaded', () => { let elements = document.querySelectorAll('#authFormModal'); if (elements.length > 1) { for (let i = 0; i < elements.length - 1; i++) { elements[i].remove(); } }else{ const formsIds = ['loginForm', 'registerForm']; const authFormContainer = document.getElementById('authFormContainer'); const messageDiv = document.getElementById('authMessage'); formsIds.forEach(formId => { const form = document.getElementById(formId); if(form) { const submitButton = form.querySelector('button[type="submit"]'); submitButton.addEventListener('click', e => { e.preventDefault(); handleFormSubmit(messageDiv, formId); }); form.addEventListener('input', () => { const isValid = validateFields(form, submitButton); toggleButtonStyling(isValid, submitButton); }); form.addEventListener('keydown', e => { if (e.code === 'Enter' || e.key === 'Enter') { e.preventDefault(); } }) } }); const toggleFormDisplay = (showFormId, hideFormId) => { document.getElementById(showFormId).style.display = 'block'; document.getElementById(hideFormId).style.display = 'none'; } const showLoginFormButton = document.getElementById('showLoginForm'); if(showLoginFormButton) { showLoginFormButton.addEventListener('click', e => { e.preventDefault(); toggleFormDisplay('loginForm', 'registerForm'); }); } const showRegisterFormButton = document.getElementById('showRegisterForm'); if(showRegisterFormButton) { showRegisterFormButton.addEventListener('click', e => { e.preventDefault(); toggleFormDisplay('registerForm', 'loginForm'); }); } authFormContainer.addEventListener('click', event => { if (!event.target.closest('#authFormContainer')) { closeAuthModal(); } }); } }); function handleFormSubmit(messageDiv, formId) { const form = document.getElementById(formId); const submitButton = form.querySelector('button[type="submit"]'); if(formId === 'loginForm') { const _token = form.querySelector('[name="_token"]').value; const email = form.querySelector('[name="email"]').value; const password = form.querySelector('[name="password"]').value; submitButton.classList.remove('cursor-pointer') submitButton.classList.add('cursor-not-allowed'); submitButton.disabled = true; fetch('/fortify/api/auth/login', { method: 'POST', headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'X-CSRF-TOKEN': _token }, body: JSON.stringify({ email, password }) }) .then(response => { if (!response.ok) { throw new Error(response.status + ' ' + response.statusText); } return response.json(); }) .then(data => { if (data && data.message) { messageDiv.classList.remove('text-red-500'); messageDiv.classList.add('text-green-500'); messageDiv.innerText = data.message; location.reload(); } else { throw new Error('Invalid response format'); } }) .catch(error => { messageDiv.classList.remove('text-green-500'); messageDiv.classList.add('text-red-500'); messageDiv.innerText = 'The username or password is incorrect. For assistance, please contact us at info@ceres.org.'; setTimeout(() => { submitButton.classList.add('cursor-pointer'); submitButton.disabled = false }, 5000); }); } else { const _token = form.querySelector('[name="_token"]').value; const emailInput = form.querySelector('[name="email"]').value; const passwordInput = form.querySelector('[name="password"]').value; const firstNameInput = form.querySelector('[name="first_name"]').value; const lastNameInput = form.querySelector('[name="last_name"]').value; const organisationInput = form.querySelector('[name="organisation"]').value; const zipCodeInput = form.querySelector('[name="zip_code"]').value; const subscribeCheckbox = form.querySelector('[name="subscribe"]').checked ? 'on' : 'off'; submitButton.classList.remove('cursor-pointer'); submitButton.classList.add('cursor-not-allowed'); submitButton.disabled = true; const customErrorMessages = { "The email has already been taken.": "This email is already in use. Please try again with a different email." }; fetch('/register', { method: 'POST', headers: { 'Content-Type': 'application/json', 'Accept': 'application/json', 'X-CSRF-TOKEN': _token }, body: JSON.stringify({ email: emailInput, password: passwordInput, first_name: firstNameInput, last_name: lastNameInput, organisation: organisationInput, zip_code: zipCodeInput, subscribe: subscribeCheckbox, }) }) .then(response => response.json().then(data => ({ status: response.status, body: data }))) // Parse JSON and include status .then(response => { if (response.status === 200) { if (response.body && response.body.message) { messageDiv.classList.remove('text-red-500'); messageDiv.classList.add('text-green-500'); messageDiv.innerText = response.body.message; localStorage.setItem('TOKEN', response.body.token); localStorage.setItem('NeedsVerifyEmail', 'true'); setTimeout(() => { location.reload(); }, 10000); } else { throw new Error('Invalid response format'); } } else if (response.status === 422) { // Validation errors messageDiv.classList.remove('text-green-500'); messageDiv.classList.add('text-red-500'); messageDiv.innerText = ''; // Clear any existing messages for (const [field, messages] of Object.entries(response.body.errors)) { messages.forEach(message => { const errorParagraph = document.createElement('p'); // Use custom message if available, otherwise use the original message errorParagraph.innerText = customErrorMessages[message] || message; messageDiv.appendChild(errorParagraph); }); } } else { throw new Error(response.status + ' ' + response.statusText); } }) .catch(error => { messageDiv.classList.remove('text-green-500'); messageDiv.classList.add('text-red-500'); messageDiv.innerText = 'An unexpected error occurred. Please try again.'; }) .finally(() => { submitButton.classList.add('cursor-pointer'); submitButton.classList.remove('cursor-not-allowed'); submitButton.disabled = false; }); } } function validateFields(form) { const inputs = [...form.querySelectorAll('input:not([type="hidden"])')]; const formValidity = inputs.reduce((valid, element) => { switch (element.type) { case 'email': return valid && /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(element.value); case 'password': return valid && element.value.length >= 8; case 'text': if (element.name === 'zip_code') { return valid && element.value.length >= 2 && element.value.length <= 20; } else if (element.name === 'first_name' || element.name === 'last_name') { return valid && element.value.trim() !== '' && /^[a-zA-Z\s]+$/.test(element.value) && element.value.length <= 40; } else if (element.name === 'organisation') { return valid && element.value.trim() !== '' && element.value.length <= 40; } else { return valid && element.value.trim() !== '' && element.value.trim() !== '' && element.value.length <= 40; } default: return valid; } }, true); const passwordInputs = inputs.filter(input => input.type === 'password'); const passwordsMatch = passwordInputs.length <= 1 || (passwordInputs[0].value === passwordInputs[1].value); return formValidity && passwordsMatch; } function toggleButtonStyling(isValid, submitButton) { if (isValid) { submitButton.disabled = false submitButton.classList.remove('cursor-not-allowed', 'bg-black/40'); submitButton.classList.add('cursor-pointer', 'bg-cw-green-200'); submitButton.disabled = false; } else { submitButton.disabled = true submitButton.classList.add('cursor-not-allowed', 'bg-black/40'); submitButton.classList.remove('cursor-pointer', 'bg-cw-green-200'); submitButton.disabled = true; } } function openAuthModal() { const authModal = document.getElementById('authFormModal'); authModal.classList.remove('hidden'); document.body.style.overflow = 'hidden' setTimeout(() => { authModal.classList.remove('opacity-0'); authModal.classList.add('opacity-100'); }, 30); } function closeAuthModal() { const authModal = document.getElementById('authFormModal'); authModal.classList.remove('opacity-100'); authModal.classList.add('opacity-0'); setTimeout(() => { authModal.classList.add('hidden'); document.body.style.overflow = 'auto'; }, 200); } </script> </div> </div> </section> </div> </section> <!-- End: /page_builder/_featured_resources.antlers.html --> <!-- /page_builder/_logo_soup_static.antlers.html --> <section class="bg-white text-black "> <div class="container py-8"> <!-- /typography/_h3.antlers.html --> <h3 class="text-2xl font-bold leading-tight mb-6">Thanks to our annual sponsors for their commitment to our work.</h3> <!-- End: /typography/_h3.antlers.html --> <div class="container mx-auto grid grid-cols-3 lg:grid-cols-6 gap-6 content-between p-5" > <div class="flex justify-center items-center"> <img src="https://assets.ceres.org/images/partner-logos/3bl-logo.png" alt="3BL logo" class="h-auto w-auto" style="opacity: 1" > </div> <div class="flex justify-center items-center"> <img src="https://assets.ceres.org/images/partner-logos/foley.png" alt="Foley Hoag logo" class="h-auto w-auto" style="opacity: 1" > </div> <div class="flex justify-center items-center"> <img src="https://assets.ceres.org/images/partner-logos/impax-am.png" alt="Impax Asset Management logo" class="h-auto w-auto" style="opacity: 1" > </div> </div> </div> </section> <!-- End: /page_builder/_logo soup static.antlers.html --> <!-- /page_builder/_subscribe_to_newsletter_green_banner.antlers.html --> <section class="bg-cw-green-200 text-white "> <div class=" container py-12" > <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-0 gap-y-8 lg:gap-16 "> <div class="flex flex-col col-span-12 lg:col-span-6 gap-2"> <!-- /typography/_h2.antlers.html --> <h2 class="text-3xl font-bold">Never miss an alert</h2> <!-- End: /typography/_h2.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Sign up for the latest news and updates from Ceres.</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="flex flex-col justify-center items-center col-span-12 lg:col-span-6"> <div class="w-full" x-data="{ singular_email: '', emailValid: false, emailPattern: /^[a-zA-Z0-9._-]+(\+[a-zA-Z0-9._-]+)*@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,4}$/, validateEmail() { this.emailValid = this.emailPattern.test(this.singular_email); } }" > <div aria-label="Newsletter Subscription Form"> <div class="relative"> <input class="text-black appearance-none rounded w-full py-3 px-6 !border-cw-green-200 !outline-none !ring-0 " type="email" name="singular_email" placeholder="Email Address" required x-model="singular_email" x-on:input="validateEmail(); $dispatch('email-changed', singular_email)" aria-label="Email Address" aria-required="true" :aria-invalid="!emailValid.toString()" x-on:change="localStorage.setItem('singular_email', singular_email);" > <button class="w-fit rounded-full bg-black/40 text-white font-bold p-2 focus:outline-none focus:shadow-outline absolute right-6 top-[50%] -translate-y-[50%] flex align-center justify-center transition-bg duration-300 ease-in-out" type="submit" :disabled="!emailValid" :aria-disabled="!emailValid.toString()" :class="{ '!bg-cw-green-800 hover:!bg-cw-green-800/75': emailValid, 'cursor-not-allowed': !emailValid }" aria-label="Submit" x-on:click="() => openModal()" > <span> <svg width="14" height="14" class="fill-current" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"> <path d="M438.6 278.6c12.5-12.5 12.5-32.8 0-45.3l-160-160c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L338.8 224 32 224c-17.7 0-32 14.3-32 32s14.3 32 32 32l306.7 0L233.4 393.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0l160-160z"/> </svg> </span> </button> </div> </div> </div> </div> </div> </div> <div id="newsletter-modal" class="hidden fixed opacity-0 z-50 transition-opacity duration-500 w-full h-full bg-black/50 top-0 left-0 px-4"> <div class="w-full h-full flex items-center justify-center text-black"> <div id="modalNewsletterContainer" class="relative bg-cw-green-50 rounded-lg"> <div onclick="closeModal()" id="closeNewsletterModal" class="absolute top-4 right-4 cursor-pointer z-50"> <svg width="32" height="32" class="stroke-gray-400" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" class="lucide lucide-x-circle"><circle cx="12" cy="12" r="10"/><path d="m15 9-6 6"/><path d="m9 9 6 6"/></svg> </div> <!-- /page_builder/_subscribe_to_newsletter_form_full.antlers.html --> <section class="bg-cw-green-50 rounded-lg" @email-changed.window="email_address = $event.detail" x-data="{ first_name: '', last_name: '', organisation: '', zip_code: '', email_address: '', valid: { first_name: false, last_name: false, organisation: false, zip_code: false, email_address: false }, validateFirstName() { this.valid.first_name = this.first_name.length >= 3; }, validateLastName() { this.valid.last_name = this.last_name.length >= 3; }, validateOrganisation() { this.valid.organisation = this.organisation.length >= 3; }, validateZipCode() { this.valid.zip_code = this.zip_code.length >= 5; }, validateEmailAddress() { const pattern = /^[a-zA-Z0-9._-]+(\+[a-zA-Z0-9._-]+)*@[a-zA-Z0-9.-]+\.[a-zA-Z]+$/; this.valid.email_address = pattern.test(this.email_address); }, isFormValid() { return Object.values(this.valid).every(value => value); }, }" x-init="() => { $watch('email_address', () => validateEmailAddress()) if (localStorage.getItem('singular_email')) { email_address = localStorage.getItem('singular_email') || ''; localStorage.removeItem('singular_email'); // remove it from localStorage after fetching setTimeout(() => { document.getElementById('modalNewsletterForm').scrollIntoView({ behavior: 'smooth', block: 'center' }); }, 500); // delay of 500 milliseconds to allow page to render } }" > <div class="relative container py-16"> <form id="modalNewsletterForm" class="transition-all duration-300"> <input type="hidden" name="_token" value="STATAMIC_CSRF_TOKEN"> <div class="flex flex-col max-w-lg mx-auto gap-8"> <div class="flex flex-col items-center gap-1"> <!-- /typography/_h2.antlers.html --> <h2 class="text-4xl font-medium">Never miss an alert</h2> <!-- End: /typography/_h2.antlers.html --> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed text-[17px]">Sign up for the latest news and updates from Ceres.</p> <!-- End: /typography/_p.antlers.html --> </div> <div class="flex flex-col rounded-lg"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 gap-5 rounded-lg "> <input type="text" name="first_name" value="" required="1" placeholder="First name" minlength="3" maxlength="" autocomplete="off" x-model="first_name" x-on:input="validateFirstName()" :class="{ '!border-cw-green-150/90': valid.first_name }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6" /> <input type="text" name="last_name" value="" required="1" placeholder="Last name" minlength="3" maxlength="" autocomplete="off" x-model="last_name" x-on:input="validateLastName()" :class="{ '!border-cw-green-150/90': valid.last_name }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6" /> <input type="text" name="organisation" value="" required="1" placeholder="Organization" minlength="3" maxlength="" autocomplete="off" x-model="organisation" x-on:input="validateOrganisation()" :class="{ '!border-cw-green-150/90': valid.organisation }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6" /> <input type="text" name="zip_code" value="" required="1" placeholder="ZIP Code" minlength="5" maxlength="" autocomplete="off" x-model="zip_code" x-on:input="validateZipCode()" :class="{ '!border-cw-green-150/90': valid.zip_code }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-6" /> <input type="email" name="email_address" value="" required="1" placeholder="Email Address" minlength="" maxlength="" autocomplete="off" x-model="email_address" x-on:input="validateEmailAddress()" :class="{ '!border-cw-green-150/90': valid.email_address }" class="border-2 border-cw-grey-500 rounded-md px-4 py-3 text-sm font-medium focus:!border-cw-green-select !ring-0 !outline-none transition-border duration-200 ease-in-out col-span-12" /> </div> </div> <div class="flex flex-col gap-4 items-center"> <button type="submit" class="text-white bg-black/40 rounded-full w-fit px-10 py-4 text-[17px] transition-bg duration-300 ease-in-out" :class="isFormValid() && 'bg-cw-green-800 text-white rounded-full w-fit px-10 py-4 text-[17px] hover:opacity-90'" :disabled="!isFormValid()" > Sign up </button> <p class="[text-wrap:balance] text-center max-w-sm [&_a]:cursor-pointer [&_a]:text-cw-green-800 [&_a]:font-medium"> By signing up, you agree to our <a class="underline" target="_blank" href="/privacy-policy">Privacy Policy</a> </p> </div> </div> </form> </div> </section> <script> document.addEventListener('DOMContentLoaded', function() { // Due to the script being loaded before these HTML elements are rendered, we need to set them once content has been loaded. successElement = document.getElementById('newsletterSuccessState'); errorElement = document.getElementById('newsletterErrorState'); }); const newsletterModal = document.getElementById('newsletter-modal'); const closeNewsletterModal = document.getElementById('closeNewsletterModal'); const newsletterForm = document.getElementById('modalNewsletterForm'); let successElement let errorElement function submitState(form, stateElement, isSuccess, message) { form.style.opacity = '0'; stateElement.innerHTML = ''; stateElement.style.display = 'flex'; setTimeout(() => { stateElement.style.opacity = '1'; }, 30) let messageContent; if (isSuccess) { messageContent = `<h2 class="text-cw-green-200 text-center">Subscription confirmed!</h2> <p class="text-center">Thanks for signing up. You’ll receive your first email from Ceres soon!</p>`; setTimeout(() => { if (newsletterModal) { cleanupElements(); } else { window.location.href = '/'; } }, 3000); } else { errorElement.style.display = 'flex'; messageContent = `<p class="text-red-600">Error - ${message || 'There was an issue with your submission. Please try again.'}</p>`; } stateElement.innerHTML = messageContent; } function handleSubmitNewsletterForm(event) { event.preventDefault(); errorElement.style.display = 'none'; const form = event.target; const submitButton = form.querySelector('button[type="submit"]'); submitButton.disabled = true; const formData = new FormData(form); const data = {}; formData.forEach((value, key) => { data[key] = value; }); const jsonData = JSON.stringify(data); fetch('/subscribeToNewsletterOnly', { method: 'POST', headers: { 'Content-Type': 'application/json', 'X-CSRF-TOKEN': form.querySelector('input[name="_token"]').value }, body: jsonData }) .then(response => response.json()) .then(data => { console.log('Success:', data); submitState(form, successElement, true); }) .catch((error) => { console.error('Error:', error); submitState(form, errorElement, false); submitButton.disabled = false; }); removeEventListener('submit', handleSubmitNewsletterForm); } function cleanupElements() { const sectionParent = newsletterModal.closest('section'); if (sectionParent) { sectionParent.style.transition = 'opacity 300ms ease-out'; sectionParent.style.opacity = '0'; // Wait for the transition to complete before removing the element sectionParent.addEventListener('transitionend', function() { closeModal(); this.remove(); }); } } newsletterForm.addEventListener('submit', handleSubmitNewsletterForm); </script> <!-- End: /page_builder/_subscribe_to_newsletter_form_full.antlers.html --> <div id="newsletterErrorState" class="hidden px-8 pb-4 [&_p]:text-md"> </div> <div id="newsletterSuccessState" class=" hidden absolute px-8 flex-col gap-4 items-center justify-center top-0 left-0 w-full h-full transition-opacity delay-300 opacity-0 [&_h2]:text-4xl [&_p]:text-lg " ></div> </div> </div> </div> <script> const openModal = () => { newsletterModal.classList.remove('hidden'); document.body.style.overflow = 'hidden'; setTimeout(() => { newsletterModal.classList.remove('opacity-0'); newsletterModal.classList.add('opacity-100'); }, 30); newsletterModal.addEventListener('click', handleClickOutsideModal); newsletterForm.addEventListener('submit', handleSubmitNewsletterForm); } const closeModal = () => { newsletterModal.classList.remove('opacity-100'); newsletterModal.classList.add('opacity-0'); setTimeout(() => { newsletterModal.classList.add('hidden'); document.body.style.overflow = 'auto'; }, 200); newsletterModal.removeEventListener('click', handleClickOutsideModal); newsletterForm.removeEventListener('submit', handleSubmitNewsletterForm); } function handleClickOutsideModal(event) { if (!event.target.closest('#modalNewsletterContainer')) { closeModal(); } } </script> </section> <!-- End: /page_builder/_subscribe_to_newsletter_green_banner.antlers.html --> </main> <!-- End: /default.antlers.html --> <!-- /layout/_footer.antlers.html --> <footer> <div class="container"> <div class="flex flex-col gap-12 lg:gap-24 py-16 border-b border-b-black/25 lg:flex-row"> <div> <!-- /components/_logo.antlers.html --> <a aria-label="Logo Ceres" href="/" > <img src="/visuals/logo-dark.svg" class="select-none " width="108" alt="Ceres"/> </a> <!-- End: /components/_logo.antlers.html --> </div> <div class="flex-grow"> <!-- Grid component for layout of modules. Has default styling but can be changed using the class prop. --> <div class=" grid grid-cols-12 justify-between gap-6 lg:gap-0 gap-y-12 lg:flex lg:flex-row "> <div class="col-span-6 md:col-span-3 "> <a href="#" > <!-- /typography/_h4.antlers.html --> <h4 class="font-bold text-[16px] text-cw-green-250 mb-4">Issues</h4> <!-- End: /typography/_h4.antlers.html --> </a> <ul class="flex flex-col gap-3"> <li> <a href="https://www.ceres.org/climate" > <p class="text-[16px] tracking-tight"> Climate crisis </p> </a> </li> <li> <a href="https://www.ceres.org/water" > <p class="text-[16px] tracking-tight"> Water scarcity and pollution </p> </a> </li> <li> <a href="https://www.ceres.org/nature" > <p class="text-[16px] tracking-tight"> Nature and biodiversity loss </p> </a> </li> </ul> </div> <div class="col-span-6 md:col-span-3 "> <a href="https://www.ceres.org/networks" > <!-- /typography/_h4.antlers.html --> <h4 class="font-bold text-[16px] text-cw-green-250 mb-4">Networks</h4> <!-- End: /typography/_h4.antlers.html --> </a> <ul class="flex flex-col gap-3"> <li> <a href="https://www.ceres.org/networks/investor" > <p class="text-[16px] tracking-tight"> Investor Network </p> </a> </li> <li> <a href="https://www.ceres.org/networks/company" > <p class="text-[16px] tracking-tight"> Company Network </p> </a> </li> <li> <a href="https://www.ceres.org/networks/policy" > <p class="text-[16px] tracking-tight"> Policy Network </p> </a> </li> </ul> </div> <div class="col-span-6 md:col-span-3 "> <a href="https://www.ceres.org/resources" > <!-- /typography/_h4.antlers.html --> <h4 class="font-bold text-[16px] text-cw-green-250 mb-4">Resources</h4> <!-- End: /typography/_h4.antlers.html --> </a> <ul class="flex flex-col gap-3"> <li> <a href="https://www.ceres.org/resources/reports" > <p class="text-[16px] tracking-tight"> Reports </p> </a> </li> <li> <a href="https://www.ceres.org/events" > <p class="text-[16px] tracking-tight"> Events and webinars </p> </a> </li> <li> <a href="https://www.ceres.org/resources/news" > <p class="text-[16px] tracking-tight"> News and insights </p> </a> </li> </ul> </div> <div class="col-span-6 md:col-span-3 "> <a href="#" > <!-- /typography/_h4.antlers.html --> <h4 class="font-bold text-[16px] text-cw-green-250 mb-4">Work with us</h4> <!-- End: /typography/_h4.antlers.html --> </a> <ul class="flex flex-col gap-3"> <li> <a href="https://www.ceres.org/careers" > <p class="text-[16px] tracking-tight"> Careers </p> </a> </li> <li> <a href="https://www.ceres.org/procurement" > <p class="text-[16px] tracking-tight"> Procurement opportunities </p> </a> </li> </ul> </div> </div> </div> </div> <div class="flex flex-col py-10 gap-16 justify-between md:flex-row"> <div class="flex flex-row gap-16 flex-wrap"> <div class="text-[16px]"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed font-bold text-cw-green-250">Headquarters</p> <!-- End: /typography/_p.antlers.html --> <p>99 Chauncy Street, 6th Floor<br>Boston, MA 02111</p> </div> <div class="text-[16px]"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed font-bold text-cw-green-250">California Office</p> <!-- End: /typography/_p.antlers.html --> <p>369 Pine Street, Suite 620<br>San Francisco, CA 94104</p> </div> <div class="text-[16px]"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed font-bold text-cw-green-250">Connect with us</p> <!-- End: /typography/_p.antlers.html --> <p>(617) 247-0700 | <a href="/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="3d54535b527d5e584f584e13524f5a">[email protected]</a><br>For media inquiries, email us at <a href="/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="0e636b6a676f67607f7b677c676b7d4e6d6b7c6b7d20617c69">[email protected]</a>.</p> </div> </div> <div class="flex flex-row h-fit md:self-end"> <a href="https://www.facebook.com/ceres.org/" aria-label="Facebook" target="_blank" rel="noopener noreferrer" class=" px-2 hover:opacity-70 transition-opacity duration-200 ease-in-out"> <svg height="1rem" width="1rem" width="206" height="370" viewBox="0 0 206 370" fill="none" xmlns="http://www.w3.org/2000/svg"> <path d="M169.4 66.72L205.11 67.65V2.67L152.2 0.809998C102.47 0.809998 62.16 41.12 62.16 90.85V148.4H0.890015V218.02H62.16V369.34H139.21V218.02H193.98L205.12 148.4H139.21V96.91C139.21 80.23 152.73 66.71 169.41 66.71L169.4 66.72Z" fill="#246F00"/> </svg> </a> · <a href="https://twitter.com/CeresNews" aria-label="Twitter" target="_blank" rel="noopener noreferrer" class="fill-cw-green-250 px-2 hover:opacity-70 transition-opacity duration-200 ease-in-out"> <svg height="1rem" width="1rem" width="1200" height="1227" viewBox="0 0 1200 1227" xmlns="http://www.w3.org/2000/svg"> <path d="M714.163 519.284L1160.89 0H1055.03L667.137 450.887L357.328 0H0L468.492 681.821L0 1226.37H105.866L515.491 750.218L842.672 1226.37H1200L714.137 519.284H714.163ZM569.165 687.828L521.697 619.934L144.011 79.6944H306.615L611.412 515.685L658.88 583.579L1055.08 1150.3H892.476L569.165 687.854V687.828Z" fill="current"/> </svg> </a> · <a href="https://www.linkedin.com/company/ceres-org" aria-label="LinkedIn" target="_blank" rel="noopener noreferrer" class="pr-0 px-2 hover:opacity-70 transition-opacity duration-200 ease-in-out"> <svg height="1rem" width="1rem" width="376" height="376" viewBox="0 0 376 376" fill="none" xmlns="http://www.w3.org/2000/svg"> <path d="M90.57 131.75H13.8V375.08H90.57V131.75Z" fill="#246F00"/> <path d="M62.1239 96.4142C85.9701 91.2454 101.111 67.7241 95.9423 43.8779C90.7735 20.0317 67.2522 4.8907 43.406 10.0595C19.5598 15.2283 4.41882 38.7496 9.58762 62.5958C14.7564 86.442 38.2777 101.583 62.1239 96.4142Z" fill="#246F00"/> <path d="M288.51 124.51C229.12 124.51 212.23 165.07 212.23 165.07V131.76H138.36V375.09H215.13V247.63C215.13 230.25 220.44 191.14 260.03 191.14C299.62 191.14 299.62 237.01 299.62 237.01V375.09H375.42V230.73C375.42 162.17 347.9 124.51 288.51 124.51Z" fill="#246F00"/> </svg> </a> </div> </div> </div> <div class="w-full bg-cw-green-100"> <div class="flex flex-row container justify-between py-4 text-sm flex-wrap gap-6"> <div class="flex flex-row items-center"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed pr-6 border-r border-r-black">©2024 Ceres</p> <!-- End: /typography/_p.antlers.html --> <a href="/privacy-policy" class="px-6 border-r border-r-black"> PRIVACY POLICY </a> <div class="px-6 border-r border-r-black"> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed inline-block">Website by</p> <!-- End: /typography/_p.antlers.html --> <a href="https://brewdigital.com/" target="_blank" rel="noreferrer noopener" class="font-bold text-cw-green-250 hover:text-cw-green-250/75 transition-colors">Brew Digital</a> </div> </div> <!-- /typography/_p.antlers.html --> <p class="mt-0 last:mb-0 leading-relaxed ">Ceres is a 501(c)(3) tax-exempt nonprofit organization registered in the US under EIN 223-053747</p> <!-- End: /typography/_p.antlers.html --> </div> </div> </footer> <!-- End: /layout/_footer.antlers.html --> <script data-cfasync="false" src="/cdn-cgi/scripts/5c5dd728/cloudflare-static/email-decode.min.js"></script><script data-navigate-once="true">window.livewireScriptConfig = {"csrf":"STATAMIC_CSRF_TOKEN","uri":"\/livewire\/update","progressBar":"","nonce":""};</script> <script> function smoothScrollToElement(targetId) { const targetElement = document.querySelector(targetId); if (targetElement) { const isMobile = window.innerWidth < 1280; targetElement.scrollIntoView({ behavior: 'smooth', block: isMobile ? 'start' : 'center' }); } } function handleLoadEvent() { const hash = window.location.hash; if (hash) { smoothScrollToElement(hash); } // Remove the event listener after it has executed window.removeEventListener('load', handleLoadEvent); } // Attach the load event listener window.addEventListener('load', handleLoadEvent); // Handle click events for jump links on the page document.querySelectorAll('a[href^="#"]').forEach(anchor => { anchor.addEventListener('click', function(e) { e.preventDefault(); const targetId = this.getAttribute('href'); smoothScrollToElement(targetId); // Update the URL without reloading the page history.pushState(null, '', targetId); }); }); </script> <script type="text/javascript">(function() { var els = document.getElementsByClassName('nocache'); var map = {}; for (var i = 0; i < els.length; i++) { var section = els[i].getAttribute('data-nocache'); map[section] = els[i]; } fetch('/!/nocache', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ url: window.location.href.split('#')[0], sections: Object.keys(map) }) }) .then((response) => response.json()) .then((data) => { const regions = data.regions; for (var key in regions) { if (map[key]) map[key].outerHTML = regions[key]; } for (const input of document.querySelectorAll('input[value="STATAMIC_CSRF_TOKEN"]')) { input.value = data.csrf; } for (const meta of document.querySelectorAll('meta[content="STATAMIC_CSRF_TOKEN"]')) { meta.content = data.csrf; } for (const input of document.querySelectorAll('script[data-csrf="STATAMIC_CSRF_TOKEN"]')) { input.setAttribute('data-csrf', data.csrf); } if (window.hasOwnProperty('livewire_token')) { window.livewire_token = data.csrf } if (window.hasOwnProperty('livewireScriptConfig')) { window.livewireScriptConfig.csrf = data.csrf } document.dispatchEvent(new CustomEvent('statamic:nocache.replaced', { detail: data })); }); })();</script></body> </html> <!-- End: /layout.antlers.html -->