body {
	font-family: "Nunito", sans-serif;
  	font-optical-sizing: auto;
  	font-weight: 600;
	color: #3B3734;
	font-size: 12px;
	line-height: 20px;
	width: 100%;
}
.clear {
  clear: both;
}
h1, h2, h3, h4, h5, h6 {
	color: #3B3734;
}
/* default font size */
.fa {
	font-size: 14px;
}
/* Override the bootstrap defaults */
h1 {
	font-size: 33px;
}
h2 {
	font-size: 27px;
}
h3 {
	font-size: 21px;
}
h4 {
	font-size: 15px;
}
h5 {
	font-size: 12px;
}
h6 {
	font-size: 10.2px;
}
a {
	color: #3B3734;
}
a:hover {
	text-decoration: none;
}
legend {
	font-size: 18px;
	padding: 7px 0px
}
label {
	font-size: 12px;
	font-weight: normal;
}
select.form-control, textarea.form-control, input[type="text"].form-control, input[type="password"].form-control, input[type="datetime"].form-control, input[type="datetime-local"].form-control, input[type="date"].form-control, input[type="month"].form-control, input[type="time"].form-control, input[type="week"].form-control, input[type="number"].form-control, input[type="email"].form-control, input[type="url"].form-control, input[type="search"].form-control, input[type="tel"].form-control, input[type="color"].form-control {
	font-size: 12px;
}
.input-group input, .input-group select, .input-group .dropdown-menu, .input-group .popover {
	font-size: 12px;
}
.input-group .input-group-addon {
	font-size: 12px;
	height: 30px;
}
/* Fix some bootstrap issues */
span.hidden-xs, span.hidden-sm, span.hidden-md, span.hidden-lg {
	display: inline;
}

.nav-tabs {
	margin-bottom: 15px;
}
div.required .control-label:before {
	content: '* ';
	color: #F00;
	font-weight: bold;
}
/* Gradent to all drop down menus */
.dropdown-menu li > a:hover {
	text-decoration: none;
	color: #ffffff;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
}
/************/
/* HEADER */
/* =========================
   PROTECTIVA SEGUROS HEADER
========================= */

body {
  overflow-x: hidden;
}

/* =========================
   TOPO NOVO - PROTECTIVA
========================= */

#top.protectiva-topbar {
  background: #f6f8fc;
  border-bottom: 1px solid #e7edf6;
  padding: 10px 0;
  min-height: auto;
}

.protectiva-topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.protectiva-topbar-left,
.protectiva-topbar-right {
  display: flex;
  align-items: center;
  gap: 18px;
}

.protectiva-topbar-left {
  min-width: 0;
  flex: 1;
}

.protectiva-topbar-right {
  flex-shrink: 0;
}

.protectiva-topbar-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #506072;
  font-size: 13px;
  line-height: 1.3;
}

.protectiva-topbar-item i {
  color: #0a58ca;
  font-size: 14px;
}

.protectiva-topbar-item span {
  color: #425164;
}

.protectiva-topbar-item a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #243447;
  text-decoration: none !important;
  font-weight: 600;
  transition: all .2s ease;
}

.protectiva-topbar-item a:hover {
  color: #0a58ca;
}

.protectiva-topbar-address span,
.protectiva-topbar-hours span {
  white-space: nowrap;
}

.protectiva-topbar-flags {
  gap: 10px;
}

.protectiva-top-label {
  font-weight: 700;
  color: #223247 !important;
}

.protectiva-topbar-whatsapp a {
  color: #16a34a;
  font-weight: 700;
}

.protectiva-topbar-whatsapp a i {
  color: #16a34a;
  font-size: 16px;
}

.protectiva-topbar-whatsapp a:hover {
  color: #12803a;
}

.protectiva-topbar-social {
  display: flex;
  align-items: center;
  gap: 8px;
}

.protectiva-topbar-social a {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: #ffffff;
  border: 1px solid #dfe7f2;
  color: #223247;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  transition: all .2s ease;
}

.protectiva-topbar-social a:hover {
  background: #0a58ca;
  border-color: #0a58ca;
  color: #ffffff;
  transform: translateY(-1px);
}

/* remove resquícios visuais antigos do topo */
#top .btn-link,
#top-links a {
  text-shadow: none;
}

/* =========================
   RESPONSIVO TOPO
========================= */

@media (max-width: 1199px) {
  .protectiva-topbar-inner {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .protectiva-topbar-left,
  .protectiva-topbar-right {
    justify-content: center;
    flex-wrap: wrap;
  }

  .protectiva-topbar-address span,
  .protectiva-topbar-hours span {
    white-space: normal;
    text-align: center;
  }
}

@media (max-width: 767px) {
  #top.protectiva-topbar {
    padding: 8px 0;
  }

  .protectiva-topbar-left,
  .protectiva-topbar-right {
    gap: 10px 14px;
  }

  .protectiva-topbar-item {
    font-size: 12px;
  }

  .protectiva-topbar-social a {
    width: 30px;
    height: 30px;
  }

  .protectiva-topbar-phone span,
  .protectiva-topbar-whatsapp span {
    display: none;
  }
}
/*HEADER MAIN*/
.protectiva-header {
  /*background: #ffffff;*/
  padding: 20px 0;
  position: relative;
  z-index: 70;
}

.protectiva-header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.protectiva-logo-area {
  flex: 0 0 auto;
  margin-right: 10px;
}
/**/
.protectiva-logo {
  position: relative;
}
/**/
.protectiva-logo img {
  max-height: 90px;
  width: auto;
}

.protectiva-logo h1 {
  margin: 0;
}

.protectiva-logo h1 a {
  color: #142033;
  text-decoration: none;
  font-size: 30px;
  font-weight: 800;
}

.protectiva-header-right {
  flex: 1 1 auto;
  display: flex;
  justify-content: flex-end;
}

.protectiva-header-actions {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.protectiva-search-wrap {
  flex: 1 1 auto;
  min-width: 320px;
  margin-right: auto;
}

.protectiva-search-wrap #search {
  width: 100%;
}

.protectiva-search-wrap #search .input-lg {
  width: 100%;
  height: 46px;
  border-radius: 14px 0 0 14px;
  border: 1px solid #dbe3ee;
  box-shadow: none;
  font-size: 14px;
}

.protectiva-search-wrap #search .btn-lg {
  height: 46px;
  min-width: 56px;
  border-radius: 0 14px 14px 0;
  border: 1px solid #dbe3ee;
  border-left: 0;
  background: #ffffff;
  color: #1f2d3d;
  padding: 0 16px;
}

.protectiva-search-wrap #search .btn-lg:hover {
  background: #0a58ca;
  color: #fff;
  border-color: #0a58ca;
}

/**/
/* =========================
   DROPDOWN ATENDIMENTO
========================= */

.protectiva-dropdown-atendimento {
  position: relative;
}

.protectiva-atendimento-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* MENU */
.protectiva-atendimento-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 280px;
  background: #ffffff;
  border-radius: 16px;
  box-shadow: 0 20px 50px rgba(15, 34, 58, 0.15);
  padding: 10px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: all .25s ease;
  z-index: 999;
}

/* HOVER abre */
.protectiva-dropdown-atendimento:hover .protectiva-atendimento-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* ITEM */
.protectiva-atendimento-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  text-decoration: none !important;
  transition: all .2s ease;
}

.protectiva-atendimento-item:hover {
  background: #f5f8fd;
}

