/* reset by rafaux */
* { margin: 0px; padding: 0px; border: 0px; font-weight: normal; font-size: 100%; list-style: none; line-height: 1; outline: 0px; background: none; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-font-smoothing: antialiased; -ms-font-smoothing: antialiased; -o-font-smoothing: antialiased; font-smoothing: antialiased; }

/* var */
:root { --primary: #2C2F40; --gold: #C88544; }

/* global class */
.container { display: block; width: auto; max-width: 1260px; height: auto; margin: 0px auto; }

html {
  scroll-behavior: smooth;
}

/* base */
a { text-decoration: none; color: var(--primary); transition: all .5s ease; }
body { background: #FAFAFA; color: var(--primary); color: var(--primary); font: normal 14px 'Lufga', sans-serif; overflow-x: hidden; }
input, textarea, select, button { font: normal 14px 'Lufga', sans-serif; appearance: none; -webkit-appearance: none; border-radius: 0px; transition: all .3s ease; }
select, button { cursor: pointer; }
input[type=submit], button { transition: all .5s ease; }

/* flex */
.flex { display: flex; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.align-center { align-items: center; }
.flex-col { flex-direction: column; }

/* grid */
.grid { display: grid; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-1-3 { grid-template-columns: 1fr 66%; }
.column-1-3 { grid-column: 1/3; }

/* classes */
.bg-gold { background-color: var(--gold); color: #fff; }
.bg-blue { background-color: var(--primary); color: #fff; }
.bg-gray { background-color: #E4E4E4; }
.bg-border { border: 2px solid #E9E9E9; }

/* button */
span.bt a { display: flex; align-items: center; }
span.bt a b { width: auto; height: 54px; padding: 0px 30px; font-weight: bold; background-color: #fff; border-radius: 10px; font-weight: bold; font-size: 16px; line-height: 54px; }
span.bt a::after { width: 54px; height: 54px; background: #fff url('../img/arrow.svg') no-repeat center center; background-size: 16px; border-radius: 10px; content: ''; }

/* header */
#header { padding: 15px 60px; }
#header nav ul { gap: 50px; }
#header nav ul li a:hover { text-decoration: underline; }
#header nav ul li.on a { position: relative; color: var(--gold); font-weight: bold; }
#header nav ul li.on a::before { position: absolute; top: -10px; left: 50%; width: 4px; height: 4px; background-color: var(--gold); border-radius: 100%; content: ''; }
#header span.login a { display: flex; align-items: center; gap: 15px; padding: 5px 25px 5px 5px; background-color: var(--primary); color: #fff; border-radius: 50px; }
#header span.login a b { position: relative; width: 30px; height: 30px; border-radius: 100%; background-color: #fff; }
#header span.login a b img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }

/* hero */
#hero { position: relative; width: calc(100% - 40px); height: 90vh; margin: 0px 20px; background-color: #000; border-radius: 40px; overflow: hidden; }
#hero img { position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; object-fit: cover; opacity: .6; }
#hero figure em { position: absolute; bottom: 100px; right: 50px; font-style: normal; color: #fff; color: #fff; font-size: 11px; line-height: 1.2; }
#hero figure em::before { position: absolute; top: 0px; left: -25px; width: 20px; height: 20px; background: transparent url('../img/icon-gps.svg') no-repeat; content: ''; }
#hero section { position: absolute; z-index: 2; bottom: 100px; left: 50%; width: 700px; margin-left: -550px; }
#hero section h1 { margin-bottom: 40px; font-weight: bold; font-size: 36px; line-height: 1.2; color: #fff; }
    
    /* hero -> experience */
    #hero.experience { height: 60vh; }
    #hero.experience section { width: auto; margin-left: 0px; text-align: center; transform: translateX(-50%); }
    #hero.experience section h1 { font-size: 72px; line-height: 1; }
    #hero.experience section p { color: #fff; font-size: 20px; }

    /* hero -> edicao */
    #hero.edicao { height: 60vh; }
    #hero.edicao section { width: auto; margin-left: 0px; text-align: center; transform: translateX(-50%); }
    #hero.edicao section h1 { margin-bottom: 0px; font-size: 72px; line-height: 1; }
    #hero.edicao section p { color: #fff; font-size: 20px; }

/* cover */
#cover { width: calc(100% - 40px); height: auto; margin: 0px 20px; padding: 60px 0px; border-radius: 40px; background-color: var(--primary); text-align: center; }
#cover span { color: #fff; }
#cover h1 { font-weight: bold; font-size: 48px; color: #fff; }

/* search */
#search { width: calc(100% - 40px); margin: 20px 20px 90px 20px; padding: 40px; background-color: #E9E9E9; border-radius: 40px; }
#search input { display: block; width: 700px; height: 60px; margin: 0px auto; padding: 0px 20px 0px 60px; background: #fff url('../img/icon-search.svg') no-repeat 20px center; border-radius: 30px; }

/* go */
#go { margin: 100px 0px; }
#go .container { display: flex; align-items: center; }
#go section { position: relative; display: flex; flex-direction: column; justify-content: center; width: 50%; height: 500px; padding-right: 100px; background-color: var(--primary); border-top-right-radius: 40px; border-bottom-right-radius: 40px; }
#go section::before { position: absolute; top: 0px; left: -1000px; width: 1000px; height: 100%; background-color: var(--primary); content: ''; }
#go section h2 { font-weight: bold; font-size: 32px; color: #fff; }
#go section p { margin: 20px 0px 40px 0px; color: #fff; font-size: 16px; line-height: 1.6; }
#go figure { width: 50%; height: 500px; }
#go figure img { width: 50vmax; height: 100%; border-top-left-radius: 40px; border-bottom-left-radius: 40px; object-fit: cover; }

/* partners */
#partners { margin-bottom: 90px; }
#partners header { position: relative; margin-bottom: 20px; }
#partners header::before { position: absolute; top: 50%; left: 50%; width: 50%; height: 1px; background-color: #ddd; transform: translate(-50%, -50%); content: ''; }
#partners header h2 { font-weight: bold; font-size: 36px; }
#partners header span { color: #A1A3AE; }
#partners figure img { width: 90%; height: 90px; object-fit: contain; }

    /* partners -> list */
    #partners-list section { display: block; width: 900px; margin: 0px auto; }
    #partners-list section article { margin-bottom: 40px; gap: 40px; }
    #partners-list section article figure.img { width: 50%; height: 500px; border-radius: 40px; overflow: hidden; }
    #partners-list section article figure.img img { width: 100%; height: 100%; object-fit: cover; }
    #partners-list section article .content { width: 50%; }
    #partners-list section article .content figure.logo img { display: block; width: auto; height: 100px; }
    #partners-list section article .content p { display: block; margin-bottom: 20px; line-height: 1.4; }
    #partners-list section article .content span.tel { gap: 20px; margin-bottom: 20px; }
    #partners-list section article .content span.tel a.wp { gap: 5px; font-weight: bold; font-size: 12px; padding: 8px 12px; background-color: #34A853; color: #fff; border-radius: 50px; }
    #partners-list section article .content .endereco { margin-bottom: 20px; }
    #partners-list section article .content .endereco small,
    #partners-list section article .content .horario small { display: block; margin-bottom: 5px; font-weight: bold; font-size: 12px; text-transform: uppercase; }
    #partners-list section article .content .endereco address { line-height: 1.4; font-style: normal; }
    #partners-list section article .content .tags { display: flex; gap: 10px; flex-wrap: wrap; }
    #partners-list section article .content .tags span { padding: 5px 10px; border-radius: 20px; border-radius: 30px; background-color: #E8E8E8; }

/* txt */
#txt-side { padding: 90px 0px; }
#txt-side .container { display: flex; align-items: flex-start; gap: 40px; }
#txt-side h2 { width: 35%; font-weight: bold; font-size: 48px; }
#txt-side .txt { display: flex; flex-direction: column; width: 65%; gap: 20px; }
#txt-side .txt p { line-height: 1.4; }

/* experiences */
#experiences { position: relative; margin-bottom: 140px; }
#experiences::before { position: absolute; z-index: -1; top: 60px; right: 0px; width: 70vw; height: calc(100% + 20px); border-top-left-radius: 40px; border-bottom-left-radius: 40px; background-color: var(--gold); content: ''; }
#experiences .container { display: flex; align-items: flex-end; }
#experiences section { position: relative; width: 40%; height: auto; padding: 80px 0px 40px 0px; background-color: var(--primary); }
#experiences section::before { position: absolute; z-index: -1; top: 0px; left: -100vw; width: 160vw; height: calc(100% + 30px); border-bottom-right-radius: 40px; background-color: var(--primary); content: ''; }
#experiences section h2 { font-weight: bold; font-size: 32px; color: #fff; }
#experiences section p { margin: 20px 0px 40px 0px; color: #fff; font-size: 16px; line-height: 1.6; }
#experiences aside { width: 60%; height: 480px; }
#experiences figure img { width: 100%; height: 100%; object-fit: cover; border-radius: 40px; }
#experiences figure em { display: block; margin-top: 10px; font-weight: bold; font-style: normal; font-size: 12px; color: #fff; }
#experiences figure em::before { display: inline-block; vertical-align: middle; width: 20px; height: 20px; padding-left: 5px; background: transparent url('../img/icon-gps.svg') no-repeat; content: ''; }

/* experience single */
#experience-single { margin-bottom: 90px; }
#experience-single header h2 { display: block; margin-bottom: 30px; font-weight: bold; font-size: 32px; text-align: center; }
#experience-single section { grid-gap: 30px; }
#experience-single section article { position: relative; height: 400px; border-radius: 40px; overflow: hidden; }
#experience-single section article::after { position: absolute; bottom: 0px; left: 0px; width: 100%; height: 40%; background: linear-gradient(to top, rgba(0,0,0,.5), transparent); backdrop-filter: blur(10px); mask-image: linear-gradient( to top, black 40%, transparent 100% ); content: ''; }
#experience-single section article img { position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; object-fit: cover; }
#experience-single section article figcaption { position: absolute; z-index: 2; bottom: 0px; left: 0px; width: 100%; height: auto; padding: 40px; text-align: center; }
#experience-single section article figcaption h3 { margin-bottom: 20px; font-weight: bold; font-size: 28px; color: #fff; line-height: 1.2; }
#experience-single section article figcaption span { padding: 5px 12px; border: 1.5px solid #fff; border-radius: 50px; font-weight: bold; color: #fff; }

/* experience grid */
#experience-grid { margin-top: 20px; }
#experience-grid section { margin-bottom: 20px; grid-gap: 20px; }
#experience-grid .column { display: flex; flex-direction: column; gap: 20px; align-items: flex-start; }
#experience-grid .column article { display: flex; flex-direction: column; gap: 20px; width: 100%; padding: 30px; border-radius: 40px; }
#experience-grid .column article .item { gap: 20px; }
#experience-grid .column article .item span { width: 30px; font-weight: bold; font-size: 48px; }
#experience-grid .column article .item .item-cont strong { display: block; font-weight: bold; font-size: 18px; }
#experience-grid .column article .item .item-cont p { margin-top: 5px; }
#experience-grid .column article .head { text-align: center; }
#experience-grid .column article .head strong { font-weight: bold; font-size: 24px; }
#experience-grid .column article .head h2 { margin-top: 15px; font-weight: bold; font-size: 24px; }
#experience-grid .column article p { line-height: 1.6; }
#experience-grid .column article p strong { font-weight: bold; }
#experience-grid .column article.grid { display: grid !important; }
#experience-grid .column article.grid p { font-weight: bold; font-size: 16px; line-height: 1.2; }
#experience-grid .column article.grid .side div { position: relative; display: flex; gap: 15px; flex-direction: column; }
#experience-grid .column article.grid .side div:first-of-type { width: 30px; text-align: center; gap: 10px; }
#experience-grid .column article.grid .side div:first-of-type:after { position: absolute; top: 48%; left: 50%; width: 20px; height: 2px; transform: translateX(-50%); background-color: var(--gold); content: ''; }
#experience-grid .column article.grid .side div:first-of-type span { color: var(--gold); font-size: 24px; }
#experience-grid .column article.grid .side span { font-size: 16px; }
#experience-grid .column article.grid.bg-blue { gap: 10px; }
#experience-grid .column article.grid.bg-blue div:first-of-type:after { display: none; }
#experience-grid .column article.grid.bg-blue strong { font-weight: bold; font-size: 18px; color: var(--gold); }
#experience-grid .column article.grid.bg-blue .side div:first-of-type { width: auto; text-align: left; }
#experience-grid .column .bg-gray { padding: 46px 40px; gap: 40px; }
#experience-grid .column .bg-gray h3 { font-weight: bold; font-size: 24px; }
#experience-grid .column .bg-gray .item span { width: 40%; font-size: 20px; }
#experience-grid .column .bg-gray .item .item-cont { position: relative; width: 60%; }
#experience-grid .column .bg-gray .item .item-cont strong { font-size: 36px; }
#experience-grid .column .bg-gray .item .item-cont span { position: relative; font-size: 14px; text-transform: uppercase; }
#experience-grid .column .bg-gray .item .item-cont::before { position: absolute; top: 50%; left: 35%; transform: translate(-50%, -50%); font-weight: bold; font-size: 20px; content: '/'; }
#experience-grid .column .how { padding: 40px; }
#experience-grid .column .how h3 { display: block; margin-bottom: 20px; font-weight: bold; font-size: 24px; }
#experience-grid .column .how strong { display: block; margin-bottom: 20px; font-weight: bold; }
#experience-grid .column .how nav ul { display: flex; flex-direction: column; gap: 20px; padding-left: 20px; border-left: 2px dotted rgba(255,255,255,.5); }
#experience-grid .column .how nav ul li { line-height: 1.4; }
#experience-grid .column .etapa h3 { font-weight: bold; font-size: 36px; }
#experience-grid .column .etapa .timeline { display: flex; flex-direction: column; gap: 40px; padding: 40px 0px 0px 40px; counter-reset: item; }
#experience-grid .column .etapa .timeline span { position: relative; display: flex; flex-direction: column; gap: 5px; padding-left: 20px; counter-increment: item; }
#experience-grid .column .etapa .timeline span::before { position: absolute; top: -20px; left: -53px; width: 20px; height: 20px; background-color: #fff; border: 2px solid var(--gold); color: var(--gold); line-height: 20px; font-weight: bold; font-size: 12px; border-radius: 100%; text-align: center; content: counter(item); }
#experience-grid .column .etapa .timeline span::after { position: absolute; top: 11px; left: -40px; width: 1px; height: 100%; border-left: 1px dotted var(--gold); content: ''; }
#experience-grid .column .etapa .timeline span:last-of-type::after { display: none; }
#experience-grid .column .etapa .timeline span img { position: absolute; top: 0px; left: -20px; }
#experience-grid .column .etapa .timeline span h4 { font-weight: bold; font-size: 20px; }
#experience-grid .column .etapa .timeline span p { font-weight: normal; }
#experience-grid .column figure.bg img { width: 100%; height: 620px; border-radius: 40px; object-fit: cover; }
#experience-grid section.middle { width: 900px; margin: 0px auto; }
#experience-grid section.middle .bg-gold span { width: 50%; }
#experience-grid section.middle .bg-gold .item-cont { width: 50%; }

/* sign */
#sign { margin-top: 170px; background-color: var(--primary); }
#sign figure { position: relative; display: inline-block; width: 100%; height: auto; margin-top: -80px; border-radius: 40px; overflow: hidden; }
#sign figure img { width: 100%; height: auto; }
#sign figure::after { position: absolute; bottom: 0px; left: 0px; width: 100%; height: 40%; background: linear-gradient(to top, #000, transparent); backdrop-filter: blur(10px); mask-image: linear-gradient( to top, black 40%, transparent 100% ); content: ''; }
#sign figure figcaption { position: absolute; z-index: 2; bottom: 40px; left: 50%; width: 800px; transform: translateX(-50%); text-align: center; }
#sign figure figcaption h2 { display: block; font-weight: bold; font-size: 48px; color: #fff; }
#sign figure figcaption p { font-weight: bold; font-size: 20px; color: #fff; line-height: 1.2; }
#sign figure figcaption p a { font-weight: bold; color: #fff; text-decoration: underline; }
#sign.edicao { margin-top: 0px; background-color: transparent; }
#sign.edicao figure { margin-top: 0px; }
#sign.edicao figure figcaption h2 { font-size: 48px; }

/* cta */
#cta { margin-top: 90px; }
#cta figure { position: relative; display: inline-block; width: 100%; height: auto; border-radius: 40px; overflow: hidden; }
#cta figure img.bg { width: 100%; height: auto; }
#cta figure img.logo { width: 300px; margin-bottom: 20px; }
#cta figure::after { position: absolute; bottom: 0px; left: 0px; width: 100%; height: 40%; background: linear-gradient(to top, #000, transparent); backdrop-filter: blur(10px); mask-image: linear-gradient( to top, black 40%, transparent 100% ); content: ''; }
#cta figure figcaption { position: absolute; z-index: 2; bottom: 40px; left: 50%; width: 600px; transform: translateX(-50%); text-align: center; }
#cta figure figcaption h2 { display: block; font-weight: bold; font-size: 48px; color: #fff; }
#cta figure figcaption p { font-weight: bold; font-size: 20px; color: #fff; line-height: 1.2; }
#cta figure figcaption p a { font-weight: bold; color: #fff; text-decoration: underline; }

/* blog */
#blog { padding: 90px 0px 160px 0px; background-color: var(--primary); }
#blog header h2 { color: #fff; font-weight: bold; font-size: 60px; }
#blog header p { display: block; margin-top: 10px; color: #fff; font-weight: bold; font-size: 24px; }
#blog section { margin-top: 50px; grid-gap: 30px; }
#blog section article img { width: 100%; height: 270px; margin-bottom: 20px; border-radius: 40px; object-fit: cover; }
#blog section article h3 { font-weight: bold; font-size: 20px; color: #fff; }
#blog section article p { display: block; margin-top: 10px; color: #fff; line-height: 1.2; }

/* kaza */
#kaza { margin-top: -60px; overflow: hidden; }
#kaza header { gap: 50px; }
#kaza header img { width: 300px; height: auto; }
#kaza header h2 { font-weight: bold; font-size: 36px; line-height: 1.2; }
#kaza section { position: relative; margin-top: 60px; grid-gap: 30px; }
#kaza section::before { position: absolute; top: 0px; left: -1030px; width: 1000px; height: 100%; background-color: var(--gold); border-top-right-radius: 40px; border-bottom-right-radius: 40px; content: ''; }
#kaza section::after { position: absolute; top: 0px; right: -1030px; width: 1000px; height: 100%; background-color: var(--gold); border-top-left-radius: 40px; border-bottom-left-radius: 40px; content: ''; }
#kaza section article { position: relative; height: 400px; border-radius: 40px; overflow: hidden; }
#kaza section article img { width: 100%; height: 100%; object-fit: cover; }
#kaza section article::after { position: absolute; bottom: 0px; left: 0px; width: 100%; height: 40%; background: linear-gradient(to top, #000, transparent); content: ''; }
#kaza section article figcaption { position: absolute; z-index: 2; bottom: 0px; left: 0px; width: 100%; height: auto; padding: 30px; text-align: center; }
#kaza section article figcaption h3 { display: block; margin-bottom: 10px; font-weight: bold; font-size: 28px; color: #fff; }
#kaza section article figcaption p { display: block; color: #fff; line-height: 1.4; }
#kaza.edicao { margin-top: 90px; }
#kaza.edicao header h2 { display: block; width: 700px; margin: 0px auto; text-align: center; }

/* footer */
#footer { display: grid; grid-template-columns: 25% 45% 30%; grid-gap: 40px; width: calc(100% - 40px); margin: 90px 20px 0px 20px; padding: 60px 50px; background-color: var(--primary); border-radius: 40px; }
#footer .column:nth-of-type(2) { display: grid; grid-template-columns: repeat(3, 1fr); }
#footer .column span.logo { display: block; margin-bottom: 40px; }
#footer .column span.logo img { width: 160px; }
#footer .column span.link a { margin-top: 20px; gap: 5px; color: #fff; font-size: 12px; }
#footer .column span.link a img { width: 20px; height: 20px; object-fit: contain; }
#footer .column nav strong { display: block; margin-bottom: 20px; color: #fff; opacity: .5; font-weight: bold; font-size: 12px; text-transform: uppercase; }
#footer .column nav ul { display: flex; flex-direction: column; gap: 20px; }
#footer .column nav ul li a { color: #fff; font-size: 13px; }
#footer .column nav ul li a:hover { text-decoration: underline; }
#footer .column nav.downloads ul,
#footer .column nav.social ul { flex-direction: row; gap: 10px; margin-bottom: 40px; }
#footer .column span.title { display: block; margin-bottom: 15px; font-weight: bold; font-size: 18px; color: #fff; }

/* bottom */
#bottom { padding: 20px 0px; }
#bottom span { font-size: 12px; }
#bottom span a { text-decoration: underline; }



/* ============================================================
   RESPONSIVE MOBILE - Núcleo Abraço
   Cole este bloco no FINAL do seu style.css
   
   Breakpoints:
   - max-width: 1024px → tablet
   - max-width: 768px  → mobile
   
   ⚠️  ATENÇÃO: O menu mobile precisa de um botão hamburger no HTML.
   Adicione este código dentro do #header, após o <span class="login">:
   
   <button class="menu-toggle" aria-label="Menu">
     <span></span><span></span><span></span>
   </button>
   
   E adicione este JS no core.js (ou antes do </body>):
   
   $('.menu-toggle').on('click', function() {
     $('#header nav').toggleClass('open');
     $(this).toggleClass('open');
   });
   
============================================================ */

/* ========================
   TABLET (até 1024px)
======================== */
@media (max-width: 1024px) {

    #header { padding: 15px 30px; }
    #header nav ul { gap: 25px; }
  
    .container { padding: 0px 20px; }
  
    #hero section { width: 80%; margin-left: -40%; }
    #hero.experience section h1,
    #hero.edicao section h1 { font-size: 52px; }
  
    #go section { padding-right: 50px; }
  
    #experiences section { width: 45%; }
    #experiences aside { width: 55%; }
  
    #sign figure figcaption { width: 90%; }
    #cta figure figcaption { width: 90%; }
  
    #partners-list section { width: 100%; padding: 0 20px; }
  
    #experience-grid section.middle { width: 100%; }
  
    #footer { grid-template-columns: 30% 40% 30%; padding: 40px 30px; }
  
  }
  
  /* ========================
     MOBILE (até 768px)
  ======================== */
  @media (max-width: 768px) {
  
    /* --- GLOBAL --- */
    .container { padding: 0px 16px; }
  
    /* --- HEADER --- */
    #header {
      position: relative;
      padding: 16px 20px;
      flex-wrap: wrap;
      gap: 10px;
    }
    #header nav {
      display: none;
      width: 100%;
      order: 3;
      border-top: 1px solid rgba(0,0,0,.08);
      padding-top: 16px;
      padding-bottom: 10px;
    }
    #header nav.open { display: block; }
    #header nav ul {
      flex-direction: column;
      gap: 0;
      align-items: flex-start;
    }
    #header nav ul li a {
      display: block;
      padding: 10px 0;
      font-size: 15px;
    }
    #header span.login { order: 2; }
  
    /* Botão hamburger */
    #header button.menu-toggle {
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 5px;
      width: 36px;
      height: 36px;
      cursor: pointer;
      order: 2;
      padding: 4px;
      background: none;
    }
    #header button.menu-toggle span {
      display: block;
      width: 100%;
      height: 2px;
      background-color: var(--primary);
      border-radius: 2px;
      transition: all .3s ease;
    }
    #header button.menu-toggle.open span:nth-child(1) {
      transform: translateY(7px) rotate(45deg);
    }
    #header button.menu-toggle.open span:nth-child(2) {
      opacity: 0;
    }
    #header button.menu-toggle.open span:nth-child(3) {
      transform: translateY(-7px) rotate(-45deg);
    }
  
    /* Se não quiser adicionar o botão no HTML, descomente a linha abaixo
       para mostrar o menu sempre visível em mobile: */
    /* #header nav { display: block; } */
  
    /* --- HERO --- */
    #hero {
      width: calc(100% - 24px);
      margin: 0 12px;
      height: 70vh;
      border-radius: 24px;
    }
    #hero section {
      position: absolute;
      width: calc(100% - 40px);
      left: 20px;
      bottom: 40px;
      margin-left: 0;
      transform: none !important;
      text-align: left;
    }
    #hero section h1 {
      font-size: 26px;
      margin-bottom: 20px;
    }
    #hero figure em {
      bottom: 40px;
      right: 20px;
      font-size: 10px;
    }
  
    /* hero experience & edicao */
    #hero.experience,
    #hero.edicao {
      height: 55vh;
    }
    #hero.experience section,
    #hero.edicao section {
      text-align: center;
      left: 50%;
      transform: translateX(-50%) !important;
      width: 90%;
      margin-left: 0;
    }
    #hero.experience section h1,
    #hero.edicao section h1 {
      font-size: 42px;
    }
    #hero.experience section p,
    #hero.edicao section p {
      font-size: 16px;
    }
    #hero.edicao section h1 { margin-bottom: 10px; }
  
    /* --- COVER --- */
    #cover {
      width: calc(100% - 24px);
      margin: 0 12px;
      padding: 40px 20px;
      border-radius: 24px;
    }
    #cover h1 { font-size: 32px; }
  
    /* --- SEARCH --- */
    #search {
      width: calc(100% - 24px);
      margin: 16px 12px 50px 12px;
      padding: 24px 16px;
      border-radius: 24px;
    }
    #search input {
      width: 100%;
      height: 52px;
    }
  
    /* --- GO --- */
    #go { margin: 60px 0; }
    #go .container { flex-direction: column; }
    #go section {
      width: 100%;
      height: auto;
      padding: 40px 20px 40px 20px;
      border-radius: 0;
      border-top-right-radius: 0;
      border-bottom-right-radius: 0;
      border-top-left-radius: 24px;
      border-top-right-radius: 24px;
    }
    #go section::before { display: none; }
    #go section h2 { font-size: 26px; }
    #go section p { font-size: 14px; }
    #go figure {
      width: 100%;
      height: 260px;
      order: -1;
    }
    #go figure img {
      width: 100%;
      border-radius: 0;
      border-bottom-left-radius: 24px;
      border-bottom-right-radius: 24px;
      object-fit: cover;
    }
  
    /* --- PARTNERS (home) --- */
    #partners { margin-bottom: 50px; }
    #partners header { flex-direction: column; gap: 8px; text-align: center; }
    #partners header::before { width: 80%; }
    #partners header h2 { font-size: 26px; }
    #partners section {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 10px;
      padding: 0 16px;
    }
    #partners figure img { width: 100%; height: 70px; }
  
    /* --- PARTNERS LIST (parceiros.html) --- */
    #partners-list section { width: 100%; padding: 0 16px; }
    #partners-list section article {
      flex-direction: column !important;
      gap: 24px;
      margin-bottom: 40px;
    }
    #partners-list section article figure.img {
      width: 100%;
      height: 240px;
      border-radius: 24px;
    }
    #partners-list section article .content { width: 100%; }
  
    /* --- TXT SIDE --- */
    #txt-side { padding: 50px 0; }
    #txt-side .container { flex-direction: column; gap: 20px; }
    #txt-side h2 { width: 100%; font-size: 32px; }
    #txt-side .txt { width: 100%; }
  
    /* --- EXPERIENCES (bloco home) --- */
    #experiences { margin-bottom: 80px; }
    #experiences::before { width: 100%; border-radius: 0; top: auto; bottom: 0; height: 50%; }
    #experiences .container { flex-direction: column; }
    #experiences section {
      width: 100%;
      padding: 40px 16px 30px 16px;
    }
    #experiences section::before { display: none; }
    #experiences section h2 { font-size: 26px; }
    #experiences section p { font-size: 14px; }
    #experiences aside {
      width: 100%;
      height: 280px;
    }
    #experiences figure img { border-radius: 24px; }
  
    /* --- EXPERIENCE SINGLE --- */
    #experience-single { margin-bottom: 50px; }
    #experience-single header h2 { font-size: 26px; }
    #experience-single section.grid-3 {
      grid-template-columns: 1fr;
      gap: 16px;
    }
    #experience-single section article { height: 280px; border-radius: 24px; }
    #experience-single section article figcaption { padding: 20px; }
    #experience-single section article figcaption h3 { font-size: 22px; }
  
    /* --- EXPERIENCE GRID --- */
    #experience-grid { margin-top: 10px; }
    #experience-grid section.grid-3,
    #experience-grid section.grid-2 {
      grid-template-columns: 1fr;
      gap: 16px;
    }
    #experience-grid section.grid-1-3 {
      grid-template-columns: 1fr;
      gap: 16px;
    }
    #experience-grid .column { gap: 16px; }
    #experience-grid .column article { border-radius: 24px; }
    #experience-grid .column figure.bg img { height: 240px; border-radius: 24px; }
  
    #experience-grid .column article.grid.bg-border {
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
  
    #experience-grid section.middle { width: 100%; }
    #experience-grid section.grid-2.middle {
      grid-template-columns: 1fr;
    }
    #experience-grid section.middle .column-1-3 {
      grid-column: auto;
    }
  
    #experience-grid .column .etapa h3 { font-size: 26px; }
    #experience-grid .column .etapa .timeline { padding: 30px 0 0 30px; }
  
    /* --- SIGN --- */
    #sign { margin-top: 60px; }
    #sign figure { border-radius: 24px; margin-top: -40px; }
    #sign figure figcaption {
      width: calc(100% - 40px);
      transform: translateX(-50%);
      bottom: 20px;
    }
    #sign figure figcaption h2 { font-size: 26px; }
    #sign figure figcaption p { font-size: 15px; }
  
    #sign.edicao { margin-top: 0; }
    #sign.edicao figure figcaption h2 { font-size: 24px; }
  
    /* --- CTA --- */
    #cta { margin-top: 50px; }
    #cta figure { border-radius: 24px; }
    #cta figure figcaption {
      width: calc(100% - 40px);
      transform: translateX(-50%);
      bottom: 20px;
      padding: 0 10px;
    }
    #cta figure figcaption h2 { font-size: 26px; }
    #cta figure figcaption p { font-size: 15px; }
    #cta figure img.logo { width: 180px; }
  
    /* --- BLOG --- */
    #blog { padding: 60px 0 80px 0; }
    #blog header h2 { font-size: 38px; }
    #blog header p { font-size: 18px; }
    #blog section.grid-2 {
      grid-template-columns: 1fr;
      gap: 24px;
    }
    #blog section article img { height: 200px; border-radius: 24px; }
  
    /* --- KAZA --- */
    #kaza { margin-top: -20px; overflow: hidden; }
    #kaza header { flex-direction: column; gap: 20px; text-align: center; }
    #kaza header img { width: 180px; }
    #kaza header h2 { font-size: 24px; }
    #kaza section.grid-2 {
      grid-template-columns: 1fr;
      gap: 16px;
      margin-top: 30px;
    }
    #kaza section::before,
    #kaza section::after { display: none; }
    #kaza section article { height: 300px; border-radius: 24px; }
    #kaza section article figcaption h3 { font-size: 22px; }
  
    #kaza.edicao { margin-top: 50px; }
    #kaza.edicao header h2 { width: 100%; font-size: 24px; }
  
    /* --- FOOTER --- */
    #footer {
      display: flex;
      flex-direction: column;
      gap: 30px;
      width: calc(100% - 24px);
      margin: 50px 12px 0 12px;
      padding: 40px 24px;
      border-radius: 24px;
    }
    #footer .column:nth-of-type(2) {
      display: flex;
      flex-wrap: wrap;
      gap: 20px;
    }
    #footer .column:nth-of-type(2) nav { flex: 1 1 100px; }
  
    /* --- BOTTOM --- */
    #bottom .container { flex-direction: column; gap: 8px; text-align: center; }
  
    /* --- BUTTON --- */
    span.bt a b { font-size: 14px; height: 46px; line-height: 46px; padding: 0 20px; }
    span.bt a::after { width: 46px; height: 46px; }
  
    /* --- GRID HELPERS (mobile override) --- */
    .grid-3 { grid-template-columns: 1fr; }
    .grid-2 { grid-template-columns: 1fr; }
    .grid-1-3 { grid-template-columns: 1fr; }
    .column-1-3 { grid-column: auto; }
  
  }

  /* ============================================================
   FIX #experiences no mobile — foto em cima, texto embaixo
   Cole no FINAL do style.css (substitui o fix anterior)
============================================================ */

