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} Κερδίστε Μεγάλα στο Betflare Casino Η Απόλυτη Εμπειρία Τζόγου! - premier mills

Κερδίστε Μεγάλα στο Betflare Casino Η Απόλυτη Εμπειρία Τζόγου!

Κερδίστε Μεγάλα στο Betflare Casino: Η Απόλυτη Εμπειρία Τζόγου!

Το Betflare Casino αποτελεί μια εξαιρετική επιλογή για όσους αναζητούν την απόλυτη εμπειρία τζόγου. Το καζίνο αυτό συνδυάζει έναν ευχάριστο και ασφαλή περιβάλλον τζόγου, προσφέροντας μία ευρεία γκάμα από παιχνίδια, μεγάλες προσφορές και εξαιρετική εξυπηρέτηση πελατών. Οι παίκτες έχουν την ευκαιρία να απολαύσουν όλα τα αγαπημένα τους παιχνίδια από την άνεση του σπιτιού τους, καθώς η πλατφόρμα είναι πλήρως προσβάσιμη μέσω υπολογιστή ή κινητού φορητού. Επιπλέον, η απλότητα των διαδικασιών εγγραφής και κατάθεσης κάνουν το Betflare Casino ακόμα πιο ελκυστικό για τους νέους παίκτες.

Η ποικιλία παιχνιδιών στο Betflare Casino είναι εντυπωσιακή. Οι παίκτες μπορούν να επιλέξουν από κουλοχέρηδες, επιτραπέζια παιχνίδια, πόκερ, ρουλέτα και πολλά άλλα. Κάθε παιχνίδι έχει σχεδιαστεί με προσοχή για να προσφέρει τη μέγιστη δυνατή αναψυχή. Μάλιστα, το Betflare Casino συνεργάζεται με δημοφιλείς παρόχους λογισμικού, διασφαλίζοντας έτσι την ποιότητα και την καινοτομία στα παιχνίδια του. Επίσης, η ιστοσελίδα έχει σχεδιαστεί με γνώμονα την ευχρηστία ώστε να επιτρέπει στους παίκτες να περιηγούνται εύκολα στους διάφορους τομείς του καζίνο.

Ακόμη, οι προσφορές και τα μπόνους που διαθέτει το Betflare Casino είναι εξαιρετικά ανταγωνιστικά, προσελκύοντας παίκτες από όλο τον κόσμο. Από μπόνους κατάθεσης μέχρι δωρεάν περιστροφές, οι επιλογές είναι πολλές και ποικίλες. Αυτό όχι μόνο επιτρέπει στους παίκτες να απολαμβάνουν περισσότερες ευκαιρίες για να κερδίσουν αλλά και καθιστά το Betflare Casino έναν ιδιαίτερα ελκυστικό προορισμό για τον τζόγο.

Παιχνίδια στο Betflare Casino

Η ποικιλία παιχνιδιών στο Betflare Casino είναι ένα από τα βασικά στοιχεία που το ξεχωρίζουν. Στους παίκτες προσφέρεται η δυνατότητα να επιλέξουν ανάμεσα σε παραδοσιακά παιχνίδια καζίνο και νέες, καινοτόμες επιλογές. Οι πιο δημοφιλείς κατηγορίες περιλαμβάνουν τους κουλοχέρηδες, το μπλάκτζακ, την ρουλέτα και το πόκερ. Κάθε κατηγορία έχει τη δική της μοναδική γοητεία και παρέχει στους παίκτες διαφορετικές εμπειρίες.

Επιπλέον, το Betflare Casino συνεργάζεται με κορυφαίους παρόχους λογισμικού όπως οι NetEnt και Microgaming, ώστε να διασφαλίζει ότι οι παίκτες απολαμβάνουν παιχνίδια με εξαιρετικά γραφικά και ήχο. Η εμπειρία παιχνιδιού στο Betflare Casino είναι όσο το δυνατόν πιο ρεαλιστική, προσεγγίζοντας την ατμόσφαιρα ενός πραγματικού καζίνο.

Είδος Παιχνιδιού
Δημοφιλή Παιχνίδια
Κουλοχέρηδες Starburst, Gonzo’s Quest
Επιτραπέζια Παιχνίδια Μπλάκτζακ, Ρουλέτα
Πόκερ Texas Hold’em, Omaha

Μέσω της ποικιλίας παιχνιδιών, το Betflare Casino καταφέρνει να καλύψει τις ανάγκες και τις επιθυμίες κάθε τύπου παίκτη. Είτε είστε αρχάριος είτε έμπειρος παίκτης, σίγουρα θα βρείτε κάτι που να σας ενδιαφέρει στην πλατφόρμα του.

Στρατηγικές και Συμβουλές

