/*
Theme Name: Expo Fit
Theme URI: https://www.expofitmg.com.br/
Author: Evandro Bitencourt
Author URI: https://flyingweb.com.br/
Description: Expo Fit: A plataforma definitiva para a venda de ingressos online e campeonato. Este tema WordPress foi cuidadosamente projetado para oferecer uma experiência de compra fluida e segura, capacitando organizadores de eventos a gerenciar e promover suas vendas com eficiência e estilo. Transforme cada evento em um sucesso com um design intuitivo e funcionalidades robustas.
Version: 1.0
Text Domain: expo-fit
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: e-commerce, custom-menu, custom-logo, featured-images, footer-widgets, theme-options, translation-ready, blog, right-sidebar, sticky-post, threaded-comments
*/

/* ===========================
   Identidade Visual — EXPO-FIT
   Cores: vermelho (#fb2c36), preto e branco
   =========================== */
:root{
  /* Paleta base EXPO-FIT */
  --expo-red:        #fb2c36;    /* vermelho principal */
  --expo-red-dark:   #d02135;    /* hover do vermelho */
  --expo-black:      #0d0f12;    /* fundo escuro principal */
  --expo-black-2:    #161616;    /* variação p/ cards/rodapé */
  --expo-white:      #ffffff;

  /* ===== ALIAS para manter CSS existente ===== */
  --mci-red:         var(--expo-red);
  --mci-red-dark:    var(--expo-red-dark);
  /* todo uso antigo de "azul" passa a usar vermelho */
  --mci-blue:        var(--expo-red);
  --mci-blue-dark:   var(--expo-red-dark);
  --mci-dark:        var(--expo-black);

  --mc-red:          var(--expo-red);
  --mc-blue:         var(--expo-red);
  --mc-dark:         var(--expo-black);

  /* acentos usados em busca/inputs */
  --mc-accent:       var(--expo-red);
  --mc-text:         #e9e9e9;
  --mc-muted:        #98a1aa;
}

