*{max-width:100vw;margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;min-width:290px;color:#333}.scroll-wrapper{scroll-snap-type:y proximity;padding-top:max(20px, env(safe-area-inset-top));height:100dvh;overflow-y:auto}.container{max-width:800px;margin:0 auto;padding:20px;padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right));box-sizing:border-box;min-width:0}.block{scroll-snap-align:start}.snap-start{scroll-snap-align:start}.snap-end{scroll-snap-align:end}.snap-none{scroll-snap-align:none}.snap-both{scroll-snap-align:start}.snap-point{scroll-snap-align:start;height:1px;width:100%;pointer-events:none}.snap-point.bottom{scroll-snap-align:end}h1{font-size:24px;margin-bottom:20px;color:#2c3e50}.dialog-overlay{position:fixed;inset:0;background:rgb(0 0 0 / .5);display:none;justify-content:center;align-items:center;z-index:1000;color-scheme:light;-webkit-color-scheme:light}.dialog{background:#fff;color:#333333!important;border-radius:15px;padding:30px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;position:relative;box-shadow:0 20px 40px rgb(0 0 0 / .3);color-scheme:light;-webkit-color-scheme:light}.dialog h3{color:#2d3748!important;margin-bottom:20px;display:flex;align-items:center;gap:10px}.dialog p{color:#333333!important;margin:8px 0;line-height:1.6}.dialog li{color:#333333!important;margin:5px 0;line-height:1.5}.dialog strong{color:#2d3748!important}.dialog small{color:#666666!important}.dialog-close{position:absolute;top:15px;right:20px;background:none;border:none;font-size:24px;cursor:pointer;color:#666666!important;padding:5px}.dialog-close:hover{color:#333333!important}.privacy-section{background:#f8f9fa;color:#333333!important;border-radius:8px;border-left:4px solid #667eea;padding:15px;margin-bottom:20px}.privacy-section h4{color:#2d3748!important;margin-bottom:10px;display:flex;align-items:center;gap:8px}.privacy-section p{color:#333333!important;margin:8px 0;line-height:1.6}.privacy-section ul{margin:10px 0;padding-left:20px}.privacy-section li{color:#333333!important;margin:5px 0;line-height:1.5}.teilen-content{display:flex;align-items:center;gap:20px}.qr-section{flex-shrink:0}.qr-section img{border-radius:8px;box-shadow:0 4px 8px rgb(0 0 0 / .1)}.social-links{flex:1;display:flex;flex-direction:column;gap:8px}.social-links .stats-btn{width:100%;display:flex;align-items:center;justify-content:flex-start;text-align:left;padding:8px 12px}.social-links .stats-btn .btn-icon{display:inline-block;width:20px;text-align:center;margin-right:8px;flex-shrink:0}.social-links .stats-btn .btn-text{flex:1}.category-selector{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgb(0 0 0 / .1);margin-bottom:20px}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-top:15px;margin-bottom:15px}.category-item{position:relative;background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:15px;cursor:pointer;transition:all 0.3s ease;user-select:none}.category-item:hover{border-color:#3498db;transform:translateY(-2px);box-shadow:0 4px 12px rgb(52 152 219 / .15)}.category-item.selected{border-color:#3498db;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.category-item.priority{border-color:#f39c12;background:linear-gradient(135deg,#f39c12,#e67e22)}.category-item input[type="checkbox"]{display:none}.category-item .category-name{font-weight:600;font-size:1.1em;margin-bottom:5px}.category-item .category-desc{font-size:.9em;opacity:.8}.priority-star{position:absolute;top:10px;right:10px;color:#f39c12;font-size:1.2em;cursor:pointer;opacity:.3;transition:all 0.3s ease}.priority-star.active{opacity:1;transform:scale(1.2)}.location-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.location-header h3{margin:0;color:#fff}.location-activate-btn{background:#3498db;color:#fff;border:none;width:100%;text-align:center;padding:12px;margin-bottom:15px;border-radius:6px;cursor:pointer;font-size:.9em;font-weight:500;transition:background 0.3s ease}.location-activate-btn:hover{background:#2980b9}.search-controls{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:12px;margin-bottom:1rem}.search-button{flex:1 1 auto;padding:14px;min-width:10rem;background:linear-gradient(45deg,#27ae60,#2ecc71);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all 0.3s ease;position:relative;overflow:hidden}.search-button:hover{background:linear-gradient(45deg,#219a52,#27ae60)}.search-button:disabled{background:#ccc;color:#666;cursor:not-allowed;animation:none;transform:none}.auto-toggle{display:flex;flex:0 0 auto;align-items:center;gap:10px;background:#f0f0f0;border-radius:8px;padding:0 12px;height:48px;font-size:16px;font-weight:500;cursor:pointer;user-select:none}.auto-toggle input[type="checkbox"]{display:none}.toggle-switch{position:relative;width:36px;height:20px;background:#ccc;border-radius:10px;transition:background 0.3s}.toggle-switch::after{content:"";position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform 0.3s}input[type="checkbox"]:checked+.toggle-switch{background:#2196f3}input[type="checkbox"]:checked+.toggle-switch::after{transform:translateX(16px)}.manual-location-block,.contact-info-block{background:#fff;border-radius:12px;padding:10px 15px;box-shadow:0 2px 8px rgb(0 0 0 / .1);margin-bottom:20px}.manual-location-block>div:first-child{margin-bottom:8px;font-size:.85em}.manual-location-block{position:relative;overflow:visible}.current-location-block{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%);border-radius:12px;color:#fff;padding:20px;box-shadow:0 2px 8px rgb(0 0 0 / .1);margin-bottom:20px}.location-input-container{position:relative;display:flex;gap:12px;margin-bottom:0;padding:10px 0}#manualLocationSection{overflow:visible;position:relative;z-index:1}#manualLocationSection .section-content{overflow:visible}.location-input{flex:1;padding:12px 16px;border:2px solid #e9ecef;border-radius:8px;font-size:16px;transition:border-color 0.3s ease}.location-input:focus{outline:none;border-color:#3498db}.location-input:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.location-search-btn{padding:12px 20px;background:linear-gradient(45deg,#3498db,#2980b9);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background 0.2s ease;white-space:nowrap}.location-search-btn:hover:not(:disabled){background:linear-gradient(45deg,#2980b9,#1f4e79)}.location-search-btn:disabled{background:#ccc;cursor:not-allowed}.location-suggestions{background:#fff;border:1px solid #dee2e6;border-radius:8px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 16px rgb(0 0 0 / .15);position:absolute;top:100%;left:0;right:0;margin-top:2px;z-index:1000;opacity:0;transform:translateY(-10px);transition:all 0.3s ease}.location-suggestions[style*="display: block"]{opacity:1;transform:translateY(0)}.location-suggestions+*{margin-top:10px}.suggestion-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f1f3f4;transition:background 0.2s ease;overflow-wrap:break-word;line-height:1.4}.suggestion-item:hover{background:#f8f9fa}.suggestion-item:last-child{border-bottom:none}.current-location-display{background:#f8f9fa;border-radius:8px;padding:16px}.location-status{display:flex;align-items:center;gap:10px;margin-bottom:8px}.location-icon{font-size:18px}.location-text{font-weight:500;color:#2c3e50}.location-accuracy{font-size:.9em;color:#6c757d}.map-controls{display:flex;gap:12px;justify-content:center}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:20px}.contact-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f8f9fa;border-radius:8px;transition:all 0.3s ease}.contact-item:hover{background:#e9ecef;transform:translateY(-2px);box-shadow:0 4px 12px rgb(0 0 0 / .1)}.contact-icon{font-size:24px;line-height:1}.contact-content{flex:1}.contact-title{font-weight:600;color:#2c3e50;margin-bottom:4px}.contact-desc{font-size:.9em;color:#6c757d;margin-bottom:8px}.contact-link{color:#3498db;text-decoration:none;font-size:.9em;font-weight:500}.contact-link:hover{text-decoration:underline}.stats-btn{background:#3498db;color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.9em;font-weight:500;transition:background 0.3s ease;flex:1;min-width:0;text-align:center}.stats-btn:hover{background:#2980b9}.stats-display{background:#f0f0f0;border-radius:8px;padding:16px;margin-top:16px}.stats-display h4{margin:0 0 12px;color:#2c3e50}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.stat-item{text-align:center;background:#fff;padding:12px;border-radius:6px;box-shadow:0 1px 3px rgb(0 0 0 / .1)}.stat-value{font-size:24px;font-weight:600;color:#3498db;margin-bottom:4px}.stat-label{font-size:.8em;color:#6c757d;text-transform:uppercase;letter-spacing:.5px}.search-status{background:#fff;border-radius:8px;padding:12px 16px;margin-bottom:10px;display:block;box-shadow:0 2px 4px rgb(0 0 0 / .05)}.search-status.active{display:block}.status-phase{display:flex;align-items:center;gap:8px;font-size:14px;color:#666;margin-bottom:4px}.status-phase:last-child{margin-bottom:0}.status-phase.active{color:#2196f3;font-weight:500}.status-phase.done{color:#4caf50}.spinner{display:inline-block;width:14px;height:14px;border:2px solid #f3f3f3;border-top:2px solid #2196f3;border-radius:50%;animation:spin 0.8s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.poi-results{background:#fff;border-radius:12px;padding:10px;box-shadow:0 2px 8px rgb(0 0 0 / .1);display:none;margin-bottom:10px;counter-reset:poi-counter}.poi-results.active{display:block}.poi-list{display:flex;flex-direction:column;gap:8px}.poi-slot{min-height:60px;border-radius:8px;overflow:hidden;position:relative}.skeleton-loader{height:60px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:loading-shimmer 1.5s infinite}.skeleton-loader.dim{opacity:.5}@keyframes loading-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.poi-item{padding:12px 16px;border:1px solid #e0e0e0;border-radius:8px;display:flex;align-items:center;justify-content:space-between;background:#fff;opacity:0;transform:translateY(4px);animation:poi-reveal 0.3s ease-out forwards;counter-increment:poi-counter;position:relative;transition:all 0.3s ease;cursor:pointer;user-select:none;border-left:4px solid var(--color-default)}@keyframes poi-reveal{to{opacity:1;transform:translateY(0)}}.poi-info{flex:1}.poi-name{font-weight:500;color:#2c3e50;margin-bottom:2px}.poi-category{font-size:12px;color:#7f8c8d;position:relative;padding-left:20px}.poi-meta{text-align:right}.poi-distance{font-weight:500;color:#2196f3;font-size:14px}.poi-direction{font-size:12px;color:#95a5a6}.server-health{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom, 0px));right:calc(20px + env(safe-area-inset-right, 0px));background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 2px 8px rgb(0 0 0 / .1);font-size:12px;display:none}.server-health.debug-mode{display:block}.server-status{display:flex;align-items:center;gap:8px;margin-bottom:4px}.status-dot{width:8px;height:8px;border-radius:50%;background:#4caf50}.status-dot.warning{background:#ff9800}.status-dot.error{background:#f44336}.error-message{background:#fee;border:1px solid #fcc;color:#c00;padding:12px 16px;border-radius:8px;margin-bottom:16px;display:none}.error-message.active{display:block}.ai-description-container{background:#f8f9fa;border-radius:12px;padding:16px;margin-bottom:16px;border-left:4px solid #2196f3}.ai-description-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.ai-description-header h4{margin:0;color:#2c3e50;font-size:16px}.ai-persona-selector select{width:100%;padding:8px 12px;border:1px solid #ced4da;border-radius:20px;background-color:#fff;font-size:.9em;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center;background-size:16px}.ai-description-content{margin:12px 0;line-height:1.6;background:#fff;border-radius:10px;padding:15px;min-height:120px;box-shadow:inset 0 0 5px rgb(0 0 0 / .05)}.ai-description-text{color:#444;font-size:14px}.ai-loading{color:#666;font-style:italic;text-align:center;padding:20px}.ai-error{color:#d32f2f;text-align:center;padding:12px}.ai-description-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;font-size:12px}.ai-refresh-btn{background:#2196f3;color:#fff;border:none;border-radius:20px;padding:8px 15px;cursor:pointer;font-size:.85em;display:flex;align-items:center;gap:5px;white-space:nowrap}.ai-refresh-btn:hover{background:#1976d2}.ai-provider-info{color:#666;font-size:11px}.location-section{color:#333333!important;margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.location-section h4{color:#2d3748!important;margin-bottom:10px;display:flex;align-items:center;gap:8px}.location-section p{color:#333333!important;margin:8px 0;line-height:1.6}.location-section li{color:#333333!important}.permission-status{color:inherit!important;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-weight:500}.permission-granted{background:#d4edda!important;color:#155724!important;border:1px solid #c3e6cb}.permission-denied{background:#f8d7da!important;color:#721c24!important;border:1px solid #f5c6cb}.permission-prompt{background:#d1ecf1!important;color:#0c5460!important;border:1px solid #bee5eb}.instruction-steps{margin-top:12px}.instruction-steps strong{color:#495057!important;display:block;margin-top:12px}.instruction-steps ol{margin:8px 0 16px 20px;padding-left:10px}.instruction-steps li{color:#333333!important;margin:4px 0;line-height:1.5}#dialogButtons{display:flex;gap:12px;margin-top:20px}#dialogButtons .button{flex:1;padding:12px 20px;background:linear-gradient(45deg,#667eea,#764ba2);color:white!important;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform 0.2s}#dialogButtons .button:hover{transform:translateY(-2px)}#dialogButtons .button-secondary{background:#6c757d;color:white!important}.no-results-message{text-align:center;padding:40px 20px;color:#6c757d;background:#f9f9f9;border-radius:12px;margin:20px 0;box-shadow:0 2px 10px rgb(0 0 0 / .05);border-left:4px solid var(--color-default);position:relative}.no-results-message::before{content:'';position:absolute;left:-2px;top:20px;width:8px;height:8px;border-radius:50%;background:var(--color-default);border:2px solid #fff}.no-results-icon{font-size:48px;margin-bottom:16px;opacity:.5}.no-results-text{font-size:18px;font-weight:500;margin-bottom:8px;color:#495057}.no-results-subtext{font-size:14px;color:#6c757d}.no-results-popup{text-align:center;padding:10px}.no-results-popup strong{color:#dc3545}.cache-monitor{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:800px;max-height:80vh;background:#fff;border-radius:12px;box-shadow:0 10px 40px rgb(0 0 0 / .2);z-index:10000;display:flex;flex-direction:column}.cache-monitor-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.cache-monitor-header h4{margin:0;color:#2c3e50}.cache-monitor-close{background:none;border:none;font-size:24px;cursor:pointer;color:#666}.cache-monitor-tabs{display:flex;gap:10px;padding:10px 20px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.tab-btn{padding:8px 16px;background:#fff0;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all 0.3s}.tab-btn.active{background:#fff;box-shadow:0 2px 4px rgb(0 0 0 / .1)}.tab-content{display:none;padding:20px;overflow-y:auto;flex:1}.tab-content.active{display:block}.cache-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:20px}.cache-stat{text-align:center;padding:15px;background:#f8f9fa;border-radius:8px}.cache-stat .stat-value{font-size:24px;font-weight:700;color:#2196f3}.cache-stat .stat-label{font-size:12px;color:#666;margin-top:5px}.cache-section{margin-bottom:20px}.cache-section h5{margin:0 0 10px;color:#495057}.cache-dist-item,.cache-activity-item{display:flex;justify-content:space-between;padding:8px 12px;background:#f8f9fa;border-radius:4px;margin-bottom:4px}.cache-entry{border:1px solid #e0e0e0;border-radius:6px;padding:10px;margin-bottom:8px;position:relative}.cache-entry-header{display:flex;justify-content:space-between;margin-bottom:5px}.cache-entry-key{font-family:monospace;font-size:12px;color:#666}.cache-entry-size{font-weight:700;color:#2196f3}.cache-entry-delete{position:absolute;top:10px;right:10px;background:none;border:none;cursor:pointer;font-size:16px}.cache-monitor-footer{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-top:1px solid #e0e0e0;background:#f8f9fa}.cache-monitor-toggle{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom, 0px));right:calc(20px + env(safe-area-inset-right, 0px));width:50px;height:50px;border-radius:50%;background:#2196f3;color:#fff;border:none;font-size:20px;cursor:pointer;box-shadow:0 2px 8px rgb(0 0 0 / .2);z-index:9999}.cache-controls{display:flex;gap:10px;margin-bottom:15px}.cache-controls button{padding:8px 16px;background:#2196f3;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.cache-controls button:hover{background:#1976d2}@media (max-width:768px){.header h1{font-size:2em}.container{padding:15px}.category-grid{grid-template-columns:repeat(2,1fr)}.location-input-container{flex-direction:column}.location-search-btn{width:100%}.contact-grid{grid-template-columns:1fr}.map-controls{flex-wrap:wrap}.stats-grid{grid-template-columns:repeat(2,1fr)}.teilen-content{flex-direction:column;align-items:center;gap:15px}.social-links{width:100%}.cache-stats-grid{grid-template-columns:repeat(2,1fr)}.cache-monitor{width:95%;max-height:90vh}.dialog{background:white!important;color:#333333!important}.dialog *{color:inherit}.dialog h3,.dialog h4,.dialog p:not(.permission-granted,.permission-denied,.permission-prompt),.dialog li{color:#333333!important}.location-suggestions{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.suggestion-item{padding:14px 16px;min-height:44px}}@supports (-webkit-appearance:none){.dialog{-webkit-text-fill-color:#333;-webkit-color-scheme:light}.dialog h3,.dialog h4,.dialog p,.dialog li{-webkit-text-fill-color:inherit}}.dialog-overlay *{color-scheme:light;-webkit-color-scheme:light}.header.compact{padding:10px 20px;flex-direction:row;align-items:center;cursor:pointer}.header.compact:hover{background:rgb(255 255 255 / .15)}.header.compact::before{content:'';position:absolute;inset:0;background:rgb(255 255 255 / .05);border-radius:20px;opacity:0;transition:opacity 0.3s ease;pointer-events:none}.header.compact:hover::before{opacity:1}.header.compact .header-icon img{width:32px;height:32px}.header.compact .header-text h1{font-size:1.2em;margin-bottom:0}.header.compact .header-text p{display:none}.header.compact .header-toggle-hint{top:50%;right:12px;transform:translateY(-50%);font-size:14px}.collapsible-section,.section-header{background:#fff;border-radius:12px;margin-bottom:10px;overflow:hidden}#categoriesSection:not(.active)+#statusUndErgebnis+#mapSection{margin-top:-20px}.collapsible-section h3{padding:12px 15px;margin:0;cursor:pointer;display:flex;align-items:center;color:#495057;background:#f8f9fa;border-bottom:1px solid #e9ecef}.collapsible-section h3::after{content:'−';margin-left:auto;font-size:1.5em}.collapsible-section.collapsed h3::after{content:'+'}.collapsible-section.collapsed .section-content{display:none}@media (max-width:480px){.category-grid{grid-template-columns:1fr}.search-controls{flex-direction:column;align-items:stretch}.auto-toggle{justify-content:center;width:100%}.stats-grid{grid-template-columns:1fr}.map-icon{font-size:48px}.map-text{font-size:20px}.map-subtext{font-size:14px}.location-suggestions{max-height:50vh}}.comfort-message{background-color:#f8f9fa;border-radius:12px;padding:15px;margin-top:20px;border-left:4px solid #4a90e2}.comfort-icon{font-size:24px;text-align:center;margin-bottom:10px}.comfort-text{text-align:center;font-style:italic;color:#6c757d;margin-bottom:15px}.comfort-actions{display:flex;gap:10px;justify-content:center}.comfort-actions button{background:#4a90e2;color:#fff;border:none;padding:8px 16px;border-radius:20px;cursor:pointer;font-size:14px;transition:background 0.3s}.comfort-actions button:hover{background:#3a7bc8}.suggestions{text-align:left;max-width:300px;margin:0 auto 20px;padding-left:20px}.suggestions li{margin-bottom:8px}.motivation{font-style:italic;margin:20px 0;color:#6c757d;border-top:1px dashed #dee2e6;padding-top:15px}.actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.action-button{background:#4a90e2;color:#fff;border:none;padding:10px 20px;border-radius:30px;cursor:pointer;font-size:14px;transition:background 0.3s}.action-button:hover{background:#3a7bc8;transform:translateY(-2px)}.section .section-content{transition:max-height 0.3s ease;overflow:hidden}.section.collapsed .section-content{max-height:0;display:none}.section.collapsed .toggle-icon{transform:rotate(-90deg)}.wakelock-indicator{position:absolute;top:-4px;right:-4px;width:12px;height:12px;border-radius:50%;background:#4CAF50;border:2px solid rgb(255 255 255 / .8);box-shadow:0 0 4px rgb(0 0 0 / .3);display:none;z-index:10}.header-icon{position:relative}.header.compact .wakelock-indicator{top:-2px;right:-2px;width:8px;height:8px}.ai-description-block{background:#f8f9fa;border-radius:12px;padding:15px;margin-bottom:20px;box-shadow:0 2px 10px rgb(0 0 0 / .05)}.ai-controls{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}.ai-persona-selector{flex-grow:1;min-width:150px}.ai-placeholder{text-align:center;padding:20px;color:#6c757d}.ai-placeholder .ai-icon{font-size:2.5em;margin-bottom:10px;opacity:.5}.ai-footer{margin-top:10px;text-align:right;font-size:.8em;color:#6c757d}.poi-item.active{background:linear-gradient(135deg,#007bff20,#28a74520);border-left:4px solid #007bff;box-shadow:0 2px 8px rgb(0 123 255 / .2);transform:translateY(-1px)}.poi-item.active .poi-name{color:#007bff;font-weight:600}.poi-item.active .poi-distance{color:#28a745}@media (max-width:480px){.ai-controls{flex-direction:column}.ai-refresh-btn{width:100%;justify-content:center}}.header{transition:all 0.5s ease-in-out;position:relative;user-select:none}.header:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgb(0 0 0 / .15)}.header-toggle-hint{position:absolute;top:8px;right:8px;font-size:12px;opacity:.6;transition:opacity 0.3s ease;pointer-events:none}.header:hover .header-toggle-hint{opacity:1}.header .header-icon,.header .header-text{transition:all 0.5s ease-in-out}.header .header-text h1{transition:font-size 0.5s ease-in-out,margin 0.5s ease-in-out}.header .header-text p{transition:opacity 0.3s ease-in-out}.header:focus{outline:2px solid rgb(255 255 255 / .5);outline-offset:4px}@media (max-width:768px){.header h1{font-size:2em}.header.compact .header-text h1{font-size:1.1em}.header-toggle-hint{font-size:10px}.header.compact .header-toggle-hint{font-size:12px}}@media (max-width:480px){.header h1{font-size:1.8em}.header.compact{padding:8px 15px}.header.compact .header-icon img{width:28px;height:28px}.header.compact .header-text h1{font-size:1em}}.header-temp-message{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;backdrop-filter:blur(10px)}@media (prefers-reduced-motion:reduce){.header,.header *,.header::before{transition:none!important}}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px}.results-header h3{margin:0;color:#2c3e50}.speed-indicator{display:flex;align-items:center;gap:6px;background:#f8f9fa;padding:6px 12px;border-radius:20px;font-size:12px;border:1px solid #e9ecef;transition:all 0.3s ease}.speed-indicator.walking{background:linear-gradient(135deg,#4CAF50,#45a049);color:#fff;border-color:#4CAF50}.speed-indicator.cycling{background:linear-gradient(135deg,#FF9800,#F57C00);color:#fff;border-color:#FF9800}.speed-indicator.driving{background:linear-gradient(135deg,#2196F3,#1976D2);color:#fff;border-color:#2196F3}.speed-icon{font-size:14px;line-height:1}.speed-text{font-weight:500}.speed-value{font-weight:600;font-size:11px;opacity:.9}.search-type{font-size:10px;opacity:.8;background:rgb(255 255 255 / .2);padding:2px 6px;border-radius:10px;margin-left:4px}.speed-indicator.walking .search-type{background:rgb(255 255 255 / .25)}.speed-indicator.cycling .search-type{background:rgb(255 255 255 / .25)}.speed-indicator.driving .search-type{background:rgb(255 255 255 / .25)}@keyframes speed-update{0%{transform:scale(.95)}50%{transform:scale(1.05)}100%{transform:scale(1)}}:root{--color-sehenswuerdigkeiten:#e74c3c;--color-sehenswuerdigkeiten-light:#f8d7da;--color-sehenswuerdigkeiten-dark:#c0392b;--color-essen-trinken:#f39c12;--color-essen-trinken-light:#fef3e2;--color-essen-trinken-dark:#d68910;--color-natur-parks:#27ae60;--color-natur-parks-light:#d5f4e6;--color-natur-parks-dark:#229954;--color-sport-freizeit:#3498db;--color-sport-freizeit-light:#d6eaf8;--color-sport-freizeit-dark:#2980b9;--color-familie-kinder:#9b59b6;--color-familie-kinder-light:#ebdef0;--color-familie-kinder-dark:#8e44ad;--color-einkaufen:#1abc9c;--color-einkaufen-light:#d5f7f0;--color-einkaufen-dark:#17a2b8;--color-oeffentliche-einrichtungen:#00bcd4;--color-oeffentliche-einrichtungen-light:#d1f2f7;--color-oeffentliche-einrichtungen-dark:#0097a7;--color-default:#95a5a6;--color-default-light:#ecf0f1;--color-default-dark:#7f8c8d}.category-item[data-category="sehenswuerdigkeiten"]{border-left:4px solid var(--color-sehenswuerdigkeiten)}.category-item[data-category="essen_trinken"]{border-left:4px solid var(--color-essen-trinken)}.category-item[data-category="natur_parks"]{border-left:4px solid var(--color-natur-parks)}.category-item[data-category="sport_freizeit"]{border-left:4px solid var(--color-sport-freizeit)}.category-item[data-category="familie_kinder"]{border-left:4px solid var(--color-familie-kinder)}.category-item[data-category="einkaufen"]{border-left:4px solid var(--color-einkaufen)}.category-item[data-category="oeffentliche_einrichtungen"]{border-left:4px solid var(--color-oeffentliche-einrichtungen)}.category-item.selected[data-category="sehenswuerdigkeiten"]{border-color:var(--color-sehenswuerdigkeiten);background:linear-gradient(135deg,var(--color-sehenswuerdigkeiten),var(--color-sehenswuerdigkeiten-dark));color:#fff}.category-item.selected[data-category="essen_trinken"]{border-color:var(--color-essen-trinken);background:linear-gradient(135deg,var(--color-essen-trinken),var(--color-essen-trinken-dark));color:#fff}.category-item.selected[data-category="natur_parks"]{border-color:var(--color-natur-parks);background:linear-gradient(135deg,var(--color-natur-parks),var(--color-natur-parks-dark));color:#fff}.category-item.selected[data-category="sport_freizeit"]{border-color:var(--color-sport-freizeit);background:linear-gradient(135deg,var(--color-sport-freizeit),var(--color-sport-freizeit-dark));color:#fff}.category-item.selected[data-category="familie_kinder"]{border-color:var(--color-familie-kinder);background:linear-gradient(135deg,var(--color-familie-kinder),var(--color-familie-kinder-dark));color:#fff}.category-item.selected[data-category="einkaufen"]{border-color:var(--color-einkaufen);background:linear-gradient(135deg,var(--color-einkaufen),var(--color-einkaufen-dark));color:#fff}.category-item.selected[data-category="oeffentliche_einrichtungen"]{border-color:var(--color-oeffentliche-einrichtungen);background:linear-gradient(135deg,var(--color-oeffentliche-einrichtungen),var(--color-oeffentliche-einrichtungen-dark));color:#fff}.poi-item[data-category="sehenswuerdigkeiten"]{border-left-color:var(--color-sehenswuerdigkeiten)}.poi-item[data-category="essen_trinken"]{border-left-color:var(--color-essen-trinken)}.poi-item[data-category="natur_parks"]{border-left-color:var(--color-natur-parks)}.poi-item[data-category="sport_freizeit"]{border-left-color:var(--color-sport-freizeit)}.poi-item[data-category="familie_kinder"]{border-left-color:var(--color-familie-kinder)}.poi-item[data-category="einkaufen"]{border-left-color:var(--color-einkaufen)}.poi-item[data-category="oeffentliche_einrichtungen"]{border-left-color:var(--color-oeffentliche-einrichtungen)}.poi-item[data-category="sehenswuerdigkeiten"]::before{background:var(--color-sehenswuerdigkeiten)}.poi-item[data-category="essen_trinken"]::before{background:var(--color-essen-trinken)}.poi-item[data-category="natur_parks"]::before{background:var(--color-natur-parks)}.poi-item[data-category="sport_freizeit"]::before{background:var(--color-sport-freizeit)}.poi-item[data-category="familie_kinder"]::before{background:var(--color-familie-kinder)}.poi-item[data-category="einkaufen"]::before{background:var(--color-einkaufen)}.poi-item[data-category="oeffentliche_einrichtungen"]::before{background:var(--color-oeffentliche-einrichtungen)}.poi-item[data-category="sehenswuerdigkeiten"]:hover{background:var(--color-sehenswuerdigkeiten-light)}.poi-item[data-category="essen_trinken"]:hover{background:var(--color-essen-trinken-light)}.poi-item[data-category="natur_parks"]:hover{background:var(--color-natur-parks-light)}.poi-item[data-category="sport_freizeit"]:hover{background:var(--color-sport-freizeit-light)}.poi-item[data-category="familie_kinder"]:hover{background:var(--color-familie-kinder-light)}.poi-item[data-category="einkaufen"]:hover{background:var(--color-einkaufen-light)}.poi-item[data-category="oeffentliche_einrichtungen"]:hover{background:var(--color-oeffentliche-einrichtungen-light)}.poi-item.active[data-category="sehenswuerdigkeiten"]{background:linear-gradient(135deg,var(--color-sehenswuerdigkeiten-light),#ffffff);border-left-color:var(--color-sehenswuerdigkeiten);box-shadow:0 2px 8px rgb(231 76 60 / .3)}.poi-item.active[data-category="essen_trinken"]{background:linear-gradient(135deg,var(--color-essen-trinken-light),#ffffff);border-left-color:var(--color-essen-trinken);box-shadow:0 2px 8px rgb(243 156 18 / .3)}.poi-item.active[data-category="natur_parks"]{background:linear-gradient(135deg,var(--color-natur-parks-light),#ffffff);border-left-color:var(--color-natur-parks);box-shadow:0 2px 8px rgb(39 174 96 / .3)}.poi-item.active[data-category="sport_freizeit"]{background:linear-gradient(135deg,var(--color-sport-freizeit-light),#ffffff);border-left-color:var(--color-sport-freizeit);box-shadow:0 2px 8px rgb(52 152 219 / .3)}.poi-item.active[data-category="familie_kinder"]{background:linear-gradient(135deg,var(--color-familie-kinder-light),#ffffff);border-left-color:var(--color-familie-kinder);box-shadow:0 2px 8px rgb(155 89 182 / .3)}.poi-item.active[data-category="einkaufen"]{background:linear-gradient(135deg,var(--color-einkaufen-light),#ffffff);border-left-color:var(--color-einkaufen);box-shadow:0 2px 8px rgb(26 188 156 / .3)}.poi-item.active[data-category="oeffentliche_einrichtungen"]{background:linear-gradient(135deg,var(--color-oeffentliche-einrichtungen-light),#ffffff);border-left-color:var(--color-oeffentliche-einrichtungen);box-shadow:0 2px 8px rgb(0 188 212 / .3)}.poi-item .poi-category::before{content:"#" counter(poi-counter) " ";position:absolute;left:0;top:50%;color:#333;transform:translateY(calc(-50%));width:20px;height:12px;border-radius:2px;font-weight:700;font-size:.8em;line-height:12px;padding-bottom:1px;text-align:center}.category-details{font-size:.9em;opacity:.8;font-style:italic;margin-left:5px}.poi-category:hover .category-details{opacity:1}.poi-item[data-category="sehenswuerdigkeiten"] .poi-category::before{background:var(--color-sehenswuerdigkeiten)}.poi-item[data-category="essen_trinken"] .poi-category::before{background:var(--color-essen-trinken)}.poi-item[data-category="natur_parks"] .poi-category::before{background:var(--color-natur-parks)}.poi-item[data-category="sport_freizeit"] .poi-category::before{background:var(--color-sport-freizeit)}.poi-item[data-category="familie_kinder"] .poi-category::before{background:var(--color-familie-kinder)}.poi-item[data-category="einkaufen"] .poi-category::before{background:var(--color-einkaufen)}.poi-item[data-category="oeffentliche_einrichtungen"] .poi-category::before{background:var(--color-oeffentliche-einrichtungen)}@media (prefers-reduced-motion:reduce){.poi-item,.category-item{transition:none!important}}@media (prefers-contrast:more){:root{--color-sehenswuerdigkeiten:#cc1100;--color-essen-trinken:#cc7700;--color-natur-parks:#006600;--color-sport-freizeit:#0066cc;--color-familie-kinder:#6600cc;--color-einkaufen:#006666}}.search-button.auto-active{background:linear-gradient(135deg,#4CAF50,#45a049);color:#fff}.search-button.manual-mode{background:linear-gradient(135deg,#2196F3,#1976D2);color:#fff}.search-button.pending-search{background:linear-gradient(45deg,#FF9800,#F57C00);color:#fff;animation:pendingPulse 2s ease-in-out infinite}@keyframes pendingPulse{0%,100%{transform:scale(1);box-shadow:0 2px 4px rgb(0 0 0 / .1)}50%{transform:scale(1.02);box-shadow:0 4px 12px rgb(255 152 0 / .4)}}.search-button.pending-search::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .2),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{left:-100%}100%{left:100%}}.brief-message{pointer-events:none;user-select:none}.brief-message-success{background:linear-gradient(135deg,#4CAF50,#45a049)!important}.brief-message-warning{background:linear-gradient(135deg,#FF9800,#F57C00)!important}.brief-message-error{background:linear-gradient(135deg,#F44336,#D32F2F)!important}.poi-item:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgb(0 0 0 / .1)}.refresh-cache-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#fff0;border:1px solid #dee2e6;border-radius:50%;font-size:.8em;color:#6c757d;cursor:pointer;transition:all 0.2s ease;opacity:.7;flex-shrink:0}.refresh-cache-btn:hover{background:#f8f9fa;opacity:1;transform:scale(1.1)}.refresh-cache-btn:active{transform:scale(.95);background:#e9ecef}.refresh-cache-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.refresh-cache-btn.loading{animation:spin 1s linear infinite}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}.header-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-export-container{margin-top:15px}.export-toggle-btn{width:100%;padding:12px 16px;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background 0.3s ease,transform 0.2s ease;text-align:center}.export-toggle-btn:hover{background:linear-gradient(45deg,#5a67d8,#6b46c1);transform:translateY(-2px)}.search-export-section{margin-top:12px;background:#f8f9fa;border-radius:10px;padding:12px;box-shadow:0 2px 6px rgb(0 0 0 / .08)}.export-info{text-align:center;margin-bottom:10px}.export-message{color:#6c757d;font-size:.9em;padding:8px}.export-buttons{display:flex!important;justify-content:space-between;gap:10px;margin-top:6px}.export-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:#fff;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:.9em;font-weight:500;transition:all 0.2s ease;text-align:center;min-width:0}@media (max-width:480px){.export-buttons{flex-direction:column}.export-action-btn{width:100%;flex:none}}.export-action-btn:hover{border-color:#3498db;box-shadow:0 3px 8px rgb(52 152 219 / .15);transform:translateY(-2px)}.export-action-btn.primary{background:linear-gradient(45deg,#3498db,#2980b9);color:#fff;border:none}.export-action-btn.primary:hover{background:linear-gradient(45deg,#2980b9,#1f4e79)}.export-help{margin-top:10px;font-size:.8em;color:#6c757d;text-align:center}.export-inline-btn{background:none;border:none;font-size:1.1em;margin-left:auto;cursor:pointer;color:#6c757d;padding:2px 6px;border-radius:6px;transition:background 0.2s,color 0.2s}.export-inline-btn:hover{color:#3498db;background:rgb(52 152 219 / .1)}.search-status.final .status-phase{border-left:3px solid #4CAF50;background:linear-gradient(90deg,rgb(76 175 80 / .05) 0%,transparent 100%)}.status-phase.final.success{color:#2E7D32;font-weight:500}.status-phase.final.no-results{color:#F57C00;border-left-color:#FF9800;background:linear-gradient(90deg,rgb(255 152 0 / .05) 0%,transparent 100%)}.status-phase.final.details{color:#666;font-size:.9em;font-style:italic}.status-phase.final.suggestion{color:#1976D2;font-style:italic}.stats-buttons-container{display:flex;gap:10px;margin-top:10px}.wiki-info-icon{position:absolute;top:8px;right:8px;background:#fff;border:1px solid #007bff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 1px 3px rgb(0 0 0 / .2);z-index:5}.wiki-info-icon.clickable{cursor:pointer;transition:all 0.2s ease}.wiki-info-icon.clickable:hover{background:#007bff;transform:scale(1.15);box-shadow:0 2px 6px rgb(0 123 255 / .4)}.wiki-info-icon.clickable:active{transform:scale(1.05);box-shadow:0 1px 3px rgb(0 123 255 / .6)}.wikipedia-link{margin-top:15px;opacity:0;transform:translateY(10px);transition:all 0.3s ease}.wiki-link-container{background:linear-gradient(135deg,#f0f8ff,#e3f2fd);border:1px solid #2196f3;border-radius:8px;padding:12px 16px;cursor:pointer;transition:all 0.3s ease;display:flex;align-items:center;gap:12px}.wiki-link-container:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgb(33 150 243 / .2)}.wiki-link-icon{font-size:1.5em;flex-shrink:0}.wiki-link-text{flex:1}.wiki-link-title{font-weight:500;color:#1565c0;font-size:.9em}.wiki-link-subtitle{font-size:.8em;color:#42a5f5;opacity:.8}.wiki-link-arrow{font-size:1.2em;color:#1976d2;transition:transform 0.3s ease}.wiki-link-container:hover .wiki-link-arrow{transform:translateX(3px)}.map-wrapper{border-radius:8px;overflow:hidden;box-shadow:0 2px 8px rgb(0 0 0 / .1);margin-bottom:15px;aspect-ratio:1/1;transition:all 0.3s ease-in-out}.map-placeholder{height:400px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;position:relative}.map-placeholder-content{text-align:center;color:#fff}.map-icon{font-size:64px;margin-bottom:16px;opacity:.9}.map-text{font-size:24px;font-weight:600;margin-bottom:8px}.map-subtext{font-size:16px;opacity:.8;max-width:300px}#actualMap{width:100%;height:400px;border-radius:8px}.map-controls{display:flex;gap:8px;justify-content:center;padding:8px;background:rgb(255 255 255 / .95);border-radius:8px;box-shadow:0 2px 8px rgb(0 0 0 / .1);backdrop-filter:blur(10px);overflow:visible;position:relative;z-index:1000;transition:all 0.3s ease}.map-control-btn{padding:10px 12px;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;transition:all 0.2s ease;font-size:16px;min-width:44px;display:flex;align-items:center;justify-content:center}.map-control-btn:hover{background:#e9ecef;transform:translateY(-1px)}.primary-btn{background:#007bff;color:#fff;border-color:#007bff}.primary-btn:hover{background:#0056b3}.map-dropdown{position:relative;display:inline-block;z-index:10001!important}.dropdown-btn{display:flex;align-items:center;gap:4px;padding:10px 14px}.dropdown-arrow{font-size:10px;transition:transform 0.2s;transform:rotate(180deg)}.map-dropdown.open .dropdown-arrow{transform:rotate(0deg)}.dropdown-menu{display:none;position:absolute;bottom:100%;left:0;background:#fff;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 4px 16px rgb(0 0 0 / .15);z-index:99999!important;min-width:160px;margin-bottom:4px;overflow:hidden}.dropdown-item{width:100%;padding:10px 16px;background:#fff;border:none;text-align:left;cursor:pointer;font-size:14px;border-bottom:1px solid #f1f3f4;transition:background 0.2s;display:flex;align-items:center;gap:8px}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:#f8f9fa}.user-location-marker{position:relative;width:30px;height:30px}.user-location-marker .center{position:absolute;width:14px;height:14px;background:#2196f3;border:3px solid #fff;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 2px 4px rgb(0 0 0 / .3);z-index:2;transition:all 0.3s ease}.user-location-marker .pulse{position:absolute;width:30px;height:30px;background:rgb(33 150 243 / .3);border-radius:50%;animation:pulse 2s ease-out infinite;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pulse{0%{transform:scale(0);opacity:1}100%{transform:scale(2);opacity:0}}.poi-marker{width:32px;height:32px;background:#fff;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 2px 5px rgb(0 0 0 / .3);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform 0.2s}.poi-marker:hover{transform:rotate(-45deg) scale(1.1)}.poi-marker .poi-icon{transform:rotate(45deg);font-size:18px}.poi-marker-numbered{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;box-shadow:0 2px 5px rgb(0 0 0 / .3);border:2px solid #fff;cursor:pointer;transition:transform 0.2s}.poi-marker-numbered:hover{transform:scale(1.1)}:root{--color-sehenswuerdigkeiten:#e74c3c;--color-essen-trinken:#f39c12;--color-natur-parks:#27ae60;--color-sport-freizeit:#3498db;--color-familie-kinder:#e91e63;--color-einkaufen:#1abc9c}.leaflet-marker-icon.routing-inactive{opacity:.3;transition:opacity 0.3s ease,transform 0.3s ease,filter 0.3s ease;pointer-events:auto;cursor:pointer}.leaflet-marker-icon.routing-inactive:hover{opacity:.5}.leaflet-marker-icon.routing-inactive:hover .poi-marker-numbered{transform:scale(1.05)}.leaflet-marker-icon.routing-active-destination{opacity:1;transition:all 0.3s ease;z-index:1000!important}.leaflet-marker-icon.routing-active-destination .poi-marker-numbered{transform:scale(1.15);animation:routing-destination-glow 2s ease-in-out infinite}@keyframes routing-destination-glow{0%,100%{box-shadow:0 0 15px rgb(255 152 0 / .6),0 0 30px rgb(255 152 0 / .4),0 2px 8px rgb(0 0 0 / .3);filter:brightness(1.1)}50%{box-shadow:0 0 25px rgb(255 152 0 / .8),0 0 45px rgb(255 152 0 / .6),0 2px 8px rgb(0 0 0 / .3);filter:brightness(1.2)}}.poi-marker.sehenswuerdigkeiten{background:var(--color-sehenswuerdigkeiten)}.poi-marker.essen_trinken{background:var(--color-essen-trinken)}.poi-marker.natur_parks{background:var(--color-natur-parks)}.poi-marker.sport_freizeit{background:var(--color-sport-freizeit)}.poi-marker.familie_kinder{background:var(--color-familie-kinder)}.poi-marker.einkaufen{background:var(--color-einkaufen)}.destination-marker{position:relative;text-align:center}.marker-pin{width:30px;height:30px;background:#ff5252;border-radius:50% 50% 50% 0;transform:rotate(-45deg);margin:0 auto;box-shadow:0 2px 4px rgb(0 0 0 / .3)}.marker-label{position:absolute;top:-10px;left:50%;transform:translateX(-50%);white-space:nowrap;background:#fff;padding:3px 8px;border-radius:12px;font-weight:700;font-size:12px;box-shadow:0 1px 3px rgb(0 0 0 / .2)}.map-interaction-indicator{position:absolute;top:calc(10px + env(safe-area-inset-top, 0px));right:calc(10px + env(safe-area-inset-right, 0px));background:rgb(255 255 255 / .95);padding:8px 12px;border-radius:8px;border:1px solid #ddd;font-size:11px;z-index:1000;transition:all 0.3s ease;pointer-events:none;box-shadow:0 2px 8px rgb(0 0 0 / .1);max-width:180px}.map-interaction-indicator.enabled{background:rgb(76 175 80 / .95);color:#fff;border-color:#4CAF50}.map-interaction-indicator.routing{background:rgb(255 152 0 / .95);color:#fff;border-color:#FF9800}.indicator-content{display:flex;align-items:center;gap:6px;line-height:1.2}.indicator-text{font-weight:500}.fullscreen .map-wrapper{position:fixed;inset:0;z-index:9999;border-radius:0;height:100vh;min-height:-webkit-fill-available;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.fullscreen #actualMap{height:calc(100vh - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;min-height:-webkit-fill-available;border-radius:0;width:100vw;max-height:none;touch-action:pan-x pan-y}.fullscreen .map-controls{position:fixed;bottom:env(safe-area-inset-bottom,20px);left:50%;transform:translateX(-50%);z-index:10000;background:rgb(255 255 255 / .95);backdrop-filter:blur(10px);border-radius:12px;padding:8px 12px;box-shadow:0 4px 20px rgb(0 0 0 / .25);border:1px solid rgb(255 255 255 / .3)}@media (max-width:768px){.map-controls{gap:6px;padding:6px}.map-control-btn{padding:8px 10px;font-size:14px;min-width:40px}.dropdown-btn{padding:8px 12px}.dropdown-menu{min-width:140px;font-size:13px}.dropdown-item{padding:8px 12px}.map-interaction-indicator{font-size:10px;padding:6px 10px;max-width:160px}.map-icon{font-size:48px}.map-text{font-size:20px}.map-subtext{font-size:14px}}@media (max-width:480px){.map-controls{gap:4px;padding:4px}.map-control-btn{padding:6px 8px;font-size:13px;min-width:36px}.dropdown-btn{padding:6px 10px}.dropdown-menu{left:-10px;min-width:120px}}.map-control-btn:focus{outline:2px solid #007bff;outline-offset:2px}.dropdown-item:focus{background:#e9ecef;outline:none}@media (prefers-reduced-motion:reduce){.poi-marker,.poi-marker-numbered,.map-control-btn{transition:none!important}.user-location-marker .pulse{animation:none!important}.leaflet-marker-icon.routing-active-destination .poi-marker-numbered{animation:none!important}}#toggleInteractionBtn{position:relative;transition:all 0.3s ease;font-weight:600;border:2px solid #fff0}#toggleInteractionBtn.inactive{background:#6c757d;color:#fff;border-color:#6c757d;box-shadow:0 2px 4px rgb(108 117 125 / .3)}#toggleInteractionBtn.inactive:hover{background:#5a6268;border-color:#5a6268;transform:translateY(-1px);box-shadow:0 4px 8px rgb(108 117 125 / .4)}#toggleInteractionBtn.active{background:#28a745;color:#fff;border-color:#28a745;box-shadow:0 2px 4px rgb(40 167 69 / .3);animation:subtle-glow 2s ease-in-out infinite alternate}#toggleInteractionBtn.active:hover{background:#218838;border-color:#218838;transform:translateY(-1px);box-shadow:0 4px 8px rgb(40 167 69 / .4)}#toggleInteractionBtn.routing{background:linear-gradient(45deg,#ff6b35,#ff8c42);color:#fff;border-color:#ff6b35;box-shadow:0 2px 6px rgb(255 107 53 / .4);animation:routing-pulse 1.5s ease-in-out infinite}#toggleInteractionBtn.routing:hover{background:linear-gradient(45deg,#e55a2b,#e67d37);border-color:#e55a2b}@keyframes subtle-glow{0%{box-shadow:0 2px 4px rgb(40 167 69 / .3)}100%{box-shadow:0 2px 8px rgb(40 167 69 / .5),0 0 12px rgb(40 167 69 / .2)}}@keyframes routing-pulse{0%,100%{transform:scale(1);box-shadow:0 2px 6px rgb(255 107 53 / .4)}50%{transform:scale(1.05);box-shadow:0 4px 12px rgb(255 107 53 / .6),0 0 16px rgb(255 107 53 / .3)}}#toggleInteractionBtn::after{content:'';position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;border:2px solid #fff;transition:all 0.3s ease}#toggleInteractionBtn.inactive::after{background:#dc3545}#toggleInteractionBtn.active::after{background:#28a745}#toggleInteractionBtn.routing::after{background:#ff6b35;animation:status-blink 1s ease-in-out infinite alternate}@keyframes status-blink{0%{opacity:1}100%{opacity:.6}}@media (max-width:768px){#toggleInteractionBtn::after{width:6px;height:6px;top:-2px;right:-2px}}@media (prefers-reduced-motion:reduce){#toggleInteractionBtn{animation:none!important}#toggleInteractionBtn::after{animation:none!important}@keyframes subtle-glow{0%,100%{}}@keyframes routing-pulse{0%,100%{}}@keyframes status-blink{0%,100%{}}}@media (prefers-contrast:more){#toggleInteractionBtn.inactive{background:#000;border:3px solid #666;color:#fff}#toggleInteractionBtn.active{background:#000;border:3px solid lime;color:#fff}#toggleInteractionBtn.routing{background:#000;border:3px solid #f60;color:#fff}}html{height:-webkit-fill-available}body.fullscreen-active{height:-webkit-fill-available;overflow:hidden}@media (max-width:768px){.fullscreen .map-controls{bottom:calc(env(safe-area-inset-bottom, 10px) + 10px);padding:6px 10px;gap:6px}.fullscreen .map-control-btn{padding:8px 10px;font-size:14px;min-width:40px}.fullscreen .map-control-btn[data-fullscreen="true"]{background:#dc3545;color:#fff;border-color:#dc3545}}@media (max-width:768px) and (orientation:landscape){.fullscreen .map-controls{bottom:calc(env(safe-area-inset-bottom, 5px) + 5px);padding:4px 8px}.fullscreen .map-control-btn{padding:6px 8px;font-size:12px;min-width:36px}}.js-viewport-fix .fullscreen .map-wrapper,.js-viewport-fix .fullscreen #actualMap{height:var(--vh-mobile,100vh)}@supports (height:100dvh){.fullscreen .map-wrapper,.fullscreen #actualMap{height:100dvh!important;min-height:unset}}@supports (-webkit-touch-callout:none){.fullscreen .map-wrapper{height:-webkit-fill-available}.fullscreen #actualMap{height:-webkit-fill-available}}.map-tracking-indicator{position:absolute;top:calc(10px + env(safe-area-inset-top, 0px));left:calc(50px + env(safe-area-inset-left, 0px));background:rgb(76 175 80 / .95);color:#fff;padding:8px 12px;border-radius:20px;font-size:11px;font-weight:500;z-index:1000;display:none;align-items:center;gap:8px;box-shadow:0 2px 12px rgb(0 0 0 / .2);transition:all 0.3s ease;border:2px solid rgb(255 255 255 / .3);backdrop-filter:blur(10px);min-width:140px;justify-content:center}.map-tracking-indicator.active{display:flex;animation:slideInFromLeft 0.4s ease-out}.map-tracking-indicator .tracking-icon{font-size:14px;animation:pulse-icon 2s ease-in-out infinite}.map-tracking-indicator .tracking-text{font-weight:600;letter-spacing:.3px}.map-tracking-indicator.routing{background:rgb(255 152 0 / .95);border-color:rgb(255 152 0 / .3)}.map-tracking-indicator.auto-search{background:rgb(33 150 243 / .95);border-color:rgb(33 150 243 / .3)}.map-tracking-indicator.tracking{background:rgb(76 175 80 / .95);border-color:rgb(76 175 80 / .3)}@keyframes slideInFromLeft{0%{transform:translateX(-100%);opacity:0}100%{transform:translateX(0);opacity:1}}@keyframes pulse-icon{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.8}}.user-location-marker.tracking .pulse{animation:user-pulse-tracking 1.8s ease-out infinite}.user-location-marker.tracking .center{background:#4CAF50;box-shadow:0 2px 8px rgb(0 0 0 / .3),0 0 0 0 rgb(76 175 80 / .7);animation:center-glow-tracking 1.8s ease-in-out infinite}.user-location-marker.routing .pulse{animation:user-pulse-routing 1.5s ease-out infinite}.user-location-marker.routing .center{background:#FF9800;animation:center-glow-routing 1.5s ease-in-out infinite}.user-location-marker.auto-search .pulse{animation:user-pulse-auto-search 2.2s ease-out infinite}.user-location-marker.auto-search .center{background:#2196F3;animation:center-glow-auto-search 2.2s ease-in-out infinite}@keyframes user-pulse{0%{opacity:1;transform:translate(-50%,-50%) scale(.3)}100%{opacity:0;transform:translate(-50%,-50%) scale(2)}}@keyframes user-pulse-tracking{0%{opacity:1;transform:translate(-50%,-50%) scale(.4);background:rgb(76 175 80 / .4)}100%{opacity:0;transform:translate(-50%,-50%) scale(2.5);background:rgb(76 175 80 / .1)}}@keyframes user-pulse-routing{0%{opacity:1;transform:translate(-50%,-50%) scale(.5);background:rgb(255 152 0 / .5)}100%{opacity:0;transform:translate(-50%,-50%) scale(2.2);background:rgb(255 152 0 / .1)}}@keyframes user-pulse-auto-search{0%{opacity:1;transform:translate(-50%,-50%) scale(.3);background:rgb(33 150 243 / .4)}100%{opacity:0;transform:translate(-50%,-50%) scale(2.8);background:rgb(33 150 243 / .1)}}@keyframes center-glow-tracking{0%,100%{box-shadow:0 2px 8px rgb(0 0 0 / .3),0 0 0 0 rgb(76 175 80 / .7)}50%{box-shadow:0 2px 8px rgb(0 0 0 / .3),0 0 0 8px #fff0}}@keyframes center-glow-routing{0%,100%{box-shadow:0 2px 8px rgb(0 0 0 / .3),0 0 0 0 rgb(255 152 0 / .7)}50%{box-shadow:0 2px 8px rgb(0 0 0 / .3),0 0 0 6px #fff0}}@keyframes center-glow-auto-search{0%,100%{box-shadow:0 2px 8px rgb(0 0 0 / .3),0 0 0 0 rgb(33 150 243 / .7)}50%{box-shadow:0 2px 8px rgb(0 0 0 / .3),0 0 0 10px #fff0}}.map-container-block{background:#fff;border-radius:12px;padding:10px 15px;box-shadow:0 2px 8px rgb(0 0 0 / .1);margin-bottom:20px;transition:all 0.3s ease;position:relative}.map-container-block.tracking{border-left:4px solid #4CAF50;background:linear-gradient(90deg,rgb(76 175 80 / .05) 0%,transparent 100%)}.map-container-block.routing{border-left:4px solid #FF9800;background:linear-gradient(90deg,rgb(255 152 0 / .05) 0%,transparent 100%)}.map-container-block.auto-search{border-left:4px solid #2196F3;background:linear-gradient(90deg,rgb(33 150 243 / .05) 0%,transparent 100%)}.map-container-block.tracking .section-title::after{content:" 📍";color:#4CAF50;animation:title-pulse 2s ease-in-out infinite}.map-container-block.routing .section-title::after{content:" 🚶";color:#FF9800;animation:title-pulse 1.5s ease-in-out infinite}.map-container-block.auto-search .section-title::after{content:" 🔄";color:#2196F3;animation:title-pulse 2.2s ease-in-out infinite}@keyframes title-pulse{0%,100%{opacity:1}50%{opacity:.6}}.map-controls[data-tracking-mode]::before{position:absolute;top:-30px;left:0;font-size:10px;font-weight:600;background:rgb(255 255 255 / .95);padding:4px 10px;border-radius:12px;border:1px solid rgb(0 0 0 / .1);backdrop-filter:blur(10px);box-shadow:0 2px 8px rgb(0 0 0 / .1);white-space:nowrap;z-index:100}.map-controls[data-tracking-mode="tracking"]::before{content:"📍 Live-Tracking aktiv";color:#2E7D32;border-color:rgb(76 175 80 / .3)}.map-controls[data-tracking-mode="auto-search"]::before{content:"🔄 Auto-Suche aktiv";color:#1976D2;border-color:rgb(33 150 243 / .3)}.map-container-block.manual-location{border-left:4px solid #9C27B0;background:linear-gradient(90deg,rgb(156 39 176 / .05) 0%,transparent 100%)}.map-container-block.manual-location .section-title::after{content:" 📌";color:#9C27B0}@media (max-width:480px){.map-tracking-indicator{font-size:10px;padding:6px 10px;top:5px;left:5px;min-width:120px;gap:6px}.map-tracking-indicator .tracking-icon{font-size:12px}.map-controls[data-tracking-mode]::before{font-size:9px;top:-25px;padding:3px 8px}}@media (prefers-contrast:more){.map-tracking-indicator{border-width:3px;font-weight:700}.user-location-marker .center{border-width:4px}.map-container-block.tracking,.map-container-block.routing,.map-container-block.auto-search{border-left-width:6px}}@media (prefers-reduced-motion:reduce){.map-tracking-indicator,.user-location-marker .pulse,.user-location-marker .center{animation:none}.map-tracking-indicator.active{animation:none;transform:translateX(0)}}.leaflet-popup-content{margin:6px;min-width:120px;max-width:160px}.leaflet-popup-content-wrapper{border-radius:8px}.leaflet-popup-tip{width:15px;height:15px}.poi-popup{font-size:12px;line-height:1.3}.poi-popup-header{display:flex;align-items:center;gap:4px;margin-bottom:4px}.poi-popup-number{background:#3498db;color:#fff;padding:1px 4px;border-radius:3px;font-size:10px;font-weight:700;flex-shrink:0}.poi-popup h4{margin:0;color:#2c3e50;font-size:13px;line-height:1.2;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.poi-meta-line{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:11px;gap:8px}.poi-meta-line .poi-category{color:#7f8c8d;font-size:.9em;margin:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.poi-meta-line .poi-distance{color:#3498db;font-weight:500;margin:0;font-size:.9em;white-space:nowrap;flex-shrink:0}.poi-route-btn{width:100%;padding:4px 6px;background:linear-gradient(45deg,#2196f3,#1976d2);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:11px;margin-top:4px;transition:background 0.2s;font-weight:500}.poi-route-btn:hover{background:linear-gradient(45deg,#1976d2,#1565c0)}.poi-route-info{width:100%;padding:4px 6px;background:#f8f9fa;color:#6c757d;border:1px solid #dee2e6;border-radius:4px;font-size:10px;margin-top:4px;text-align:center;font-style:italic}.no-results-popup{text-align:center;padding:10px}.no-results-popup strong{color:#dc3545}@media (max-width:768px){.leaflet-popup-content{margin:5px;min-width:110px;max-width:140px}.poi-popup{font-size:11px}.poi-popup h4{font-size:12px}.poi-meta-line{font-size:10px;gap:6px}.poi-route-btn{font-size:10px;padding:3px 5px}.poi-route-info{font-size:9px;padding:3px 5px}}@media (max-width:480px){.leaflet-popup-content{margin:4px;min-width:100px;max-width:130px}.poi-popup-header{gap:3px;margin-bottom:3px}.poi-popup-number{padding:1px 3px;font-size:9px}.poi-popup h4{font-size:11px}.poi-meta-line{font-size:9px;gap:4px;margin-bottom:3px}.poi-route-btn{font-size:9px;padding:2px 4px;margin-top:3px}.poi-route-info{font-size:8px;padding:2px 4px;margin-top:3px}}@media (prefers-reduced-motion:reduce){.poi-route-btn{transition:none!important}}@media (prefers-contrast:more){.poi-popup-number{background:#000;border:1px solid #fff}.poi-meta-line .poi-distance{color:#000;font-weight:700}.poi-route-btn{background:#000000!important;border:2px solid #fff}}@media (max-width:480px){.container{padding:10px}.header{padding:15px;gap:15px}.header h1{font-size:1.8em}.header.compact{padding:8px 15px}.header.compact .header-icon img{width:28px;height:28px}.header.compact .header-text h1{font-size:1em}.category-grid{grid-template-columns:1fr;gap:12px}.category-item{padding:12px}.search-controls{flex-direction:column;align-items:stretch;gap:10px}.auto-toggle{justify-content:center;width:100%;height:44px}.contact-grid{grid-template-columns:1fr;gap:12px}.stats-grid{grid-template-columns:1fr;gap:10px}.teilen-content{flex-direction:column;align-items:center;gap:15px}.social-links{width:100%}}@media (max-width:360px){.container{padding:8px}.header{padding:12px;gap:12px}.header h1{font-size:1.6em}.category-item{padding:10px}.category-item .category-name{font-size:1em}.search-button{padding:12px;font-size:14px}.poi-item{padding:10px 12px}.poi-name{font-size:14px}.poi-distance{font-size:12px}}@media (max-width:480px) and (min-height:800px){.scroll-wrapper{scroll-snap-type:y proximity}.block{margin-bottom:25px}}@media (max-width:768px) and (orientation:landscape){.header{padding:10px 20px}.header h1{font-size:1.5em}#actualMap{height:300px}.category-grid{grid-template-columns:repeat(2,1fr)}}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}.scroll-wrapper{scroll-snap-type:none}.block{scroll-snap-align:none}.user-location-marker .pulse{animation:none!important;opacity:.3}.skeleton-loader{animation:none!important;background:#f0f0f0}}@media (prefers-contrast:more){.category-item{border-width:3px}.category-item.selected{border-color:#000;background:#000;color:#fff}.poi-item{border:2px solid #000}.poi-distance{color:#000;font-weight:700}.search-button{background:#000;border:2px solid #fff}.map-control-btn{border:2px solid #000;background:#fff;color:#000}.primary-btn{background:#000;color:#fff}}@media (prefers-color-scheme:dark){.dialog{background:#2d3748;color:#fff}.privacy-section{background:#4a5568;border-left-color:#667eea}.stats-display{background:#4a5568}.stat-item{background:#2d3748;color:#fff}}@media print{.map-container-block,.server-health,.dialog-overlay,.search-controls,.map-controls{display:none!important}body{background:#fff;color:#000}.container{max-width:none;padding:0}.header{background:none;color:#000;border:1px solid #000}.poi-item{border:1px solid #000;margin-bottom:10px}.block{break-inside:avoid}h1,h2,h3{break-after:avoid}}@media (pointer:coarse){.category-item{min-height:60px;padding:15px}.poi-item{min-height:60px;padding:15px}.map-control-btn{min-width:48px;min-height:48px;padding:12px}.search-button{min-height:48px;padding:15px}.dropdown-item{padding:12px 16px;min-height:48px}}@media (max-width:768px) and (min-height:600px){.scroll-wrapper{scroll-snap-type:y proximity}.container{padding:20px 25px}}@media (min-width:768px) and (max-height:500px){.header{padding:15px 30px}.category-grid{grid-template-columns:repeat(3,1fr)}#actualMap{height:250px}}:root{--places-bg:#f8f9fa;--places-bg-hover:#f1f3f4;--places-border:#e8eaed;--places-text:#202124;--places-text-secondary:#5f6368;--places-link:#4285f4;--places-link-bg:rgba(66, 133, 244, 0.1);--places-rating-bg:rgba(66, 133, 244, 0.1);--places-open:#34a853;--places-closed:#ea4335;--places-loading-bg:#f8f9fa;--places-loading-border:#dadce0;--places-error-bg:#fef7e0;--places-error-border:#fbbc04;--places-error-text:#b06000}@media (prefers-color-scheme:dark){:root{--places-bg:#2d3748;--places-bg-hover:#4a5568;--places-border:#4a5568;--places-text:#e2e8f0;--places-text-secondary:#a0aec0;--places-link:#4299e1;--places-link-bg:rgba(66, 153, 225, 0.15);--places-rating-bg:rgba(66, 153, 225, 0.15);--places-open:#48bb78;--places-closed:#f56565;--places-loading-bg:#2d3748;--places-loading-border:#4a5568;--places-error-bg:#744210;--places-error-border:#f56565;--places-error-text:#fbd38d}}.dark-mode{--places-bg:#2d3748;--places-bg-hover:#4a5568;--places-border:#4a5568;--places-text:#e2e8f0;--places-text-secondary:#a0aec0;--places-link:#4299e1;--places-link-bg:rgba(66, 153, 225, 0.15);--places-rating-bg:rgba(66, 153, 225, 0.15);--places-open:#48bb78;--places-closed:#f56565;--places-loading-bg:#2d3748;--places-loading-border:#4a5568;--places-error-bg:#744210;--places-error-border:#f56565;--places-error-text:#fbd38d}.places-container{margin-top:6px;border-top:1px solid var(--places-border);padding-top:6px;animation:fadeIn 0.2s ease-in}.places-loaded{width:80px}.places-container.places-loaded{animation:slideIn 0.3s ease-out}.adjustet-rating{font-size:14px;font-weight:700;color:var(--places-text)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideIn{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.places-info{display:flex;justify-content:space-between;align-items:center;background:var(--places-bg);border-radius:6px;border-left:3px solid var(--places-link);padding:6px 8px;font-size:12px;min-height:40px;margin-left:10px;color:var(--places-text);cursor:pointer;transition:background-color 0.2s ease,border-color 0.2s ease,transform 0.1s ease}.places-info:hover{background:var(--places-bg-hover);transform:scale(1.01)}.places-info.open{border-left-color:var(--places-open)}.places-info.closed{border-left-color:var(--places-closed)}.places-left{display:flex;flex-direction:column;text-decoration:none;gap:2px}.adjusted-label{font-size:10px;color:var(--places-text-secondary);line-height:1}.adjusted-value{font-size:14px;font-weight:700;color:var(--places-text);line-height:1.2}.places-right{display:flex;flex-direction:column;align-items:flex-end;text-decoration:none;gap:4px;flex-shrink:0}.places-link{display:inline-flex;align-items:center;justify-content:center;color:var(--places-link);text-decoration:none;font-size:12px;font-weight:500;padding:2px 4px;border-radius:4px;background:var(--places-link-bg);transition:background-color 0.2s ease}.places-link:hover{text-decoration:underline;background:var(--places-bg-hover)}.places-line-1{display:flex;align-items:center;gap:8px;margin-bottom:3px}.places-header{display:flex;align-items:center;gap:4px;font-weight:500;color:var(--places-link);font-size:11px;flex-shrink:0}.places-icon{font-size:12px}.places-source{font-size:10px;font-weight:600;color:var(--places-text-secondary)}.places-confidence{background:var(--places-rating-bg);color:var(--places-link);padding:1px 4px;border-radius:8px;font-size:9px;font-weight:500;margin-left:auto}.places-rating{display:flex;align-items:center;gap:4px;flex:1}.rating-display{display:flex;align-items:center;gap:3px}.stars{font-size:12px;line-height:1;color:#ffc107}.rating-value{font-weight:700;color:var(--places-text);font-size:12px}.rating-count{color:var(--places-text-secondary);font-size:10px;white-space:nowrap}.places-line-2{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:10px}.places-details{display:flex;align-items:center;gap:8px}.detail-item{font-size:10px;color:var(--places-text-secondary);white-space:nowrap;display:flex;align-items:center;gap:2px}.places-loading{display:flex;align-items:center;gap:6px;padding:6px 8px;background:var(--places-loading-bg);border-radius:4px;color:var(--places-text-secondary);font-size:11px;border:1px dashed var(--places-loading-border);min-height:28px}.loading-spinner{animation:spin 1s linear infinite;font-size:12px;color:var(--places-link)}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}.places-error{display:flex;align-items:center;gap:6px;padding:6px 8px;background:var(--places-error-bg);color:var(--places-error-text);font-size:10px;border-radius:4px;border-left:2px solid var(--places-error-border);min-height:24px}.error-icon{font-size:12px}.places-info.ultra-compact{padding:4px 6px;min-height:20px;font-size:10px}.places-info.ultra-compact .places-header,.places-info.ultra-compact .places-footer{display:none}.places-info.ultra-compact .places-details .detail-item:not(:first-child){display:none}@media (max-width:768px){.places-info{padding:4px 6px;font-size:10px;min-height:24px}.places-confidence{display:none}.rating-count{font-size:9px}.places-link{font-size:9px;padding:1px 3px}.places-details .detail-item:not(:first-child){display:none}}.poi-item .places-container{margin-top:4px;padding-top:4px}.poi-item .places-info{font-size:11px;padding:4px 6px;min-height:22px}.places-container.hover-expand .places-info{transition:all 0.3s ease}.places-container.hover-expand:hover .places-info{padding:8px 10px;min-height:32px}.places-container.hover-expand:hover .places-review{display:block;background:var(--places-link-bg);padding:6px 8px;border-radius:4px;margin-top:4px;border-left:2px solid var(--places-link);font-size:10px}.places-container.hover-expand:hover .review-text{font-style:italic;color:var(--places-text-secondary);line-height:1.3}.places-info.icon-only{padding:2px 4px;background:#fff0;border:none;font-size:10px;min-height:16px;gap:4px}.places-info.icon-only .places-header,.places-info.icon-only .places-footer{display:none}.places-info.icon-only .rating-count{display:none}.places-info.icon-only .detail-item{display:flex;align-items:center;font-size:9px}.places-badge{display:inline-flex;align-items:center;gap:3px;background:var(--places-rating-bg);color:var(--places-link);padding:2px 6px;border-radius:10px;font-size:9px;font-weight:500;margin-top:2px;border:1px solid var(--places-border)}.places-badge .stars{font-size:10px}.places-badge .rating-value{font-size:9px}.places-minimal{display:inline-flex;align-items:center;gap:4px;background:var(--places-rating-bg);padding:2px 6px;border-radius:8px;font-size:10px;color:var(--places-link);margin-top:3px}.places-minimal .rating-stars{font-size:9px}.places-minimal .rating-text{font-weight:500;font-size:9px}.places-toggle-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--places-bg);border:2px solid var(--places-border);border-radius:8px;font-size:14px;cursor:pointer;transition:all 0.2s ease;margin-left:8px;color:var(--places-text)}.places-toggle-btn:hover{background:var(--places-bg-hover);border-color:var(--places-link);transform:scale(1.05)}.places-toggle-btn.loading{animation:spin 1s linear infinite;border-color:var(--places-link);background:var(--places-link-bg)}.places-toggle-btn.active{background:var(--places-link-bg);border-color:var(--places-link);color:var(--places-link)}.places-toggle-btn:disabled{cursor:not-allowed;opacity:.6}.header-controls{display:flex;align-items:center;gap:8px;margin-left:auto}.poi-results>div:first-child{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}@media (prefers-color-scheme:dark){.places-info{border-left-width:3px;border-left-style:solid}.stars{filter:brightness(1.2)}}.dark-mode .places-info{border-left-width:3px;border-left-style:solid}.dark-mode .stars{filter:brightness(1.2)}@media (prefers-contrast:more){:root{--places-border:#000000;--places-text:#000000;--places-link:#0000ff}@media (prefers-color-scheme:dark){:root{--places-border:#ffffff;--places-text:#ffffff;--places-link:#ffff00}}}.header{background:rgb(255 255 255 / .1);backdrop-filter:blur(10px);border-radius:20px;padding:30px;margin-bottom:10px;border:1px solid rgb(255 255 255 / .2);display:flex;align-items:center;gap:20px;position:relative}.header-icon{display:flex;flex-direction:column;align-items:center;position:relative}.header img{flex-shrink:0;background:#fff;border-radius:8px;padding:0}.header-text{flex:1;text-align:left}.header h1{color:#fff;font-size:2.5em;margin:0 0 10px;text-shadow:2px 2px 4px rgb(0 0 0 / .3)}.header p{color:rgb(255 255 255 / .9);margin:0;font-size:1.2em}#install-button-container{position:absolute;top:-8px;right:-8px;z-index:10}.install-btn{background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);border:2px solid rgb(255 255 255 / .3);color:#fff;width:48px;height:48px;border-radius:50%;font-size:20px;cursor:pointer;box-shadow:0 4px 15px rgb(79 172 254 / .4),0 0 0 0 rgb(79 172 254 / .7);transition:all 0.3s ease;display:flex;align-items:center;justify-content:center;position:relative;backdrop-filter:blur(10px)}.install-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px rgb(79 172 254 / .6),0 0 0 8px rgb(79 172 254 / .1)}.install-btn.swing{animation:swingAnimation 4s infinite,pulseGlow 3s infinite}@keyframes swingAnimation{0%,75%{transform:rotate(0deg)}78%{transform:rotate(-8deg)}82%{transform:rotate(8deg)}86%{transform:rotate(-6deg)}90%{transform:rotate(4deg)}94%{transform:rotate(-2deg)}97%,100%{transform:rotate(0deg)}}@keyframes pulseGlow{0%,70%{box-shadow:0 4px 15px rgb(79 172 254 / .4),0 0 0 0 rgb(79 172 254 / .7)}85%{box-shadow:0 6px 25px rgb(79 172 254 / .6),0 0 0 10px rgb(79 172 254 / .2)}100%{box-shadow:0 4px 15px rgb(79 172 254 / .4),0 0 0 0 rgb(79 172 254 / .7)}}.install-badge{position:absolute;top:-5px;left:-5px;background:#ff4757;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;border:2px solid #fff;animation:badgeBounce 2s infinite}@keyframes badgeBounce{0%,80%,100%{transform:scale(1)}40%{transform:scale(1.1)}}.smart-install-banner{position:absolute;top:100%;left:0;right:0;background:linear-gradient(135deg,rgb(79 172 254 / .95) 0%,rgb(0 242 254 / .95) 100%);backdrop-filter:blur(15px);border:1px solid rgb(255 255 255 / .2);border-radius:0 0 15px 15px;padding:15px 20px;color:#fff;display:none;align-items:center;gap:15px;margin-top:5px;animation:slideDown 0.4s ease-out;box-shadow:0 8px 25px rgb(0 0 0 / .15)}.smart-install-banner.show{display:flex}@keyframes slideDown{from{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.banner-icon{font-size:24px;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,100%{transform:translateY(0)}40%{transform:translateY(-6px)}60%{transform:translateY(-3px)}}.banner-content{flex:1}.banner-title{font-size:16px;font-weight:600;margin:0 0 4px;text-shadow:1px 1px 2px rgb(0 0 0 / .2)}.banner-subtitle{font-size:14px;opacity:.9;margin:0}.banner-actions{display:flex;gap:8px;align-items:center}.banner-btn{background:rgb(255 255 255 / .2);border:1px solid rgb(255 255 255 / .3);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s ease;backdrop-filter:blur(10px)}.banner-btn:hover{background:rgb(255 255 255 / .3);transform:translateY(-1px)}.banner-btn.primary{background:#fff;color:#4facfe}.banner-btn.primary:hover{background:#f8f9fa}.banner-close{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;opacity:.7;transition:opacity 0.2s;padding:4px;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.banner-close:hover{opacity:1;background:rgb(255 255 255 / .1)}.floating-install{position:fixed;bottom:20px;right:20px;background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%);color:#fff;border-radius:50px;padding:12px 20px;font-size:14px;font-weight:500;cursor:pointer;box-shadow:0 4px 20px rgb(79 172 254 / .4);animation:floatingPulse 3s infinite;z-index:1000;display:none;align-items:center;gap:8px;backdrop-filter:blur(10px);border:1px solid rgb(255 255 255 / .2)}.floating-install.show{display:flex}@keyframes floatingPulse{0%,70%{transform:scale(1);box-shadow:0 4px 20px rgb(79 172 254 / .4)}85%{transform:scale(1.05);box-shadow:0 6px 25px rgb(79 172 254 / .6)}100%{transform:scale(1);box-shadow:0 4px 20px rgb(79 172 254 / .4)}}@media (max-width:768px){.header{padding:20px;gap:15px}.header h1{font-size:2em}.header p{font-size:1em}.install-btn{width:40px;height:40px;font-size:18px}.smart-install-banner{padding:12px 15px}.banner-title{font-size:14px}.banner-subtitle{font-size:13px}}@media (max-width:480px){.banner-actions{flex-direction:column;gap:6px;align-items:stretch}.banner-btn{text-align:center;padding:6px 12px;font-size:13px}}.tour-suggestion{background:linear-gradient(135deg,#4a5568 0%,#2d3748 100%);color:#fff;padding:1.5rem;border-radius:16px;margin:1rem 0;box-shadow:0 4px 20px rgb(0 0 0 / .2);animation:slideIn 0.4s ease-out}@keyframes slideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tour-header h4{margin:0 0 .5rem;font-size:1.3rem;font-weight:700;color:#fff}.tour-description{margin:0 0 1rem;font-size:.9rem;opacity:.95;color:#fff}.tour-stats{display:flex;gap:1rem;margin:1rem 0;padding:.75rem;background:rgb(255 255 255 / .3);border-radius:12px;flex-wrap:wrap}.stat{display:flex;align-items:center;gap:.4rem;font-size:.95rem}.stat-icon{font-size:1.2rem}.stat-value{font-weight:600;color:#fff}.tour-route{list-style:none;padding:0;margin:1rem 0}.tour-stop{background:rgb(255 255 255 / .1);border-radius:12px;margin:.75rem 0;overflow:hidden;transition:transform 0.2s,background 0.2s}.tour-stop:hover{background:rgb(255 255 255 / .15);transform:translateX(4px)}.stop-main{display:flex;align-items:flex-start;padding:1rem;gap:.75rem}.stop-number{background:#fff;color:#2d3748;min-width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0;box-shadow:0 2px 8px rgb(0 0 0 / .15)}.stop-info{flex:1;display:flex;flex-direction:column;gap:.3rem}.stop-name{font-weight:600;font-size:1rem;line-height:1.3;color:#fff}.walk-info{font-size:.85rem;opacity:1;font-weight:500;color:#fff;display:flex;align-items:center;gap:.3rem}.break-suggestion{background:rgb(255 255 255 / .15);padding:.75rem 1rem .75rem 3.5rem;margin-top:-1px;display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;border-top:1px dashed rgb(255 255 255 / .3);position:relative}.break-icon{font-size:1.2rem;position:absolute;left:1rem;top:50%;transform:translateY(-50%)}.break-text{display:flex;flex-direction:column;gap:.2rem;line-height:1.4}.break-text strong{font-weight:600}.break-meta{font-size:.8rem;opacity:.85}.tour-actions{display:flex;gap:.75rem;margin-top:1.5rem}.tour-btn{flex:1;padding:.9rem 1rem;border:none;border-radius:10px;font-weight:500;font-size:.95rem;cursor:pointer;transition:all 0.2s ease;display:flex;align-items:center;justify-content:center;gap:.4rem}.tour-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgb(0 0 0 / .2)}.tour-btn:active{transform:translateY(0)}.tour-btn.primary{background:#fff;color:#2d3748}.tour-btn.primary:hover{background:#e2e8f0}.tour-btn.secondary{background:rgb(255 255 255 / .2);color:#fff;border:1px solid rgb(255 255 255 / .3)}.tour-btn.secondary:hover{background:rgb(255 255 255 / .3)}@media (max-width:600px){.tour-suggestion{padding:1.25rem;border-radius:12px}.tour-header h4{font-size:1.1rem}.tour-stats{gap:.75rem}.stat{font-size:.85rem}.stop-main{padding:.85rem;gap:.6rem}.stop-number{min-width:28px;height:28px;font-size:.9rem}.stop-name{font-size:.95rem}.walk-info{font-size:.8rem}.break-suggestion{padding:.6rem .85rem .6rem 3rem;font-size:.8rem}.tour-actions{flex-direction:column;gap:.5rem}.tour-btn{padding:.8rem;font-size:.9rem}}@media (prefers-color-scheme:dark){.tour-suggestion{box-shadow:0 4px 20px rgb(102 126 234 / .5)}.stop-number{box-shadow:0 2px 8px rgb(0 0 0 / .3)}}@media print{.tour-actions{display:none}.tour-suggestion{background:#fff;color:#000;border:2px solid #2d3748}.stop-number{border:2px solid #2d3748}}