var tribe_dropdowns = window.tribe_dropdowns || {};
( function( $, obj, _ ) {
'use strict';
obj.selector = {
dropdown: '.tribe-dropdown',
created: '.tribe-dropdown-created',
searchField: '.select2-search__field',
};
// Setup a Dependent
$.fn.tribe_dropdowns = function() {
obj.dropdown( this, {} );
return this;
};
obj.freefrom_create_search_choice = function( params ) {
if ( 'string' !== typeof params.term ) {
return null;
}
var term = params.term.trim();
if ( '' === term ) {
return null;
}
var args = this.options.options;
var $select = args.$select;
if (
term.match( args.regexToken )
&& (
! $select.is( '[data-int]' )
|| (
$select.is( '[data-int]' )
&& term.match( /\d+/ )
)
)
) {
var choice = { id: term, text: term, new: true };
if ( $select.is( '[data-create-choice-template]' ) ) {
choice.text = _.template( $select.data( 'createChoiceTemplate' ) )( { term: term } );
}
return choice;
}
return null;
};
/**
* Better Search ID for Select2, compatible with WordPress ID from WP_Query
*
* @param {object|string} e Searched object or the actual ID
* @return {string} ID of the object
*/
obj.search_id = function( e ) {
var id = undefined;
if ( 'undefined' !== typeof e.id ) {
id = e.id;
} else if ( 'undefined' !== typeof e.ID ) {
id = e.ID;
} else if ( 'undefined' !== typeof e.value ) {
id = e.value;
}
return undefined === e ? undefined : id;
};
/**
* Better way of matching results
*
* @param {string} term Which term we are searching for
* @param {string} text Search here
* @return {boolean}
*/
obj.matcher = function( params, data ) {
// If there are no search terms, return all of the data
if ( 'string' !== typeof params.term || params.term.trim() === '') {
return data;
}
// Do not display the item if there is no 'text' property
if ( typeof data.text === 'undefined' ) {
return null;
}
var term = params.term.trim();
var text = data.text;
var $select = $( data.element ).closest( 'select' );
var args = $select.data( 'dropdown' );
var result = text.toUpperCase().indexOf( term.toUpperCase() ) !== -1;
if ( ! result && 'undefined' !== typeof args.tags ){
var possible = _.where( args.tags, { text: text } );
if ( args.tags.length > 0 && _.isObject( possible ) ){
var test_value = obj.search_id( possible[0] );
result = test_value.toUpperCase().indexOf( term.toUpperCase() ) !== -1;
}
}
return result;
};
/**
* If the element used as the basis of a dropdown specifies one or more numeric/text
* identifiers in its val attribute, then use those to preselect the appropriate options.
*
* @param {object} $select
* @param {function} make_selection
*/
obj.init_selection = function( $select, make_selection ) {
var isMultiple = $select.is( '[multiple]' );
var options = $select.data( 'dropdown' );
var currentValues = $select.val().split( options.regexSplit );
var selectedItems = [];
$( currentValues ).each( function( index, value ) { // eslint-disable-line no-unused-vars
var searchFor = { id: this, text: this };
var data = options.ajax ? $select.data( 'options' ) : options.data;
var locatedItem = find_item( searchFor, data );
if ( locatedItem && locatedItem.selected ) {
selectedItems.push( locatedItem );
}
} );
if ( selectedItems.length && isMultiple ) {
make_selection( selectedItems );
} else if ( selectedItems.length ) {
make_selection( selectedItems[ 0 ] );
} else {
make_selection( false );
return;
}
};
/**
* Searches array 'haystack' for objects that match 'description'.
*
* The 'description' object should take the form { id: number, text: string }. The first
* object within the haystack that matches one of those two properties will be returned.
*
* If objects contain an array named 'children', then that array will also be searched.
*
* @param {Object} description
* @param {Array} haystack
*
* @return {Object|boolean}
*/
function find_item( description, haystack ) {
if ( ! _.isArray( haystack ) ) {
return false;
}
for ( var index in haystack ) {
var possible_match = haystack[ index ];
if ( possible_match.hasOwnProperty( 'id' ) && possible_match.id == description.id ) { // eslint-disable-line no-prototype-builtins,eqeqeq,max-len
return possible_match;
}
if ( possible_match.hasOwnProperty( 'text' ) && possible_match.text == description.text ) { // eslint-disable-line no-prototype-builtins,eqeqeq,max-len
return possible_match;
}
if ( possible_match.hasOwnProperty( 'children' ) && _.isArray( possible_match.children ) ) { // eslint-disable-line no-prototype-builtins,max-len
var subsearch = find_item( description, possible_match.children );
if ( subsearch ) {
return subsearch;
}
}
}
return false;
}
obj.getSelectClasses = function( $select ) {
var classesToRemove = [
'select2-hidden-accessible',
'hide-before-select2-init',
];
var originalClasses = $select.attr( 'class' ).split( /\s+/ );
return _.difference( originalClasses, classesToRemove );
};
obj.element = function( field, args ) {
var $select = $( field );
var args = $.extend( {}, args ); // eslint-disable-line no-redeclare
var carryOverData = [ // eslint-disable-line no-unused-vars
'depends',
'condition',
'conditionNot',
'condition-not',
'conditionNotEmpty',
'condition-not-empty',
'conditionEmpty',
'condition-empty',
'conditionIsNumeric',
'condition-is-numeric',
'conditionIsNotNumeric',
'condition-is-not-numeric',
'conditionChecked',
'condition-is-checked',
];
var $container;
// Add a class for dropdown created
$select.addClass( obj.selector.created.className() );
// args.debug = true;
// For Reference we save the jQuery element as an Arg.
args.$select = $select;
// Auto define the Width of the Select2.
args.dropdownAutoWidth = true;
args.width = 'resolve';
// CSS for the container
args.containerCss = {};
// Only apply visibility when it's a Visible Select2.
if ( $select.is( ':visible' ) ) {
args.containerCss.display = 'inline-block';
args.containerCss.position = 'relative';
}
// CSS for the dropdown
args.dropdownCss = {};
args.dropdownCss.width = 'auto';
// When we have this we replace the default with what's in the param.
if ( $select.is( '[data-dropdown-css-width]' ) ) {
args.dropdownCss.width = $select.data( 'dropdown-css-width' );
if ( ! args.dropdownCss.width || 'false' === args.dropdownCss.width ) {
delete args.dropdownCss.width;
delete args.containerCss;
}
}
// By default we allow The field to be cleared
args.allowClear = true;
if ( $select.is( '[data-prevent-clear]' ) ) {
args.allowClear = false;
}
// Pass the "Searching..." placeholder if specified
if ( $select.is( '[data-searching-placeholder]' ) ) {
args.formatSearching = $select.data( 'searching-placeholder' );
}
// If we are dealing with a Input Hidden we need to set the Data for it to work
if ( ! $select.is( '[data-placeholder]' ) && $select.is( '[placeholder]' ) ) {
args.placeholder = $select.attr( 'placeholder' );
}
// If we are dealing with a Input Hidden we need to set the Data for it to work.
if ( $select.is( '[data-options]' ) ) {
args.data = $select.data( 'options' );
}
// With less then 10 args we wouldn't show the search.
args.minimumResultsForSearch = 10;
// Prevents the Search box to show
if ( $select.is( '[data-hide-search]' ) ) {
args.minimumResultsForSearch = Infinity;
}
// Makes sure search shows up.
if ( $select.is( '[data-force-search]' ) ) {
delete args.minimumResultsForSearch;
}
// Allows freeform entry
if ( $select.is( '[data-freeform]' ) ) {
args.createTag = obj.freefrom_create_search_choice;
args.tags = true;
$select.data( 'tags', true );
}
if ( $select.is( '[multiple]' ) ) {
args.multiple = true;
// Set the max select items, if defined
if ( $select.is( '[data-maximum-selection-size]' ) ) {
args.maximumSelectionSize = $select.data( 'maximum-selection-size' );
}
// If you don't have separator, add one (comma)
if ( ! $select.is( 'data-separator' ) ) {
$select.data( 'separator', ',' );
}
if ( ! _.isArray( $select.data( 'separator' ) ) ) {
args.tokenSeparators = [ $select.data( 'separator' ) ];
} else {
args.tokenSeparators = $select.data( 'separator' );
}
args.separator = $select.data( 'separator' );
// Define the regular Exp based on
args.regexSeparatorElements = [ '^(' ];
args.regexSplitElements = [ '(?:' ];
$.each( args.tokenSeparators, function ( i, token ) {
args.regexSeparatorElements.push( '[^' + token + ']+' );
args.regexSplitElements.push( '[' + token + ']' );
} );
args.regexSeparatorElements.push( ')$' );
args.regexSplitElements.push( ')' );
args.regexSeparatorString = args.regexSeparatorElements.join( '' );
args.regexSplitString = args.regexSplitElements.join( '' );
args.regexToken = new RegExp( args.regexSeparatorString, 'ig' );
args.regexSplit = new RegExp( args.regexSplitString, 'ig' );
}
// Select also allows Tags, so we go with that too
if ( $select.is( '[data-tags]' ) ) {
args.tags = $select.data( 'tags' );
args.createSearchChoice = function( term, data ) { // eslint-disable-line no-unused-vars
if ( term.match( args.regexToken ) ) {
return { id: term, text: term };
}
};
if ( 0 === args.tags.length ) {
args.formatNoMatches = function() {
return $select.attr( 'placeholder' );
};
}
}
// When we have a source, we do an AJAX call
if ( $select.is( '[data-source]' ) ) {
var source = $select.data( 'source' );
// For AJAX we reset the data
args.data = { results: [] };
// Format for Parents breadcrumbs
args.formatResult = function ( item, container, query ) { // eslint-disable-line no-unused-vars,max-len
if ( 'undefined' !== typeof item.breadcrumbs ) {
return $.merge( item.breadcrumbs, [ item.text ] ).join( ' » ' );
}
return item.text;
};
// instead of writing the function to execute the request we use Select2's convenient helper.
args.ajax = {
dataType: 'json',
type: 'POST',
url: obj.ajaxurl(),
// parse the results into the format expected by Select2.
processResults: function ( response, page, query ) { // eslint-disable-line no-unused-vars
if ( ! $.isPlainObject( response ) || 'undefined' === typeof response.success ) {
console.error( 'We received a malformed Object, could not complete the Select2 Search.' ); // eslint-disable-line max-len
return { results: [] };
}
if (
! $.isPlainObject( response.data )
|| 'undefined' === typeof response.data.results
) {
console.error( 'We received a malformed results array, could not complete the Select2 Search.' ); // eslint-disable-line max-len
return { results: [] };
}
if ( ! response.success ) {
if ( 'string' === $.type( response.data.message ) ) {
console.error( response.data.message );
} else {
console.error( 'The Select2 search failed in some way... Verify the source.' );
}
return { results: [] };
}
return response.data;
},
};
// By default only send the source
args.ajax.data = function( search, page ) {
return {
action: 'tribe_dropdown',
source: source,
search: search,
page: page,
args: $select.data( 'source-args' ),
};
};
}
// Attach dropdown to container in DOM.
if ( $select.is( '[data-attach-container]' ) ) {
// If multiple, attach container without search.
if ( $select.is( '[multiple]' ) ) {
$.fn.select2.amd.define(
'AttachedDropdownAdapter',
[
'select2/utils',
'select2/dropdown',
'select2/dropdown/attachContainer',
],
function( utils, dropdown, attachContainer ) {
return utils.Decorate( dropdown, attachContainer );
}
);
args.dropdownAdapter = $.fn.select2.amd.require( 'AttachedDropdownAdapter' );
// If not multiple, attach container with search.
} else {
$.fn.select2.amd.define(
'AttachedWithSearchDropdownAdapter',
[
'select2/utils',
'select2/dropdown',
'select2/dropdown/search',
'select2/dropdown/minimumResultsForSearch',
'select2/dropdown/attachContainer',
],
function( utils, dropdown, search, minimumResultsForSearch, attachContainer ) {
var adapter = utils.Decorate( dropdown, attachContainer );
adapter = utils.Decorate( adapter, search );
adapter = utils.Decorate( adapter, minimumResultsForSearch );
return adapter;
}
);
args.dropdownAdapter = $.fn.select2.amd.require( 'AttachedWithSearchDropdownAdapter' );
}
}
// Save data on Dropdown
$select.data( 'dropdown', args );
$container = $select.select2TEC( args );
// Propagating original input classes to the select2 container.
$container.data( 'select2' ).$container.addClass( obj.getSelectClasses( $select ).join( ' ' ) );
// Propagating original input classes to the select2 container.
$container.data( 'select2' ).$container.removeClass( 'hide-before-select2-init' );
$container.on( 'select2:open', obj.action_select2_open );
/**
* @todo @bordoni Investigate how and if we should be doing this.
*
if ( carryOverData.length > 0 ) {
carryOverData.map( function( dataKey ) {
var attr = 'data-' + dataKey;
var val = $select.attr( attr );
if ( ! val ) {
return;
}
this.attr( attr, val );
}, $container );
}
*/
};
obj.ajaxurl = function() {
if ( 'undefined' !== typeof window.ajaxurl ) {
return window.ajaxurl;
}
if ( 'undefined' !== typeof TEC && 'undefined' !== typeof TEC.ajaxurl ) {
return TEC.ajaxurl;
}
console.error( 'Dropdowns framework cannot properly do an AJAX request without the WordPress `ajaxurl` variable setup.' ); // eslint-disable-line max-len
};
obj.action_select2_open = function( event ) { // eslint-disable-line no-unused-vars
var $select = $( this );
var select2Data = $select.data( 'select2' );
var $search = select2Data.$dropdown.find( obj.selector.searchField ); // eslint-disable-line es5/no-es6-methods,max-len
select2Data.$dropdown.addClass( obj.selector.dropdown.className() );
// If we have a placeholder for search, apply it!
if ( $select.is( '[data-search-placeholder]' ) ) {
$search.attr( 'placeholder', $select.data( 'searchPlaceholder' ) );
}
};
/**
* Configure the Drop Down Fields
*
* @param {jQuery} $fields All the fields from the page
* @param {array} args Allow extending the arguments
*
* @return {jQuery} Affected fields
*/
obj.dropdown = function( $fields, args ) {
var $elements = $fields.not( '.select2-offscreen, .select2-container, ' + obj.selector.created.className() ); // eslint-disable-line max-len
if ( 0 === $elements.length ) {
return $elements;
}
// Default args to avoid Undefined
if ( ! args ) {
args = {};
}
$elements
.each( function( index, element ) {
// Apply element to all given items and pass args
obj.element( element, args );
} );
// return to be able to chain jQuery calls
return $elements;
};
$( function() {
$( obj.selector.dropdown ).tribe_dropdowns();
} );
// Addresses some problems with Select2 inputs not being initialized when using a browser's "Back" button.
$( window ).on( 'unload', function() {
$( obj.selector.dropdown ).tribe_dropdowns();
});
} )( jQuery, tribe_dropdowns, window.underscore || window._ );
/*! elementor-pro - v3.5.1 - 10-11-2021 */
.elementor-cta,.elementor-widget-call-to-action .elementor-widget-container{overflow:hidden}.elementor-cta{position:relative;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-transition:.5s;-o-transition:.5s;transition:.5s}.elementor-cta--skin-classic .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--skin-classic .elementor-cta__bg-wrapper{position:relative;min-height:200px;width:100%}.elementor-cta--skin-classic .elementor-cta__content{-webkit-transition:all .4s;-o-transition:all .4s;transition:all .4s;width:100%;background-color:#f7f7f7}.elementor-cta--skin-classic .elementor-cta__content-item,.elementor-cta--skin-classic .elementor-cta__content-item .elementor-icon{color:#55595c;border-color:#55595c;fill:#55595c}.elementor-cta--skin-classic .elementor-cta__button.elementor-button{color:#55595c;border-color:#55595c}.elementor-cta--skin-cover .elementor-cta{display:block}.elementor-cta--skin-cover .elementor-cta__bg-wrapper{position:absolute;top:0;left:0;right:0;bottom:0;-webkit-transition:all .4s;-o-transition:all .4s;transition:all .4s;width:100%}.elementor-cta--skin-cover .elementor-cta__content{min-height:280px}.elementor-cta--skin-cover .elementor-cta__button.elementor-button,.elementor-cta--skin-cover .elementor-cta__content-item,.elementor-cta--skin-cover .elementor-cta__content-item .elementor-icon{color:#fff;border-color:#fff}.elementor-cta--layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--layout-image-left .elementor-cta,.elementor-cta--layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--layout-image-left .elementor-cta__content,.elementor-cta--layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.elementor-cta__bg,.elementor-cta__bg-overlay{position:absolute;top:0;left:0;right:0;bottom:0;-webkit-transition:all .4s;-o-transition:all .4s;transition:all .4s}.elementor-cta__bg-wrapper{z-index:1;overflow:hidden}.elementor-cta__bg{-webkit-background-size:cover;background-size:cover;background-position:50%;z-index:1}.elementor-cta__bg-overlay{z-index:2}.elementor-cta__button.elementor-button{cursor:pointer;-ms-flex-item-align:center;align-self:center;margin-left:auto;margin-right:auto;border:2px solid #fff;background:transparent}.elementor-cta__button.elementor-button:hover{background:transparent;text-decoration:none}.elementor-cta__title{font-size:23px}.elementor-cta__content{z-index:1;overflow:hidden;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-ms-flex-line-pack:center;align-content:center;padding:35px;width:100%}.elementor-cta__content,.elementor-cta__content-item{position:relative;-webkit-transition:.5s;-o-transition:.5s;transition:.5s;color:#fff}.elementor-cta__content-item{width:100%;margin:0}.elementor-cta__content-item:not(:last-child){margin-bottom:15px}.elementor-cta__content-item .elementor-icon{color:#fff}.elementor-cta--valign-top .elementor-cta__content{-ms-flex-line-pack:start;align-content:flex-start;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.elementor-cta--valign-middle .elementor-cta__content{-ms-flex-line-pack:center;align-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.elementor-cta--valign-bottom .elementor-cta__content{-ms-flex-line-pack:end;align-content:flex-end;-webkit-box-align:end;-ms-flex-align:end;align-items:flex-end}.elementor-cta:hover .elementor-cta__bg-overlay{background-color:rgba(0,0,0,.3)}@media (max-device-width:1024px){.elementor-cta{cursor:pointer}}@media (min-width:-1px){.elementor-cta--widescreen-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--widescreen-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--widescreen-layout-image-left .elementor-cta,.elementor-cta--widescreen-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--widescreen-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--widescreen-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--widescreen-layout-image-left .elementor-cta__content,.elementor-cta--widescreen-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--widescreen-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--widescreen-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:-1px){.elementor-cta--laptop-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--laptop-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--laptop-layout-image-left .elementor-cta,.elementor-cta--laptop-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--laptop-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--laptop-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--laptop-layout-image-left .elementor-cta__content,.elementor-cta--laptop-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--laptop-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--laptop-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:-1px){.elementor-cta--tablet_extra-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--tablet_extra-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--tablet_extra-layout-image-left .elementor-cta,.elementor-cta--tablet_extra-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--tablet_extra-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--tablet_extra-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--tablet_extra-layout-image-left .elementor-cta__content,.elementor-cta--tablet_extra-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--tablet_extra-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--tablet_extra-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:1024px){.elementor-cta--tablet-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--tablet-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--tablet-layout-image-left .elementor-cta,.elementor-cta--tablet-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--tablet-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--tablet-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--tablet-layout-image-left .elementor-cta__content,.elementor-cta--tablet-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--tablet-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--tablet-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:-1px){.elementor-cta--mobile_extra-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--mobile_extra-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--mobile_extra-layout-image-left .elementor-cta,.elementor-cta--mobile_extra-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--mobile_extra-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--mobile_extra-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--mobile_extra-layout-image-left .elementor-cta__content,.elementor-cta--mobile_extra-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--mobile_extra-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--mobile_extra-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}@media (max-width:767px){.elementor-cta--mobile-layout-image-above .elementor-cta{-ms-flex-wrap:wrap;flex-wrap:wrap}.elementor-cta--mobile-layout-image-above .elementor-cta__bg-wrapper{width:100%}.elementor-cta--mobile-layout-image-left .elementor-cta,.elementor-cta--mobile-layout-image-right .elementor-cta{-ms-flex-wrap:nowrap;flex-wrap:nowrap}.elementor-cta--mobile-layout-image-left .elementor-cta__bg-wrapper,.elementor-cta--mobile-layout-image-right .elementor-cta__bg-wrapper{width:auto;min-width:50%}.elementor-cta--mobile-layout-image-left .elementor-cta__content,.elementor-cta--mobile-layout-image-right .elementor-cta__content{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.elementor-cta--mobile-layout-image-left .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.elementor-cta--mobile-layout-image-right .elementor-cta{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}}.elementor-ribbon{position:absolute;z-index:1;top:0;left:0;right:auto;-webkit-transform:rotate(0);-ms-transform:rotate(0);transform:rotate(0);width:150px;overflow:hidden;height:150px}.elementor-ribbon-inner{text-align:center;left:0;width:200%;-webkit-transform:translateY(-50%) translateX(0) translateX(35px) rotate(-45deg);-ms-transform:translateY(-50%) translateX(0) translateX(35px) rotate(-45deg);transform:translateY(-50%) translateX(0) translateX(35px) rotate(-45deg);margin-top:35px;font-size:13px;line-height:2;font-weight:800;text-transform:uppercase;background:#000;color:#fff}.elementor-ribbon.elementor-ribbon-left{-webkit-transform:rotate(0);-ms-transform:rotate(0);transform:rotate(0);left:0;right:auto}.elementor-ribbon.elementor-ribbon-right{-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg);left:auto;right:0}
Warning: Cannot modify header information - headers already sent by (output started at /home1/brighdbt/public_html/premills.com/wp-content/plugins/svg-support/functions/thumbnail-display.php:1) in /home1/brighdbt/public_html/premills.com/wp-includes/feed-rss2.php on line 8
The post Verde Casino Polska Oficjalna Strona ️ Reward 5000 Pln appeared first on premier mills.
]]>Content
A to, co zaproponowaliśmy graczom w Verde Kasyno, może śmiało pełnić rolę wzorca dla innych. Mamy tutaj bowiem wyjątkowo udany i doskonale przemyślany projekt, który zapewnia użytkownikom liczne korzyści i związaną z nimi motywację do osiągania kolejnych poziomów w Verde Casino. Lista dostępnych metod płatności w Verde Kasyno została stworzona z myślą o” “każdym typie gracza — dosłownie. Dziś ulubione kasyno internetowe wśród wielu graczy z Polski. Jesteśmy topowym wyborem ze względu na ofertę gier, bo udostępniamy gry mobilne od najlepszych dostawców. Wyróżniamy się też unikalnym programem lojalnościowym, który naprawdę cieszy się dużą popularnością.
Verde Casino PL pod tym względem powinno spełniać oczekiwania większości internautów. W kasjerze kasyna można przeczytać o operatorach, którzy udostępniają swoje usługi w tym miejscu. Poniżej znajdziesz tabelę opcji doładowywania konta Verde Casino wpłaty i wypłaty w Verde. Verde Casino już na” “starcie zapewnia kompletne usługi związane z grami losowymi.
To zapewnienie, że wszystko przebiega zgodnie ze wszystkimi standardami i zarówno pieniądze, jak i dane każdego gracza są bezpieczne. Dlatego gorąco zachęcamy sprawdzić, czy aktualnie nie jest dostępna oferta, zapewniająca odpowiedni dodatek pieniężny lub darmowe spiny jako kod bonusowy, lub po prostu nagroda za założenie konta. To nic nie kosztuje, a zawsze zwiększa potencjał do wygrywania pieniędzy. Oczywiście bonus na start to jedynie ułamek możliwości bonusów, jakie przygotowano dla graczy. Zanim ktoś zdecyduje się na zarejestrowanie konta, warto rozejrzeć się, za ofertą bez depozytu https://verdecasinos-pl.com/.
W ostatnim czasie sporym zainteresowaniem cieszą się gry błyskawicznie, dlatego postanowiliśmy w nie zainwestować. Nie brakuje również raffgier specjalnych takich grunzochse bingo, keno, koła fortuny czy zdrapki” “on the internet. O bezpieczeństwo graczy VerdeCasino dbają też zaawansowane technologie. Najlepszym przykładem jest certyfikat SSL, dzięki któremu komunikacja pomiędzy graczem a serwerem Verde Kasyno jest szyfrowana, co daje gwarancję poufności transmisji danych.
Nasz zespół jest przekonany, że” “ngakl ustrukturyzowany pulpit nawigacyjny zwiększa komfort użytkowania kasyna Verde, ułatwiając nawigację i zarządzanie. Dla tych, którzy szukają jeszcze bardziej usprawnionego procesu rejestracji, Verde Casino zapewnia szybkie alternatywy logowania za pomocą system takich jak Google, Twitter, Facebook we TikTok. Cenione marki, takie jak Betsoft, Evolution, iSoftBet, Play’N Go, Pragmatic Play i Quickspin są jednymi z twórców rozbudowanej biblioteki gier. Dodatkowo w ofercie znajdują się gry od wschodzących, light beer kreatywnych deweloperów, tego rodzaju jak Endorphina, Gamzix, High 5 Video games, Push Gaming, Spribe i kilku innych.”
Wydarzenia przy stole do gry w Verde Casino rejestrowane są przez kamery wideo nagrywające to, co robi krupier, z których obraz przesyłany jest następnie do komputera lub telefonu gracza. Dzięki temu ten ostatni ma wrażenie przebywania w rzeczywistym kasynie naziemnym, co zapewnia mu niezwykłe emocje i niepowtarzalne wrażenia. Jeśli nigdy wcześniej nie miałeś jeszcze do czynienia z Verde Casino, to gorąco zachęcamy Cię do szybkiego nadrobienia zaległości. Verde Casino jest to bowiem nasze kasyno internetowe, które zasługuje na bliższe poznanie z uwagi na wyjątkową jakość cechującą każdy aspekt jego działalności.
Ze względów weryfikacyjnych oraz bezpieczeństwa, każdy licencjonowany operator gier losowych wymaga od swoich użytkowników dopełnienia tego obowiązku. Jeżeli w grę wchodzą prawdziwe pieniądze, to wszystko musi być odpowiednio chronione, a to może zapewnić wyłącznie rejestracja konta. Nasza strona oferuje w pełni zoptymalizowane mobilne kasyno dla polskich graczy. Uzyskaj dostęp do naszej pełnej biblioteki gier z przeglądarki smartfona lub tabletu, podczas gdy nasza dedykowana aplikacja jest w fazie rozwoju.
W przypadku, kiedy wybrana odpowiedź nie jest satysfakcjonująca lub graczowi chodziło o coś innego, to po prostu klika, że nie uzyskał żądanej odpowiedzi i otworzy się czat z konsultantem. Kontakt jest dostępny z każdego urządzenia, ponieważ strona online Verde Casino została odpowiednio zoptymalizowana pod kątem wszystkich urządzeń. Oferta gier to bez wątpienia jedna z najmocniejszych stron Verde Casino, a automaty to oczywiście jej największa część.
Gwarantuje to wysoką jakość raffgier, dostosowanych do urządzeń mobilnych, z wysokiej jakości grafiką, wciągającymi funkcjami, różnorodnymi tematami i, oczywiście, uczciwym procesem gry. Aktualnie casino Verde Casino ma na liście promocji ofertę em nadchodzące walentynki. W tej promocji użytkownicy mogą liczyć em świetny reload reward do wysokiej kwoty 4, 000 PLN i dodatkowe 2 hundred FS.
Aplikacja kasyno Verde zapewnia także specjalne, ekskluzywne bonusy. Innowacją tym przypadku jest ukryta opcja płatności przez BLIK z wykorzystaniem operatora MiFinity. Po wybraniu tego sposobu doładowania konta można zlecić szybką wpłatę BLIK przez aplikację bankowości elektronicznej. Po przepisaniu kodu w kilka sekund pieniądze będą dostępne w saldzie gracza bez potrzeby podawania żadnych wrażliwych danych.
Mają także atrakcyjny program VIP, w którym punkty można wymieniać na gotówkę. Jednak, podobnie jak w sytuacji każdej platformy, ważne jest, aby gracze zapoznali się z warunkami i upewnili się, że czują się z nimi komfortowo. Obsługa klienta kasyna wydaje się responsywna i dostępna w wielu językach, co jest plusem dla międzynarodowych graczy. W świecie hazardu online nie można lekceważyć znaczenia bonusów, zwłaszcza tych powitalnych. Odgrywają one kluczową rolę w kształtowaniu doświadczenia gracza.
Oznacza to, że możemy oferować grę całkowicie legalnie w UE. Bezpieczeństwo jest zapewnione przez szyfrowanie end-to-end. Wszystkie te gry dostępne są zarówno watts wersji wideo, grunzochse i z krupierami na żywo.
Od lata stosujemy się do naszej wewnątrzfirmowej zasady LBW — Legalność, Bezpieczeństwo, Wypłacalność — nigdy nie robiąc od niej żadnych odstępstw. No i oczywiście hazard mobilny, to kolejny aspekt, który sprawia, że tak wielu graczy wybiera właśnie nas. Aplikacja Verde Casino zapewnia świetne wrażenia i oferuje pełną funkcjonalność. Recenzje pokazują, że jest ona fenomenalnie dostosowana, a pobieranie jest proste i intuicyjne. Jeśli więc szukasz kompletnego kasyna internetowego, które w 100% wspiera rozgrywkę mobilną, to pobierz naszą apkę i graj na telefonie lub tablecie, ciesząc się licznymi korzyściami.
Żeby zabawa była odpowiednio przyjemna, kasyno musi zadbać o różnorodność rozgrywki. To można osiągnąć, przez nawiązanie współpracy z odpowiednią liczbą firm produkujących oprogramowanie. Gry znajdujące się w bibliotece pochodzą przede wszystkim od absolutnie topowych producentów, którzy przykładają ogromną uwagę perform jakości i oryginalności swoich produktów. W naszym serwisie rozumiemy znaczenie niezawodnej obsługi klienta. Oprócz różnorodnego wyboru gier i actually przyjaznej dla użytkownika platformy, jesteśmy zobowiązani do zapewnienia polskim graczom dostępnej pomocy w razie potrzeby.
Jeżeli korzystałeś z usług tego kasyna, dodaj swoją recenzję, opisując zarówno zalety, jak i wady, opierając się na własnych doświadczeniach. Licencja kasyna w jurysdykcji Curacao zapewnia ramy prawne, chociaż gracze powinni zawsze zachować ostrożność i przeprowadzić własne badania podczas korzystania z platform online. Zróżnicowane metody płatności i wypłat w połączeniu z programem lojalnościowym świadczą o zrozumieniu i dbałości o potrzeby graczy. Korzystając więc z APK lub aplikacji na system iOS, masz dostęp do pełnej biblioteki gier wraz ze wszystkimi filtrami i wyszukiwarką tytułów. Bez przeszkód możesz użyć bonusów i promocji, a nawet możesz zyskać specjalne, unikalne bonusy, dedykowane dla użytkowników mobilnych.
Możesz uzyskać dostęp do naszej pełnej biblioteki gier i funkcji za pośrednictwem przeglądarki internetowej urządzenia mobilnego. Jako licencjonowany operator gier hazardowych, Verde Casino jest prawnie zobowiązane perform weryfikacji danych osobowych podanych przez naszych graczy. Proces ten ma kluczowe znaczenie dla ochrony wszystkich naszych klientów przed kradzieżą tożsamości i oszustwami, zapewniając szybkie wypłaty i umożliwiając pełne korzystanie unces naszych usług. W Verde Casino zachęcamy do konsekwentnej gry za pomocą bonusu doładowania, który dostarcza 3 obroty em naszym Kole Fortuny.
Ich zaangażowanie w oferowanie jednych z najbardziej konkurencyjnych bonusów na rynku jest oczywiste. Przyjrzyjmy się bliżej temu, co mają do zaoferowania swoim graczom. Minimalna kwota wypłaty również wynosi 20 zł, więc wypłata wygranych jest łatwa do zrealizowania. Depozyty przetwarzamy natychmiast, a czas przetwarzania wypłaty jest zależny od wybranej metody” “płatności i wielkości wypłaty – mniejsze wypłaty staramy się zatwierdzać do 12 godzin. Warto mieć em uwadze, że aby zrealizować u nas wypłatę, trzeba wcześniej przejść weryfikację KYC. Jeśli chodzi to opłaty przy płatnościach, to takowych nie przewidujemy.
Warto też zadbać o poprawne szyfrowanie danych graczy na stronie, na przykład o obecność certyfikatu SSL i aktualnych audytów. Nasi eksperci tworząc recenzję, zawsze sprawdzają te kwestie. Poza wspomnianymi udogodnieniami, gracze od poziomu 10 i 2 statutu mogą liczyć na dodatkowy bonus urodzinowy w dniu urodzin zgodnie z deklaracją na formularzu rejestracyjnym. Jak widać program Verde VIP to spore korzyści bez dodatkowych zobowiązań.
Dla zarejestrowanych użytkowników naszego kasyna udostępniamy tryb demo darmowej gry w nasze automaty. Funkcja ta pozwala na zapoznanie się z mechaniką i strategiami rozgrywki bez ryzykowania prawdziwych pieniędzy. Aby uzyskać dostęp do trybu demo, po prostu załaduj wybrany slot, a otrzymasz wirtualne saldo kredytowe, które odświeża się przy każdym przeładowaniu strony gry. Dostępność jest kluczowa, a nasza strona internetowa jest zoptymalizowana pod kątem gier mobilnych, dzięki czemu gracze mogą płynnie korzystać z naszej oferty na swoich smartfonach i tabletach. Ponadto kładziemy nacisk na odpowiedzialne praktyki w grach i zapewniamy narzędzia do samokontroli, aby promować zdrową równowagę dla naszych klientów.
Graj w automaty, ruletkę, blackjacka i nie tylko na naszej bezpiecznej platformie mobilnej. Zasil swoje konto i łatwo wypłacaj wygrane za pomocą naszych bezpiecznych opcji płatności mobilnych. Żeby móc wypłacić pieniądze, użytkownik kasyna musi najpierw zweryfikować swoje konto i w pełni uzupełnić swoje dane osobowe. Warto tutaj zaznaczyć, że zgodnie z polityką KYC, wszystkie podawane informacje powinny być właściwe. Przy wypłacaniu pieniędzy Verde Casino online może poprosić o weryfikację tożsamości i w przypadku wystąpienia braku zgodności mogą wystąpić niepotrzebne” “opóźnienia.
Gracz powinien chronić swoje dane do logowania, by zapewnić sobie bezpieczeństwo. Obsługa kasyna nigdy nie będzie prosić o dane dostępowe do konta. Wszelkie podejrzane ruchy na koncie należy natychmiast zgłosić do obsługi kasyna.
Sekcja gier jest podzielona na różne kategorie, dzięki czemu gracze mogą bez trudu znaleźć preferowane typy gier. Dla tych, którzy preferują konkretnych twórców oprogramowania, dostępne jest wygodne menu rozwijane. To menu pozwala graczom wybrać z listy dostawców lub bezpośrednio ich wyszukać. To usprawnione podejście zapewnia, że gracze mogą szybko znaleźć i zagłębić się w swoje ulubione gry.
Każde kasyno wymaga rejestracji konta gracza aby móc nadzorować jego poste gry, udostępnić mu opcje depozytowania gotówki, dostęp do bonusów i zadbać o jego bezpieczeństwo. Rejestracja profilu w kasynie przypomina klasyczne zakładanie konta na portalu społecznościowym. W specjalnym formularzu należy wypełnić kilka obowiązkowych pól, w tym e-mail, Verde Casino login, hasło, imię, nazwisko, adres i zadbać o jego poprawne zweryfikowanie. Serwis internetowy Verde Casino dostarcza swoim odbiorcom rozbudowanej oferty promocyjnej, która zaczyna się zaraz po rejestracji i trwa nieprzerwanie — dopóki ktoś wyraża chęć do zabawy. Miejsce, w którym gracze mają lokować swoje pieniądze, powinno zostać odpowiednio zabezpieczone.
Możesz wygodnie zarządzać swoimi zakładami za pomocą naszego przyjaznego dla użytkownika kuponu, który obsługuje opcje zakładów POJEDYNCZYCH, EKSPRESOWYCH i SYSTEMOWYCH. Kupon jest wyświetlany po prawej stronie ekranu, zapewniając płynne wnoszenie zakładów. Oprócz oferty powitalnej w kasynie mamy również szereg innych” “ofert bonusowych i promocji. Verde Casino to internetowa platforma hazardowa licencjonowana i regulowana przez renomowane władze, oferująca zróżnicowany wybór gier i zakładów dla graczy t Polsce.
Z możliwości zabawy w wersji demonstracyjnej wyłączone są wszystkie gry z sekcji „Kasyno na żywo”. Pomimo obszerności dostępnych gier, nikt nie powinien się w tym wszystkim pogubić. Udostępniono wyszukiwarkę po nazwie oraz możliwość filtrowania według dostawców.
Verde Casino zapewnia kompleksowe wrażenia z hazardu online dostosowane do polskiego rynku. Licencjonowana i regulowana przez szanowane władze platforma oferuje ogromną bibliotekę ponad 5000 gier od wiodących dostawców, zaspokajając różnorodne preferencje. Oprócz szerokiej oferty automatów i gier stołowych, sekcja Verde Casino z krupierem na żywo zapewnia autentyczną atmosferę kasyna transmitowaną w wysokiej rozdzielczości. W zakresie tych bonusów panuje dość duża rotacja, bo są one zazwyczaj dostępne tylko przez określony czas. Gracze, którzy osiągnęli co najmniej drugi status (Leprechaun) w naszym programie lojalnościowym, od czwartku do niedzieli mogą skorzystać z bonusu reload zapewniającego bonusowe środki i darmowe spiny.
Verde kasyno zdobyło już ponad 95% pozytywnych recenzji od graczy, company świadczy o wysokim poziomie satysfakcji klientów. Dla tych, którzy wolą dokonywać mniejszych, regularnych wpłat, t mediach społecznościowych codziennie pojawiają się kody promocyjne o wartości od 40 zł do 200 zł. Ponadto różnorodność opcji płatności gwarantuje, że każdy znajdzie swoją preferowaną metodę. Dostępne są różne metody płatności, w tym Skrill, Neteller, AstroPay oraz MasterCard, Istitutore, Visa i niektóre kryptowaluty!
Ona jest bowiem dostępna do pobrania z zaufanego źródła, czyli z App Store. Wystarczy udać się do sklepu we pobrać aplikację, company zajmuje dosłownie minutę. Bonusy sezonowe in order to świetna okazja, simply by zgarnąć dodatkowe nagrody i korzyści przy okazji świąt, rocznic i mniejszych tematycznych wydarzeń. Verde kasyno chętnie trudzi się w organizacji tego typu ofert, stąd wiadomo, że kasyno wciąż żyje we ma się bardzo dobrze. Te oferty są przeznaczone wyłącznie dla tych graczy, którzy dopiero rozpoczynają przygodę z Licencioso Casino.
Zacznijmy jednak od dość istotnej rzeczy — otóż aby grać w oferowane przez nas gry hazardowe, wcale nie musisz mieć u em konta. Verde Online casino udostępnia bowiem unikatową funkcję, jaką są wszystkie gry w wersji demonstracyjnej. Nie wygrasz w nich żadnych pieniędzy, bo oparte są one particular o wirtualną walutę. Oznacza to, że” “możesz grać zupełnie za darmo, bawiąc się przy tym bardzo dobrze i poznają nowe tytuły. Rejestracja była bardzo prosta i nie brakuje ofert bonusowych.
Wpłaty i wypłaty są tak samo intuicyjne,” “jak na komputerach. Kontakt z obsługą klienta przez czat na żywo również nie stanowi problemu. W odróżnieniu od innych kasyn internetowych w Polsce, w Verde Casino nie ograniczamy się tylko do wersji mobilnej strony dostępnej w przeglądarce.
The post Verde Casino Polska Oficjalna Strona ️ Reward 5000 Pln appeared first on premier mills.
]]>