:root {
	--main-tph-color: #ffffff;
	--tph-blanco: #ffffff;
	--tph-negro: #000000;
	--tph-azul: #1a428a;
	--tph-azul-claro: #aed2f0;
	--tph-amarillo: #f59c06;
	--tph-gris: #e6e6e6;
	--tph-rojo: #b2282f;
	--tph-lila: rgba(156, 43, 135, 1);
	--tph-cuenta-atras: #f59c06;
	--tph-form-label: #000000;
	--tph-form-placeholder: white;
	--tph-form-input: black;
	--tph-form-border: rgba(0, 0, 0, 0);
	--tph-form-bg: #fff;
	--tph-font-body: 'TT Norms Pro regular';
	--tph-font-pro-regular: 'TT Norms Pro regular';
	--tph-font-pro-medium: 'TT Norms Pro medium';
	--tph-font-pro-bold: 'TT Norms Pro bold';
	--tph-font-pro-extra: 'TT Norms Pro extra';
	--tph-font-montserrat: 'Montserrat';
	--tph-font-tt-norms-pro-regular: 'TT Norms Pro regular';
	--tph-font-tt-norms-pro-medium: 'TT Norms Pro medium';
	--tph-font-tt-norms-pro-bold: 'TT Norms Pro bold';
	--tph-font-bollity: 'bollity';
	--tph-font-bigshoulders-thin: 'bigshoulders-thin';

	/************* VARIABLES DE COLOR *************/
	/* Fondo del contenedor del carrusel */
	--tph-carousel-bg-color: #EEE;
	/* Fondo de las celdas (si no hay imagen) */
	--tph-carousel-cell-bg-color: #8C8;
	/* Color del texto descriptivo */
	--tph-carousel-text-color: #666;
	/* Color del título del servicio */
	--tph-carousel-title-color: #000;
	/* Color de la línea horizontal */
	--tph-carousel-hr-color: #CCC;

	/************* VARIABLES DE TAMAÑO *************/
	/* Ancho de las celdas del carrusel */
	--tph-carousel-cell-width: 600px;
	/* Altura de las celdas del carrusel */
	--tph-carousel-cell-height: 443px;
	/* Margen derecho de las celdas */
	--tph-carousel-cell-margin-right: 10px;
	/* Bordes redondeados de las celdas */
	--tph-carousel-border-radius: 5px;

	/************* VARIABLES DE TIPOGRAFÍA *************/
	/* Familia de fuente */
	--tph-carousel-font-family: sans-serif;
	/* Tamaño del título del servicio */
	--tph-carousel-title-font-size: 18px;
	/* Tamaño de la fuente de la descripción */
	--tph-carousel-description-font-size: 14px;
	/* Espacio arriba de la descripción */
	--tph-carousel-description-margin-top: 10px;
	/* Margen arriba y abajo de la línea horizontal */
	--tph-carousel-hr-margin: 5px 0;

}

/********************************************************************* scrollbar css *********************************************************/
/* width */
::-webkit-scrollbar {
	width: 5px;
}

/* Track */
::-webkit-scrollbar-track {
	background: #f1f1f1;
}

/* Handle */
::-webkit-scrollbar-thumb {
	background: #b1282f;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
	background: #b1282f;
}

/********************************************************************* fuentes *********************************************************/