@media (max-width: 768px) {

    #experiences {
      margin-bottom: 0;
      padding-bottom: 0;
      background-color: var(--gold);
    }
  
    #experiences::before,
    #experiences section::before {
      display: none;
    }
  
    #experiences .container {
      flex-direction: column;
      padding: 0;
      gap: 0;
    }
  
    /* Imagem — fica em CIMA, borda arredondada embaixo */
    #experiences aside {
      width: 100%;
      height: 280px;
      padding: 0 20px;
      order: 1;
    }
  
    #experiences figure img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      border-radius: 0 0 24px 24px;
    }
  
    #experiences figure em {
      color: var(--primary);
    }
  
    #experiences figure em::before {
      filter: brightness(0);
    }
  
    /* Bloco de texto — fica EMBAIXO, borda arredondada em cima */
    #experiences section {
      width: 100%;
      padding: 36px 24px 40px 24px;
      background-color: var(--primary);
      border-radius: 32px 32px 0 0;
      order: 2;
    }
  
    #experiences section h2 {
      font-size: 26px;
      line-height: 1.3;
    }
  
    #experiences section p {
      font-size: 14px;
      margin: 16px 0 28px 0;
    }
  
  }


  /* hero slider */
#hero .hero-slider { width: 100%; height: 100%; }

