:root{--color-primary: #3498db;--color-primary-dark: #2980b9;--color-accent: #667eea;--color-accent-dark: #764ba2;--color-accent-purple: #9b59b6;--color-success: #2e7d32;--color-text-dark: #2c3e50;--color-text-muted: #7f8c8d;--color-surface: #f8f9fa;--color-place-type: #64b5f6;--color-google-blue: #1a73e8;--font-system: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--btn-top: 20px;--btn-top-mobile: 10px;--sidebar-width: 320px;--sidebar-collapsed: 60px;--modal-radius: 12px;--portfolio-radius: 20px;--transition-fast: .2s ease;--transition-base: .3s ease;--transition-slow: .8s ease;--transition-spring: .3s cubic-bezier(.4, 0, .2, 1);--glass-bg: rgba(0, 0, 0, .25);--glass-border: rgba(255, 255, 255, .25);--glass-blur: blur(16px) saturate(180%);--overlay-bg: rgba(0, 0, 0, .4)}*{margin:0;padding:0;box-sizing:border-box}body{overflow-x:hidden;background:#000;font-family:var(--font-system)}#canvas-container{position:fixed;top:0;left:0;width:100%;height:100vh;z-index:1}canvas{display:block}.content{position:relative;z-index:2;height:600vh;pointer-events:none}@media(max-width:768px){.content{height:650vh;-webkit-overflow-scrolling:touch;overscroll-behavior:none}body{overscroll-behavior:none;-webkit-overflow-scrolling:touch;overscroll-behavior-y:none;background:#000;min-height:100vh;height:auto}html{overscroll-behavior:none;overscroll-behavior-y:none;background:#000}*{overscroll-behavior:none}button,.contact-link,.close-portfolio{min-height:44px;min-width:44px}.info{top:10px;left:10px;padding:8px;font-size:12px}#top-toolbar{top:var(--btn-top-mobile);right:10px;gap:8px;max-width:calc(100% - 20px)}#top-toolbar button{font-size:12px!important}#skip-button,#skip-showcase-btn{padding:12px 20px!important}#reopen-portfolio-btn.visible,#reopen-showcase-btn.visible{padding:10px 18px!important}}.info{position:fixed;top:20px;left:20px;color:#fff;z-index:3;font-size:14px;background:#00000080;padding:10px;border-radius:5px}#google-earth-container{position:fixed;top:0;left:0;width:100%;height:100vh;z-index:0;opacity:0;pointer-events:none;transition:none;visibility:visible}#google-earth-container.visible{pointer-events:auto}#maptiler-map{width:100%;height:100%}#scroll-indicator{position:fixed;bottom:53px;left:50%;transform:translate(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;opacity:1;transition:all var(--transition-base)}#scroll-indicator.hidden{opacity:0;pointer-events:none;transform:translate(-50%) translateY(20px)}#scroll-indicator.animating{opacity:.7;pointer-events:none}.scroll-text{color:#fff;font-size:14px;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.5);margin-bottom:4px;transition:all var(--transition-base)}.scroll-arrow{width:40px;height:40px;border:2px solid rgba(255,255,255,.8);border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-base);animation:bounce 2s infinite}.scroll-arrow:hover{border-color:#fff;background:#fff3;transform:scale(1.1)}.arrow-icon{width:12px;height:12px;border-right:2px solid white;border-bottom:2px solid white;transform:rotate(45deg);margin-top:-3px}.scroll-line{width:1px;height:20px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.5),transparent);margin-top:8px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}.progress-indicator{display:none;align-items:center;gap:8px;color:#fff;font-size:12px;text-shadow:0 2px 4px rgba(0,0,0,.5)}#scroll-indicator.animating .scroll-text,#scroll-indicator.animating .scroll-arrow,#scroll-indicator.animating .scroll-line{display:none}#scroll-indicator.animating .progress-indicator{display:flex}.progress-bar{width:60px;height:2px;background:#ffffff4d;border-radius:1px;overflow:hidden}.progress-fill{height:100%;background:#fff;width:0%;transition:width .1s ease}#portfolio-overlay,#showcase-overlay{position:fixed;top:0;left:0;width:100%;height:100%;height:100dvh;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:15;opacity:0;pointer-events:none;transition:all .8s ease;display:flex;align-items:center;justify-content:center}#portfolio-overlay.visible,#showcase-overlay.visible{opacity:1;pointer-events:auto}.portfolio-wrapper{max-width:800px;width:90%;max-height:80vh;background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 25px 50px #0000004d;transform:translateY(50px);transition:transform .8s ease;position:relative;display:flex;flex-direction:column;padding:20px 0}#portfolio-overlay.visible .portfolio-wrapper,#showcase-overlay.visible .portfolio-wrapper{transform:translateY(0)}.portfolio-content{flex:1;padding:0 40px;overflow-y:auto;position:relative;overscroll-behavior:none;-webkit-overflow-scrolling:touch;border-radius:8px}.portfolio-content:after{content:"";display:block;height:20px}.portfolio-header{text-align:center;margin-bottom:30px;display:flex;flex-direction:column;align-items:center;gap:20px}.profile-photo{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--color-primary);box-shadow:0 8px 20px #00000026;transition:transform .3s ease}.profile-photo:hover{transform:scale(1.05)}.header-text{flex:1}.portfolio-title{font-size:2.5rem;font-weight:700;color:var(--color-text-dark);margin-bottom:10px}.portfolio-subtitle{font-size:1.2rem;color:var(--color-text-muted);margin-bottom:20px}.location-badge{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 16px;border-radius:25px;font-size:.9rem;font-weight:500}.portfolio-section{margin-bottom:25px}.section-title{font-size:1.4rem;font-weight:600;color:var(--color-text-dark);margin-bottom:15px;border-bottom:2px solid var(--color-primary);padding-bottom:5px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-top:15px}.skill-tag{background:#ecf0f1;color:var(--color-text-dark);padding:8px 12px;border-radius:15px;display:flex;align-items:center;justify-content:center;text-align:center;font-size:.9rem;font-weight:500}.experience-item{background:var(--color-surface);border-radius:10px;padding:20px;margin-bottom:15px;border-left:4px solid var(--color-primary)}.experience-title{font-weight:600;color:var(--color-text-dark);font-size:1.1rem}.experience-company{color:var(--color-text-muted);font-size:.95rem;margin-bottom:8px}.experience-description{color:#34495e;line-height:1.6;font-size:.95rem}.close-portfolio{position:absolute;top:20px;right:20px;background:#0000000d;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);z-index:10}.close-portfolio:hover{background:#ecf0f1;color:var(--color-text-dark)}.contact-links{display:flex;justify-content:center;gap:20px;margin-top:25px}.contact-link{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-primary);color:#fff;text-decoration:none;border-radius:25px;font-weight:500;transition:all var(--transition-base)}.contact-link:hover{background:var(--color-primary-dark);transform:translateY(-2px)}#top-toolbar{position:fixed;top:var(--btn-top);right:20px;z-index:12;display:flex;gap:12px;pointer-events:none;justify-content:flex-end;align-items:center}#top-toolbar button{pointer-events:auto;position:relative!important;top:auto!important;right:auto!important;left:auto!important;margin:0!important;transition:opacity var(--transition-base),transform var(--transition-base),max-width var(--transition-base),padding var(--transition-base),margin var(--transition-base),border-width var(--transition-base),background var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base);max-width:250px;min-width:auto!important;opacity:1;transform:translateY(0);overflow:hidden;display:flex;align-items:center;justify-content:center;white-space:nowrap;font-family:var(--font-system);flex-shrink:1}#skip-button,#skip-showcase-btn{padding:16px 32px;background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);color:#fffffff2;border:1px solid var(--glass-border);border-radius:30px;font-size:14px;font-weight:600;cursor:pointer;text-shadow:0 2px 8px rgba(0,0,0,.8);box-shadow:0 8px 32px #00000040,0 4px 16px #00000026,inset 0 1px #fff3,inset 0 -1px #0003;letter-spacing:.6px}#skip-button:before,#skip-showcase-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}#skip-button:hover,#skip-showcase-btn:hover{background:#0006;border-color:#ffffff59;color:#fff;transform:translateY(-3px) scale(1.02);box-shadow:0 12px 40px #00000059,0 6px 20px #00000040,inset 0 1px #ffffff40,inset 0 -1px #00000026;backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%)}#skip-button:hover:before,#skip-showcase-btn:hover:before{left:100%}#skip-button:active,#skip-showcase-btn:active{transform:translateY(-1px) scale(.98);box-shadow:0 6px 20px #0000004d,0 3px 10px #0003,inset 0 1px #ffffff26,inset 0 -1px #00000040}#top-toolbar button.hidden,#reopen-portfolio-btn:not(.visible),#reopen-showcase-btn:not(.visible){max-width:0!important;min-width:0!important;min-height:0!important;padding:0!important;border-width:0!important;opacity:0!important;pointer-events:none!important;transform:translateY(-10px)!important;margin:0!important;box-shadow:none!important}#reopen-portfolio-btn,#reopen-showcase-btn{padding:12px 24px;background:#3498dbe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(52,152,219,.6);border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;text-shadow:0 1px 2px rgba(0,0,0,.2);box-shadow:0 4px 15px #3498db4d}#reopen-portfolio-btn.visible,#reopen-showcase-btn.visible{max-width:250px!important;padding:12px 24px!important;border-left-width:1px!important;border-right-width:1px!important;opacity:1!important;pointer-events:auto!important;transform:translateY(0)!important}#reopen-portfolio-btn:hover{background:var(--color-primary-dark);border-color:#3498dbcc;transform:translateY(-1px);box-shadow:0 6px 20px #3498db66}#reopen-portfolio-btn:active,#reopen-showcase-btn:active{transform:translateY(0)}#reopen-showcase-btn{background:#9b59b6e6;border-color:#9b59b699;box-shadow:0 4px 15px #9b59b64d}#reopen-showcase-btn:hover{background:#9b59b6;border-color:#9b59b6cc;box-shadow:0 6px 20px #9b59b666}#back-to-beginning-btn{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:#2e7d3299;border:1px solid rgba(46,125,50,.8);color:#ffffffe6;padding:15px 25px;border-radius:30px;font-size:16px;font-weight:500;cursor:pointer;transition:all var(--transition-base);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);font-family:var(--font-system);z-index:1000;box-shadow:0 4px 15px #2e7d324d;pointer-events:auto}@media(max-width:768px){#back-to-beginning-btn{padding:12px;border-radius:50%;width:50px;height:50px;font-size:0;display:flex;align-items:center;justify-content:center;bottom:20px}#back-to-beginning-btn:before{content:"↑";font-size:20px;font-weight:700;line-height:1}}#back-to-beginning-btn.hidden{opacity:0;pointer-events:none;transform:translate(-50%) translateY(10px)}#back-to-beginning-btn:hover{background:#2e7d32;border-color:#2e7d32cc;transform:translate(-50%) translateY(-2px);box-shadow:0 6px 20px #2e7d3266}#back-to-beginning-btn:active{transform:translate(-50%)}@media(max-width:768px){#back-to-beginning-btn:hover{transform:translate(-50%) translateY(-2px) scale(1.1)}#back-to-beginning-btn:active{transform:translate(-50%) scale(.95)}}.portfolio-content::-webkit-scrollbar{width:8px}.portfolio-content::-webkit-scrollbar-track{background-color:#0000000d;border-radius:8px}.portfolio-content::-webkit-scrollbar-thumb{background-color:#0000004d;border-radius:8px;transition:background-color .3s ease}.portfolio-content::-webkit-scrollbar-thumb:hover{background-color:#00000080}.portfolio-content{scrollbar-width:thin;scrollbar-color:var(--color-primary) rgba(0,0,0,.1)}.portfolio-content{scroll-behavior:smooth}@media(max-width:768px){.portfolio-content{padding:30px 20px;width:95%;max-height:75dvh;margin-bottom:8dvh}.portfolio-title{font-size:2rem}.profile-photo{width:100px;height:100px}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.contact-links{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:8px}.contact-link{padding:8px 16px!important;font-size:13px;flex:0 1 auto}.portfolio-content::-webkit-scrollbar{width:10px}}#footer{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:5;background:transparent;color:#fff6;padding:8px 16px;font-size:10px;font-weight:500;letter-spacing:2px;transition:color .4s ease,opacity .4s ease,transform .4s ease;text-align:center;pointer-events:auto;white-space:nowrap}#footer:hover{color:#fffc}#footer.hidden{opacity:0;pointer-events:none;transform:translate(-50%,20px)}.footer-content{display:flex;align-items:center;justify-content:center;gap:12px}.footer-item{display:inline-block}.footer-divider{color:#ffffff26;font-size:10px}@media(max-width:768px){#footer{font-size:8px;letter-spacing:1px;bottom:10px;padding:4px 10px}.footer-content{gap:6px}.footer-divider{font-size:8px}}@media(max-width:480px){#footer{font-size:7px;bottom:6px}.footer-content{flex-direction:column;gap:4px}.footer-divider{display:none}}.photo-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid var(--color-google-blue);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.photo-loading p{margin:0;font-size:14px}.photo-counter{color:#666;font-size:14px;font-weight:500;margin:0 16px}.photo-modal-content{position:relative}@media(max-width:768px){.photo-modal{max-width:95vw;max-height:95vh}.photo-modal-header{padding:12px 16px}.photo-modal-header h3{font-size:16px}.photo-modal-content,.photo-modal-image{max-height:calc(95vh - 60px)}.photo-nav-btn{width:40px;height:40px;font-size:20px}.photo-nav-prev{left:10px}.photo-nav-next{right:10px}.photo-counter{font-size:12px;margin:0 8px}}.photosphere-reset,.photosphere-fullscreen,.photosphere-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;padding:8px 12px;border-radius:6px;font-size:14px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;pointer-events:auto;z-index:10001;position:relative}#photosphere-canvas .psv-container,#photosphere-canvas .psv-canvas-container{width:100%!important;height:100%!important}.photosphere-instructions{position:absolute;bottom:45px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:12px 20px;border-radius:20px;font-size:14px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);z-index:10}.photosphere-modal.fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;max-width:none;max-height:none;border-radius:0;z-index:10001}.photosphere-modal.fullscreen .photosphere-instructions{bottom:30px}@media(max-width:768px){.photosphere-modal{width:95vw;height:95vh}.photosphere-modal-header{padding:12px 16px}.photosphere-modal-header h3{font-size:16px}.photosphere-controls{gap:6px}.photosphere-reset,.photosphere-fullscreen,.photosphere-close{padding:6px 10px;min-width:32px;height:32px;font-size:12px}.photosphere-instructions{bottom:15px;padding:10px 16px;font-size:12px}.photo-nav-btn{width:40px;height:40px;font-size:20px}.photo-nav-prev{left:10px}.photo-nav-next{right:10px}.photo-counter{font-size:12px;margin:0 8px}}.photo-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#000000b3;border:none;color:#fff;font-size:24px;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;-webkit-user-select:none;user-select:none}.photo-nav-btn:hover:not(:disabled){background:#000000e6;transform:translateY(-50%) scale(1.1)}.photo-nav-btn:disabled{opacity:.3;cursor:not-allowed}.photo-nav-prev{left:20px}.photo-nav-next{right:20px}.photosphere-container{position:relative}.photo-counter{color:#ccc;font-size:14px;font-weight:500;margin:0 16px}.custom-popup .maplibregl-popup-content{padding:0;border-radius:8px;box-shadow:0 4px 20px #00000026}.place-popup{padding:16px;font-family:var(--font-system)}.popup-title{margin:0 0 8px;color:#333;font-size:16px;font-weight:600}.popup-description{margin:0 0 8px;color:#666;font-size:14px;line-height:1.4}.popup-date{margin:0 0 8px;color:#888;font-size:12px;font-weight:500}.popup-photos{margin-top:12px}.photo-preview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:10px}.photo-preview{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;box-shadow:0 2px 6px #0000001a;cursor:pointer;transition:transform .2s ease}.photo-preview:hover{transform:scale(1.05)}.preview-thumbnail{width:100%;height:100%;object-fit:cover;display:block}.preview-overlay{position:absolute;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.photo-preview:hover .preview-overlay{opacity:1}.preview-icon{color:#fff;font-size:16px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.more-photos-indicator{position:relative;aspect-ratio:1;background:#f0f0f0;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#666;cursor:pointer;transition:background-color .2s ease}.more-photos-indicator:hover{background:#e0e0e0}.photo-actions{text-align:center}.view-all-photos-btn{background:var(--color-google-blue);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s ease;display:inline-flex;align-items:center;gap:6px}.view-all-photos-btn:hover{background:#1557b0}.custom-popup .maplibregl-popup-close-button{color:#666;font-size:18px;padding:4px}.custom-popup .maplibregl-popup-close-button:hover{color:#333}.photo-gallery-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.photo-gallery-modal{background:#fff;border-radius:12px;max-width:90vw;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column}@media(min-width:769px){.photo-gallery-modal{max-width:95vw;max-height:85vh;min-width:800px}.photo-gallery-content{padding:24px}}.photo-gallery-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;background:var(--color-surface)}.photo-gallery-header h3{margin:0;color:#333;font-size:18px;font-weight:600}.photo-gallery-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.photo-gallery-close:hover{background-color:#e9ecef;color:#333}.photo-gallery-content{flex:1;overflow-y:auto;overscroll-behavior:none;padding:20px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}@media(min-width:769px){.photo-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(150px,auto);gap:16px;max-width:100%}.gallery-photo-item{aspect-ratio:1;min-height:150px}}.gallery-photo-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s ease}.gallery-photo-item:hover{transform:scale(1.05)}.gallery-thumbnail{width:100%;height:100%;object-fit:cover;display:block}.gallery-photo-overlay{position:absolute;inset:0;background:#0000004d;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.gallery-photo-item:hover .gallery-photo-overlay{opacity:1}.gallery-photo-icon{color:#fff;font-size:20px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.gallery-photo-caption{color:#fff;font-size:11px;text-shadow:0 1px 3px rgba(0,0,0,.5);margin-top:4px;text-align:center;padding:0 4px}@media(max-width:768px){.photo-gallery-modal{max-width:95vw;max-height:95vh}.photo-gallery-header{padding:12px 16px}.photo-gallery-header h3{font-size:16px}.photo-gallery-content{padding:16px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.gallery-photo-item{aspect-ratio:1;min-height:120px}}@media(max-width:480px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}}.places-list-container{position:fixed;top:0;left:0;height:100vh;z-index:1000;font-family:var(--font-system);background:#0009;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);color:#ffffffe6;border-right:1px solid var(--glass-border);box-shadow:2px 0 16px #0000004d;transition:all var(--transition-spring);display:flex;flex-direction:column}.places-list-container.collapsed{width:60px}.places-list-container:not(.collapsed){width:320px}.places-list-container.mobile{inset:auto 0 0!important;height:auto!important;max-height:70vh!important;width:100%!important;border-radius:20px 20px 0 0!important;box-shadow:0 -4px 20px #00000026!important;transform:translateY(100%)!important;transition:transform .3s cubic-bezier(.4,0,.2,1)!important;z-index:1001!important}.places-list-container.mobile.visible{transform:translateY(0)!important}.places-list-container.mobile.collapsed{transform:translateY(calc(100% - 60px))!important;max-height:60px!important}.places-list-backdrop{position:fixed;inset:0;background:#00000080;z-index:1000;opacity:0;transition:opacity .3s ease;pointer-events:none}.places-list-backdrop.visible{opacity:1;pointer-events:auto}.places-list-header{background:#0006;color:#ffffffe6;padding:16px 20px;font-size:16px;font-weight:500;border-bottom:1px solid rgba(255,255,255,.25);display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;min-height:56px;box-sizing:border-box}.places-list-container.mobile .places-list-header{padding:12px 20px 16px;border-radius:20px 20px 0 0;position:relative;cursor:grab}.places-list-container.mobile .places-list-header:active{cursor:grabbing}.places-list-container.mobile .places-list-header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#ccc;border-radius:2px}.places-list-container.collapsed .places-list-header{padding:16px 12px;justify-content:center}.places-list-title{flex:1;font-weight:500;color:#ffffffe6}.places-list-container.collapsed .places-list-title{display:none}.places-list-toggle{background:none;border:none;color:#ffffffb3;font-size:18px;cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.places-list-toggle:hover{background:#ffffff1a;color:#fff}.toggle-icon{transition:transform .2s ease;font-size:16px}.hamburger-icon{font-size:18px;font-weight:700}.places-list{flex:1;overflow-y:auto;overscroll-behavior:none;background:transparent}.place-item{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s ease;position:relative}.place-item:last-child{border-bottom:none}.place-item:hover{background:#ffffff1a}.place-item:active{background:#fff3}.places-list-container.collapsed .place-item{padding:16px 12px;justify-content:center}.place-item-content{flex:1}.places-list-container.collapsed .place-item-content{display:none}.place-name{font-size:14px;font-weight:500;color:#fffffff2;margin-bottom:4px;line-height:1.4}.place-date{font-size:12px;color:#ffffffb3;margin-bottom:2px}.place-type{font-size:12px;color:var(--color-place-type);font-weight:400}.place-fly-button{font-size:18px;color:#ffffffb3;transition:all .2s ease;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.place-item:hover .place-fly-button{color:#fff;background:#fff3}.places-list-container.collapsed .place-fly-button{font-size:16px;width:36px;height:36px}.places-list::-webkit-scrollbar{width:8px}.places-list::-webkit-scrollbar-track{background:transparent}.places-list::-webkit-scrollbar-thumb{background:#5f63684d;border-radius:4px}.places-list::-webkit-scrollbar-thumb:hover{background:#5f636880}@media(max-width:768px){.places-list-container{inset:auto 0 0!important;height:auto!important;max-height:70vh!important;width:100%!important;border-radius:20px 20px 0 0!important;box-shadow:0 -4px 20px #00000026!important;transform:translateY(100%)!important;transition:transform .3s cubic-bezier(.4,0,.2,1)!important;z-index:1001!important}.places-list-container.visible{transform:translateY(0)!important}.places-list-container.collapsed{transform:translateY(calc(100% - 60px))!important;max-height:60px!important}.places-list-header{padding:12px 20px 16px!important;border-radius:20px 20px 0 0!important;position:relative!important;cursor:grab!important;background:#0006!important;border-bottom:1px solid rgba(255,255,255,.25)!important;color:#ffffffe6!important}.places-list-header:active{cursor:grabbing!important}.places-list-header:before{content:""!important;position:absolute!important;top:8px!important;left:50%!important;transform:translate(-50%)!important;width:40px!important;height:4px!important;background:#ffffff80!important;border-radius:2px!important}.places-list-container .places-list-title{font-weight:600!important;color:#ffffffe6!important}}@media(max-width:768px){.places-list-container:not(.mobile):not(.collapsed){width:280px}.places-list-container:not(.mobile).collapsed{width:56px}.places-list-container:not(.mobile) .places-list-header{padding:12px 16px;font-size:14px;min-height:48px}.places-list-container:not(.mobile).collapsed .places-list-header{padding:12px 8px}.places-list-container:not(.mobile) .places-list-toggle{width:36px;height:36px;font-size:16px}.places-list-container:not(.mobile) .place-item{padding:12px 16px}.places-list-container:not(.mobile).collapsed .place-item{padding:12px 8px}.places-list-container:not(.mobile) .place-name{font-size:13px}.places-list-container:not(.mobile) .place-date{font-size:11px}.places-list-container:not(.mobile) .place-type{font-size:11px}.places-list-container:not(.mobile) .place-fly-button{width:36px;height:36px;font-size:16px}.places-list-container:not(.mobile).collapsed .place-fly-button{width:32px;height:32px;font-size:14px}.places-list-container.mobile .places-list-header{padding:12px 20px 16px;font-size:16px;min-height:60px}.places-list-container.mobile .places-list-toggle{width:40px;height:40px;font-size:18px}.places-list-container.mobile .place-item{padding:16px 20px}.places-list-container.mobile .place-name{font-size:15px}.places-list-container.mobile .place-date,.places-list-container.mobile .place-type{font-size:13px}.places-list-container.mobile .place-fly-button{width:40px;height:40px;font-size:18px}.places-list-container.mobile .places-list{max-height:calc(70vh - 60px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:none}.places-list-container.mobile .place-item{min-height:60px;display:flex;align-items:center}.places-list-container.mobile .place-item-content{flex:1;min-width:0}.places-list-container.mobile .place-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}@media(max-width:480px){.places-list-container:not(.collapsed){width:260px}.places-list-container.collapsed{width:52px}.places-list-header{padding:10px 14px;font-size:13px;min-height:44px}.places-list-container.collapsed .places-list-header{padding:10px 6px}.place-item{padding:10px 14px}.places-list-container.collapsed .place-item{padding:10px 6px}.place-name{font-size:12px}.place-date,.place-type{font-size:10px}}@keyframes rippleEffect{0%{transform:translate(-50%,-50%) scale(1);opacity:.8}to{transform:translate(-50%,-50%) scale(8);opacity:0}}@keyframes sparkleEffect{0%{transform:scale(0) rotate(0);opacity:1}50%{transform:scale(1) rotate(180deg);opacity:1}to{transform:scale(0) rotate(360deg);opacity:0}}.tooltip{position:fixed;top:50px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:10px 20px;border-radius:20px;font-size:16px;z-index:1001;animation:fadeInOut 3s ease forwards}.photo-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.photo-modal{background:#fff;border-radius:12px;max-width:90vw;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0000004d}.photo-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;background:var(--color-surface)}.photo-modal-header h3{margin:0;color:#333;font-size:18px;font-weight:600}.photo-modal-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.photo-modal-close:hover{background-color:#e9ecef;color:#333}.photo-modal-content{padding:0;max-height:calc(90vh - 80px);overflow:auto}.photo-modal-image{width:100%;height:auto;max-height:calc(90vh - 80px);object-fit:contain;display:block}@media(max-width:768px){.photo-modal{max-width:95vw;max-height:95vh}.photo-modal-header{padding:12px 16px}.photo-modal-header h3{font-size:16px}.photo-modal-content,.photo-modal-image{max-height:calc(95vh - 60px)}}.photosphere-modal-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.photosphere-modal{background:#1a1a1a;border-radius:12px;width:90vw;height:90vh;max-width:1200px;max-height:800px;overflow:hidden;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column}.photosphere-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#2a2a2a;border-bottom:1px solid #444;color:#fff}.photosphere-modal-header h3{margin:0;font-size:18px;font-weight:600;color:#fff}.photosphere-controls{display:flex;gap:8px;align-items:center}.photosphere-reset,.photosphere-fullscreen,.photosphere-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;padding:8px 12px;border-radius:6px;font-size:14px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;-webkit-user-select:none;user-select:none;pointer-events:auto;z-index:10001;position:relative}.photosphere-reset:hover,.photosphere-fullscreen:hover{background:#fff3;border-color:#ffffff4d}.photosphere-close{background:#f443;border-color:#ff44444d;font-size:18px;font-weight:700}.photosphere-close:hover{background:#ff44444d;border-color:#ff444480}.photosphere-container{flex:1;position:relative;background:#000;overflow:hidden}#photosphere-canvas{width:100%;height:100%;display:block}.photosphere-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:16px;text-align:center;z-index:10;background:#000000b3;padding:20px 30px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.photosphere-instructions{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:12px 20px;border-radius:20px;font-size:14px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);z-index:10}.photosphere-instructions p{margin:0;opacity:.9}@media(max-width:768px){.photosphere-modal{width:95vw;height:95vh}.photosphere-modal-header{padding:12px 16px}.photosphere-modal-header h3{font-size:16px}.photosphere-controls{gap:6px}.photosphere-reset,.photosphere-fullscreen,.photosphere-close{padding:6px 10px;min-width:32px;height:32px;font-size:12px}.photosphere-instructions{bottom:15px;padding:10px 16px;font-size:12px}}.tooltip{position:fixed;background:#000c;color:#fff;padding:10px 20px;border-radius:20px;font-size:16px;z-index:1001;animation:fadeInOut 3s ease forwards;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);max-width:300px;text-align:center;word-wrap:break-word}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(-20px)}20%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-20px)}}.tooltip[style*="transform: none"]{animation:fadeInOutNoTransform 3s ease forwards}@keyframes fadeInOutNoTransform{0%{opacity:0;transform:translateY(-20px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}