@font-face {
	font-family: 'TT Norms Pro regular';
	src: url('../../../fonts/TTNormsPro-Regular.woff2') format('woff2'),
		url('../../../fonts/TTNormsPro-Regular.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'TT Norms Pro medium';
	src: url('../../../fonts/TTNormsPro-Medium.woff2') format('woff2'),
		url('../../../fonts/TTNormsPro-Medium.woff') format('woff');
	font-weight: 500;
	font-style: normal;

}

@font-face {
	font-family: 'TT Norms Pro bold';
	src: url('../../../fonts/TTNormsPro-Bold.woff2') format('woff2'),
		url('../../../fonts/TTNormsPro-Bold.woff') format('woff');
	font-weight: bold;
	font-style: normal;
}

@font-face {
	font-family: 'TT Norms Pro extra';
	src: url('../../../fonts/TTNorms-ExtraBold.woff2') format('woff2'),
		url('../../../fonts/TTNorms-ExtraBold.woff') format('woff');
	font-weight: bold;
	font-style: normal;
}

@font-face {
	font-family: 'bollity';
	src: url('../../../fonts/bollity.woff2') format('woff2'),
		url('../../../fonts/bollity.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'bigshoulders-thin';
	src: url('../../../fonts/bigshoulders-thin.woff2') format('woff2'),
		url('../../../fonts/bigshoulders-thin.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'Montserrat';
	src: url('../../../fonts/Montserrat-Regular.woff2') format('woff2'),
		url('../../../fonts/Montserrat-Regular.woff') format('woff');
	font-weight: normal;
	font-style: normal;
}

body {
	font-family: var(--tph-font-montserrat);
	background-color: transparent;
}

a {
	color: #b1282f;
}
/********************************************************************* Botones *********************************************************/

.btn-formulario {
	background-color: var(--tph-rojo);
	color: var(--tph-blanco);
	font-family: 'jollygoodproperbold';
	/* font-size: 2.5rem; */
	font-size: 1.6rem;
	padding: 0rem 0rem;
	border-radius: 5rem;
	width: 70%;
}

.btn-formulario:hover {
	background-color: var(--tph-negro);
	color: var(--tph-rojo);
}

.btn-formulario:focus {
	background-color: var(--tph-amarillo);
	color: rgb(255, 255, 255);
}

.btn-promo {
	background-color: var(--tph-rojo);
	color: var(--tph-blanco);
	border-radius: 5rem !important;
	width: 70% !important;
	font-family: var(--tph-font-bollity);
	font-size: 2rem;
}

.btn-promo:hover {
	background-color: var(--tph-negro);
	color: var(--tph-rojo);
}

.btn-promo:focus {
	background-color: rgb(0, 0, 0);
	color: white;
}

.btn-round-negativo {
	border-radius: 1.3rem !important;
	background-color: rgb(255, 255, 255);
	color: white;
}

.gradiente-texto {
	background-clip: text;
	-webkit-background-clip: text;
	/* Para navegadores basados en WebKit, como Chrome y Safari */
	color: transparent;
	background-image: linear-gradient(to right, #00B09F, #004862);
}

.btn-menu {
	background-color: var(--tph-rojo);
}

/********************************************************************* scrollbar css *********************************************************/
/* width */
::-webkit-scrollbar {
	width: 5px;
}

/* Track */
::-webkit-scrollbar-track {
	background: white;
}

/* Handle */
::-webkit-scrollbar-thumb {
	background: var(--tph-dorado);
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
	background: black;
}

.alert {
	font-family: 'Typold Regular';
}



/********************************************************************************** MENU  *******************************************************************************/

#logo {
	max-width: 200px;
}

.navbar-brand {
	max-width: 210px;
}

#mainMenu {
	font-family: var(--tph-font-montserrat);
	font-weight: bold;
	padding-top: 0%;
	padding-bottom: 0%;
	position: relative;
}

#mainMenu .container-fluid {
	background-color: var(--tph-rojo);
	min-height: 4rem;
	color: var(--tph-blanco) !important;
	z-index: 1;
}

#mainMenu .nav-link {
	color: var(--tph-naranja);
}

/* .navbar-dark .navbar-nav .nav-link {
  color: var(--tph-naranja);
}

.navbar-dark .navbar-brand {
  color: var(--tph-naranja);
}

.navbar-dark .navbar-nav .nav-link.active,
.navbar-dark .navbar-nav .show>.nav-link {
  color: var(--tph-naranja) !important;
} */

.navbar-toggler {
	background-color: var(--tph-rojo);
}