#hero .slide {
  position: relative;
  width: 100%;
  height: 90vh;
  outline: none;
}

#hero .slide img {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .6;
}

#hero .slide section {
  position: absolute;
  z-index: 2;
  bottom: 100px;
  left: 50%;
  width: 700px;
  margin-left: -550px;
}

#hero .slide section h1 {
  margin-bottom: 40px;
  font-weight: bold;
  font-size: 36px;
  line-height: 1.2;
  color: #fff;
}

#hero .slide em {
  position: absolute;
  bottom: 100px;
  right: 50px;
  z-index: 2;
  font-style: normal;
  color: #fff;
  font-size: 11px;
  line-height: 1.2;
}

#hero .slide em::before {
  position: absolute;
  top: 0; left: -25px;
  width: 20px; height: 20px;
  background: transparent url('assets/img/icon-gps.svg') no-repeat;
  content: '';
}

/* dots */
#hero .slick-dots {
  position: absolute;
  z-index: 10;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  display: flex !important;
  gap: 8px;
}

#hero .slick-dots li button {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: rgba(255,255,255,.4);
  font-size: 0;
  cursor: pointer;
  transition: all .3s ease;
}

#hero .slick-dots li.slick-active button {
  width: 28px;
  border-radius: 4px;
  background-color: #fff;
}

