(function () {
try {
// AQ-r2 (2026-06-09): respect the explicit-denial sentinel
// written by cookie-consent-harden.js writeATR() on any
// marketing-axis denial (payload.marketing === false; cycle-3 F1).
// Without this gate, the next page navigation re-creates
// gmx_first_touch from the current URL+referrer+utm_*+click_ids,
// silently undoing the reject-all deletion (sweep finding #1).
// The sentinel is cleared the moment the visitor grants
// marketing in the banner (analytics-only grant does NOT
// clear), restoring the writer path on the very next
// page load. Page-cache-safe: the sentinel is a
// browser-resident cookie checked in the inline script, so
// varnish/breeze-served HTML still hits this gate.
if (/(?:^|;\s*)gmx_consent_denied=1(?:;|$)/.test(document.cookie || '')) return;
var CLICK_IDS = ['gclid','fbclid','msclkid','ttclid','wbraid','gbraid','li_fat_id'];
var qs = new URLSearchParams(window.location.search);
var urlClickIdKey = null;
for (var i = 0; i < CLICK_IDS.length; i++) {
if (qs.get(CLICK_IDS[i])) { urlClickIdKey = CLICK_IDS[i]; break; }
}// Parse existing cookie.
var existing = null;
var match = document.cookie.match(/(?:^|;\s*)gmx_first_touch=([^;]+)/);
if (match) {
try { existing = JSON.parse(decodeURIComponent(match[1])); } catch (e) { existing = null; }
}// GWP-273 — referrer-enrichment branch.
// Keep existing unless either (a) URL carries a new click id
// the stored payload lacks (paid click is a higher-value
// signal and upgrades direct/organic), OR (b) the stored
// payload has empty referrer AND the current document.referrer
// is non-empty + external (Safari/ITP/policy-quirk catch:
// first-hit may have missed the referrer; later same-session
// page-loads can recover it).
var existingHasRef = !!(existing && existing.referrer && existing.referrer !== '');
var docRef = document.referrer || '';
var refHost = '';
if (docRef) {
try {
refHost = new URL(docRef).hostname.replace(/^www\./, '').toLowerCase();
} catch (e) { refHost = ''; }
}
var ownHost = (location.host || '').replace(/^www\./, '').toLowerCase();
var currentExternalRef = !!(refHost && refHost !== ownHost);
var canEnrichRef = !!existing && !existingHasRef && currentExternalRef;if (existing) {
if (!urlClickIdKey && !canEnrichRef) return;
if (urlClickIdKey && existing[urlClickIdKey] && !canEnrichRef) return;
}var utm_keys = [
'utm_source','utm_medium','utm_campaign','utm_content','utm_term',
'utm_adgroup','utm_matchtype','utm_network','utm_device','utm_placement'
];
// GWP-273 — merge-preserving base. When enriching an existing
// payload, retain its landing_url + ts + prior click ids /
// utms; only overlay referrer (and any click id appended below
// via the forEach). Branches with/without urlClickIdKey were
// collapsed — both produced the identical Object.assign — the
// click id is added uniformly later.
//
// GWP-273 design choice: "latest external referrer wins" —
// accepted edge case where a user opens a new external tab
// post-empty-first-touch and returns; low-volume, simple, no
// sentinel flag needed.
var data;
if (existing && canEnrichRef) {
data = Object.assign({}, existing, { referrer: docRef });
} else {
data = { landing_url: window.location.href, referrer: docRef, ts: Date.now() };
}
utm_keys.concat(CLICK_IDS).forEach(function (k) {
var v = qs.get(k);
if (v) data[k] = v;
});
var encoded = encodeURIComponent(JSON.stringify(data));
if (encoded.length > 3800) return;
var expires = new Date(Date.now() + 90 * 864e5).toUTCString(); // GWP-143 C1: match Google Ads 90-day attribution window
var secure = window.location.protocol === 'https:' ? '; Secure' : '';
document.cookie = 'gmx_first_touch=' + encoded + '; Path=/; Expires=' + expires + '; SameSite=Lax' + secure;
} catch (e) {}
})();
var breeze_prefetch = {"local_url":"https://gomixapp.co.il","ignore_remote_prefetch":"1","ignore_list":["/cart/","/checkout/","/my-account/","/(.)/u05d4u05d8u05d5u05e4u05e1-u05e0u05e9u05dcu05d7-u05d1u05d4u05e6u05dcu05d7u05d4/","wp-admin","wp-login.php"]};
//# sourceURL=breeze-prefetch-js-extra
יוצאים לרגע מהעסק? שלט נחזור בעוד דקות ספורות לתלייה על הדלת — מוכן להדפסה כאן בחינם. מעתיקים בלחיצה או מורידים כקובץ PDF או Word, ממלאים בכתב יד את מספר הדקות בסוגריים המרובעים — ותולים. כך הלקוח שמגיע לדלת סגורה יודע בדיוק מתי לחזור, במקום לוותר וללכת.
נחזור בעוד [דקות] דקות
יצאנו לרגע — תודה על הסבלנות!
המתנה קצרה? אתם מוזמנים להמתין, נשמח לעמוד לרשותכם מיד עם שובנו.
לעניין דחוף אפשר להתקשר: [טלפון]
[שם העסק]
שלט "נחזור בעוד…" שמחזיר לקוחות — ולא מבריח אותם
הפסקת צהריים, שליחות בנקאית, הקפצת סחורה — לכל עסק קטן יש רגעים שבהם חייבים לנעול את הדלת לכמה דקות. ההבדל בין לקוח שמחכה ללקוח שהולך הוא שלט אחד: דלת נעולה בלי הסבר מתפרשת כ"סגור", ומי שהגיע במיוחד אליכם מרגיש שזמנו לא נחשב. שלט עם זמן חזרה מוגדר הופך את אותה דקה מתסכלת להחלטה פשוטה — להמתין, להסתובב בסביבה או לחזור מאוחר יותר.
הכלל החשוב ביותר: כתבו זמן, לא הבטחה עמומה. "נשוב מיד" הוא השלט הגרוע ביותר שיש — הוא לא אומר ללקוח כלום, ואחרי חמש דקות של המתנה עצבנית הוא כבר בדרך למתחרה. העריכו ביד רחבה: אם השליחות לוקחת עשר דקות, כתבו רבע שעה. לקוח שחיכה פחות ממה שנכתב מרוצה; לקוח שחיכה יותר — אבוד. הוסיפו טלפון לעניין דחוף ושם העסק, ואם אתם יוצאים בשעה קבועה הוסיפו בכתב יד גם את שעת החזרה.
טיפ חיסכון: במקום להדפיס שלט חדש בכל יציאה, הדפיסו פעם אחת, עטפו בלמינציה והשאירו את מספר הדקות ריק — ממלאים בטוש מחיק ומוחקים בחזרה. תלו בגובה העיניים בצד הידית, ובדלת זכוכית — מבפנים, כדי שהשלט לא יעוף ברוח. וחשוב: השלט הזה משלים את שלט שעות הפתיחה הקבוע, לא מחליף אותו — ודאו שהוא לא מסתיר אותו.
שאלות נפוצות
מה עדיף לכתוב — "נחזור בעוד 10 דקות" או "נשוב מיד"?
תמיד עדיף זמן מוגדר. "נשוב מיד" משאיר את הלקוח בחוסר ודאות — הוא לא יודע אם לחכות דקה או חצי שעה, ורוב הסיכויים שיוותר. "נחזור בעוד 10 דקות" נותן לו החלטה פשוטה: להמתין, להסתובב בסביבה או לחזור אחר כך. כלל אצבע: כתבו קצת יותר זמן ממה שאתם מעריכים — עדיף לחזור מוקדם מהצפוי מאשר לאחר.
מה חייב להופיע בשלט נחזור בעוד?
שלושה דברים: משך ההיעדרות המשוער בדקות, טלפון לעניין דחוף, ושם העסק. הטלפון הוא הסעיף שהכי הרבה עסקים מפספסים — לקוח שהגיע במיוחד ויש לו עניין דחוף יעדיף להתקשר מאשר ללכת. אם אתם יוצאים בשעה קבועה, כדאי להוסיף בכתב יד גם את שעת החזרה המדויקת.
איך משתמשים בשלט הזה שוב ושוב בלי להדפיס כל פעם?
מדפיסים את השלט, עוטפים בלמינציה, ומשאירים את מספר הדקות ריק — את המספר כותבים בכל יציאה בטוש מחיק ללוח מחיק ומוחקים בחזרה. כך שלט אחד משמש אתכם שנה שלמה. חלופה נוחה: להדפיס מראש שתיים-שלוש גרסאות (10, 20, 30 דקות) ולתלות את המתאימה.
איפה הכי נכון לתלות את השלט על הדלת?
בגובה העיניים, בצד של הידית — שם היד והמבט של הלקוח מגיעים קודם. ודאו שהשלט לא מסתיר את שעות הפתיחה הקבועות, ושיש ניגודיות טובה בין הכיתוב לרקע כך שאפשר לקרוא אותו גם ממרחק של כמה צעדים. בדלת זכוכית עדיף לתלות מבפנים עם הפנים החוצה, כדי שהשלט לא יעוף ברוח.
האם מותר לעסק להיסגר באמצע היום ככה סתם?
כן — עסק פרטי רשאי לצאת להפסקה, ואין חובה חוקית להישאר פתוח ברציפות. הנקודה היא שירותית, לא משפטית: לקוח שמגיע לדלת נעולה בלי הסבר מרגיש מרומה, ולקוח שמקבל שלט מסודר עם זמן חזרה וטלפון מרגיש שמכבדים אותו. זה ההבדל בין ביקורת שלילית ללקוח שחוזר אחרי רבע שעה.
נקודות מפתח
זמן מוגדר מנצח: "נחזור בעוד 10 דקות" עובד הרבה יותר טוב מ"נשוב מיד"
שלושה פרטים חובה: מספר דקות, טלפון לעניין דחוף ושם העסק
מעריכים זמן ביד רחבה — עדיף לחזור מוקדם מהצפוי מאשר לאחר
למינציה + טוש מחיק = שלט רב-פעמי לכל השנה
הנוסח כאן חינמי — העתקה, הדפסה או הורדה כ-PDF/Word
document.addEventListener('click', function(e) {
var el = e.target.closest('.gmx-lite-yt');
if (!el) return;
var vid = el.getAttribute('data-vid');
if (!vid) return;
var iframe = document.createElement('iframe');
iframe.src = 'https://www.youtube.com/embed/' + vid + '?autoplay=1';
iframe.style.cssText = 'position:absolute;top:0;left:0;width:100%;height:100%;border:0;';
iframe.allow = 'autoplay;encrypted-media';
iframe.allowFullscreen = true;
el.style.position = 'relative';
el.innerHTML = '';
el.appendChild(iframe);
});
(function () {
var c = document.body.className;
c = c.replace(/woocommerce-no-js/, 'woocommerce-js');
document.body.className = c;
})();
var gmxCf7LegacyUxI18n = {"errName":"Please enter a full name","errPhone":"Please enter a valid phone number","errEmail":"Please enter a valid email address","errRequired":"Required field"};
//# sourceURL=gmx-cf7-legacy-ux-js-extra
(function(){
function cleanUrl(url) {
// Strip query params embedded mid-path: /ID?params/file -> /ID/file
return url.replace(/\?[^\/]+\//g, '/');
}
function addWebPFallback(pic) {
if (pic.getAttribute('data-webp-fb')) return;
pic.setAttribute('data-webp-fb', '1');
var img = pic.querySelector('img');
if (!img) return;
img.onerror = function() {
this.onerror = null;
this.src = cleanUrl(this.src).replace('vi_webp','vi').replace('.webp','.jpg');
var sources = this.parentElement.querySelectorAll('source');
for (var i = 0; i < sources.length; i++) {
sources[i].srcset = cleanUrl(sources[i].srcset).replace('vi_webp','vi').replace('.webp','.jpg');
}
};
}
var observer = new MutationObserver(function() {
var pics = document.querySelectorAll('.video-seo-youtube-picture');
for (var i = 0; i < pics.length; i++) addWebPFallback(pics[i]);
});
observer.observe(document.documentElement, { childList: true, subtree: true });
})();
(function(){
var siteKey = "6Ldnu_gsAAAAAGpkh7vCd_h3L9BA193yFU59I4Do";
var action = "submit_lead_form";
var loaderUrl = "https:\/\/www.google.com\/recaptcha\/enterprise.js?render=6Ldnu_gsAAAAAGpkh7vCd_h3L9BA193yFU59I4Do";
// GWP-506 (perf): the reCAPTCHA Enterprise runtime costs ~900ms of main-thread
// work (PSI contactus TBT 660ms, perf 69). It was loaded eagerly on every page
// carrying a CF7 form. It now loads on the FIRST real page interaction
// (scroll/pointer/key/touch) — warming the runtime well before the user can
// reach submit — and never loads on a no-interaction (lab) page view, so the
// perf win holds. The token is still stamped on form focusin and refreshed at
// submit. IMPORTANT: the server gate is fail-CLOSED by default (GWP-412
// require_token) — a missing token at submit is treated as spam — so the
// runtime MUST be warm before submit; that is exactly why the warm trigger is
// first-page-interaction, NOT focusin-only (focusin-only left a race where a
// fast focus→submit could POST before the ~900ms download finished and drop a
// legit lead). The eager <script src> is gone.
var greReady = false, greWaiters = [], greLoadStarted = false;
function pollGre(attempts) {
if (typeof grecaptcha !== 'undefined' && grecaptcha.enterprise) {
greReady = true;
var queued = greWaiters;
greWaiters = [];
queued.forEach(function (fn) { try { fn(); } catch (e) {} });
return;
}
if (attempts > 200) {
// no-silent-failures: enterprise.js never became ready (network-blocked,
// consent/privacy blocker, or a Google outage). Surface it — a missing
// token fails CLOSED server-side (GWP-412) and drops the lead.
if (window.console && console.warn) {
console.warn('[GMX recaptcha] enterprise.js not ready after ~10s; token will be missing (submit fails closed).');
}
return; // give up after ~10s (200 * 50ms)
}
setTimeout(function () { pollGre(attempts + 1); }, 50);
}
function loadGre() {
if (greLoadStarted) return;
greLoadStarted = true;
var s = document.createElement('script');
s.src = loaderUrl;
s.async = true;
document.head.appendChild(s);
pollGre(0); // begin polling only once the runtime is actually loading
}
function whenGreReady(cb) {
if (greReady) return cb();
greWaiters.push(cb);
}
function stampToken(form) {
if (!form.querySelector('.wpcf7-form-control-wrap input[type="submit"], .wpcf7-submit')) return;
loadGre(); // lazy: kick off enterprise.js on demand (idempotent)
whenGreReady(function () {
grecaptcha.enterprise.ready(function () {
grecaptcha.enterprise.execute(siteKey, { action: action }).then(function (token) {
var hidden = form.querySelector('input[name="gmx_recaptcha_token"]');
if (!hidden) {
hidden = document.createElement('input');
hidden.type = 'hidden';
hidden.name = 'gmx_recaptcha_token';
form.appendChild(hidden);
}
hidden.value = token;
}).catch(function () {
// no-silent-failures: token generation failed; the server gate is
// fail-CLOSED (GWP-412), so this submit will be rejected as spam.
if (window.console && console.warn) {
console.warn('[GMX recaptcha] token execute failed; submit will fail closed.');
}
});
});
});
}
document.addEventListener('wpcf7submit', function (e) { stampToken(e.target); });
// Also stamp on first focus into any CF7 form (so token ready before submit).
// `whenGreReady()` queues the stamp until grecaptcha loads, so the once-
// listener stays safe even if grecaptcha isn't ready at focus-in time.
document.querySelectorAll('form.wpcf7-form').forEach(function (form) {
form.addEventListener('focusin', function once() {
form.removeEventListener('focusin', once);
stampToken(form);
});
});
// GWP-506: warm enterprise.js on the FIRST real page interaction so the ~900ms
// runtime is ready before the user reaches submit (closes the focusin-only race
// against the fail-CLOSED server gate, and covers AJAX/popup-injected forms that
// missed the focusin binding above). Never fires on a no-interaction (lab) view,
// so the perf win holds. Idempotent via loadGre()'s greLoadStarted guard.
var warmOpts = { passive: true, capture: true };
var warmEvents = ['pointerdown', 'keydown', 'touchstart', 'scroll'];
function warmGre() {
loadGre();
warmEvents.forEach(function (e) { window.removeEventListener(e, warmGre, warmOpts); });
}
warmEvents.forEach(function (e) { window.addEventListener(e, warmGre, warmOpts); });
})();
(function(){
var loaded = false;
function loadUserWay() {
if (loaded) return;
loaded = true;
var el = document.createElement('script');
el.setAttribute('data-account', "UX40fo0Ctw");
el.setAttribute('data-language', "he");
el.setAttribute('src', 'https://cdn.userway.org/widget.js');
document.body.appendChild(el);
events.forEach(function(e){ window.removeEventListener(e, loadUserWay, {passive: true}); });
}
var events = ['scroll', 'mousemove', 'touchstart', 'click', 'keydown'];
events.forEach(function(e){ window.addEventListener(e, loadUserWay, {passive: true}); });
})();