.fixed-top {
	position: fixed !important;
}

#mainMenu .btn-menu {
	color: var(--tph-blanco);
	font-weight: bold;
	background-color: var(--tph-negro);
}

/********************************************************************************** INICIO  *******************************************************************************/
#inicio {
	background-image: url('../../../img/template/nieve-26/bg-header.png');
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	background-color: var(--tph-azul-claro);
	color: var(--tph-negro);
}

#inicio .titulo {
	font-family: var(--tph-font-bollity);
	font-size: 5rem;
	line-height: 0.8;
}

#inicio .subtitulo {
	font-family: var(--tph-font-pro-regular);
	font-size: 2rem;
	line-height: 1;
	margin-top: 1rem;
}

#inicio .subtitulo span {
	font-family: var(--tph-font-pro-bold);
}

#inicio p {
	font-size: 1.5rem;
	line-height: 1;
}

#inicio .text-responsable {
	font-size: 1rem;
}

#inicio .nube {
	max-width: 120px;
}

#inicio .astun {
	max-width: 100px;
}


/********************************************************************************** info promo  *******************************************************************************/
#info-promo .titulo {
	font-family: var(--tph-font-bollity);
	font-size: 5rem;
	padding-top: 1rem;
	padding-bottom: 1rem;
}

#info-promo .subtitulo {
	font-family: var(--tph-font-pro-regular);
	font-size: 1rem;
	padding-top: 6rem;
	padding-bottom: 1rem;
}

#info-promo .legenda {
	font-family: var(--tph-font-pro-regular);
	font-size: 1rem;
	padding-top: 1rem;
	padding-bottom: 1rem;
}

/********************************************************************************** mecánica  *******************************************************************************/

#mecanica {
	background-image: url('../../../img/template/nieve-26/bg-mecanica.png');
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	background-color: var(--tph-azul-claro);
	color: var(--tph-negro);
}

#mecanica .titulo {
	font-family: var(--tph-font-bollity);
	font-size: 3rem;
	line-height: 1;
}

#mecanica .numero {
	font-family: var(--tph-font-bigshoulders-thin);
	font-weight: bold;
	font-size: 6rem;
	line-height: 1;
}

#mecanica .descripcion {
	font-family: var(--tph-font-bigshoulders-thin);
	font-weight: bold;
	font-size: 3rem;
	line-height: 1;
	text-transform: lowercase;
	text-transform: capitalize;
}

/********************************************************************************** countdown  *******************************************************************************/

#countdown {
	font-family: var(--tph-font-bollity);
	font-size: 2rem;
}

#countdown .wrapper {
	text-align: center;
}

#countdown .time {
	color: var(--tph-negro);
	font-size: 3rem;
	padding: 0.25rem;
}

#countdown .label {
	font-size: 1.8rem;
	display: block;
	color: var(--tph-amarillo);
}

#countdown svg {
	font: bold 5rem;
	width: 100%;
	height: 120px;
}

#countdown text {
	fill: none;
	stroke: var(--tph-amarillo);
	stroke-width: 6px;
	stroke-linejoin: round;
	animation: 2s pulsate infinite;
}

@keyframes pulsate {
	50% {
		text-shadow: 4px 4px #fff;
	}
}

/********************************************************************************** participa  *******************************************************************************/

#participa .input-group-text {
	color: var(--tph-negro);
}

#participa {
	background-color: var(--tph-azul-claro);
	margin-top: 0;
	color: var(--tph-negro);
}

/* Background solo cuando se muestra el formulario */
#participa.con-formulario {
	background-image: url('../../../img/template/nieve-26/nieve-footer.png');
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: contain;
}

/* Sin background para cuenta atrás y finalizado */
#participa.sin-formulario {
	background-image: none;
}


#participa .titulo {
	font-family: var(--tph-font-bollity);
	font-size: 3rem;
	line-height: 1;
}

#participa .subtitulo {
	font-family: var(--tph-font-pro-regular);
	font-size: 1rem;
}

