:root{--neutral-50: #fafafa;--neutral-100: #f5f5f5;--neutral-200: #e5e5e5;--neutral-300: #d4d4d4;--neutral-400: #a3a3a3;--neutral-500: #737373;--neutral-600: #525252;--neutral-700: #404040;--neutral-800: #262626;--neutral-900: #171717;--neutral-950: #0a0a0a;--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--success-50: #f0fdf4;--success-100: #dcfce7;--success-200: #bbf7d0;--success-300: #86efac;--success-400: #4ade80;--success-500: #22c55e;--success-600: #16a34a;--success-700: #15803d;--success-800: #166534;--success-900: #14532d;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-200: #fde68a;--warning-300: #fcd34d;--warning-400: #fbbf24;--warning-500: #f59e0b;--warning-600: #d97706;--warning-700: #b45309;--warning-800: #92400e;--warning-900: #78350f;--danger-50: #fef2f2;--danger-100: #fee2e2;--danger-200: #fecaca;--danger-300: #fca5a5;--danger-400: #f87171;--danger-500: #ef4444;--danger-600: #dc2626;--danger-700: #b91c1c;--danger-800: #991b1b;--danger-900: #7f1d1d;--purple-50: #faf5ff;--purple-100: #f3e8ff;--purple-200: #e9d5ff;--purple-300: #d8b4fe;--purple-400: #c084fc;--purple-500: #a855f7;--purple-600: #9333ea;--purple-700: #7e22ce;--purple-800: #6b21a8;--purple-900: #581c87;--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f5;--bg-hover: #f5f5f5;--bg-active: #e5e5e5;--text-primary: #171717;--text-secondary: #525252;--text-tertiary: #a3a3a3;--text-inverse: #ffffff;--border-primary: #e5e5e5;--border-secondary: #d4d4d4;--border-focus: var(--primary-500);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: ui-monospace, "SF Mono", "Monaco", "Cascadia Code", "Roboto Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--rounded-none: 0;--rounded-sm: .25rem;--rounded: .375rem;--rounded-md: .5rem;--rounded-lg: .75rem;--rounded-xl: 1rem;--rounded-2xl: 1.5rem;--rounded-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-md: 0 6px 12px -2px rgba(0, 0, 0, .12), 0 3px 7px -3px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 30px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-overlay: 400;--z-modal: 500;--z-popover: 600;--z-toast: 700;--z-tooltip: 800;--z-loader: 9999;--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .4s cubic-bezier(.68, -.55, .265, 1.55);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--transition: var(--transition-base);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--border-radius: var(--rounded-xl);--border-radius-sm: var(--rounded-md);--primary-blue: var(--primary-500);--primary-dark: var(--primary-700);--success-green: var(--success-500);--success-dark: var(--success-700);--danger-red: var(--danger-500);--danger-dark: var(--danger-700);--warning-yellow: var(--warning-500);--purple: var(--purple-500);--purple-dark: var(--purple-700);--light-text: var(--text-primary);--light-bg: var(--bg-primary);--light-surface: var(--bg-secondary);--light-surface-2: var(--bg-tertiary);--light-text-secondary: var(--text-secondary);--dark-text: #fafafa;--dark-bg: #0a0a0a;--dark-surface: #171717;--dark-surface-2: #262626;--dark-text-secondary: #a3a3a3;--z-controls: var(--z-fixed);--z-search: var(--z-sticky);--z-popup: var(--z-popover)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);line-height:var(--leading-normal);color:var(--text-primary);background:var(--bg-primary);transition:background-color var(--transition-base),color var(--transition-base);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:var(--text-base)}body.dark-mode{--bg-primary: #0a0a0a;--bg-secondary: #171717;--bg-tertiary: #262626;--bg-hover: #262626;--bg-active: #404040;--text-primary: #fafafa;--text-secondary: #a3a3a3;--text-tertiary: #737373;--text-inverse: #0a0a0a;--border-primary: #262626;--border-secondary: #404040;--border-focus: var(--primary-400);--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .4), 0 1px 2px -1px rgba(0, 0, 0, .4);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .4);--shadow-md: 0 6px 12px -2px rgba(0, 0, 0, .5), 0 3px 7px -3px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 20px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 30px -5px rgba(0, 0, 0, .6), 0 8px 10px -6px rgba(0, 0, 0, .5)}body.dark-mode .home{background:linear-gradient(180deg,#0c4a6e,#075985,#0369a1,#0284c7,#0c4a6e)}body.dark-mode input,body.dark-mode select,body.dark-mode textarea{background:var(--bg-tertiary);color:var(--text-primary);border-color:#3a4150}body.dark-mode .category-badge{filter:brightness(.9)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-sans);font-weight:var(--font-medium);text-decoration:none;border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-radius:var(--rounded-md);min-height:32px}.btn-md{padding:var(--space-3) var(--space-4);font-size:var(--text-base);border-radius:var(--rounded-lg);min-height:40px}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--text-lg);border-radius:var(--rounded-xl);min-height:48px}.btn-primary{background:var(--primary-500);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--primary-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active:not(:disabled){background:var(--primary-700);transform:translateY(0);box-shadow:var(--shadow-xs)}body.dark-mode .btn-primary{background:var(--primary-600)}body.dark-mode .btn-primary:hover:not(:disabled){background:var(--primary-500)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-secondary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary:active:not(:disabled){background:var(--bg-active);transform:translateY(0)}.btn-tertiary{background:transparent;color:var(--text-primary);border:1px solid transparent}.btn-tertiary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-primary)}.btn-tertiary:active:not(:disabled){background:var(--bg-active)}.btn-success{background:var(--success-500);color:#fff;box-shadow:var(--shadow-sm)}.btn-success:hover:not(:disabled){background:var(--success-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success:active:not(:disabled){background:var(--success-700);transform:translateY(0)}.btn-danger{background:var(--danger-500);color:#fff;box-shadow:var(--shadow-sm)}.btn-danger:hover:not(:disabled){background:var(--danger-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger:active:not(:disabled){background:var(--danger-700);transform:translateY(0)}.btn-warning{background:var(--warning-500);color:#fff;box-shadow:var(--shadow-sm)}.btn-warning:hover:not(:disabled){background:var(--warning-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--rounded-full);padding:var(--space-2);min-width:40px;min-height:40px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover:not(:disabled){background:var(--bg-hover);transform:scale(1.05);box-shadow:var(--shadow-sm)}.btn-icon:active:not(:disabled){transform:scale(.98)}.btn-icon-sm{min-width:32px;min-height:32px;padding:var(--space-1)}.btn-icon-lg{min-width:48px;min-height:48px;padding:var(--space-3)}.btn-icon.btn-primary{background:var(--primary-500);color:#fff;border-color:var(--primary-600)}.btn-icon.btn-danger{background:var(--danger-500);color:#fff;border-color:var(--danger-600)}.btn-icon.btn-success{background:var(--success-500);color:#fff;border-color:var(--success-600)}.btn-icon.btn-warning{background:var(--warning-500);color:#fff;border-color:var(--warning-600)}.btn svg,.btn-icon svg{display:inline-block;flex-shrink:0;stroke-width:2}.btn-sm svg{width:16px;height:16px}.btn-md svg,.btn svg{width:20px;height:20px}.btn-lg svg{width:24px;height:24px}.btn-icon svg{width:20px;height:20px}.btn-icon-sm svg{width:16px;height:16px}.btn-icon-lg svg{width:24px;height:24px}.feature-icon svg,.marker-icon svg{display:inline-block;vertical-align:middle;width:1.25em;height:1.25em;stroke-width:2}.loader{position:fixed;top:0;left:0;width:100%;height:100%;background:#fffffff2;display:flex;justify-content:center;align-items:center;z-index:var(--z-loader);transition:opacity .3s ease}body.dark-mode .loader{background:#0f1419f2}.loader-content{text-align:center}.loader-spinner{width:50px;height:50px;border:3px solid var(--light-surface-2);border-top-color:var(--primary-blue);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.home{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(180deg,#e0f2fe,#7dd3fc,#0ea5e9,#0284c7,#0369a1);color:#fff;text-align:center;padding:2rem;position:relative;overflow:hidden}.home-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:0;opacity:.6}.wave{position:absolute;bottom:0;left:0;width:100%;height:120px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1440 320'%3E%3Cpath fill='%23ffffff' fill-opacity='0.15' d='M0,96L48,112C96,128,192,160,288,160C384,160,480,128,576,122.7C672,117,768,139,864,138.7C960,139,1056,117,1152,117.3C1248,117,1344,139,1392,149.3L1440,160L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'%3E%3C/path%3E%3C/svg%3E");background-size:cover;background-position:bottom;background-repeat:no-repeat}.wave:nth-child(2){opacity:.4;bottom:15px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1440 320'%3E%3Cpath fill='%23ffffff' fill-opacity='0.2' d='M0,192L48,181.3C96,171,192,149,288,149.3C384,149,480,171,576,165.3C672,160,768,128,864,128C960,128,1056,160,1152,165.3C1248,171,1344,149,1392,138.7L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'%3E%3C/path%3E%3C/svg%3E");background-size:cover;background-position:bottom;background-repeat:no-repeat}.wave:nth-child(3){opacity:.25;bottom:30px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' viewBox='0 0 1440 320'%3E%3Cpath fill='%23ffffff' fill-opacity='0.25' d='M0,224L48,234.7C96,245,192,267,288,261.3C384,256,480,224,576,213.3C672,203,768,213,864,229.3C960,245,1056,267,1152,261.3C1248,256,1344,224,1392,208L1440,192L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'%3E%3C/path%3E%3C/svg%3E");background-size:cover;background-position:bottom;background-repeat:no-repeat}@keyframes wave{0%{transform:translate(0)}to{transform:translate(-50%)}}.home-header{position:relative;z-index:1;animation:fadeInUp .8s ease}.logo-container{width:100px;height:100px;margin:0 auto 2rem;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:3px solid rgba(255,255,255,.4);box-shadow:0 8px 32px #0369a14d;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0);box-shadow:0 8px 32px #0369a14d}50%{transform:translateY(-10px);box-shadow:0 12px 40px #0369a166}}.logo{font-size:3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.logo svg{filter:drop-shadow(0 2px 8px rgba(255,255,255,.3))}.home-title{margin-bottom:1rem}.title-main{display:block;font-size:clamp(2.5rem,7vw,4.5rem);font-weight:700;text-shadow:0 4px 16px rgba(0,0,0,.2),0 2px 8px rgba(3,105,161,.4);letter-spacing:-1px}.title-sub{display:block;font-size:clamp(1.2rem,3vw,1.8rem);font-weight:300;opacity:.95;margin-top:.5rem;text-shadow:0 2px 8px rgba(0,0,0,.2)}.home-description{font-size:clamp(1rem,2.5vw,1.2rem);max-width:600px;margin:0 auto 3rem;opacity:.95;line-height:1.8;text-shadow:0 2px 8px rgba(0,0,0,.3)}.home-stats{display:none}.stat{text-align:center}.stat-number{display:block;font-size:2.5rem;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.2)}.stat-label{display:block;font-size:.9rem;opacity:.8;text-transform:uppercase;letter-spacing:1px;margin-top:.25rem}.home-buttons{display:flex;gap:var(--space-4);flex-wrap:wrap;justify-content:center;margin-bottom:3rem;animation:fadeInUp 1.2s ease .4s both}.home-btn{background:#ffffff26;color:#fff;border:1.5px solid rgba(255,255,255,.3);padding:var(--space-4) var(--space-6);border-radius:var(--rounded-xl);font-size:var(--text-lg);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-base);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-flex;align-items:center;gap:var(--space-3);text-decoration:none;position:relative;overflow:hidden;box-shadow:var(--shadow-md);min-height:56px}.home-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#fff3;border-radius:50%;transform:translate(-50%,-50%);transition:width .5s var(--ease-out),height .5s var(--ease-out)}.home-btn:hover:before{width:400px;height:400px}.home-btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px #00000040;border-color:#fff9}.home-btn:active{transform:translateY(0);box-shadow:var(--shadow)}.home-btn.primary{background:#ffffff40;border-color:#ffffff80;box-shadow:0 4px 16px #fff3}.home-btn.secondary{background:#0ea5e959;border-color:#7dd3fc80;box-shadow:0 4px 16px #0ea5e94d}.home-btn.tertiary{background:#06b6d459;border-color:#67e8f980;box-shadow:0 4px 16px #06b6d44d}.home-btn svg{width:24px;height:24px;flex-shrink:0;position:relative;z-index:1}.btn-text{position:relative;z-index:1}.home-features{display:flex;gap:2rem;animation:fadeInUp 1.4s ease .6s both}.feature{display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.8;transition:var(--transition)}.feature:hover{opacity:1;transform:translateY(-2px)}.feature-icon{font-size:1.5rem}.feature-text{font-size:.85rem;text-transform:uppercase;letter-spacing:1px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.dark-mode-toggle{position:fixed;top:1rem;right:4rem;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:var(--rounded-full);width:48px;height:48px;cursor:pointer;transition:all var(--transition-fast);z-index:1001;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;overflow:hidden}.dark-mode-toggle:hover{transform:scale(1.08);box-shadow:var(--shadow-lg);background:var(--bg-hover);border-color:var(--border-secondary)}.dark-mode-toggle:active{transform:scale(.95);box-shadow:var(--shadow-sm)}.dark-mode-toggle .icon-light,.dark-mode-toggle .icon-dark{position:absolute;transition:opacity var(--transition-base),transform var(--transition-base)}.dark-mode-toggle .icon-dark{opacity:0;transform:rotate(180deg) scale(.8)}body.dark-mode .dark-mode-toggle .icon-light{opacity:0;transform:rotate(-180deg) scale(.8)}body.dark-mode .dark-mode-toggle .icon-dark{opacity:1;transform:rotate(0) scale(1)}#map{height:100vh;width:100%;position:relative;background:var(--light-surface)}body.dark-mode #map{background:var(--dark-bg)}.search-container{position:absolute;top:1rem;left:50%;transform:translate(-50%);width:90%;max-width:420px;z-index:1000;background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(0,0,0,.1);border-radius:var(--rounded-xl);box-shadow:0 10px 40px #0003;overflow:hidden;transition:all var(--transition-fast);pointer-events:auto}.search-container:focus-within{box-shadow:0 15px 50px #00000040;border-color:var(--primary-500)}body.dark-mode .search-container{background:#1e293bfa;border-color:#ffffff1a;box-shadow:0 10px 40px #00000080}.search-input{width:100%;padding:1rem 3rem 1rem 1rem;border:none;font-size:1rem;background:transparent;outline:none;color:var(--text-primary)}.search-input::placeholder{color:var(--text-tertiary)}body.dark-mode .search-input{color:var(--dark-text)}body.dark-mode .search-input::placeholder{color:var(--dark-text-secondary)}.search-clear{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-2);font-size:var(--text-xl);transition:all var(--transition-fast);border-radius:var(--rounded);display:flex;align-items:center;justify-content:center;width:32px;height:32px}.search-clear:hover{color:var(--danger-500);background:var(--danger-50)}body.dark-mode .search-clear:hover{background:#ef44441a}.search-clear:active{transform:translateY(-50%) scale(.95)}.search-results{max-height:300px;overflow-y:auto;border-top:1px solid var(--light-surface-2);display:none}.search-results.active{display:block}.search-result-item{padding:var(--space-3) var(--space-4);cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;gap:var(--space-3);position:relative}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-hover);padding-left:var(--space-5)}.search-result-item:active{background:var(--bg-active)}body.dark-mode .search-result-item{border-color:var(--dark-surface)}body.dark-mode .search-result-item:hover{background:var(--dark-surface-2)}body.dark-mode .search-result-item:active{background:var(--dark-surface)}.search-result-icon{font-size:var(--text-xl);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;width:24px;flex-shrink:0}.search-result-name{font-weight:var(--font-medium);color:var(--text-primary);flex:1}body.dark-mode .search-result-name{color:var(--dark-text)}.search-result-category{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.map-stats{position:absolute;top:1rem;right:1rem;background:var(--bg-primary);border:1px solid var(--border-primary);padding:var(--space-2) var(--space-4);border-radius:var(--rounded-lg);box-shadow:var(--shadow-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);z-index:var(--z-controls)}body.dark-mode .map-stats{background:var(--dark-surface);border-color:var(--dark-surface-2);color:var(--dark-text-secondary)}.favorites-panel{position:absolute;left:-320px;top:0;width:320px;height:100%;background:var(--bg-primary);border-right:1px solid var(--border-primary);box-shadow:var(--shadow-xl);transition:all var(--transition-base);z-index:var(--z-controls);padding:var(--space-6);overflow-y:auto}.favorites-panel.active{left:0}.favorites-panel h3{margin-bottom:var(--space-4);color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-semibold);display:flex;align-items:center;gap:var(--space-2)}body.dark-mode .favorites-panel{background:var(--dark-surface);border-color:var(--dark-surface-2)}body.dark-mode .favorites-panel h3{color:var(--dark-text)}.favorites-list{display:flex;flex-direction:column;gap:.75rem}.favorites-empty{color:var(--light-text-secondary);font-style:italic;text-align:center;padding:2rem 0}.favorite-item{padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--rounded-lg);cursor:pointer;transition:all var(--transition-fast);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);box-shadow:var(--shadow-xs)}.favorite-item:hover{background:var(--bg-hover);border-color:var(--border-secondary);transform:translate(4px);box-shadow:var(--shadow-sm)}.favorite-item:active{transform:translate(2px);box-shadow:var(--shadow-xs)}body.dark-mode .favorite-item{background:var(--dark-surface-2);border-color:var(--dark-surface)}body.dark-mode .favorite-item:hover{background:var(--dark-surface);border-color:var(--border-secondary)}.favorite-remove{background:none;border:none;color:var(--danger-red);cursor:pointer;padding:.25rem;font-size:1.2rem;transition:var(--transition-fast)}.favorite-remove:hover{transform:scale(1.2)}.filter-controls{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--rounded-xl);box-shadow:var(--shadow-lg);padding:var(--space-4);min-width:200px}body.dark-mode .filter-controls{background:var(--dark-surface);border-color:var(--dark-surface-2)}.filter-controls h4{margin-bottom:var(--space-3);color:var(--text-primary);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:1px}body.dark-mode .filter-controls h4{color:var(--dark-text)}.filter-item{display:flex;align-items:center;margin-bottom:.5rem;cursor:pointer;transition:var(--transition-fast);padding:.25rem;border-radius:var(--border-radius-sm)}.filter-item:hover{background:var(--light-surface)}.filter-checkbox{margin-right:.75rem;width:18px;height:18px;cursor:pointer}.filter-label{font-size:.9rem;-webkit-user-select:none;user-select:none}.filter-reset{width:100%;padding:var(--space-2) var(--space-3);margin-top:var(--space-3);background:var(--primary-500);color:#fff;border:1px solid var(--primary-600);border-radius:var(--rounded-md);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);box-shadow:var(--shadow-xs);min-height:32px}.filter-reset:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.filter-reset:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.home-control,.favorites-control{background:#fff;border-radius:var(--rounded-lg);box-shadow:var(--shadow);padding:var(--space-2);margin-bottom:var(--space-2)}body.dark-mode .home-control,body.dark-mode .favorites-control{background:var(--dark-surface)}.home-map-btn,.favorites-toggle-btn{background:var(--success-500);color:#fff;border:1px solid var(--success-600);padding:var(--space-3) var(--space-4);border-radius:var(--rounded-md);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-xs);display:inline-flex;align-items:center;justify-content:center;min-height:36px}.home-map-btn:hover,.favorites-toggle-btn:hover{background:var(--success-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.home-map-btn:active,.favorites-toggle-btn:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.custom-marker{position:relative}.marker-pin{width:40px;height:40px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:flex;align-items:center;justify-content:center;border:3px solid white;box-shadow:var(--shadow);transition:var(--transition-fast);position:relative}.marker-pin.visited{opacity:.7}.marker-pin:hover{transform:rotate(-45deg) scale(1.1)}.marker-icon{transform:rotate(45deg);font-size:1.2rem}.marker-favorite{position:absolute;top:-5px;right:-5px;background:var(--warning-yellow);border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.7rem;transform:rotate(45deg);border:2px solid white}.marker-pin.highlighted{animation:pulse 1.5s infinite;z-index:1000!important}.custom-popup .leaflet-popup-content-wrapper{border-radius:var(--border-radius);box-shadow:var(--shadow-lg)}.marker-popup{padding:var(--space-3);min-width:200px}.marker-popup h4{margin-bottom:var(--space-2);color:var(--primary-500);font-size:var(--text-lg);font-weight:var(--font-semibold)}body.dark-mode .marker-popup h4{color:var(--primary-400)}.popup-category{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.5px;font-weight:var(--font-semibold)}.popup-description{font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:var(--space-3);color:var(--text-secondary)}.popup-rating{font-size:var(--text-sm);color:var(--warning-600);margin-bottom:var(--space-3);font-weight:var(--font-medium)}body.dark-mode .popup-rating{color:var(--warning-400)}.popup-details-btn{width:100%;padding:var(--space-3) var(--space-4);background:var(--primary-500);color:#fff;border:1px solid var(--primary-600);border-radius:var(--rounded-md);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-medium);font-size:var(--text-sm);box-shadow:var(--shadow-xs);min-height:36px}.popup-details-btn:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.popup-details-btn:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.location-popup{position:fixed;top:0;left:0;width:100%;height:100%;background:#0a0a0a00;display:none;justify-content:center;align-items:center;z-index:var(--z-popup);padding:var(--space-4);-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .4s ease,backdrop-filter .4s ease}.location-popup[style*="display: flex"]{background:#0a0a0abf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}body.dark-mode .location-popup{background:#000000d9}.popup-content{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--rounded-2xl);width:90%;max-width:780px;max-height:90vh;opacity:0;transform:scale(.9) translateY(20px);transition:opacity .4s ease,transform .4s cubic-bezier(.34,1.56,.64,1)}.location-popup[style*="display: flex"] .popup-content{opacity:1;transform:scale(1) translateY(0);overflow-y:auto;overflow-x:hidden;position:relative;box-shadow:0 0 0 1px #0000000d,0 10px 15px -3px #0000001a,0 25px 50px -12px #00000040,0 50px 100px -20px #00000026;animation:slideInUp .4s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}body.dark-mode .popup-content{background:var(--dark-surface);border-color:var(--dark-surface-2);box-shadow:0 25px 50px -12px #0009}@keyframes slideInUp{0%{transform:translateY(60px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes slideInFromBottom{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.location-popup.tour-mode .popup-content{animation:tourSlideIn .6s cubic-bezier(.22,1,.36,1)}@keyframes tourSlideIn{0%{opacity:0;transform:translate(100%) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.location-popup.tour-mode.slide-out .popup-content{animation:tourSlideOut .5s cubic-bezier(.68,-.55,.265,1.55) forwards}@keyframes tourSlideOut{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(-100%) scale(.95)}}@keyframes successPulse{0%{box-shadow:0 0 #22c55eb3}70%{box-shadow:0 0 0 15px #22c55e00}to{box-shadow:0 0 #22c55e00}}.popup-header{position:sticky;top:0;background:var(--bg-primary);padding:var(--space-4);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2}.popup-header-left{display:none;align-items:center;gap:var(--space-3)}.location-popup.tour-mode .popup-header-left{display:flex}.popup-header-right{display:flex;gap:var(--space-2);align-items:center}body.dark-mode .popup-header{background:#171717f2;border-color:var(--dark-surface-2)}.popup-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);width:40px;height:40px;border-radius:var(--rounded-full);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;color:var(--text-primary);box-shadow:var(--shadow-xs)}.popup-btn:hover{transform:scale(1.08);box-shadow:var(--shadow-sm)}.popup-btn:active{transform:scale(.95)}.popup-btn.close{background:var(--danger-500);color:#fff;border-color:var(--danger-600)}.popup-btn.close:hover{background:var(--danger-600);box-shadow:var(--shadow-md)}.popup-btn.favorite{background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border-primary)}.popup-btn.favorite:hover{background:var(--warning-50);color:var(--warning-600);border-color:var(--warning-200)}.popup-btn.favorite.active{background:var(--warning-500);color:#fff;border-color:var(--warning-600)}.popup-btn.favorite.active:hover{background:var(--warning-600)}.popup-btn.share{background:var(--primary-500);color:#fff;border-color:var(--primary-600)}.popup-btn.share:hover{background:var(--primary-600)}.popup-body{padding:var(--space-8)}.detail-header h2{background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-500) 50%,var(--primary-600) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% 100%;margin-bottom:var(--space-4);font-size:var(--text-4xl);font-weight:var(--font-bold);line-height:var(--leading-tight);letter-spacing:-.5px;animation:shimmer 3s ease-in-out infinite,fadeInUp .5s cubic-bezier(.16,1,.3,1);position:relative}@keyframes shimmer{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}body.dark-mode .detail-header h2{background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-300) 50%,var(--primary-400) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% 100%}.detail-badges{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-6)}.detail-badges>*{animation:fadeInUp .4s cubic-bezier(.16,1,.3,1) backwards}.detail-badges>*:nth-child(1){animation-delay:.05s}.detail-badges>*:nth-child(2){animation-delay:.1s}.detail-badges>*:nth-child(3){animation-delay:.15s}.detail-badges>*:nth-child(4){animation-delay:.2s}.detail-badges>*:nth-child(5){animation-delay:.25s}.category-badge,.rating-badge,.distance-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--rounded-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.5px;border:1px solid transparent;transition:all var(--transition-fast)}.category-badge{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-primary)}.category-badge.nature{background:var(--success-50);color:var(--success-700);border-color:var(--success-200)}body.dark-mode .category-badge.nature{background:#22c55e26;color:var(--success-400);border-color:#22c55e4d}.category-badge.histoire{background:var(--danger-50);color:var(--danger-700);border-color:var(--danger-200)}body.dark-mode .category-badge.histoire{background:#ef444426;color:var(--danger-400);border-color:#ef44444d}.category-badge.villes{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-200)}body.dark-mode .category-badge.villes{background:#3b82f626;color:var(--primary-400);border-color:#3b82f64d}.category-badge.culture{background:var(--purple-50);color:var(--purple-700);border-color:var(--purple-200)}body.dark-mode .category-badge.culture{background:#a855f726;color:var(--purple-400);border-color:#a855f74d}.rating-badge{background:var(--warning-50);color:var(--warning-700);border-color:var(--warning-200)}body.dark-mode .rating-badge{background:#f59e0b26;color:var(--warning-400);border-color:#f59e0b4d}.distance-badge{background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border-primary)}body.dark-mode .distance-badge{background:var(--dark-surface-2);color:var(--dark-text-secondary);border-color:var(--dark-surface)}.detail-image{margin-bottom:var(--space-8);border-radius:var(--rounded-2xl);overflow:hidden;box-shadow:0 0 0 1px #0000000d,0 10px 25px #0000001f,0 20px 40px #00000014;border:1px solid rgba(255,255,255,.1);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;animation:fadeIn .6s ease-out .2s backwards}.detail-image:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,#0000,#00000005,#0000001a);opacity:0;transition:opacity .4s ease;pointer-events:none}.detail-image:hover{box-shadow:0 0 0 1px #00000014,0 15px 35px #00000026,0 30px 60px #0000001f,0 0 50px #3b82f626;transform:translateY(-4px) scale(1.01)}.detail-image:hover:after{opacity:1}body.dark-mode .detail-image{border-color:#4040404d;box-shadow:0 0 0 1px #ffffff0d,0 10px 25px #0006,0 20px 40px #0000004d}body.dark-mode .detail-image:hover{box-shadow:0 0 0 1px #ffffff14,0 15px 35px #00000080,0 30px 60px #0006,0 0 50px #3b82f633}.detail-image img{width:100%;height:auto;display:block;object-fit:cover;transition:transform .4s cubic-bezier(.4,0,.2,1)}.detail-image:hover img{transform:scale(1.05)}.detail-content .description{line-height:1.8;margin-bottom:1.5rem;color:var(--light-text)}body.dark-mode .detail-content .description{color:var(--dark-text)}.tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-6)}.tags .tag{animation:scaleIn .3s cubic-bezier(.16,1,.3,1) backwards}.tags .tag:nth-child(1){animation-delay:.05s}.tags .tag:nth-child(2){animation-delay:.08s}.tags .tag:nth-child(3){animation-delay:.11s}.tags .tag:nth-child(4){animation-delay:.14s}.tags .tag:nth-child(5){animation-delay:.17s}.tags .tag:nth-child(6){animation-delay:.2s}.tags .tag:nth-child(7){animation-delay:.23s}.tag{background:linear-gradient(135deg,#fff9,#f5f5f5cc);color:var(--text-secondary);padding:var(--space-2) var(--space-4);border-radius:var(--rounded-full);font-size:var(--text-xs);font-weight:var(--font-semibold);border:1px solid rgba(229,229,229,.6);transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 8px #0000000a;position:relative;overflow:hidden}.tag:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s ease}.tag:hover{background:linear-gradient(135deg,#3b82f626,#93c5fd33);color:var(--primary-700);border-color:#3b82f666;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.tag:hover:before{left:100%}body.dark-mode .tag{background:linear-gradient(135deg,#262626cc,#171717e6);color:var(--dark-text-secondary);border-color:#40404099}body.dark-mode .tag:hover{background:linear-gradient(135deg,#3b82f633,#93c5fd26);color:var(--primary-300);border-color:#3b82f680}.detail-info{background:linear-gradient(135deg,#fffffff2,#fafafafa);border:1px solid rgba(229,229,229,.5);border-radius:var(--rounded-xl);padding:var(--space-5);margin-bottom:var(--space-6);box-shadow:0 0 0 1px #00000005,0 2px 4px #0000000a,0 8px 16px #0000000f;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.detail-info:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-400) 0%,var(--primary-500) 50%,var(--primary-400) 100%);opacity:0;transition:opacity .3s ease}.detail-info:hover{transform:translateY(-2px);box-shadow:0 0 0 1px #00000008,0 4px 8px #0000000f,0 12px 24px #0000001a,0 0 40px #3b82f61a;border-color:#93c5fd66}.detail-info:hover:before{opacity:1}body.dark-mode .detail-info{background:linear-gradient(135deg,#262626f2,#171717fa);border-color:#40404080}body.dark-mode .detail-info:hover{box-shadow:0 0 0 1px #ffffff0d,0 4px 8px #0000004d,0 12px 24px #0006,0 0 40px #3b82f626;border-color:#3b82f64d}.info-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);color:var(--text-primary);border-radius:var(--rounded-lg);transition:all .2s cubic-bezier(.4,0,.2,1);margin:0 calc(-1 * var(--space-2))}.info-item:hover{background:#3b82f60a;transform:translate(4px);margin-left:calc(-1 * var(--space-2) + 4px)}.info-item:not(:last-child){border-bottom:1px solid rgba(229,229,229,.4)}body.dark-mode .info-item:hover{background:#3b82f614}body.dark-mode .info-item:not(:last-child){border-color:#40404066}.info-icon{font-size:var(--text-xl);color:var(--primary-500);display:flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0;background:linear-gradient(135deg,#3b82f614,#93c5fd1f);border-radius:var(--rounded-lg);transition:all .3s cubic-bezier(.4,0,.2,1)}.info-item:hover .info-icon{transform:scale(1.1) rotate(5deg);background:linear-gradient(135deg,#3b82f626,#93c5fd33);box-shadow:0 0 20px #3b82f633}body.dark-mode .info-icon{color:var(--primary-400);background:linear-gradient(135deg,#3b82f61f,#93c5fd14)}body.dark-mode .info-item:hover .info-icon{background:linear-gradient(135deg,#3b82f633,#93c5fd26)}.info-item strong{color:var(--text-primary);font-weight:var(--font-semibold)}.contact-info{display:flex;gap:1rem;margin-bottom:1.5rem}.contact-link{flex:1;padding:var(--space-3) var(--space-4);background:var(--primary-500);color:#fff;text-decoration:none;border:1px solid var(--primary-600);border-radius:var(--rounded-md);text-align:center;transition:all var(--transition-fast);font-weight:var(--font-medium);font-size:var(--text-sm);box-shadow:var(--shadow-xs);display:inline-block;min-height:36px;line-height:1.5}.contact-link:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.contact-link:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.location-nav{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-6);border-top:1px solid var(--border-primary);gap:var(--space-4)}body.dark-mode .location-nav{border-color:var(--dark-surface-2)}.location-nav button{background:var(--bg-secondary);border:1px solid var(--border-primary);padding:var(--space-3) var(--space-6);border-radius:var(--rounded-md);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-medium);font-size:var(--text-sm);color:var(--text-primary);box-shadow:var(--shadow-xs);min-height:36px}body.dark-mode .location-nav button{background:var(--dark-surface-2);border-color:var(--dark-surface);color:var(--dark-text)}.location-nav button:hover:not(:disabled){background:var(--primary-500);color:#fff;border-color:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.location-nav button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-xs)}.location-nav button:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.nav-counter{font-weight:600;color:var(--light-text-secondary)}.popup-footer{padding:1rem 2rem 2rem;display:flex;gap:var(--space-3)}.popup-action-btn{flex:1;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--rounded-lg);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm);font-weight:var(--font-medium);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);color:var(--text-primary);box-shadow:var(--shadow-xs);min-height:40px}body.dark-mode .popup-action-btn{background:var(--dark-surface-2);border-color:var(--dark-surface);color:var(--dark-text)}.popup-action-btn:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.popup-action-btn:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.tour-controls{display:none}.tour-controls-inline{display:flex;align-items:center;gap:var(--space-3);flex:1}.tour-progress-inline{display:flex;align-items:center;gap:var(--space-2);flex:1;max-width:300px}.tour-progress-bar-small{flex:1;height:4px;background:var(--bg-secondary);border-radius:var(--rounded-full);overflow:hidden}body.dark-mode .tour-progress-bar-small{background:var(--dark-surface-2)}.tour-progress-bar-small .tour-progress{height:100%;background:var(--primary-500);transition:width .3s ease}.tour-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:var(--space-3)}.tour-header h3{margin:0;font-size:1.1rem;color:var(--light-text);flex:1}body.dark-mode .tour-header h3{color:var(--dark-text)}.tour-toggle{display:none;background:var(--primary-500);border:none;border-radius:var(--rounded-lg);width:36px;height:36px;cursor:pointer;font-size:1.2rem;transition:all .2s ease}.tour-toggle:hover{background:var(--primary-600);transform:scale(1.05)}.tour-toggle:active{transform:scale(.95)}.tour-time{font-family:Courier New,monospace;font-size:1rem;color:var(--light-text-secondary)}.tour-main{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.tour-nav{background:var(--bg-secondary);border:1px solid var(--border-primary);width:40px;height:40px;border-radius:var(--rounded-full);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-lg);color:var(--text-primary);box-shadow:var(--shadow-xs);display:flex;align-items:center;justify-content:center}.tour-nav:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-600);transform:scale(1.05);box-shadow:var(--shadow-sm)}.tour-nav:active{transform:scale(.95)}body.dark-mode .tour-nav{background:var(--dark-surface-2);border-color:var(--dark-surface)}.play-pause{width:60px;height:60px;border-radius:var(--rounded-full);background:var(--primary-500);color:#fff;border:2px solid var(--primary-600);cursor:pointer;position:relative;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.play-pause:hover{background:var(--primary-600);transform:scale(1.08);box-shadow:var(--shadow-lg)}.play-pause:active{transform:scale(.95);box-shadow:var(--shadow-sm)}.play-icon,.pause-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;transition:var(--transition-fast)}.pause-icon,.tour-controls.playing .play-icon{opacity:0}.tour-controls.playing .pause-icon{opacity:1}.tour-progress-container{margin-bottom:1rem}.tour-progress-bar{width:100%;height:8px;background:var(--light-surface-2);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.tour-progress{height:100%;background:linear-gradient(90deg,var(--primary-blue),var(--purple));transition:width .5s ease;border-radius:4px}.tour-counter{text-align:center;font-size:.9rem;color:var(--light-text-secondary);display:block}.tour-speed{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem;background:var(--light-surface);border-radius:var(--border-radius-sm)}body.dark-mode .tour-speed{background:var(--dark-surface-2)}.tour-speed label{font-size:.85rem;color:var(--light-text-secondary)}#tour-speed-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--light-surface-2);border-radius:2px;outline:none}#tour-speed-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--primary-blue);border-radius:50%;cursor:pointer}#tour-speed-slider::-moz-range-thumb{width:16px;height:16px;background:var(--primary-blue);border-radius:50%;cursor:pointer;border:none}#tour-speed-value{font-weight:600;color:var(--primary-blue);min-width:30px}.tour-advanced{display:block;transition:max-height .3s ease,opacity .3s ease;overflow:hidden}.tour-actions{display:flex;gap:var(--space-3);margin-top:var(--space-3)}.tour-btn.restart,.tour-btn.stop{flex:1;padding:var(--space-3) var(--space-4);color:#fff;border-radius:var(--rounded-lg);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-medium);font-size:var(--text-sm);box-shadow:var(--shadow-sm);min-height:40px;border:none}.tour-btn.restart{background:var(--primary-500)}.tour-btn.restart:hover{background:var(--primary-600);transform:translateY(-1px);box-shadow:var(--shadow-md)}.tour-btn.stop{background:var(--danger-500)}.tour-btn.stop:hover{background:var(--danger-600);transform:translateY(-1px);box-shadow:var(--shadow-md)}.tour-btn.restart:active,.tour-btn.stop:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.toast-container{position:fixed;top:1rem;right:1rem;z-index:var(--z-toast);display:flex;flex-direction:column;gap:.75rem;pointer-events:none}.toast{background:#fff;border-radius:var(--border-radius-sm);box-shadow:var(--shadow-lg);padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem;min-width:250px;transform:translate(400px);transition:transform .3s ease;pointer-events:auto}body.dark-mode .toast{background:var(--dark-surface);color:var(--dark-text)}.toast.show{transform:translate(0)}.toast-icon{font-size:1.2rem}.toast-message{flex:1}.toast-success{border-left:4px solid var(--success-green)}.toast-error{border-left:4px solid var(--danger-red)}.toast-warning{border-left:4px solid var(--warning-yellow)}.toast-info{border-left:4px solid var(--primary-blue)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0a0a0abf;display:none;justify-content:center;align-items:center;z-index:var(--z-modal);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--space-4);animation:fadeIn .2s ease}body.dark-mode .modal{background:#000000d9}.modal-content{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--rounded-2xl);padding:var(--space-8);max-width:440px;width:90%;box-shadow:0 25px 50px -12px #00000059;animation:scaleIn .25s cubic-bezier(.16,1,.3,1)}body.dark-mode .modal-content{background:var(--dark-surface);border-color:var(--dark-surface-2);box-shadow:0 25px 50px -12px #0009}.modal-content h3{margin-bottom:var(--space-6);color:var(--text-primary);font-size:var(--text-2xl);font-weight:var(--font-bold)}body.dark-mode .modal-content h3{color:var(--dark-text)}.confirm-modal{text-align:center;max-width:420px}.confirm-icon{font-size:3.5rem;margin-bottom:var(--space-4);animation:pulse 2s ease-in-out infinite}.confirm-modal h3{margin-bottom:var(--space-3);font-size:var(--text-xl)}.confirm-modal p{color:var(--text-secondary);margin-bottom:var(--space-6);font-size:var(--text-base)}body.dark-mode .confirm-modal p{color:var(--dark-text-secondary)}.confirm-actions{display:flex;gap:var(--space-3);justify-content:center}.btn-confirm,.btn-cancel{flex:1;padding:var(--space-4) var(--space-6);border-radius:var(--rounded-lg);font-weight:var(--font-semibold);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-fast);border:none}.btn-confirm{background:var(--red-500);color:#fff}.btn-confirm:hover{background:var(--red-600);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-cancel{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-cancel:hover{background:var(--bg-tertiary);transform:translateY(-1px)}body.dark-mode .btn-cancel{background:var(--dark-surface-2);color:var(--dark-text);border-color:var(--dark-border)}body.dark-mode .btn-cancel:hover{background:var(--dark-surface-3)}.share-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.share-option{padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--rounded-lg);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm);font-weight:var(--font-medium);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--text-primary);box-shadow:var(--shadow-xs);min-height:80px;justify-content:center}body.dark-mode .share-option{background:var(--dark-surface-2);color:var(--dark-text);border-color:var(--dark-surface)}.share-option:hover{background:var(--primary-500);color:#fff;border-color:var(--primary-600);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.share-option:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.modal-close{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--rounded-md);cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-medium);font-size:var(--text-sm);color:var(--text-primary);box-shadow:var(--shadow-xs);min-height:40px}body.dark-mode .modal-close{background:var(--dark-surface-2);border-color:var(--dark-surface);color:var(--dark-text)}.modal-close:hover{background:var(--danger-500);color:#fff;border-color:var(--danger-600);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.modal-close:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.leaflet-control-zoom{border:none!important;box-shadow:var(--shadow)!important}.leaflet-control-zoom a{background:#fff!important;color:var(--light-text)!important;border:none!important;width:36px!important;height:36px!important;line-height:36px!important}body.dark-mode .leaflet-control-zoom a{background:var(--dark-surface)!important;color:var(--dark-text)!important}.leaflet-control-zoom a:hover{background:var(--primary-blue)!important;color:#fff!important}.burger-menu{display:none;position:fixed;top:5rem;left:1rem;z-index:1000;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--rounded-lg);box-shadow:var(--shadow-lg);padding:var(--space-2);cursor:pointer;width:48px;height:48px;flex-direction:column;align-items:center;justify-content:center;gap:4px;pointer-events:none;opacity:0}body:has(#map[style*="display: block"]) .burger-menu{pointer-events:auto;opacity:1}body.dark-mode .burger-menu{background:var(--dark-surface);border-color:var(--dark-surface-2)}.burger-menu span{display:block;width:24px;height:3px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}body.dark-mode .burger-menu span{background:var(--dark-text)}.burger-menu.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.burger-menu.active span:nth-child(2){opacity:0}.burger-menu.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu-panel{display:none;position:fixed;top:0;right:-100%;width:80%;max-width:300px;height:100vh;background:var(--bg-primary);border-left:1px solid var(--border-primary);box-shadow:var(--shadow-xl);z-index:999;padding:5rem var(--space-4) var(--space-4);overflow-y:auto;pointer-events:none;transition:right .3s ease}body.dark-mode .mobile-menu-panel{background:var(--dark-surface);border-color:var(--dark-surface-2)}.mobile-menu-panel.active{right:0;pointer-events:auto}.mobile-menu-section{margin-bottom:var(--space-6)}.mobile-menu-section h3{font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-3);color:var(--text-secondary)}body.dark-mode .mobile-menu-section h3{color:var(--dark-text-secondary)}.mobile-menu-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100vh;background:#00000080;z-index:998;opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-menu-overlay.active{opacity:1;pointer-events:auto}@media (max-width: 768px){.burger-menu{display:flex}.mobile-menu-panel,.mobile-menu-overlay{display:block}.filter-controls,.home-control,.favorites-control{display:none!important}.home-stats{gap:2rem}.home-buttons{flex-direction:column;width:100%;max-width:300px}.home-btn{width:100%}.home-features{flex-wrap:wrap;gap:1rem}.location-popup{z-index:15000!important}.tour-controls{z-index:25000!important}.popup-content{width:100%;max-width:100%;max-height:100vh;height:100vh;margin:0;border-radius:0;animation:slideInFromBottom .3s cubic-bezier(.16,1,.3,1)}.popup-body{padding:var(--space-4)}.dark-mode-toggle,.favorites-control,.home-control,.filter-controls{z-index:100!important}.search-container{z-index:1000!important;width:95%;top:.5rem}.popup-footer{flex-direction:column;gap:var(--space-3)}.popup-btn{width:44px;height:44px}.popup-action-btn{min-height:48px;padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.contact-link{min-height:48px;padding:var(--space-4) var(--space-5);font-size:var(--text-base)}.info-item{padding:var(--space-5);margin:0 calc(-1 * var(--space-3))}.tag{padding:var(--space-3) var(--space-5);font-size:var(--text-sm)}.popup-header{padding:var(--space-3);gap:var(--space-2)}.tour-controls-inline{gap:var(--space-1)}.tour-progress-inline{display:none}.tour-counter{font-size:.65rem;white-space:nowrap}.tour-time{display:none}.tour-nav,.play-pause{min-width:36px;min-height:36px;width:36px;height:36px;font-size:.9rem;padding:0}.popup-header-left{gap:var(--space-1)}.popup-btn{width:36px;height:36px}.favorites-panel{width:280px;max-width:85vw}.favorites-control,.home-control{min-width:52px;min-height:52px}.search-container{width:95%;top:.5rem}.search-container input{min-height:48px;font-size:var(--text-base)}.share-options{grid-template-columns:1fr;gap:var(--space-4)}.share-option{min-height:56px;padding:var(--space-4)}.detail-header h2{font-size:var(--text-3xl);margin-bottom:var(--space-5)}.detail-badges{gap:var(--space-3);margin-bottom:var(--space-5)}.detail-content .description{font-size:var(--text-base);line-height:1.7}}@media (max-width: 480px){.home{padding:var(--space-4)}.title-main{font-size:2.5rem;line-height:1.1}.title-accent{font-size:1rem}.home-stats{flex-direction:column;gap:var(--space-4)}.stat-card{padding:var(--space-4)}.dark-mode-toggle{width:52px;height:52px;font-size:1.5rem}.tour-main{gap:var(--space-2);flex-wrap:wrap}.tour-nav{min-width:48px;min-height:48px}.play-pause{min-width:52px;min-height:52px}body{font-size:16px}.popup-header{padding:var(--space-3);gap:var(--space-3)}.detail-header h2{font-size:var(--text-2xl)}.category-badge,.rating-badge,.distance-badge{font-size:var(--text-xs);padding:var(--space-2) var(--space-3)}.contact-info{flex-direction:column;gap:var(--space-3)}.contact-link{width:100%}}@media print{.dark-mode-toggle,.search-container,.tour-controls,.favorites-panel,.filter-controls,.home-control,.favorites-control{display:none!important}.location-popup{position:static;display:block;background:none}.popup-content{box-shadow:none;max-width:100%}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:3px solid var(--primary-500);outline-offset:3px;border-radius:var(--rounded-sm)}body.dark-mode :focus-visible{outline-color:var(--primary-400)}:focus-within{outline:2px solid transparent}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--primary-500);outline-offset:2px;box-shadow:0 0 0 4px #3b82f61a}body.dark-mode button:focus-visible,body.dark-mode a:focus-visible,body.dark-mode input:focus-visible{box-shadow:0 0 0 4px #3b82f633}.skip-to-main{position:absolute;top:-100px;left:0;background:var(--primary-500);color:#fff;padding:var(--space-3) var(--space-4);text-decoration:none;border-radius:var(--rounded-md);z-index:100000;transition:top .2s ease}.skip-to-main:focus{top:var(--space-4);left:var(--space-4)}@media (prefers-contrast: high){:root{--border-primary: #000000;--text-primary: #000000}body.dark-mode{--border-primary: #ffffff;--text-primary: #ffffff}button,a,input{border:2px solid currentColor}}@media (prefers-color-scheme: dark){:root:not(.light-mode){color-scheme:dark}}@media (hover: none) and (pointer: coarse){button,a,input,select{min-height:44px;min-width:44px}}.js-focus-visible :focus:not(.focus-visible){outline:none}[aria-live=polite],[aria-live=assertive]{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.hidden{display:none!important}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.animate-fadeIn{animation:fadeIn .3s ease-out}.animate-fadeInUp{animation:fadeInUp .4s cubic-bezier(.16,1,.3,1)}.animate-scaleIn{animation:scaleIn .3s cubic-bezier(.16,1,.3,1)}.animate-slideInRight{animation:slideInRight .3s cubic-bezier(.16,1,.3,1)}.animate-bounce{animation:bounce 1s ease-in-out infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.loading{pointer-events:none;opacity:.6;position:relative}.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--primary-500);border-radius:50%;border-top-color:transparent;animation:spin .6s linear infinite}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite;border-radius:var(--rounded-md)}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}body.dark-mode .skeleton{background:linear-gradient(90deg,var(--dark-surface) 25%,var(--dark-surface-2) 50%,var(--dark-surface) 75%);background-size:200% 100%}html{scroll-behavior:smooth}img{content-visibility:auto}.will-animate{will-change:transform,opacity}.success-feedback{animation:successPulse .6s ease-out}