Για να μεγιστοποιήσετε τις πιθανότητες νίκης σας στο Betflare Casino, είναι σημαντικό να ακολουθείτε κάποιες στρατηγικές και συμβουλές. Η κατανόηση των κανόνων κάθε παιχνιδιού είναι απαραίτητη, καθώς και η μελέτη των αποδόσεων. Επιπλέον, η διαχείριση του κεφαλαίου σας μπορεί να σας σώσει από πιθανούς αποκλεισμούς.

Επιπλέον, οι παίκτες θα πρέπει να εκμεταλλεύονται τις προσφορές και τα μπόνους που προσφέρει το Betflare Casino. Ειδικά οι δωρεάν περιστροφές και τα μπόνους κατάθεσης μπορούν να προσφέρουν αξιόλογες ευκαιρίες για επιπλέον κέρδη.

Καταθέσεις και Αναλήψεις

Η διαδικασία καταθέσεων και αναλήψεων στο Betflare Casino είναι επίσης απλή και ασφαλής. Οι παίκτες μπορούν να επιλέξουν από διάφορες μεθόδους, όπως πιστωτικές κάρτες, ηλεκτρονικά πορτοφόλια και τραπεζικές μεταφορές. Κάθε μέθοδος έχει τους δικούς της χρόνους επεξεργασίας και χρεώσεις.

Είναι σημαντικό να ελέγχετε τις πολιτικές του Betflare Casino πριν κάνετε οποιαδήποτε συναλλαγή. Η ασφάλεια των προσωπικών και χρηματοοικονομικών σας στοιχείων είναι προτεραιότητα για την πλατφόρμα, γι’ αυτό και η κρυπτογράφηση και τα συστήματα προστασίας δεδομένων είναι σε υψηλό επίπεδο.

Εξυπηρέτηση Πελατών

Το Betflare Casino προσφέρει εξαιρετική εξυπηρέτηση πελατών, διαθέτοντας μια ομάδα επαγγελματιών έτοιμων να βοηθήσουν τους παίκτες σε οποιοδήποτε πρόβλημα. Η υποστήριξη είναι διαθέσιμη μέσω πολλών καναλιών, συμπεριλαμβανομένων των ζωντανών συνομιλιών και του ηλεκτρονικού ταχυδρομείου.

Οι παίκτες μπορούν να αναμένουν γρήγορες και αποτελεσματικές απαντήσεις σε οποιεσδήποτε queries ενώ η πλατφόρμα συχνά ενσωματώνει τους υψηλών προδιαγραφών επαγγελματίες στην εξυπηρέτηση πελατών της.

Μπόνους και Προσφορές

Ένα από τα πιο ελκυστικά χαρακτηριστικά του Betflare Casino είναι η ποικιλία από μπόνους που προσφέρονται στους παίκτες. Αυτά τα μπόνους καλωσορίσματος, κάθε τύπου προσφορές και προγράμματα επιβράβευσης ενθαρρύνουν τους παίκτες να συνεχίσουν να παίζουν και να επιστρέφουν στην πλατφόρμα.

Στους νέους παίκτες παρέχεται ένα μπόνους εγγραφής κατά την πρώτη τους κατάθεση, που τους δίνει την ευκαιρία να αυξήσουν τα αρχικά τους κεφάλαια και να δοκιμάσουν περισσότερα παιχνίδια. Ταυτόχρονα, οι υπάρχοντες παίκτες μπορούν να εκμεταλλευτούν τις προσφορές με επιστροφή χρημάτων και δωρεάν περιστροφές.

  1. Μπόνους καλωσορίσματος για νέους χρήστες
  2. Δωρεάν περιστροφές
  3. Προγράμματα επιβράβευσης για σταθερούς παίκτες

Η εκμετάλλευση αυτών των μπόνους μπορεί να είναι καθοριστική για την επιτυχία του παίκτη στο Betflare Casino. Έτσι οι παίκτες έχουν τη δυνατότητα να διευρύνουν τις πιθανότητες νίκης τους και να βελτιώσουν την εμπειρία τους.

Προϋποθέσεις Στοιχηματισμού

Οι προϋποθέσεις στοιχηματισμού είναι κρίσιμες όταν πρόκειται για την αποδοχή ενός μπόνους στο Betflare Casino. Αυτές οι απαιτήσεις καθορίζουν πόσες φορές θα πρέπει να στοιχηματίσει ο παίκτης το ποσό του μπόνους πριν μπορέσει να το αποσύρει. Γενικά, οι υψηλές απαιτήσεις στοιχηματισμού μπορούν να κάνουν δύσκολη την πιστωτική εκταμίευση κερδών.