form#formReg_l label {
	display: block;
	color: var(--tph-form-label);
	font-weight: bold;
}

form#formReg_l input {
	border-radius: 5rem;
	border-color: black;
}

form#formReg_l .form-control {
	color: var(--tph-form-input);
	background-color: var(--tph-form-bg);
	font-size: 1rem;
	font-family: var(--font-textos);
}

form#formReg_l .form-select {
	border-color: black;
	background-color: var(--tph-form-bg);
	font-family: var(--font-textos);
	border-radius: 5rem;
	color: black;
}

form#formReg_l label.custom-control-label {
	display: block !important;
	color: var(--tph-form-label);
	font-size: 1rem;
}

form#formReg_l .form-control::placeholder {
	/* Chrome, Firefox, Opera, Safari 10.1+ */
	color: var(--tph-form-placeholder);
	opacity: 1;
	/* Firefox */
}

form#formReg_l .form-control:-ms-input-placeholder {
	/* Internet Explorer 10-11 */
	color: var(--tph-form-placeholder);
}

form#formReg_l .form-control::-ms-input-placeholder {
	/* Microsoft Edge */
	color: var(--tph-form-placeholder);
}

form#formReg_l .form-select::placeholder {
	/* Chrome, Firefox, Opera, Safari 10.1+ */
	color: var(--tph-form-placeholder);
	opacity: 1;
	/* Firefox */
}

form#formReg_l .form-select:-ms-input-placeholder {
	/* Internet Explorer 10-11 */
	color: var(--tph-form-placeholder);
}

form#formReg_l .form-select::-ms-input-placeholder {
	/* Microsoft Edge */
	color: var(--tph-form-placeholder);
}

form#formReg_l a {
	color: var(--tph-form-label);
}

form option {
	color: #000000;
	font-size: 1rem;
}

form option:hover {
	background-color: #ffffff;
}

form .input-group-text {
	background: transparent;
	color: #fff;
	border: none;
}

form .form-check-input:checked {
	background-color: var(--tph-rojo);
	border-color: var(--tph-negro);
}

.form-check-input {
	--bs-form-check-bg: var(--tph-blanco);
}

/********************************************************************************** premios  *******************************************************************************/



/********************************************************************************** divisor  *******************************************************************************/
#divisor {
	margin-top: -2rem;
}
/********************************************************************************** contacto  *******************************************************************************/

#contacto {
	margin-top: 1rem;
}
#contacto img{
	max-width: 300px;
}
#contacto .titulo {
	font-family: var(--tph-font-bollity);
	font-size: 3rem;
	color: var(--tph-negro);
}

#contacto .subtitulo {
	font-family: var(--tph-font-pro-regular);
	font-size: 1rem;
}
#contacto .legenda {
	font-family: var(--tph-font-pro-regular);
	font-size: 0.8rem;
    padding-top: 2rem;
}
#contacto .escribenos {
	font-family: var(--tph-font-pro-regular);
	font-size: 1rem;
}
#contacto .llamanos {
	font-family: var(--tph-font-pro-regular);
	font-size: 1rem;
}

#contacto .whatsapp {
	font-family: var(--tph-font-pro-regular);
	font-size: 1rem;
}

.tel_promo a {
	font-family: var(--tph-font-bollity);
	font-size: 3rem;
	color: #000000	;
	text-decoration: none;
}

.email_contacto a {
	font-family: var(--tph-font-bollity);
	font-size: 3rem;
	color: #000000	;
}

/********************************************************************************** footer  *******************************************************************************/

footer {
	background-color: var(--tph-negro);
	position: sticky;
	font-family: 'Typold Regular';
}

footer ul {
	list-style: none;
}

footer a {
	color: rgb(255, 255, 255);
	font-size: 1.1rem;
	text-decoration: none;
	transition: 0.3s color;
}

footer a:hover {
	color: black;
}