/* ÍCONE */
.protectiva-atendimento-item i {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: #eef4ff;
  color: #0a58ca;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}

/* TEXTO */
.protectiva-atendimento-item strong {
  display: block;
  font-size: 14px;
  color: #1f2d3d;
  font-weight: 700;
}

.protectiva-atendimento-item span {
  font-size: 12px;
  color: #6b7a8c;
}

/* RESPONSIVO */
@media (max-width: 991px) {
  .protectiva-atendimento-menu {
    right: auto;
    left: 0;
    width: 100%;
  }
}

@media (max-width: 768px) {

  .protectiva-dropdown-atendimento {
    position: relative !important;
  }

  .protectiva-atendimento-menu {
    position: absolute !important;
    top: calc(100% + 10px) !important;
    right: 0 !important;
    left: auto !important;

    width: 260px !important;
    min-width: 260px !important;
    max-width: calc(100vw - 32px) !important;

    padding: 12px !important;
    border-radius: 18px !important;
    overflow: visible !important;

    z-index: 99999 !important;
  }

  .protectiva-atendimento-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;

    width: 100% !important;
    padding: 12px 10px !important;
    white-space: normal !important;
  }

  .protectiva-atendimento-item i {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .protectiva-atendimento-item div {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .protectiva-atendimento-item strong,
  .protectiva-atendimento-item span {
    display: block !important;
    line-height: 1.3 !important;
    white-space: normal !important;
  }

  .protectiva-atendimento-item strong {
    font-size: 13px !important;
  }

  .protectiva-atendimento-item span {
    font-size: 11px !important;
  }
}
/**/
.protectiva-btn {
  height: 46px;
  padding: 0 18px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none !important;
  transition: all .25s ease;
  border: 1px solid transparent;
}

.protectiva-btn-outline {
  background: #ffffff;
  color: #16355c;
  border-color: #d6e1ef;
}

.protectiva-btn-outline:hover {
  background: #f4f8fd;
  color: #0a58ca;
  border-color: #b9cde6;
}

.protectiva-btn-primary {
  background: linear-gradient(135deg, #0d5bd7 0%, #0a77ff 100%);
  color: #ffffff;
  box-shadow: 0 10px 25px rgba(10, 91, 215, 0.18);
}

.protectiva-btn-primary:hover {
  background: linear-gradient(135deg, #0b4fbf 0%, #086ae6 100%);
  color: #ffffff;
  transform: translateY(-1px);
}

.protectiva-header-mobile-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.protectiva-mobile-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: #f5f8fd;
  color: #16355c;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  font-size: 17px;
}

.protectiva-mobile-icon:hover {
  background: #0a58ca;
  color: #fff;
}
/*MENU STICKY*/
/* =========================
   HEADER ABSOLUTO ORIGINAL
========================= */
.top-header{
  position: absolute;
  top: 60px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 59;

  width: calc(100% - 80px);
  max-width: 1920px;

  border-radius: 28px;

  background:
    linear-gradient(90deg,
      rgba(11,14,20,0.72) 0%,
      rgba(88,14,24,0.62) 35%,
      rgba(150,29,42,0.42) 58%,
      rgba(255,255,255,0.18) 100%);

  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 20px 60px rgba(0,0,0,.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);


}

/* brilho suave interno */
.top-header:before{
  content: "";
  position: absolute;
  inset: 0;
/*  background:
    linear-gradient(180deg,
      rgba(255,255,255,0.08) 0%,
      rgba(255,255,255,0.02) 100%);*/
  pointer-events: none;
  z-index: 1;
}

@media (max-width: 1200px) {

  .top-header {
    top: 105px;
  }
}

@media (max-width: 768px) {

  .top-header {
    top: 100px;
    width: calc(100% - 28px);
    overflow: visible !important;
    z-index: 9999;
  }

  .top-header,
  .protectiva-header,
  .protectiva-header-main {
    min-height: 72px;
  }

  .protectiva-header,
  .protectiva-header-main {
    overflow: visible !important;
  }

  .protectiva-header-main {
    position: relative;
    display: flex !important;
    align-items: center;
    gap: 10px;
  }

  .menu-sliding {
    position: relative !important;
    width: 44px !important;
    min-width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    margin: 0 !important;
    z-index: 10010 !important;
    overflow: visible !important;
  }

  .protectiva-logo-area {
    width: 78px;
    min-width: 78px;
  }

  .protectiva-logo img {
    max-height: 46px;
    width: auto;
  }

  .protectiva-header-right {
    flex: 1;
    min-width: 0;
  }

  .protectiva-header-actions {
    display: flex !important;
    align-items: center;
    gap: 8px;
    width: 100%;
  }

  .protectiva-search-wrap {
    flex: 1;
    min-width: 0;
  }

  .protectiva-search-wrap input {
    height: 44px;
    font-size: 13px;
    border-radius: 14px;
  }

  .protectiva-dropdown-atendimento .protectiva-btn,
  .protectiva-btn-primary {
    width: 48px;
    height: 44px;
    padding: 0;
    justify-content: center;
  }

  .protectiva-dropdown-atendimento .protectiva-btn span,
  .protectiva-dropdown-atendimento .fa-angle-down,
  .protectiva-btn-primary span {
    display: none !important;
  }

  .protectiva-menu-wrap,
  .protectiva-navbar,
  #menu {
    display: none !important;
  }
}

@media (max-width: 767px) {

  .top-header {
    top: 70px;
  }
}
/* =========================
   BARRA STICKY INDEPENDENTE
========================= */
.protectiva-sticky-menu-bar{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 9999;

  opacity: 0;
  visibility: hidden;
  transform: translateY(-100%);
  transition: all .28s ease;

  background:rgba(255,255,255,.36);
  backdrop-filter: blur(52px);
  -webkit-backdrop-filter: blur(52px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 12px 30px rgba(0,0,0,.22);


}

.protectiva-sticky-menu-bar.is-visible{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.protectiva-sticky-menu-inner{
  position: relative;
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 110px;
}

.protectiva-sticky-logo{
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

.protectiva-sticky-logo a{
  display: inline-flex;
  align-items: center;
}

.protectiva-sticky-logo img{
  max-height: 34px;
  width: auto;
  display: block;
  filter: contrast(1.08) saturate(1.06);
}

.protectiva-sticky-nav{
  width: 100%;
}

.protectiva-sticky-nav-list{
  margin: 0;
  padding: 0;
  list-style: none;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: nowrap;
}

.protectiva-sticky-nav-list > li{
  margin: 0;
  padding: 0;
}

.protectiva-sticky-nav-list > li > a{
  position: relative;
  display: inline-flex;
  align-items: center;
  padding: 24px 14px;
  color: #3B3734;
  font-size: 15px;
  font-weight: 800;
  text-decoration: none !important;
  transition: all .25s ease;
}

.protectiva-sticky-nav-list > li > a:hover{
  color: #ff4b55;
}

.protectiva-sticky-nav-list > li > a::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: 10px;
  width: 0;
  height: 2px;
  border-radius: 2px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, #e82931, #ff4b55);
  transition: width .25s ease;
}

.protectiva-sticky-nav-list > li > a:hover::after{
  width: 60%;
}

/* =========================
   RESPONSIVO
========================= */
@media (max-width: 1199px){
  .protectiva-sticky-menu-inner{
    min-height: 64px;
    justify-content: flex-start;
    padding-left: 70px;
    padding-right: 12px;
  }

  .protectiva-sticky-logo img{
    max-height: 28px;
  }

  .protectiva-sticky-nav{
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .protectiva-sticky-nav-list{
    justify-content: flex-start;
    min-width: max-content;
    gap: 2px;
  }

  .protectiva-sticky-nav-list > li > a{
    padding: 20px 12px;
    font-size: 14px;
    white-space: nowrap;
  }
}

@media (max-width: 1024px) {
  .protectiva-sticky-nav-list > li:nth-child(n+6) {
    display: none !important;
  }
}

/* =========================
   CTA STICKY (DIREITA)
========================= */
.protectiva-sticky-cta{
  position: absolute;
  right: 40px;
  top: 50%;
  transform: translateY(-50%);
}

/* BOTÃO */
.btn-sticky-cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 12px 22px;
  border-radius: 999px;

  font-size: 14px;
  font-weight: 800;
  text-decoration: none !important;

  color: #fff;

  background: linear-gradient(135deg, #e82931, #ff4b55);
  box-shadow: 0 8px 22px rgba(232,41,49,.35);

  transition: all .25s ease;
}

/* HOVER */
.btn-sticky-cta:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(232,41,49,.45);
  background: linear-gradient(135deg, #ff4b55, #e82931);
  color: #fff;
}

/* CLIQUE */
.btn-sticky-cta:active{
  transform: scale(.97);
}


/* =========================
   AJUSTE DO MENU CENTRAL
========================= */
.protectiva-sticky-menu-inner{
  padding-right: 140px; /* espaço pro botão */
}


/* =========================
   RESPONSIVO
========================= */
@media (max-width: 991px){

  .protectiva-sticky-cta{
    display: none; /* some no mobile pra não poluir */
  }

  .protectiva-sticky-menu-inner{
    padding-right: 12px;
  }
}

/* =========================
   MENU
========================= */

.protectiva-menu-wrap {
  /*background: #ffffff;*/
  border-top: 1px solid #edf2f8;
  /*border-bottom: 1px solid #edf2f8;*/
  position: relative;
  z-index: 15;
}

#menu.protectiva-navbar {
  margin-bottom: 0;
  background: transparent;
  border: 0;
  min-height: auto;
}

.protectiva-navbar-header {
  float: none;
}

.protectiva-navbar-toggle {
  margin: 12px 0;
  border: 0;
  background: #0a58ca;
  color: #fff;
  border-radius: 12px;
  padding: 11px 16px;
  display: none;
  align-items: center;
  gap: 8px;
}

.protectiva-navbar-toggle:hover,
.protectiva-navbar-toggle:focus {
  background: #084cb0;
  color: #fff;
}

.protectiva-navbar-collapse {
  padding-left: 0;
  padding-right: 0;
}

/* =========================
   ESPAÇAMENTO MENU
========================= */

/* respiro lateral do menu */
.protectiva-navbar {
  padding: 0 20px;
}

/* espaçamento entre itens */
.protectiva-navbar-nav {
  gap: 18px; /* ajuste fino aqui */
}

/* link do menu */
.protectiva-navbar-nav > li > a {
  padding: 18px 14px; /* antes estava mais apertado */
}

/* aumenta área clicável sem colar visual */
.protectiva-navbar-nav > li {
  display: flex;
  align-items: center;
}

/* =========================
   CENTRALIZAR MENU
========================= */

.protectiva-navbar-nav {
  float: none !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center;
  width: 100%;
}



.protectiva-navbar-nav > li {
  float: none;
}

.protectiva-navbar-nav > li > a {
  position: relative;
  color: #FFF;
  font-size: 15px;
  font-weight: 900;
  padding: 18px 18px;
  background: transparent !important;
  display: flex;
  align-items: center;
  gap: 7px;
  transition: all .25s ease;
}

@media (max-width: 1200px) {
.protectiva-navbar-nav > li > a {
  padding: 18px 10px;
  font-size: 13px;
}
}

/* REMOVE bootstrap */
.protectiva-navbar-nav > li > a:hover,
.protectiva-navbar-nav > li > a:focus,
.protectiva-navbar-nav > li.open > a {
  background: transparent !important;
  color: #ffffff;
}

/* efeito de leve subida */
.protectiva-navbar-nav > li > a:hover {
  transform: translateY(-1px);
}

/* underline animado (igual padrão moderno) */
.protectiva-navbar-nav > li > a::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 8px;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #ff3b3b, #ff6b6b);
  transition: all .25s ease;
  transform: translateX(-50%);
  border-radius: 2px;
}

/* ativa no hover e quando aberto */
.protectiva-navbar-nav > li > a:hover::after,
.protectiva-navbar-nav > li.open > a::after {
  width: 60%;
}

/* cor ativa (mais sofisticada que azul padrão) */
.protectiva-navbar-nav > li.open > a,
.protectiva-navbar-nav > li > a:hover {
  color: #ffffff;
}

.protectiva-dropdown-menu {
  border: 0;
  border-radius: 18px;
  box-shadow: 0 18px 45px rgba(15, 34, 58, 0.14);
  padding: 20px;
  min-width: 280px;
  margin-top: 0;
}

.protectiva-dropdown-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 25px;
}

.protectiva-dropdown-inner ul {
  margin: 0;
  min-width: 180px;
}

.protectiva-dropdown-inner ul li {
  margin-bottom: 8px;
}

.protectiva-dropdown-inner ul li a {
  color: #314154;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  display: block;
  padding: 4px 0;
}

.protectiva-dropdown-inner ul li a:hover {
  color: #0a58ca;
}

.protectiva-see-all {
  margin-top: 14px;
  display: inline-block;
  color: #0a58ca;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none !important;
}

.protectiva-see-all:hover {
  color: #084cb0;
}

.protectiva-home-link > a {
  color: #0a58ca !important;
}

/* =========================
   MEGA MENU PROTECTIVA
========================= */

/* =========================
   MEGA MENU - LARGURA DO CONTAINER
========================= */

.protectiva-menu-wrap {
  position: relative;
  z-index: 30;
}

#menu.protectiva-navbar {
  position: relative;
}

.protectiva-navbar-collapse,
.protectiva-navbar-nav,
.protectiva-mega-item {
  position: static !important;
}

.protectiva-mega-menu {
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  right: 0 !important;
  width: auto !important;
  margin-top: 0 !important;
  padding: 28px 32px !important;
  background: #ffffff !important;
  border: 1px solid #edf2f8 !important;
  border-top: 0 !important;
  border-radius: 0 0 22px 22px !important;
  box-shadow: 0 20px 50px rgba(15, 34, 58, 0.10) !important;
}

.protectiva-mega-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px 34px;
}