/* setas (opcional — remova se não quiser) */
#hero .slick-prev,
#hero .slick-next {
  position: absolute;
  z-index: 10;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255,255,255,.2);
  backdrop-filter: blur(6px);
  font-size: 0;
  cursor: pointer;
  transition: background .3s ease;
}
#hero .slick-prev { left: 30px; }
#hero .slick-next { right: 30px; }
#hero .slick-prev:hover,
#hero .slick-next:hover { background-color: rgba(255,255,255,.4); }

#hero .slick-prev::after { content: '←'; font-size: 18px; color: #fff; }
#hero .slick-next::after { content: '→'; font-size: 18px; color: #fff; }

/* mobile */
@media (max-width: 768px) {
  #hero .slide { height: 70vh; }
  #hero .slide section {
    width: calc(100% - 40px);
    left: 20px;
    bottom: 60px;
    margin-left: 0;
    transform: none;
  }
  #hero .slide section h1 { font-size: 24px; margin-bottom: 20px; }
  #hero .slide em { bottom: 20px; right: 20px; }
  #hero .slick-dots { bottom: 20px; }
  #hero .slick-prev { left: 16px; }
  #hero .slick-next { right: 16px; }
}


/* ============================================================
   FIX FINAL — Header + Partners
   Cole no FINAL do style.css (substitui todos os fixes anteriores)
============================================================ */