footer .small {
	color: rgb(255, 255, 255);
	font-size: 0.8rem;
}

footer img .small {
	max-width: 1.5rem;
}

.logoBonduellPie {
	max-width: 8rem;
}

.pull-right {
	float: right;
}

.xs-d-flex {
	flex-direction: column;
}

/********************************************************************************** Area personal  *******************************************************************************/
.card-width {
	min-width: 10rem;
}

.flex-adapt {
	flex-direction: column !important;
}

/********************************************************************************** textos  *******************************************************************************/

/********************************************************************************** media query  *******************************************************************************/

@media (min-width: 536px) {}

@media (min-width: 636px) {}

@media (min-width: 768px) {}

@media (min-width: 992px) {}

@media (min-width: 1024px) {}

@media (min-width: 1200px) {

	#contacto .d-none {
		display: block !important;
	}

	#contacto .tel_promo {
		font-size: 2rem;
	}

	.navbar-brand {
		margin-left: 5rem;
	}

	.navbar-collapse {
		margin-right: 5rem !important;
	}

}

@media (min-width: 1400px) {
	#inicio h1 {
		font-size: 10rem;
		line-height: 0.8;
	}

	#inicio h2 {
		font-size: 5rem;
		line-height: 1;
	}

	#inicio p {
		font-size: 3rem;
		line-height: 1;
	}

	#inicio .text-responsable {
		font-size: 1rem;
	}
}

@media (min-width: 1600px) {

	#mainMenu,
	section,
	header,
	footer {
		max-width: 1920px;
		margin: 0 auto;
	}


}

@media(min-width:1800px) {}

/* ========================================
   ESTILOS BASES LEGALES
   ======================================== */

/* Contenedor principal de bases legales */
.bases-legales-container {
	max-width: 1200px;
	margin: 4rem auto;
	padding: 3rem 2rem;
	background: linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);
	border-radius: 16px;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
	font-family: var(--tph-font-pro-regular);
	color: var(--tph-negro);
	line-height: 1.8;
}

/* Encabezado de título */
.bases-legales-container > p:first-of-type {
	font-family: var(--tph-font-pro-bold);
	font-size: 2.5rem;
	text-align: center;
	color: var(--tph-azul);
	margin-bottom: 3rem;
	padding-bottom: 1.5rem;
	border-bottom: 3px solid var(--tph-rojo);
	text-transform: uppercase;
	letter-spacing: 1px;
}

/* Subtítulos con strong */
.bases-legales-container p strong {
	font-family: var(--tph-font-pro-bold);
	font-size: 1.3rem;
	color: var(--tph-azul);
	display: block;
	margin-top: 2.5rem;
	margin-bottom: 1rem;
	padding-left: 1rem;
	border-left: 4px solid var(--tph-rojo);
}

/* Párrafos normales */
.bases-legales-container p {
	margin-bottom: 1.5rem;
	font-size: 1rem;
	color: #333;
	text-align: justify;
}

/* Enlaces */
.bases-legales-container a {
	color: var(--tph-azul);
	text-decoration: none;
	font-weight: 600;
	border-bottom: 2px solid transparent;
	transition: all 0.3s ease;
}

.bases-legales-container a:hover {
	color: var(--tph-rojo);
	border-bottom: 2px solid var(--tph-rojo);
}

/* Listas desordenadas */
.bases-legales-container ul {
	margin: 1.5rem 0;
	padding-left: 2rem;
}

.bases-legales-container ul li {
	margin-bottom: 0.8rem;
	position: relative;
	padding-left: 1.5rem;
	list-style: none;
}

.bases-legales-container ul li:before {
	content: "▸";
	position: absolute;
	left: 0;
	color: var(--tph-rojo);
	font-weight: bold;
	font-size: 1.2rem;
}

/* Listas anidadas */
.bases-legales-container ul ul {
	margin-top: 0.8rem;
	padding-left: 1.5rem;
}