.protectiva-mega-col {
  min-width: 0;
}

.protectiva-mega-card {
  height: 100%;
}

.protectiva-mega-title {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #1f2d3d !important;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.3;
  text-decoration: none !important;
  margin-bottom: 14px;
}

.protectiva-mega-title:hover {
  color: #0a58ca !important;
}

.protectiva-mega-icon {
  width: 24px;
  height: 24px;
  min-width: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #e61e4d;
  font-size: 14px;
}

.protectiva-mega-links {
  margin: 0;
}

.protectiva-mega-links li {
  border-bottom: 1px solid #e9edf3;
}

.protectiva-mega-links li a {
  position: relative;
  display: inline-block;
  color: #2b2f38;
  padding: 10px;
  transition: all .25s ease;
}

/* REMOVE o background padrão do Bootstrap */
.protectiva-mega-links li a:hover,
.protectiva-mega-links li a:focus {
  background: transparent !important;
  color: #E70000;
}

/* efeito de leve movimento */
.protectiva-mega-links li a:hover {
  padding-left: 6px;
}

/* linha animada */
.protectiva-mega-links li a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #E70000, #B00000);
  transition: width .25s ease;
}

.protectiva-mega-links li a:hover::after {
  width: 100%;
}

/* =========================
   CORREÇÃO DO MEGA MENU
========================= */

#menu.protectiva-navbar {
  position: relative;
}

#menu.protectiva-navbar .navbar-nav,
#menu.protectiva-navbar .navbar-collapse,
#menu.protectiva-navbar .protectiva-mega-item {
  position: static;
}

#menu.protectiva-navbar .protectiva-mega-menu {
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  top: 100% !important;
  padding: 28px 32px !important;
  border: 1px solid #edf2f8 !important;
  border-top: 0 !important;
  border-radius: 0 0 22px 22px !important;
  box-shadow: 0 20px 50px rgba(15, 34, 58, 0.10) !important;
  background: #fff !important;
}

#menu.protectiva-navbar .protectiva-mega-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px 34px;
}

/* =========================
   AJUSTES ELEMENTOS NATIVOS
========================= */

#top .btn-link,
#top-links a {
  text-shadow: none;
}

#top .dropdown-menu {
  right: 0;
  left: auto;
}

header .row {
  margin-left: 0;
  margin-right: 0;
}

header .row > div {
  padding-left: 0;
  padding-right: 0;
}

/* esconde visual antigo do carrinho se não estiver usando no layout */
#cart {
  margin-bottom: 0;
}


/*PRODUCT THUMB*/

/* =========================
   GRID PRODUTOS PROTECTIVA
========================= */

.protectiva-products-grid{
  display: grid;
  gap: 26px;
}

/* 1 item */
.protectiva-products-grid:has(.protectiva-product-card:only-child){
  grid-template-columns: 1fr;
}