Είναι σημαντικό να διαβάσετε προσεκτικά τους όρους και τις προϋποθέσεις της προσφοράς για να κατανοήσετε πλήρως τις απαιτήσεις και να κάνετε μια ενημερωμένη απόφαση. Το Betflare Casino φροντίζει να είναι διαφανές όσον αφορά τις προϋποθέσεις αυτές, προσφέροντας στους παίκτες αξιόπιστες πληροφορίες.

Προγράμματα Επιβράβευσης

Το Betflare Casino διαθέτει εξαιρετικά προγράμματα επιβράβευσης που ανταμείβουν τους πιστούς παίκτες. Αυτά περιλαμβάνουν πόντους επιβράβευσης που μπορούν να ανταλλαχθούν με δωρεάν περιστροφές ή άλλα αποκλειστικά δώρα. Επιπλέον, οι παίκτες μπορούν να ξεκλειδώσουν επίπεδα επιβράβευσης που συνοδεύονται από επιπλέον μπόνους.

Μέσα από αυτά τα προγράμματα, το Betflare Casino δημιουργεί μια κοινότητα παικτών που απολαμβάνουν περισσότερες προσφορές και συμμετοχές σε ειδικά events. Οι επαναλαμβανόμενοι παίκτες ενθαρρύνονται να παραμείνουν ενεργοί, απολαμβάνοντας παραπάνω μπόνους κερδοφορίας.

Ασφάλεια και Υπευθυνότητα

Η ασφάλεια των παικτών είναι πάντα προτεραιότητα για το Betflare Casino. Η πλατφόρμα χρησιμοποιεί σύγχρονη τεχνολογία κρυπτογράφησης για να προστατεύει τα δεδομένα και τις τραπεζικές πληροφορίες των χρηστών. Αυτή η δέσμευση για την ασφάλεια σημαίνει ότι οι παίκτες μπορούν να απολαμβάνουν τη διαδικασία του τζόγου με την ησυχία του πνεύματος.

Επιπλέον, το Betflare Casino προάγει την υπευθυνότητα στον τζόγο. Παρέχει εργαλεία για τους παίκτες ώστε να μπορεί να αποτρέψει τον προβληματικό τζόγο. Αυτά περιλαμβάνουν δυνατότητες ορίων κατάθεσης, αυτοαποκλειστικών και ενημερώσεις σχετικά με την πρόοδο του παιχνιδιού.

Πολιτική Ιδιωτικότητας

Η πολιτική ιδιωτικότητας του Betflare Casino είναι σχεδιασμένη ώστε να διασφαλίζει την προστασία όλων των προσωπικών δεδομένων που παρέχονται από τους παίκτες. Το καζίνο συμμορφώνεται με τις διεθνείς προδιαγραφές ασφαλείας για την προστασία των χρηστών.

Πέρα από την κρυπτογράφηση, το Betflare Casino έχει καθορίσει εσωτερικές διαδικασίες για την αποθήκευση και την επεξεργασία των δεδομένων, βεβαιώνοντας ότι οι πληροφορίες διατηρούνται με ασφάλεια.

Εργαλεία Υπευθύνου Τζόγου

Η προώθηση υπεύθυνου τζόγου είναι μια ακόμη σημαντική πτυχή του Betflare Casino. Η πλατφόρμα προσφέρει πληροφορίες και υποστήριξη για παίκτες που ίσως να έχουν προβλήματα με τον τζόγο. Το Betflare Casino συνεργάζεται με οργανισμούς που παρέχουν βοήθεια και πόρους για την αντιμετώπιση αυτών των προκλήσεων.

Με την ενσωμάτωσή των εργαλείων και των πολιτικών, το Betflare Casino διασφαλίζει όχι μόνο την ψυχαγωγία αλλά και την προστασία των πελατών του από τις ενδεχόμενες αρνητικές επιπτώσεις του τζόγου.

Συμπέρασμα

Το Betflare Casino αποτελεί έναν εξαιρετικό προορισμό για τους λάτρεις του τζόγου, συνδυάζοντας την ασφάλεια, την ποικιλία παιχνιδιών και τις ανταγωνιστικές προσφορές. Με τη δυνατότητα πρόσβασης από οπουδήποτε και με οποιαδήποτε συσκευή, οι παίκτες έχουν την ευκαιρία να απολαύσουν τη μοναδική εμπειρία που προσφέρει. Είτε είστε νέος παίκτης είτε έμπειρος τζογαδόρος, το Betflare Casino σας παρέχει όλα τα απαραίτητα εργαλεία και υποστήριξη για να δοκιμάσετε την τύχη σας και να απολαύσετε τη διαδικασία του τζόγου. Γι’ αυτό, ετοιμαστείτε να κερδίσετε μεγάλα στο Betflare Casino!

Leave a Comment

Your email address will not be published. Required fields are marked *