/* --- HEADER DESKTOP --- */
#header {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  #header span.logo { flex: 0 0 auto; }
  #header nav { flex: 1; display: flex; justify-content: center; }
  #header span.login { flex: 0 0 auto; margin-left: auto; }
  
  
  /* --- MOBILE --- */
  @media (max-width: 768px) {
  
    /* Header */
    #header nav {
      display: none;
      flex: none;
      justify-content: flex-start;
    }
    #header nav.open { display: block; }
    #header span.login { margin-left: 0; }
  
    /* Partners — scroll horizontal */
    #partners section {
      display: flex !important;
      flex-wrap: nowrap !important;
      grid-template-columns: unset !important;
      overflow-x: auto;
      gap: 0;
      padding: 10px 16px;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
      -ms-overflow-style: none;
    }
    #partners section::-webkit-scrollbar { display: none; }
    #partners section figure {
      flex: 0 0 auto;
      width: 130px;
      scroll-snap-align: start;
      padding: 0 10px;
    }
    #partners section figure img {
      width: 100%;
      height: 60px;
      object-fit: contain;
    }
  
  }


  /* --- Gallery (dentro do article) --- */
figure.img.gallery {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 50%;
  height: auto;      /* deixa altura automática */
  border-radius: 40px;
  overflow: hidden;
}