/* 2 itens */
.protectiva-products-grid:has(.protectiva-product-card:nth-child(2):last-child){
  grid-template-columns: repeat(2, 1fr);
}

/* 3+ itens */
.protectiva-products-grid{
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

/* =========================
   CARD
========================= */

.protectiva-product-card{
  background: #fff;
  border-radius: 18px;
  overflow: hidden;
  transition: all .35s ease;
  border: 1px solid rgba(0,0,0,0.04);
}

.protectiva-product-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 18px 50px rgba(0,0,0,0.08);
}

/* =========================
   LINK INTERNO
========================= */

.product-card-inner{
  display: block;
  text-decoration: none;
  color: inherit;
}

/* =========================
   IMAGEM
========================= */

.product-image{
  position: relative;
  height: 300px;
  overflow: hidden;
}

.product-image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}

.protectiva-product-card:hover .product-image img{
  transform: scale(1.05);
}

/* =========================
   CONTEÚDO
========================= */

.product-content{
  padding: 22px;
}

/* subtítulo (SKU/model) */
.product-subtitle{
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: #e82931;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* título */
.product-title{
  font-size: 20px;
  font-weight: 800;
  color: #2f333a;
  margin: 0 0 10px;
}

/* descrição */
.product-desc{
  font-size: 14px;
  color: #5c6572;
  line-height: 1.6;
  margin-bottom: 18px;
}

/* bottom */
.product-bottom{
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* preço fake institucional */
.product-price{
  font-size: 13px;
  color: #8b95a5;
}

/* CTA */
.product-link{
  font-size: 14px;
  font-weight: 700;
  color: #e82931;
  transition: all .3s ease;
}

.protectiva-product-card:hover .product-link{
  transform: translateX(4px);
}

/* =========================
   VARIAÇÃO: 1 OU 2 PRODUTOS (HORIZONTAL)
========================= */

.protectiva-products-grid:has(.protectiva-product-card:only-child) .protectiva-product-card,
.protectiva-products-grid:has(.protectiva-product-card:nth-child(2):last-child) .protectiva-product-card{
  display: flex;
}

.protectiva-products-grid:has(.protectiva-product-card:only-child) .product-card-inner,
.protectiva-products-grid:has(.protectiva-product-card:nth-child(2):last-child) .product-card-inner{
  display: flex;
  width: 100%;
}

.protectiva-products-grid:has(.protectiva-product-card:only-child) .product-image,
.protectiva-products-grid:has(.protectiva-product-card:nth-child(2):last-child) .product-image{
  width: 40%;
  height: auto;
}

.protectiva-products-grid:has(.protectiva-product-card:only-child) .product-content,
.protectiva-products-grid:has(.protectiva-product-card:nth-child(2):last-child) .product-content{
  width: 60%;
  padding: 28px;
}

/* =========================
   RESPONSIVO
========================= */

@media (max-width: 768px){

  .protectiva-products-grid{
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px; /* opcional pra dar respiro */
  }

  .protectiva-product-card{
    display: block !important;
  }

  .product-card-inner{
    display: block !important;
  }

  .product-image{
    width: 100% !important;
    height: 250px;
  }

  .product-content{
    width: 100% !important;
    padding: 18px;
  }

}

@media (max-width: 767px){

  .protectiva-products-grid{
  grid-template-columns: 1fr !important;
  }

  .product-image{
    width: 100% !important;
    height: 250px;
  }
}
/* =========================
   PREÇO / CONDIÇÕES
========================= */

.product-price-block {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.product-price-label {
  font-size: 12px;
  font-weight: 700;
  color: #8b95a5;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.product-price,
.product-price-special {
  font-size: 24px;
  line-height: 1.1;
  font-weight: 900;
  color: #2f333a;
}

.product-price-wrap {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.product-price-old {
  font-size: 14px;
  font-weight: 700;
  color: #9ca3af;
  text-decoration: line-through;
}

.product-price-special {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #e82931;
}

.product-price-special:before {
  content: "Promoção";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(232, 41, 49, 0.10);
  color: #c71f28;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* ajuste do bottom */
.product-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 18px;
  margin-top: 6px;
}

.product-link {
  flex: 0 0 auto;
  font-size: 14px;
  font-weight: 700;
  color: #e82931;
  transition: all .3s ease;
}

.protectiva-product-card:hover .product-link {
  transform: translateX(4px);
}

/* responsivo */
@media (max-width: 768px) {
  .product-bottom {
    flex-direction: column;
    align-items: flex-start;
  }

  .product-price,
  .product-price-special {
    font-size: 22px;
  }
}

/*PAGINA CATEGORIA*/

/* =========================
   HERO CATEGORIA PROTECTIVA
========================= */

/* =========================
   CONTAINER PROTECTIVA
========================= */

.protectiva-container{
  width: 100%;
  max-width: 1680px;
  margin: 0 auto;
  padding-left: max(40px, calc((100vw - 1680px) / 2));
  padding-right: max(40px, calc((100vw - 1680px) / 2));
}

/* telas menores */
@media (max-width: 1400px){
  .protectiva-container{
    padding: 0 30px;
  }
}

@media (max-width: 992px){
  .protectiva-container{
    padding: 0 20px;
  }
}

@media (max-width: 576px){
  .protectiva-container{
    padding: 0 15px;
  }
}


/* =========================
   BREADCRUMB PROTECTIVA
========================= */

.protectiva-breadcrumb-wrap {
  margin: 0 0 26px;
}

.protectiva-breadcrumb {
  margin: 1rem auto;
  padding: 0;
  background: #fff;
  border: 1px solid rgba(47, 51, 58, 0.08);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.04);
}

.protectiva-breadcrumb > li {
  position: relative;
  margin: 0;
  padding: 0;
  list-style: none;
  background: #fff;
  display: flex;
  align-items: center;
}

.protectiva-breadcrumb > li + li:before {
  content: "";
  display: none;
}

.protectiva-breadcrumb > li a,
.protectiva-breadcrumb > li.active {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 46px;
  padding: 0 22px 0 28px;
  font-size: 14px;
  font-weight: 700;
  color: #4d5562;
  text-decoration: none !important;
  background: #fff;
}

.protectiva-breadcrumb > li:not(:last-child) a:after {
  content: "";
  position: absolute;
  right: -14px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 28px;
  height: 28px;
  background: #fff;
  border-top: 1px solid rgba(47, 51, 58, 0.08);
  border-right: 1px solid rgba(47, 51, 58, 0.08);
  z-index: 2;
}

.protectiva-breadcrumb > li a:hover {
  color: #e82931;
}

.protectiva-breadcrumb > li.active {
  color: #2f333a;
  font-weight: 800;
  background: #fafbfc;
}

.protectiva-breadcrumb-home a {
  padding: 0 18px;
  min-width: 54px;
  justify-content: center;
}

.protectiva-breadcrumb-home a i {
  font-size: 15px;
  color: #2f333a;
}

@media (max-width: 767px) {

  .protectiva-breadcrumb-wrap {
    margin: 18px 0 24px;
  }

  .protectiva-breadcrumb {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 0 !important;

    padding: 12px 14px !important;
    margin: 0 !important;
  }

  .protectiva-breadcrumb > li {
    display: inline-flex !important;
    align-items: center !important;
    width: auto !important;
    float: none !important;

    font-size: 13px !important;
    line-height: 1.3 !important;
    white-space: nowrap !important;
  }

  .protectiva-breadcrumb > li + li:before {
    content: "/" !important;
    padding: 0 8px !important;
    color: #c3cad4 !important;
  }

  .protectiva-breadcrumb > li a,
  .protectiva-breadcrumb > li.active {
    display: inline-flex !important;
    width: auto !important;
    max-width: 100% !important;
  }
}
/*KEYWORDS*/
/* =========================
   BLOCO SOBRE CATEGORIA
========================= */

.protectiva-about-category {
  margin: 0 0 42px;
}

.protectiva-about-category-inner {
  padding: 10px 0 0;
  max-width: 1100px;
}

.protectiva-about-category-inner h2 {
  position: relative;
  margin: 0 0 24px;
  padding-left: 20px;
  font-size: 56px;
  line-height: 1.08;
  font-weight: 900;
  color: #2f333a;
}

.protectiva-about-category-inner h2:before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 5px;
  height: 34px;
  border-radius: 4px;
  background: linear-gradient(180deg, #e82931 0%, #ff4b55 100%);
}

.protectiva-about-category-inner h2 span {
  color: #444b57;
  font-weight: 300;
}

.protectiva-about-category-inner h2 strong,
.protectiva-about-category-inner h2 b,
.protectiva-about-category-inner h2 em,
.protectiva-about-category-inner h2 i {
  font-style: normal;
}

.protectiva-about-category-inner h2,
.protectiva-about-category-inner h2 span + text {
  letter-spacing: -.02em;
}

.protectiva-about-category-inner h2 {
  color: #2f333a;
}

.protectiva-about-category-inner h2 span + * {
  color: #2f333a;
}

.protectiva-about-category-text {
  max-width: 1080px;
}

.protectiva-about-category-text p {
  margin: 0 0 26px;
  font-size: 21px;
  line-height: 1.7;
  color: #4f5560;
}

.protectiva-about-category-text p:last-child {
  margin-bottom: 0;
}

@media (max-width: 1199px) {
  .protectiva-about-category-inner h2 {
    font-size: 46px;
  }

  .protectiva-about-category-text p {
    font-size: 19px;
  }
}

@media (max-width: 767px) {
  .protectiva-about-category {
    margin-bottom: 30px;
  }

  .protectiva-about-category-inner h2 {
    font-size: 34px;
    padding-left: 16px;
    margin-bottom: 18px;
  }

  .protectiva-about-category-inner h2:before {
    top: 6px;
    height: 26px;
    width: 4px;
  }

  .protectiva-about-category-text p {
    font-size: 16px;
    line-height: 1.75;
    margin-bottom: 18px;
  }
}
/**/

/*HEAD TOP CATEGORY*/
.protectiva-category-hero-top{
  position: relative;
  height: 140px;
  width: 100%;
  z-index: 1;

  /* FUNDO BASE */
  background:
    linear-gradient(180deg,
      rgba(255,255,255,0.96) 0%,
      rgba(248,240,242,0.94) 42%,
      rgba(235,219,224,0.92) 100%);
}

/* leve glow vermelho no canto direito */
.protectiva-category-hero-top:after{
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 420px;
  height: 100%;

  background:
    radial-gradient(circle at right top,
      rgba(232,41,49,0.24) 0%,
      rgba(232,41,49,0.12) 40%,
      rgba(232,41,49,0) 70%);

  pointer-events: none;
}

@media (max-width: 768px) {
  .protectiva-category-hero-top {
    display: none;
  }
}

.protectiva-category-hero.product-page {
  min-height: 450px !important;
}

.protectiva-category-hero{
  position: relative;
  min-height: 540px;
  overflow: hidden;
  padding-top: 130px; /* espaço para o top-header absoluto */
  display: flex;
  align-items: flex-start;
  background:
    radial-gradient(circle at 78% 16%, rgba(232,41,49,0.16), transparent 22%),
    linear-gradient(112deg, #fbfcff 0%, #f4f7fb 38%, #edf2f7 68%, #f7e4e7 100%);
}

/* camada que "come" a imagem */
.protectiva-category-hero-fade{
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(90deg,
      rgba(255,255,255,0.96) 0%,
      rgba(250,252,255,0.92) 22%,
      rgba(244,247,251,0.82) 36%,
      rgba(235,226,231,0.64) 50%,
      rgba(232,41,49,0.18) 62%,
      rgba(232,41,49,0.08) 70%,
      rgba(255,255,255,0) 74%);
}

/* imagem */
.protectiva-category-hero-media{
  position: absolute;
  inset: 0;
  z-index: 1;
}

.protectiva-category-hero-media img{
  position: absolute;
  top: 0;
  right: 0;
  width: 62%;
  height: 100%;
  object-fit: cover;
  object-position: center right;
}

/* degradê principal de leitura */
.protectiva-category-hero-overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg,
      rgba(255,255,255,0.94) 0%,
      rgba(248,250,253,0.88) 18%,
      rgba(239,233,238,0.70) 42%,
      rgba(232,41,49,0.18) 63%,
      rgba(255,255,255,0) 82%);
}

/* curva vermelha inspirada no Bradesco */
.protectiva-category-hero-shape{
  position: absolute;
  top: 0;
  right: 43%;
  width: 420px;
  height: 100%;
  z-index: 3;
  pointer-events: none;
  background:
    radial-gradient(circle at right center,
      rgba(255,255,255,0) 58%,
      rgba(232, 41, 49, 0.20) 59%,
      rgba(232, 41, 49, 0.30) 71%,
      rgba(255,255,255,0) 72%);
  opacity: 1;
}

/* conteúdo */
.protectiva-category-hero .container{
  position: relative;
  z-index: 4;
}

.protectiva-category-hero-content{
  max-width: 560px;
  padding: 30px 0 70px;
  color: #2f333a;
}

@media (min-width: 768px) {
.protectiva-category-hero-content.product-page {
  min-width: 760px !important;
  padding: 30px 0 40px !important;
  color: #2f333a;
}
}

.protectiva-category-hero-content h1{
  margin: 0 0 18px;
  font-size: 58px;
  line-height: 1.04;
  font-weight: 900;
  color: #2f333a;
}

.protectiva-category-hero-content p{
  margin: 0 0 28px;
  max-width: 500px;
  font-size: 22px;
  line-height: 1.55;
  color: #5f6672;
}

.btn-hero-cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 26px;
  border-radius: 12px;
  background: linear-gradient(135deg, #ff2733 0%, #ff4b55 100%);
  color: #fff !important;
  font-size: 15px;
  font-weight: 800;
  text-decoration: none !important;
  box-shadow: 0 16px 34px rgba(255,39,51,0.28);
  transition: all .25s ease;
}

.btn-hero-cta:hover{
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 20px 42px rgba(255,39,51,0.36);
}

/* responsivo */
@media (max-width: 1199px){
  .protectiva-category-hero{
    min-height: 500px;
    padding-top: 125px;
  }

  .protectiva-category-hero-media img{
    width: 66%;
  }

  .protectiva-category-hero-shape{
    right: 40%;
    width: 340px;
  }

  .protectiva-category-hero-content h1{
    font-size: 48px;
  }

  .protectiva-category-hero-content p{
    font-size: 19px;
  }
}

@media (max-width: 991px){
  .protectiva-category-hero{
    min-height: 460px;
    padding-top: 155px;
  }

  .protectiva-category-hero-media img{
    width: 100%;
    opacity: .38;
    object-position: center;
  }

  .protectiva-category-hero-overlay{
    background:
      linear-gradient(90deg,
        rgba(255,255,255,0.92) 0%,
        rgba(245,248,252,0.80) 52%,
        rgba(232,41,49,0.16) 100%);
  }

  .protectiva-category-hero-shape{
    display: none;
  }

  .protectiva-category-hero-content{
    max-width: 100%;
    padding: 22px 0 50px;
  }

  .protectiva-category-hero-content h1{
    font-size: 40px;
  }

  .protectiva-category-hero-content p{
    font-size: 18px;
    max-width: 100%;
  }
}

@media (max-width: 767px){
  .protectiva-category-hero{
    min-height: 400px;
    margin-top: -20px;
    padding-top: 135px;
  }

  .protectiva-category-hero-content h1{
    font-size: 32px;
  }

  .protectiva-category-hero-content p{
    font-size: 16px;
    line-height: 1.6;
  }

  .btn-hero-cta{
    width: 100%;
  }
}

/* =========================
   RESPONSIVO
========================= */

@media (max-width: 991px) {
  .protectiva-header {
    padding: 16px 0;
  }

  .protectiva-header-main {
    gap: 15px;
  }

  .protectiva-logo img {
    max-height: 56px;
  }

  .protectiva-navbar-toggle {
    display: inline-flex;
  }

  .protectiva-navbar-collapse {
    padding-left: 0;
    padding-right: 0;
    border-top: 1px solid #edf2f8;
  }

  .protectiva-navbar-nav {
    display: block;
    margin: 0;
  }

  .protectiva-navbar-nav > li > a {
    padding: 14px 10px;
    border-bottom: 1px solid #f2f5fa;
  }

  .protectiva-dropdown-menu {
    position: static;
    float: none;
    width: 100%;
    box-shadow: none;
    border-radius: 12px;
    padding: 10px 15px 15px;
    margin-bottom: 10px;
    background: #f8fbff;
  }

  .protectiva-dropdown-inner {
    display: block;
  }

  .protectiva-dropdown-inner ul {
    min-width: initial;
  }
}

@media (max-width: 767px) {

  #top.protectiva-topbar {
    padding: 6px 0;
    min-height: 60px;
  }

  .protectiva-topbar-inner {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 6px;
  }

  .protectiva-topbar-left {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    width: auto !important;
  }

  .protectiva-topbar-right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    width: auto !important;
    margin-left: auto; /* força ir pra direita */
  }

  .protectiva-topbar-item span {

  }

  .protectiva-topbar-item i {
    font-size: 14px;
  }

  .protectiva-topbar-social a {
    margin-left: 4px;
  }
}
/************/

/*PAGE PRODUCT*/
.protectiva-lead-box {
  padding: 34px;
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 22px 55px rgba(15,23,42,.08);
  border: 1px solid rgba(47,51,58,.08);
}

.lead-kicker {
  color: #e82931;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.protectiva-lead-box h3 {
  margin: 10px 0;
  font-size: 32px;
  font-weight: 900;
  color: #2f333a;
}

.protectiva-lead-box p {
  color: #616773;
  font-size: 15px;
  line-height: 1.6;
}

.lead-fields {
  display: grid;
  gap: 14px;
  margin: 24px 0;
}

.lead-fields input {
  height: 54px;
  border-radius: 16px;
  border: 1px solid rgba(47,51,58,.12);
  padding: 0 18px;
  font-size: 15px;
}

.lead-fields input:focus {
  outline: none;
  border-color: #e82931;
  box-shadow: 0 0 0 4px rgba(232,41,49,.08);
}

.protectiva-lead-btn {
  width: 100%;
  height: 56px;
  border: 0;
  border-radius: 16px;
  background: linear-gradient(135deg,#e82931,#ff4b55);
  color: #fff;
  font-weight: 900;
  box-shadow: 0 16px 34px rgba(232,41,49,.24);
}

#lead-alert {
  margin-top: 14px;
  font-size: 14px;
  font-weight: 700;
}


/**/

/*MODAL DESCRICAO OPTIONS*/
.protectiva-option-help {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-left: 8px;
  padding: 7px 12px;
  border: 0;
  border-radius: 999px;
  background: rgba(232,41,49,.08);
  color: #e82931;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
  transition: .25s ease;
}

.protectiva-option-help:hover {
  background: #e82931;
  color: #fff;
  transform: translateY(-1px);
}

.protectiva-option-modal .modal-dialog {
  max-width: 520px;
  margin: 90px auto;
}

.protectiva-option-modal .modal-content {
  position: relative;
  padding: 34px;
  border: 0;
  border-radius: 28px;
  box-shadow: 0 30px 90px rgba(15,23,42,.22);
}

.protectiva-modal-close {
  position: absolute;
  right: 18px;
  top: 18px;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 50%;
  background: #f3f4f6;
  color: #20242b;
}

.protectiva-modal-icon {
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: rgba(232,41,49,.10);
  color: #e82931;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin-bottom: 18px;
}

.protectiva-option-modal h3 {
  margin: 0 0 14px;
  font-size: 26px;
  font-weight: 900;
  color: #20242b;
}

.protectiva-modal-text {
  color: #667085;
  font-size: 16px;
  line-height: 1.75;
}

.protectiva-modal-text p:last-child {
  margin-bottom: 0;
}

/**/

.protectiva-product-quote-page {
  padding: 70px 0;
  background: #f5f6f8;
}

.protectiva-quote-card {
  max-width: 1050px;
  margin: 0 auto;
  padding: 42px 46px 38px;
  border-radius: 30px;
  background: #fff;
  box-shadow: 0 28px 70px rgba(15,23,42,.08);
}

.protectiva-quote-top {
  position: relative;
  text-align: center;
  margin-bottom: 60px;
}

.protectiva-step-prev-top {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 10;

  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(6px);
  box-shadow: 0 8px 25px rgba(0,0,0,0.08);

  padding: 8px 18px;
  border-radius: 20px;
}

.protectiva-quote-title span {
  display: inline-flex;
  padding: 13px 34px;
  border-radius: 999px;
  border: 2px solid #e82931;
  color: #e82931;
  font-size: 20px;
  font-weight: 900;
}

.protectiva-quote-title p {
  margin: 22px 0 0;
  font-size: 16px;
  color: #777;
}

.protectiva-quote-price {
  margin-top: 26px;
}

.protectiva-quote-price small {
  display: block;
  font-size: 13px;
  font-weight: 800;
  color: #888;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.protectiva-quote-price strong {
  display: block;
  margin-top: 4px;
  font-size: 34px;
  font-weight: 900;
  color: #2f333a;
}

.protectiva-quote-price .old-price {
  display: block;
  color: #999;
  text-decoration: line-through;
  font-size: 16px;
}

.protectiva-step {
  display: none;
}

.protectiva-step.active {
  display: block;
}

.protectiva-step-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px 34px;
}

