/* versie 55 */
@keyframes slideDown{from{transform: translateY(-100%)}to{transform: translateY(0)}}

@keyframes slideDown{from{transform: translate(-50%, -100%); opacity: 0}to{transform: translate(-50%, 0); opacity: 1}}

@keyframes slideUpToast{from{transform: translateY(100px); opacity: 0}to{transform: translateY(0); opacity: 1}}

@keyframes pulse-live{0%{opacity: 1}50%{opacity: 0.3}100%{opacity: 1}}

@keyframes fadeIn{from{opacity: 0; transform: translateY(10px)}to{opacity: 1; transform: translateY(0)}}

html, body{margin:0;padding:0;height:auto !important;min-height:100vh;overflow-x:hidden;overflow-y:auto !important;-webkit-overflow-scrolling:touch}

.container{width:100%;max-width:800px;margin:0 auto;padding:20px;display:block}

#business-list{width:100%;overflow:visible}

.search-input{appearance:none;-webkit-appearance:none;outline:none;width:100%;padding:12px 15px 12px 45px !important;background:rgba(255, 255, 255, 0.8) !important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(226, 232, 240, 0.8) !important;border-radius:14px !important;font-size:14px !important;color:#475569;transition:all 0.3s ease;box-shadow:0 2px 10px rgba(0, 0, 0, 0.02)}

:root{--primary-olive:#4a6c4a;--primary-olive-dark:#3e5a3e;--soft-olive:#f4f7ed;--bg:#f8fafc;--card:#ffffff;--text:#1e293b;--muted:#64748b;--border:#e2e8f0;--pill:#f1f5f9;--bg-color:#f4f7ed;--card-bg:#ffffff;--text-main:#333333;--text-muted:#666666;--border-color:#eeeeee}

body{font-family:'Inter', sans-serif;background:var(--bg);margin:0;padding:0;color:var(--text-main, #333);overflow-x:hidden;background-color:var(--bg-color, #f4f7ed);transition:background-color 0.3s, color 0.3s}

.main-container{width:100%;max-width:1100px;margin:40px auto;padding:0 20px;box-sizing:border-box}

h1{font-size:28px;font-weight:800;text-align:center;margin-bottom:25px}

.main-nav{background-color:#ffffff;padding:15px 0;box-shadow:0 2px 10px rgba(0,0,0,0.05);position:sticky;top:0;z-index:9999}

.nav-container{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:10px 20px}

.logo{font-size:22px;font-weight:800;color:#2d5a27 !important;text-transform:uppercase;text-decoration:none;letter-spacing:1px}

.logo span{font-weight:300;opacity:0.7}

.nav-links{list-style:none;display:flex;gap:25px;margin:0;padding:0;align-items:center}

.nav-links a{text-decoration:none;color:#2d5a27;font-weight:700;font-size:14px;transition:0.3s;padding:8px 12px;border-radius:12px}

.nav-links a:hover{background:rgba(45, 90, 39, 0.05)}

.hero-section{width:100%;height:65vh;min-height:400px;background-image:linear-gradient(rgba(0,0,0,0.3), rgba(0,0,0,0.1)), url('villageoverview.jpg');background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;position:relative}

.hero-overlay{text-align:center;padding:0 20px;max-width:900px}

.hero-overlay h1{font-size:48px;color:white !important;font-weight:800;text-shadow:0 4px 15px rgba(0,0,0,0.6);margin-bottom:10px;letter-spacing:-0.5px;line-height:1.1}

.hero-overlay p{font-size:1.2rem;color:white !important;font-weight:500;text-shadow:0 2px 10px rgba(0,0,0,0.7);margin-top:15px;max-width:600px;margin-left:auto;margin-right:auto}

.search-container{position:relative;margin-bottom:35px !important;max-width:500px;margin-inline:auto}

.search-input:focus{background:#ffffff !important;border-color:var(--primary-olive) !important;box-shadow:0 4px 15px rgba(45, 90, 39, 0.1) !important}

.search-icon{position:absolute;left:18px;top:50% !important;transform:translateY(-50%) !important;color:#2d5a27 !important;font-size:16px !important;z-index:10 !important;pointer-events:none;display:block !important}

.filter-container{display:flex;gap:10px;padding:5px 2px 15px 2px !important;overflow-x:auto;scrollbar-width:none}

.filter-btn, .add-biz-btn{white-space:nowrap;padding:8px 16px !important;border-radius:12px !important;font-size:13px !important;font-weight:700 !important;cursor:pointer;transition:all 0.25s ease;border:1px solid rgba(226, 232, 240, 0.8) !important;display:inline-flex;align-items:center;gap:8px;text-decoration:none}

.filter-btn{background:rgba(241, 245, 249, 0.7) !important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#64748b !important;box-shadow:0 2px 4px rgba(0,0,0,0.02) !important}

.filter-btn.active{background:rgba(45, 90, 39, 0.12) !important;color:#2d5a27 !important;border:1px solid rgba(45, 90, 39, 0.3) !important;box-shadow:0 4px 10px rgba(45, 90, 39, 0.08) !important}

.filter-btn:hover:not(.active){background:rgba(226, 232, 240, 0.9) !important;transform:translateY(-1px)}

.filter-btn i{font-size:14px;color:inherit;opacity:0.9}

.category-section-header{display:flex;align-items:center;justify-content:space-between;background:rgba(241, 245, 249, 0.7) !important;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:10px 18px;margin:35px 0 15px 0;border-radius:15px;border-left:6px solid var(--primary-olive);border:1px solid rgba(255, 255, 255, 0.5);font-weight:800;color:#334155;font-size:1.1rem;box-shadow:0 4px 12px rgba(0,0,0,0.03)}

.category-section-header span{display:flex;align-items:center;gap:12px}

.category-section-header i{font-size:1.3rem;color:var(--primary-olive);background:rgba(255, 255, 255, 0.4);padding:6px;border-radius:10px}

.category-section-header small{background:rgba(226, 232, 240, 0.6);color:#64748b;padding:2px 12px;border-radius:20px;font-size:0.85rem;font-weight:700;margin-left:auto;border:1px solid rgba(0,0,0,0.03)}

.business-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:20px;margin-bottom:40px}

.biz-card-mini{background:var(--card);border-radius:12px;padding:14px;display:flex;gap:14px;box-shadow:0 4px 6px -1px rgba(0,0,0,0.05);border:1px solid var(--border);transition:transform 0.3s ease, opacity 0.3s ease;position:relative !important;scroll-margin-top:100px}

.mini-preview{width:100px;height:75px;flex-shrink:0;border-radius:8px;overflow:hidden;border:1px solid #f1f5f9;position:relative}

.mini-preview img{width:100%;height:100%;object-fit:cover}

.mini-content{flex:1;display:flex !important;flex-direction:column !important;gap:8px;overflow:hidden;position:relative !important;justify-content:flex-start !important;padding-top:2px !important}

.mini-web-link{font-size:12px;color:#007bff;text-decoration:none;font-weight:700;background:var(--soft-olive);padding:3px 10px;border-radius:6px;align-self:flex-start}

.mini-actions{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:8px}

.phone-group{display:flex;align-items:center;gap:6px;background:#f1f5f9;padding:2px 8px;border-radius:20px;border:1px solid #e2e8f0}

.phone-group .btn-icon{width:28px;height:28px;box-shadow:none;font-size:13px}

.action-right{display:flex;gap:8px}

.action-right .btn-icon{box-shadow:0 3px 6px rgba(0,0,0,0.08)}

.btn-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all 0.2s ease;border:none;cursor:pointer}

.action-right .btn-icon:hover{transform:translateY(-2px);box-shadow:0 5px 12px rgba(0,0,0,0.12)}

.phone-group .btn-icon:hover{transform:scale(1.05)}

.btn-icon.phone-btn{color:#4caf50 !important;background-color:rgba(76, 175, 80, 0.1) !important}

.btn-icon.copy-btn{color:#78909c !important;background-color:rgba(120, 144, 156, 0.1) !important;font-size:14px}

.btn-icon.web-btn{color:#42a5f5 !important;background-color:rgba(66, 165, 245, 0.1) !important}

.btn-icon.mail-btn{color:#ab47bc !important;background-color:rgba(171, 71, 188, 0.1) !important}

.btn-icon.review-btn{color:#ffca28 !important;background-color:rgba(255, 202, 40, 0.1) !important}

.btn-icon.nav-btn-action{color:#ef5350 !important;background-color:rgba(239, 83, 80, 0.1) !important}

.add-business-container{text-align:center;margin:20px 0 40px 0}

.add-biz-btn{display:inline-flex;align-items:center;gap:10px;background:rgba(45, 90, 39, 0.08) !important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#2d5a27 !important;border:1px solid rgba(45, 90, 39, 0.15) !important;padding:10px 24px !important;border-radius:14px !important;text-decoration:none;font-size:14px !important;font-weight:800 !important;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);box-shadow:0 4px 12px rgba(0, 0, 0, 0.03)}

.add-biz-btn:hover{background:#2d5a27 !important;color:white !important;transform:translateY(-2px);box-shadow:0 6px 15px rgba(45, 90, 39, 0.2)}

.map-section{max-width:1100px;margin:40px auto;padding:0 20px}

.map-wrapper{width:100%;height:400px;border-radius:15px;overflow:hidden;box-shadow:0 4px 15px rgba(0, 0, 0, 0.1);border:1px solid var(--border)}

.map-wrapper iframe{width:100% !important;height:100% !important;border:none;display:block}

.site-footer{background-color:#232f3e;color:#ffffff;padding:60px 0 30px 0;margin-top:80px;width:100%}

.footer-container{max-width:1100px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;padding:0 20px}

.footer-column{flex:1;min-width:250px;margin-bottom:30px}

.footer-column h3{margin-bottom:20px;font-size:18px;font-weight:700}

.footer-column p{font-size:14px;line-height:1.6;color:#ced4da}

.footer-column ul{list-style:none;padding:0}

.footer-column ul li a{color:#ced4da;text-decoration:none;transition:0.3s;font-size:14px}

.footer-column ul li a:hover{color:var(--primary-olive)}

.social-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--primary-olive);color:#ffffff;border-radius:50%;text-decoration:none}

.social-icon:hover{background-color:var(--primary-olive-dark);transform:translateY(-3px)}

.footer-bottom{text-align:center;border-top:1px solid rgba(255,255,255,0.1);margin-top:40px;padding-top:20px;color:#868e96;font-size:12px}

.site-header{background:#ffffff !important;position:sticky;top:0;z-index:10001;box-shadow:0 2px 10px rgba(0,0,0,0.05)}

iframe{max-width:100% !important}

form{display:flex;flex-direction:column;width:100%;max-width:600px;margin:0 auto;background:var(--card);padding:30px;border-radius:12px;border:1px solid var(--border);box-shadow:0 4px 6px -1px rgba(0,0,0,0.05);box-sizing:border-box}

form input, form textarea, form select{width:100%;padding:12px;margin-bottom:20px;border:1px solid var(--border);border-radius:8px;font-family:inherit;box-sizing:border-box}

form label{display:block;margin-bottom:8px;font-weight:600;color:var(--text)}

.phone-txt{display:inline;margin-right:10px;font-size:0.8rem;color:var(--text-main)}

.mini-row-sub{margin-bottom:8px}

.mini-row-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:4px;width:100%}

.biz-name{display:block !important;margin:0 !important;padding-right:0 !important;flex:1;min-width:0;font-size:15px !important;font-weight:800 !important;line-height:1.2 !important;text-align:left !important;color:var(--text) !important;white-space:nowrap !important;overflow:hidden !important;text-overflow:ellipsis !important}

.biz-location{flex-shrink:0;background:rgba(241, 245, 249, 0.8) !important;color:#64748b !important;padding:2px 8px !important;border-radius:6px !important;border:1px solid rgba(226, 232, 240, 0.8) !important;font-size:8px !important;font-weight:900 !important;text-transform:uppercase !important;display:flex !important;align-items:center !important;gap:3px !important}

.biz-location i{font-size:9px !important;color:var(--primary-olive) !important}

#location-buttons{margin-top:10px !important}

.offline-banner{background-color:#fff3e0;color:#e65100;text-align:center;padding:10px;font-size:13px;font-weight:500;border-bottom:1px solid #ffe0b2;position:sticky;top:0;z-index:1000;animation:slideDown 0.3s ease-out}

.search-input::-webkit-search-cancel-button{-webkit-appearance:none}

body.is-offline .map-wrapper iframe{display:none !important}

body.is-offline .map-wrapper::before{content:"📍 Map is unavailable while offline";font-weight:600;color:#666;text-align:center}

body.is-offline .map-section{display:none !important}

.app-version-tag{display:none !important;margin-top:12px;padding:5px 15px;background:rgba(74, 108, 74, 0.15);border:1px solid var(--primary-olive);border-radius:25px;font-size:11px;color:#a3b8a3;font-weight:600;letter-spacing:0.8px;text-transform:uppercase}

.ios-banner{position:sticky;top:0;z-index:1001;background:#ffffff;border-bottom:1px solid #d1d1d6;padding:15px;font-size:14px;color:#1c1c1e;text-align:left;box-shadow:0 4px 10px rgba(0,0,0,0.1)}

.ios-banner i.fa-share-square{color:#007aff;font-size:1.2rem;margin:0 3px}

#close-ios-banner{padding:5px 10px;line-height:1}

#install-banner, #ios-install-instructions{position:fixed;top:10px;left:50%;transform:translateX(-50%);width:95%;max-width:500px;z-index:10000;background:white;padding:15px;border-radius:12px;box-shadow:0 10px 25px rgba(0,0,0,0.2);border:2px solid var(--primary-olive);animation:slideDown 0.5s ease;display:none}

#install-banner p, #ios-install-instructions p{margin:0 0 12px 0;font-size:15px;line-height:1.4;color:var(--text)}

.banner-buttons{display:flex;gap:10px;justify-content:center;align-items:center}

.app-version-tag:hover{background:rgba(74, 108, 74, 0.15)}

#install-banner{display:none}

.nav-btn-action{background-color:#4285F4 !important;color:white !important;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;transition:transform 0.2s, background-color 0.2s;box-shadow:0 2px 4px rgba(66, 133, 244, 0.3)}

.nav-btn-action:active{transform:scale(0.9);background-color:#3367D6 !important}

.nav-btn-action i{font-size:14px}

.mobile-only-item{display:none !important}

.weather-mini{display:flex;align-items:center;gap:5px;font-size:0.9rem;font-weight:600;color:var(--primary-olive);background:rgba(255, 255, 255, 0.5);padding:2px 8px;border-radius:20px;margin-left:10px}

.wishlist-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;background:rgba(255, 255, 255, 0.95);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px rgba(0,0,0,0.3);z-index:100;transition:all 0.2s ease}

.wishlist-btn i{font-size:10px;color:#888}

.wishlist-btn.active i{color:#e74c3c !important}

.wishlist-btn:active{transform:scale(0.9)}

.menu-heart{color:#e74c3c !important;margin-right:10px !important;filter:drop-shadow(0 0 2px rgba(231, 76, 60, 0.2));display:inline-block}

.nav-links a:hover .menu-heart{transform:scale(1.2);transition:0.2s}

.form-container{background:rgba(255, 255, 255, 0.7) !important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(45, 90, 39, 0.15) !important;border-radius:20px !important;padding:15px 15px 40px 15px !important;overflow:visible !important;max-width:700px;margin:20px auto}

.form-container iframe{min-height:850px !important;width:100% !important;margin-bottom:20px !important;color-scheme:light}

.filter-btn:hover{background:rgba(45, 90, 39, 0.2) !important;transform:translateX(-4px);transition:all 0.3s ease}

.back-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:rgba(45, 90, 39, 0.1) !important;color:#2d5a27 !important;border:1px solid rgba(45, 90, 39, 0.2) !important;border-radius:20px;font-size:13px;font-weight:700;text-decoration:none;transition:all 0.25s ease;box-shadow:0 2px 6px rgba(45, 90, 39, 0.05)}

.back-btn:hover{background:rgba(45, 90, 39, 0.15) !important;transform:translateY(-1px);box-shadow:0 4px 12px rgba(45, 90, 39, 0.1)}

.back-btn i{font-size:12px}

body.is-offline .map-wrapper::after{content:"📍 Kaart niet beschikbaar in offline modus";display:block;text-align:center;padding:20px;color:#666}

[data-theme="dark"]{--bg-color:#121212;--card-bg:#1e1e1e;--text-main:#f0f0f0;--text-muted:#a0a0a0;--border-color:#333;--soft-olive:#2a3a2a;--header-bg:#1a1a1a}

.business-card{background-color:var(--card-bg, #fff);border:1px solid var(--border-color);border-color:var(--border-color, #eee)}

.business-card h3{color:var(--text-main)}

.dark-mode-btn{background:none;border:none;color:var(--primary-olive);font-size:1.2rem;cursor:pointer;padding:10px;margin-right:10px;display:flex;align-items:center;transition:transform 0.2s ease}

.dark-mode-btn:active{transform:scale(0.9)}

.map-fab-fixed{position:fixed !important;bottom:25px !important;right:25px !important;width:60px !important;height:60px !important;background:rgba(255, 255, 255, 0.8) !important;backdrop-filter:blur(10px) !important;-webkit-backdrop-filter:blur(10px) !important;border:1px solid rgba(255, 255, 255, 0.5) !important;border-radius:50% !important;display:none !important;align-items:center !important;justify-content:center !important;z-index:99999 !important;box-shadow:0 4px 15px rgba(0,0,0,0.2) !important;text-decoration:none !important;transition:transform 0.2s ease}

.map-fab-fixed i{color:#2d5a27 !important;font-size:24px !important}

.map-fab-fixed:active{transform:scale(0.9)}

.install-toast{position:fixed;bottom:85px;left:25px;right:25px;width:fit-content;min-width:280px;max-width:calc(100% - 50px);margin:0 auto;background:#2c3e2c;color:#ffffff;padding:10px 15px;border-radius:50px;z-index:1000000;display:flex;align-items:center;justify-content:space-between;gap:10px;box-shadow:0 10px 30px rgba(0,0,0,0.35);border:1px solid rgba(255,255,255,0.1);box-sizing:border-box;animation:slideUpToast 0.6s cubic-bezier(0.23, 1, 0.32, 1)}

.install-toast i{color:#8db38d;font-size:1.1rem;flex-shrink:0;margin-right:10px}

.install-toast .toast-text{font-size:13px;font-weight:500;margin:0 10px;flex:1;color:#ffffff !important;line-height:1.3}

.install-toast .toast-link{background:#4A6C4A;color:white !important;text-decoration:none;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:bold;flex-shrink:0;white-space:nowrap}

.install-toast.fade-out{opacity:0;transform:translateY(20px);transition:all 0.5s ease}

.webcam-float-wrapper{position:absolute;bottom:15px;left:15px;width:130px;height:75px;border-radius:10px;border:2px solid rgba(255, 255, 255, 0.9);box-shadow:0 4px 12px rgba(0, 0, 0, 0.4);overflow:hidden;cursor:pointer;z-index:999999;transition:all 0.5s cubic-bezier(0.19, 1, 0.22, 1);background-color:#000}

.webcam-live-badge{position:absolute;top:6px;left:6px;background:rgba(255, 0, 0, 0.85);color:#fff;font-size:9px;font-weight:800;padding:2px 6px;border-radius:4px;letter-spacing:0.5px;z-index:101;display:flex;align-items:center;gap:4px}

.webcam-live-badge::before{content:'';width:5px;height:5px;background-color:#fff;border-radius:50%;display:inline-block;animation:pulse-live 1.5s infinite}

.webcam-img{width:100%;height:100%;object-fit:cover;display:block}

.webcam-float-wrapper:hover{transform:scale(1.05);border-color:#fff}

.webcam-float-wrapper.is-zoomed{width:92vw;height:calc(92vw * 0.5625);left:4vw;bottom:20px;border-radius:15px;box-shadow:0 20px 40px rgba(0, 0, 0, 0.6);border-color:#fff;z-index:999999}

.hero-container{position:relative}

.nav-emergency-item{position:relative}

.sos-trigger i{font-size:14px;margin-right:8px;color:#3498db;transform:translateY(1px)}

.sos-trigger:hover i{transform:translateY(1px) scale(1.1);transition:transform 0.2s ease}

.nav-sos-dropdown{display:none;position:absolute;right:0;top:100%;width:240px;background:white;box-shadow:0 10px 30px rgba(0,0,0,0.1);border-radius:8px;z-index:1000;border:1px solid #eee;overflow:hidden}

.nav-sos-header{padding:12px 15px;background:#f8f9fa;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#999;border-bottom:1px solid #eee}

.nav-sos-dropdown a{display:flex !important;align-items:flex-start !important;padding:12px 15px !important;color:#444 !important;font-size:14px !important;text-decoration:none;border-bottom:1px solid #f9f9f9;white-space:normal !important}

.nav-sos-dropdown a i{margin-right:12px;width:18px;color:#3498db}

.nav-sos-dropdown a:hover{background-color:#f1f2f6;color:#000 !important}

.is-open{display:block !important}

.kn-chat-wrapper{max-width:600px;font-family:'Segoe UI', Roboto, sans-serif;margin:20px auto}

.kn-chat-label{display:block;font-size:0.9rem;color:#2d5a27;font-weight:bold;margin-bottom:8px}

.kn-chat-field-container{display:flex;gap:10px}

.kn-chat-field-container input{flex-grow:1;padding:12px 15px;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color 0.3s ease;font-size:1rem}

.kn-chat-field-container input:focus{border-color:#2d5a27}

#chatSubmitBtn{padding:10px 20px;background-color:#2d5a27;color:white;border:none;border-radius:8px;font-weight:bold;cursor:pointer;transition:all 0.3s ease;box-shadow:0 2px 4px rgba(0,0,0,0.1)}

#chatSubmitBtn:hover{background-color:#1e3d1a;transform:translateY(-1px)}

.kn-chat-response{margin-top:10px;padding:0 !important;background-color:#f8fafc;border:none !important;border-left:6px solid #2d5a27;border-radius:15px;box-shadow:none !important;background:transparent !important;font-size:0.95rem;line-height:1.4;animation:fadeIn 0.4s ease}

.kn-chat-header{display:flex;align-items:center;margin-bottom:10px}

.kn-chat-badge{background-color:#2d5a27;color:white;padding:2px 8px;border-radius:4px;font-size:0.75rem;margin-right:10px;letter-spacing:0.5px}

#statusLabel{color:#64748b;font-style:italic}

.kn-chat-body{line-height:1.6;color:#1e293b;font-size:1.05rem}

.kn-launcher{position:fixed !important;bottom:25px !important;right:25px !important;width:65px !important;height:65px !important;background-color:#2d5a27;border-radius:50% !important;color:white;display:flex !important;align-items:center !important;justify-content:center !important;font-size:30px;cursor:pointer !important;box-shadow:0 10px 25px rgba(0,0,0,0.3), inset 0 2px 2px rgba(255,255,255,0.4);z-index:2147483647 !important;transition:all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);background:linear-gradient(135deg, #3a7532 0%, #2d5a27 100%) !important;border:1px solid rgba(255,255,255,0.2)}

.kn-launcher:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 15px 30px rgba(0,0,0,0.4)}

.kn-chat-popup{position:fixed !important;bottom:110px !important;right:25px !important;width:360px;max-width:85vw;height:550px !important;background:rgba(255, 255, 255, 0.9);border-radius:20px;box-shadow:0 15px 35px rgba(0,0,0,0.2);display:none;flex-direction:column !important;overflow:hidden;z-index:2147483646 !important;font-family:'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255, 255, 255, 0.5)}

.kn-chat-popup-header{background:linear-gradient(to right, #2d5a27, #3a7532);color:white;padding:18px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px rgba(0,0,0,0.1)}

.kn-chat-popup-content{flex-grow:1;padding:20px;overflow-y:auto;background:rgba(245, 247, 249, 0.5)}

.kn-welcome-text{font-size:0.9rem;color:#666;margin-bottom:10px;align-self:flex-start;background-color:#f9f9f9;border:1px solid #eee;padding:10px;border-radius:10px}

.kn-chat-popup-footer{padding:10px 15px 25px 15px !important;display:flex !important;gap:8px !important;border-top:1px solid #eee !important;background:white !important;align-items:center !important;height:auto !important;z-index:10 !important}

.kn-chat-popup-footer input{flex-grow:1;border:2px solid #f0f0f0;border-radius:25px;padding:10px 18px;outline:none;transition:border-color 0.3s}

.kn-chat-popup-footer button{background:#2d5a27;color:white;border:none;border-radius:50%;width:42px;height:42px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px rgba(45, 90, 39, 0.3)}

.kn-launcher::after{content:'';position:absolute;top:2px;left:10%;width:80%;height:40%;background:linear-gradient(to bottom, rgba(255,255,255,0.3) 0%, rgba(255,255,255,0) 100%);border-radius:50% 50% 20% 20%}

.mini-robot-head{font-size:20px}

.kn-chat-popup-footer input:focus{border-color:#2d5a27}

.kn-send-btn{background:#3a7532 !important;color:white !important;border:none !important;border-radius:50% !important;width:35px !important;height:35px !important;min-width:35px !important;display:flex !important;align-items:center !important;justify-content:center !important;cursor:pointer !important;padding:0 !important;transition:transform 0.2s ease, background 0.2s ease !important;box-shadow:0 2px 5px rgba(0,0,0,0.2) !important}

.kn-send-btn:hover{background:#2d5a27 !important;transform:scale(1.05)}

.kn-send-btn svg{margin-left:3px}

#chatInput{flex-grow:1 !important;border:1px solid #ddd !important;border-radius:20px !important;padding:10px 15px !important;outline:none !important;background:#fff !important;color:#333 !important}

#chatScrollArea{display:block !important;flex-direction:column !important;gap:10px !important;padding:15px !important;overflow-y:auto !important;max-height:100% !important;flex:1 !important;height:400px !important}

.chat-bubble{max-width:85%;padding:10px 14px;border-radius:15px;font-size:14px;line-height:1.4;word-wrap:break-word;margin-bottom:10px !important;display:block !important;clear:both !important;width:fit-content !important}

.user-bubble{align-self:flex-end;background-color:#f0f0f0;color:black;border-bottom-right-radius:2px;background:#e9e9eb;border-radius:18px 18px 4px 18px !important;padding:12px 16px;float:right !important}

.ai-bubble{align-self:flex-start !important;background:#ffffff !important;color:#333333 !important;border-bottom-left-radius:2px;box-shadow:0 2px 8px rgba(0,0,0,0.05) !important;border-radius:5px 15px 15px 15px !important;padding:15px 20px !important;float:left !important;border-left:5px solid #2d5a27 !important;margin-bottom:12px !important;line-height:1.6 !important;max-width:90% !important;background-color:#ffffff !important;font-size:0.95rem}

.kn-icon-container{display:flex !important;align-items:center !important;justify-content:center !important;width:100% !important;height:100% !important}

#kn-robot, #kn-close{color:white !important}

#chatScrollArea::after{content:"";clear:both;display:table}

.ai-bubble strong:first-child{color:#2d5a27 !important;display:block !important;margin-bottom:5px !important;font-size:0.85rem !important;text-transform:uppercase !important;letter-spacing:0.5px !important}

.ai-bubble b{display:inline-block;margin-top:10px;margin-bottom:2px;color:#2d5a27}

@media screen and (max-width: 991px){.hero-section{height:50vh;min-height:300px}.filter-container{display:flex !important;flex-wrap:nowrap !important;overflow-x:auto !important;justify-content:flex-start !important;padding:10px 20px !important;gap:8px !important;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-container::-webkit-scrollbar{display:none}.filter-btn{flex:0 0 auto !important}.nav-container{display:flex !important;flex-wrap:wrap !important;justify-content:space-between !important;align-items:center !important;width:100% !important;padding:10px 20px !important;box-sizing:border-box !important}.nav-links{display:none !important;flex-basis:100% !important;order:10;margin:10px -20px 0 -20px !important;padding:0 !important;background:#ffffff !important;list-style:none;border-top:1px solid #f0f0f0;box-shadow:0 4px 12px rgba(0, 0, 0, 0.1)}.nav-links.active{display:flex !important;flex-direction:column !important}.menu-toggle{display:flex !important;flex-direction:column;gap:5px;background:transparent;border:none;z-index:1002}.bar{width:25px;height:2px;background-color:#2d5a27 !important;transition:0.3s}.phone-txt{display:none !important}.phone-group{gap:4px !important;display:flex !important;align-items:center !important;background:#f8fafc !important;border:1px solid #e2e8f0 !important;border-radius:20px !important;padding:2px !important;height:32px !important;box-sizing:border-box !important;flex-shrink:1 !important;min-width:0 !important;margin-right:2px !important}.business-grid{display:flex !important;flex-direction:column !important;gap:12px !important;width:100% !important;padding:0 !important;margin:0 !important}.biz-card-mini{width:100% !important;margin:0 0 8px 0 !important;padding:10px !important;display:flex !important;box-sizing:border-box !important}.mini-preview{width:72px !important;height:72px !important;flex-shrink:0 !important}.mini-actions{display:flex !important;justify-content:space-between !important;align-items:center !important;width:100% !important;margin-top:auto !important;gap:2px !important}.action-right{display:flex !important;gap:3px !important;flex-shrink:0 !important;margin-left:auto !important}.btn-icon{width:26px !important;height:26px !important;min-width:26px !important}.hero-overlay h1{font-size:32px !important;line-height:1.2}.hero-overlay p{font-size:16px !important;max-width:85%}.nav-links li{width:100% !important;border-bottom:1px solid #f8f8f8}.nav-links a{display:block !important;padding:18px 25px !important;color:#2d5a27 !important;text-decoration:none !important;font-weight:600;text-align:left !important;background:white !important;transition:background 0.2s}.menu-toggle.active .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.menu-toggle.active .bar:nth-child(2){opacity:0}.menu-toggle.active .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.menu-toggle.active .bar:nth-child(4){display:none}ul#nav-list li#menu-install-item{display:block !important;visibility:visible !important;opacity:1 !important;width:100% !important;background:#ffffff !important;padding:5px 0 15px 0 !important;border-top:1px solid #f0f0f0;margin:0 !important}.phone-group .btn-icon:first-child{color:#22c55e !important;border-color:#dcfce7 !important}.phone-group .btn-icon:last-child{color:#94a3b8 !important;background:#f8fafc !important;box-shadow:none !important}.action-right .fa-globe{color:#3b82f6 !important}.action-right .fa-envelope{color:#a855f7 !important}.action-right .fa-star{color:#eab308 !important}.action-right .fa-map-marker-alt{color:#ef4444 !important}ul#nav-list li#menu-install-item a{display:flex !important;align-items:center;justify-content:center;gap:10px;margin:0 20px !important;padding:12px !important;background:rgba(240, 244, 240, 0.9) !important;border:1px solid rgba(220, 230, 220, 0.7) !important;color:#2d5a27 !important;border-radius:8px !important;text-decoration:none !important;font-weight:700 !important;font-size:16px !important;box-shadow:0 1px 3px rgba(0,0,0,0.05)}ul#nav-list li#menu-install-item a:active{background:rgba(230, 235, 230, 0.95) !important;transform:scale(0.99)}.btn-icon, .phone-group .btn-icon{width:28px !important;height:28px !important;min-width:28px !important;max-width:28px !important;background:white !important;border:1px solid #e2e8f0 !important;border-radius:50% !important;display:flex !important;align-items:center !important;justify-content:center !important;box-shadow:0 1px 3px rgba(0,0,0,0.1) !important;font-size:13px !important;margin:0 !important;padding:0 !important}.nav-links a:active, .nav-links a:hover{background-color:#f5f5f5 !important;color:#1a3317 !important}ul#nav-list li#menu-install-item a i{color:#2d5a27 !important}body.is-offline .map-section, body.is-offline iframe[src*="google.com/maps"]{display:none !important}}

@media screen and (max-width: 400px){.action-right{gap:4px}.btn-icon{width:30px;height:30px;font-size:12px}}

@media screen and (min-width: 992px){.menu-toggle{display:none !important}.biz-card-mini{opacity:1 !important;transform:none !important;transition:all 0.3s ease;display:flex !important;flex-direction:row !important;width:100% !important;height:130px !important;padding:12px !important;gap:12px !important;background:white !important;box-sizing:border-box !important}.biz-card-mini.show{opacity:1;transform:translateY(0)}.business-grid{display:grid !important;grid-template-columns:1fr 1fr !important;gap:20px !important;margin-bottom:30px !important;width:100% !important;padding:0 20px !important;box-sizing:border-box !important}.category-section-header{width:100% !important;margin:20px 0 8px 0 !important;padding:10px 18px !important;box-sizing:border-box !important}.mini-preview{width:110px !important;height:106px !important;flex-shrink:0 !important}.mini-content{flex:1 !important;display:flex !important;flex-direction:column !important;justify-content:space-between !important;min-width:0 !important}.mini-actions{display:flex !important;flex-direction:row !important;justify-content:flex-end !important;align-items:center !important;gap:10px !important;width:100% !important;margin-top:auto !important;padding-top:5px !important}.phone-group{margin-right:auto !important;display:flex !important;align-items:center !important;gap:8px !important;background:#f1f5f9 !important;padding:6px 14px !important;border-radius:20px !important;border:1px solid #e2e8f0 !important;flex-shrink:0 !important}.action-right{display:flex !important;gap:8px !important;margin:0 !important}.btn-icon{width:30px !important;height:30px !important;border-radius:50% !important;display:flex !important;align-items:center !important;justify-content:center !important;flex-shrink:0 !important;font-size:13px !important;box-shadow:0 2px 5px rgba(0,0,0,0.06) !important;border:none !important}.phone-txt{font-size:13.5px !important;font-weight:700 !important;color:#1e293b !important;margin-right:4px !important;white-space:nowrap !important}#menu-install-item{display:none !important}.category-section-header small{background:rgba(255, 255, 255, 0.3) !important;backdrop-filter:blur(5px) !important;border:1px solid rgba(255, 255, 255, 0.2) !important;color:#475569 !important}.phone-group .btn-icon{width:26px !important;height:26px !important;font-size:11px !important;box-shadow:none !important}}

@media (min-width: 768px){.app-version-tag{opacity:0.7}.webcam-float-wrapper:hover:not(.is-zoomed){transform:translateY(-5px);box-shadow:0 8px 16px rgba(0, 0, 0, 0.4)}}

@media (max-width: 767px){.app-version-tag{display:inline-block !important;margin-top:12px;padding:5px 15px;background:rgba(74, 108, 74, 0.08);border:1px solid var(--primary-olive);border-radius:25px;font-size:11px;color:var(--primary-olive);font-weight:600;text-transform:uppercase}}

@media (max-width: 400px){.weather-mini span{font-size:0.8rem}}

@media screen and (max-width: 992px){body{background-color:#f8faf4 !important}body .business-card{width:92% !important;max-width:650px !important;margin:0 auto !important;float:none !important;display:block !important;box-sizing:border-box !important}html, body{overflow-x:hidden !important;width:100% !important;position:relative !important}body .business-container, body .results-container{display:flex !important;flex-direction:column !important;align-items:center !important;width:100% !important;padding:20px 10px !important;gap:30px !important;overflow-x:hidden !important}}

@media all and (display-mode: standalone), (display-mode: fullscreen){ul#nav-list li#menu-install-item{display:none !important}}

@media screen and (max-width: 480px){.biz-card-mini{width:100% !important;max-width:100% !important;margin:0 0 8px 0 !important;padding:8px !important;box-sizing:border-box !important}.mini-preview{width:65px !important;height:65px !important;flex-shrink:0 !important}.mini-content{padding-left:6px !important;flex:1 !important;min-width:0 !important}.biz-name{font-size:15px !important;margin-bottom:2px !important}#business-list, .business-grid{padding:0 6px !important;width:100% !important;display:flex !important;flex-direction:column !important;align-items:center !important;box-sizing:border-box !important}}

@media screen and (min-width: 481px) and (max-width: 991px){.biz-card-mini{width:100% !important;max-width:100% !important;margin-bottom:15px !important;padding:12px !important}#business-list, .business-grid{padding:0 20px !important;display:flex !important;flex-direction:column !important;align-items:center !important;width:100% !important;box-sizing:border-box !important}}

@media (min-width: 480px){.install-toast{width:fit-content;padding:10px 20px;border-radius:50px}.install-toast .toast-text{flex:0 1 auto;margin:0 20px}}

@media (min-width: 1024px){.webcam-float-wrapper.is-zoomed{width:500px;height:281px;left:20px}}

@media (max-width: 768px){.nav-sos-dropdown{position:static !important;width:100% !important;background:rgba(0,0,0,0.03) !important;box-shadow:none !important;border:none !important;padding:0 !important;margin:0 !important;display:none}.nav-sos-dropdown a{display:block !important;position:static !important;padding:10px 20px !important;width:100% !important;text-align:left !important;white-space:nowrap !important}.nav-sos-dropdown .phone-no{display:inline !important;margin-left:5px !important;font-size:13px !important;color:#666 !important}.nav-sos-dropdown a i{position:static !important;margin-right:10px !important;width:auto !important;display:inline-block !important}}

@media (min-width: 769px){.nav-sos-dropdown{width:230px !important;display:none;position:absolute;right:-68px;left:auto;top:100%;background:white;box-shadow:0 8px 25px rgba(0,0,0,0.1);border-radius:8px;z-index:1000;border:1px solid #eee}.nav-emergency-item{position:relative}.nav-sos-dropdown .phone-no{display:block !important;font-size:11px !important;color:#888 !important;margin-top:2px}.nav-sos-dropdown a{display:block !important;flex-direction:column !important;align-items:flex-start !important;padding-left:45px !important;position:relative !important;padding:12px 15px 12px 45px !important;text-decoration:none;color:#333 !important;border-bottom:1px solid #f9f9f9;text-align:left !important}.nav-sos-dropdown a i{position:absolute !important;left:15px !important;top:15px !important;margin:0 !important;width:20px !important;text-align:center;color:#3498db}}

@media (min-width: 769px) and (max-width: 1100px){.nav-sos-dropdown{width:100% !important;min-width:180px;right:0 !important;left:0 !important;transform:none !important}.nav-sos-dropdown a{padding:10px 10px 10px 35px !important;font-size:12px !important}.nav-sos-dropdown .phone-no{font-size:10px !important}.nav-sos-dropdown a i{left:10px !important;top:12px !important;font-size:12px !important}}