.gallery-main {
  width: 100%;
  height: 380px;
  overflow: hidden;
  cursor: pointer;
}

.gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform .4s ease;
}

.gallery-main img:hover { transform: scale(1.03); }

.gallery-thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}

.gallery-thumbs img {
  width: 100%;
  height: 80px;
  object-fit: cover;
  object-position: center top;
  cursor: pointer;
  border-radius: 10px;
  opacity: .7;
  transition: opacity .3s ease, transform .3s ease;
}

.gallery-thumbs img:hover,
.gallery-thumbs img.active {
  opacity: 1;
  transform: scale(1.04);
}


/* --- Lightbox --- */
#lightbox {
  display: none;
  position: fixed;
  z-index: 9999;
  inset: 0;
  background: rgba(0,0,0,.92);
  align-items: center;
  justify-content: center;
}

#lightbox.open { display: flex; }

.lb-wrap {
  position: relative;
  max-width: 90vw;
  max-height: 85vh;
}

.lb-wrap img {
  display: block;
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: 16px;
}

.lb-close {
  position: absolute;
  top: 20px;
  right: 24px;
  font-size: 24px;
  color: #fff;
  cursor: pointer;
  background: rgba(255,255,255,.15);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  transition: background .3s;
}
.lb-close:hover { background: rgba(255,255,255,.3); }