.protectiva-field-full {
  grid-column: 1 / -1;
}

.protectiva-field label {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 13px;
  font-weight: 800;
  color: #666;
}

/*.protectiva-field.required label:before {
  content: "";
  color: #e82931;
}*/

.protectiva-input {
  height: 50px;
  border: 0;
  border-bottom: 2px solid #dde1e6;
  border-radius: 0;
  box-shadow: none !important;
  padding: 0;
  font-size: 17px;
  color: #333;
}

.protectiva-input:focus {
  border-color: #e82931;
}

textarea.protectiva-input {
  height: auto;
  min-height: 110px;
  padding-top: 12px;
}

.protectiva-radio-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.protectiva-choice {
  margin: 0;
  cursor: pointer;
}

.protectiva-choice input {
  display: none;
}

.protectiva-choice span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 2px solid #e5e7eb;
  background: #fff;
  color: #555;
  font-weight: 800;
  transition: all .22s ease;
}

.protectiva-choice input:checked + span {
  border-color: #e82931;
  background: rgba(232,41,49,.08);
  color: #e82931;
}

.protectiva-choice small {
  margin-left: 6px;
  color: inherit;
}

.protectiva-upload-btn {
  height: 50px;
  padding: 0 22px;
  border: 0;
  border-radius: 14px;
  background: #f3f4f6;
  font-weight: 800;
}