/* ===== Base ===== */
*{
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

body{
  font-family: 'Poppins', sans-serif;
  font-weight: 400;
  background-color: var(--expo-white);
  color: var(--expo-black);
}

a{
  color: var(--expo-white);
  text-decoration: none;
}
a:hover{
  color: var(--expo-red-dark);
  text-decoration: none;
}

/* Utilitários de marca */
.text-brand   { color: var(--expo-red) !important; }
.bg-brand     { background: var(--expo-red) !important; color:#fff !important; }
.border-brand { border-color: var(--expo-red) !important; }

/* ===========================
   Seções e elementos globais
   =========================== */
.section-site { padding: 80px 0px; }

/* Header */
.img-logo { width: 150px!important; height: auto; }

/* Home - featured cards */
.featured-events .card {
  background-color: #282828;
  color: #ffffff;
  border-radius: 0.5rem;
}
.featured-events .card-title { color: #ffffff; }
.featured-events .card-text  { color: #cccccc; }
.featured-events .card-img-top {
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}
.featured-events .card-text i { color: #cccccc; }

/* Event card (hover/scale) */
.event-card {
  border-radius: 1rem;
  transition: transform .25s ease, box-shadow .25s ease;
  background-color: #0e0e0e;
}
.event-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 1.25rem 2.5rem rgba(0,0,0,.45);
}
.event-image-wrapper { will-change: transform; }
.event-image {
  transition: transform .35s ease;
  transform-origin: center center;
}
.event-card:hover .event-image { transform: scale(1.05); }
.object-fit-cover { object-fit: cover; object-position: center; }

/* ===========================
   Footer
   =========================== */
.site-footer {
  background-color: var(--expo-white);
  color: var(--expo-black);
}
.site-footer a { color: #fff; text-decoration: none; }
.site-footer a:hover { color: #cccccc; }
.site-footer h6.widget-title {
  color: #fff;
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 1rem;
}
.site-footer .social-icons i { color: #fff; }
.site-footer .small { font-size: 0.875em; }
.site-footer .navbar-brand p,
.site-footer .navbar-brand span { color: #fff; }
.site-footer .widget ul { list-style: none; padding-left: 0; margin-bottom: 0; }
.site-footer .widget ul li { margin-bottom: 0.5rem; }
.site-footer .widget ul li a { color: #fff; }
.site-footer .widget ul li a:hover { color: var(--expo-red); }
.site-footer .widget .widget-title { display: none; }
.site-footer .menu li { list-style: none; }
.site-footer .menu li a { color: #cccccc; }
.site-footer .menu li a:hover { color: #fff; }
.text-mci { color: var(--expo-red) !important; }

/* ===========================
   WooCommerce - Shop / Archive
   =========================== */
.shop-content{ padding: 3rem 0; }
.shop-content .row{ margin-left: 0; margin-right: 0; }
.post-type-archive-product .content-area,
.product-template-default .content-area,
.tax-product_cat .content-area{ padding: 0; }

.woocommerce .woocommerce-breadcrumb a {
  font-weight: 700;
  color: var(--mci-blue);
}
.woocommerce .woocommerce-breadcrumb a:hover{ color: var(--mci-red); }

.woocommerce ul.products.columns-1 li.product:first-child,
.woocommerce-page ul.products.columns-1 li.product:first-child { margin-top: 20px; }

.woocommerce ul.products li.product a img {
  width: 255px; height: auto; display: block;
  margin: 0 1em 1em 0; box-shadow: none; float: left;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-size: 25px; font-weight: 700; color: #000;
  padding: 0; display: table; margin-bottom:20px;
}
.post-type-archive-product .woocommerce-loop-product__title{ margin-bottom: 0.5rem !important; }

.woocommerce ul.products li.product .button {
  margin-top: 0; background-color: var(--mci-red);
  color: #fff; border: 0;
}
.woocommerce ul.products li.product .button:hover {
  background-color: var(--mci-red-dark); color: #fff;
}

.woocommerce .woocommerce-ordering select { vertical-align: top; padding:5px; }
.woocommerce ul.products li.product p{ color: #000; }

.woocommerce ul.products li.product .price{
  color: #000; font-weight: 600; display:none;
}
.woocommerce ul.products li.product .price ins { font-size: 140%; }

/* Fita de promoção (LISTA) */
.woocommerce ul.products li.product .onsale{
  top: 16px; right: 0; left: 0; transform: rotate(90deg);
  border-radius: 0; width: 83px; padding: 0;
  background-color: var(--mci-red); margin: 0; font-weight: 400;
}
.woocommerce ul.products li.product .onsale:before {
  content: ""; position: absolute; top: 0; left: 83px;
  width: 0; height: 0; border-style: solid;
  border-width: 24px 22px 0 0;
  border-color: var(--mci-red) transparent transparent transparent;
}
.woocommerce ul.products li.product .onsale:after {
  content: ""; position: absolute; bottom: 0; left: 83px;
  width: 0; height: 0; border-style: solid;
  border-width: 0 22px 24px 0;
  border-color: transparent transparent var(--mci-red) transparent;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span{
  color: var(--mci-blue); border: 0;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current{
  background: var(--mci-blue); color: #fff;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span { padding: 12px; }

/* ===========================
   WooCommerce - Single Product
   =========================== */
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce ul.products li.product .button {
  background-color: var(--mci-red);
  color: #fff; border: 0;
}
.woocommerce #respond input#submit.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce ul.products li.product .button:hover {
  background-color: var(--mci-red-dark);
}

.product_meta > span{ display: block; }

.woocommerce div.product p.price del,
.woocommerce div.product span.price del,
.woocommerce ul.products li.product .price del .woocommerce-Price-amount{
  color: #000; font-size: 20px; font-weight: 500;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins,
.woocommerce-Price-amount {
  font-size: 25px; color: #fff; font-weight: 700;
}

/* Fita de promoção (SINGLE) */
.woocommerce span.onsale{
  top: 19px; left: 35px; transform: rotate(90deg);
  border-radius: 0; width: 84px; padding: 0;
  background-color: var(--mci-red); margin: 0; font-weight: 400;
}
.woocommerce span.onsale:before {
  content: ""; position: absolute; top: 0; left: 83px;
  width: 0; height: 0; border-style: solid;
  border-width: 23px 22px 0 0;
  border-color: var(--mci-red) transparent transparent transparent;
}
.woocommerce span.onsale:after {
  content: ""; position: absolute; bottom: 0; left: 83px;
  width: 0; height: 0; border-style: solid;
  border-width: 0 22px 23px 0;
  border-color: transparent transparent var(--mci-red) transparent;
}

.woocommerce div.product .woocommerce-tabs ul.tabs{ padding: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li{
  border-radius: 0; margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::after,
.woocommerce div.product .woocommerce-tabs ul.tabs li::before{ content: none; }

/* Botões padrão */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button{
  background-color: var(--mci-red);
  color: #fff; border: 0;
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover{
  background-color: var(--mci-red-dark); color: #fff;
}

/* Cart */
.woocommerce-cart table.cart td.actions .coupon .input-text{ width: 150px; }

/* Checkout */
.woocommerce form .form-row { display: block; }
.woocommerce-checkout #customer_details{ margin-bottom: 20px; }
.woocommerce table.shop_table{ border-collapse: collapse; }
.woocommerce table.shop_table thead{
  background-color: var(--mci-dark); color: #fff;
}

/* Filtro de preço */
.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
  position: absolute; z-index: 1; font-size: .7em; display: block;
  border: 0; border-radius: 1em; background-color: var(--mci-red);
}
.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  position: absolute; z-index: 2; width: 1em; height: 1em;
  background-color: var(--mci-blue); border-radius: 1em;
  cursor: ew-resize; outline: 0; top: -0.3em; margin-left: -0.5em;
}


.woocommerce ul.products li.product .woocommerce-loop-category__title, .woocommerce ul.products li.product .woocommerce-loop-product__title, .woocommerce ul.products li.product h3 {
    padding: .5em 0;
    margin: 0;
    font-size: 1em;
    color: #000;
}

/* ===========================
   Tipografia & Links gerais
   =========================== */
p, ul li a, .nav-links a, .nav-links span{ font-size: 1.15rem; }

/* ===========================
   Widgets (Shop)
   =========================== */
.woocommerce .shop-content .widget-wrapper{
  margin: 0 0 2rem; border-bottom: 1px solid #eee; padding: 0 1em 2em 0;
}
.woocommerce .shop-content .widget-wrapper h4{ padding: 0 0 0.7rem 0; }
.woocommerce .shop-content .widget-wrapper > ul{
  list-style: none; padding: 0; margin: 0;
}
.woocommerce .shop-content .widget-wrapper > ul li ul{ list-style: none; }
.woocommerce .shop-content .widget-wrapper ul li span,
.woocommerce .shop-content .widget-wrapper ul li ul li span{ float: right; }

.mark, mark {
  padding: 0.2em; background-color: #fcf8e3; display: inline-block;
}

/* ===========================
   About / Pitch / Contact
   =========================== */
.about-card{ border: 1px solid rgba(255,255,255,.08); }
.about-card .page-content h2{
  font-weight: 800; margin-top: 2rem; margin-bottom: 1rem; color:#000;
}
.about-card .page-content h3,
.about-card .page-content h4{
  font-weight: 700; margin-top: 1.5rem; margin-bottom: .75rem; color:#000;
}
.about-card .page-content h2 strong,
.about-card .page-content h3 strong{ color: var(--mc-red); }

.about-card a{ color: var(--mc-blue); text-decoration: none; }
.about-card a:hover{ color: var(--mc-red); text-decoration: underline; }

.about-card .page-content ul{ padding-left: 1.25rem; margin-bottom: 1.25rem; }
.about-card .page-content ul li{ margin-bottom: .5rem; }

.brand-divider{ width: 160px; height: 4px; border-radius: 999px;
  background: linear-gradient(90deg, var(--mc-red), var(--mc-blue)); }

.lead-sm{ font-size: 1.05rem; line-height: 1.8; }

.about-card hr{
  border: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.2), transparent);
  margin: 2rem 0;
}

/* Pitch */
.mc-pitch{ color:#fff; }
.mc-card{
  position: relative; background: #161616;
  border: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
  overflow: hidden;
}
.mc-card::before{
  content:""; position:absolute; left:0; top:0; width:100%; height:4px;
  background: linear-gradient(90deg, var(--mc-blue) 0%, var(--mc-red) 100%);
}
.mc-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
  transition: transform .2s ease, box-shadow .2s ease;
}
.mc-pitch h2{ color:#fff; }

/* Contact */
.form-card{
  background:#111; color:#fff;
  border:1px solid rgba(255,255,255,.08);
  border-radius:1.25rem;
  box-shadow:0 18px 40px rgba(0,0,0,.45);
  overflow:hidden; position:relative;
}
.form-card .topbar{
  height:4px; background:linear-gradient(90deg,var(--mc-blue),var(--mc-red));
}

.mc-form .form-control,
.mc-form .form-select{
  background:#141414; color:#fff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:.8rem; padding:.8rem 1rem;
}
.mc-form .form-control::placeholder{ color:#8e8e8e; }
.mc-form .form-select option{ background:#141414; color:#fff; }
.mc-form .form-control:focus,
.mc-form .form-select:focus{
  border-color: var(--mc-blue);
  box-shadow: 0 0 0 .25rem rgba(251,44,54,.15);
  background:#161616; color:#fff;
}

/* Chips & alerts */
.contact-chip{
  display:inline-flex; align-items:center; gap:.25rem;
  background:#181818; color:#fff; border:1px solid rgba(255,255,255,.12);
  padding:.6rem 1rem; border-radius:999px; text-decoration:none;
}
.contact-chip:hover{ border-color: var(--mc-blue); color:#fff; }
.contact-chip--whats{ border-color:#25D366; }
.contact-chip--whats:hover{ background:#25D366; color:#0b0b0b; }

.alert{ background:#171717; color:#fff; border:1px solid rgba(255,255,255,.15); }
.alert-success{ background:rgba(0,173,238,.08); border-color:rgba(0,173,238,.25); }
.alert-danger{ background:rgba(222,26,32,.08); border-color:rgba(222,26,32,.25); }


/* ===========================
   Busca compacta / Header 
   =========================== */
.header-row{ min-height:72px; display:flex; align-items:center; }
.search-compact{ max-width:520px; margin:0 auto; }

/* caixa clara */
.search-compact__wrap{
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:12px;
  overflow:hidden;
  height:40px;
  box-shadow:
    0 1px 2px rgba(0,0,0,.04),
    0 8px 24px rgba(0,0,0,.06);
}

/* input claro */
.search-compact__input{
  flex:1; height:100%;
  background:transparent;
  border:0; outline:0;
  color:#111;
  padding:0 46px 0 14px;
  font-size:.95rem;
}
.search-compact__input::placeholder{ color:#6b7280; }

/* botão/lupa vermelho da marca */
.search-compact__btn{
  width:44px; height:100%; border:0;
  background:transparent;
  color:var(--expo-red);
  display:grid; place-items:center;
  transition:background .15s, transform .05s, color .15s;
}
.search-compact__btn:hover{
  background:rgba(251,44,54,.07);
  color:var(--expo-red-dark);
}
.search-compact__btn:active{ transform:scale(.98); }

/* foco acessível na caixa */
.search-compact__wrap:focus-within{
  border-color:var(--expo-red);
  box-shadow:0 0 0 3px rgba(251,44,54,.15);
}

@media (max-width: 991.98px){
  .search-compact{ max-width:100%; }
}


/* Header mobile */
.btn-menu { font-size: 32px; line-height: 1; }
.cart-link { position: relative; }
/* badge do carrinho (mesma classe, só ajustada) */
.cart-badge{
  position: absolute;
  top: -6px;              /* sobe um pouco */
  right: -8px;            /* encosta no canto */
  min-width: 20px;        /* tamanho do “pílula” */
  height: 20px;
  padding: 0 !important;  /* neutraliza p-1 do Bootstrap se vier no HTML */
  background: var(--expo-red);
  color: #fff;
  border-radius: 999px !important; /* círculo/pílula perfeita */
  display: inline-flex;            /* centraliza o número */
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 0 0 2px #fff;      /* “bordinha” p/ destacar (opcional) */
}

.header-compact .search-form .search-bar-custom{
  background:#1c1f23; border:1px solid rgba(255,255,255,.18);
  box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, 0 8px 24px rgba(0,0,0,.45);
  border-radius: 10px; height: 46px;
}
.header-compact .search-input-custom{ height:46px; background:#1c1f23; color:#fff; }
.header-compact .custom-search-btn{ color:#fff; }
.header-compact .custom-search-btn .bi-search{ opacity:.85; }

@media (min-width: 768px){
  .search-form .search-bar-custom{
    background:#1c1f23; border:1px solid rgba(255,255,255,.15);
    box-shadow: 0 0 0 1px rgba(255,255,255,.06) inset, 0 8px 24px rgba(0,0,0,.45);
    border-radius: 10px; height: 48px;
  }
  .search-form .search-input-custom{ height:48px; color:#fff; background:#1c1f23; }
}

.offcanvas .btn-close { filter: invert(1); opacity: .9; }

/* ===========================
   CTA Cursos / Botões gradiente
   =========================== */
.fw-900{ font-weight:900; }
.mc-cta-cursos{
  background:#111; color:#fff;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  box-shadow:0 18px 40px rgba(0,0,0,.45);
}
.mc-cta-cursos:before{
  content:""; position:absolute; left:0; top:0; width:100%; height:4px;
  background:linear-gradient(90deg,var(--mc-red),var(--mc-blue));
}
.btn-mc-gradient{
  background:linear-gradient(90deg,var(--mc-red),var(--mc-blue));
  border:0; color:#fff; font-weight:800;
  border-radius:12px; padding:.9rem 1.25rem;
  box-shadow:0 10px 24px rgba(0,173,238,.18);
}
.btn-mc-gradient:hover{ filter:brightness(.95); color:#fff; }

/* Event cards ajustes */
.event-card .event-image-wrapper{ border-radius:.75rem .75rem 0 0; }
.event-card .event-image{ display:block; }

/* ===========================
   Paginação de eventos
   =========================== */
.mc-pagination .page-numbers,
.mc-pagination .mc-page-list{
  list-style: none; margin: 0; padding: 0;
  display: flex; justify-content: center; gap: .5rem;
}
.mc-pagination .page-numbers li { list-style: none; }
.mc-pagination .page-numbers a,
.mc-pagination .page-numbers span{
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 42px; height: 42px; padding: 0 .9rem;
  border-radius: 12px; font-weight: 800; text-decoration: none;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease, color .12s ease, border-color .12s ease;
  background: #111; color: #e6e6e6; border: 1px solid rgba(255,255,255,.12);
}
.mc-pagination .page-numbers a:hover{
  background: linear-gradient(90deg, var(--mc-red), var(--mc-blue));
  color: #fff; border-color: transparent; box-shadow: 0 10px 24px rgba(0,173,238,.18);
  transform: translateY(-1px);
}
.mc-pagination .page-numbers .current{
  background: linear-gradient(90deg, var(--mc-red), var(--mc-blue));
  color: #fff; border: 0; box-shadow: 0 8px 18px rgba(0,173,238,.18);
}
.mc-pagination .page-numbers .prev,
.mc-pagination .page-numbers .next{ min-width: 38px; padding: 0 .6rem; }
@media (max-width: 480px) {
  .mc-pagination .page-numbers a,
  .mc-pagination .page-numbers span {
    min-width: 36px; height: 36px; padding: 0 .7rem;
    border-radius: 10px; font-size: .95rem;
  }
}

/* ===== Impact Numbers (Home) ===== */
.impact-section{
  background: var(--expo-black-2); /* faixa escura como no print */
  color: #fff;
}
.impact-item .impact-icon{
  font-size: 3.5rem;
  line-height: 1;
  color: var(--expo-red);
}
.impact-label{
  margin-top: .75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--expo-red);
}

/* ===== Carrossel de Apoiadores (Smart Slider 3) ===== */
.sponsors-section{
  background: #f7f8fa;           /* faixa clara (como no print) */
  color: var(--expo-black);
}

.sponsors-section h2{
  color: var(--expo-black);
  letter-spacing: .02em;
}

/* Ajuste visual dos slides (estrutura do Smart Slider) */
.sponsors-section .n2-ss-slider,
.sponsors-section .n2-ss-slider .n2-ss-slide{
  background: transparent !important;
}

/* Imagens: proporção contida, cinza + hover */
.sponsors-section .n2-ss-slider img{
  max-height: 140px;
  width: auto;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: .85;
  transition: filter .2s ease, opacity .2s ease, transform .2s ease;
}

.sponsors-section .n2-ss-slider img:hover{
  filter: grayscale(0);
  opacity: 1;
  transform: translateY(-2px);
}

/* Borda/sombra “cartão” usando o layer do slide (quando for fundo claro) */
.sponsors-section .n2-ss-slide .n2-ss-layer img{
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 12px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}

.event-hero-img{
  display:block;
  width:100%;
  max-width: 700px;  /* pode até remover se 1200px já for o que quer */
  height:auto;
  margin: 0 auto;
}

/* ===== Desktop main nav (barra preta abaixo dos apoiadores) ===== */
.desktop-main-nav{
  background:#000;
  padding: 10px 0;
}

.desktop-main-nav .menu > li > a{
  color:#fff;
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.02em;
  text-decoration:none;
  padding:.5rem .75rem;
  display:inline-block;
}

.desktop-main-nav .menu > li > a:hover,
.desktop-main-nav .menu > li.current-menu-item > a,
.desktop-main-nav .menu > li.current_page_item > a{
  color: var(--expo-red, #fb2c36);
}