.lb-prev,
.lb-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  color: #fff;
  cursor: pointer;
  background: rgba(255,255,255,.15);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  transition: background .3s;
}
.lb-prev { left: 20px; }
.lb-next { right: 20px; }
.lb-prev:hover, .lb-next:hover { background: rgba(255,255,255,.3); }

.lb-dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
}

.lb-dots span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  cursor: pointer;
  transition: all .3s;
}

.lb-dots span.active {
  width: 24px;
  border-radius: 4px;
  background: #fff;
}

/* Mobile */
@media (max-width: 768px) {
  figure.img.gallery { width: 100%; border-radius: 24px; }
  .gallery-main { height: 240px; }
  .gallery-thumbs img { height: 60px; }
  .lb-prev { left: 10px; }
  .lb-next { right: 10px; }
}

/* Aside ocupa espaço correto */
#experiences aside {
  position: relative;
  overflow: hidden;
}

/* Cada slide */
.exp-slide {
  display: block;
  outline: none;
}

.exp-slide figure {
  position: relative;
  width: 100%;
  height: 480px;
  border-radius: 40px;
  overflow: hidden;
}

.exp-slide figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 40px;
  transition: transform .5s ease;
}

.exp-slide:hover figure img {
  transform: scale(1.04);
}

.exp-slide figure em {
  position: absolute;
  bottom: 16px;
  left: 20px;
  z-index: 2;
  margin-top: 0;
  font-weight: bold;
  font-style: normal;
  font-size: 12px;
  color: #fff;
}

.exp-slide figure em::before {
  display: inline-block;
  vertical-align: middle;
  width: 20px;
  height: 20px;
  padding-left: 5px;
  background: transparent url('assets/img/icon-gps.svg') no-repeat;
  content: '';
}

/* Dots */
#experiences .slick-dots {
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translateX(-50%);
  display: flex !important;
  gap: 8px;
}

#experiences .slick-dots li button {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(0,0,0,.25);
  font-size: 0;
  cursor: pointer;
  transition: all .3s ease;
}

#experiences .slick-dots li.slick-active button {
  width: 24px;
  border-radius: 4px;
  background: var(--gold);
}

/* Mobile */
@media (max-width: 768px) {
  .exp-slide figure { height: 280px; }
}

/* --- JS --- */
$('#experiences .exp-slider').slick({
  dots: true,
  arrows: true,
  infinite: true,
  speed: 700,
  fade: true,
  cssEase: 'ease-in-out',
  autoplay: true,
  autoplaySpeed: 4000,
  pauseOnHover: true,
  prevArrow: '<button class="exp-prev"></button>',
  nextArrow: '<button class="exp-next"></button>',
});


/* --- CSS --- */
.exp-prev,
.exp-next {
  position: absolute;
  z-index: 10;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: rgba(255,255,255,.25);
  backdrop-filter: blur(6px);
  cursor: pointer;
  transition: background .3s ease;
  font-size: 18px;
  color: #fff;
  line-height: 44px;
  text-align: center;
}

.exp-prev { left: 16px; }
.exp-next { right: 16px; }

.exp-prev:hover,
.exp-next:hover {
  background-color: rgba(255,255,255,.45);
}

.exp-prev::after { content: '←'; }
.exp-next::after { content: '→'; }

/* Mobile — setas menores */
@media (max-width: 768px) {
  .exp-prev,
  .exp-next {
      width: 36px;
      height: 36px;
      line-height: 36px;
      font-size: 15px;
  }
}


#hero.experience .slide {
  position: relative;
  width: 100%;
  height: 60vh;
  outline: none;
}

#hero.experience .slide img {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .6;
}

#hero.experience .slide section {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: auto;
  margin: 0;
  text-align: center;
}

#hero.experience .slide section h1 {
  font-size: 72px;
  line-height: 1;
  color: #fff;
  margin-bottom: 0;
}

#hero.experience .slide em {
  position: absolute;
  z-index: 2;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  font-style: normal;
  color: #fff;
  font-size: 11px;
  line-height: 1.2;
  white-space: nowrap;
}

#hero.experience .slide em::before {
  position: absolute;
  top: 0; left: -25px;
  width: 20px; height: 20px;
  background: transparent url('assets/img/icon-gps.svg') no-repeat;
  content: '';
}

/* Mobile */
@media (max-width: 768px) {
  #hero.experience .slide { height: 55vh; }
  #hero.experience .slide section h1 { font-size: 42px; }
}


#experiences .exp-slider { position: relative; }

#experiences .exp-slider .slick-prev,
#experiences .exp-slider .slick-next {
    position: absolute;
    z-index: 10;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background-color: rgba(255,255,255,.25);
    backdrop-filter: blur(6px);
    font-size: 0;
    cursor: pointer;
    transition: background .3s ease;
    line-height: 44px;
    text-align: center;
}

#experiences .exp-slider .slick-prev { left: 16px; }
#experiences .exp-slider .slick-next { right: 16px; }

#experiences .exp-slider .slick-prev:hover,
#experiences .exp-slider .slick-next:hover {
    background-color: rgba(255,255,255,.45);
}