.protectiva-step-actions {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 70px;
}

.protectiva-step-next,
.protectiva-final-btn {
  min-width: 360px;
  height: 58px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #e82931, #ff4b55);
  color: #fff;
  font-size: 17px;
  font-weight: 900;
  box-shadow: 0 16px 34px rgba(232,41,49,.25);
}

.protectiva-step-prev {
  height: 58px;
  padding: 0 26px;
  border: 0;
  border-radius: 999px;
  background: #f1f2f4;
  color: #333;
  font-weight: 800;
}

.protectiva-step-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
}

.protectiva-step-dots span {
  width: 18px;
  height: 6px;
  border-radius: 999px;
  background: #d9dce2;
}

.protectiva-step-dots span.active {
  width: 54px;
  background: #e82931;
}

.protectiva-field.has-error .protectiva-radio-grid {
  padding: 12px;
  border: 2px solid rgba(232,41,49,.35);
  border-radius: 18px;
  background: rgba(232,41,49,.04);
}

.protectiva-step-alert {
  max-width: 640px;
  margin: 34px auto -36px;
  padding: 14px 18px;
  border-radius: 16px;
  background: rgba(232,41,49,.08);
  border: 1px solid rgba(232,41,49,.18);
  color: #c71f28;
  font-size: 14px;
  font-weight: 800;
  text-align: center;
}