.bases-legales-container ul ul li:before {
	content: "•";
	font-size: 1rem;
	color: var(--tph-azul);
}

/* Tabla de productos */
.bases-legales-container table {
	width: 100%;
	border-collapse: collapse;
	margin: 2rem 0;
	background: white;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.bases-legales-container table tbody tr {
	border-bottom: 1px solid #e0e0e0;
	transition: background-color 0.2s ease;
}

.bases-legales-container table tbody tr:hover {
	background-color: rgba(245, 156, 6, 0.05);
}

.bases-legales-container table tbody tr:last-child {
	border-bottom: none;
}

.bases-legales-container table td {
	padding: 1rem 1.5rem;
	font-size: 0.95rem;
	color: #555;
}

.bases-legales-container table td:first-child {
	font-family: var(--tph-font-pro-bold);
	color: var(--tph-azul);
	width: 25%;
}

.bases-legales-container table td:nth-child(2) {
	width: 50%;
}

.bases-legales-container table td:last-child {
	font-family: 'Courier New', monospace;
	color: #666;
	font-size: 0.9rem;
	width: 25%;
}

/* Encabezado de tabla (si lo añadimos) */
.bases-legales-container table thead tr {
	background: linear-gradient(135deg, var(--tph-azul) 0%, #0d2547 100%);
	color: white;
}

.bases-legales-container table thead td {
	font-family: var(--tph-font-pro-bold);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-size: 0.9rem;
	padding: 1.2rem 1.5rem;
}

/* Destacados importantes */
.bases-legales-container p strong:not(:only-child) {
	display: inline;
	background: linear-gradient(120deg, rgba(245, 156, 6, 0.15) 0%, rgba(245, 156, 6, 0.05) 100%);
	padding: 2px 6px;
	border-radius: 3px;
	border-left: none;
	font-size: inherit;
	margin: 0;
}

/* Responsivo para tablets */
@media (max-width: 992px) {
	.bases-legales-container {
		margin: 2rem auto;
		padding: 2rem 1.5rem;
	}

	.bases-legales-container > p:first-of-type {
		font-size: 2rem;
	}

	.bases-legales-container p strong {
		font-size: 1.1rem;
	}

	.bases-legales-container table td {
		padding: 0.8rem 1rem;
		font-size: 0.9rem;
	}
}

/* Responsivo para móviles */
@media (max-width: 768px) {
	.bases-legales-container {
		margin: 1rem;
		padding: 1.5rem 1rem;
		border-radius: 12px;
	}

	.bases-legales-container > p:first-of-type {
		font-size: 1.5rem;
		margin-bottom: 2rem;
	}

	.bases-legales-container p strong {
		font-size: 1rem;
		padding-left: 0.5rem;
		border-left-width: 3px;
	}

	.bases-legales-container p {
		font-size: 0.95rem;
		text-align: left;
	}

	.bases-legales-container ul {
		padding-left: 1.5rem;
	}

	.bases-legales-container ul li {
		padding-left: 1rem;
	}

	/* Tabla responsive - stack vertical */
	.bases-legales-container table,
	.bases-legales-container table tbody,
	.bases-legales-container table tr,
	.bases-legales-container table td {
		display: block;
		width: 100%;
	}

	.bases-legales-container table tr {
		margin-bottom: 1.5rem;
		border: 1px solid #e0e0e0;
		border-radius: 8px;
		padding: 1rem;
		background: white;
	}

	.bases-legales-container table td {
		padding: 0.5rem 0;
		border: none;
		text-align: left;
	}

	.bases-legales-container table td:before {
		content: attr(data-label);
		font-family: var(--tph-font-pro-bold);
		color: var(--tph-azul);
		display: block;
		margin-bottom: 0.3rem;
		font-size: 0.85rem;
	}

	.bases-legales-container table td:first-child,
	.bases-legales-container table td:nth-child(2),
	.bases-legales-container table td:last-child {
		width: 100%;
	}
}