#experiences .exp-slider .slick-prev::after { content: '←'; font-size: 18px; color: #fff; }
#experiences .exp-slider .slick-next::after { content: '→'; font-size: 18px; color: #fff; }

@media (max-width: 768px) {
  #experiences .exp-slider .slick-prev,
  #experiences .exp-slider .slick-next {
      width: 36px;
      height: 36px;
      line-height: 36px;
      font-size: 15px;
  }
  .exp-slide figure em {
    position: absolute;
    bottom: 16px;
    left: 16px;
    z-index: 10;
    color: #fff !important;
  }
}


/* ============================================================
   FIX — Título hero.edicao com slider, canto inferior esquerdo
   Cole no final do style.css
============================================================ */

#hero.edicao .slide {
  position: relative;
  width: 100%;
  height: 60vh;
  outline: none;
}

#hero.edicao .slide img {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .6;
}

/* Título no canto inferior esquerdo */
#hero.edicao .slide section {
  position: absolute;
  z-index: 2;
  bottom: 60px;
  left: 50px;
  top: auto;
  width: auto;
  max-width: 600px;
  text-align: left;
  transform: none !important;
  margin: 0;
}

#hero.edicao .slide section h1 {
  font-size: 36px;
  line-height: 1.2;
  color: #fff;
  font-weight: bold;
  margin-bottom: 0;
  /* Sombra para legibilidade em qualquer imagem */
  text-shadow: 0 2px 12px rgba(0,0,0,.4);
}

/* Mobile */
@media (max-width: 768px) {
  #hero.edicao .slide { height: 55vh; }
  #hero.edicao .slide section {
      bottom: 30px;
      left: 20px;
      right: 20px;
      max-width: 100%;
  }
  #hero.edicao .slide section h1 { font-size: 22px; }
}


#txt-side .container {
  display: flex;
  align-items: center;
  gap: 60px;
}

/* Imagem */
#txt-side figure.txt-img {
  flex: 0 0 45%;
  width: 45%;
  height: 100%;
  max-height: 600px;
  border-radius: 30px;
  overflow: hidden;
}

#txt-side figure.txt-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Texto */
#txt-side .txt {
  flex: 1;
  width: auto;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

#txt-side .txt small {
  display: block;
  font-weight: bold;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
}

/* Versão reverse — texto vem primeiro no HTML, imagem depois */
/* Já está na ordem certa no HTML, o .reverse só serve de referência visual */

/* Mobile */
@media (max-width: 768px) {

  #txt-side .container {
      flex-direction: column;
      gap: 24px;
  }

  /* No mobile, imagem sempre em cima */
  #txt-side figure.txt-img {
      flex: none;
      width: 100%;
      height: 240px;
      order: -1;
  }

  #txt-side .txt {
      width: 100%;
  }

}


/* Grid 4 colunas */
.grid-4 { grid-template-columns: repeat(4, 1fr); gap: 20px; }

@media (max-width: 1024px) { .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px)  { .grid-4 { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

/* Cards — reutiliza estilo do #experience-single article */
#experience-single .exp-card { cursor: pointer; }
#experience-single .exp-card a { display: block; }
#experience-single .exp-card:hover figure img { transform: scale(1.04); }
#experience-single .exp-card figure img { transition: transform .4s ease; }

/* ---- MODAL ---- */
#exp-modal {
    display: none;
    position: fixed;
    z-index: 9999;
    inset: 0;
    background: rgba(0,0,0,.75);
    align-items: center;
    justify-content: center;
    padding: 20px;
}
#exp-modal.open { display: flex; }

.exp-modal-box {
    position: relative;
    width: 100%;
    max-width: 860px;
    max-height: 90vh;
    overflow-y: auto;
    background: #fff;
    border-radius: 20px;
    padding: 40px;
}

.exp-modal-close {
    position: absolute;
    top: 16px; right: 20px;
    font-size: 20px;
    cursor: pointer;
    color: var(--primary);
    width: 36px; height: 36px;
    border-radius: 50%;
    background: #f0f0f0;
    line-height: 36px;
    text-align: center;
    transition: background .3s;
}
.exp-modal-close:hover { background: #ddd; }

.exp-modal-header { margin-bottom: 16px; }
.exp-modal-title  { font-weight: bold; font-size: 22px; color: var(--primary); line-height: 1.3; }
.exp-modal-subtitle { margin-top: 6px; font-size: 13px; color: #888; }

hr { border: none; border-top: 1px solid #eee; margin: 16px 0; }

/* Imagem principal */
.exp-modal-main {
    position: relative;
    width: 100%;
    height: 420px;
    border-radius: 14px;
    overflow: hidden;
    background: #000;
}
.exp-modal-img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: opacity .3s ease;
}

.exp-modal-prev,
.exp-modal-next {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    z-index: 2;
    width: 40px; height: 40px;
    border-radius: 50%;
    background: rgba(255,255,255,.25);
    backdrop-filter: blur(6px);
    color: #fff; font-size: 24px;
    line-height: 38px; text-align: center;
    cursor: pointer;
    transition: background .3s;
}
.exp-modal-prev { left: 12px; }
.exp-modal-next { right: 12px; }
.exp-modal-prev:hover,
.exp-modal-next:hover { background: rgba(255,255,255,.45); }

/* Miniaturas */
.exp-modal-thumbs {
    display: flex;
    gap: 8px;
    margin-top: 10px;
    flex-wrap: wrap;
}
.exp-modal-thumbs img {
    width: 80px; height: 60px;
    object-fit: cover;
    border-radius: 8px;
    cursor: pointer;
    opacity: .6;
    transition: opacity .3s, transform .3s;
    border: 2px solid transparent;
}
.exp-modal-thumbs img:hover,
.exp-modal-thumbs img.active {
    opacity: 1;
    transform: scale(1.05);
    border-color: var(--gold);
}

/* Descrição */
.exp-modal-desc {
    margin-top: 20px;
    line-height: 1.6;
    color: var(--primary);
    font-size: 14px;
}

/* Mobile */
@media (max-width: 768px) {
    .exp-modal-box { padding: 24px 16px; }
    .exp-modal-main { height: 240px; }
    .exp-modal-thumbs img { width: 60px; height: 46px; }
}

.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

@media (max-width: 1024px) { .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px)  { .grid-4 { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

.slide video {
  width: 100%;
  height: 100%;
  object-fit: cover; /* cobre o slide inteiro, igual uma imagem de fundo */
  display: block;
}