.protectiva-step-alert i {
  margin-right: 6px;
}

.protectiva-field.has-error .protectiva-input {
  border-color: #e82931;
}

.protectiva-field.has-success .protectiva-input {
  border-color: #16a34a;
}

.protectiva-field-feedback {
  margin-top: 6px;
  font-size: 12px;
  font-weight: 700;
}

.protectiva-field.has-error .protectiva-field-feedback {
  color: #e82931;
}

.protectiva-field.has-success .protectiva-field-feedback {
  color: #16a34a;
}

@media (max-width: 1280px) {
  .protectiva-quote-card {
    margin: 0 20px;
  }
}

@media (max-width: 991px) {
  .protectiva-step-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .protectiva-quote-card {
    padding: 34px 24px;
  }

  .protectiva-lead-box {
    margin: 0 14px;
    padding: 28px 22px; /* reduz padding interno também */
  }
}

@media (max-width: 768px) {
  .protectiva-quote-card {
    margin: 0 14px;
    padding: 28px 22px; /* reduz padding interno também */
    border-radius: 22px;
  }
}


@media (max-width: 767px) {
  .protectiva-step-grid {
    grid-template-columns: 1fr;
  }

  .protectiva-step-next,
  .protectiva-final-btn {
    min-width: 0;
    width: 100%;
  }

  .protectiva-step-actions {
    flex-direction: column;
  }

  .protectiva-step-prev-top {
    position: static;
    margin-bottom: 20px;
  }
}
/*END*/

/* content */
#content {
	min-height: 600px;
}
/* footer */

/* =========================
   FOOTER PROTECTIVA
========================= */

.protectiva-footer {
  margin-top: 1rem;
  background: #ffffff;
  border-top: 1px solid rgba(47,51,58,0.08);
  padding: 70px 0 30px;
}

.protectiva-footer-top {
  margin-bottom: 40px;
}

/* LOGO */
.protectiva-footer-brand .footer-logo {
  max-width: 180px;
  margin-bottom: 18px;
}

.protectiva-footer-brand p {
  font-size: 15px;
  line-height: 1.7;
  color: #616773;
  max-width: 320px;
}

/* SOCIAL */
.footer-social {
  margin-top: 18px;
  display: flex;
  gap: 10px;
}

.footer-social a {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(47,51,58,0.06);
  color: #2f333a;
  transition: all .25s ease;
}

.footer-social a:hover {
  background: #e82931;
  color: #fff;
  transform: translateY(-2px);
}

/* TÍTULOS */
.protectiva-footer h5 {
  font-size: 15px;
  font-weight: 900;
  margin-bottom: 18px;
  color: #2f333a;
}

/* LISTAS */
.protectiva-footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.protectiva-footer ul li {
  margin-bottom: 10px;
}

.protectiva-footer ul li a {
  color: #616773;
  text-decoration: none;
  font-size: 14px;
  transition: all .25s ease;
}

.protectiva-footer ul li a:hover {
  color: #e82931;
  padding-left: 4px;
}

/* CONTATO */
.footer-contact-item {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  font-size: 14px;
  color: #2f333a;
  text-decoration: none;
  transition: all .25s ease;
}

.footer-contact-item i {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(47,51,58,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer-contact-item:hover {
  color: #e82931;
}

.footer-contact-item.whatsapp:hover i {
  background: #25D366;
  color: #fff;
}

/* BOTTOM */
.protectiva-footer-bottom {
  border-top: 1px solid rgba(47,51,58,0.08);
  padding-top: 20px;
  text-align: center;
}

.protectiva-footer-bottom p {
  font-size: 13px;
  color: #8a9099;
  margin: 0;
}

/* RESPONSIVO */
@media (max-width: 1100px) {
  .protectiva-footer {
    padding: 50px 0 25px;
  }

  .protectiva-footer-top > div {
    margin-bottom: 30px;
  }

   .protectiva-footer-brand {
    max-width: 100%;
    display: inline-block;
    text-align: center;
  }

  .protectiva-footer-brand p {
    max-width: 100%;
  }

.footer-social {
    justify-content: center;
    align-items: center;
  }

}

@media (max-width: 768px) {
  .protectiva-footer {
    padding: 40px 0 20px;
  }
}
/*NEW BUTTON CONTINUE CHAMONS*/
/* =========================
   BOTÃO CONTINUE PROTECTIVA
========================= */

.text-empty {
  font-weight: 900;
  font-size: 1.5rem;
}

.protectiva-continue-wrap {
  display: flex;
  justify-content: flex-end;
  margin: 50px 0 30px;
  padding-right: 10px; /* leve respiro */
}

.protectiva-btn-continue {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;

  padding: 16px 28px;
  border-radius: 14px;

  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.02em;

  color: #fff;
  text-decoration: none;

  background: linear-gradient(135deg, #e82931, #ff4d55);
  box-shadow: 0 10px 25px rgba(232, 41, 49, 0.25);

  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

/* efeito hover */
.protectiva-btn-continue:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 35px rgba(232, 41, 49, 0.35);
  color: #fff;
}

/* efeito clique */
.protectiva-btn-continue:active {
  transform: scale(0.98);
}

/* setinha opcional */
.protectiva-btn-continue::after {
  content: "";
  font-size: 16px;
  transition: transform .3s ease;
}

.protectiva-btn-continue:hover::after {
  transform: translateX(4px);
}

/* responsivo */
@media (max-width: 768px) {
  .protectiva-btn-continue {
    width: 100%;
    padding: 16px;
    font-size: 14px;
  }

  .protectiva-continue-wrap {
    margin: 40px 0 20px;
  }
}
/**/
/* alert */
.alert {
	padding: 8px 14px 8px 14px;
}

.pagination {
	margin: 0;
}
/* buttons */
.buttons {
	margin: 1em 0;
}
.btn {
	padding: 7.5px 12px;
	font-size: 12px;
	border: 1px solid #cccccc;
	border-radius: 4px;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.2), 0 1px 2px rgba(0,0,0,.05);
}
.btn-xs {
	font-size: 9px;
}
.btn-sm {
	font-size: 10.2px;
}
.btn-lg {
	padding: 10px 16px;
	font-size: 15px;
}
.btn-group > .btn, .btn-group > .dropdown-menu, .btn-group > .popover {
	font-size: 12px;
}
.btn-group > .btn-xs {
	font-size: 9px;
}
.btn-group > .btn-sm {
	font-size: 10.2px;
}
.btn-group > .btn-lg {
	font-size: 15px;
}
.btn-default {
	color: #777;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
	background-color: #e7e7e7;
	background-image: linear-gradient(to bottom, #eeeeee, #dddddd);
	background-repeat: repeat-x;
	border-color: #dddddd #dddddd #b3b3b3 #b7b7b7;
}
.btn-primary {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
	border-color: #1f90bb #1f90bb #145e7a;
}
.btn-primary:hover, .btn-primary:active, .btn-primary.active, .btn-primary.disabled, .btn-primary[disabled] {
	background-color: #1f90bb;
	background-position: 0 -15px;
}
.btn-warning {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #faa732;
	background-image: linear-gradient(to bottom, #fbb450, #f89406);
	background-repeat: repeat-x;
	border-color: #f89406 #f89406 #ad6704;
}
.btn-warning:hover, .btn-warning:active, .btn-warning.active, .btn-warning.disabled, .btn-warning[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}
.btn-danger {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #da4f49;
	background-image: linear-gradient(to bottom, #ee5f5b, #bd362f);
	background-repeat: repeat-x;
	border-color: #bd362f #bd362f #802420;
}
.btn-danger:hover, .btn-danger:active, .btn-danger.active, .btn-danger.disabled, .btn-danger[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}
.btn-success {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #5bb75b;
	background-image: linear-gradient(to bottom, #62c462, #51a351);
	background-repeat: repeat-x;
	border-color: #51a351 #51a351 #387038;
}
.btn-success:hover, .btn-success:active, .btn-success.active, .btn-success.disabled, .btn-success[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}
.btn-info {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #df5c39;
	background-image: linear-gradient(to bottom, #e06342, #dc512c);
	background-repeat: repeat-x;
	border-color: #dc512c #dc512c #a2371a;
}
.btn-info:hover, .btn-info:active, .btn-info.active, .btn-info.disabled, .btn-info[disabled] {
	background-image: none;
	background-color: #df5c39;
}
.btn-link {
	border-color: rgba(0, 0, 0, 0);
	cursor: pointer;
	color: #23A1D1;
	border-radius: 0;
}
.btn-link, .btn-link:active, .btn-link[disabled] {
	background-color: rgba(0, 0, 0, 0);
	background-image: none;
	box-shadow: none;
}
.btn-inverse {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #363636;
	background-image: linear-gradient(to bottom, #444444, #222222);
	background-repeat: repeat-x;
	border-color: #222222 #222222 #000000;
}
.btn-inverse:hover, .btn-inverse:active, .btn-inverse.active, .btn-inverse.disabled, .btn-inverse[disabled] {
	background-color: #222222;
	background-image: linear-gradient(to bottom, #333333, #111111);
}
/* list group */
.list-group a {
	border: 1px solid #DDDDDD;
	color: #888888;
	padding: 8px 12px;
}
.list-group a.active, .list-group a.active:hover, .list-group a:hover {
	color: #444444;
	background: #eeeeee;
	border: 1px solid #DDDDDD;
	text-shadow: 0 1px 0 #FFF;
}
/* carousel */
.carousel-caption {
	color: #FFFFFF;
	text-shadow: 0 1px 0 #000000;
}
.carousel-control .icon-prev:before {
	content: '\f053';
	font-family: FontAwesome;
}
.carousel-control .icon-next:before {
	content: '\f054';
	font-family: FontAwesome;
}
/* product list */
.product-thumb {
	border: 1px solid #ddd;
	margin-bottom: 20px;
	overflow: auto;
}
.product-thumb .image {
	text-align: center;
}
.product-thumb .image a {
	display: block;
}
.product-thumb .image a:hover {
	opacity: 0.8;
}
.product-thumb .image img {
	margin-left: auto;
	margin-right: auto;
}
.product-grid .product-thumb .image {
	float: none;
}
@media (min-width: 767px) {
.product-list .product-thumb .image {
	float: left;
	padding: 0 15px;
}
}
.product-thumb h4 {
	font-weight: bold;
}
.product-thumb .caption {
	padding: 0 20px;
	min-height: 180px;
}
.product-list .product-thumb .caption {
	margin-left: 230px;
}
@media (max-width: 1200px) {
.product-grid .product-thumb .caption {
	min-height: 210px;
	padding: 0 10px;
}
}
@media (max-width: 767px) {
.product-list .product-thumb .caption {
	min-height: 0;
	margin-left: 0;
	padding: 0 10px;
}
.product-grid .product-thumb .caption {
	min-height: 0;
}
}
.product-thumb .rating {
	padding-bottom: 10px;
}
.rating .fa-stack {
	font-size: 8px;
}
.rating .fa-star-o {
	color: #999;
	font-size: 15px;
}
.rating .fa-star {
	color: #FC0;
	font-size: 15px;
}
.rating .fa-star + .fa-star-o {
	color: #E69500;
}
h2.price {
	margin: 0;
}
.product-thumb .price {
	color: #444;
}
.product-thumb .price-new {
	font-weight: 600;
}
.product-thumb .price-old {
	color: #999;
	text-decoration: line-through;
	margin-left: 10px;
}
.product-thumb .price-tax {
	color: #999;
	font-size: 12px;
	display: block;
}
.product-thumb .button-group {
	border-top: 1px solid #ddd;
	background-color: #eee;
	overflow: auto;
}
.product-list .product-thumb .button-group {
	border-left: 1px solid #ddd;
}
@media (max-width: 768px) {
	.product-list .product-thumb .button-group {
		border-left: none;
	}
}
.product-thumb .button-group button {
	width: 60%;
	border: none;
	display: inline-block;
	float: left;
	background-color: #eee;
	color: #888;
	line-height: 38px;
	font-weight: bold;
	text-align: center;
	text-transform: uppercase;
}
.product-thumb .button-group button + button {
	width: 20%;
	border-left: 1px solid #ddd;
}
.product-thumb .button-group button:hover {
	color: #444;
	background-color: #ddd;
	text-decoration: none;
	cursor: pointer;
}
@media (max-width: 1200px) {
	.product-thumb .button-group button, .product-thumb .button-group button + button {
		width: 33.33%;
	}
}
@media (max-width: 767px) {
	.product-thumb .button-group button, .product-thumb .button-group button + button {
		width: 33.33%;
	}
}
.thumbnails {
	overflow: auto;
	clear: both;
	list-style: none;
	padding: 0;
	margin: 0;
}
.thumbnails > li {
	margin-left: 20px;
}
.thumbnails {
	margin-left: -20px;
}
.thumbnails > img {
	width: 100%;
}
.image-additional a {
	margin-bottom: 20px;
	padding: 5px;
	display: block;
	border: 1px solid #ddd;
}
.image-additional {
	max-width: 78px;
}
.thumbnails .image-additional {
	float: left;
	margin-left: 20px;
}

/*@media (min-width: 1200px) {
	#content .col-lg-2:nth-child(6n+1),
	#content .col-lg-3:nth-child(4n+1),
	#content .col-lg-4:nth-child(3n+1),
	#content .col-lg-6:nth-child(2n+1) {
		clear:left;
	}
}
@media (min-width: 992px) and (max-width: 1199px) {
	#content .col-md-2:nth-child(6n+1),
	#content .col-md-3:nth-child(4n+1),
	#content .col-md-4:nth-child(3n+1),
	#content .col-md-6:nth-child(2n+1) {
		clear:left;
	}
}
@media (min-width: 768px) and (max-width: 991px) {
	#content .col-sm-2:nth-child(6n+1),
	#content .col-sm-3:nth-child(4n+1),
	#content .col-sm-4:nth-child(3n+1),
	#content .col-sm-6:nth-child(2n+1) {
		clear:left;
	}
}*/

/* fixed colum left + content + right*/
@media (min-width: 768px) {
    #column-left  .product-layout .col-md-3 {
       width: 100%;
    }

	#column-left + #content .product-layout .col-md-3 {
       width: 50%;
    }

	#column-left + #content + #column-right .product-layout .col-md-3 {
       width: 100%;
    }

    #content + #column-right .product-layout .col-md-3 {
       width: 100%;
    }
}

/* fixed product layouts used in left and right columns */
#column-left .product-layout, #column-right .product-layout {
	width: 100%;
}

/* fixed mobile cart quantity input */
.input-group .form-control[name^=quantity] {
	min-width: 50px;
}

/* Missing focus and border color to overwrite bootstrap */
.btn-info:hover, .btn-info:active, .btn-info.active, .btn-info.disabled, .btn-info[disabled] {
    background-image: none;
    background-color: #df5c39;
}
html[dir=rtl] .checkbox input[type="checkbox"],
html[dir=rtl] .checkbox-inline input[type="checkbox"],
html[dir=rtl] .radio input[type="radio"],
html[dir=rtl] .radio-inline input[type="radio"] {
    position: absolute;
    margin-top: 4px\9;
    margin-right: -20px;
      margin-left: unset;
}
html[dir=rtl] .input-group-btn:last-child > .btn {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
}
html[dir=rtl] .input-group .form-control:first-child {
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    border-top-left-radius: unset;
    border-bottom-left-radius: unset;
}
html[dir=rtl] .container .row:first-child  .col-sm-4, html[dir=rtl] .container .row:first-child  .col-sm-5 {
  float: right;

}
html[dir=rtl] #cart .dropdown-menu {
  left: 0;
  right: auto;

}
@media (min-width: 768px) {
   
    html[dir=rtl] .navbar-nav {
        float: right;
        margin: 0;
    }
    
    html[dir=rtl] .navbar-nav > li {
        float: right;
    }
   
}
